/* ═══ RESET & ROOT ═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  --bg:#f4f2ee;--surface:#faf8f3;--surface-2:#ebe8e2;--border:rgba(15,23,42,.10);--text:#0f172a;--text-soft:#475569;--text-mute:#94a3b8;--accent:#2563eb;--accent-dim:rgba(37,99,235,.07);--accent-border:rgba(37,99,235,.22);--purple:#7c3aed;--green:#16a34a;--red:#dc2626;
  --font:   'DM Sans',sans-serif;
  --mono:   'JetBrains Mono',monospace;
  --serif:  'Playfair Display',serif;
  --max:    1160px;
  --r:      14px;
  --r-lg:   20px;
}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font);
  font-size:15px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  max-width:100vw;
}
html{overflow-x:hidden;max-width:100vw}

/* Grid overlay */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(59,130,246,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(59,130,246,.025) 1px,transparent 1px);
  background-size:60px 60px;
  pointer-events:none;z-index:0;
}
a{text-decoration:none;color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px;position:relative;z-index:1;box-sizing:border-box}
.wrap-sm{max-width:760px;margin:0 auto;padding:0 32px;position:relative;z-index:1}
section{padding:90px 0;border-top:none;position:relative;z-index:1}

/* ═══ NAV ════════════════════════════════════════════════════ */
nav{
  position:sticky;top:0;z-index:200;
  height:58px;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:border-color .3s;
}
.nav-inner{
  max-width:var(--max);margin:0 auto;
  padding:0 32px;height:100%;
  display:flex;align-items:center;gap:0;
}
.logo-wordmark{
  font-family:var(--mono);font-size:15px;font-weight:700;
  background:linear-gradient(135deg,#60a5fa,#a78bfa);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:.02em;
}
.logo-wordmark span{
  font-weight:400;
  background:linear-gradient(135deg,rgba(96,165,250,.55),rgba(167,139,250,.55));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.nav-badge{
  font-family:var(--mono);font-size:9px;
  padding:3px 9px;border-radius:999px;
  background:var(--accent-dim);border:1px solid var(--accent-border);
  color:var(--accent2);letter-spacing:.08em;text-transform:uppercase;
}
.nav-links{
  display:flex;align-items:center;gap:2px;flex:1;
}
.nav-links a{
  font-size:13px;font-weight:500;
  color:var(--text3);
  padding:5px 12px;border-radius:8px;
  transition:color .15s,background .15s;
  white-space:nowrap;
}
.nav-links a:hover{color:var(--text);background:var(--border)}
.nav-actions{display:flex;align-items:center;gap:10px;margin-left:auto}

.lang-toggle{
  display:flex;gap:2px;padding:3px;
  background:var(--border);
  border-radius:8px;border:1px solid var(--border);
}
.lang-btn{
  font-family:var(--mono);font-size:10px;font-weight:600;
  padding:3px 10px;border-radius:6px;
  border:none;background:transparent;color:var(--text3);
  cursor:pointer;transition:all .12s;letter-spacing:.05em;
}
.lang-btn.active{background:var(--border);color:var(--text)}

.cta-nav{
  font-family:var(--font);font-size:13px;font-weight:700;
  padding:8px 18px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),#2563eb);
  color:var(--text);border:none;cursor:pointer;
  transition:transform .15s,box-shadow .15s;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 4px 16px rgba(59,130,246,.25);
}
.cta-nav:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(59,130,246,.35)}
@media(max-width:920px){.nav-links{display:none}.nav-burger{display:flex}}
@media(max-width:600px){.wrap{padding:0 20px}.wrap-sm{padding:0 20px}}

/* ═══ MARQUEE ════════════════════════════════════════════════ */
.marquee-strip{
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:14px 0;overflow:hidden;
  max-width:100vw;
  background:var(--border);
}
.marquee{display:flex;gap:48px;animation:scroll-x 32s linear infinite;width:max-content}
.marquee span{
  font-family:var(--mono);font-size:11px;
  color:var(--text3);letter-spacing:.05em;
  white-space:nowrap;text-transform:uppercase;
}
.marquee span::before{content:'/ ';color:var(--accent);margin-right:4px;opacity:.6}
@keyframes scroll-x{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ═══ HERO ═══════════════════════════════════════════════════ */
.hero{
  padding:130px 0 100px;
  border-top:none;
  position:relative;
  min-height:82vh;
  display:flex;align-items:center;
  overflow:hidden;
}
/* Glow orbs */
.hero::before,.hero::after{
  content:'';
  position:absolute;border-radius:50%;
  filter:blur(120px);opacity:.14;
  pointer-events:none;
}
.hero::before{
  width:400px;height:400px;
  background:radial-gradient(circle,#3b82f6,transparent 70%);
  top:-60px;left:-60px;
}
.hero::after{
  width:300px;height:300px;
  background:radial-gradient(circle,#8b5cf6,transparent 70%);
  top:40px;right:-40px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;font-weight:700;
  color:var(--accent2);letter-spacing:.05em;
  margin-bottom:24px;
  padding:7px 16px;
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.24);
  border-radius:999px;
}
.hero-eyebrow .sep{display:none}
.hero-eyebrow .tag{color:var(--accent2)}
.hero-eyebrow::before{
  content:'';display:block;
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);flex-shrink:0;
}
.hero h1{
  font-family:var(--serif);
  font-size:clamp(48px,6vw,78px);
  font-weight:800;
  letter-spacing:-.04em;
  line-height:1.04;
  margin-bottom:22px;
  color:#15171c;
  -webkit-text-fill-color:#15171c;
}
.hero h1 .light{
  font-weight:800;font-style:normal;
  background:linear-gradient(115deg,#2563eb,#6d28d9 60%,#7c3aed);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-desc{
  font-size:18px;font-weight:400;
  color:var(--text2);line-height:1.7;
  max-width:560px;margin-bottom:36px;
}
.hero-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.pill{
  font-family:var(--mono);font-size:11px;font-weight:500;
  padding:7px 13px;border-radius:999px;
  background:var(--border);border:1px solid var(--border);
  color:var(--text-soft);letter-spacing:.02em;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* ═══ BUTTONS ═══════════════════════════════════════════════ */
.btn-p{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font);font-size:15px;font-weight:700;
  padding:13px 26px;border-radius:12px;
  background:linear-gradient(135deg,#3b82f6,#2563eb);
  color:var(--text);
  box-shadow:0 4px 20px rgba(59,130,246,.3);
  transition:transform .15s,box-shadow .15s;
}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(59,130,246,.42)}
.btn-s{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font);font-size:15px;font-weight:600;
  padding:13px 26px;border-radius:12px;
  background:var(--border);color:var(--text);
  border:1px solid var(--border);
  transition:all .15s;
}
.btn-s:hover{background:var(--border);border-color:var(--text-mute)}

/* ═══ SECTION HEADERS ═══════════════════════════════════════ */
.sh{margin-bottom:56px}
.sh .label{
  font-family:var(--mono);font-size:11px;font-weight:700;
  color:var(--accent2);letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:16px;display:flex;align-items:center;gap:10px;
}
.sh .label::before{
  content:'';display:block;width:18px;height:2px;
  background:linear-gradient(to right,var(--accent),var(--purple));
  flex-shrink:0;border-radius:1px;
}
.sh h2{
  font-family:var(--serif);
  font-size:clamp(30px,3.6vw,46px);
  font-weight:700;letter-spacing:-.02em;
  color:var(--text);line-height:1.1;margin-bottom:16px;
}
.sh h2 .dim{font-weight:700;font-style:italic;color:var(--text-mute)}
.sh p{font-size:16px;color:var(--text2);max-width:560px;line-height:1.7}
.sh.center{text-align:center}
.sh.center p{margin:0 auto}
.sh.center .label{justify-content:center}
.sh.center .label::before{display:none}

/* ═══ PLATFORM CARDS ════════════════════════════════════════ */
.platform-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:900px;margin:0 auto;
}
.p-card{
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:28px 24px;
  transition:transform .25s,border-color .2s,background .2s;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.p-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:transparent;
  transition:background .2s;
  border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.p-card:hover{
  transform:translateY(-4px);
  border-color:rgba(59,130,246,.32);
  background:rgba(59,130,246,.04);
}
.p-card:hover::before{background:linear-gradient(to right,var(--accent),var(--purple))}
.p-card.span2{grid-column:span 2}
.p-num{
  font-family:var(--mono);font-size:10px;color:var(--accent2);
  margin-bottom:18px;letter-spacing:.08em;font-weight:700;text-transform:uppercase;
}
.p-card h3{
  font-size:16px;font-weight:700;color:var(--text);
  margin-bottom:10px;letter-spacing:-.01em;
}
.p-card p{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:18px;flex:1}
.p-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.p-tag{
  font-family:var(--mono);font-size:10px;font-weight:600;
  padding:3px 9px;border-radius:5px;
  background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.2);
  color:#a78bfa;
}
@media(max-width:800px){.platform-grid{grid-template-columns:1fr 1fr}.p-card.span2{grid-column:span 2}}
@media(max-width:540px){.platform-grid{grid-template-columns:1fr}.p-card.span2{grid-column:span 1}}

