:root{
  --bg:#ffffff;
  --bg2:#f5fbff;
  --panel:#88D7FA;
  --panel2:#ffffff;
  --text:#0b1220;
  --muted:#1f3b5a;
  --border:rgba(19,74,128,.18);
  --primary:#134A80;
  --primary2:#1b6db8;
  --shadow: 0 18px 50px rgba(19,74,128,.18);
  --radius: 18px;
  --max: 1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 700px at 15% -10%, rgba(136,215,250,.55), transparent 60%),
              radial-gradient(900px 600px at 90% 10%, rgba(19,74,128,.10), transparent 55%),
              var(--bg);
  color:var(--text);
  line-height:1.6;
}
a{color:inherit}
img{max-width:100%; height:auto}
.container{width:min(var(--max), calc(100% - 40px)); margin:0 auto}
.skip-link{position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip-link:focus{left:10px; top:10px; width:auto; height:auto; padding:10px 14px; background:#fff; color:#000; border-radius:10px; z-index:9999}

.site-header{
  position:sticky; top:0; z-index:50;
  background: #fff;
  border-bottom:1px solid var(--border);
}

.header-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:16px}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none}
.brand img{display:block}

.nav{display:flex; align-items:center; gap:18px}
.nav a{opacity:1; text-decoration:none; font-weight:700; font-size:14px; color:var(--primary)}
.nav a:hover{opacity:1}
.nav .btn-sm{padding:10px 14px; font-size:13px}
/* Ensure button text inside header nav stays readable */
.nav a.btn{color:#fff}
.nav a.btn:hover{color:#fff}

.nav-toggle{display:none; width:44px; height:42px; border-radius:12px; border:1px solid var(--border); background:transparent; color:var(--text)}
.nav-toggle span{display:block; width:20px; height:2px; background:var(--text); margin:5px auto; border-radius:5px}

.hero{padding:64px 0 26px; position:relative; overflow:hidden}
.hero-bg{
  position:absolute; inset:-40px -40px auto -40px; height:340px;
  background: linear-gradient(120deg, rgba(0,163,255,.20), rgba(0,212,255,.10), transparent 70%);
  filter: blur(0px);
  pointer-events:none;
}
.hero-inner{display:grid; grid-template-columns: 1.15fr .85fr; gap:28px; align-items:start}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border:1px solid var(--border); border-radius:999px;
  background:rgba(255,255,255,.70);
  color:var(--muted); font-weight:600; font-size:13px
}
h1{font-size:46px; line-height:1.15; margin:14px 0 14px}
.lead{font-size:18px; color:var(--muted); margin:0 0 18px}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin:18px 0}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px;
  border-radius:14px;
  background: var(--primary);
  border:1px solid rgba(19,74,128,.25);
  text-decoration:none;
  color:#fff;
  font-weight:800;
  box-shadow: 0 12px 28px rgba(19,74,128,.18);
}

.btn:hover{transform:translateY(-1px)}
.btn-ghost{
  background:transparent; color:var(--text);
  border:1px solid var(--border);
  box-shadow:none;
}
.btn-block{width:100%}
.hero-points{margin:14px 0 0; padding:0; list-style:none; display:grid; gap:8px}
.hero-points li{color:var(--muted); padding-left:26px; position:relative}
.hero-points li:before{
  content:"✓"; position:absolute; left:0; top:0; color:var(--primary2); font-weight:900
}

.card{
  background: var(--panel);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:22px;
  box-shadow: var(--shadow);
}
.card-title{font-size:18px; margin:0 0 14px}
.checklist{margin:0; padding:0; list-style:none; display:grid; gap:10px}
.checklist li{padding-left:28px; position:relative; color:var(--muted)}
.checklist li:before{
  content:""; position:absolute; left:0; top:.45em; width:14px; height:14px;
  border-radius:4px; background:linear-gradient(135deg, var(--primary), var(--primary2));
}
.small{font-size:13px}
.muted{color:var(--muted)}
.card-note{
  margin:16px 0; padding:12px 12px;
  background: rgba(255,255,255,.55);
  border:1px solid var(--border);
  border-radius:14px;
  color:var(--muted)
}

.section{padding:62px 0}
.section-alt{background: rgba(255,255,255,.03)}
.section-line{width:64px;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--primary),rgba(19,74,128,.22));margin:0 0 18px}

