:root {
  --bg: #f4f8fb;
  --paper: #ffffff;
  --ink: #122033;
  --muted: #64748b;
  --soft: #e7eef6;
  --line: #d9e3ee;
  --blue: #2563eb;
  --blue2: #0f4fbf;
  --teal: #0aa68a;
  --green: #16a34a;
  --amber: #d97706;
  --red: #dc2626;
  --navy: #11243b;
  --navy2: #17314f;
  --shadow: 0 22px 60px rgba(18, 32, 51, .12);
  --radius: 22px;

  --dash-bg: #0b0f16;
  --dash-surface: #121821;
  --dash-panel: #171d26;
  --dash-panel-2: #101720;
  --dash-line: rgba(148, 163, 184, .18);
  --dash-text: #d8dee9;
  --dash-muted: #8b98aa;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
.container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 max(20px, 5vw);
  background: rgba(255, 255, 255, .84);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(217, 227, 238, .8);
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark {
  width: 42px; height: 42px;
  border-radius: 13px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--blue), var(--teal));
  color: #fff;
  font-weight: 900;
  box-shadow: 0 12px 30px rgba(37, 99, 235, .25);
}
.brand strong { display: block; font-size: 17px; }
.brand small { display: block; margin-top: 2px; font: 600 11px JetBrains Mono, monospace; color: var(--muted); }
.nav { display: flex; align-items: center; gap: 26px; }
.nav a { font-weight: 700; font-size: 14px; color: var(--muted); }
.nav a:hover { color: var(--blue); }
.nav-cta { padding: 11px 16px; border-radius: 999px; background: var(--navy); color: #fff !important; }
.menu-toggle { display: none; border: 0; background: var(--navy); color: #fff; border-radius: 10px; width: 42px; height: 42px; font-size: 22px; }

.hero {
  position: relative;
  min-height: 720px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.hero-media { position: absolute; inset: 0; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.94) contrast(1.05); }
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(244, 248, 251, .98) 0%, rgba(244, 248, 251, .91) 36%, rgba(244, 248, 251, .62) 62%, rgba(244, 248, 251, .20) 100%);
}
.hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) 430px;
  gap: 50px;
  align-items: center;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  margin: 0 0 16px;
  color: var(--blue);
  font: 700 12px JetBrains Mono, monospace;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.eyebrow span,
.live-dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 6px rgba(22, 163, 74, .12);
  flex: 0 0 auto;
}
h1, h2, h3, p { margin-top: 0; }
h1 {
  max-width: 850px;
  margin-bottom: 24px;
  color: var(--ink);
  font-size: clamp(46px, 6vw, 78px);
  line-height: .98;
  letter-spacing: -.065em;
}
h2 {
  margin-bottom: 18px;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1;
  letter-spacing: -.05em;
}
.hero-text,
.section-head p,
.ad-grid p,
.why-grid p,
.contact-copy p {
  max-width: 740px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin: 34px 0; }
.btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border: 0;
  border-radius: 14px;
  padding: 15px 22px;
  font-weight: 900;
  cursor: pointer;
}
.btn-primary { background: linear-gradient(135deg, var(--blue), var(--teal)); color: #fff; box-shadow: 0 18px 45px rgba(37, 99, 235, .25); }
.btn-secondary { background: #fff; color: var(--navy); border: 1px solid var(--line); }
.hero-points { display: flex; gap: 10px; flex-wrap: wrap; }
.hero-points span,
.trust-strip span {
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  color: var(--muted);
  font: 700 12px JetBrains Mono, monospace;
}

.hero-card {
  border-radius: 30px;
  padding: 24px;
  background: rgba(255, 255, 255, .88);
  border: 1px solid rgba(255, 255, 255, .75);
  box-shadow: 0 28px 75px rgba(18, 32, 51, .18);
  backdrop-filter: blur(18px);
}
.hero-card-premium { position: relative; overflow: hidden; }
.hero-card-premium::before {
  content: "";
  position: absolute;
  inset: -1px;
  background: radial-gradient(circle at 20% 10%, rgba(37, 99, 235, .16), transparent 38%), radial-gradient(circle at 80% 0%, rgba(10, 166, 138, .18), transparent 34%);
  pointer-events: none;
}
.hero-card > * { position: relative; z-index: 1; }
.hero-card-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  color: var(--muted);
  font-weight: 900;
  font-size: 13px;
}
.hero-card-top > div { display: inline-flex; align-items: center; gap: 10px; }
.hero-card-top strong { color: var(--ink); font: 700 13px JetBrains Mono, monospace; }
.health-layout {
  display: grid;
  grid-template-columns: 172px 1fr;
  gap: 20px;
  align-items: center;
  margin: 24px 0 18px;
}
.health-ring {
  width: 172px;
  height: 172px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: conic-gradient(var(--green) 0 96%, #d9e5f1 96%);
  position: relative;
  box-shadow: 0 15px 35px rgba(22, 163, 74, .18);
}
.health-ring::before {
  content: "";
  position: absolute;
  inset: 14px;
  background: #fff;
  border-radius: 50%;
  box-shadow: inset 0 0 0 1px var(--line);
}
.health-ring span,
.health-ring small { position: relative; font-weight: 950; color: var(--navy); }
.health-ring span { font-size: 56px; letter-spacing: -.06em; }
.health-ring small { font-size: 22px; margin-left: 60px; margin-top: -60px; }
.health-copy strong { display: block; margin-bottom: 8px; font-size: 18px; color: var(--navy); }
.health-copy p,
.hero-card p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.65; }
.health-mini-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 16px;
}
.health-mini-grid div {
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, .78);
  border-radius: 16px;
  padding: 12px;
}
.health-mini-grid span { display: block; margin-bottom: 5px; color: var(--muted); font: 800 11px JetBrains Mono, monospace; text-transform: uppercase; }
.health-mini-grid b { color: var(--green); font-size: 13px; }
.health-mini-grid .warn b { color: var(--amber); }
.health-alert {
  margin-top: 14px;
  padding: 14px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(217, 119, 6, .12), rgba(37, 99, 235, .08));
  border: 1px solid rgba(217, 119, 6, .22);
}
.health-alert span { display: block; margin-bottom: 5px; color: var(--amber); font: 900 11px JetBrains Mono, monospace; text-transform: uppercase; }
.health-alert strong { color: var(--navy); line-height: 1.45; }
.mini-status { display: none; }

