/* ==========================================================
   GeoExpert Academy & Consulting — Design tokens
   Identité alignée sur le logo : fond clair, dégradé
   sarcelle -> indigo -> magenta, serif élégant + sans-serif.
   ========================================================== */

:root{
  --bg:            #FFFFFF;
  --bg-soft:       #F6F3FA;
  --bg-soft-2:     #F0ECF6;
  --line:          rgba(46,44,52,0.10);
  --line-strong:   rgba(46,44,52,0.18);

  --teal:          #0092A6;
  --teal-soft:     rgba(0,146,166,0.10);
  --indigo:        #4B3F92;
  --magenta:       #A83C93;

  --gradient-brand: linear-gradient(100deg, var(--teal) 0%, var(--indigo) 55%, var(--magenta) 100%);

  --ink:           #2A2A28;
  --ink-dim:       #6B6A72;
  --ink-faint:     #9C9AA4;

  --font-display:  'Cormorant Garamond', serif;
  --font-body:     'Inter', sans-serif;
  --font-mono:     'JetBrains Mono', monospace;

  --radius:        14px;
  --container-w:   1180px;
}

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

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

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

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.15;
  letter-spacing:0;
  color:var(--ink);
}
h2{ font-size:clamp(30px,4.2vw,44px); margin-bottom:10px; }
h3{ font-size:22px; margin-bottom:8px; font-weight:600; }
p{ color:var(--ink-dim); }

a{ color:inherit; text-decoration:none; }
:focus-visible{ outline:2px solid var(--teal); outline-offset:3px; }

.text-accent{
  background:var(--gradient-brand);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.section-eyebrow{
  font-family:var(--font-mono);
  font-size:11.5px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--teal);
  margin-bottom:10px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.section-eyebrow::before{
  content:'';
  width:16px; height:1px;
  background:var(--gradient-brand);
}
.section-lead{ max-width:560px; margin-top:6px; margin-bottom:36px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 26px; border-radius:10px;
  font-family:var(--font-body); font-weight:600; font-size:15px;
  border:1px solid transparent; cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.btn:hover{ transform:translateY(-1px); }
.btn-primary{
  background:var(--gradient-brand);
  color:#fff;
  box-shadow:0 6px 18px rgba(75,63,146,0.22);
}
.btn-primary:hover{ box-shadow:0 8px 22px rgba(75,63,146,0.3); }
.btn-outline{ border-color:var(--line-strong); color:var(--ink); }
.btn-outline:hover{ border-color:var(--teal); color:var(--teal); }
.btn-whatsapp{ background:#25B357; color:#fff; }
.btn-whatsapp:hover{ background:#1FA34D; }
.btn-block{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,0.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; height:80px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand-logo{ height:46px; width:auto; display:block; border-radius:40px;}

.main-nav{ display:flex; gap:32px; }
.main-nav a{ font-size:14.5px; color:var(--ink-dim); font-weight:500; transition:color .2s; }
.main-nav a:hover{ color:var(--teal); }

.header-cta{ padding:10px 20px; font-size:14px; }
.nav-toggle{ display:none; background:none; border:none; flex-direction:column; gap:5px; cursor:pointer; }
.nav-toggle span{ width:22px; height:2px; background:var(--ink); display:block; }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:100px 0 90px;
  overflow:hidden;
  background:var(--bg-soft);
  border-bottom:1px solid var(--line);
}
.hero-contours{
  position:absolute; inset:0;
  background-image:
    repeating-radial-gradient(circle at 84% 18%, transparent 0, transparent 26px, rgba(0,146,166,0.08) 27px, transparent 28px),
    repeating-radial-gradient(circle at 84% 18%, transparent 0, transparent 60px, rgba(168,60,147,0.06) 61px, transparent 62px);
  pointer-events:none;
}
.hero-coords{
  position:absolute; top:26px; right:24px;
  font-family:var(--font-mono); font-size:11px; color:var(--ink-faint);
  letter-spacing:0.05em;
}
.hero-inner{ position:relative; max-width:720px; }
.eyebrow{
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-dim); margin-bottom:18px;
}
.hero h1{ font-size:clamp(36px,5.4vw,58px); margin-bottom:22px; font-weight:600; }
.hero-lead{ font-size:17px; max-width:560px; margin-bottom:34px; color:var(--ink-dim); }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:56px; }
.hero-stats{ display:flex; gap:40px; flex-wrap:wrap; }
.hero-stats > div{ display:flex; flex-direction:column; gap:2px; }
.stat-num{ font-family:var(--font-mono); font-size:17px; color:var(--indigo); font-weight:500; }
.stat-label{ font-size:12.5px; color:var(--ink-faint); }

/* ---------- Who section ---------- */
.who-section{ padding:80px 0; border-bottom:1px solid var(--line); }
.who-section h2{ max-width:640px; margin-bottom:44px; }
.who-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(200px,1fr)); gap:14px; }
.who-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:10px;
  padding:16px;
  transition:border-color .2s, box-shadow .2s;
}
.who-card:hover{ border-color:var(--teal); box-shadow:0 10px 24px rgba(0,146,166,0.08); }
.who-icon{ font-size:22px; display:block; margin-bottom:8px; }
.who-card h3{ font-size:16px; margin-bottom:6px; }
.who-card p{ font-size:13px; line-height:1.45; }