/* ═══ HOW IT WORKS ══════════════════════════════════════════ */
.how-list{max-width:680px;margin:0 auto}
.how-item{
  display:grid;grid-template-columns:48px 1fr;gap:20px;
  padding:24px 0;border-bottom:1px solid var(--border);
}
.how-item:last-child{border-bottom:none}
.how-n{
  font-family:var(--mono);font-size:13px;color:var(--accent2);
  font-weight:700;padding-top:3px;
  background:linear-gradient(135deg,#60a5fa,#a78bfa);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.how-item h4{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:-.01em}
.how-item p{font-size:13px;color:var(--text2);line-height:1.7}

/* ═══ WHY COMPARISON ════════════════════════════════════════ */
.why-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  max-width:780px;margin:0 auto;
}
.why-col{border-radius:var(--r-lg);overflow:hidden}
.why-col.bad{
  background:rgba(239,68,68,.04);
  border:1px solid rgba(239,68,68,.2);
}
.why-col.good{
  background:rgba(34,197,94,.04);
  border:1px solid rgba(34,197,94,.22);
}
.why-head{
  padding:14px 22px;
  font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  border-bottom:1px solid var(--border);
}
.why-col.bad .why-head{color:var(--red);background:rgba(239,68,68,.05)}
.why-col.good .why-head{color:var(--green);background:rgba(34,197,94,.05)}
.why-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 22px;font-size:13px;color:var(--text2);
  border-bottom:1px solid var(--border);
}
.why-row:last-child{border-bottom:none}
.why-row .mk{font-family:var(--mono);font-size:13px;flex-shrink:0;font-weight:700}
.why-col.bad .mk{color:var(--red)}
.why-col.good .mk{color:var(--green)}
@media(max-width:540px){.why-grid{grid-template-columns:1fr}}

/* ═══ BLINDSPOTS ════════════════════════════════════════════ */
.bs-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin-bottom:16px;
}
.bs-item{
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:22px;transition:border-color .2s,transform .2s;
  display:flex;flex-direction:column;gap:12px;
}
.bs-item:hover{border-color:rgba(59,130,246,.28);transform:translateY(-2px)}
.bs-n{font-family:var(--mono);font-size:10px;color:var(--accent2);letter-spacing:.06em;font-weight:700}
.bs-item p{font-size:13px;color:var(--text2);line-height:1.65}

.sovereignty-table{
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;margin-bottom:16px;
}
.st-head{
  display:grid;grid-template-columns:200px 1fr;
  padding:12px 22px;background:var(--surface);
  border-bottom:1px solid var(--border);
  font-family:var(--mono);font-size:10px;color:var(--text3);
  letter-spacing:.06em;text-transform:uppercase;font-weight:600;
}
.st-row{
  display:grid;grid-template-columns:200px 1fr;
  padding:14px 22px;border-bottom:1px solid var(--border);
  background:var(--bg);transition:background .15s;
}
.st-row:last-child{border-bottom:none}
.st-row:hover{background:var(--bg2)}
.st-row .k{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}
.st-row .k::before{
  content:'';display:block;width:5px;height:5px;border-radius:50%;
  background:var(--accent);flex-shrink:0;
}
.st-row .v{font-size:13px;color:var(--text2)}
.shadow-box{
  padding:28px 32px;
  background:rgba(59,130,246,.04);
  border:1px solid rgba(59,130,246,.18);
  border-radius:var(--r-lg);
  margin-top:20px;
}
.shadow-box h4{font-size:16px;font-weight:700;color:var(--text);margin-bottom:10px}
.shadow-box p{font-size:13px;color:var(--text2);line-height:1.75;margin-bottom:16px}
.shadow-chips{display:flex;flex-wrap:wrap;gap:7px}
.shadow-chips span{
  font-family:var(--mono);font-size:11px;
  padding:4px 11px;border-radius:6px;
  background:var(--border);border:1px solid var(--border2);
  color:var(--text3);
}
.disclaimer{
  font-family:var(--mono);font-size:11px;color:var(--text3);
  line-height:1.65;padding-top:14px;border-top:1px solid var(--border);
  margin-top:14px;
}
@media(max-width:700px){.bs-grid{grid-template-columns:1fr 1fr}.st-head{grid-template-columns:140px 1fr}.st-row{grid-template-columns:140px 1fr}}
@media(max-width:480px){.bs-grid{grid-template-columns:1fr}}

/* ═══ AI DEV ═════════════════════════════════════════════════ */
.aidev-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.aidev-card{
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:28px 24px;transition:transform .25s,border-color .2s;
}
.aidev-card:hover{transform:translateY(-4px);border-color:rgba(59,130,246,.3)}
.aidev-card .ico{font-size:22px;margin-bottom:16px;color:var(--accent2)}
.aidev-card h4{font-size:15px;font-weight:700;color:var(--text);margin-bottom:10px}
.aidev-card p{font-size:13px;color:var(--text2);line-height:1.7}
.aidev-note{
  margin-top:16px;padding:14px 20px;
  background:var(--border);
  border:1px solid var(--border);border-radius:10px;
  font-family:var(--mono);font-size:11px;color:var(--text3);
  display:flex;align-items:center;gap:10px;
}
.aidev-note::before{content:'-';color:var(--accent2)}
@media(max-width:640px){.aidev-grid{grid-template-columns:1fr}}

