/* ============================================================
   IVOIRE INFLUENCE — Global Stylesheet
   Charte : Bleu Marine #0D1B2A + Or #C9A840
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Instrument+Serif:ital@0;1&family=Space+Mono:wght@400;700&display=swap');

/* ── TOKENS ── */
:root {
  --navy:       #0D1B2A;
  --navy-deep:  #081219;
  --navy-mid:   #122130;
  --navy-light: #1A2E42;
  --navy-muted: #243548;

  --gold:       #C9A840;
  --gold-light: #E2C05A;
  --gold-pale:  #F0DFA0;
  --gold-dim:   rgba(201,168,64,.15);

  --text:       #EAE4D4;
  --muted:      #7A8EA0;
  --white:      #F8F6F0;

  --green:      #25D366;

  --fs-xs:   .62rem;
  --fs-sm:   .82rem;
  --fs-base: .95rem;
  --fs-md:   1.1rem;
  --fs-lg:   1.4rem;
  --fs-xl:   clamp(2rem,4vw,4rem);
  --fs-2xl:  clamp(3rem,6vw,7rem);

  --radius: 2px;
  --transition: .35s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; font-size:16px; }
body {
  background: var(--navy-deep);
  color: var(--text);
  font-family: 'Syne', sans-serif;
  overflow-x: hidden;
  cursor: none;
}
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
ul { list-style:none; }

/* ── CURSOR ── */
#cur {
  position:fixed; width:10px; height:10px;
  background:var(--gold); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .25s, height .25s, opacity .3s;
  mix-blend-mode:difference;
}
#cur-r {
  position:fixed; width:36px; height:36px;
  border:1px solid rgba(201,168,64,.55);
  border-radius:50%; pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:all .38s cubic-bezier(.25,.46,.45,.94);
}
.cursor-grow { width:22px!important; height:22px!important; }
.cursor-ring-grow { width:58px!important; height:58px!important; }

/* ── SCROLL PROGRESS ── */
#prog {
  position:fixed; top:0; left:0; height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  z-index:1001; width:0%; transition:width .1s;
}

/* ── LOADER ── */
#loader {
  position:fixed; inset:0; background:var(--navy-deep);
  z-index:10000; display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:22px;
  transition:opacity .9s ease, visibility .9s;
}
#loader.out { opacity:0; visibility:hidden; pointer-events:none; }
.ld-emblem {
  width:72px; height:72px;
  animation:ldPulse 1.4s ease-in-out infinite;
}
.ld-title {
  font-size:clamp(1.5rem,3vw,2.4rem); font-weight:800;
  color:var(--gold); letter-spacing:.28em;
  opacity:0; animation:ldFade .8s .3s ease forwards;
}
.ld-sub {
  font-family:'Space Mono',monospace; font-size:.55rem;
  letter-spacing:.3em; color:var(--muted); text-transform:uppercase;
  opacity:0; animation:ldFade .7s .6s ease forwards;
}
.ld-bar { width:160px; height:1.5px; background:rgba(201,168,64,.18); overflow:hidden; }
.ld-bar::after {
  content:''; display:block; height:100%;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  animation:ldLoad 2.2s ease forwards;
}
@keyframes ldLoad  { from{width:0} to{width:100%} }
@keyframes ldFade  { to{opacity:1} }
@keyframes ldPulse { 0%,100%{transform:scale(1);opacity:.8} 50%{transform:scale(1.1);opacity:1} }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:24px 56px;
  display:flex; align-items:center; justify-content:space-between;
  transition:all .4s ease;
}
nav.scrolled {
  background:rgba(8,18,25,.95);
  backdrop-filter:blur(24px);
  padding:14px 56px;
  border-bottom:1px solid rgba(201,168,64,.14);
  box-shadow:0 4px 40px rgba(0,0,0,.4);
}
.nav-logo {
  display:flex; align-items:center; gap:12px; text-decoration:none;
}
.nav-logo-img { width:40px; height:40px; object-fit:contain; }
.nav-logo-text { display:flex; flex-direction:column; line-height:1; }
.nav-logo-name {
  font-family:'Syne',sans-serif; font-weight:800; font-size:.95rem;
  letter-spacing:.18em; color:var(--gold);
}
.nav-logo-sub {
  font-family:'Instrument Serif',serif; font-style:italic;
  font-size:.72rem; color:var(--muted); letter-spacing:.05em;
}
.nav-links { display:flex; gap:34px; }
.nav-links a {
  font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); transition:color var(--transition); position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-5px; left:0; width:0; height:1px;
  background:var(--gold); transition:width var(--transition);
}
.nav-links a:hover,
.nav-links a.active { color:var(--gold); }
.nav-links a:hover::after,
.nav-links a.active::after { width:100%; }
.nav-cta {
  background:var(--gold); color:var(--navy-deep);
  padding:9px 22px; font-size:.7rem; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  transition:all var(--transition);
}
.nav-cta:hover { background:var(--gold-light); transform:translateY(-1px); box-shadow:0 8px 24px rgba(201,168,64,.3); }

