:root{
  --bg:#07131a;
  --bg-hero:#0a1a22;
  --txt:#f6fbff;
  --muted:#b9c9d3;
  --primary-2:#0f8c99;
  --primary:#32b3be;
  --accent:#ffc533;
  --card:#0b1b23;
  --stroke:rgba(255,255,255,.10);
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --radius:16px;
  --radius-lg:20px;
  --maxw:1120px;
}

.section.alt1 {background: #0b1b23;}
.section.alt2 {background: #08171e;}

.section + .section{
  border-top: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 -1px 0 rgba(255,255,255,0.05);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;
  background:linear-gradient(180deg,var(--bg-hero),var(--bg) 30%, var(--bg) 100%);
  color:var(--txt);
  line-height:1.6;
}

/* ==============================
   LIENS (hors menus & boutons)
   Objectif :
   - liens texte + mailto en jaune (y compris après clic)
   - aucun impact sur les liens du menu (.nav / .mobile-nav)
   - aucun impact sur les boutons (.btn, .btn-cta-big)
   ============================== */

/* Liens "contenu" (sections, pages, cards, footer) */
main a:not(.btn):not(.btn-cta-big),
.section a:not(.btn):not(.btn-cta-big),
.card a:not(.btn):not(.btn-cta-big),
.footer a:not(.btn):not(.btn-cta-big){
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

main a:not(.btn):not(.btn-cta-big):visited,
.section a:not(.btn):not(.btn-cta-big):visited,
.card a:not(.btn):not(.btn-cta-big):visited,
.footer a:not(.btn):not(.btn-cta-big):visited{
  color: var(--accent);
}

main a:not(.btn):not(.btn-cta-big):hover,
.section a:not(.btn):not(.btn-cta-big):hover,
.card a:not(.btn):not(.btn-cta-big):hover,
.footer a:not(.btn):not(.btn-cta-big):hover{
  filter: brightness(1.05);
}

/* Menus : on verrouille la couleur même après clic */
.nav a:visited,
.mobile-nav a:visited{
  color: var(--muted);
}

/* Boutons (quand ce sont des <a>) : ne pas les impacter */
a.btn,
a.btn:visited{ text-decoration: none; }

a.btn-primary,
a.btn-primary:visited{ color:#042a28; }

a.btn-outline,
a.btn-outline:visited{ color:var(--primary); }

.container{max-width:var(--maxw);margin:0 auto;padding:24px}

/* HEADER */
.header{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  position:sticky;top:0;z-index:30;
  background:rgba(7,19,26,.70);backdrop-filter:blur(6px);
  border-bottom:1px solid var(--stroke);
}

.brand{display:flex;align-items:center;gap:12px}

.logo{
  height: 50px;
  width: auto;
  object-fit: contain;
  margin-right: 4px;
}

.brand-name{font-weight:800;letter-spacing:.3px;color:#eaf6fb}

.nav{display:flex;gap:18px;flex-wrap:wrap}
.nav a{color:var(--muted);text-decoration:none;font-weight:600;position:relative;padding:6px 0}
.nav a:hover{color:var(--txt)}
.nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  transform:scaleX(0);transform-origin:left;transition:transform .2s ease
}
.nav a:hover::after{transform:scaleX(1)}

.btn{
  border:none;border-radius:999px;padding:12px 18px;font-weight:800;cursor:pointer;
  transition:transform .12s ease, box-shadow .2s ease
}
.btn-primary{background:linear-gradient(90deg,var(--primary),var(--primary-2));color:#042a28;box-shadow:var(--shadow)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-outline{background:transparent;border:1px solid var(--primary);color:var(--primary)}

/* MENU MOBILE */
.hamburger{
  display:none;
  background:none;
  border:none;
  color:#fff;
  font-size:28px;
  cursor:pointer;
}

.desktop-nav{display:flex;align-items:center;gap:24px}
.desktop-nav a{font-size:14px;text-transform:uppercase;letter-spacing:.08em}
.desktop-cta{margin-left:16px}

.mobile-nav{
  display:none;
  position:absolute;
  top:64px;
  right:16px;
  background:rgba(0,0,0,0.94);
  padding:18px 20px;
  border-radius:16px;
  width:75%;
  max-width:320px;
  box-shadow:0 18px 45px rgba(0,0,0,0.6);
  flex-direction:column;
  gap:8px;
}
.mobile-nav a{font-size:15px;padding:6px 0}
.mobile-nav.is-open{display:flex}

@media (max-width: 900px){
  .desktop-nav{display:none}
  .desktop-cta{display:none}
  .hamburger{display:block}
}

/* CTA JAUNE */
.cta-row{display:flex;justify-content:center;align-items:center;text-align:center;margin-top:32px}
.btn-cta-big{
  background: var(--accent);
  color:#000;
  border:none;
  padding:16px 32px;
  border-radius:16px;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  cursor:pointer;
  font-weight:600;
  box-shadow:0 8px 20px rgba(255, 200, 0, 0.25);
  transition:all 0.25s ease;
}
.btn-cta-big .cta-main{font-size:1.15rem;line-height:1.3}
.btn-cta-big .cta-sub{font-size:0.85rem;opacity:0.8;line-height:1.3;margin-top:-2px}
.btn-cta-big:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(255, 200, 0, 0.35)}

/* HERO */
.hero{position:relative;min-height:78vh;display:grid;align-items:center;background:var(--bg-hero)}
.hero-bg{position:absolute;inset:0;background-image:url('hero.jpg');background-size:cover;background-position:center;filter:saturate(1.05) contrast(1.02)}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,125,139,.55),rgba(7,19,26,.86)),
             radial-gradient(60% 60% at 70% 20%, rgba(0,127,139,.35) 0%, transparent 60%);
}
.hero-inner{position:relative;z-index:2;display:flex;flex-direction:column;gap:18px}

.hero-title{
  font-size:42px;line-height:1.18;margin:0;font-weight:900;letter-spacing:.2px;
  text-shadow:0 1px 0 rgba(0,0,0,.35);
  text-align:center;
}

.hero-subtitle{
  text-align:center;
  margin:8px auto 0;
  max-width:680px;
  opacity:0.9;
  font-size:1.05rem;
}

.hero-cols{
  display:grid;
  grid-template-columns: fit-content(420px) minmax(0, 1fr);
  gap:20px;
  align-items:stretch;
  margin-top:28px;
}

.hero-panel-features{
  justify-self:start;
}
@media (max-width: 960px){ .hero-cols{grid-template-columns:1fr} }

.panel{
  padding:16px 18px;border-radius:18px;border:1px solid rgba(255,255,255,.18);
  background:rgba(10,26,34,.55);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  box-shadow:var(--shadow);
  transition:box-shadow .2s ease, background .2s ease, transform .15s ease;
}
.panel p{max-width:500px}
.panel:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(0,0,0,.45)}