/* ═══ SECTORS ════════════════════════════════════════════════ */
.sectors-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
}
.sector{
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
  border-radius:var(--r-lg);padding:28px;
  transition:transform .25s,border-color .2s;
}
.sector:hover{transform:translateY(-3px);border-color:rgba(59,130,246,.3)}
.sector-label{
  font-family:var(--mono);font-size:10px;font-weight:700;
  color:var(--accent2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;
}
.sector h4{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px}
.sector p{font-size:13px;color:var(--text2);line-height:1.65}
@media(max-width:540px){.sectors-grid{grid-template-columns:1fr}}

/* ═══ SECURITY TABLE ════════════════════════════════════════ */
.sec-tbl{
  border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;
}
.sec-th{
  display:grid;grid-template-columns:180px 110px 1fr;
  padding:12px 22px;background:var(--surface);border-bottom:1px solid var(--border);
  font-family:var(--mono);font-size:10px;color:var(--text3);
  letter-spacing:.06em;text-transform:uppercase;font-weight:600;
}
.sec-tr{
  display:grid;grid-template-columns:180px 110px 1fr;
  padding:13px 22px;border-bottom:1px solid var(--border);
  background:var(--bg);transition:background .15s;align-items:center;
}
.sec-tr:last-child{border-bottom:none}
.sec-tr:hover{background:var(--bg2)}
.sec-tr .n{font-size:13px;font-weight:600;color:var(--text)}
.sec-tr .t{
  font-family:var(--mono);font-size:10px;color:var(--accent2);
  background:rgba(96,165,250,.08);padding:2px 8px;border-radius:4px;
  width:fit-content;font-weight:700;
}
.sec-tr .d{font-size:13px;color:var(--text2)}
@media(max-width:700px){
  .sec-th{grid-template-columns:140px 1fr}
  .sec-tr{grid-template-columns:140px 1fr}
  .sec-th div:nth-child(2),.sec-tr .t{display:none}
}

/* ═══ REGULATORY ═════════════════════════════════════════════ */
.reg-box{
  max-width:700px;margin:0 auto;
  background:var(--border);
  border:1px solid var(--border);border-radius:var(--r-lg);
  border-left:3px solid var(--accent);
  padding:28px 32px;
}
.reg-box p{font-size:15px;color:var(--text2);line-height:1.8;margin-bottom:16px}
.reg-box p:last-of-type{margin-bottom:20px}
.reg-note{
  font-family:var(--mono);font-size:11px;color:var(--text3);
  line-height:1.65;padding:14px 16px;
  background:var(--border);border:1px solid var(--border);border-radius:8px;
}

/* ═══ FAQ ════════════════════════════════════════════════════ */
.faq-wrap{max-width:700px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--border);
  border-radius:0;transition:background .15s;
}
.faq-q{
  padding:20px 0;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-size:15px;font-weight:600;color:var(--text);user-select:none;
  transition:color .15s;
}
.faq-q:hover{color:var(--text)}
.faq-ico{
  font-family:var(--mono);font-size:16px;color:var(--text3);
  transition:transform .2s,color .15s;flex-shrink:0;
}
.faq-item.open .faq-ico{transform:rotate(45deg);color:var(--accent2)}
.faq-a{display:none;padding:0 0 20px}
.faq-item.open .faq-a{display:block}
.faq-a p{font-size:14px;color:var(--text2);line-height:1.8}

/* ═══ CTA FINAL ══════════════════════════════════════════════ */
.cta-final{
  text-align:center;padding:100px 0;
  border-top:1px solid var(--border);
}
.cta-final-inner{
  max-width:700px;margin:0 auto;
  background:linear-gradient(135deg,rgba(59,130,246,.09),rgba(139,92,246,.06));
  border:1px solid rgba(59,130,246,.18);
  border-radius:24px;padding:64px 48px;
}
.cta-final h2{
  font-family:var(--serif);
  font-size:clamp(34px,4vw,52px);
  font-weight:700;letter-spacing:-.03em;
  color:var(--text);margin-bottom:16px;line-height:1.1;
}
.cta-final h2 .dim{font-style:italic;color:var(--text-mute)}
.cta-final p{font-size:16px;color:var(--text2);max-width:480px;margin:0 auto 36px;line-height:1.75}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ═══ PROBLEM SECTION INLINE STYLES ═════════════════════════ */
/* The problem section uses inline styles, we override the generic containers */
section > .wrap > div[style*="grid-template-columns:1fr 1fr"] > div:last-child{
  border-radius:var(--r-lg);overflow:hidden;
}

