/* =========================
   Variables & bases
   ========================= */
:root{
  --blue:#26a6d4;
  --blue-strong:#1e9ac7;
  --text:#111;
  --border:#e6e9ee;
  --cta:#ef6a6a;
  --cta-dark:#db5959;
  --container:1100px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0}
body{
  font:400 16px/1.6 Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text); background:#fff;
}
.wrap{max-width:var(--container); margin-inline:auto; padding:0 20px}

/* =========================
   Topbar (bandeau image)
   ========================= */
.topbar img{
  display:block;
  width:100%;
  max-width:1000px;
  height:auto;
  margin:0 auto;
}

/* =========================
   Navigation
   ========================= */
.mainnav{
  border-block:2px solid var(--blue);
  margin-top:10px;
  background:#fff;
  min-height:48px;
}
.mainnav .wrap{
  position:relative;
}
.menu{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:24px;
  list-style:none;
  padding:14px 0;
  margin:0;
}
.menu a{
  display:inline-block;
  padding:10px 14px;
  color:var(--text);
  text-decoration:none;
  letter-spacing:.3px;
  font-weight:600;
  border-radius:6px;
}
.menu a.active{
  background:var(--blue);
  color:#fff;
  box-shadow:0 2px 0 var(--blue-strong) inset;
}
.nav-toggle{
  display:none;
  background:none;
  border:0;
  font-size:1.6rem;
  line-height:1;
}

.subline{border-block:1px solid var(--blue); background:#fff}
.under-title{margin:10px 0; text-align:center; font-weight:600}

/* =========================
   Accueil / layout généraux
   ========================= */
.home-layout{
  display:grid;
  grid-template-columns:320px 1fr; /* un peu plus large pour le bloc bienvenue */
  gap:32px;
  padding-top:26px;
  align-items:flex-start;
}

/* colonne boutons */
.left-col{
  display:flex;
  flex-direction:column;
  gap:18px;
  /* on limite la largeur des boutons sur desktop */
  max-width:420px;
}

/* boutons rouges */
.cta-red{
  display:block;
  width:100%;
  max-width:420px;        /* ✅ plus petit sur desktop */
  padding:14px 16px;      /* ✅ moins haut */
  text-align:center;
  text-transform:uppercase;
  font-weight:700;
  letter-spacing:.4px;
  color:#fff;
  background:var(--cta);
  border:1px solid rgba(0,0,0,.06);
  border-radius:6px;
  text-decoration:none;
  box-shadow:0 1px 0 rgba(0,0,0,.05) inset;
  margin-left:auto;       /* pousse vers la droite pour s’aligner avec le bloc central */
}
.cta-red:hover{background:var(--cta-dark)}

/* bloc bienvenue */
.welcome{
  min-height:160px;
  padding:18px 20px;
  background:#fff;
  border:1px solid var(--border);
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}
.welcome p{
  margin:0;
  line-height:1.5;
}

/* =========================
   Contenus variés (autres pages)
   ========================= */
.photo{max-width:360px}
.photo img{width:100%; height:auto}

.row{display:flex; flex-wrap:wrap; gap:20px; align-items:flex-start}
.row .photo{flex:0 0 320px}
.row .content{flex:1 1 280px; min-width:260px}

/* Accordéons */
.accordions{max-width:820px; margin-inline:auto}
.acc-summary{min-height:48px}

/* =========================
   Footer
   ========================= */
.big-footer{
  margin-top:80px;
  padding:48px 0 64px;
  text-align:center;
  background:#2f2e2b;
  color:#cfd2d6;
}

/* =========================
   Breakpoints
   ========================= */
@media (max-width:1100px){
  :root{--container:92vw}
}

@media (max-width:980px){
  .menu{gap:22px}
  .home-layout{
    grid-template-columns:300px 1fr;
  }
}

@media (max-width:900px){
  .home-layout{
    grid-template-columns:1fr;
  }
  /* sur tablette, on centre les boutons */
  .left-col{
    max-width:460px;
    margin-inline:auto;
  }
  .cta-red{
    margin-left:0;
  }
}

@media (max-width:700px){
  .mainnav,.mainnav .wrap{
    position:relative;
  }

  /* bouton burger visible */
  .nav-toggle{
    display:block;
    position:absolute;
    right:20px;
    top:9px;
    cursor:pointer;
    z-index:3;
    padding:6px 10px;
    background:#fff;
    border:1px solid transparent;
    border-radius:4px;
  }

  /* on laisse de la place pour le burger dans la ligne */
  .mainnav .wrap{
    padding-right:60px;
  }

  .menu{
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:16px;
    padding:8px 0 12px;
    margin-top:44px;
    border-top:1px solid #e5e7eb;
    position:relative;
    z-index:2;
    background:#fff;
  }
  .menu.open{display:flex}

  .topbar img{max-width:92vw}

  /* mobile : on remet dans l’ordre colonne */
  .home-layout{
    display:flex;
    flex-direction:column;
    gap:14px;
    padding-top:18px;
  }

  /* bienvenue moins haut et moins large */
  .welcome{
    border:1px solid #eceff1;
    border-radius:6px;
    margin-inline:6px;
    padding:14px 14px;
  }
  .welcome p{
    font-size:0.95rem;
  }

  /* boutons : pas collés aux bords */
  .left-col{
    width:100%;
    max-width:none;
    margin:0;
    padding-inline:6px;
  }
  .cta-red{
    max-width:none;
    width:100%;
    margin-left:0;
    margin-right:0;
    border-radius:10px;
  }
}

@media (max-width:360px){
  .menu a{padding:10px 8px}
}

/* liens sous-titre */
.under-title a {
  color: inherit;
  text-decoration: none;
  font-weight: 600;
}
.under-title a:hover {
  color: var(--blue);
}