/* ---------- Formations ---------- */
.formations{ padding:90px 0; border-bottom:1px solid var(--line); background:var(--bg-soft); }
.formation-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:10px; }
.formation-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  display:flex; flex-direction:column;
}
.formation-card.featured{
  border-color:var(--teal);
  box-shadow:0 14px 30px rgba(0,146,166,0.1);
}
.formation-tag{
  align-self:flex-start;
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.06em;
  color:var(--teal); background:var(--teal-soft);
  padding:5px 10px; border-radius:6px; margin-bottom:16px;
}
.tag-muted{ color:var(--ink-faint); background:var(--bg-soft-2); }
.formation-desc{ font-size:14.5px; margin-bottom:18px; }
.formation-meta{ list-style:none; font-size:13.5px; margin-bottom:20px; display:flex; flex-direction:column; gap:6px; color:var(--ink-dim); }
.formation-meta strong{ color:var(--ink); }
.formation-price{ margin-bottom:20px; padding-top:16px; border-top:1px solid var(--line); }
.price-amount{ display:block; font-family:var(--font-display); font-size:26px; color:var(--magenta); font-weight:600; }
.price-detail{ font-size:12.5px; color:var(--ink-faint); }
.formation-card.placeholder{ justify-content:space-between; opacity:0.85; }
.formation-card.placeholder .btn{ margin-top:16px; }

/* ---------- Videos ---------- */
.videos{ padding:90px 0; border-bottom:1px solid var(--line); }
.video-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.video-card h4{ margin-top:12px; font-size:15px; font-weight:500; color:var(--ink); }
.video-embed{ position:relative; padding-top:56.25%; border-radius:var(--radius); overflow:hidden; background:var(--bg-soft); border:1px solid var(--line); }
.video-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.video-note{ margin-top:24px; font-size:13px; color:var(--ink-faint); }
.video-note code{ font-family:var(--font-mono); color:var(--teal); }