/* ═══ FOOTER ══════════════════════════════════════════════════ */
footer{
  border-top:1px solid var(--border);padding:56px 0 32px;
  position:relative;z-index:1;
}
.footer-wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
.footer-top{
  display:flex;justify-content:space-between;
  gap:40px;flex-wrap:wrap;margin-bottom:40px;
}
.footer-brand .wm{
  font-family:var(--mono);font-size:15px;font-weight:700;
  background:linear-gradient(135deg,#60a5fa,#a78bfa);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.footer-brand .wm span{
  font-weight:400;
  background:linear-gradient(135deg,rgba(96,165,250,.55),rgba(167,139,250,.55));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.footer-brand .sub{
  font-family:var(--mono);font-size:11px;color:var(--text3);
  margin-top:6px;letter-spacing:.04em;
}
.footer-cols{display:flex;gap:56px;flex-wrap:wrap}
.fc{display:flex;flex-direction:column;gap:10px}
.fc-title{
  font-family:var(--mono);font-size:10px;color:var(--text3);
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;font-weight:700;
}
.fc a{font-size:13px;color:var(--text3);transition:color .15s}
.fc a:hover{color:var(--text)}
.footer-bottom{
  border-top:1px solid var(--border);padding-top:24px;
  display:flex;justify-content:space-between;gap:20px;
  align-items:flex-start;flex-wrap:wrap;
}
.footer-legal p{font-size:11px;color:var(--text3);line-height:1.7;max-width:640px}
.footer-chips{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}
.f-chip{
  font-family:var(--mono);font-size:10px;
  padding:3px 11px;border-radius:999px;
  border:1px solid var(--border);color:var(--text3);letter-spacing:.04em;
}

/* ═══ FLOATING CTA ═══════════════════════════════════════════ */
#fcta{
  position:fixed;bottom:24px;right:24px;z-index:500;
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,#3b82f6,#8b5cf6);
  color:var(--text);font-family:var(--font);
  font-size:14px;font-weight:700;
  padding:12px 24px;border-radius:50px;
  box-shadow:0 8px 32px rgba(59,130,246,.4);
  opacity:0;transition:opacity .4s,transform .2s,box-shadow .2s;cursor:pointer;
}
#fcta:hover{transform:scale(1.04);box-shadow:0 12px 40px rgba(59,130,246,.5)}
#fcta .arr{font-family:var(--mono);opacity:.8}

/* ═══ LANG ═══════════════════════════════════════════════════ */
[data-en]{display:none}
body.lang-en [data-fr]{display:none}
body.lang-en [data-en]{display:unset}
body.lang-en p[data-en],body.lang-en div[data-en],body.lang-en li[data-en],
body.lang-en h1[data-en],body.lang-en h2[data-en],body.lang-en h3[data-en],
body.lang-en h4[data-en],body.lang-en span[data-en]{display:block}
body.lang-en a[data-en]{display:inline-flex}

/* ═══ PROBLEM SECTION ════════════════════════════════════════ */
/* Inline-styled problem list gets design tokens via CSS vars */

/* Hero clarifier */
.hero-clarifier{
  font-family:var(--mono);font-size:12px;font-weight:500;
  color:var(--text3);line-height:1.6;
  max-width:520px;
  margin-top:-20px;margin-bottom:32px;
  letter-spacing:.01em;
}
.hero-clarifier::before{
  content:'';display:inline-block;
  width:18px;height:1px;
  background:linear-gradient(to right,var(--accent),var(--purple));
  vertical-align:middle;margin-right:10px;
}

/* ═══ MOBILE, RESPONSIVE COMPLET ══════════════════════════════════════ */
@media(max-width:768px){

  /* Hero */
  .hero{padding:100px 0 64px;min-height:auto}
  .hero h1{font-size:clamp(36px,8vw,52px)}
  .hero-desc{font-size:16px}
  .hero-clarifier{font-size:11px}
  .hero-ctas{flex-direction:column;gap:10px}
  .hero-ctas .btn-p,.hero-ctas .btn-s{width:100%;justify-content:center}
  .hero-pills{gap:6px}

  /* Section padding */
  section{padding:56px 0}

  /* Problem section, 2-col → 1-col */
  section > .wrap > div[style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
    gap:28px !important;
  }

  /* Platform */
  .platform-grid{grid-template-columns:1fr}
  .p-card.span2{grid-column:span 1}

  /* Why comparison */
  .why-grid{grid-template-columns:1fr;max-width:100%}

  /* Blindspots */
  .bs-grid{grid-template-columns:1fr 1fr}
  .sovereignty-table{overflow-x:auto}
  .st-head,.st-row{grid-template-columns:130px 1fr;font-size:12px}

  /* AI Dev */
  .aidev-grid{grid-template-columns:1fr}

  /* Sectors */
  .sectors-grid{grid-template-columns:1fr}

  /* Security table */
  .sec-tbl{overflow-x:auto}
  .sec-th,.sec-tr{grid-template-columns:130px 1fr;font-size:12px}
  .sec-th div:nth-child(2),.sec-tr .t{display:none}

  /* Regulatory */
  .reg-box{padding:20px 18px}

  /* CTA Final */
  .cta-final-inner{padding:40px 24px}
  .cta-final h2{font-size:clamp(28px,6vw,38px)}
  .cta-btns{flex-direction:column;gap:10px}
  .cta-btns .btn-p,.cta-btns .btn-s{width:100%;justify-content:center}

  /* Footer */
  .footer-wrap{padding:0 20px}
  .footer-top{flex-direction:column;gap:32px}
  .footer-cols{flex-direction:column;gap:28px}
  .footer-bottom{flex-direction:column;gap:16px}

  /* Floating CTA */
  #fcta{bottom:16px;right:16px;padding:10px 18px;font-size:13px}

  /* How it works */
  .how-item{gap:14px}

  /* Section headers */
  .sh{margin-bottom:36px}
  .sh h2{font-size:clamp(26px,6vw,36px)}

  /* Modal */
  #modal-panel{padding:28px 20px;border-radius:16px;margin:0 4px}
  #modal-panel > div[style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
  }
}

@media(max-width:480px){
  .bs-grid{grid-template-columns:1fr}
  .hero-eyebrow{font-size:10px;padding:5px 12px}
  .nav-badge{display:none}
  .wrap{padding:0 16px}
  .how-item{grid-template-columns:32px 1fr;gap:12px}
  .how-n{font-size:11px}
}

@media(max-width:500px){
  .modal-name-row{grid-template-columns:1fr !important}
}

@media(max-width:400px){
  .lang-toggle{display:none}
  .cta-nav{font-size:12px;padding:7px 12px}
  .logo-wordmark{font-size:13px}
}
@media(max-width:980px){}
.nav-logo{display:inline-flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap;flex-shrink:0}
.nav-company{font-family:var(--font);font-weight:700;font-size:15px;color:var(--text);letter-spacing:-.01em;white-space:nowrap}
.nav-dash{color:var(--text-soft);font-weight:400}
.nav-logo-ic{width:26px;height:26px;border-radius:7px;display:block}
.nav-product{font-family:var(--serif);font-weight:800;font-size:17px;white-space:nowrap;background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
@media(max-width:680px){
.nav-company,.nav-dash{display:none}
.nav-product{font-size:16px}
.nav-logo-ic{width:24px;height:24px}
.cta-nav{padding:8px 12px!important;font-size:12px!important}
}
@media(max-width:430px){
.cta-nav span[data-fr]{font-size:0}
.cta-nav span[data-fr]::after{content:'Démo';font-size:12px}
.cta-nav span[data-en]{font-size:0}
.cta-nav span[data-en]::after{content:'Demo';font-size:12px}
}
/* --- Scroll reveal animations --- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
/* --- Modern hover on cards --- */
.feat-card,.explore-card{transition:transform .25s cubic-bezier(.16,1,.3,1),border-color .25s,box-shadow .25s}
.feat-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(15,23,42,.10)}
/* --- Browser frame subtle float on hover --- */
.browser-frame{transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s}
.browser-frame:hover{transform:translateY(-5px);box-shadow:0 36px 90px rgba(15,23,42,.22)}
/* --- Trust bar (preuve sociale, masquée par défaut) --- */
.trust-bar{display:none;padding:40px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.trust-bar.active{display:block}
.trust-label{text-align:center;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mute);margin-bottom:24px}
.trust-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:40px;opacity:.65}
.trust-logos img{height:32px;filter:grayscale(1);opacity:.7}
/* --- Testimonials (masqué par défaut) --- */
.testimonials{display:none;padding:80px 0}
.testimonials.active{display:block}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:36px}
.testi-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:26px}
.testi-quote{font-size:15px;line-height:1.6;color:var(--text);margin-bottom:18px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px}
.testi-name{font-size:14px;font-weight:600;color:var(--text)}
.testi-role{font-size:12px;color:var(--text-mute)}
/* === HERO PUNCH (esprit Hercules) === */
.hero{padding:80px 0 50px!important;text-align:center}
.hero .wrap{display:flex;flex-direction:column;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:100px;padding:7px 18px;margin-bottom:28px}
.hero-eyebrow .sep{display:none}
.hero-eyebrow .tag{background:transparent;border:none;padding:0;color:var(--accent);font-weight:600}
.hero h1{font-size:clamp(40px,6vw,76px)!important;line-height:1.02!important;font-weight:800;letter-spacing:-.02em;margin-bottom:24px;max-width:14ch}
.hero h1 .light{background:linear-gradient(120deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:normal}
.hero-desc{font-size:clamp(17px,2vw,21px)!important;color:var(--text-soft)!important;max-width:600px;margin:0 auto 18px;line-height:1.5}
.hero-clarifier{max-width:560px;margin:0 auto 32px;font-size:13px!important;color:var(--text-mute)!important}
.hero-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:36px;max-width:680px}
.hero-pills .pill{background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:9px 18px;font-size:13px;font-weight:500;color:var(--text-soft);box-shadow:0 1px 3px rgba(15,23,42,.04)}
.hero-pills .pill:nth-child(1){border-color:rgba(37,99,235,.3);color:var(--accent)}
.hero-pills .pill:nth-child(2){border-color:rgba(124,58,237,.3);color:var(--purple)}
.hero-pills .pill:nth-child(3){border-color:rgba(22,163,74,.3);color:var(--green)}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-ctas .btn-p{font-size:16px;padding:15px 30px;border-radius:100px;box-shadow:0 8px 24px rgba(37,99,235,.28)}
.hero-ctas .btn-s{font-size:16px;padding:15px 30px;border-radius:100px}
/* Section titles bigger punch */
section h2{letter-spacing:-.015em}
@media(max-width:600px){.hero h1{font-size:clamp(34px,9vw,46px)!important}}
/* === PROFONDEUR / RELIEF (esprit Hercules) === */
/* Alternance de fonds de section */
section{position:relative}
section:nth-of-type(even){background:transparent!important}