/* ── BURGER ── */
.burger { display:none; flex-direction:column; gap:5px; padding:4px; }
.burger span { display:block; width:24px; height:1.5px; background:var(--gold); transition:all .3s; }
.burger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.burger.open span:nth-child(2) { opacity:0; }
.burger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── MOBILE MENU ── */
.mmenu {
  display:none; position:fixed; inset:0;
  background:var(--navy-deep); z-index:999;
  flex-direction:column; align-items:center; justify-content:center;
  gap:32px;
}
.mmenu.on { display:flex; }
.mmenu a {
  font-size:2rem; font-weight:800; color:var(--text);
  transition:color .3s; letter-spacing:.05em;
}
.mmenu a:hover { color:var(--gold); }
.mmenu-close {
  position:absolute; top:24px; right:28px;
  font-size:1.8rem; color:var(--muted); background:none; border:none; cursor:pointer;
}

/* ── PAGE HERO (inner pages) ── */
.page-hero {
  min-height:52vh; display:flex; align-items:flex-end; justify-content:flex-start;
  padding:140px 56px 72px; position:relative; overflow:hidden;
}
.page-hero-bg {
  position:absolute; inset:0;
  background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy-mid) 60%,var(--navy-light) 100%);
}
.page-hero-img {
  position:absolute; inset:0; object-fit:cover; width:100%; height:100%;
  opacity:.12; filter:grayscale(1);
}
.page-hero-grid {
  position:absolute; inset:0; opacity:.025;
  background-image:linear-gradient(var(--gold) 1px,transparent 1px),linear-gradient(90deg,var(--gold) 1px,transparent 1px);
  background-size:64px 64px;
}
.page-hero-accent {
  position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--gold),transparent);
}
.page-hero-content { position:relative; z-index:1; }
.page-hero-eyebrow {
  font-family:'Space Mono',monospace; font-size:.62rem;
  letter-spacing:.3em; text-transform:uppercase; color:var(--gold);
  display:flex; align-items:center; gap:14px; margin-bottom:20px;
}
.page-hero-eyebrow::before { content:''; width:32px; height:1px; background:var(--gold); }
.page-hero-title {
  font-size:clamp(2.4rem,5vw,5.5rem); font-weight:800;
  line-height:.92; letter-spacing:-.025em;
}
.page-hero-title em {
  font-family:'Instrument Serif',serif; font-style:italic;
  font-weight:400; color:var(--gold);
}