.trust-strip {
  position: relative;
  z-index: 3;
  margin-top: -28px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  padding: 18px;
  background: rgba(255, 255, 255, .88);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: var(--shadow);
}
.section { padding: 95px 0; }
.section-head { margin-bottom: 36px; }
.centered { text-align: center; }
.centered p { margin-inline: auto; }

.dashboard-section {
  background: linear-gradient(180deg, #eef4fa 0%, #dfeaf5 100%);
}
.dashboard-section .section-head h2 { color: var(--ink); }

.grafana-board {
  background: var(--dash-bg);
  border: 1px solid rgba(148, 163, 184, .24);
  border-radius: 24px;
  box-shadow: 0 30px 90px rgba(15, 23, 42, .32);
  overflow: hidden;
  color: var(--dash-text);
}
.board-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--dash-line);
  background: #10151d;
}
.filters { display: flex; gap: 10px; flex-wrap: wrap; }
.filters button {
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid rgba(148, 163, 184, .24);
  background: #151b24;
  color: var(--dash-muted);
  font-weight: 800;
}
.filters strong { color: #8ab4ff; margin-left: 6px; }
.clock { display: flex; align-items: center; gap: 10px; color: var(--dash-text); font: 700 14px JetBrains Mono, monospace; }
.kpi-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  padding: 14px;
  background: #0d1219;
}
.kpi {
  border-radius: 14px;
  background: linear-gradient(180deg, #171d26, #121820);
  border: 1px solid rgba(148, 163, 184, .18);
  padding: 16px;
}
.kpi small { display: block; color: var(--dash-muted); font-weight: 800; }
.kpi strong { display: block; margin: 6px 0; color: #60a5fa; font-size: 30px; letter-spacing: -.04em; }
.kpi span { font-size: 12px; color: var(--dash-muted); }
.kpi.good strong { color: #22c55e; }
.kpi.warn strong { color: #f59e0b; }
.kpi.danger strong { color: #f87171; }
.board-grid {
  display: grid;
  grid-template-columns: 1.35fr 1fr 1fr;
  gap: 12px;
  padding: 14px;
}
.panel {
  min-width: 0;
  background: linear-gradient(180deg, var(--dash-panel), var(--dash-panel-2));
  border: 1px solid rgba(148, 163, 184, .16);
  border-radius: 14px;
  padding: 16px;
  box-shadow: inset 0 1px rgba(255, 255, 255, .03);
}
.panel-wide { grid-column: span 2; }
.panel-tall { grid-row: span 2; }
.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  gap: 12px;
}
.panel-head h3 { margin: 0; color: var(--dash-text); font-size: 17px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.panel-head span { color: var(--dash-muted); font: 700 12px JetBrains Mono, monospace; }
canvas { width: 100%; max-width: 100%; }
.topology {
  height: 360px;
  position: relative;
  border-radius: 14px;
  background: radial-gradient(circle at 50% 40%, #172536, #0d131b 70%);
  border: 1px solid rgba(148, 163, 184, .16);
  overflow: hidden;
}
.topology::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(96, 165, 250, .10) 1px, transparent 1px), linear-gradient(90deg, rgba(96, 165, 250, .10) 1px, transparent 1px);
  background-size: 32px 32px;
}
.node {
  position: absolute;
  z-index: 2;
  width: 64px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #fff;
  font: 900 12px JetBrains Mono, monospace;
  box-shadow: 0 10px 25px rgba(0, 0, 0, .28);
}
.internet { left: 8%; top: 41%; background: var(--teal); }
.firewall { left: 28%; top: 41%; background: var(--red); }
.core { left: 48%; top: 41%; background: var(--blue); }
.ad { right: 12%; top: 18%; background: #1f2937; }
.srv { right: 12%; top: 42%; background: var(--amber); }
.nas { right: 12%; bottom: 18%; background: var(--green); }
.users { left: 47%; bottom: 15%; background: #7c3aed; }
.link {
  position: absolute;
  height: 3px;
  background: linear-gradient(90deg, rgba(96, 165, 250, .1), #60a5fa, rgba(96, 165, 250, .1));
  border-radius: 99px;
  z-index: 1;
  animation: flow 2.3s linear infinite;
}
.l-internet-fw { left: 16%; top: 47%; width: 13%; }
.l-fw-core { left: 36%; top: 47%; width: 13%; }
.l-core-ad { right: 20%; top: 33%; width: 28%; transform: rotate(-18deg); }
.l-core-srv { right: 20%; top: 48%; width: 28%; }
.l-core-nas { right: 20%; bottom: 30%; width: 28%; transform: rotate(18deg); }
.l-core-users { left: 52%; bottom: 28%; height: 25%; width: 3px; }
.topology-legend { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-top: 12px; color: var(--dash-muted); font: 700 12px JetBrains Mono, monospace; }
.ok-dot, .warn-dot, .bad-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.ok-dot { background: var(--green); }
.warn-dot { background: var(--amber); }
.bad-dot { background: var(--red); }
.ad-status { display: grid; gap: 10px; }
.ad-status div {
  display: flex;
  justify-content: space-between;
  padding: 12px;
  border-radius: 10px;
  background: #111923;
  border: 1px solid rgba(148, 163, 184, .14);
  color: var(--dash-text);
  font-weight: 800;
}
.ok { color: #22c55e; }
.warn { color: #f59e0b; }
.events { display: grid; gap: 1px; background: rgba(148, 163, 184, .14); border-radius: 12px; overflow: hidden; }
.event {
  display: grid;
  grid-template-columns: 78px 80px 1fr;
  gap: 14px;
  background: #111923;
  padding: 12px;
  color: var(--dash-muted);
  font: 600 12px JetBrains Mono, monospace;
}
.event b { color: #60a5fa; }
.event.warn b { color: #f59e0b; }
.event.crit b { color: #f87171; }

.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 28px;
  box-shadow: 0 12px 35px rgba(18, 32, 51, .07);
  transition: .25s;
}
.service-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: #bcd2ea; }
.service-card span { color: var(--blue); font: 900 13px JetBrains Mono, monospace; }
.service-card h3 { margin: 14px 0 10px; font-size: 22px; }
.service-card p { margin: 0; color: var(--muted); line-height: 1.7; }
.ad-section { background: #fff; }
.ad-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center; }
.checklist { list-style: none; padding: 0; margin: 28px 0 0; display: grid; gap: 14px; }
.checklist li { position: relative; padding-left: 34px; color: var(--muted); font-size: 16px; line-height: 1.6; }
.checklist li::before { content: "✓"; position: absolute; left: 0; top: 0; width: 23px; height: 23px; border-radius: 8px; display: grid; place-items: center; background: #e9f8ef; color: var(--green); font-weight: 900; }
.tier-card { background: linear-gradient(180deg, #17314f, #11243b); color: #fff; border-radius: 28px; padding: 28px; box-shadow: var(--shadow); }
.tier-card h3 { margin-bottom: 18px; font-size: 26px; }
.tier { padding: 18px; border-radius: 18px; margin: 12px 0; border: 1px solid rgba(255, 255, 255, .15); background: rgba(255, 255, 255, .06); }
.tier b { display: block; margin-bottom: 6px; font: 900 18px JetBrains Mono, monospace; }
.tier span { color: rgba(255, 255, 255, .75); line-height: 1.55; }
.tier0 b { color: #93c5fd; }
.tier1 b { color: #86efac; }
.tier2 b { color: #fde68a; }
.tier-card p { color: rgba(255, 255, 255, .72); font-size: 14px; }
.why-section { background: linear-gradient(180deg, #f4f8fb, #fff); }
.why-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 55px; align-items: center; }
.why-image { border-radius: 28px; overflow: hidden; box-shadow: var(--shadow); border: 1px solid #fff; }
.why-image img { height: 440px; width: 100%; object-fit: cover; }
.method-list { display: grid; gap: 14px; margin-top: 26px; }
.method-list div { display: grid; grid-template-columns: 48px 1fr; gap: 8px 16px; padding: 18px; background: #fff; border: 1px solid var(--line); border-radius: 18px; }
.method-list b { grid-row: span 2; color: var(--blue); font: 900 20px JetBrains Mono, monospace; }
.method-list span { font-weight: 900; }
.method-list p { margin: 0; color: var(--muted); font-size: 14px; }
.contact-section { background: linear-gradient(135deg, #eaf1f8, #f8fbfe); }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 45px; }
.contact-card { margin-top: 16px; padding: 18px; border-radius: 18px; background: #fff; border: 1px solid var(--line); box-shadow: 0 10px 28px rgba(18, 32, 51, .06); }
.contact-card b { display: block; }
.contact-card span { color: var(--muted); font-size: 14px; }
.contact-form { background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow); border-radius: 26px; padding: 28px; display: grid; gap: 16px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
label { color: var(--navy); font-weight: 800; font-size: 13px; }
input, select, textarea { margin-top: 7px; width: 100%; border: 1px solid var(--line); border-radius: 14px; padding: 14px 15px; background: #f8fbfe; color: var(--ink); font: 500 14px Inter, sans-serif; }
textarea { resize: vertical; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 4px rgba(37, 99, 235, .12); }
.form-note { margin: 0; color: var(--muted); font-weight: 700; }
.footer { background: var(--navy); color: #fff; padding: 32px 0; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.footer span, .footer small { color: rgba(255, 255, 255, .62); }

@keyframes flow {
  0% { filter: brightness(.7); }
  50% { filter: brightness(1.8); }
  100% { filter: brightness(.7); }
}

@media (max-width: 1100px) {
  .hero-grid, .ad-grid, .why-grid, .contact-grid { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding: 90px 0; }
  .hero-card { max-width: 620px; }
  .board-grid { grid-template-columns: 1fr 1fr; }
  .panel-wide { grid-column: span 2; }
  .kpi-row { grid-template-columns: repeat(3, 1fr); }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .container { width: min(100% - 28px, 1180px); }
  .site-header { height: auto; min-height: 68px; padding: 12px 16px; }
  .menu-toggle { display: block; }
  .nav { display: none; position: absolute; top: 68px; left: 0; right: 0; background: #fff; border-bottom: 1px solid var(--line); padding: 18px; flex-direction: column; align-items: flex-start; }
  .nav.open { display: flex; }
  .hero-overlay { background: rgba(244, 248, 251, .92); }
  h1 { font-size: 44px; }
  .hero-actions, .footer-inner { align-items: stretch; flex-direction: column; }
  .health-layout, .health-mini-grid { grid-template-columns: 1fr; }
  .health-ring { margin-inline: auto; }
  .board-toolbar { align-items: flex-start; flex-direction: column; }
  .kpi-row, .board-grid, .service-grid, .form-row { grid-template-columns: 1fr; }
  .panel-wide { grid-column: auto; }
  .topology { height: 300px; }
  .event { grid-template-columns: 1fr; }
  .why-image img { height: 300px; }
}

/* --- Prestations : détails au survol --- */
.service-card {
  position: relative;
  overflow: hidden;
  min-height: 260px;
  isolation: isolate;
}

.service-card::after {
  content: "Voir les détails";
  position: absolute;
  right: 22px;
  bottom: 20px;
  color: var(--blue);
  font: 900 11px JetBrains Mono, monospace;
  letter-spacing: .04em;
  opacity: .78;
  transition: .25s ease;
}

.service-card .service-details {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 26px;
  background: linear-gradient(135deg, #0f2744 0%, #143f5f 52%, #0f766e 100%);
  color: #fff;
  opacity: 0;
  transform: translateY(18px) scale(.98);
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
}

.service-card:hover .service-details,
.service-card:focus-within .service-details,
.service-card:focus .service-details {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.service-card:hover::after,
.service-card:focus::after,
.service-card:focus-within::after {
  opacity: 0;
}

.service-details strong {
  display: block;
  margin-bottom: 14px;
  color: #fff;
  font-size: 18px;
  line-height: 1.25;
}

.service-details ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.service-details li {
  position: relative;
  padding-left: 24px;
  color: rgba(255, 255, 255, .86);
  font-size: 14px;
  line-height: 1.55;
}

.service-details li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: #86efac;
  font-weight: 950;
}

@media (max-width: 720px) {
  .service-card {
    min-height: auto;
  }

  .service-card::after {
    content: "";
    display: none;
  }

  .service-card .service-details {
    position: static;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    margin-top: 18px;
    border-radius: 18px;
    padding: 18px;
  }
}


/* --- Navigation vers pages de déploiement --- */
.hero-links a,
.trust-strip a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  text-decoration: none;
}

.hero-links a {
  padding: 10px 15px;
  border: 1px solid #d5e3f4;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  color: #536783;
  font: 800 13px JetBrains Mono, monospace;
  transition: .22s ease;
}

.hero-links a:hover,
.trust-strip a:hover {
  transform: translateY(-2px);
  border-color: #2f6dff;
  color: #2f6dff;
  box-shadow: 0 14px 30px rgba(47,109,255,.12);
}

.trust-strip a {
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid #d4e2f3;
  background: #fff;
  color: #65758f;
  font: 800 14px JetBrains Mono, monospace;
  transition: .22s ease;
}

.service-grid a.service-card { text-decoration: none; color: inherit; display: block; }
.service-details em {
  display: inline-flex;
  margin-top: 14px;
  color: #dbeafe;
  font: 900 12px JetBrains Mono, monospace;
  font-style: normal;
}

/* --- Pages de détail / déploiement --- */
.detail-body { background: #eef5fb; color: #102033; }
.detail-header {
  position: sticky; top: 0; z-index: 20;
  background: rgba(248,251,255,.86);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid #d8e4f2;
}
.detail-nav {
  height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
.detail-brand { display: flex; align-items: center; gap: 12px; text-decoration: none; color: #102033; font-weight: 900; }
.detail-brand span { width: 40px; height: 40px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg,#2f6dff,#09a884); color: white; box-shadow: 0 16px 36px rgba(47,109,255,.18); }
.detail-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.detail-link { border: 1px solid #d4e2f3; border-radius: 999px; padding: 10px 14px; background: #fff; color: #536783; text-decoration: none; font: 800 12px JetBrains Mono, monospace; }
.detail-link:hover { color: #2f6dff; border-color: #2f6dff; }
.detail-hero { padding: 72px 0 42px; }
.detail-hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 28px; align-items: stretch; }
.detail-kicker { display: inline-flex; gap: 10px; align-items: center; color: #09a884; font: 900 12px JetBrains Mono, monospace; text-transform: uppercase; letter-spacing: .14em; }
.detail-kicker::before { content: ''; width: 10px; height: 10px; border-radius: 99px; background: #19b66b; box-shadow: 0 0 0 6px rgba(25,182,107,.1); }
.detail-hero h1 { margin: 16px 0; font-size: clamp(44px,6vw,82px); line-height: .94; letter-spacing: -.06em; color: #0d1b2f; }
.detail-lead { max-width: 760px; color: #65758f; font-size: 19px; line-height: 1.75; }
.detail-chipline { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.detail-chipline span { padding: 10px 14px; background: #fff; border: 1px solid #d4e2f3; border-radius: 999px; color: #536783; font: 800 12px JetBrains Mono, monospace; }
.deploy-card { background: #fff; border: 1px solid #d8e4f2; border-radius: 30px; padding: 28px; box-shadow: 0 24px 80px rgba(16,32,51,.09); }
.deploy-card h2 { margin: 0 0 18px; font-size: 26px; }
.deploy-steps { counter-reset: step; display: grid; gap: 14px; }
.deploy-steps li { list-style: none; position: relative; padding: 16px 16px 16px 58px; border: 1px solid #dbe6f3; border-radius: 18px; background: linear-gradient(180deg,#fff,#f8fbff); color: #536783; line-height: 1.55; }
.deploy-steps li::before { counter-increment: step; content: counter(step, decimal-leading-zero); position: absolute; left: 15px; top: 15px; color: #2f6dff; font: 950 13px JetBrains Mono, monospace; }
.detail-section { padding: 34px 0; }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.live-panel { background: #111827; color: #dbeafe; border-radius: 30px; padding: 24px; box-shadow: 0 30px 90px rgba(15,23,42,.22); border: 1px solid rgba(255,255,255,.08); }
.live-panel-top { display: flex; justify-content: space-between; color: #94a3b8; font: 800 12px JetBrains Mono, monospace; margin-bottom: 18px; }
.live-panel-top b { color: #22c55e; }
.ops-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; }
.ops-tile { padding: 16px; border-radius: 18px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.08); }
.ops-tile span { display: block; color: #94a3b8; font: 800 11px JetBrains Mono, monospace; }
.ops-tile strong { display: block; margin-top: 8px; font-size: 22px; color: #f8fafc; }
.ops-tile i { display: block; height: 6px; border-radius: 999px; margin-top: 10px; background: rgba(148,163,184,.18); overflow: hidden; }
.ops-tile i::after { content: ''; display: block; height: 100%; width: var(--w,70%); border-radius: inherit; background: linear-gradient(90deg,#22c55e,#38bdf8); }
.running-card { background: #fff; border: 1px solid #d8e4f2; border-radius: 30px; padding: 24px; box-shadow: 0 24px 80px rgba(16,32,51,.08); }
.running-card h2 { margin-bottom: 18px; font-size: 26px; }
.running-list { display: grid; gap: 10px; }
.running-list div { display: flex; justify-content: space-between; gap: 14px; align-items: center; padding: 14px 16px; border-radius: 16px; background: #f7fbff; border: 1px solid #dbe6f3; color: #536783; }
.running-list b { color: #16a34a; font: 900 12px JetBrains Mono, monospace; }
.timeline { display: grid; gap: 10px; margin-top: 14px; }
.timeline div { display: grid; grid-template-columns: 82px 70px 1fr; gap: 12px; align-items: center; padding: 12px 14px; border-radius: 14px; background: #0b1220; border: 1px solid rgba(255,255,255,.08); color: #cbd5e1; font: 700 12px JetBrains Mono, monospace; }
.timeline b { color: #38bdf8; }
.arch-card { background: linear-gradient(135deg,#eff6ff,#ecfdf5); border: 1px solid #cfe1f5; border-radius: 30px; padding: 26px; }
.arch-card h2 { font-size: 26px; margin-bottom: 12px; }
.arch-card p { color: #536783; line-height: 1.75; }
.arch-map { min-height: 220px; margin-top: 20px; border-radius: 22px; background-image: linear-gradient(#dbeafe 1px,transparent 1px),linear-gradient(90deg,#dbeafe 1px,transparent 1px); background-size: 26px 26px; position: relative; overflow: hidden; border: 1px solid #d8e4f2; }
.arch-node { position: absolute; padding: 10px 12px; border-radius: 14px; background: #102033; color: #fff; font: 900 11px JetBrains Mono, monospace; box-shadow: 0 12px 28px rgba(16,32,51,.16); }
.arch-node.n1 { left: 42%; top: 22%; background:#2f6dff; } .arch-node.n2 { left: 14%; top: 54%; background:#09a884; } .arch-node.n3 { right: 14%; top: 54%; background:#ea7a00; } .arch-node.n4 { left: 42%; bottom: 12%; background:#7c3aed; }
.arch-map::before,.arch-map::after { content:''; position:absolute; height:2px; background:#5b93ff; transform-origin:left center; opacity:.75; } .arch-map::before{ width:42%; left:28%; top:48%; } .arch-map::after{ width:22%; left:47%; top:52%; transform:rotate(90deg); }
@media (max-width: 900px){ .detail-hero-grid,.detail-grid{grid-template-columns:1fr}.detail-actions{display:none}.ops-grid{grid-template-columns:1fr}.timeline div{grid-template-columns:1fr}.detail-hero{padding-top:42px} }

/* --- Boutons plus visibles / cliquables --- */
.btn, .nav-cta, .detail-link, .hero-links a, .trust-strip a, .service-card, .cookie-btn, .chat-toggle, .quick-replies button, .chat-form button {
  position: relative;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.btn:hover, .nav-cta:hover, .detail-link:hover, .hero-links a:hover, .trust-strip a:hover, .cookie-btn:hover, .chat-toggle:hover, .quick-replies button:hover, .chat-form button:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 42px rgba(37, 99, 235, .18);
}
.btn:focus-visible, .nav a:focus-visible, .detail-link:focus-visible, .service-card:focus-visible, .cookie-btn:focus-visible, .chat-toggle:focus-visible, .chat-form button:focus-visible {
  outline: 4px solid rgba(37,99,235,.22);
  outline-offset: 3px;
}
.service-card::before {
  content: "Cliquable";
  position: absolute;
  top: 18px;
  right: 18px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(37,99,235,.1);
  color: #2563eb;
  font: 900 10px JetBrains Mono, monospace;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.service-card:hover::before { background: #2563eb; color: #fff; }

/* --- Vues de déploiement détaillées --- */
.deploy-visual-card { overflow: hidden; }
.deploy-visual-card .arch-copy { max-width: 980px; }
.deploy-visual {
  min-height: 310px;
  margin-top: 24px;
  border-radius: 26px;
  border: 1px solid #d2e2f3;
  background: radial-gradient(circle at 15% 20%, rgba(47,109,255,.13), transparent 28%), radial-gradient(circle at 86% 18%, rgba(9,168,132,.13), transparent 30%), #f8fbff;
  position: relative;
  overflow: hidden;
}
.deploy-visual::before {
  content: "";
  position: absolute; inset: 0;
  background-image: linear-gradient(#dbeafe 1px, transparent 1px), linear-gradient(90deg, #dbeafe 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: .75;
}
.deploy-flow { position: relative; z-index: 1; min-height: 310px; }
.deploy-flow::before, .deploy-flow::after {
  content: ""; position: absolute; background: linear-gradient(90deg,#2f6dff,#09a884); opacity: .65; border-radius: 999px;
}
.deploy-flow::before { left: 12%; right: 12%; top: 50%; height: 4px; }
.deploy-flow::after { left: 50%; top: 16%; bottom: 16%; width: 4px; }
.deploy-flow span {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 130px;
  min-height: 54px;
  padding: 12px 16px;
  border-radius: 18px;
  background: #fff;
  color: #102033;
  border: 1px solid #cbdcf0;
  box-shadow: 0 18px 40px rgba(16,32,51,.12);
  font: 900 12px JetBrains Mono, monospace;
  text-align: center;
}
.deploy-flow span:nth-child(1){left:6%;top:42%}.deploy-flow span:nth-child(2){left:25%;top:16%}.deploy-flow span:nth-child(3){left:42%;top:40%;background:#102033;color:#fff}.deploy-flow span:nth-child(4){right:26%;top:16%}.deploy-flow span:nth-child(5){right:7%;top:42%}.deploy-flow span:nth-child(6){left:27%;bottom:13%}.deploy-flow span:nth-child(7){right:24%;bottom:13%}
.windows-diagram .deploy-flow span:nth-child(3), .linux-diagram .deploy-flow span:nth-child(2), .monitoring-diagram .deploy-flow span:nth-child(2){background:#2563eb;color:#fff}
.firewall-diagram .deploy-flow span:nth-child(2), .security-diagram .deploy-flow span:nth-child(3){background:#dc2626;color:#fff}
.backup-diagram .deploy-flow span:nth-child(2){background:#0aa68a;color:#fff}
.tier-diagram .deploy-flow span:nth-child(1){background:#2563eb;color:#fff}.tier-diagram .deploy-flow span:nth-child(2){background:#0aa68a;color:#fff}.tier-diagram .deploy-flow span:nth-child(3){background:#d97706;color:#fff}
.support-diagram .deploy-flow::before { background: linear-gradient(90deg,#09a884,#2563eb,#d97706); }
.network-diagram .deploy-flow::after { display:none; }
.network-diagram .deploy-flow span:nth-child(2){background:#102033;color:#fff}

/* --- Cookies --- */
.cookie-banner {
  position: fixed;
  left: 24px; right: 24px; bottom: 24px;
  z-index: 200;
  display: none;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 20px;
  border-radius: 24px;
  background: rgba(255,255,255,.96);
  border: 1px solid #d8e4f2;
  box-shadow: 0 24px 80px rgba(16,32,51,.2);
  backdrop-filter: blur(16px);
}
.cookie-banner.show { display: grid; }
.cookie-banner strong { display:block; margin-bottom:6px; color:#102033; font-size:18px; }
.cookie-banner p { margin:0; color:#64748b; line-height:1.55; }
.cookie-actions { display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.cookie-btn { border:1px solid #d4e2f3; border-radius:999px; background:#fff; color:#536783; padding:12px 15px; cursor:pointer; font-weight:900; }
.cookie-primary { background:linear-gradient(135deg,#2563eb,#0aa68a); color:#fff; border-color:transparent; }
.cookie-settings { position:fixed; inset:0; z-index:210; display:none; place-items:center; background:rgba(15,23,42,.45); padding:20px; }
.cookie-settings.show { display:grid; }
.cookie-modal { width:min(520px,100%); background:#fff; border-radius:26px; padding:26px; box-shadow:0 30px 100px rgba(15,23,42,.35); position:relative; }
.modal-close { position:absolute; right:18px; top:14px; border:0; background:#eef5fb; width:38px; height:38px; border-radius:12px; font-size:24px; cursor:pointer; }
.switch-row { display:flex; justify-content:space-between; gap:20px; align-items:center; padding:16px 0; border-top:1px solid #e2e8f0; }
.switch-row span { font-weight:900; }.switch-row small { display:block; margin-top:4px; color:#64748b; font-weight:600; }
.switch-row input { width:auto; transform:scale(1.25); }

/* --- Chat box --- */
.chat-widget { position:fixed; right:26px; bottom:26px; z-index:190; font-family:inherit; }
.chat-toggle { border:0; border-radius:24px; padding:14px 18px; background:linear-gradient(135deg,#0f172a,#2563eb 58%,#0aa68a); color:#fff; font-weight:950; cursor:pointer; box-shadow:0 22px 65px rgba(37,99,235,.38); display:flex; align-items:center; gap:12px; min-width:230px; min-height:66px; position:relative; overflow:visible; animation:chatFloat 2.8s ease-in-out infinite; }
.chat-toggle::after { content:'1'; position:absolute; top:-9px; right:-8px; width:28px; height:28px; border-radius:999px; background:#ef4444; color:#fff; display:grid; place-items:center; font-size:13px; border:3px solid #fff; box-shadow:0 10px 25px rgba(239,68,68,.4); }
.chat-pulse { position:absolute; inset:-7px; border-radius:30px; border:2px solid rgba(37,99,235,.24); animation:chatPulse 1.8s infinite; }
.chat-icon { width:42px; height:42px; display:grid; place-items:center; border-radius:16px; background:rgba(255,255,255,.16); font-size:23px; }
.chat-toggle-text { display:grid; text-align:left; line-height:1.05; }
.chat-toggle-text b { font-size:16px; }
.chat-toggle-text small { margin-top:5px; color:rgba(255,255,255,.82); font-size:12px; font-weight:800; }
@keyframes chatFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }
@keyframes chatPulse { 0%{opacity:.85; transform:scale(.98)} 100%{opacity:0; transform:scale(1.12)} }
.chat-box { display:none; width:min(430px, calc(100vw - 32px)); margin-bottom:16px; background:#fff; border:1px solid #d8e4f2; border-radius:28px; overflow:hidden; box-shadow:0 30px 100px rgba(16,32,51,.28); }
.chat-box.open { display:block; animation:chatOpen .2s ease-out; }
@keyframes chatOpen { from{opacity:0; transform:translateY(10px) scale(.98)} to{opacity:1; transform:translateY(0) scale(1)} }
.chat-head { display:flex; justify-content:space-between; gap:14px; align-items:center; padding:18px; background:linear-gradient(135deg,#102033,#1d4ed8); color:#fff; }
.chat-agent { display:flex; align-items:center; gap:12px; }
.agent-avatar { width:42px; height:42px; border-radius:16px; background:#fff; color:#2563eb; display:grid; place-items:center; font-weight:1000; }
.online-dot { display:inline-block; width:8px; height:8px; border-radius:999px; background:#22c55e; margin-right:5px; box-shadow:0 0 0 4px rgba(34,197,94,.18); }
.chat-head small { display:block; color:rgba(255,255,255,.76); margin-top:3px; }
.chat-head button { border:0; background:rgba(255,255,255,.14); color:#fff; width:38px; height:38px; border-radius:14px; font-size:24px; cursor:pointer; }
.chat-intro { padding:14px 18px; background:#ecfdf5; color:#315042; border-bottom:1px solid #d9f4e8; line-height:1.45; font-size:14px; }
.chat-messages { max-height:245px; overflow:auto; padding:16px; display:grid; gap:10px; background:#f8fbff; }
.bot-msg, .user-msg { padding:12px 14px; border-radius:16px; line-height:1.45; font-size:14px; }
.bot-msg { background:#fff; border:1px solid #dbe6f3; color:#536783; }
.user-msg { background:#2563eb; color:#fff; justify-self:end; max-width:88%; }
.quick-replies { display:flex; gap:8px; flex-wrap:wrap; padding:12px 16px; border-top:1px solid #e2e8f0; }
.quick-replies button { border:1px solid #bfd6f6; border-radius:999px; padding:10px 12px; background:#fff; color:#1d4ed8; font-weight:900; cursor:pointer; }
.chat-form { display:grid; grid-template-columns:1fr; gap:9px; padding:13px 16px 16px; border-top:1px solid #e2e8f0; }
.chat-form input, .chat-form textarea { width:100%; border:1px solid #cbd8e8; border-radius:16px; padding:12px 13px; font:inherit; color:#102033; background:#fff; resize:none; }
.chat-form input:focus, .chat-form textarea:focus { outline:3px solid rgba(37,99,235,.18); border-color:#2563eb; }
.chat-form button { border:0; border-radius:16px; background:linear-gradient(135deg,#0aa68a,#2563eb); color:#fff; padding:13px 15px; font-weight:1000; cursor:pointer; box-shadow:0 12px 25px rgba(10,166,138,.25); }
.chat-privacy { color:#64748b; line-height:1.35; }
@media (max-width: 760px) {
  .cookie-banner { grid-template-columns:1fr; left:12px; right:12px; bottom:12px; }
  .cookie-actions { justify-content:stretch; }.cookie-btn { flex:1; }
  .chat-widget { right:14px; bottom:14px; }
  .deploy-flow span { min-width:105px; font-size:10px; padding:10px; }
  .deploy-flow span:nth-child(1){left:4%;top:8%}.deploy-flow span:nth-child(2){left:52%;top:8%}.deploy-flow span:nth-child(3){left:28%;top:38%}.deploy-flow span:nth-child(4){right:4%;top:38%}.deploy-flow span:nth-child(5){left:4%;top:68%}.deploy-flow span:nth-child(6){left:38%;bottom:6%}.deploy-flow span:nth-child(7){right:4%;bottom:6%}
}

/* Corrections demandées : logo plus propre, hover explicite, légendes de graphes, cookies sur une ligne, chat manuel */
.brand-mark { position:relative; overflow:hidden; border-radius:15px; background:linear-gradient(135deg,#102033 0%,#2563eb 55%,#0aa68a 100%); }
.brand-mark b { position:relative; z-index:2; letter-spacing:-.5px; }
.brand-mark i { position:absolute; width:26px; height:26px; right:-8px; bottom:-8px; border-radius:999px; background:rgba(255,255,255,.24); }

.service-card { overflow:hidden; }
.service-details { background:linear-gradient(135deg,#12355f,#102a4a); color:#fff; border:0; box-shadow:0 18px 45px rgba(16,42,74,.28); }
.service-details strong { color:#7dd3fc; font-size:18px; }
.service-details li { color:#fff; font-size:16px; }
.service-details em { display:inline-flex; align-items:center; margin-top:8px; color:#7dd3fc; font-weight:950; font-style:normal; }
.service-card:hover .service-details { transform:translateY(0); opacity:1; }
.service-card:hover h3 { color:#102033; }

.chart-legend { display:flex; flex-wrap:wrap; gap:10px 16px; padding:0 4px 4px; margin-top:-4px; color:#cbd5e1; font-size:12px; font-weight:800; }
.chart-legend span { display:inline-flex; align-items:center; gap:7px; }
.chart-legend i { width:18px; height:4px; border-radius:999px; display:inline-block; }
.lg-blue{background:#60a5fa}.lg-teal{background:#2dd4bf}.lg-orange{background:#f59e0b}.lg-red{background:#f87171}.lg-green{background:#22c55e}.lg-purple{background:#a78bfa}

.cookie-banner { grid-template-columns:auto auto !important; align-items:center; max-width:1180px; padding:12px 14px; border-radius:999px; }
.cookie-banner > div:first-child { display:flex; align-items:center; gap:12px; min-width:0; }
.cookie-banner strong { margin:0; white-space:nowrap; font-size:15px; }
.cookie-banner p { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-size:13px; }
.cookie-actions { flex-wrap:nowrap; }
.cookie-btn { padding:10px 13px; white-space:nowrap; }

.chat-toggle { min-width:285px; min-height:74px; border-radius:28px; padding:16px 20px; box-shadow:0 26px 80px rgba(37,99,235,.48); }
.chat-toggle::after { content:'?'; width:32px; height:32px; font-size:15px; }
.chat-toggle-text b { font-size:17px; }
.chat-toggle-text small { font-size:12px; }
.chat-box { width:min(460px, calc(100vw - 32px)); }
.chat-form { grid-template-columns:1fr auto; align-items:end; }
.chat-form textarea { min-height:52px; }
.chat-form button { height:52px; padding-inline:18px; }
.chat-privacy { grid-column:1 / -1; }

@media (max-width: 760px) {
  .cookie-banner { grid-template-columns:1fr !important; border-radius:24px; }
  .cookie-banner > div:first-child { display:block; }
  .cookie-banner p { white-space:normal; }
  .cookie-actions { flex-wrap:wrap; justify-content:flex-start; }
  .chat-widget { right:14px; bottom:14px; }
  .chat-toggle { min-width:0; width:calc(100vw - 28px); }
  .chat-form { grid-template-columns:1fr; }
}


/* Chatbox professionnelle - version finale */
.chat-toggle { background:linear-gradient(135deg,#0b1220,#1d4ed8 62%,#0f766e); min-width:300px; min-height:76px; border-radius:26px; }
.chat-icon { font-weight:1000; font-size:15px; letter-spacing:.5px; background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.22); }
.chat-toggle-text b { font-size:18px; }
.chat-toggle-text small { color:rgba(255,255,255,.86); }
.chat-box { width:min(480px, calc(100vw - 32px)); border-radius:24px; border:1px solid #cfe0f5; }
.chat-head { background:linear-gradient(135deg,#0b1220,#1d4ed8); padding:18px 20px; }
.agent-avatar { background:#eef6ff; color:#1d4ed8; border:1px solid rgba(255,255,255,.7); }
.chat-statusbar { display:flex; justify-content:space-between; align-items:center; gap:12px; padding:12px 18px; background:#f8fafc; border-bottom:1px solid #e2e8f0; color:#475569; font-size:13px; font-weight:800; }
.chat-statusbar strong { color:#0f766e; background:#dcfce7; border:1px solid #bbf7d0; padding:5px 9px; border-radius:999px; font-size:12px; }
.chat-intro { display:none !important; }
.chat-messages { background:#f8fbff; min-height:180px; max-height:300px; }
.bot-msg, .user-msg { border-radius:18px; padding:12px 14px; line-height:1.45; font-size:14px; }
.bot-msg { background:#ffffff; border:1px solid #dbe7f5; color:#102033; box-shadow:0 8px 22px rgba(15,23,42,.04); }
.user-msg { background:#1d4ed8; color:#fff; justify-self:end; max-width:86%; }
.quick-replies { background:#fff; border-top:1px solid #e2e8f0; }
.quick-replies button { background:#fff; color:#1d4ed8; border:1px solid #bfdbfe; box-shadow:none; }
.chat-form { background:#fff; grid-template-columns:1fr auto; }
.chat-form textarea { min-height:54px; border-radius:18px; }
.chat-form button { height:54px; border-radius:18px; min-width:110px; }
.chat-privacy { font-size:12px; color:#64748b; }
.brand-mark { border-radius:16px; background:linear-gradient(135deg,#0b1220 0%,#1d4ed8 56%,#0f766e 100%); border:1px solid rgba(29,78,216,.15); }
.brand-mark em { position:absolute; width:7px; height:7px; left:9px; top:9px; border-radius:999px; background:#22c55e; box-shadow:0 0 0 5px rgba(34,197,94,.14); }
.cookie-banner { flex-direction:row !important; align-items:center !important; }
.cookie-banner p { margin:0; }
@media (max-width:640px){ .chat-toggle{width:calc(100vw - 28px); min-width:0;} .chat-form{grid-template-columns:1fr;} .chat-form button{width:100%;} .cookie-banner{flex-direction:column !important; align-items:flex-start !important;} }
