/* =========================================================================
   Baralu — Aluminier & menuiserie : mise en relation devis gratuits.
   Thème conversion « atelier alu » — taxonomie de classes bra-.
   Palette : graphite #252b33 · graphite foncé #1b2026 · CTA corail #ef4a2c
             alu #8a93a0 · texte #222831 · fond alt #eef1f4 · filet #d8dde3
   ========================================================================= */

:root{
  --bra-graphite:#252b33;
  --bra-graphite-d:#1b2026;
  --bra-graphite-2:#313945;
  --bra-cta:#ef4a2c;
  --bra-cta-d:#d63c20;
  --bra-alu:#8a93a0;
  --bra-texte:#222831;
  --bra-mut:#5c6470;
  --bra-bg:#ffffff;
  --bra-alt:#eef1f4;
  --bra-filet:#d8dde3;
  --bra-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --bra-rampe:1160px;
  --bra-r:2px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:72px;-webkit-text-size-adjust:100%}
body.theme-baralu{
  font-family:var(--bra-sans);
  color:var(--bra-texte);
  background:var(--bra-bg);
  line-height:1.62;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img,iframe{max-width:100%;display:block}
a{color:var(--bra-graphite);text-decoration:none}
a:hover{text-decoration:underline}
ul,ol{list-style:none}

h1,h2,h3,h4{font-family:var(--bra-sans);font-weight:800;line-height:1.18;color:var(--bra-graphite);letter-spacing:-.2px}
p{margin-bottom:.85rem}

.bra-rampe{max-width:var(--bra-rampe);margin:0 auto;padding:0 20px}

.bra-skip{position:absolute;left:-9999px;top:0;background:var(--bra-graphite);color:#fff;padding:12px 18px;z-index:1000}
.bra-skip:focus{left:12px;top:12px}

/* page wrappers (pas de style propre, ancrage seulement) */
.bra-accueil,.bra-phare,.bra-departement,.bra-ville,.bra-generique,.bra-statique,.bra-404{display:block}

/* ---------------------------------------------------------------- en-tête */
.bra-entete{
  position:sticky;top:0;z-index:200;
  background:#fff;
  border-bottom:3px solid var(--bra-cta);
}
.bra-entete .bra-rampe{display:flex;align-items:center;justify-content:space-between;min-height:66px;gap:14px}
.bra-sceau{display:flex;flex-direction:column;line-height:1.12}
.bra-sceau-nom{font-size:22px;font-weight:800;color:var(--bra-graphite);letter-spacing:-.4px}
.bra-sceau-ligne{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--bra-cta);font-weight:700;margin-top:3px}

.bra-voile ul{display:flex;align-items:center;gap:22px}
.bra-liste-nav a{font-size:14.5px;font-weight:600;color:var(--bra-texte);padding:6px 0;border-bottom:2px solid transparent;transition:border-color .16s,color .16s}
.bra-liste-nav a:hover{color:var(--bra-cta);border-bottom-color:var(--bra-cta);text-decoration:none}
.bra-nav-action a{
  background:var(--bra-cta);color:#fff !important;
  padding:10px 20px;border-radius:var(--bra-r);border-bottom:none !important;
  font-size:14px;font-weight:800;
}
.bra-nav-action a:hover{background:var(--bra-cta-d);text-decoration:none}

.bra-bascule{display:none;background:none;border:1px solid var(--bra-filet);border-radius:var(--bra-r);width:46px;height:42px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.bra-bascule span{display:block;width:22px;height:2px;background:var(--bra-graphite);transition:.2s}

/* ---------------------------------------------------------------- hero (fronton/portique) */
.bra-fronton,.bra-portique{
  background:linear-gradient(135deg,var(--bra-graphite-d) 0%,var(--bra-graphite) 55%,var(--bra-graphite-2) 100%);
  color:#eef1f4;
  padding:54px 0;
}
.bra-portique{padding:62px 0}
.bra-fronton h1,.bra-portique h1,
.bra-fronton-h1,.bra-portique-h1{color:#fff}

/* hero 2 colonnes : texte+CTA gauche / image droite */
.bra-heros{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.bra-heros-txt{min-width:0}
.bra-heros-img{
  width:100%;height:auto;aspect-ratio:800/533;
  object-fit:cover;border-radius:var(--bra-r);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 10px 30px rgba(10,14,20,.42);
}

.bra-fil{font-size:13px;color:#aab3c0;margin-bottom:18px}
.bra-fil a{color:#cfd7e2}
.bra-fil a:hover{color:#fff}
.bra-fil span{margin:0 7px;color:#6b7480}
.bra-fil-actif{color:#fff;font-weight:600}

.bra-fronton-sur,.bra-portique-sur{
  display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:1.4px;
  text-transform:uppercase;color:var(--bra-cta);
  background:rgba(239,74,44,.12);border:1px solid rgba(239,74,44,.32);
  padding:6px 14px;border-radius:var(--bra-r);margin-bottom:18px;
}
.bra-fronton-h1{font-size:clamp(1.55rem,3vw,2.3rem);max-width:20ch;margin-bottom:18px}
.bra-portique-h1{font-size:clamp(1.7rem,3.4vw,2.6rem);max-width:18ch;margin-bottom:18px}
.bra-fronton-prix,.bra-portique-desc{font-size:.95rem;color:#cdd5df;max-width:44ch;margin-bottom:26px;line-height:1.5}
.bra-fronton-prix strong{color:#fff}

.bra-fronton-action,.bra-portique-action{
  display:inline-block;background:var(--bra-cta);color:#fff;
  padding:15px 32px;border-radius:var(--bra-r);font-size:15.5px;font-weight:800;
  transition:background .18s,transform .18s;
}
.bra-fronton-action:hover,.bra-portique-action:hover{background:var(--bra-cta-d);transform:translateY(-2px);text-decoration:none}

.bra-portique-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.bra-portique-badges li{
  font-size:13.5px;font-weight:600;color:#dfe4ec;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  padding:8px 16px;border-radius:var(--bra-r);
}
.bra-portique-badges li::before{content:"✓";color:var(--bra-cta);font-weight:800;margin-right:8px}

/* ---------------------------------------------------------------- visuel libre */
.bra-visuel{margin:0}
.bra-visuel-img{
  width:100%;height:auto;aspect-ratio:800/533;object-fit:cover;
  border-radius:var(--bra-r);border:1px solid var(--bra-filet);
}

/* ---------------------------------------------------------------- titres de section */
.bra-section-sur{font-size:12.5px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--bra-cta);margin-bottom:10px}
.bra-section-h2{font-size:clamp(22px,3vw,32px);margin-bottom:30px;max-width:26ch}
.bra-bloc-titre{font-size:clamp(20px,2.6vw,27px);margin-bottom:24px;padding-bottom:12px;border-bottom:2px solid var(--bra-filet);position:relative}
.bra-bloc-titre::after{content:"";position:absolute;left:0;bottom:-2px;width:56px;height:2px;background:var(--bra-cta)}

/* ---------------------------------------------------------------- métiers (cartes services) */
.bra-metiers{padding:56px 0;background:var(--bra-alt)}
.bra-metiers-grille{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}
.bra-metier{
  background:#fff;border:1px solid var(--bra-filet);border-radius:var(--bra-r);
  padding:24px 22px;display:flex;flex-direction:column;gap:8px;color:var(--bra-texte);
  transition:border-color .16s,box-shadow .16s,transform .16s;
}
.bra-metier:hover{border-color:var(--bra-cta);box-shadow:0 8px 22px rgba(37,43,51,.12);transform:translateY(-3px);text-decoration:none}
.bra-metier-img{
  width:calc(100% + 44px);height:auto;aspect-ratio:800/533;object-fit:cover;
  margin:-24px -22px 14px;border-bottom:1px solid var(--bra-filet);
}
.bra-metier-icon{font-size:28px;line-height:1}
.bra-metier-nom{font-size:18px;font-weight:800;color:var(--bra-graphite)}
.bra-metier-desc{font-size:14.5px;color:var(--bra-mut);line-height:1.55;flex:1}
.bra-metier-fleche{margin-top:6px;font-size:13px;font-weight:700;color:var(--bra-cta)}

/* ---------------------------------------------------------------- démarche (3 étapes) */
.bra-demarche{padding:60px 0;background:var(--bra-graphite);color:#eef1f4}
.bra-demarche .bra-section-sur{color:var(--bra-cta)}
.bra-demarche .bra-section-h2{color:#fff}
.bra-demarche-suite{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bra-demarche-suite li{background:var(--bra-graphite-2);border:1px solid rgba(255,255,255,.08);border-radius:var(--bra-r);padding:28px 26px}
.bra-demarche-num{font-size:34px;font-weight:800;color:var(--bra-cta);display:block;margin-bottom:10px}
.bra-demarche-t{font-size:18px;font-weight:800;color:#fff;margin-bottom:6px}
.bra-demarche-x{font-size:14.5px;color:#c2c9d3;line-height:1.62;margin:0}

/* ---------------------------------------------------------------- récit (intro + fiche) */
.bra-recit{padding:54px 0}
.bra-recit-cadre{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.bra-recit-prose p{font-size:17px;line-height:1.78;color:#3a414c}
.bra-recit-fiche{border:1px solid var(--bra-filet);background:var(--bra-alt);padding:26px 24px;border-radius:var(--bra-r);border-top:4px solid var(--bra-cta)}
.bra-recit-fiche-t{font-size:18px;font-weight:800;color:var(--bra-graphite);padding-bottom:14px;margin-bottom:16px;border-bottom:1px solid var(--bra-filet)}
.bra-recit-fiche dl{display:grid;grid-template-columns:1fr;gap:13px;margin-bottom:22px}
.bra-recit-fiche dt{font-size:11.5px;letter-spacing:1px;text-transform:uppercase;color:var(--bra-alu);font-weight:700;margin-bottom:2px}
.bra-recit-fiche dd{font-size:15px;color:var(--bra-texte)}
.bra-recit-fiche-lien{display:block;text-align:center;background:var(--bra-cta);color:#fff;padding:13px;border-radius:var(--bra-r);font-size:14.5px;font-weight:800;transition:background .18s}
.bra-recit-fiche-lien:hover{background:var(--bra-cta-d);text-decoration:none}

/* ---------------------------------------------------------------- atelier (formulaire VUD) */
.bra-atelier{padding:56px 0;background:var(--bra-graphite);color:#eef1f4;overflow-x:hidden}
.bra-atelier-bloc{max-width:820px;margin:0 auto;text-align:center}
.bra-atelier-sur{font-size:12.5px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--bra-cta);margin-bottom:12px}
.bra-atelier-titre{font-size:clamp(22px,3vw,32px);color:#fff;margin-bottom:14px}
.bra-atelier-desc{font-size:16px;color:#c8cfd9;line-height:1.72;margin:0 auto 22px;max-width:62ch}
.bra-atelier-form{background:#fff;color:var(--bra-texte);border-radius:var(--bra-r);padding:22px;min-height:220px;box-shadow:0 12px 34px rgba(10,14,20,.34);text-align:left;max-width:100%;overflow-x:auto}
.bra-atelier-form>div{max-width:100%}
.bra-atelier-form iframe{width:100%;max-width:100%!important;border:0}

/* ---------------------------------------------------------------- savoir-faire (H3 blocs) */
.bra-savoir{padding:54px 0}
.bra-savoir-volet{max-width:860px;padding:26px 0;border-bottom:1px solid var(--bra-filet)}
.bra-savoir-volet:last-child{border-bottom:none}
.bra-savoir-h3{font-size:21px;font-weight:800;margin-bottom:12px;color:var(--bra-graphite)}
.bra-savoir-h3::before{content:"";display:inline-block;width:28px;height:3px;background:var(--bra-cta);vertical-align:middle;margin-right:14px;border-radius:2px}
.bra-savoir-volet p{font-size:16px;color:#43474f;line-height:1.74}

/* ---------------------------------------------------------------- annuaire entreprises */
.bra-annuaire{padding:54px 0;background:var(--bra-alt)}
.bra-annuaire-grille{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px}
.bra-annuaire-fiche{border:1px solid var(--bra-filet);border-left:4px solid var(--bra-cta);padding:20px 22px;border-radius:var(--bra-r);background:#fff}
.bra-annuaire-nom{font-size:17px;font-weight:800;color:var(--bra-graphite);margin-bottom:6px}
.bra-annuaire-ligne{font-size:14px;color:var(--bra-mut);margin-bottom:3px}
.bra-annuaire-note{font-size:13.5px;color:var(--bra-cta);font-weight:700;margin-top:7px}

/* ---------------------------------------------------------------- carte */
.bra-carte{padding:54px 0}
.bra-carte-vitre{border:1px solid var(--bra-filet);border-radius:var(--bra-r);overflow:hidden}
.bra-carte-vitre iframe{width:100%;height:360px;border:0}

/* ---------------------------------------------------------------- avis */
.bra-avis{padding:54px 0;background:var(--bra-alt)}
.bra-avis-rang{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bra-avis-carte{border:1px solid var(--bra-filet);padding:24px 22px;border-radius:var(--bra-r);background:#fff;display:flex;flex-direction:column;gap:12px}
.bra-avis-etoiles{color:var(--bra-cta);font-size:16px;letter-spacing:2px}
.bra-avis-carte blockquote{font-size:15.5px;color:#3a414c;line-height:1.66;flex:1}
.bra-avis-carte figcaption{font-size:13px;font-weight:700;color:var(--bra-mut)}

/* ---------------------------------------------------------------- faq */
.bra-faq{padding:54px 0}
.bra-faq-pile{max-width:860px;border-top:1px solid var(--bra-filet)}
.bra-faq-item{border-bottom:1px solid var(--bra-filet)}
.bra-faq-item summary{cursor:pointer;list-style:none;padding:20px 44px 20px 0;font-size:17px;font-weight:700;color:var(--bra-graphite);position:relative}
.bra-faq-item summary::-webkit-details-marker{display:none}
.bra-faq-item summary::after{content:"+";position:absolute;right:6px;top:18px;font-size:22px;color:var(--bra-cta);transition:transform .2s}
.bra-faq-item[open] summary::after{content:"–"}
.bra-faq-rep{padding:0 0 22px}
.bra-faq-rep p{font-size:15.5px;color:#4c515b;line-height:1.74;margin:0}

/* ---------------------------------------------------------------- liens / maillage */
.bra-liens{padding:54px 0}
.bra-liens-cadre{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.bra-liens-col{min-width:0}
.bra-liens-titre{font-size:19px;font-weight:800;margin-bottom:18px;padding-bottom:11px;border-bottom:2px solid var(--bra-filet);color:var(--bra-graphite)}
.bra-liens-liste li{border-bottom:1px solid var(--bra-filet)}
.bra-liens-liste a{display:block;padding:12px 0;font-size:14.5px;color:#43474f;transition:color .16s,padding .16s}
.bra-liens-liste a:hover{color:var(--bra-cta);padding-left:8px;text-decoration:none}
.bra-liens-large{columns:2;column-gap:44px}
.bra-liens-large li{break-inside:avoid}

/* ---------------------------------------------------------------- villes / territoires */
.bra-villes,.bra-territoires{padding:54px 0}
.bra-territoires{background:var(--bra-alt)}
.bra-villes-grille,.bra-territoires-grille{columns:3;column-gap:34px}
.bra-villes-grille li,.bra-territoires-grille li{break-inside:avoid;border-bottom:1px solid var(--bra-filet)}
.bra-villes-grille a,.bra-territoires-grille a{display:block;padding:11px 0;font-size:14px;color:#43474f;transition:.16s}
.bra-villes-grille a:hover,.bra-territoires-grille a:hover{color:var(--bra-cta);padding-left:6px;text-decoration:none}

/* ---------------------------------------------------------------- plan / légal */
.bra-plan{padding:48px 0}
.bra-plan-section{margin-bottom:44px}
.bra-legal{padding:48px 0}
.bra-legal-prose{max-width:820px}
.bra-legal-prose h2{font-size:21px;font-weight:800;margin:34px 0 12px;color:var(--bra-graphite)}
.bra-legal-prose h2:first-child{margin-top:0}
.bra-legal-prose p{font-size:16px;color:#43474f;line-height:1.76;margin-bottom:13px}

/* ---------------------------------------------------------------- rappel CTA */
.bra-rappel{padding:56px 0;background:var(--bra-cta)}
.bra-rappel .bra-rampe{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.bra-rappel-txt{font-size:21px;font-weight:800;color:#fff;max-width:60ch;margin:0}
.bra-rappel-action{
  display:inline-block;background:#fff;color:var(--bra-cta);
  padding:15px 32px;border-radius:var(--bra-r);font-size:15px;font-weight:800;
  white-space:nowrap;transition:background .18s,color .18s;
}
.bra-rappel-action:hover{background:var(--bra-graphite);color:#fff;text-decoration:none}

/* ---------------------------------------------------------------- trame footer (maillage TOP20) */
.bra-trame{padding:52px 0;background:var(--bra-alt);border-top:1px solid var(--bra-filet)}
.bra-trame-titre{font-size:22px;font-weight:800;margin-bottom:24px;padding-bottom:11px;border-bottom:2px solid var(--bra-filet);color:var(--bra-graphite)}
.bra-trame-grille{columns:4;column-gap:28px}
.bra-trame-grille li{break-inside:avoid;margin-bottom:2px}
.bra-trame-grille a{display:block;padding:8px 0;font-size:13.5px;color:#54585f;transition:.16s}
.bra-trame-grille a:hover{color:var(--bra-cta);text-decoration:none}

/* ---------------------------------------------------------------- socle (footer) */
.bra-socle{background:var(--bra-graphite-d);color:#aeb6c1;padding:52px 0 0}
.bra-socle-grille{display:grid;grid-template-columns:2fr 1fr 1fr;gap:42px;padding-bottom:38px}
.bra-socle-bloc{min-width:0}
.bra-socle-marque{font-size:21px;font-weight:800;color:#fff;margin-bottom:12px}
.bra-socle-note{font-size:13.5px;line-height:1.68;color:#8d96a3;max-width:46ch}
.bra-socle-titre{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;color:var(--bra-cta);font-weight:700;margin-bottom:16px}
.bra-socle-liens li{margin-bottom:10px}
.bra-socle-liens a{font-size:14px;color:#aeb6c1;transition:color .16s}
.bra-socle-liens a:hover{color:#fff;text-decoration:none}
.bra-socle-bas{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;padding-bottom:28px}
.bra-socle-bas p{font-size:13px;color:#79818d;margin:0}

/* ---------------------------------------------------------------- émergence (popup sortie) */
.bra-emergence{position:fixed;inset:0;background:rgba(20,24,30,.74);display:none;align-items:center;justify-content:center;z-index:900;padding:24px}
.bra-emergence.bra-visible{display:flex;animation:bra-fade .22s ease}
@keyframes bra-fade{from{opacity:0}to{opacity:1}}
.bra-emergence-vitre{background:#fff;border-radius:var(--bra-r);max-width:430px;width:100%;padding:38px 34px;position:relative;border-top:5px solid var(--bra-cta)}
.bra-emergence-fermer{position:absolute;top:12px;right:16px;background:none;border:none;font-size:26px;color:var(--bra-alu);cursor:pointer;line-height:1}
.bra-emergence-fermer:hover{color:var(--bra-graphite)}
.bra-emergence-sur{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;color:var(--bra-cta);font-weight:700;margin-bottom:10px}
.bra-emergence-titre{font-size:23px;font-weight:800;color:var(--bra-graphite);margin-bottom:10px}
.bra-emergence-txt{font-size:15px;color:#4c515b;line-height:1.66;margin-bottom:22px}
.bra-emergence-action{display:inline-block;background:var(--bra-cta);color:#fff;padding:14px 28px;border-radius:var(--bra-r);font-size:14.5px;font-weight:800;transition:background .18s}
.bra-emergence-action:hover{background:var(--bra-cta-d);text-decoration:none}

/* ---------------------------------------------------------------- 404 */
.bra-404 .bra-fronton{padding-bottom:60px}

/* ---------------------------------------------------------------- responsive */
@media (max-width:860px){
  .bra-rampe{padding:0 16px}
  .bra-bascule{display:flex}
  .bra-voile{
    position:fixed;inset:66px 0 auto 0;background:#fff;
    border-bottom:3px solid var(--bra-cta);
    transform:translateY(-130%);transition:transform .24s ease;
    max-height:calc(100vh - 66px);overflow:auto;
  }
  body.bra-menu-ouvert .bra-voile{transform:translateY(0)}
  body.bra-menu-ouvert{overflow:hidden}
  .bra-voile ul{flex-direction:column;align-items:stretch;gap:0;padding:12px 16px}
  .bra-liste-nav li{border-bottom:1px solid var(--bra-filet)}
  .bra-liste-nav a{display:block;padding:15px 0}
  .bra-nav-action{margin-top:12px}
  .bra-nav-action a{display:block;text-align:center}

  .bra-heros{grid-template-columns:1fr;gap:28px}
  .bra-heros-img{order:2}
  .bra-recit-cadre,.bra-atelier-cadre,.bra-liens-cadre{grid-template-columns:1fr;gap:34px}
  .bra-demarche-suite{grid-template-columns:1fr}
  .bra-avis-rang{grid-template-columns:1fr}
  .bra-villes-grille,.bra-territoires-grille,.bra-trame-grille{columns:2}
  .bra-liens-large{columns:1}
  .bra-socle-grille{grid-template-columns:1fr;gap:30px}
  .bra-rappel .bra-rampe{flex-direction:column;align-items:flex-start}
  .bra-fronton,.bra-portique{padding:42px 0}
}
@media (max-width:540px){
  .bra-villes-grille,.bra-territoires-grille,.bra-trame-grille{columns:1}
  .bra-metiers-grille{grid-template-columns:1fr}
  .bra-fronton-action,.bra-portique-action,.bra-rappel-action{display:block;text-align:center}
}