/* ── MARQUEE ── */
.mq {
  overflow:hidden; padding:24px 0;
  border-top:1px solid rgba(201,168,64,.1);
  border-bottom:1px solid rgba(201,168,64,.1);
  background:var(--navy-mid);
}
.mq-track {
  display:flex; gap:48px;
  animation:mqRun 24s linear infinite; white-space:nowrap;
}
.mq-item {
  font-family:'Instrument Serif',serif; font-style:italic;
  font-size:1.2rem; color:var(--muted); flex-shrink:0;
  display:flex; align-items:center; gap:18px;
}
.mq-item::after { content:'✦'; color:var(--gold); font-size:.7rem; font-style:normal; }
@keyframes mqRun { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── SECTION UTILS ── */
section { padding:108px 56px; }
.sec-lbl {
  font-family:'Space Mono',monospace; font-size:.6rem; letter-spacing:.3em;
  text-transform:uppercase; color:var(--gold); margin-bottom:18px;
  display:flex; align-items:center; gap:14px;
}
.sec-lbl::before { content:''; width:26px; height:1px; background:var(--gold); }
.sec-title {
  font-size:clamp(2rem,4.5vw,4.8rem); font-weight:800;
  line-height:.94; letter-spacing:-.025em; margin-bottom:18px;
}
.sec-title em { font-family:'Instrument Serif',serif; font-style:italic; font-weight:400; color:var(--gold); }
.sec-sub { font-size:var(--fs-base); color:var(--muted); line-height:1.8; max-width:500px; }

/* ── REVEAL ── */
.reveal {
  opacity:0; transform:translateY(32px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.vis { opacity:1; transform:translateY(0); }

/* ── BTN ── */
.btn-p {
  background:var(--gold); color:var(--navy-deep);
  padding:13px 30px; font-size:.72rem; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  transition:all var(--transition); display:inline-flex; align-items:center; gap:10px;
  border:2px solid var(--gold);
}
.btn-p:hover { background:var(--gold-light); border-color:var(--gold-light); transform:translateY(-2px); box-shadow:0 12px 30px rgba(201,168,64,.28); }
.btn-g {
  border:1.5px solid rgba(201,168,64,.35); color:var(--text);
  padding:13px 30px; font-size:.72rem; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  transition:all var(--transition); display:inline-flex; align-items:center; gap:10px;
  background:none;
}
.btn-g:hover { border-color:var(--gold); color:var(--gold); background:rgba(201,168,64,.05); }
.btn-navy {
  background:var(--navy-light); color:var(--gold);
  border:1.5px solid rgba(201,168,64,.25); padding:13px 30px;
  font-size:.72rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
  transition:all var(--transition); display:inline-flex; align-items:center; gap:10px;
}
.btn-navy:hover { background:var(--navy-muted); border-color:var(--gold); }

/* ── CARD BASE ── */
.card {
  background:var(--navy-mid); border:1px solid rgba(201,168,64,.09);
  transition:border-color var(--transition), background var(--transition);
}
.card:hover { border-color:rgba(201,168,64,.28); background:var(--navy-light); }

/* ── DIVIDER ── */
.divider { width:100%; height:1px; background:rgba(201,168,64,.1); margin:0; }
.divider-gold { height:3px; background:linear-gradient(90deg,var(--gold),transparent); border:none; }

/* ── TAGS ── */
.tag {
  font-family:'Space Mono',monospace; font-size:.57rem;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold); background:rgba(201,168,64,.1);
  padding:3px 10px; display:inline-block;
}

/* ── WHATSAPP FLOAT ── */
.wa-float {
  position:fixed; bottom:28px; right:28px; z-index:900;
  width:56px; height:56px; border-radius:50%;
  background:var(--green); color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.4);
  animation:waBounce 1s 2.5s ease both;
  transition:transform .3s, box-shadow .3s;
}
.wa-float:hover { transform:scale(1.1); box-shadow:0 14px 36px rgba(37,211,102,.5); }
.wa-pulse {
  position:absolute; inset:0; border-radius:50%;
  background:rgba(37,211,102,.3);
  animation:waPulse 2.2s 3s ease-out infinite;
}
.wa-tip {
  position:absolute; right:68px; top:50%; transform:translateY(-50%);
  background:var(--navy-light); color:var(--text); font-size:.7rem; font-weight:600;
  letter-spacing:.04em; white-space:nowrap; padding:7px 14px;
  border:1px solid rgba(201,168,64,.2); opacity:0; pointer-events:none;
  transition:opacity .3s;
}
.wa-float:hover .wa-tip { opacity:1; }
@keyframes waBounce { from{opacity:0;transform:scale(0) rotate(-90deg)} 50%{transform:scale(1.15)} to{opacity:1;transform:scale(1)} }
@keyframes waPulse  { 0%{transform:scale(1);opacity:.8} 100%{transform:scale(2.2);opacity:0} }

/* ── FOOTER ── */
footer {
  background:var(--navy-deep);
  border-top:1px solid rgba(201,168,64,.12);
  padding:64px 56px 36px;
}
.footer-top {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:52px;
  margin-bottom:56px;
}
.footer-brand-logo { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.footer-brand-logo img { width:48px; height:48px; object-fit:contain; }
.footer-brand-name { font-weight:800; font-size:1.1rem; color:var(--gold); letter-spacing:.15em; }
.footer-brand-tag { font-size:.82rem; color:var(--muted); line-height:1.7; margin-bottom:24px; max-width:280px; }
.footer-socials { display:flex; gap:10px; flex-wrap:wrap; }
.footer-social {
  width:38px; height:38px; border:1px solid rgba(201,168,64,.18);
  display:flex; align-items:center; justify-content:center;
  font-size:.95rem; color:var(--muted); transition:all var(--transition);
}
.footer-social:hover { border-color:var(--gold); color:var(--gold); background:rgba(201,168,64,.06); }
.footer-col-title {
  font-family:'Space Mono',monospace; font-size:.6rem;
  letter-spacing:.25em; text-transform:uppercase; color:var(--gold);
  margin-bottom:22px;
}
.footer-col ul { display:flex; flex-direction:column; gap:12px; }
.footer-col ul a {
  font-size:.8rem; color:var(--muted); transition:color .3s;
  letter-spacing:.04em;
}
.footer-col ul a:hover { color:var(--gold); }
.footer-contact-item { display:flex; flex-direction:column; gap:3px; margin-bottom:14px; }
.footer-contact-lbl { font-family:'Space Mono',monospace; font-size:.55rem; letter-spacing:.2em; color:var(--muted); text-transform:uppercase; }
.footer-contact-val { font-size:.8rem; color:var(--text); }
.footer-contact-val a { transition:color .3s; }
.footer-contact-val a:hover { color:var(--gold); }
.footer-bottom {
  border-top:1px solid rgba(201,168,64,.08);
  padding-top:28px; display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:14px;
}
.footer-copy { font-family:'Space Mono',monospace; font-size:.62rem; color:var(--muted); }
.footer-made { font-size:.72rem; color:var(--muted); display:flex; align-items:center; gap:8px; }
.footer-made span { color:var(--gold); }

/* ── FORMS ── */
.fg { display:flex; flex-direction:column; gap:7px; }
.fg label { font-family:'Space Mono',monospace; font-size:.57rem; letter-spacing:.2em; color:var(--muted); text-transform:uppercase; }
.fg input, .fg textarea, .fg select {
  background:var(--navy-mid); border:1px solid rgba(201,168,64,.16);
  color:var(--text); padding:13px 16px; font-family:'Syne',sans-serif;
  font-size:.88rem; outline:none; transition:border-color .3s;
  -webkit-appearance:none; appearance:none; border-radius:0;
}
.fg input:focus, .fg textarea:focus, .fg select:focus { border-color:var(--gold); }
.fg textarea { resize:vertical; min-height:110px; }
.fg select option { background:var(--navy-mid); }
.form-note {
  font-size:.75rem; color:var(--muted); line-height:1.65;
  padding:13px 16px; background:rgba(201,168,64,.05);
  border-left:2px solid var(--gold);
}
.wa-btn {
  background:var(--green); color:#fff; border:none;
  padding:14px 32px; font-family:'Syne',sans-serif;
  font-size:.74rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
  cursor:pointer; transition:all .3s;
  display:inline-flex; align-items:center; gap:10px; align-self:flex-start;
}
.wa-btn:hover { background:#1fbe55; transform:translateY(-2px); box-shadow:0 10px 28px rgba(37,211,102,.3); }

/* ── TABS ── */
.tabs { display:flex; gap:2px; margin-bottom:32px; }
.tab-btn {
  padding:11px 24px; background:var(--navy-mid);
  border:1px solid rgba(201,168,64,.12);
  font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted); cursor:pointer; transition:all .3s; border-bottom:none;
}
.tab-btn.active { background:var(--gold); color:var(--navy-deep); border-color:var(--gold); }

/* ── BREADCRUMB ── */
.breadcrumb {
  position:absolute; top:0; left:56px; right:56px;
  padding:20px 0;
  font-family:'Space Mono',monospace; font-size:.58rem;
  letter-spacing:.14em; text-transform:uppercase;
  display:flex; align-items:center; gap:12px; color:var(--muted); z-index:2;
}
.breadcrumb a { color:var(--muted); transition:color .3s; }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb-sep { color:var(--gold); opacity:.4; }
.breadcrumb-current { color:var(--gold); }

/* ── INNOVATIONS NAV BADGE ── */
.nav-innov-link {
  position: relative;
  color: var(--gold) !important;
  font-weight: 700 !important;
}
.nav-innov-link::after { background: var(--gold) !important; }
.nav-innov-badge {
  display: inline-flex; align-items: center;
  background: linear-gradient(135deg, var(--gold), var(--gold-light));
  color: var(--navy-deep);
  font-size: .48rem; font-weight: 800; letter-spacing: .1em;
  padding: 2px 7px; border-radius: 20px;
  margin-right: 5px; vertical-align: middle;
  animation: badgePulse 2.5s ease-in-out infinite;
}
@keyframes badgePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201,168,64,.4); }
  50%       { box-shadow: 0 0 0 6px rgba(201,168,64,0); }
}