main > .section > .container::before,
.footer > .container::before{
  content:"";
  display:block;
  width:64px;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary),rgba(19,74,128,.22));
  margin:-18px 0 16px;
}
h2{font-size:32px; line-height:1.2; margin:0 0 10px}
.sublead{margin:0 0 22px; color:var(--muted); font-size:17px}
.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:16px}
.feature{
  background: rgba(255,255,255,.70);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
}
.feature h3{margin:10px 0 8px; font-size:18px}
.feature p{margin:0; color:var(--muted)}
.icon{width:42px; height:42px; border-radius:14px; display:grid; place-items:center;
  background: rgba(0,163,255,.12); border:1px solid var(--border);
  color:var(--primary2)
}
.icon svg{width:22px; height:22px}

.callout{
  margin-top:18px;
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:18px;
  border-radius: var(--radius);
  border:1px solid rgba(0,212,255,.25);
  background: rgba(0,212,255,.07);
}
.callout h3{margin:0 0 4px}
.callout p{margin:0; color:var(--muted)}
.callout .btn{white-space:nowrap}

.rich{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.rich .box{
  background: rgba(255,255,255,.70);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
  height:100%;
  display:flex;
  flex-direction:column;
}
.rich h3{margin:0 0 8px}
.rich p{margin:0; color:var(--muted)}
.klist{margin:12px 0 0; padding-left:18px; color:var(--muted)}
.klist li{margin:6px 0}

.timeline{display:grid; gap:12px; margin-top:14px}
.step{display:grid; grid-template-columns: 44px 1fr; gap:14px; padding:16px; border-radius: var(--radius); border:1px solid var(--border); background: rgba(255,255,255,.70)}
.step-n{width:44px; height:44px; border-radius:16px; display:grid; place-items:center; font-weight:900; color:#02101f; background: linear-gradient(135deg, var(--primary), var(--primary2))}
.step h3{margin:2px 0 6px}
.step p{margin:0; color:var(--muted)}

.faq{margin-top:16px; display:grid; gap:10px}
details{background: rgba(255,255,255,.70); border:1px solid var(--border); border-radius: var(--radius); padding:14px}
summary{cursor:pointer; font-weight:800}
details p{margin:10px 0 0; color:var(--muted)}

.form{
  display:grid; gap:12px; margin-top:14px
}
.input{
  width:100%; padding:12px 14px;
  border-radius: 14px;
  border:1px solid var(--border);
  /* Contact section inputs should be light */
  background: #fff;
  color:var(--text);
  outline:none;
}
textarea.input{min-height:120px; resize:vertical}
.form-row{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
.note{font-size:13px; color:var(--muted)}

.footer{
  padding:26px 0;
  background: #fff;
}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap}
.footer a{text-decoration:none; color:var(--muted)}
.footer a:hover{color:var(--text)}
.footer img{display:block; opacity:.95}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible{
  outline:3px solid rgba(27,109,184,.35);
  outline-offset:2px;
}

.tiny{font-size:12px}
.sep{display:inline-block; margin:0 8px; opacity:.7}
.grid{display:grid}
.check{margin:0; padding-left:18px; color:var(--muted)}
.check li{margin:8px 0}

@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr}
  h1{font-size:38px}
  .grid-3{grid-template-columns:1fr}
  .rich{grid-template-columns:1fr}
  .callout{flex-direction:column; align-items:flex-start}
  .nav{display:none; position:absolute; right:20px; top:64px; flex-direction:column; align-items:stretch;
       background: rgba(7,11,20,.95); border:1px solid var(--border); border-radius:16px; padding:12px; min-width:240px}
  .nav a{padding:10px 10px; color:#fff}
  .nav a.btn{color:#fff}
  .nav-toggle{display:block}
  .nav.open{display:flex}
  .form-row{grid-template-columns:1fr}
}
/* Pages (mentions légales / contact) */
.page{padding:42px 0 60px}
.page-card{
  background: var(--panel);
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 26px;
}

/* Simple form styling on the dedicated contact page */
.page-card label{display:block; font-weight:700; color:var(--text); margin:0 0 6px}
.page-card .row{display:grid; gap:8px}
.page-card input, .page-card textarea{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  outline:none;
}
.page-card h1{margin-top:0}
.page-card h2{margin-top:24px}
.page-card ul{padding-left:18px}
.page-card li{margin:8px 0}


.trust-strip{display:flex;flex-wrap:nowrap;gap:10px;margin-top:18px}
.trust-strip span{display:inline-flex;align-items:center;justify-content:center;flex:1;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.78);border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:700;text-align:center;white-space:nowrap}
.card-soft{background:rgba(255,255,255,.72);box-shadow:none}
.stack{display:grid;gap:18px}
.contact-grid .row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.page-card select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);outline:none}
.contact-intro{margin-top:18px}

@media (max-width: 980px){
  .contact-grid{grid-template-columns:1fr !important}
  .contact-grid .row-2{grid-template-columns:1fr}
  .trust-strip{flex-wrap:wrap}
  .trust-strip span{flex:unset;white-space:normal}
}
