/* ==========================================================================
   FOCOM Grand Sud-Est — Feuille de styles principale
   Charte « système fédéral, accent régional »
   ========================================================================== */

/* ---------- Polices ---------- */
@font-face { font-family:"Barlow"; src:url(../fonts/Barlow-Regular.ttf) format("truetype"); font-weight:400; font-display:swap; }
@font-face { font-family:"Barlow"; src:url(../fonts/Barlow-Medium.ttf) format("truetype"); font-weight:500; font-display:swap; }
@font-face { font-family:"Barlow"; src:url(../fonts/Barlow-SemiBold.ttf) format("truetype"); font-weight:600; font-display:swap; }
@font-face { font-family:"Barlow"; src:url(../fonts/Barlow-Bold.ttf) format("truetype"); font-weight:700; font-display:swap; }
@font-face { font-family:"Source Sans 3"; src:url(../fonts/SourceSans3.ttf) format("truetype"); font-weight:400 700; font-display:swap; }

/* ---------- Variables ---------- */
:root{
  --rouge:#E2001A;
  --rouge-fonce:#B80016;
  --bleu:#003D5C;
  --bleu-clair:#0a5278;
  --ambre:#F39200;
  --anthracite:#1D1D1B;
  --perle:#F4F5F7;
  --gris:#5f6b73;
  --blanc:#ffffff;
  --bordure:#e3e7ea;

  --font-titre:"Barlow", "Trebuchet MS", sans-serif;
  --font-texte:"Source Sans 3", "Segoe UI", sans-serif;

  --largeur:1180px;
  --rayon:8px;
  --rayon-lg:14px;
  --transition:.2s ease;
  --ombre:0 2px 14px rgba(0,61,92,.08);
}

/* ---------- Base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family:var(--font-texte); color:var(--anthracite);
  font-size:17px; line-height:1.65; background:var(--blanc);
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--bleu); text-decoration:none; transition:color var(--transition); }
a:hover,a:focus{ color:var(--rouge); }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:3px solid var(--ambre); outline-offset:2px;
}
h1,h2,h3,h4,h5{ font-family:var(--font-titre); font-weight:600; color:var(--bleu); line-height:1.15; margin:0 0 .5em; }
h1{ font-size:2.4rem; font-weight:700; }
h2{ font-size:1.85rem; }
h3{ font-size:1.35rem; }
p{ margin:0 0 1em; }
.container{ width:100%; max-width:var(--largeur); margin:0 auto; padding:0 24px; }

/* Skip link */
.skip-link{ position:absolute; left:-9999px; top:0; }
.skip-link:focus{ left:8px; top:8px; z-index:100000; }

/* ---------- Motif relief ---------- */
.relief{ display:block; width:100%; height:14px; line-height:0; }
.relief svg{ display:block; width:100%; height:14px; }