.panel-titre{
  font-size:1.1rem;font-weight:600;color:var(--primary);
  margin-bottom:12px;letter-spacing:0.3px;
}
.panel-titre::after{
  content:"";display:block;width:48px;height:3px;background:var(--primary);
  margin-top:6px;border-radius:2px;opacity:0.8;
}

.pill{
  display:inline-block;background:var(--accent);color:#2b1f00;
  font-weight:900;border-radius:999px;padding:0px 12px;
}

/* HERO FEATURES */
.hero-features{
  list-style:none;padding:0;margin:12px 0 0 0;
  display:flex;flex-direction:column;gap:10px;
}
.hero-features li{
  display:flex;align-items:center;gap:10px;
  color:var(--muted);font-weight:600;
}
.ico-badge{
  width:28px;height:28px;flex:0 0 28px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:10px;
  background: rgba(255,197,51,0.10);
  border: 1px solid rgba(255,197,51,0.22);
  box-shadow: 0 10px 22px rgba(0,0,0,0.20);
}
.ico-badge svg{
  width:18px;height:18px;
  stroke: var(--accent);stroke-width: 2.2;
  fill: none;stroke-linecap: round;stroke-linejoin: round;
  opacity: 0.95;
}

/* Sections */
.section{padding:48px 0}

.h2{
  margin:0 0 12px;
  font-size:30px;
  line-height:1.25;
  font-weight:800;
  letter-spacing:.2px;
  margin-bottom:20px;
}
.h2::after{
  content:"";
  display:block;
  width:72px;
  height:4px;
  margin-top:10px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  box-shadow:0 4px 14px rgba(15,140,153,.15);
}

.muted{color:var(--muted)}
.center{text-align:center}
.mt{margin-top:12px}

.txt-glow-primary{
  color: var(--primary);
  text-shadow: 0 0 8px rgba(15,140,153,0.4);
  font-weight:700;
}

.txt-accent{color: var(--accent);font-weight:700}
.highlight{margin-top:28px;margin-bottom:10px;font-size:1.05rem;color:var(--primary)}
.highlight2{margin-top:28px;margin-bottom:10px;color:var(--primary)}

/* HBlocks */
.hblocks{display:flex;flex-direction:column;gap:26px;margin-top:24px}
.hblock{
  display:flex;gap:18px;align-items:flex-start;
  background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius-lg);
  padding:16px 18px;
  box-shadow: 0 10px 28px rgba(0,0,0,0.22);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.hblock:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 40px rgba(0,0,0,.45);
  border-color:rgba(15,140,153,.35)
}

/* Tag pill + icon (premium, sans “effet géant”) */
.hblock-tag{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:8px;

  font-weight:900;
  letter-spacing:.3px;

  color:#042a28;
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  padding:8px 12px;
  border-radius:999px;
}

