/* Handi-Link – mini site vitrine
   Palette (depuis la brochure) :
   --teal: #167a79
   --mustard: #f6b334
   --orange: #ef7c2a
   --cream: #fff6e7
*/
:root{
  --teal:#167a79;
  --teal-2:#116564;
  --teal-3:#488E86;
  --mustard:#F1BA37;
  --orange:#E1832F;
  --cream:#fff6e7;
  --ink:#203036;
  --ink-soft:#38535b;
  --bg:#fbfbfb;
  --radius:14px;
  --shadow:0 10px 25px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
}

.container{width:min(1100px, 92vw); margin:auto}

header.site-header{
  position:sticky; top:0; z-index:10;
  background:linear-gradient(0deg, rgba(255,255,255,.6), rgba(255,255,255,.9));
  backdrop-filter: blur(8px);
  border-bottom:1px solid #e9ecef;
}
.nav{
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:.75rem 0;
}
.brand{
  display:flex; align-items:center; gap:.75rem; text-decoration:none; color:var(--ink);
}
.brand img{width:38px; height:38px}
.brand b{font-weight:800; letter-spacing:.2px}
.brand small{display:block; color:var(--ink-soft); margin-top:-4px; font-weight:500}

nav ul{list-style:none; display:flex; gap:1rem; margin:0; padding:0}
nav a{color:var(--ink); text-decoration:none; font-weight:600; padding:.5rem .75rem; border-radius:10px}
nav a:hover{background:#eef6f6}

.btn{display:inline-flex; align-items:center; gap:.5rem; font-weight:700;
  text-decoration:none; color:#103; background:var(--mustard);
  border-radius:999px; padding:.8rem 1.1rem; box-shadow:var(--shadow); border:0; cursor:pointer}
.btn:hover{filter:brightness(.95)}
.btn.secondary{background:var(--teal); color:white}
.btn.ghost{background:transparent; border:2px solid var(--teal); color:var(--teal)}

.hero{
  background:
    radial-gradient(1200px 300px at 50% 0%, rgba(22,122,121,.12), transparent 70%),
    linear-gradient(180deg, var(--cream), #fff);
  padding:clamp(2rem, 5vw, 4rem) 0 2rem;
}
.hero .grid{display:grid; grid-template-columns:1.05fr .95fr; gap:2rem; align-items:center}
.hero h1{font-size: clamp(1.8rem, 3.6vw, 3rem); line-height:1.2; margin:.2rem 0}
.hero p{font-size:1.05rem; color:var(--ink-soft)}
.hero .pill{
  display:inline-block; background:var(--teal); color:white; padding:.35rem .7rem; border-radius:999px; font-weight:700; font-size:.9rem
}
.badge{
  display:inline-flex; align-items:center; gap:.35rem; font-weight:800; color:var(--teal);
  background:#e6f4f4; padding:.35rem .6rem; border-radius:999px; border:1px solid #cde8e7
}
.badge .pct{background:var(--mustard); color:#231f20; padding:.2rem .45rem; border-radius:999px}

.hero-card{
  background:white; border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden;
}
.hero-card img{display:block; width:100%; height:auto}
.hero-card .caption{padding:1rem; font-size:.95rem; color:var(--ink-soft)}

.section{padding:3.5rem 0}
.section h2{font-size: clamp(1.4rem, 2.6vw, 2rem); margin:0 0 1rem}
.lead{font-size:1.05rem; color:var(--ink-soft); margin-top:.5rem}


.cards{display:grid; grid-template-columns:repeat(12, 1fr); gap:1rem; margin-top:1.25rem}
.card{
  grid-column: span 6; background:white; border-radius:var(--radius); box-shadow:var(--shadow);
  padding:1.1rem; border:1px solid #eef1f2; position:relative;
}
.card .icon{width:30px; height:30px}
.card h3{margin:.4rem 0 .25rem}
.card p{margin:0; color:var(--ink-soft)}

.card.accent{border:2px solid var(--mustard);}
.card .tag{position:absolute; top:12px; right:12px; font-size:.8rem; background:var(--mustard); padding:.25rem .5rem; border-radius:6px; font-weight:800}

.split{display:grid; grid-template-columns: 1fr 1fr; gap:2rem; align-items:center}

.list-plus{margin:.6rem 0 0; padding:0; list-style:none}
.list-plus li{padding-left:1.7rem; position:relative; margin:.6rem 0}
.list-plus li:before{
  content:"+"; position:absolute; left:0; top:-1px; color:var(--orange); font-weight:900; font-size:1.2rem
}

.domains{display:grid; grid-template-columns:repeat(2, 1fr); gap:1rem}
.domain{background:white; border-radius:var(--radius); box-shadow:var(--shadow); padding:1rem; border:1px solid #eef1f2}
.domain h4{margin:.2rem 0 .25rem}
.domain small{color:var(--ink-soft)}

.cta{background: linear-gradient(180deg, #fff, var(--cream)); border-top:1px solid #eee; border-bottom:1px solid #eee}
.cta .wrap{display:flex; gap:1rem; flex-wrap:wrap; align-items:center; justify-content:space-between}

.contact{background:white; border-radius:var(--radius); box-shadow:var(--shadow); padding:1.25rem; border:1px solid #e9ecef}
form .row{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
input, textarea{width:100%; padding:.85rem 1rem; border:1.5px solid #d7e3e3; border-radius:10px; font:inherit}
textarea{min-height:130px; resize:vertical}
label{display:block; font-weight:700; margin:.75rem 0 .35rem}
.required{color:var(--orange)}

footer{background:var(--teal-3); color:#cde8e7; padding:2.2rem 0; margin-top:2rem}
footer a{color:#fff; text-decoration:none}
footer .foot-grid{display:grid; grid-template-columns:1.2fr .8fr .8fr; gap:1rem}
small.disclaimer{display:block; margin-top:1rem; color:#a9c7c6}

.badge-pill{display:inline-block; padding:.35rem .6rem; border:1px solid #cde8e7; border-radius:999px}

@media (max-width: 900px){
  .hero .grid, .split{grid-template-columns:1fr}
  .cards .card{grid-column: span 12}
  .domains{grid-template-columns:1fr}
  nav ul{display:none}
}


/* Header layout fix (scopé) */
.site-header .header-bar{
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; flex-wrap:nowrap;
}
.site-header .brand{
  display:flex; align-items:center; gap:.75rem;
  white-space:nowrap; flex-shrink:0;
}
.site-header .brand .logo{ height:40px; width:auto; display:block; }
.site-header .brand b{ font-weight:800; }
.site-header .brand small{ display:block; margin-top:-4px; color:var(--ink-soft); }

.site-header .main-nav{ flex:1 1 auto; }
.site-header .main-nav ul{
  display:flex; justify-content:center; align-items:center;
  gap:1.25rem; margin:0; padding:0; list-style:none;
}
.site-header .btn{ flex-shrink:0; }

@media (max-width:900px){
  .site-header .main-nav ul{ display:none; }
}

/* Footer brand fix */
footer .brand{
  display:flex; align-items:center; gap:.75rem;
}
footer .brand svg{
  width:38px; height:38px; flex:0 0 auto;
}
footer .brand b{ color:#fff; }
footer .brand small{ color:#cde8e7; }

/* Logo dans le bloc Coordonnées */
.logo-contact {
  display: block;           /* permet de centrer */
  margin: 1rem auto 0 auto; /* centre horizontalement */
  max-width: 150px;         /* largeur max (ajuste selon ton logo) */
  height: auto;             /* garde les proportions */
}

/* Footer layout tweaks */
footer .foot-grid{
  align-items: flex-start;
  gap: 2rem;
}

/* Navigation liste dans le footer */
footer .foot-grid nav ul{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: .4rem;
}




/* --- Finitions footer --- */

/* 1) Haut du footer : 3 colonnes équilibrées + espaces réguliers */
footer .foot-grid{
  grid-template-columns: 1fr auto auto; /* la colonne brand prend la largeur dispo */
  column-gap: 3rem;
  row-gap: 1rem;
}

/* Petites marges plus serrées dans la colonne "Contact" */
footer .foot-grid p{ margin: .25rem 0; }

/* Titres uniformes */
footer .foot-title{
  margin: 0 0 .6rem 0;
  font-weight: 700;
  letter-spacing: .2px;
}

/* 2) Bande "Mentions légales" : vraie grille responsive, lignes propres */
footer .foot-legal{
  margin-top: 2.2rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255,255,255,.22);
}

footer .legal-grid{
  display: grid;
  grid-template-columns: 1fr;          /* mobile par défaut */
  gap: .9rem 1.5rem;
  color:#cfe2e1;
  font-size:.92rem;
  line-height:1.5;
}
footer .legal-grid p{ margin: 0; }      /* supprime les gros espacements */
footer .legal-grid p b{ color:#fff; }

/* 2 colonnes à partir de tablettes, 4 colonnes sur grands écrans */
@media (min-width: 700px){
  footer .legal-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px){
  footer .legal-grid{ grid-template-columns: repeat(4, 1fr); }
}

/* 3) Liens : lisibles mais discrets */
footer a{ color:#fff; text-decoration:none; }
footer .foot-legal a{ text-decoration: underline; }
footer a:hover{ opacity:.9; text-decoration: underline; }

/* 4) Petit réalignement du logo brand du footer */
footer .brand{ display:flex; align-items:center; gap:.75rem; }
footer .brand svg{ width:38px; height:38px; flex:0 0 auto; }


.logo-legal {
  width: 100px;
  height: auto;
  margin-left: 8px;
  vertical-align: middle;
}


.formations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
  margin-top: 2rem;
}

.formation-block {
  background: #fff;
  padding: 1.5rem;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.formation-block h3 {
  margin-bottom: 1rem;
  color: #004d40;
  font-size: 1.2rem;
  border-bottom: 2px solid #e0e0e0;
  padding-bottom: .5rem;
}

.formation-block ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.formation-block ul li {
  margin: 0.5rem 0;
  padding-left: 1.5rem;
  position: relative;
}

.formation-block ul li::before {
  content: "✔";
  position: absolute;
  left: 0;
  color: #00796b;
  font-size: 0.9rem;
}