/* ---------- Barre supérieure ---------- */
.topbar{ background:var(--anthracite); color:#cfd6da; font-size:.82rem; }
.topbar .container{ display:flex; justify-content:space-between; align-items:center; min-height:34px; gap:16px; }
.topbar a{ color:#cfd6da; }
.topbar a:hover{ color:var(--blanc); }
.topbar .social a{ margin-left:12px; font-weight:600; }

/* ---------- En-tête / bloc-marque ---------- */
.site-header{ background:var(--bleu); color:var(--blanc); position:sticky; top:0; z-index:900; }
.header-inner{ display:flex; align-items:center; gap:18px; padding:14px 0; }
.brand{ display:flex; align-items:center; gap:16px; text-decoration:none; }
.brand .logo{ width:60px; height:60px; flex-shrink:0; }
.brand .logo img{ width:100%; height:100%; }
.brand .divider{ width:1px; align-self:stretch; background:rgba(255,255,255,.28); }
.brand .terr .t1{ font-family:var(--font-titre); font-weight:700; font-size:1.25rem; color:var(--blanc); line-height:1; letter-spacing:.3px; white-space:nowrap; }
.brand .terr .t2{ font-size:.74rem; letter-spacing:1.5px; color:rgba(255,255,255,.7); margin-top:4px; text-transform:uppercase; }
/* Déclinaison entité « Orange » : titres empilés + ligne d'entité en ambre */
.brand .terr{ display:flex; flex-direction:column; justify-content:center; }
.brand .terr .t0{ font-family:var(--font-titre); font-weight:600; font-size:1.875rem; line-height:1.05; color:var(--ambre); }
.brand .terr .t1{ margin-top:2px; }
.brand .logo{ width:72px; height:72px; }   /* logo agrandi pour la maquette Orange */
.header-spacer{ flex:1; }

/* CTA J'adhère */
.btn-adhere{
  background:var(--rouge); color:var(--blanc); font-family:var(--font-titre); font-weight:600;
  padding:11px 20px; border-radius:var(--rayon); font-size:.98rem; white-space:nowrap;
  transition:background var(--transition), transform var(--transition);
}
.btn-adhere:hover,.btn-adhere:focus{ background:var(--rouge-fonce); color:var(--blanc); transform:translateY(-1px); }

/* ---------- Navigation ---------- */
.main-nav{ background:var(--bleu-clair); }
.main-nav .container{ display:flex; align-items:center; }
.menu-toggle{ display:none; }
.nav-menu{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; }
.nav-menu li{ position:relative; }
.nav-menu a{
  display:block; color:var(--blanc); font-family:var(--font-titre); font-weight:500;
  padding:14px 18px; font-size:1rem; border-bottom:3px solid transparent;
}
.nav-menu a:hover, .nav-menu .current-menu-item > a, .nav-menu .current_page_item > a{
  color:var(--blanc); border-bottom-color:var(--ambre); background:rgba(255,255,255,.06);
}
/* sous-menus */
.nav-menu ul{ list-style:none; margin:0; padding:0; position:absolute; left:0; top:100%; min-width:230px;
  background:var(--bleu); box-shadow:var(--ombre); display:none; z-index:950; }
.nav-menu li:hover > ul, .nav-menu li:focus-within > ul{ display:block; }
.nav-menu ul a{ padding:11px 18px; border-bottom:1px solid rgba(255,255,255,.08); }
.nav-menu ul a:hover{ border-bottom-color:rgba(255,255,255,.08); background:var(--bleu-clair); }

/* ---------- Hero accueil ---------- */
.hero{ background:var(--bleu); color:var(--blanc); position:relative; overflow:hidden; }
.hero::after{ content:""; position:absolute; right:-80px; bottom:-80px; width:340px; height:340px;
  border-radius:50%; background:rgba(243,146,0,.10); }
.hero .container{ position:relative; z-index:2; padding:64px 24px; max-width:860px; }
.hero .eyebrow{ font-family:var(--font-titre); font-weight:600; letter-spacing:2px; text-transform:uppercase;
  color:var(--ambre); font-size:.85rem; margin-bottom:12px; }
.hero h1{ color:var(--blanc); font-size:2.9rem; margin-bottom:14px; }
.hero p{ font-size:1.25rem; color:rgba(255,255,255,.9); max-width:640px; }
.hero .actions{ margin-top:26px; display:flex; gap:14px; flex-wrap:wrap; }
.btn{ display:inline-block; font-family:var(--font-titre); font-weight:600; padding:13px 26px;
  border-radius:var(--rayon); transition:all var(--transition); border:2px solid transparent; cursor:pointer; }
.btn-primary{ background:var(--rouge); color:var(--blanc); }
.btn-primary:hover{ background:var(--rouge-fonce); color:var(--blanc); }
.btn-ghost{ background:transparent; color:var(--blanc); border-color:rgba(255,255,255,.5); }
.btn-ghost:hover{ background:var(--blanc); color:var(--bleu); }

/* ---------- Sections ---------- */
.section{ padding:56px 0; }
.section.alt{ background:var(--perle); }
.section-head{ max-width:760px; margin:0 auto 36px; text-align:center; }
.section-head .eyebrow{ font-family:var(--font-titre); font-weight:600; letter-spacing:2px;
  text-transform:uppercase; color:var(--ambre); font-size:.82rem; }
.section-head h2{ margin:.2em 0; }

/* Cartes thématiques */
.grid{ display:grid; gap:22px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.card{ background:var(--blanc); border:1px solid var(--bordure); border-radius:var(--rayon-lg);
  padding:24px; box-shadow:var(--ombre); transition:transform var(--transition), box-shadow var(--transition); }
.card:hover{ transform:translateY(-3px); box-shadow:0 8px 26px rgba(0,61,92,.13); }
.card h3{ margin-top:0; }
.card .icon{ width:46px; height:46px; border-radius:10px; background:var(--perle); display:flex;
  align-items:center; justify-content:center; margin-bottom:14px; color:var(--bleu); font-size:1.4rem; }
.card .more{ font-family:var(--font-titre); font-weight:600; color:var(--rouge); display:inline-block; margin-top:8px; }

/* badge national/local */
.badge{ display:inline-block; font-family:var(--font-titre); font-weight:600; font-size:.72rem;
  padding:3px 10px; border-radius:20px; letter-spacing:.3px; }
.badge-national{ background:#e7eef3; color:var(--bleu); }
.badge-local{ background:#fff1e0; color:#9a5b00; }

/* ---------- Actualités / articles ---------- */
.post-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.post-card{ background:var(--blanc); border:1px solid var(--bordure); border-radius:var(--rayon-lg);
  overflow:hidden; box-shadow:var(--ombre); display:flex; flex-direction:column; }
.post-card .thumb{ aspect-ratio:16/9; background:var(--perle); overflow:hidden; }
.post-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.post-card .body{ padding:20px; flex:1; display:flex; flex-direction:column; }
.post-card .meta{ font-size:.8rem; color:var(--gris); margin-bottom:8px; text-transform:uppercase; letter-spacing:.5px; }
.post-card h3{ font-size:1.2rem; margin:0 0 10px; }
.post-card h3 a{ color:var(--bleu); }
.post-card h3 a:hover{ color:var(--rouge); }
.post-card .excerpt{ color:#444; font-size:.96rem; flex:1; }
.post-card .more{ margin-top:14px; font-family:var(--font-titre); font-weight:600; color:var(--rouge); }

/* article seul */
.entry{ max-width:780px; margin:0 auto; padding:48px 24px; }
.entry-header h1{ margin-bottom:10px; }
.entry-meta{ color:var(--gris); font-size:.92rem; margin-bottom:24px; }
.entry-content{ font-size:1.08rem; }
.entry-content h2{ margin-top:1.4em; }
.entry-content img{ border-radius:var(--rayon); margin:1.2em 0; }
.entry-content blockquote{ border-left:4px solid var(--ambre); margin:1.2em 0; padding:6px 0 6px 20px;
  color:#444; font-style:italic; }
.entry-content a{ text-decoration:underline; }

/* ---------- Tracts ---------- */
.tract-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.tract-item{ display:flex; gap:16px; align-items:center; background:var(--blanc); border:1px solid var(--bordure);
  border-radius:var(--rayon); padding:16px 18px; transition:border-color var(--transition); }
.tract-item:hover{ border-color:var(--ambre); }
.tract-item .ext{ width:48px; height:48px; flex-shrink:0; border-radius:8px; background:var(--rouge); color:#fff;
  display:flex; align-items:center; justify-content:center; font-family:var(--font-titre); font-weight:700; font-size:.78rem; }
.tract-item .info h3{ margin:0 0 3px; font-size:1.05rem; }
.tract-item .info .meta{ font-size:.82rem; color:var(--gris); }

/* ---------- Formulaires ---------- */
.form-card{ max-width:680px; margin:0 auto; background:var(--blanc); border:1px solid var(--bordure);
  border-radius:var(--rayon-lg); padding:32px; box-shadow:var(--ombre); }
.form-row{ margin-bottom:18px; }
.form-row label{ display:block; font-family:var(--font-titre); font-weight:600; color:var(--bleu); margin-bottom:6px; }
.form-row .req{ color:var(--rouge); }
.form-row input[type=text], .form-row input[type=email], .form-row input[type=tel],
.form-row select, .form-row textarea{
  width:100%; padding:12px 14px; border:1px solid var(--bordure); border-radius:var(--rayon);
  font-family:var(--font-texte); font-size:1rem; background:#fff; transition:border-color var(--transition);
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus{ border-color:var(--bleu); }
.form-row textarea{ min-height:130px; resize:vertical; }
.form-consent{ display:flex; gap:10px; align-items:flex-start; background:var(--perle);
  padding:14px 16px; border-radius:var(--rayon); border-left:3px solid var(--ambre); font-size:.92rem; }
.form-consent input{ margin-top:4px; }
.form-honeypot{ position:absolute; left:-9999px; }
.form-note{ font-size:.85rem; color:var(--gris); margin-top:6px; }
.form-message{ padding:14px 18px; border-radius:var(--rayon); margin-bottom:22px; font-weight:600; }
.form-message.ok{ background:#e7f6ea; color:#1e7a33; border:1px solid #bfe3c5; }
.form-message.err{ background:#fbecec; color:#b22; border:1px solid #f0c7c7; }

/* ---------- Encadrés ---------- */
.callout{ background:var(--perle); border-left:4px solid var(--ambre); padding:16px 20px;
  border-radius:0 var(--rayon) var(--rayon) 0; margin:1.4em 0; }
.callout.alert{ background:#fbecec; border-left-color:var(--rouge); }

/* ---------- Pied de page ---------- */
.site-footer{ background:var(--bleu); color:#cfd9e0; margin-top:40px; }
.footer-relief{ height:14px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; padding:48px 0 36px; }
.footer-grid h4{ color:var(--blanc); font-size:1.05rem; margin-bottom:14px; }
.footer-brand .terr .t1{ font-family:var(--font-titre); font-weight:700; color:#fff; font-size:1.15rem; }
.footer-brand p{ color:#aebecb; font-size:.92rem; max-width:320px; }
.footer-grid ul{ list-style:none; margin:0; padding:0; }
.footer-grid ul li{ margin-bottom:8px; }
.footer-grid ul a{ color:#cfd9e0; font-size:.95rem; }
.footer-grid ul a:hover{ color:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding:18px 0; font-size:.85rem; color:#9fb2c0;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.footer-bottom a{ color:#9fb2c0; }
.footer-bottom a:hover{ color:#fff; }

/* ---------- Fil d'Ariane & pagination ---------- */
.breadcrumb{ background:var(--perle); font-size:.86rem; color:var(--gris); }
.breadcrumb .container{ padding:10px 24px; }
.breadcrumb a{ color:var(--bleu); }
.pagination{ display:flex; gap:8px; justify-content:center; margin:36px 0; flex-wrap:wrap; }
.pagination .page-numbers{ display:inline-block; padding:9px 15px; border:1px solid var(--bordure);
  border-radius:var(--rayon); font-family:var(--font-titre); font-weight:600; color:var(--bleu); }
.pagination .current{ background:var(--bleu); color:#fff; border-color:var(--bleu); }
.pagination a:hover{ background:var(--ambre); color:#fff; border-color:var(--ambre); }

/* ---------- Page contenu générique ---------- */
.page-hero{ background:var(--bleu); color:#fff; padding:42px 0; }
.page-hero h1{ color:#fff; margin:0; }
.page-hero .lead{ color:rgba(255,255,255,.85); font-size:1.15rem; max-width:680px; margin-top:8px; }
.page-body{ max-width:820px; margin:0 auto; padding:44px 24px; font-size:1.06rem; }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .grid-3,.post-list{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .tract-list{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  h1{ font-size:1.9rem; } .hero h1{ font-size:2.1rem; }
  .grid-3,.grid-2,.post-list,.footer-grid{ grid-template-columns:1fr; }
  .header-inner{ flex-wrap:wrap; gap:12px; }
  .brand .terr .t1{ font-size:1.05rem; }
  .brand .terr .t0{ font-size:1.4rem; }
  .brand .logo{ width:58px; height:58px; }
  .topbar{ display:none; }

  /* menu mobile */
  .menu-toggle{ display:inline-flex; align-items:center; gap:8px; margin-left:auto;
    background:transparent; border:2px solid rgba(255,255,255,.5); color:#fff;
    font-family:var(--font-titre); font-weight:600; padding:9px 14px; border-radius:var(--rayon); cursor:pointer; }
  .main-nav .container{ display:block; padding:0; }
  .nav-menu{ flex-direction:column; display:none; }
  .nav-menu.is-open{ display:flex; }
  .nav-menu a{ padding:14px 24px; border-bottom:1px solid rgba(255,255,255,.1); }
  .nav-menu ul{ position:static; box-shadow:none; display:block; background:rgba(0,0,0,.15); }
}

/* ---------- Préférences de mouvement ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}