/* ── INNOVATIONS PAGE ── */
.innov-hero-glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 80% 50%, rgba(201,168,64,.12) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 20% 80%, rgba(100,160,255,.06) 0%, transparent 50%);
}
.innov-particles { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.innov-particles span {
  position: absolute; width: 2px; height: 2px;
  background: var(--gold); border-radius: 50%;
  animation: floatPart linear infinite;
  opacity: 0;
}
@keyframes floatPart {
  0%   { transform: translateY(100vh) translateX(0); opacity: 0; }
  10%  { opacity: .6; }
  90%  { opacity: .3; }
  100% { transform: translateY(-10vh) translateX(60px); opacity: 0; }
}
.innov-grid-bg {
  position: absolute; inset: 0; opacity: .025;
  background-image:
    linear-gradient(var(--gold) 1px, transparent 1px),
    linear-gradient(90deg, var(--gold) 1px, transparent 1px);
  background-size: 48px 48px;
}
/* Project cards */
.innov-projects { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; margin-top: 72px; }
.ip-card {
  position: relative; overflow: hidden;
  border: 1px solid rgba(201,168,64,.12);
  background: var(--navy-mid);
  transition: all .4s ease;
  cursor: pointer;
}
.ip-card:hover { border-color: rgba(201,168,64,.4); transform: translateY(-4px); box-shadow: 0 24px 60px rgba(0,0,0,.5); }
.ip-card.featured { grid-column: span 2; display: grid; grid-template-columns: 1fr 1fr; }
.ip-card-visual {
  position: relative; overflow: hidden; min-height: 320px;
}
.ip-card.featured .ip-card-visual { min-height: 420px; }
.ip-card:not(.featured) .ip-card-visual { min-height: 220px; }
.ip-visual-bg {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.ip-visual-canvas { width: 100%; height: 100%; }
.ip-card-body { padding: 44px 40px; display: flex; flex-direction: column; justify-content: center; }
.ip-card:not(.featured) .ip-card-body { padding: 32px 28px; }
.ip-status {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Space Mono', monospace; font-size: .56rem;
  letter-spacing: .2em; text-transform: uppercase;
  padding: 5px 12px; margin-bottom: 24px; width: fit-content;
}
.ip-status.live { background: rgba(37,211,102,.12); color: #25D366; border: 1px solid rgba(37,211,102,.25); }
.ip-status.soon { background: rgba(201,168,64,.1); color: var(--gold); border: 1px solid rgba(201,168,64,.2); }
.ip-status.dev  { background: rgba(100,149,237,.1); color: #6495ED; border: 1px solid rgba(100,149,237,.2); }
.ip-status-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; animation: dotBlink 1.4s ease-in-out infinite; }
.ip-status.live .ip-status-dot { box-shadow: 0 0 0 0 rgba(37,211,102,.4); animation: dotPing 1.4s infinite; }
@keyframes dotBlink { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes dotPing { 0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)} 100%{box-shadow:0 0 0 10px rgba(37,211,102,0)} }
.ip-tag { margin-bottom: 16px; }
.ip-title { font-size: clamp(1.6rem, 3vw, 2.8rem); font-weight: 800; line-height: 1; letter-spacing: -.02em; margin-bottom: 16px; }
.ip-card:not(.featured) .ip-title { font-size: 1.4rem; }
.ip-title em { font-family: 'Instrument Serif', serif; font-style: italic; font-weight: 400; color: var(--gold); }
.ip-subtitle { font-size: .88rem; color: var(--gold); font-family: 'Space Mono', monospace; letter-spacing: .08em; margin-bottom: 20px; }
.ip-desc { font-size: .9rem; color: var(--muted); line-height: 1.78; margin-bottom: 28px; }
.ip-card:not(.featured) .ip-desc { font-size: .83rem; }
.ip-features { display: flex; flex-direction: column; gap: 10px; margin-bottom: 32px; }
.ip-feat { display: flex; align-items: flex-start; gap: 12px; font-size: .82rem; color: var(--muted); }
.ip-feat-icon { color: var(--gold); flex-shrink: 0; font-size: .9rem; margin-top: 1px; }
.ip-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.ip-stats { display: flex; gap: 28px; margin-top: 28px; padding-top: 28px; border-top: 1px solid rgba(201,168,64,.1); }
.ip-stat-n { font-size: 1.8rem; font-weight: 800; color: var(--gold); display: block; line-height: 1; }
.ip-stat-l { font-family: 'Space Mono', monospace; font-size: .52rem; color: var(--muted); letter-spacing: .1em; text-transform: uppercase; }

/* Roadmap */
.innov-roadmap { margin-top: 72px; }
.roadmap-line { position: relative; }
.roadmap-line::before { content: ''; position: absolute; left: 24px; top: 0; bottom: 0; width: 1px; background: linear-gradient(to bottom, var(--gold), rgba(201,168,64,.1)); }
.roadmap-item { display: flex; gap: 32px; margin-bottom: 40px; position: relative; }
.roadmap-dot { width: 50px; height: 50px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 1.3rem; position: relative; z-index: 1; }
.roadmap-dot.done { background: var(--gold); }
.roadmap-dot.active { background: var(--navy-mid); border: 2px solid var(--gold); animation: rdotPulse 2s ease-in-out infinite; }
.roadmap-dot.future { background: var(--navy-mid); border: 1px solid rgba(201,168,64,.2); }
@keyframes rdotPulse { 0%,100%{box-shadow:0 0 0 0 rgba(201,168,64,.4)} 50%{box-shadow:0 0 0 12px rgba(201,168,64,0)} }
.roadmap-content { padding-top: 10px; }
.roadmap-q { font-family: 'Space Mono', monospace; font-size: .58rem; letter-spacing: .2em; color: var(--gold); text-transform: uppercase; margin-bottom: 6px; }
.roadmap-title { font-size: 1.1rem; font-weight: 800; margin-bottom: 8px; }
.roadmap-desc { font-size: .83rem; color: var(--muted); line-height: 1.7; }

/* CTA strip innov */
.innov-cta-strip {
  background: linear-gradient(135deg, var(--navy-deep) 0%, var(--navy-mid) 50%, var(--navy-deep) 100%);
  border-top: 1px solid rgba(201,168,64,.15);
  border-bottom: 1px solid rgba(201,168,64,.15);
  padding: 80px 56px;
  text-align: center; position: relative; overflow: hidden;
}
.innov-cta-strip::before {
  content: '';position:absolute;inset:0;
  background: radial-gradient(ellipse 60% 80% at 50% 50%, rgba(201,168,64,.06), transparent);
}

/* Waitlist form */
.waitlist-form {
  display: flex; gap: 0; max-width: 520px; margin: 32px auto 0;
}
.waitlist-form input {
  flex: 1; background: var(--navy-mid); border: 1px solid rgba(201,168,64,.2);
  border-right: none; color: var(--text); padding: 14px 18px;
  font-family: 'Syne', sans-serif; font-size: .88rem; outline: none;
  transition: border-color .3s;
}
.waitlist-form input:focus { border-color: var(--gold); }
.waitlist-form button {
  background: var(--gold); color: var(--navy-deep); border: none;
  padding: 14px 24px; font-family: 'Syne', sans-serif;
  font-size: .72rem; font-weight: 800; letter-spacing: .14em;
  text-transform: uppercase; cursor: pointer; white-space: nowrap;
  transition: background .3s;
}
.waitlist-form button:hover { background: var(--gold-light); }

@media(max-width:1024px) {
  .innov-projects { grid-template-columns: 1fr; }
  .ip-card.featured { grid-column: span 1; grid-template-columns: 1fr; }
  .ip-card.featured .ip-card-visual { min-height: 240px; }
  .innov-cta-strip { padding: 64px 22px; }
  .waitlist-form { flex-direction: column; }
  .waitlist-form input { border-right: 1px solid rgba(201,168,64,.2); border-bottom: none; }
}

  nav { padding:18px 22px; }
  nav.scrolled { padding:13px 22px; }
  .nav-links, .nav-cta { display:none; }
  .burger { display:flex; }
  section { padding:80px 22px; }
  .page-hero { padding:120px 22px 60px; }
  .breadcrumb { left:22px; right:22px; }
  footer { padding:56px 22px 32px; }
  .footer-top { grid-template-columns:1fr 1fr; gap:36px; }
  .footer-brand { grid-column:span 2; }
}
@media(max-width:600px) {
  .footer-top { grid-template-columns:1fr; }
  .footer-brand { grid-column:span 1; }
  .tabs { flex-wrap:wrap; }
}