.tag-ico{
  width:16px;
  height:16px;
  flex:0 0 16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  opacity: 0.95;
}

.tag-ico svg{
  width:16px;
  height:16px;
  stroke: currentColor;       /* suit la couleur du texte du pill */
  stroke-width: 2.2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  display:block;
}

.hblock-body{color:var(--muted)}
@media (max-width: 720px){
  .hblock{flex-direction:column;gap:10px}
  .hblock-tag{align-self:flex-start}
}

/* Grids & Cards */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width: 960px){
  .grid2{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
}

.card{
  border-radius: 16px;
  background:var(--card);
  border:1px solid var(--stroke);
  padding:20px;
  box-shadow:var(--shadow);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(0,0,0,.45);border-color:rgba(15,140,153,.35)}
.card.list ul{padding-left:18px;margin:10px 0}
.card.list li{margin:8px 0}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:20px}
@media (max-width: 960px){ .steps{grid-template-columns:1fr} }
.steps .step{
  background:var(--card);
  border:1px solid var(--stroke);
  border-radius:16px;
  padding:24px 26px;
  box-shadow:0 10px 28px rgba(0,0,0,0.25);
  max-width:300px;
}
.step-n{
  width:34px;height:34px;border-radius:50%;
  display:flex;justify-content:center;align-items:center;
  background:var(--primary);
  color:#042a28;
  font-weight:800;
  margin-bottom:12px;
}

/* Tableau */
.table-wrap{overflow-x:auto;margin-top:10px;max-width:900px;margin:0 auto}
.table{
  width:100%;
  border-collapse:collapse;
  border-radius:16px;
  overflow:hidden;
  background: rgba(0, 0, 0, 0.25);
  border:1px solid var(--stroke);
}
.table th,.table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--stroke)}
.table thead th{background:rgba(255,255,255,0.05);font-weight:700}
.table tbody tr:nth-child(even){background:rgba(255,255,255,0.02)}
.table tr.emph td{font-weight:700;background:rgba(0, 255, 255, 0.07);border-top:1px solid var(--primary);border-bottom:1px solid var(--primary)}
.table td.brazil-emph{background: rgba(255, 200, 0, 0.08);font-weight:800;color:var(--primary)}
.note{margin-top:4px;font-size:0.8rem;opacity:0.55}

/* Lists ticks (restent pour les cartes / call details) */
.ticks{list-style:none;padding-left:0;margin:0}
.ticks li{position:relative;padding-left:26px;margin:8px 0;color:var(--muted)}
.ticks li::before{content:"✓";position:absolute;left:0;top:0;color:var(--accent);font-weight:900}

/* Founder */
.founder-layout{
  display:grid;
  grid-template-columns:minmax(0, 0.9fr) minmax(0, 1.3fr);
  gap:3rem;
  align-items:center;
}
@media (max-width: 900px){
  .founder-layout{grid-template-columns:1fr;text-align:center}
  .founder-meta{flex-direction:column;align-items:stretch}
  .founder-meta .btn{align-self:stretch;width:100%;justify-content:center}
}
.founder-photo-wrap{display:flex;justify-content:center}
.founder-photo{
  width:100%;
  max-width:280px;
  border-radius:999px;
  display:block;
  box-shadow:0 18px 45px rgba(0, 0, 0, 0.22);
}
.founder-content p{margin-bottom:0.75rem;max-width:600px;padding-top:0.8rem}
.founder-content h2{margin-bottom:1.3rem}
.founder-intro{font-weight:600;margin-top:0.5rem}
.founder-quote{font-style:italic;opacity:0.9}
.founder-meta{
  display:flex;
  flex-wrap:wrap;
  gap:1.5rem;
  align-items:stretch;
  margin-top:1.5rem;
}
.founder-facts{flex:1 1 230px;max-width:340px;border-radius:14px}
.founder-meta .btn{align-self:flex-start;min-width:210px;margin-top:0.5rem;margin-left:1rem}

/* Accompagnement */
.accom-card{padding:26px 28px}
.accom-text{max-width:820px;margin:0 0 12px}

.accom-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:18px;
}
@media (max-width: 960px){
  .accom-split{grid-template-columns:1fr}
}

.h3{margin:0 0 10px;font-size:18px;font-weight:800}

.accom-list{
  margin:0;
  padding-left:18px;
  color:var(--muted);
}
.accom-list li{margin:10px 0}

/* Footer */
.footer{border-top:1px solid var(--stroke);background:#061017}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px;align-items:start}
.links{list-style:none;padding:0;margin:0}
.links a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.links a:visited{color:var(--accent)}
.links a:hover{filter:brightness(1.05)}
.small{color:var(--muted);font-size:14px;margin-top:8px}