/* Cartes : ombres marquées + bordure présente + hover net */
.feat-card{background:#faf8f3!important;border:1px solid rgba(15,23,42,.08)!important;border-radius:18px!important;box-shadow:0 2px 4px rgba(15,23,42,.04),0 12px 28px rgba(15,23,42,.06)!important;padding:30px!important;position:relative;overflow:hidden}
.feat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--purple));opacity:0;transition:opacity .3s}
.feat-card:hover{transform:translateY(-6px)!important;box-shadow:0 8px 16px rgba(15,23,42,.08),0 24px 50px rgba(15,23,42,.12)!important}
.feat-card:hover::before{opacity:1}
.feat-card .num{font-size:12px!important;font-weight:700!important}
.feat-card h3{font-size:19px!important;margin:6px 0 12px!important}
/* tags dans les cartes : plus de pep */
.feat-card span[class*="tag"],.feat-card .p-tag{background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:8px;padding:5px 11px;font-size:12px;color:var(--accent);display:inline-block;margin:3px}
/* Comparatif sans/avec : cartes contrastées */
.cmp-col,.compare-card{border-radius:16px!important;box-shadow:0 8px 24px rgba(15,23,42,.06)!important}
/* Explore cards : relief */
.explore-card{background:#faf8f3!important;border:1px solid rgba(15,23,42,.08)!important;border-radius:18px!important;box-shadow:0 2px 4px rgba(15,23,42,.04),0 12px 28px rgba(15,23,42,.06)!important}
.explore-card:hover{transform:translateY(-6px)!important;box-shadow:0 8px 16px rgba(15,23,42,.08),0 24px 50px rgba(15,23,42,.12)!important}
/* Resserrer l'espacement vertical des sections */
section{padding-top:70px!important;padding-bottom:70px!important}
.hero{padding:70px 0 40px!important}
/* Titres de section : eyebrow en petit tag coloré */
.section-eyebrow,section .wrap>.hero-eyebrow{margin-bottom:18px}
/* Liens du footer / divers restent ok */
/* Alternance plus visible + suppression du vide excessif */
section:nth-of-type(even){background:transparent!important}
section:nth-of-type(odd){background:transparent!important}

/* Réduire le vide : padding raisonnable, pas de min-height fantôme */
section{padding:64px 0!important;min-height:0!important}
/* La section architecture a un grand padding inline → normaliser */
#architecture{padding:64px 0!important}
/* Marquee strip garde son style */
.marquee-strip{background:var(--surface-2)}
/* CTA final / footer transitions douces */
footer{background:var(--surface-2)!important;border-top:1px solid var(--border)}
/* S'assurer que les cartes blanches restent blanches même en section gris */
section:nth-of-type(even) .feat-card,section:nth-of-type(even) .explore-card{background:#faf8f3!important}
/* === FOND CRÈME + TITRE QUI CLAQUE (esprit Hercules, ton B2B) === */
:root{--bg:#f4f2ee;--surface:#faf8f3;--surface-2:#ebe8e2;}
body{background:var(--bg)}
/* alternance : crème / blanc */
section:nth-of-type(odd){background:transparent!important}
section:nth-of-type(even){background:transparent!important}

.marquee-strip{background:var(--surface-2)}
footer{background:var(--surface-2)!important}
/* HERO TITLE : énorme, gras, qui claque */
.hero h1{font-size:clamp(46px,7vw,86px)!important;font-weight:800!important;line-height:.98!important;letter-spacing:-.03em!important;color:#15171c!important;margin-bottom:26px!important}
.hero h1 .light{display:inline-block;background:linear-gradient(115deg,#2563eb 0%,#6d28d9 60%,#7c3aed 100%)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important;font-style:normal!important}
/* cartes restent blanches sur fond crème */
.feat-card,.explore-card{background:#faf8f3!important}
section:nth-of-type(even) .feat-card,section:nth-of-type(even) .explore-card{background:#faf8f3!important}
/* ============ EFFET WOW : contraste, air, animations ============ */
/* Fonds de section plus contrastés : crème prononcé / blanc pur en alternance */
section:nth-of-type(odd){background:transparent!important}
section:nth-of-type(even){background:transparent!important}
.hero{background:linear-gradient(180deg,#f4f1eb 0%,#ece8e0 100%)!important}
.marquee-strip{background:#15171c!important}
.marquee-strip span{color:rgba(255,255,255,.55)!important}

/* Cartes : très arrondies, détachées, ombre marquée, marge autour */
.feat-card,.explore-card{
  background:#faf8f3!important;
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:24px!important;
  box-shadow:0 4px 12px rgba(15,23,42,.05),0 20px 48px rgba(15,23,42,.10)!important;
  padding:34px!important;
}
/* Sur les sections BLANCHES, les cartes prennent un fond crème pour ressortir */
section:nth-of-type(even) .feat-card,section:nth-of-type(even) .explore-card{
  background:#faf8f3!important;
  border:1px solid rgba(15,23,42,.07)!important;
}
/* Plus d'espace autour des grilles de cartes */
.feat-grid,.explore-grid{gap:26px!important;padding:6px!important}

/* Accent coloré en haut de carte, visible en permanence (léger) + franc au survol */
.feat-card::before{height:4px!important;opacity:.5!important}
.feat-card:hover{transform:translateY(-10px) scale(1.015)!important;box-shadow:0 12px 24px rgba(15,23,42,.10),0 36px 70px rgba(37,99,235,.18)!important}
.feat-card:hover::before{opacity:1!important}
.explore-card:hover{transform:translateY(-10px) scale(1.015)!important;box-shadow:0 12px 24px rgba(15,23,42,.10),0 36px 70px rgba(124,58,237,.18)!important}

/* Browser frames : plus d'air + flottement plus ample */
.browser-frame{margin:8px auto!important}
.browser-frame:hover{transform:translateY(-10px)!important;box-shadow:0 50px 110px rgba(15,23,42,.28)!important}

/* ============ ANIMATIONS PLUS PRONONCÉES ============ */
.reveal{opacity:0;transform:translateY(48px) scale(.97);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0) scale(1)}
/* Stagger : les cartes d'une grille apparaissent en cascade */
.feat-grid .feat-card{opacity:0;transform:translateY(40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.feat-grid.in .feat-card{opacity:1;transform:translateY(0)}
.feat-grid.in .feat-card:nth-child(1){transition-delay:.05s}
.feat-grid.in .feat-card:nth-child(2){transition-delay:.15s}
.feat-grid.in .feat-card:nth-child(3){transition-delay:.25s}
.feat-grid.in .feat-card:nth-child(4){transition-delay:.35s}
@media(prefers-reduced-motion:reduce){.reveal,.feat-grid .feat-card{opacity:1!important;transform:none!important}}
.archi-anim{display:grid;grid-template-columns:auto 56px 1fr 56px auto;align-items:center;gap:0;max-width:1000px;margin:0 auto}
.archi-node{background:#faf8f3;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:20px 18px;text-align:center;box-shadow:0 8px 24px rgba(15,23,42,.07)}
.archi-node-title{font-weight:700;font-size:15px;color:#15171c;margin-bottom:6px}
.archi-node-sub{font-family:var(--mono);font-size:10px;color:var(--text-mute);line-height:1.5}
.archi-models{background:#15171c;border-color:#15171c}
.archi-models .archi-node-title{color:#fff}
.archi-model-list{display:flex;flex-direction:column;gap:5px;margin-top:8px}
.archi-model-list span{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.6)}
.archi-local{color:#4ade80!important}
/* Flux animés */
.archi-flow{position:relative;height:3px;background:linear-gradient(90deg,rgba(37,99,235,.15),rgba(124,58,237,.15));border-radius:3px;align-self:center}
.archi-pulse{position:absolute;top:50%;left:0;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle,#2563eb,rgba(37,99,235,0));transform:translateY(-50%);animation:flowmove 2.4s ease-in-out infinite}
.archi-pulse-2{background:radial-gradient(circle,#7c3aed,rgba(124,58,237,0));animation-delay:1.2s}
@keyframes flowmove{0%{left:-4px;opacity:0}20%{opacity:1}80%{opacity:1}100%{left:calc(100% - 10px);opacity:0}}
/* Coeur : 4 cartes */
.archi-core{background:rgba(37,99,235,.04);border:1px dashed rgba(37,99,235,.25);border-radius:22px;padding:22px 18px}
.archi-core-label{text-align:center;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.archi-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.archi-cards .archi-card:nth-child(5){grid-column:1 / -1;text-align:center}
.archi-cards .archi-card:nth-child(5) .archi-card-dot{margin-left:auto;margin-right:auto}
.archi-card{background:#faf8f3;border:1px solid rgba(15,23,42,.07);border-left:3px solid var(--c);border-radius:14px;padding:16px;box-shadow:0 4px 14px rgba(15,23,42,.06);transition:transform .3s,box-shadow .3s}
.archi-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(15,23,42,.12)}
.archi-card-dot{width:9px;height:9px;border-radius:50%;background:var(--c);margin-bottom:10px;box-shadow:0 0 0 4px color-mix(in srgb,var(--c) 18%,transparent)}
.archi-card-name{font-weight:700;font-size:14px;color:#15171c;margin-bottom:6px}
.archi-card-desc{font-size:12px;color:var(--text-soft);line-height:1.5}
/* Responsive : empiler sur mobile */
@media(max-width:820px){
  .archi-anim{grid-template-columns:1fr;gap:16px}
  .archi-flow{height:36px;width:3px;justify-self:center;background:linear-gradient(180deg,rgba(37,99,235,.15),rgba(124,58,237,.15))}
  .archi-pulse{left:50%;top:0;transform:translateX(-50%);animation:flowmovev 2.4s ease-in-out infinite}
  @keyframes flowmovev{0%{top:-4px;opacity:0}20%{opacity:1}80%{opacity:1}100%{top:calc(100% - 10px);opacity:0}}
}
@media(max-width:520px){.archi-cards{grid-template-columns:1fr}}
/* Grille bleutée claire globale (esprit carreaux Hercules, version claire) */

/* Les sections laissent voir la grille : fonds semi-transparents au lieu d'opaques */
section:nth-of-type(odd){background:transparent!important}
section:nth-of-type(even){background:transparent!important}
.hero{background:transparent!important}
/* UN SEUL FOND : grille bleue uniforme, sections transparentes */
section{background:transparent!important}
.hero{background:transparent!important}

/* Exceptions volontaires : le CTA final garde son fond violet, le marquee son noir */
section.final-cta{background:linear-gradient(135deg,#1e1b4b 0%,#3730a3 55%,#5b21b6 100%)!important}
.marquee-strip{background:#15171c!important}
footer{background:rgba(236,232,224,.85)!important}
/* === FOND BLEU-GRIS FROID + TREILLIS ORIENTAL + PARALLAXE === */
body{background:#e8ecf3}

/* dégradé doux par-dessus le motif pour la profondeur */

/* Sections transparentes : laissent voir le fond */
section{background:transparent!important}
.hero{background:transparent!important}
/* CARTES À FOND PROPRE : blanc légèrement froid, bien détaché */
.feat-card,.explore-card,.archi-node,.archi-card,.cmp-col{
  background:#ffffff!important;
  border:1px solid rgba(60,80,120,.10)!important;
  box-shadow:0 4px 14px rgba(30,50,90,.06),0 20px 44px rgba(30,50,90,.10)!important;
}
.archi-core{background:rgba(255,255,255,.55)!important;border:1px dashed rgba(37,99,235,.28)!important}
/* Exceptions : CTA violet + marquee noir */
section.final-cta{background:linear-gradient(135deg,#1e1b4b 0%,#3730a3 55%,#5b21b6 100%)!important}
.marquee-strip{background:#15171c!important}
footer{background:rgba(232,236,243,.9)!important}
/* Fond qui DÉFILE avec le contenu (pas fixed) */
.bg-grid{display:none}
body{background-color:#e8ecf3;background-image:url("data:image/svg+xml,%3Csvg width='56' height='100' viewBox='0 0 56 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%237c8aa8' stroke-opacity='0.15'%3E%3Cpath d='M28 0 L56 16 L56 50 L28 66 L0 50 L0 16 Z'/%3E%3Cpath d='M28 66 L56 82 L56 116 L28 132 L0 116 L0 82 Z'/%3E%3C/g%3E%3C/svg%3E");background-size:56px 100px;background-repeat:repeat;background-attachment:scroll;}
section{background:transparent!important}
.hero{background:transparent!important}
section.final-cta{background:linear-gradient(135deg,#1e1b4b 0%,#3730a3 55%,#5b21b6 100%)!important}
.marquee-strip{background:#15171c!important}
footer{background:rgba(232,236,243,.9)!important}
/* Fond propre pour TOUTES les cartes (vraies classes) */
.p-card,.sector,.how-item,.explore-card,.archi-node,.cmp-col,.feat-card{
  background:#ffffff!important;
  border:1px solid rgba(60,80,120,.10)!important;
  border-radius:20px!important;
  box-shadow:0 4px 14px rgba(30,50,90,.06),0 18px 40px rgba(30,50,90,.09)!important;
}
.p-card{padding:28px!important}
.archi-card{background:#ffffff!important}
/* how-item : transformer les étapes en cartes */
.how-item{padding:24px 26px!important;margin-bottom:0!important;display:flex;gap:18px;align-items:flex-start;transition:transform .25s,box-shadow .25s}
.how-item:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(30,50,90,.14)!important}
.how-list{display:grid;gap:16px!important}
.how-n{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
/* secteurs : grille de cartes avec un peu d'air */
.sectors-grid{gap:18px!important}
.sector{padding:24px!important}
/* hover cartes */
.p-card:hover,.sector:hover,.explore-card:hover{transform:translateY(-6px)!important;box-shadow:0 14px 34px rgba(30,50,90,.14)!important;transition:transform .3s,box-shadow .3s}
/* Forcer le bloc Modèles IA en sombre (écrasé par la règle cartes blanches) */
.archi-node.archi-models{background:#15171c!important;border-color:#15171c!important}
.archi-node.archi-models .archi-node-title{color:#fff!important}
/* HEADER / NAV : fond accordé au fond du site (pas blanc) */
nav{background:rgba(232,236,243,.82)!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(60,80,120,.10)!important}
/* Comparatif "Sans/Avec HUB IA" : fond propre */
.why-col{
  background:#ffffff!important;
  border:1px solid rgba(60,80,120,.10)!important;
  border-radius:18px!important;
  box-shadow:0 4px 14px rgba(30,50,90,.06),0 18px 40px rgba(30,50,90,.09)!important;
  padding:8px!important;overflow:hidden;
}
.why-col.bad{border-top:3px solid #f87171!important}
.why-col.good{border-top:3px solid #16a34a!important}
.why-head{padding:14px 18px!important;font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.why-col.bad .why-head{color:#f87171}
.why-col.good .why-head{color:#16a34a}
.why-row{padding:11px 18px!important;display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text-soft);border-top:1px solid rgba(60,80,120,.07)}
.why-row .mk{font-family:var(--mono);font-weight:700}
.why-col.bad .mk{color:#f87171}
.why-col.good .mk{color:#16a34a}
.why-grid{gap:20px!important}
/* Icônes de cartes modules */
.p-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;background:color-mix(in srgb,var(--ic) 12%,transparent);color:var(--ic)}
.p-icon svg{width:24px;height:24px}
/* === CONTRASTE : assombrir les textes pâles === */
.hero-desc{color:#334155!important}
.hero-clarifier{color:#5b6b82!important}
.p-card p{color:#475569!important}
.sector p,.sector .sector-label{color:#475569!important}
.how-item p,.how-item span:not(.how-n){color:#475569!important}
[style*="color:var(--text2)"]{color:#475569!important}
.dim{color:#64748b!important}
.p-num{color:#7c8aa8!important}
section p{color:#475569}
.how-n svg{width:20px;height:20px;color:#fff}
.how-n{display:flex!important;align-items:center;justify-content:center}
/* Badges de section : fond pilule propre (eyebrow + label) */
.label,.hero-eyebrow{
  display:inline-flex!important;align-items:center;gap:8px;
  background:#ffffff!important;
  border:1px solid rgba(37,99,235,.22)!important;
  border-radius:100px!important;
  padding:7px 16px!important;
  font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  color:#2563eb!important;
  box-shadow:0 2px 8px rgba(30,50,90,.06);
  margin-bottom:18px;
}
/* le point/puce dans hero-eyebrow */
.hero-eyebrow .tag{background:transparent!important;border:none!important;padding:0!important;color:#2563eb!important}
.label .dim,.hero-eyebrow .dim{color:#7c8aa8!important}
/* Textes en GRIS-BLEU (harmonie avec le fond bleu-gris) */
.hero-desc{color:#3d4b63!important}
.hero-clarifier{color:#5a6b85!important}
.p-card p,.sector p,.how-item p,.why-row,section p{color:#4a5a73!important}
.p-num{color:#6b7a96!important}
.dim{color:#6b7a96!important}
h2,h3,h4{color:#1a2438!important}
.hero h1{color:#16203a!important;-webkit-text-fill-color:#16203a!important}
body{color:#3d4b63}
/* 2e ligne des titres de section : dégradé gris-bleu */
.dim{
  background:linear-gradient(120deg,#64748b,#3b5b8c 70%,#2563eb)!important;
  -webkit-background-clip:text!important;
  -webkit-text-fill-color:transparent!important;
  background-clip:text!important;
  color:transparent!important;
  font-style:italic;font-weight:700;
}
/* === HEADER propre et net === */
nav{
  background:rgba(248,250,253,.92)!important;
  backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid rgba(60,80,120,.08)!important;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset,0 4px 20px rgba(30,50,90,.05)!important;
}
/* === MARQUEE : bandeau dégradé bleu→violet (au lieu du noir) === */
.marquee-strip{
  background:linear-gradient(90deg,#2563eb,#5b21b6 50%,#7c3aed)!important;
  border-top:none!important;border-bottom:none!important;
}
.marquee span{color:rgba(255,255,255,.92)!important;font-weight:500}
.marquee span::before{content:'/ '!important;color:rgba(255,255,255,.45)!important;margin-right:4px;opacity:1}
.sector-ic,.explore-ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;background:color-mix(in srgb,var(--c) 12%,transparent);color:var(--c)}
.sector-ic svg,.explore-ic svg{width:22px;height:22px}
.hero-mockup{margin:36px auto 40px;max-width:1040px}
.browser-frame{background:#1a2030;border:1px solid rgba(15,23,42,.12);border-radius:12px;overflow:hidden;box-shadow:0 24px 60px rgba(15,23,42,.18);margin:0 auto}
.browser-bar{display:flex;align-items:center;gap:8px;padding:11px 16px;background:#12182a;border-bottom:1px solid rgba(255,255,255,.06)}
.browser-dot{width:11px;height:11px;border-radius:50%}
.browser-url{margin-left:14px;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.45);background:#0a0e17;padding:5px 14px;border-radius:6px;flex:1;max-width:360px}
.prob-vs{border-radius:18px;overflow:hidden;border:1px solid rgba(60,80,120,.10);background:#fff;box-shadow:0 4px 14px rgba(30,50,90,.06),0 18px 40px rgba(30,50,90,.09)}
.prob-vs-head{display:grid;grid-template-columns:1fr 1fr;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.pvh-bad{padding:12px 18px;background:rgba(239,68,68,.07);color:#dc2626}
.pvh-good{padding:12px 18px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}
.prob-vs-row{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(60,80,120,.08)}
.prob-vs-row .pv-bad,.prob-vs-row .pv-good{padding:13px 18px;font-size:12.5px;line-height:1.4;display:flex;align-items:center;gap:8px}
.pv-bad{color:#8a93a6;border-right:1px solid rgba(60,80,120,.08)}
.pv-bad::before{content:"✕";color:#dc2626;font-weight:700;flex-shrink:0}
.pv-good{color:#1a2438;font-weight:500}
.pv-good::before{content:"✓";color:#16a34a;font-weight:700;flex-shrink:0}
.codelabs-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:center}
.codelabs-mockup .browser-frame{margin:0}
.codelabs-points{display:flex;flex-direction:column;gap:22px}
.cl-point{display:flex;gap:16px;align-items:flex-start}
.cl-ic{flex-shrink:0;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--c) 12%,transparent);color:var(--c)}
.cl-ic svg{width:22px;height:22px}
.cl-point h4{font-size:16px;margin-bottom:5px;color:#1a2438}
.cl-point p{font-size:13.5px;color:#4a5a73;line-height:1.55}
@media(max-width:860px){.codelabs-grid{grid-template-columns:1fr;gap:28px}}
.explore-card:hover{border-color:var(--accent-border);transform:translateY(-3px)}
.archi-svg{width:100%;height:auto;display:block}
.patents{padding:70px 0!important}
.patents-head{text-align:center;max-width:640px;margin:0 auto 40px}
.patents-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1000px;margin:0 auto}
.patent-stat{background:#fff;border:1px solid rgba(60,80,120,.10);border-radius:20px;padding:32px 28px;text-align:center;box-shadow:0 4px 14px rgba(30,50,90,.06),0 18px 40px rgba(30,50,90,.09)}
.patent-num{font-family:var(--serif);font-size:46px;font-weight:800;line-height:1;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:14px;display:flex;align-items:center;justify-content:center;min-height:48px;color:#2563eb}
.patent-num svg{color:#2563eb}
.patent-lbl{font-size:15px;font-weight:700;color:#1a2438;margin-bottom:8px}
.patent-desc{font-size:13px;color:#4a5a73;line-height:1.55}
@media(max-width:760px){.patents-grid{grid-template-columns:1fr}}
section.final-cta,section.final-cta:nth-of-type(odd),section.final-cta:nth-of-type(even){background:linear-gradient(135deg,#1e1b4b 0%,#3730a3 55%,#5b21b6 100%)!important}
.final-cta{padding:90px 0!important;position:relative;overflow:hidden}
.final-cta::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:44px 44px;pointer-events:none}
.final-cta-title{font-size:clamp(34px,5vw,60px)!important;font-weight:800!important;line-height:1.05!important;letter-spacing:-.02em;color:#fff!important;margin-bottom:18px}
.final-cta-title .light{background:linear-gradient(115deg,#a5b4fc,#e9d5ff)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}
.final-cta-sub{color:rgba(255,255,255,.8)!important;font-size:clamp(15px,2vw,18px)!important;max-width:560px;margin:0 auto 34px;line-height:1.55}
.final-cta-btn{display:inline-flex;align-items:center;gap:12px;background:#faf8f3;color:#1e1b4b;font-weight:700;font-size:17px;padding:18px 36px;border:none;border-radius:100px;cursor:pointer;box-shadow:0 12px 40px rgba(0,0,0,.3);transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s}
.final-cta-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 18px 50px rgba(0,0,0,.4)}
/* === FIX feat-grid (pages platform etc.) : grille + cartes visibles === */
.feat-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))!important;gap:20px!important}
.feat-grid .feat-card{opacity:1!important;transform:none!important}
.feat-card{background:#ffffff!important}
.hero-accroche{font-family:var(--serif);font-size:clamp(18px,2.2vw,26px);font-style:italic;font-weight:700;background:linear-gradient(120deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;max-width:640px;margin:0 auto 22px;line-height:1.3}
.uc-chapeau{max-width:760px;margin:0 auto 40px;text-align:center;font-size:15px;line-height:1.6;color:#3d4b63;background:rgba(37,99,235,.05);border:1px solid rgba(37,99,235,.14);border-radius:14px;padding:18px 28px}
.uc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1000px;margin:0 auto}
.uc-card{background:#fff;border:1px solid rgba(60,80,120,.10);border-radius:20px;overflow:hidden;box-shadow:0 4px 14px rgba(30,50,90,.06),0 18px 40px rgba(30,50,90,.09);transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s}
.uc-card:hover{transform:translateY(-6px);box-shadow:0 14px 34px rgba(30,50,90,.14)}
.uc-shot{background:#1a2030;padding:18px 18px 0}
.uc-shot .browser-frame{margin:0;border-radius:8px 8px 0 0;box-shadow:none;border:none}
.uc-shot img{width:100%;display:block}
.uc-body{padding:24px 26px 28px}
.uc-tag{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c);background:color-mix(in srgb,var(--c) 10%,transparent);padding:5px 11px;border-radius:7px;margin-bottom:12px}
.uc-body h3{font-size:18px;color:#1a2438;margin-bottom:8px}
.uc-body p{font-size:13.5px;color:#4a5a73;line-height:1.55}
@media(max-width:760px){.uc-grid{grid-template-columns:1fr}}
.uc-shot{background:#1a2030;padding:18px 18px 0}
.uc-shot .browser-frame{margin:0;border-radius:8px 8px 0 0;box-shadow:none;border:none}
.uc-shot img{width:100%;display:block;border-radius:0}
.uc-body{padding:24px 26px 28px}
.uc-tag{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c);background:color-mix(in srgb,var(--c) 10%,transparent);padding:5px 11px;border-radius:7px;margin-bottom:12px}
.uc-body h3{font-size:18px;color:#1a2438;margin-bottom:8px}
.uc-body p{font-size:13.5px;color:#4a5a73;line-height:1.55}
@media(max-width:760px){.uc-grid{grid-template-columns:1fr}}
.start-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto}
.start-step{position:relative;background:#fff;border:1px solid rgba(60,80,120,.10);border-radius:20px;padding:32px 28px;box-shadow:0 4px 14px rgba(30,50,90,.06),0 18px 40px rgba(30,50,90,.09)}
.start-num{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:24px;font-weight:800;margin-bottom:18px}
.start-step h4{font-size:18px;color:#1a2438;margin-bottom:10px}
.start-step p{font-size:13.5px;color:#4a5a73;line-height:1.55}
.start-line{position:absolute;top:56px;right:-24px;width:24px;height:2px;background:linear-gradient(90deg,rgba(37,99,235,.4),rgba(124,58,237,.1));z-index:1}
@media(max-width:760px){.start-steps{grid-template-columns:1fr}.start-line{display:none}}
/* Modale claire : lisibilité */
#modal-panel{background:#ffffff!important;border:1px solid rgba(60,80,120,.12)!important;box-shadow:0 32px 80px rgba(15,23,42,.3)!important}
#modal-panel input,#modal-panel textarea{background:#f4f6fa!important;border:1px solid rgba(60,80,120,.18)!important;color:#1a2438!important}
#modal-panel input::placeholder,#modal-panel textarea::placeholder{color:#94a3b8!important}
#modal-panel input:focus,#modal-panel textarea:focus{border-color:rgba(37,99,235,.5)!important;background:#fff!important}
#modal-panel label,#modal-panel label span{color:#5a6b85!important}
#modal-panel button[type="submit"],#modal-panel button[type="submit"] span{color:#fff!important}

/* burger mobile (discret) */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:36px;background:none;border:0;cursor:pointer;padding:7px;margin-left:4px}
.nav-burger span{display:block;height:2px;width:100%;background:#475569;border-radius:2px;transition:.25s ease}
.nav-burger.open span{background:#0f172a}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;flex-direction:column;padding:4px 20px 16px;background:#faf8f3;box-shadow:0 14px 30px -16px rgba(15,23,42,.35);border-bottom:1px solid rgba(15,23,42,.10)}
.nav-mobile a{padding:13px 2px;font-size:16px;color:#475569;border-top:1px solid rgba(15,23,42,.10)}
.nav-mobile a:hover{color:#0f172a}
.nav-mobile.open{display:flex}
@media(prefers-reduced-motion:reduce){.nav-burger span{transition:none}}