/* ---------- Réalisations ---------- */
.realisations{ padding:90px 0; border-bottom:1px solid var(--line); background:var(--bg-soft); }
.map-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.map-card{ background:var(--bg); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.map-card img{
  aspect-ratio: 2200/1700;
  width:100%;
  height:auto;
  object-fit:cover;
  display:block;
}
.map-placeholder span{ font-family:var(--font-body); font-size:11px; }
.map-card figcaption{ padding:12px 16px; font-size:12.5px; color:var(--ink-faint); border-top:1px solid var(--line); }

/* ---------- Inscription ---------- */
.inscription{ padding:90px 0; border-bottom:1px solid var(--line); }
.inscription-inner{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.inscription-note{ font-size:13.5px; color:var(--ink-faint); margin-top:20px; }
.inscription-form{ display:flex; flex-direction:column; gap:18px; background:var(--bg-soft); padding:28px; border-radius:var(--radius); border:1px solid var(--line); }
.inscription-form label{ display:flex; flex-direction:column; gap:8px; font-size:13.5px; color:var(--ink-dim); }
.inscription-form input, .inscription-form select, .inscription-form textarea{
  background:var(--bg);
  border:1px solid var(--line-strong);
  border-radius:8px;
  padding:11px 13px;
  color:var(--ink);
  font-family:var(--font-body);
  font-size:14.5px;
}
.inscription-form input:focus, .inscription-form select:focus, .inscription-form textarea:focus{ border-color:var(--teal); }

/* ---------- Contact ---------- */
.contact{ padding:90px 0; }
.contact-inner{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.contact-details{ display:flex; flex-direction:column; gap:0; }
.contact-row{ display:flex; justify-content:space-between; padding:16px 0; border-bottom:1px solid var(--line); font-size:14.5px; }
.contact-row span{ color:var(--ink-faint); }
.contact-row strong{ font-family:var(--font-mono); font-weight:500; color:var(--ink); }

/* ---------- Footer ---------- */
.site-footer{ padding:36px 0; border-top:1px solid var(--line); background:var(--bg-soft); }
.footer-inner{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; }
.footer-inner .brand-logo{ height:38px; }
.footer-inner p{ font-size:13px; color:var(--ink-faint); }

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .main-nav{
    display:none;
    position:absolute; top:80px; left:0; right:0;
    background:var(--bg);
    border-bottom:1px solid var(--line);
    flex-direction:column;
    padding:10px 24px 20px;
    gap:4px;
  }
  .main-nav.open{ display:flex; }
  .main-nav a{ padding:10px 0; border-bottom:1px solid var(--line); }
  .nav-toggle{ display:flex; }
  .who-grid{ grid-template-columns:repeat(2,1fr); }
  .formation-grid, .video-grid{ grid-template-columns:1fr; }
  .map-grid{ grid-template-columns:repeat(2,1fr); }
  .inscription-inner, .contact-inner{ grid-template-columns:1fr; gap:36px; }
  .header-cta{ display:none; }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
}
/* ---------- Moyens de paiement ---------- */
.payment-block{
  margin-top:28px;
  padding:22px;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.payment-block h4{
  font-family:var(--font-body);
  font-size:14px;
  font-weight:600;
  color:var(--ink);
  margin-bottom:14px;
}
.payment-methods{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:14px;
}
.payment-method{
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:8px;
  padding:12px 16px;
  font-size:14px;
}
.payment-method .method-name{
  font-weight:600;
  color:var(--ink);
}
.payment-method .method-number{
  font-family:var(--font-mono);
  color:var(--indigo);
}
.payment-note{
  font-size:12.5px;
  color:var(--ink-faint);
  line-height:1.5;
}
.payment-method{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:8px;
  padding:12px 16px;
  font-size:14px;
}
.payment-method .method-left{
  display:flex;
  align-items:center;
  gap:10px;
}
.payment-method img{
  height:22px;
  width:auto;
  object-fit:contain;
}
/* ---------- Icônes réseaux sociaux ---------- */
.social-icons{
  display:flex;
  align-items:center;
  gap:14px;
}
.social-icons a{
  display:flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:9px;
  background:var(--bg-soft-2);
  color:var(--ink-dim);
  transition:background .2s, color .2s, transform .15s;
}
.social-icons a:hover{
  background:var(--gradient-brand);
  color:#fff;
  transform:translateY(-2px);
}
.social-icons svg{
  width:18px;
  height:18px;
}
