@import url("fonts.css");

:root{
  --navy:#09122b;
  --blue:#088fcf;
  --blue-soft:#84b6dd;
  --blue-pale:#adcee8;
  --orange:#ff814f;
  --bg:#f2f7fc;
  --card:#ffffff;
  --text:#1c2536;
  --muted:#5b6577;
  --line:#d8e2ee;
  --radius:12px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;padding:0;
  font-family:"Open Sans",Helvetica,Arial,sans-serif;
  font-size:17px;line-height:1.6;color:var(--text);
  background:var(--bg);
}

/* En-tête */
.site-header{background:#fff;border-bottom:3px solid var(--blue-pale)}
.site-header .inner{max-width:820px;margin:0 auto;padding:18px 20px;display:flex;align-items:center;gap:14px}
.site-header img{height:46px;width:auto}

/* Conteneur */
.wrap{max-width:820px;margin:0 auto;padding:24px 20px 60px}

h1{font-family:"Raleway",sans-serif;font-weight:800;color:var(--navy);font-size:2rem;line-height:1.2;margin:6px 0 14px}
h2{font-family:"Raleway",sans-serif;font-weight:700;color:var(--navy);font-size:1.3rem;margin:0 0 4px}
p{margin:0 0 14px}
a{color:var(--blue)}
small,.muted{color:var(--muted)}

/* Bloc d'intro */
.intro p{margin:0 0 14px;text-align:justify;hyphens:auto}
.intro .lead{font-size:1.05rem}

/* Cartes / sections */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 22px;margin:18px 0;box-shadow:0 2px 10px rgba(9,18,43,.05)}
.section-num{display:inline-block;font-family:"Raleway",sans-serif;font-weight:800;font-size:.8rem;
  letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin-bottom:2px}

/* Préambule visible de section */
.preambule{background:#eaf3fb;border-left:4px solid var(--orange);border-radius:0 8px 8px 0;
  padding:10px 14px;margin:8px 0 22px;color:#33425b;font-style:italic;font-size:.96rem;
  text-align:justify;hyphens:auto}

/* Champs */
.field{margin:26px 0}
.field:first-of-type{margin-top:8px}
.field > label.q{display:block;font-weight:600;color:var(--navy);margin-bottom:6px}
.req{color:var(--orange);font-weight:700}
.hint{display:block;color:var(--muted);font-size:.88rem;margin:3px 0 0}
input[type=text],input[type=email],input[type=number],input[type=date],select,textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;
  font:inherit;color:var(--text);background:#fff}
textarea{min-height:90px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(8,143,207,.15)}

/* Choix (radio / checkbox) */
.choices{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.choices.inline{flex-direction:row;flex-wrap:wrap;gap:8px 18px}
.opt{display:flex;align-items:flex-start;gap:9px;cursor:pointer;
  border:1px solid var(--line);border-radius:8px;padding:9px 12px;background:#fff}
.opt:hover{border-color:var(--blue-soft)}
.opt input{margin-top:3px;accent-color:var(--blue);width:18px;height:18px;flex:0 0 auto}
.opt span{flex:1}

/* Consentement */
.consent{background:#fbfdff;border:1px solid var(--blue-pale)}
.rgpd{font-size:.92rem;color:#33425b}
.rgpd summary{cursor:pointer;font-weight:600;color:var(--navy)}
.rgpd ul{margin:10px 0 0;padding-left:18px}
.rgpd li{margin:6px 0}

/* Bouton */
.actions{margin-top:24px}
button.submit{font-family:"Raleway",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  border:none;cursor:pointer;color:#fff;background:var(--navy);
  padding:14px 34px;border-radius:50px;font-size:1rem;box-shadow:0 4px 12px rgba(9,18,43,.18);
  transition:background .15s ease}
button.submit:hover{background:var(--orange)}

/* Erreurs */
.errors{background:#fff4f0;border:1px solid var(--orange);border-radius:8px;padding:12px 16px;margin:16px 0;color:#8a2d12}
.errors ul{margin:6px 0 0;padding-left:18px}

/* Honeypot */
.hp{position:absolute;left:-9999px;top:-9999px;height:0;overflow:hidden}

/* Merci */
.merci{text-align:center;padding:30px 10px}
.merci .flamme{height:70px;margin-bottom:10px}

/* Pied */
.site-footer{border-top:1px solid var(--line);background:#fff}
.site-footer .inner{max-width:820px;margin:0 auto;padding:18px 20px;color:var(--muted);font-size:.85rem;
  display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap}

@media (max-width:560px){
  body{font-size:16px}
  h1{font-size:1.6rem}
  .card{padding:18px 16px}
}
