/* ============================================================
   FALIKOU SANOGO — Shared Stylesheet
   ============================================================ */

/* === RESET & VARIABLES === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:      #0e1b17;
  --bg-soft: #111f1a;
  --panel:   #162920;
  --panel-2: #1c3228;
  --ink:     #f1f4ec;
  --muted:   rgba(241,244,236,.62);
  --line:    rgba(241,244,236,.1);
  --accent:  #9dff09;
  --accent-2:#ffd447;
  --radius:  16px;
  --radius-sm:10px;
  --ease:    .2s ease;
  --max-w:   1160px;
  --nav-h:   72px;

  /* Alias pour compatibilité slider (tokens.css naming) */
  --bg2:          #162920;
  --bg3:          #1c3228;
  --border:       rgba(241,244,236,.1);
  --white:        #f1f4ec;
  --font-display: 'Montserrat', sans-serif;
  --font-mono:    'DM Mono', monospace;
  --accent-dim:   rgba(157,255,9,0.1);
}

html { scroll-behavior: smooth; overflow-x: hidden; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: 'Montserrat', sans-serif;
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
}

a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
ul, ol { list-style: none; }

/* === LAYOUT === */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 28px; }
.section    { padding: 88px 0; }
.section + .section { border-top: 1px solid rgba(241,244,236,.16); }
.section--alt  {
  background: var(--bg2);
  border-top: 1px solid rgba(157,255,9,.09) !important;
  border-bottom: 1px solid rgba(157,255,9,.09) !important;
}
.section--deep {
  background: var(--bg3);
  border-top: 1px solid rgba(157,255,9,.14) !important;
  border-bottom: 1px solid rgba(157,255,9,.14) !important;
}

/* === TYPOGRAPHY === */
h1, h2, h3, h4, h5 { font-family: 'Montserrat', sans-serif; line-height: 1.1; font-weight: 800; }

.label {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
}

.mono { font-family: 'DM Mono', monospace; }

/* === NAV === */
.topbar {
  position: sticky; top: 0; z-index: 100;
  background: rgba(14,27,23,.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
  height: var(--nav-h);
}

.nav-inner {
  max-width: var(--max-w);
  margin: 0 auto; padding: 0 28px;
  height: 100%;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}

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

.brand-badge {
  width: 40px; height: 40px; border-radius: 12px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  display: flex; align-items: center; justify-content: center;
  color: #0e1b17;
  font-family: 'DM Mono', monospace; font-size: 13px; font-weight: 700;
  flex-shrink: 0;
}

.brand-text { line-height: 1.25; }
.brand-name { font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 700; display: block; }
.brand-role { font-family: 'DM Mono', monospace; font-size: 10px; color: var(--muted); letter-spacing: .06em; display: block; }

.nav-menu { display: flex; align-items: center; gap: 2px; }

.nav-menu a {
  font-family: 'DM Mono', monospace;
  font-size: 11px; letter-spacing: .06em; text-transform: uppercase;
  color: var(--muted);
  padding: 8px 14px; border-radius: 999px;
  transition: color var(--ease), background var(--ease);
  white-space: nowrap;
}

.nav-menu a:hover,
.nav-menu a.active { color: var(--ink); background: rgba(255,255,255,.06); }

.nav-cta {
  background: var(--accent) !important;
  color: #0e1b17 !important;
  font-weight: 700 !important;
  margin-left: 8px;
}
.nav-cta:hover { background: #b4ff4f !important; }

.nav-lang-item {
  margin-left: 6px;
  border-bottom: none !important;
}

.nav-lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 3px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
}

.lang-btn {
  border: none;
  background: transparent;
  color: var(--muted);
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 6px 10px;
  cursor: pointer;
  transition: background var(--ease), color var(--ease);
}

.lang-btn:hover {
  color: var(--ink);
}

.lang-btn.is-active {
  color: #0e1b17;
  background: var(--accent);
}

.nav-toggle {
  display: none;
  flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
}
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--ink); border-radius: 2px; transition: var(--ease); }

/* === BUTTONS === */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  padding: 14px 28px;
  min-height: 46px;
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 15px;
  cursor: pointer; border: none;
  transition: transform var(--ease), opacity var(--ease), background var(--ease);
  text-decoration: none; white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--accent); color: #0e1b17; }
.btn-primary:hover { background: #b4ff4f; }
.btn-outline { background: transparent; border: 1px solid rgba(241,244,236,.2); color: var(--ink); }
.btn-outline:hover { border-color: rgba(157,255,9,.5); color: var(--accent); }
.btn-sm { padding: 10px 20px; font-size: 13px; }

/* === SECTION HEADING === */
.sec-head {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 48px;
}
.sec-head h2 { font-size: clamp(28px, 3.5vw, 40px); }
.sec-line { flex: 1; height: 1px; background: var(--line); }

.sec-tag {
  font-family: 'DM Mono', monospace;
  font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--muted);
  border: 1px solid var(--line); border-radius: 999px; padding: 5px 12px;
  white-space: nowrap;
}

/* === PAGE HERO (inner pages) === */
.page-hero {
  padding: 72px 0 56px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 72px;
}
.page-hero .label { margin-bottom: 18px; display: block; }
.page-hero h1 { font-size: clamp(28px, 6vw, 68px); max-width: 20ch; margin-bottom: 24px; }
.page-hero p  { font-size: 19px; color: var(--muted); max-width: 52ch; line-height: 1.7; }

/* === FOOTER === */
.site-footer { border-top: 1px solid var(--line); padding: 56px 0 32px; }

.footer-inner { max-width: var(--max-w); margin: 0 auto; padding: 0 28px; }

/* Top row : brand + CTAs */
.footer-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap; margin-bottom: 36px;
}
.footer-brand-wrap { display: flex; align-items: center; gap: 12px; }
.footer-brand-name { font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 700; color: var(--ink); }
.footer-brand-role { font-family: 'DM Mono', monospace; font-size: 10px; color: var(--muted); letter-spacing: .05em; margin-top: 2px; }

/* Footer CTAs */
.footer-ctas { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }

/* Simulateur block */
.footer-sim-block {
  display: flex; flex-direction: column; align-items: flex-end; gap: 12px;
  max-width: 300px;
}
.footer-sim-desc {
  font-family: 'DM Mono', monospace; font-size: 11px; color: var(--muted);
  line-height: 1.7; text-align: right; letter-spacing: .02em;
}
@media (max-width: 640px) {
  .footer-sim-block   { align-items: flex-start; max-width: 100%; width: 100%; gap: 14px; }
  .footer-sim-desc    { text-align: left; font-size: 13px; color: var(--ink); line-height: 1.6; letter-spacing: 0; }
  .footer-cta-audit   { white-space: normal !important; width: 100%; box-sizing: border-box; justify-content: space-between; }
}
.footer-cta-audit {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'DM Mono', monospace; font-size: 12px; font-weight: 600; letter-spacing: .06em;
  color: var(--accent);
  border: 1.5px solid var(--accent);
  border-radius: 999px;
  padding: 10px 22px;
  text-decoration: none;
  background: rgba(157,255,9,0.06);
  transition: background var(--ease), color var(--ease), box-shadow var(--ease), transform var(--ease);
  white-space: nowrap;
  position: relative;
  overflow: visible;
}
.footer-cta-audit:hover {
  background: rgba(157,255,9,0.14);
  box-shadow: 0 0 18px rgba(157,255,9,0.25);
  transform: translateY(-1px);
}
.footer-cta-audit__pulse {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  animation: cta-pulse 1.8s ease-in-out infinite;
}
@keyframes cta-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(157,255,9,0.55); }
  50%       { box-shadow: 0 0 0 6px rgba(157,255,9,0); }
}
.footer-cta-audit__label { flex: 1; }
.footer-cta-audit__arrow {
  transition: transform var(--ease);
  display: inline-block;
}
.footer-cta-audit:hover .footer-cta-audit__arrow { transform: translateX(4px); }
.footer-cta-pack {
  font-family: 'DM Mono', monospace; font-size: 11px; letter-spacing: .04em;
  background: var(--accent); color: #0e1b17; font-weight: 700;
  border-radius: 999px; padding: 8px 18px; text-decoration: none;
  transition: background var(--ease); white-space: nowrap;
}
.footer-cta-pack:hover { background: #b4ff4f; }

/* Mid : nav links */
.footer-mid { border-top: 1px solid var(--line); padding: 24px 0; margin-bottom: 24px; }
.footer-links { display: flex; gap: 24px; flex-wrap: wrap; }
.footer-links a {
  font-family: 'DM Mono', monospace; font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--muted); transition: color var(--ease); text-decoration: none;
}
.footer-links a:hover { color: var(--accent); }

/* Bottom : copyright */
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.footer-copy { font-family: 'DM Mono', monospace; font-size: 11px; color: rgba(220,229,240,.4); }
.footer-email { font-family: 'DM Mono', monospace; font-size: 11px; color: rgba(220,229,240,.4); text-decoration: none; transition: color var(--ease); }
.footer-email:hover { color: var(--muted); }

/* === CHIPS === */
.chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip {
  font-family: 'DM Mono', monospace; font-size: 11px;
  padding: 6px 12px; border: 1px solid var(--line); border-radius: 999px;
  color: var(--muted); background: rgba(255,255,255,.02);
}
.chip-accent { border-color: rgba(157,255,9,.35); color: var(--accent); background: rgba(157,255,9,.07); }

/* ============================================================
   HOMEPAGE — sections after hero
   ============================================================ */

/* Clients strip */
.home-clients {
  padding: 48px 0;
  border-bottom: 1px solid var(--line);
}

.home-clients-label {
  font-family: 'DM Mono', monospace;
  font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 24px;
}

.home-clients-strip {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.clients-track {
  display: flex;
  gap: 12px;
  align-items: center;
  width: max-content;
  animation: marquee-logos 28s linear infinite;
}
.clients-track:hover { animation-play-state: paused; }
@keyframes marquee-logos {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.client-logo {
  padding: 12px 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.03);
  display: flex; align-items: center; justify-content: center;
  min-height: 56px; min-width: 110px;
  transition: border-color var(--ease);
}
.client-logo:hover { border-color: rgba(157,255,9,.35); }

.client-logo img {
  max-height: 32px; max-width: 110px;
  object-fit: contain;
  opacity: .95;
}

.client-name {
  font-family: 'DM Mono', monospace;
  font-size: 11px; letter-spacing: .06em; text-transform: uppercase;
  color: var(--muted);
}

/* About preview */
.home-about-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.home-about-text .sec-label {
  font-family: 'DM Mono', monospace;
  font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 20px; display: block;
}

.home-about-text h2 { font-size: clamp(26px, 3vw, 38px); margin-bottom: 20px; }
.home-about-text p  { font-size: 16px; color: var(--muted); line-height: 1.8; margin-bottom: 16px; }

.home-about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.home-about-visual {
  background: linear-gradient(145deg, var(--panel), rgba(157,255,9,.06));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.home-about-img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center top;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.1);
  background: var(--panel-2);
}
.home-about-note {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
  font-family: 'DM Mono', monospace;
}

/* ── À propos mockup browser AGNA ── */
.ha-mockup {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ha-browser {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 60px rgba(0,0,0,.55), 0 2px 8px rgba(0,0,0,.3);
  background: #0c141f;
  position: relative;
  z-index: 1;
}
.ha-browser-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: #111927;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ha-bdot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.ha-bdot--r { background: #ff5f57; }
.ha-bdot--y { background: #febc2e; }
.ha-bdot--g { background: #28c840; }
.ha-browser-url {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 6px;
  padding: 4px 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: rgba(220,229,240,.55);
  letter-spacing: .03em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ha-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: center top;
  display: block;
}
/* Instagram interaction badge */
.ha-ig-card {
  position: absolute;
  right: -18px;
  bottom: 60px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(10,17,28,.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(225,48,108,.3);
  border-radius: 12px;
  padding: 9px 13px;
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
  z-index: 2;
  animation: ha-float 4s ease-in-out infinite;
}
.ha-ig-stats { display: flex; flex-direction: column; line-height: 1.1; }
.ha-ig-num {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 800;
  color: var(--white);
}
.ha-ig-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: rgba(220,229,240,.55);
}
/* Projet tag */
.ha-project-tag {
  position: absolute;
  left: -14px;
  top: 48px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(157,255,9,.1);
  border: 1px solid rgba(157,255,9,.3);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 99px;
  padding: 7px 13px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: .04em;
  white-space: nowrap;
  z-index: 2;
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
  animation: ha-float 3.5s ease-in-out infinite .8s;
}
@keyframes ha-float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}
/* ── KPI strip — À propos ──────────────────────────── */
.ha-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin: 20px 0 22px;
}
.ha-kpi-c {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 10px;
  padding: 13px 8px 11px;
}
.ha-kpi-val {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}
.ha-kpi-desc {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 5px;
  line-height: 1.4;
}

.stat-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 24px 20px;
}
.stat-n { font-size: 42px; font-weight: 800; color: var(--accent); line-height: 1; margin-bottom: 8px; }
.stat-l {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.45;
  word-break: break-word;
}

/* Blog preview */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

.blog-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; display: flex; flex-direction: column;
  transition: border-color var(--ease), transform var(--ease);
}
.blog-card:hover { border-color: rgba(157,255,9,.3); transform: translateY(-3px); }

.blog-card-img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  object-position: center;
  background: var(--panel-2);
  display: block;
}
.blog-card-img-placeholder {
  width: 100%; aspect-ratio: 16/9;
  background:
    radial-gradient(circle at 20% 30%, rgba(157,255,9,.18), transparent 44%),
    linear-gradient(135deg, #13251e, #1c3228 55%, #111f1a);
  display: block;
}

.blog-card-body { padding: 22px 24px 24px; flex: 1; display: flex; flex-direction: column; }
.blog-card-cat {
  font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 10px;
}
.blog-card-title {
  font-size: 18px; font-weight: 700; line-height: 1.3; margin-bottom: 12px;
}
.blog-card-title a { color: var(--ink); }
.blog-card-title a:hover { color: var(--accent); }
.blog-card-excerpt { font-size: 14px; color: var(--muted); line-height: 1.7; flex: 1; }
.blog-card-meta {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 18px;
  font-family: 'DM Mono', monospace; font-size: 10px; color: var(--muted);
}
.blog-card-read { color: var(--accent); font-weight: 500; transition: opacity var(--ease); }
.blog-card-read:hover { opacity: .75; }

/* Featured product */
.featured-product {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden;
  display: grid; grid-template-columns: 1fr 360px;
}

.featured-product-content {
  padding: 48px 52px;
}

.featured-product-content .label { display: block; margin-bottom: 18px; }
.featured-product-content h3 { font-size: clamp(26px, 3vw, 40px); max-width: 20ch; margin-bottom: 16px; }
.featured-product-content p { font-size: 16px; color: var(--muted); line-height: 1.75; max-width: 46ch; }

.featured-product-footer { margin-top: 28px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.product-price { font-size: 32px; font-weight: 800; color: var(--accent); font-family: 'Montserrat', sans-serif; }
.product-old-price { font-family: 'DM Mono', monospace; font-size: 13px; color: var(--muted); text-decoration: line-through; }

.featured-product-visual {
  background: linear-gradient(135deg, rgba(157,255,9,.12), rgba(255,212,71,.08));
  border-left: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  min-height: 360px;
}

.featured-product-img {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: contain;
  border-radius: 12px;
}

.featured-product-badge {
  font-family: 'Montserrat', sans-serif;
  font-size: 42px; font-weight: 800;
  color: rgba(157,255,9,.2);
  text-align: center;
  line-height: 1.15;
  letter-spacing: -.02em;
}

/* ============================================================
   À PROPOS PAGE
   ============================================================ */

.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }

.about-photo {
  width: 100%; aspect-ratio: 4/5;
  object-fit: cover; object-position: center top;
  border-radius: var(--radius); border: 1px solid var(--line);
  background: var(--panel);
}

.about-bio h2 { font-size: clamp(28px, 3vw, 38px); margin-bottom: 20px; }
.about-bio p  { font-size: 16px; color: var(--muted); line-height: 1.85; margin-bottom: 18px; }

/* Timeline */
.timeline { display: flex; flex-direction: column; gap: 0; }
.timeline-item {
  display: grid; grid-template-columns: 100px 1fr;
  gap: 24px; padding: 28px 0;
  border-bottom: 1px solid var(--line);
  align-items: start;
}
.timeline-item:last-child { border-bottom: none; }
.timeline-year { font-family: 'DM Mono', monospace; font-size: 11px; letter-spacing: .08em; color: var(--accent); padding-top: 4px; }
.timeline-body h4 { font-size: 18px; margin-bottom: 6px; }
.timeline-body .tl-company { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--accent-2); letter-spacing: .06em; margin-bottom: 10px; display: block; }
.timeline-body p { font-size: 14px; color: var(--muted); line-height: 1.7; }

/* Compétences */
.skills-bento {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 40px;
  align-items: start;
}
.skills-bars-col { display: flex; flex-direction: column; }
.skills-list { display: flex; flex-direction: column; gap: 24px; }
.skill-row { display: flex; flex-direction: column; gap: 8px; }
.skill-row-top { display: flex; justify-content: space-between; align-items: center; }
.skill-name { font-family: 'DM Mono', monospace; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--ink); }
.skill-pct  { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--accent); letter-spacing: .04em; min-width: 32px; text-align: right; }
.skill-bar-bg { height: 5px; background: var(--line); border-radius: 999px; overflow: hidden; }
.skill-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), #39ff14);
  border-radius: 999px;
  width: 0;
  transition: width .9s cubic-bezier(.4,0,.2,1);
}

/* Skill stats column */
.skills-stats-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  position: sticky;
  top: calc(var(--nav-h) + 24px);
}
.skill-stat-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  transition: border-color .2s, transform .2s;
}
.skill-stat-card:hover { border-color: rgba(157,255,9,.3); transform: translateY(-2px); }
.skill-stat-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 32px;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
  letter-spacing: -1px;
}
.skill-stat-unit { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--muted); }
.skill-stat-label { font-size: 11px; color: var(--muted); line-height: 1.4; margin-top: 6px; }

@media (max-width: 900px) {
  .skills-bento { grid-template-columns: 1fr; gap: 36px; }
  .skills-stats-col { position: static; grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 600px) {
  .skills-stats-col { grid-template-columns: repeat(2, 1fr); }
  .skill-stat-num { font-size: 26px; }
}

/* ============================================================
   BLOG PAGE
   ============================================================ */

.blog-listing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

/* Bouton Voir plus */
.blog-load-more-btn {
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 10px;
  background: transparent;
  border: 1.5px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-family: 'DM Mono', monospace; font-size: 12px; letter-spacing: .06em;
  padding: 13px 28px;
  transition: color .2s, border-color .2s, background .2s, box-shadow .2s, transform .15s;
}
.blog-load-more-btn:hover {
  color: var(--accent);
  border-color: var(--accent);
  background: rgba(157,255,9,.05);
  box-shadow: 0 0 14px rgba(157,255,9,.15);
  transform: translateY(-1px);
}
.blog-load-more-btn .blm-label { font-weight: 600; }
#blm-count {
  font-size: 11px; color: var(--muted); opacity: .7;
  background: rgba(255,255,255,.06);
  border-radius: 999px; padding: 2px 9px;
}

/* Article page */
.article-head { padding: 64px 0 48px; }
.article-head-outer {
  background: var(--bg2);
  border-bottom: 1px solid rgba(157,255,9,.09);
  margin-bottom: 64px;
}
.article-meta { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; flex-wrap: wrap; }
.article-views {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
}
.article-cat-tag {
  font-family: 'DM Mono', monospace; font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--accent); border: 1px solid rgba(157,255,9,.35); border-radius: 999px;
  padding: 5px 14px; background: rgba(157,255,9,.07);
}
.article-date {
  font-family: 'DM Mono', monospace; font-size: 11px; color: var(--muted);
}
.article-title { font-size: clamp(34px, 5vw, 62px); line-height: 1.04; max-width: 22ch; margin-bottom: 24px; }
.article-intro { font-size: 20px; color: var(--muted); line-height: 1.65; max-width: 58ch; }

.article-layout { display: grid; grid-template-columns: 1fr 280px; gap: 64px; align-items: start; }
.article-featured { grid-column: 1 / -1; margin-bottom: 48px; }
.article-hero-img {
  width: 100%;
  max-height: 500px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  display: block;
}
.article-featured-caption {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  text-align: center;
  margin-top: 12px;
  letter-spacing: .03em;
}
.article-body h2 { font-size: 26px; margin: 52px 0 18px; }
.article-body h3 { font-size: 20px; margin: 40px 0 14px; }
.article-body p  { font-size: 17px; color: rgba(241,244,236,.88); line-height: 1.85; margin-bottom: 22px; text-align: justify; hyphens: auto; }
@media (max-width: 600px) {
  .article-body p { text-align: left; hyphens: none; }
}
.article-body ul,
.article-body ol { padding-left: 22px; margin-bottom: 22px; }
.article-body li { font-size: 17px; color: rgba(241,244,236,.85); line-height: 1.85; margin-bottom: 8px; }
.article-body strong { color: var(--ink); font-weight: 700; }
.article-body blockquote {
  border-left: 3px solid var(--accent);
  padding: 16px 24px;
  margin: 32px 0;
  background: rgba(157,255,9,.06);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.article-body blockquote p { color: var(--ink); font-style: italic; margin: 0; font-size: 18px; }

.article-body img {
  width: 100%; border-radius: 12px;
  border: 1px solid var(--line);
  display: block; margin: 0 auto;
}
.article-body figure {
  margin: 36px 0;
}
.article-body figcaption {
  font-family: 'DM Mono', monospace;
  font-size: 12px; color: var(--muted);
  text-align: center; margin-top: 10px;
  line-height: 1.5;
}
.article-body .step-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--accent); color: var(--bg);
  font-family: 'DM Mono', monospace; font-size: 13px; font-weight: 700;
  flex-shrink: 0; margin-right: 10px; vertical-align: middle;
}
.article-body .step-block {
  background: rgba(157,255,9,.06);
  border: 1px solid rgba(157,255,9,.2);
  border-radius: 12px; padding: 20px 24px;
  margin: 32px 0;
}
.article-body .step-block h3 {
  display: flex; align-items: center;
  margin-top: 0; margin-bottom: 12px;
  font-size: 18px;
}
.article-body .tip-box {
  background: rgba(255,212,71,.07);
  border: 1px solid rgba(255,212,71,.25);
  border-radius: 12px; padding: 16px 20px;
  margin: 28px 0; font-size: 15px;
  color: var(--muted); line-height: 1.7;
}
.article-body .tip-box strong { color: #ffd447; }

.article-sidebar { position: sticky; top: 88px; }
.sidebar-cta {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px 24px;
}
.article-sidebar {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.sidebar-cta .label { display: block; margin-bottom: 14px; }
.sidebar-cta h3 { font-size: 20px; margin-bottom: 12px; }
.sidebar-cta p { font-size: 14px; color: var(--muted); line-height: 1.65; margin-bottom: 20px; }
.sidebar-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 18px 16px;
}
.sidebar-card h4 {
  font-size: 14px;
  margin-bottom: 12px;
  font-family: 'DM Mono', monospace;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
}
.sidebar-filter-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.sidebar-filter-link {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 11px;
  text-decoration: none;
  font-family: 'DM Mono', monospace;
}
.sidebar-filter-link:hover {
  color: var(--fg);
  border-color: rgba(157,255,9,.35);
}
.sidebar-filter-link.is-active {
  color: var(--accent);
  border-color: rgba(157,255,9,.35);
  background: rgba(157,255,9,.08);
}
.sidebar-shortcuts {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sidebar-shortcut {
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-decoration: none;
  color: var(--muted);
  padding: 9px 10px;
  border-radius: 8px;
  border: 1px solid var(--line);
  font-size: 13px;
}
.sidebar-shortcut:hover {
  color: var(--fg);
  border-color: rgba(157,255,9,.35);
}
.sidebar-shortcut::after {
  content: '→';
  color: var(--accent);
}

/* ── Sidebar ToC ─────────────────────────────────── */
.sidebar-toc { display: none; }
.toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.toc-link {
  display: block;
  font-size: 12px;
  color: var(--muted);
  text-decoration: none;
  line-height: 1.45;
  padding: 5px 8px 5px 10px;
  border-radius: 6px;
  border-left: 2px solid transparent;
  transition: color .15s, border-color .15s, background .15s;
}
.toc-link--sub {
  padding-left: 22px;
  font-size: 11px;
  opacity: .85;
}
.toc-link:hover {
  color: var(--fg);
  background: rgba(255,255,255,.04);
  border-left-color: rgba(157,255,9,.3);
}
.toc-link.is-active {
  color: var(--accent);
  border-left-color: var(--accent);
  background: rgba(157,255,9,.06);
}

/* ── Sidebar Author ──────────────────────────────── */
.sidebar-author-inner {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.sidebar-author-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
}
.sidebar-author-role {
  font-size: 11px;
  color: var(--muted);
  font-family: 'DM Mono', monospace;
  margin-top: 2px;
  line-height: 1.4;
}
.sidebar-author-bio {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.65;
  margin-bottom: 12px;
}

/* ── Article end CTA ─────────────────────────────── */
.article-end-cta {
  background: linear-gradient(135deg, var(--panel), rgba(157,255,9,.06));
  border: 1px solid rgba(157,255,9,.2);
  border-radius: var(--radius);
  padding: 36px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  margin-top: 48px;
  margin-bottom: 40px;
}
.article-end-cta-text h3 { font-size: clamp(18px, 2vw, 24px); margin-bottom: 8px; }
.article-end-cta-text p { font-size: 15px; color: var(--muted); margin: 0; line-height: 1.6; max-width: 42ch; }

/* ============================================================
   BOUTIQUE PAGE
   ============================================================ */

/* Produit phare */
.boutique-featured {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  display: grid; grid-template-columns: 1fr 1.35fr; overflow: hidden;
}
.boutique-featured-visual {
  background: linear-gradient(135deg, rgba(157,255,9,.12), rgba(255,212,71,.07));
  display: flex; align-items: center; justify-content: center;
  min-height: 400px;
  border-right: 1px solid var(--line);
  overflow: hidden;
}
.boutique-featured-visual img { width: 100%; height: 100%; object-fit: contain; object-position: center; display: block; padding: 18px; }
.boutique-featured-body {
  padding: 48px 44px; display: flex; flex-direction: column; justify-content: center;
}
.boutique-featured-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(157,255,9,.1); border: 1px solid rgba(157,255,9,.3);
  border-radius: 999px; padding: 6px 14px; margin-bottom: 20px; width: fit-content;
  font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent);
}
.boutique-featured-title { font-size: clamp(24px, 2.8vw, 36px); font-weight: 800; line-height: 1.2; margin-bottom: 16px; }
.boutique-featured-desc { font-size: 15px; color: var(--muted); line-height: 1.75; margin-bottom: 0; }
.boutique-featured-footer { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-top: 28px; }

/* Modules list */
.product-modules {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 6px 24px; margin: 20px 0 24px;
}
.product-module-item {
  font-family: 'DM Mono', monospace; font-size: 11px;
  color: var(--muted); display: flex; align-items: flex-start;
  gap: 7px; line-height: 1.5;
}
.product-module-item::before { content: '→'; color: var(--accent); flex-shrink: 0; }

/* Pour toi si */
.pour-toi-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  margin-top: 40px;
}
.pour-toi-card {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px 24px;
}
.pour-toi-card-check {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(157,255,9,.12); border: 1px solid rgba(157,255,9,.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--accent); margin-bottom: 16px;
}
.pour-toi-card p { font-size: 14px; color: var(--muted); line-height: 1.7; }

/* Produits secondaires */
.boutique-secondary-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

/* CTA simulateur */
.boutique-cta-inner {
  display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center;
  padding: 48px;
  background: var(--panel); border: 1px solid rgba(157,255,9,.2); border-radius: var(--radius);
}

.product-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; display: flex; flex-direction: column;
  transition: border-color var(--ease), transform var(--ease);
}
.product-card:hover { border-color: rgba(157,255,9,.3); transform: translateY(-4px); }

.product-card-visual {
  width: 100%; aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--panel-2), rgba(157,255,9,.06));
  display: flex; align-items: center; justify-content: center;
  border-bottom: 1px solid var(--line);
}
.product-card-icon {
  font-size: 56px; font-weight: 800; font-family: 'Montserrat', sans-serif;
  color: rgba(157,255,9,.25); line-height: 1;
}

.product-card-body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.product-card-cat {
  font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent-2); margin-bottom: 10px;
}
.product-card-title { font-size: 20px; font-weight: 700; line-height: 1.25; margin-bottom: 12px; }
.product-card-desc { font-size: 14px; color: var(--muted); line-height: 1.7; flex: 1; }
.product-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 20px; gap: 10px;
}
.product-price  { font-size: 28px; font-weight: 800; color: var(--accent); font-family: 'Montserrat', sans-serif; }
.product-old-price { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--muted); text-decoration: line-through; }

/* ============================================================
   PORTFOLIO PAGE
   ============================================================ */

.portfolio-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

.project-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden;
  transition: border-color var(--ease), transform var(--ease);
}
.project-card:hover { border-color: rgba(157,255,9,.3); transform: translateY(-4px); }
.project-card-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; object-position: center; background: var(--panel-2); display: block; }
.project-card-body { padding: 22px 24px 24px; }
.project-card-type {
  font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 8px;
}
.project-card-title { font-size: 20px; font-weight: 700; margin-bottom: 10px; }
.project-card-desc { font-size: 14px; color: var(--muted); line-height: 1.7; }
.project-card-result {
  margin-top: 14px; padding: 10px 14px;
  background: rgba(157,255,9,.07); border: 1px solid rgba(157,255,9,.2); border-radius: var(--radius-sm);
  font-family: 'DM Mono', monospace; font-size: 11px; color: var(--accent); letter-spacing: .04em;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }

.contact-info h2 { font-size: clamp(26px, 3vw, 38px); margin-bottom: 18px; }
.contact-info p  { font-size: 16px; color: var(--muted); line-height: 1.8; margin-bottom: 32px; }

.contact-socials { display: flex; flex-direction: column; gap: 12px; }
.contact-social-link {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 20px;
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-sm);
  transition: border-color var(--ease);
}
.contact-social-link:hover { border-color: rgba(157,255,9,.4); }
.csl-icon { flex-shrink: 0; }
.csl-text { font-size: 14px; color: var(--muted); }

/* Contact form */
.contact-form { display: flex; flex-direction: column; gap: 18px; }
.form-group { display: flex; flex-direction: column; gap: 7px; }
.form-label {
  font-family: 'DM Mono', monospace; font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase; color: var(--muted);
}
.form-input,
.form-textarea,
.form-select {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px 18px; color: var(--ink);
  font-family: 'Montserrat', sans-serif; font-size: 16px; /* 16px min pour éviter l'auto-zoom iOS Safari */
  transition: border-color var(--ease); width: 100%;
}
.form-input:focus,
.form-textarea:focus { outline: none; border-color: rgba(157,255,9,.5); }
.form-input::placeholder,
.form-textarea::placeholder { color: rgba(241,244,236,.3); }
.form-textarea { min-height: 150px; resize: vertical; }
.form-submit { align-self: flex-start; margin-top: 4px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* — Tablette / petits laptops — */
@media (max-width: 1024px) {
  :root { --nav-h: 64px; }
  .container { padding: 0 20px; }
  .section    { padding: 64px 0; }

  /* sec-head : évite le débordement avec les boutons intégrés */
  .sec-head { flex-wrap: wrap; gap: 10px; }

  /* Navigation mobile */
  .nav-toggle { display: flex; }
  .nav-menu {
    display: none;
    position: fixed;
    top: var(--nav-h);
    left: 0; right: 0;
    background: rgba(14,27,23,.98);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    flex-direction: column; align-items: stretch;
    padding: 16px 20px 28px; gap: 4px;
    border-bottom: 1px solid var(--line);
    max-height: calc(100vh - var(--nav-h));
    overflow-y: auto;
    z-index: 99;
  }
  .nav-menu.open { display: flex; }
  .nav-menu li   { border-bottom: 1px solid var(--line); }
  .nav-menu li:last-child { border-bottom: none; }
  .nav-menu a    { padding: 14px 16px; border-radius: 0; font-size: 15px; display: block; }
  .nav-menu a:hover,
  .nav-menu a.active { background: rgba(255,255,255,.05); color: var(--ink); border-radius: 0; }
  .nav-cta { margin-left: 0 !important; margin-top: 8px; text-align: center;
             background: var(--accent) !important; color: #0e1b17 !important;
             border-radius: var(--radius-sm) !important; }
  .nav-lang-item { margin-left: 0; }
  .nav-lang-switch {
    margin: 10px 16px 2px;
    padding: 4px;
    justify-content: center;
    border-radius: var(--radius-sm);
  }
  .lang-btn {
    font-size: 12px;
    min-width: 72px;
    padding: 10px 12px;
  }

  /* Hamburger → X quand ouvert */
  .nav-toggle span { transition: transform .25s ease, opacity .25s ease; }
  .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
  .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* Grilles */
  .home-hero-inner        { grid-template-columns: 1fr; gap: 40px; }
  .home-hero-photo img    { aspect-ratio: 16/9; max-height: 400px; object-position: top; }
  .home-about-inner       { grid-template-columns: 1fr; gap: 40px; }
  .home-about-stats       { grid-template-columns: repeat(2, 1fr); }
  /* Mockup AGNA : compenser les badges qui débordent */
  .ha-mockup { margin: 0 20px; }
  .ha-ig-card { right: -10px; bottom: 50px; }
  .ha-project-tag { left: -10px; }
  .ha-img { aspect-ratio: 4/3; }
  .ha-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .home-about-img         { aspect-ratio: 16 / 10; object-position: center; }
  .featured-product       { grid-template-columns: 1fr; }
  .featured-product-visual{ display: none; }
  .blog-grid,
  .blog-listing-grid      { grid-template-columns: repeat(2, 1fr); }
  .boutique-featured        { grid-template-columns: 1fr; }
  .boutique-featured-visual { min-height: 260px; border-right: none; border-bottom: 1px solid var(--line); }
  .boutique-featured-body   { padding: 36px 32px; justify-content: flex-start; }
  .product-modules          { grid-template-columns: 1fr; }
  .pour-toi-grid            { grid-template-columns: 1fr 1fr; }
  .boutique-secondary-grid  { grid-template-columns: 1fr 1fr; }
  .portfolio-grid           { grid-template-columns: repeat(2, 1fr); }
  .contact-grid           { grid-template-columns: 1fr; gap: 40px; }
  .about-grid             { grid-template-columns: 1fr; }
  .about-photo            { aspect-ratio: 16/9; }
  .article-layout         { grid-template-columns: 1fr; }
  .article-sidebar        { position: static; }
  .sidebar-cta            { display: none; }
  .sidebar-filters        { display: none; }
  .article-end-cta        { flex-direction: column; padding: 28px 24px; align-items: flex-start; }
  .article-end-cta .btn   { width: 100%; justify-content: center; }
}

/* — Mobile — */
@media (max-width: 600px) {
  .section    { padding: 52px 0; }
  .container  { padding: 0 16px; }
  .blog-grid,
  .blog-listing-grid  { grid-template-columns: 1fr; }
  .boutique-featured-visual {
    display: flex;
    min-height: 220px;
    border-right: none;
    border-bottom: 1px solid var(--line);
  }
  .boutique-featured-visual img { object-fit: contain; object-position: center; padding: 14px; }
  .boutique-featured-body   { padding: 28px 20px; }
  .boutique-secondary-grid  { grid-template-columns: 1fr; }
  .boutique-cta-inner       { grid-template-columns: 1fr; padding: 32px 24px; }
  .pour-toi-grid      { grid-template-columns: 1fr; }
  .portfolio-grid     { grid-template-columns: 1fr; }
  .timeline-item      { grid-template-columns: 1fr; gap: 6px; }
  .clients-track { gap: 8px; animation-duration: 20s; }
  .client-logo        { min-width: 90px; padding: 10px 14px; }
  .featured-product-content { padding: 32px 24px; }
  .sec-head           { flex-wrap: wrap; gap: 10px; }
  .sec-line           { display: none; }
  .page-hero          { padding: 44px 0 36px; margin-bottom: 44px; }
  .page-hero p        { font-size: 16px; }
  .article-intro      { font-size: 16px; line-height: 1.7; }
  .ha-ig-card,
  .ha-project-tag     { display: none; }
  .ha-mockup          { margin: 0; }
  .footer-top         { flex-direction: column; align-items: flex-start; gap: 20px; }
  .footer-bottom      { flex-direction: column; align-items: flex-start; gap: 8px; }

  /* Home hero: reduce typography pressure on small screens */
  .home-hero { padding: 56px 0 50px; }
  .home-hero-inner { gap: 26px; }
  .home-hero-text h1 { font-size: clamp(32px, 10vw, 44px); line-height: 1.05; }
  .home-hero-text p { font-size: 16px; line-height: 1.7; margin-bottom: 24px; }
  .home-hero-photo img { aspect-ratio: 4/3; max-height: 320px; }

  /* Boutons héro empilés */
  .home-hero-btns     { flex-direction: column; align-items: stretch; }
  .home-hero-btns .btn { width: 100%; justify-content: center; }

  /* Home about: stack stats cards for better readability */
  .home-about-inner { gap: 22px; }
  .home-about-text h2 { font-size: clamp(24px, 7vw, 32px); }
  .home-about-text p { font-size: 15px; line-height: 1.75; }
  .home-about-stats { grid-template-columns: 1fr; gap: 10px; }
  .home-about-visual { padding: 14px; }
  .home-about-img { aspect-ratio: 4 / 3; }
  .stat-card { padding: 18px 16px; }
  .stat-n { font-size: 34px; }
  .stat-l { font-size: 10px; letter-spacing: .04em; }

  /* Contact: icon + text alignment */
  .contact-social-link { align-items: center; }
  .csl-text { font-size: 13px; line-height: 1.55; }
  .contact-availability { margin-top: 24px !important; padding: 18px 16px !important; }

  /* About page: chips and CTA row breathing room */
  .about-chips { gap: 6px; }
  .about-chips .chip { font-size: 10px; padding: 5px 10px; }
  .about-cta-row { flex-direction: column; align-items: stretch; }
  .about-cta-row .btn { width: 100%; justify-content: center; }

  /* Card paddings tuned for narrow screens */
  .blog-card-body,
  .project-card-body,
  .product-card-body { padding: 18px 16px; }

  /* Prix / footer produit */
  .featured-product-footer  { flex-direction: column; align-items: flex-start; gap: 12px; }
  .boutique-featured-footer { flex-direction: column; align-items: flex-start; gap: 12px; }

  /* Bouton CTA simulateur (white-space:nowrap peut déborder) */
  .boutique-cta-inner .btn { white-space: normal; text-align: center; width: 100%; justify-content: center; }

  /* Lien voir publication sur les cartes portfolio */
  .project-card-result { font-size: 10px; }

  /* A-propos : boutons CTA */
  .about-bio .btn { width: 100%; justify-content: center; }
}

/* — Très petits écrans (≤ 420 px) — */
@media (max-width: 420px) {
  .container  { padding: 0 14px; }
  .brand-role { display: none; }
  .brand-name { font-size: 13px; }
  .home-about-stats { grid-template-columns: 1fr; }
  .stat-n     { font-size: 34px; }
  .nav-inner  { gap: 12px; }

  /* Small phones: avoid compressed link rows */
  .contact-social-link { padding: 13px 12px; }
  .contact-socials { gap: 8px; }
  .project-card-result { font-size: 9px; }

  /* Grids qui peuvent déborder sur très petits écrans */
  .home-hero-inner    { grid-template-columns: 1fr !important; }
  .boutique-cta-inner { grid-template-columns: 1fr !important; }
  .featured-product   { grid-template-columns: 1fr !important; }
}

/* ============================================================
   HERO — réécriture complète
   ============================================================ */
.home-hero {
  padding: 80px 0 72px;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}

/* Grain texture */
.hero-grain {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
  opacity: .6;
}

.home-hero > .container { position: relative; z-index: 1; }

.home-hero-inner {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 56px;
  align-items: center;
}

/* Disponibilité */
.hero-available {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--muted);
  background: rgba(157,255,9,.06);
  border: 1px solid rgba(157,255,9,.2);
  border-radius: 999px;
  padding: 7px 14px;
  margin-bottom: 24px;
}
.hero-available-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(157,255,9,.5);
  animation: pulse-dot 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes pulse-dot {
  0%   { box-shadow: 0 0 0 0 rgba(157,255,9,.5); }
  60%  { box-shadow: 0 0 0 7px rgba(157,255,9,0); }
  100% { box-shadow: 0 0 0 0 rgba(157,255,9,0); }
}

/* Titre + typewriter */
.hero-h1 {
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: 1.05;
  max-width: 18ch;
  margin-bottom: 22px;
  letter-spacing: -.025em;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hero-typewriter {
  color: var(--accent);
  display: block;
  min-height: 1.1em;
  border-right: 3px solid var(--accent);
  animation: blink-cursor .8s step-end infinite;
  padding-right: 4px;
  line-height: 1.0;
}
@keyframes blink-cursor {
  50% { border-color: transparent; }
}

/* Description */
.hero-desc {
  font-size: 17px;
  color: var(--muted);
  line-height: 1.8;
  max-width: 50ch;
  margin-bottom: 32px;
}

/* Boutons */
.home-hero-btns { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 40px; }

.btn-ghost-line {
  background: transparent;
  border: none;
  color: var(--muted);
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  letter-spacing: .06em;
  padding: 14px 4px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  transition: color .2s;
}
.btn-ghost-line:hover { color: var(--accent); transform: none; }

/* Métriques */
.hero-metrics {
  display: flex;
  align-items: center;
  gap: 0;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.hero-metric {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0 28px 0 0;
}
.hero-metric:first-child { padding-left: 0; }
.hero-metric-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 36px;
  font-weight: 800;
  color: var(--ink);
  line-height: 1;
  letter-spacing: -.03em;
}
.hero-metric-unit {
  font-family: 'DM Mono', monospace;
  font-size: 16px;
  color: var(--accent);
  font-weight: 700;
}
.hero-metric-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--muted);
}
.hero-metric-sep {
  width: 1px;
  height: 36px;
  background: var(--line);
  margin: 0 28px 0 0;
  flex-shrink: 0;
}

/* Photo wrap */
.hero-photo-wrap {
  position: relative;
  transition: transform .1s ease-out;
  will-change: transform;
}
.home-hero-photo img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  object-position: center top;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: var(--panel);
  display: block;
}

/* Cartes flottantes */
.hero-float-card {
  position: absolute;
  background: rgba(14,27,23,.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 9px 14px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  animation: float-bounce 3s ease-in-out infinite;
  user-select: none;
}
.hero-float-platforms {
  bottom: 18px;
  left: -20px;
  animation-delay: 0s;
}
.hero-float-remote {
  top: 24px;
  right: -16px;
  animation-delay: 1.5s;
  color: var(--accent);
  border-color: rgba(157,255,9,.25);
}
@keyframes float-bounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}
.hero-float-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.hero-float-dot.meta    { background: #1877f2; }
.hero-float-dot.ig      { background: #e1306c; }
.hero-float-dot.li      { background: #0a66c2; }
.hero-float-dot.tiktok  { background: #fff; }

/* Scroll fade-up */
.fade-up {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .55s ease, transform .55s ease;
}
.fade-up.in-view {
  opacity: 1;
  transform: translateY(0);
}

/* ── Responsive hero ── */
@media (max-width: 1024px) {
  .home-hero-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .home-hero-photo img {
    aspect-ratio: 3/2;
    max-height: 380px;
    object-position: top;
  }
  .hero-float-platforms { left: 10px; }
  .hero-float-remote { right: 10px; }
}
@media (max-width: 600px) {
  .home-hero { padding: 52px 0 48px; }
  .hero-h1 { font-size: clamp(34px, 9vw, 48px); }
  .hero-desc { font-size: 15px; }
  .home-hero-btns { flex-direction: column; align-items: stretch; }
  .home-hero-btns .btn { width: 100%; justify-content: center; }
  .hero-metrics { gap: 0; overflow-x: auto; padding-bottom: 4px; scrollbar-width: none; }
  .hero-metrics::-webkit-scrollbar { display: none; }
  .hero-metric { padding: 0 18px 0 0; }
  .hero-metric-sep { margin-right: 18px; }
  .hero-metric-num { font-size: 28px; }
  .home-hero-photo img { aspect-ratio: 4/3; border-radius: 16px; }
  .hero-float-platforms, .hero-float-remote { display: none; }
}

/* ============================================================
   ARTICLE COVER IMAGE
   ============================================================ */
.article-cover-wrap {
  margin-bottom: 60px;
}
.article-cover-img {
  width: 100%;
  aspect-ratio: 21/9;
  object-fit: cover;
  object-position: center;
  border-radius: 20px;
  border: 1px solid var(--line);
  display: block;
  background: var(--panel);
}
@media (max-width: 1024px) {
  .article-cover-img { aspect-ratio: 16/9; border-radius: 14px; }
  .article-cover-wrap { margin-bottom: 44px; }
}
@media (max-width: 600px) {
  .article-cover-img { aspect-ratio: 4/3; border-radius: 10px; }
  .article-cover-wrap { margin-bottom: 32px; }
}

/* ============================================================
   BLOG CARD — amélioration éditoriale
   Image en position relative pour le chip catégorie overlay
   ============================================================ */
.blog-card-img-wrap {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.blog-card-img-wrap .blog-card-img {
  transition: transform .35s ease;
}
.blog-card:hover .blog-card-img {
  transform: scale(1.04);
}
.blog-card-img-cat {
  position: absolute;
  bottom: 10px;
  left: 12px;
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(14,27,23,.82);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(157,255,9,.35);
  color: var(--accent);
}
.blog-card-read-time {
  position: absolute;
  bottom: 10px;
  right: 12px;
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: .06em;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(14,27,23,.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: rgba(241,244,236,.7);
}

/* ============================================================
   STAT CARDS — plus impactant
   ============================================================ */
.stat-card {
  position: relative;
  overflow: hidden;
}
.stat-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
  opacity: 0;
  transition: opacity .25s;
}
.stat-card:hover::after { opacity: 1; }
.stat-card:hover { border-color: rgba(157,255,9,.3); }

/* ============================================================
   ARTICLE HEAD — plus d'espace, lecture plus éditoriale
   ============================================================ */
.article-head {
  padding: 56px 0 52px;
}
.article-title {
  letter-spacing: -.02em;
}
.article-intro {
  font-size: 19px;
}

/* ============================================================
   SECTION heading — sec-label cohérence
   ============================================================ */
.sec-label {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
}

/* ============================================================
   Reading progress bar
   ============================================================ */
#reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0;
  height: 3px;
  background: var(--accent);
  z-index: 9999;
  transition: width .1s linear;
  border-radius: 0 2px 2px 0;
}

/* ============================================================
   Article share row
   ============================================================ */
.art-share-row {
  display: none;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 48px;
  padding: 16px 18px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.art-share-label {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted);
  flex-shrink: 0;
}
.art-share-btns {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.art-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border-radius: 7px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .04em;
  text-decoration: none;
  transition: opacity .18s, transform .18s;
}
.art-share-btn svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
}
.art-share-text { display: inline; }
.art-share-btn:hover { opacity: .85; transform: translateY(-1px); }
.art-share-btn--linkedin  { background: #0a66c2; color: #fff; }
.art-share-btn--facebook  { background: #1877f2; color: #fff; }
.art-share-btn--whatsapp  { background: #25d366; color: #fff; }
.art-share-btn--instagram {
  color: #fff;
  background: linear-gradient(135deg, #f58529 0%, #dd2a7b 50%, #8134af 100%);
}
.art-share-btn--copy {
  background: transparent;
  color: var(--fg);
  border: 1px solid var(--line);
  cursor: pointer;
}
.art-share-feedback {
  display: none;
  align-items: center;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--muted);
}

/* ============================================================
   Contact page — SVG platform icons
   ============================================================ */
.csl-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  flex-shrink: 0;
  transition: transform .18s;
}
.csl-icon svg {
  width: 24px;
  height: 24px;
}
.contact-social-link:hover .csl-icon { transform: scale(1.1); }
.csl-icon--whatsapp { background: #25d366; color: #fff; }
.csl-icon--email    { background: var(--accent); color: var(--bg); }
.csl-icon--linkedin { background: #0a66c2; color: #fff; }

/* ============================================================
   Back-to-top button
   ============================================================ */
#back-to-top {
  position: fixed;
  bottom: 32px;
  right: 28px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--bg);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .25s, transform .25s;
  z-index: 900;
  box-shadow: 0 4px 16px rgba(0,0,0,.35);
}
#back-to-top.visible {
  opacity: 1;
  transform: translateY(0);
}
#back-to-top:hover { filter: brightness(1.1); }

@media (max-width: 480px) {
  .art-share-row { padding: 18px 16px; gap: 12px; }
  #back-to-top { bottom: 20px; right: 16px; }
}

/* ── RESPONSIVE — responsive complet toutes sections ── */
@media (max-width: 600px) {
  /* SM banner cards */
  .sm-card-value { font-size: 38px; letter-spacing: -1px; }
  /* Page hero chips */
  .page-hero-platforms { gap: 6px; }
  .php-chip { font-size: 10px; padding: 4px 10px; }
  /* Method steps */
  .method-step { padding: 20px 16px; }
  /* Art share row */
  .art-share-row { flex-direction: column; align-items: flex-start; gap: 10px; }
  .art-share-btns { width: 100%; display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
  .art-share-btn  {
    width: 100%;
    min-height: 36px;
    padding: 8px;
    justify-content: center;
    border-radius: 9px;
  }
  .art-share-btn svg { width: 15px; height: 15px; }
  .art-share-text { display: none; }
}
@media (max-width: 420px) {
  .art-share-btns { grid-template-columns: repeat(5, 1fr); }
}

/* ============================================================
   ARTICLE HERO IMAGE — image mise en avant dans l'article
   ============================================================ */
.article-featured {
  margin: 8px 0 30px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--panel);
}
.article-featured-caption {
  margin: 0;
  padding: 10px 14px 12px;
  border-top: 1px solid var(--line);
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--muted);
}
.article-hero-img {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  display: block;
  margin-bottom: 0;
}
@media (max-width: 1024px) {
  .article-featured { margin-bottom: 24px; }
  .article-hero-img { max-height: 360px; }
}
@media (max-width: 600px)  {
  .article-featured { border-radius: 14px; margin-bottom: 20px; }
  .article-hero-img { max-height: 240px; }
}

/* ============================================================
   BLOG FILTER BAR — style dropdowns premium
   ============================================================ */
.blog-filter-bar {
  position: sticky;
  top: var(--nav-h);
  z-index: 80;
  background: rgba(14,27,23,.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(241,244,236,.1);
  padding: 0;
}
.blog-filter-inner {
  display: flex;
  align-items: center;
  gap: 0;
  height: 56px;
  overflow-x: auto;
  scrollbar-width: none;
}
.blog-filter-inner::-webkit-scrollbar { display: none; }

/* Search */
.bfb-search {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 160px;
  max-width: 240px;
  padding: 0 16px;
  height: 100%;
  color: var(--muted);
}
.bfb-search svg { flex-shrink: 0; }
.bfb-search input {
  background: none;
  border: none;
  outline: none;
  color: var(--ink);
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  letter-spacing: .04em;
  width: 100%;
}
.bfb-search input::placeholder { color: rgba(241,244,236,.35); }

.bfb-clear-search {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  display: flex;
  align-items: center;
  padding: 2px;
  transition: color .15s;
  flex-shrink: 0;
}
.bfb-clear-search:hover { color: var(--accent); }

/* Separators */
.bfb-sep {
  width: 1px;
  height: 24px;
  background: rgba(241,244,236,.1);
  flex-shrink: 0;
}

/* Dropdown wraps */
.bfb-select-wrap {
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.bfb-select-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  height: 100%;
  padding: 0 18px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .05em;
  white-space: nowrap;
  transition: color .15s, background .15s;
}
.bfb-select-btn:hover { color: var(--ink); background: rgba(255,255,255,.04); }
.bfb-select-btn[aria-expanded="true"] { color: var(--accent); background: rgba(157,255,9,.05); }
.bfb-select-btn[aria-expanded="true"] .bfb-chevron { transform: rotate(180deg); }

.bfb-chevron { transition: transform .2s; flex-shrink: 0; }

/* Dropdown list */
.bfb-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  min-width: 200px;
  background: #162920;
  border: 1px solid rgba(241,244,236,.12);
  border-radius: 12px;
  padding: 6px;
  box-shadow: 0 16px 48px rgba(0,0,0,.5);
  z-index: 999;
  animation: bfb-fade-in .15s ease;
}
.bfb-dropdown.open { display: block; }

@keyframes bfb-fade-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bfb-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 8px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--muted);
  cursor: pointer;
  transition: color .12s, background .12s;
  white-space: nowrap;
}
.bfb-option:hover { color: var(--ink); background: rgba(255,255,255,.06); }
.bfb-option.is-selected { color: var(--accent); }
.bfb-option.is-selected::before {
  content: '';
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}

/* Reset button */
.bfb-reset {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255,100,100,.1);
  border: 1px solid rgba(255,100,100,.2);
  color: rgba(255,140,140,.8);
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .05em;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, border-color .15s;
  flex-shrink: 0;
}
.bfb-reset:hover { background: rgba(255,100,100,.18); border-color: rgba(255,100,100,.35); }

/* Article count badge */
.bfb-count {
  margin-left: auto;
  padding: 0 16px 0 8px;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .06em;
  color: rgba(241,244,236,.3);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Responsive */
@media (max-width: 768px) {
  .bfb-search { max-width: 160px; min-width: 120px; padding: 0 12px; }
  .bfb-select-btn { padding: 0 12px; font-size: 11px; }
  .bfb-count { display: none; }
}
@media (max-width: 480px) {
  .bfb-search { min-width: 90px; }
  .blog-filter-inner { height: 50px; }
}

/* ============================================================
   SM METRICS BANNER
   ============================================================ */
.sm-banner {
  padding: 72px 0;
  background: var(--bg);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.sm-banner-label {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 32px;
}
.sm-metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.sm-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 24px 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: transform .22s, border-color .22s, box-shadow .22s;
  position: relative;
  overflow: hidden;
}
.sm-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: 16px 16px 0 0;
}
.sm-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
}
.sm-card--ig::before  { background: linear-gradient(90deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.sm-card--li::before  { background: #0a66c2; }
.sm-card--orange::before { background: linear-gradient(90deg, #ff6600, #ff9900); }
.sm-card--accent::before { background: var(--accent); }
.sm-card:hover.sm-card--ig  { border-color: rgba(220,39,67,.35); }
.sm-card:hover.sm-card--li  { border-color: rgba(10,102,194,.35); }
.sm-card:hover.sm-card--orange { border-color: rgba(255,102,0,.35); }
.sm-card:hover.sm-card--accent { border-color: rgba(157,255,9,.4); }

.sm-card-platform {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
}
.sm-card--ig .sm-card-platform  { color: #e1306c; }
.sm-card--li .sm-card-platform  { color: #0a66c2; }
.sm-card--orange .sm-card-platform { color: #ff7700; }
.sm-card--accent .sm-card-platform { color: var(--accent); }

.sm-card-value {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -2px;
  line-height: 1;
}
.sm-card-unit {
  font-size: .5em;
  font-weight: 700;
  letter-spacing: 0;
  color: var(--muted);
}
.sm-card-label {
  font-size: 13px;
  color: var(--ink);
  font-weight: 600;
  margin-top: 4px;
}
.sm-card-trend {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--muted);
  margin-top: 8px;
  line-height: 1.5;
}
.sm-card-trend--up { color: #4caf50; }

@media (max-width: 900px) {
  .sm-metrics-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .sm-metrics-grid { grid-template-columns: 1fr; }
  .sm-banner { padding: 48px 0; }
}

/* ============================================================
   OPERATOR — Méthode en 3 étapes
   ============================================================ */
.operator-method {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.method-step {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 32px 28px;
  position: relative;
  transition: border-color .22s, transform .22s;
}
.method-step:hover {
  border-color: rgba(157,255,9,.35);
  transform: translateY(-3px);
}
.method-step-num {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--accent);
  display: block;
  margin-bottom: 16px;
}
.method-step h4 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 12px;
  line-height: 1.2;
}
.method-step p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.75;
  margin: 0;
}

@media (max-width: 860px) {
  .operator-method { grid-template-columns: 1fr; gap: 16px; }
  .method-step { padding: 24px 20px; }
}

/* ============================================================
   PLATFORM EXPERTISE CARDS (a-propos)
   ============================================================ */
.platform-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.platform-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform .2s, border-color .2s;
}
.platform-card:hover {
  transform: translateY(-3px);
}
.platform-card-icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
}
.platform-card-icon--ig     { background: linear-gradient(135deg,#f09433,#e6683c,#dc2743,#bc1888); color: #fff; }
.platform-card-icon--li     { background: #0a66c2; color: #fff; }
.platform-card-icon--google { background: #fff; color: #4285f4; border: 1px solid var(--line); }
.platform-card-icon--tiktok { background: #010101; color: #fff; border: 1px solid var(--line); }

.platform-card:hover.platform-card { border-color: rgba(157,255,9,.25); }

.platform-card h4 {
  font-size: 16px;
  font-weight: 700;
  margin: 0;
}
.platform-card p {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.7;
  margin: 0;
}
.platform-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}
.platform-card-tags span {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .04em;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(157,255,9,.08);
  border: 1px solid rgba(157,255,9,.18);
  color: var(--accent);
}
@media (max-width: 900px) { .platform-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .platform-grid { grid-template-columns: 1fr; } }

/* ============================================================
   PAGE HERO — platform chips (blog, portfolio, contact)
   ============================================================ */
.page-hero-platforms {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}
.php-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: .04em;
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  white-space: nowrap;
}
.php-chip svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}
.php-chip--ig       { border-color: rgba(225,48,108,.4); color: #e1306c; background: rgba(225,48,108,.06); }
.php-chip--li       { border-color: rgba(10,102,194,.4); color: #4d9de0; background: rgba(10,102,194,.06); }
.php-chip--meta     { border-color: rgba(24,119,242,.4); color: #4d9de0; background: rgba(24,119,242,.06); }
.php-chip--google   { border-color: rgba(66,133,244,.4); color: #7eaff5; background: rgba(66,133,244,.06); }
.php-chip--orange   { border-color: rgba(255,102,0,.4);  color: #ff7700; background: rgba(255,102,0,.06); }
.php-chip--whatsapp { border-color: rgba(37,211,102,.4); color: #25d366; background: rgba(37,211,102,.06); }

/* ============================================================
   HERO SLIDER — 4 slides, auto-advance 6s, transitions fade+slide
   Structure : .hs > .hs-slide × 4 + .hs-nav-bar
   ============================================================ */

/* Container — CSS grid stacking pour que les slides aient une hauteur définie */
.hs {
  display: grid;
  grid-template-rows: 1fr;
  position: relative;
  min-height: calc(100vh - var(--nav-h));   /* fallback anciens navigateurs */
  min-height: calc(100svh - var(--nav-h));  /* modern: small viewport height */
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  touch-action: pan-y;
}

/* Progress line */
.hs-progress-line {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: rgba(255,255,255,.06);
  z-index: 20;
}
.hs-progress-fill {
  height: 100%;
  background: var(--accent);
  width: 0%;
}

/* Individual slide — grid stacking : toutes les slides occupent la même cellule */
.hs-slide {
  grid-area: 1 / 1;
  position: relative;       /* active z-index dans le contexte grid */
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: calc(var(--nav-h) + 48px) 0 104px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1);
  will-change: opacity, transform;
  min-height: calc(100vh - var(--nav-h));
  min-height: calc(100svh - var(--nav-h));
}
.hs-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  z-index: 2;
}

/* Grain overlay */
.hs-grain {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
  opacity: .55;
}

/* Background glows */
.hs-bg-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(130px);
  pointer-events: none;
  opacity: .12;
  z-index: 0;
}
.hs-bg-glow--green  { width: 640px; height: 640px; background: var(--accent);   top: -220px; right: -160px; }
.hs-bg-glow--blue   { width: 520px; height: 520px; background: #4dabf7;          top: -80px;  right: -80px; }
.hs-bg-glow--purple { width: 520px; height: 520px; background: #cc5de8;          top: 0;      right: 0; }

/* Container content */
.hs .container { position: relative; z-index: 1; }

/* 2-column layout (text + visual) */
.hs-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  width: 100%;
}

/* Slide 2 & 3: enforce balanced two-column rhythm */
.hs-slide[data-idx="1"] .hs-inner,
.hs-slide[data-idx="2"] .hs-inner {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  align-items: stretch;
}
.hs-slide[data-idx="1"] .hs-text,
.hs-slide[data-idx="2"] .hs-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100%;
  max-width: 560px;
}
.hs-slide[data-idx="1"] .hs-visual,
.hs-slide[data-idx="2"] .hs-visual {
  align-items: stretch;
}

.hs-slide[data-idx="1"] .hs-p,
.hs-slide[data-idx="2"] .hs-p {
  max-width: 54ch;
}
.hs-slide[data-idx="2"] .hs-p { color: rgba(241,244,236,.88); }

.hs-slide[data-idx="1"] .hs-feats,
.hs-slide[data-idx="2"] .hs-feats {
  max-width: 52ch;
}
.hs-slide[data-idx="2"] .hs-feats li { color: rgba(241,244,236,.88); }
/* Full-width layout (slide 4 — services) */
.hs-inner--full {
  grid-template-columns: 1fr;
  gap: 32px;
  max-width: 1180px;
  margin: 0 auto;
}

/* ── Badge disponibilité (slide 1) ── */
.hs-avail {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(157,255,9,.06);
  border: 1px solid rgba(157,255,9,.2);
  border-radius: 99px;
  padding: 6px 14px;
  margin-bottom: 22px;
}
.hs-avail-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(157,255,9,.25);
  animation: hsPulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes hsPulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(157,255,9,.25); }
  50%       { box-shadow: 0 0 0 8px rgba(157,255,9,.06); }
}

/* Badge pill (slides 2, 3, 4) */
.hs-badge-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(157,255,9,.08);
  border: 1px solid rgba(157,255,9,.25);
  border-radius: 99px;
  padding: 5px 14px;
  margin-bottom: 20px;
}
.hs-badge-pill--limited { color: #ffa94d; background: rgba(255,169,77,.08); border-color: rgba(255,169,77,.3); }
.hs-badge-star { color: #ffd43b; }

/* ── Titles ── */
.hs-h1 {
  font-family: var(--font-display);
  font-size: clamp(44px, 5.5vw, 74px);
  font-weight: 800;
  line-height: 1.0;
  letter-spacing: -2px;
  margin-bottom: 20px;
  color: var(--white);
}
.hs-h2 {
  font-family: var(--font-display);
  font-size: clamp(36px, 4.5vw, 60px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -1.5px;
  margin-bottom: 18px;
  color: var(--white);
}
.hs-h2--full {
  font-family: var(--font-display);
  font-size: clamp(38px, 4.5vw, 62px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -2px;
  margin: 12px 0 16px;
  color: var(--white);
  text-align: center;
}
.hs-em { font-style: normal; color: var(--accent); }

/* ── Body text ── */
.hs-p {
  font-size: 16px;
  color: var(--muted);
  line-height: 1.75;
  margin-bottom: 24px;
  max-width: 480px;
}
.hs-p--center { text-align: center; max-width: 540px; margin: 0 auto 32px; }
.hs-text--center { text-align: center; }

/* ── Platform chips (slide 1) ── */
.hs-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }
.hs-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 99px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  transition: border-color .2s, color .2s;
}
.hs-chip:hover      { border-color: rgba(157,255,9,.35); color: var(--white); }
.hs-chip--ig        { border-color: rgba(225,48,108,.3); color: #f77782; }
.hs-chip--meta      { border-color: rgba(24,119,242,.3); color: #74b6f7; }
.hs-chip--li        { border-color: rgba(0,119,181,.3);  color: #74b6f7; }
.hs-chip--tiktok    { border-color: rgba(105,201,208,.3); color: #69c9d0; }
.hs-chip--google    { border-color: rgba(66,133,244,.3); color: #74b6f7; }

/* ── Metrics row (slide 1) ── */
.hs-metrics { display: flex; align-items: center; margin-bottom: 32px; }
.hs-metric  { padding: 0 24px 0 0; }
.hs-metric-num {
  display: block;
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 800;
  color: var(--white);
  line-height: 1;
  letter-spacing: -1px;
}
.hs-metric-unit { font-size: 17px; color: var(--accent); }
.hs-metric-lbl  {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 3px;
}
.hs-metric-sep  { width: 1px; height: 34px; background: var(--border); margin-right: 24px; flex-shrink: 0; }

/* ── Feature list (slides 2 & 3) ── */
.hs-feats { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.hs-feats li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: rgba(255,255,255,.8); line-height: 1.5; }
.hs-feat-check { color: var(--accent); font-weight: 700; flex-shrink: 0; margin-top: 1px; }

/* ── Price row (slide 2) ── */
.hs-price-row { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.hs-price-old { font-family: var(--font-mono); font-size: 14px; color: var(--muted); text-decoration: line-through; }
.hs-price     { font-family: var(--font-display); font-size: 32px; font-weight: 800; color: var(--accent); letter-spacing: -1px; line-height: 1; }
.hs-price-badge { font-family: var(--font-mono); font-size: 11px; color: var(--bg); background: var(--accent); padding: 3px 10px; border-radius: 99px; font-weight: 700; letter-spacing: .04em; }
.hs-micro { font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: .04em; }

/* ── CTA buttons ── */
.hs-btns { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }

/* Programme tools mini section (slide 2) */
.hs-program-tools {
  padding-top: 12px;
  border-top: 1px solid rgba(241,244,236,.1);
  margin-bottom: 12px;
}
.hs-program-tools .btn-sm {
  font-size: 11px;
  padding: 8px 12px;
  flex: 1;
  min-width: 140px;
}
@media (max-width: 560px) {
  .hs-program-tools .btn-sm {
    min-width: 100%;
  }
  .hs-program-tools > div {
    flex-direction: column !important;
    gap: 6px !important;
  }
}

/* ── VISUAL column ── */
.hs-visual { display: flex; justify-content: center; align-items: center; position: relative; }

/* iPhone 16 in-hand scene (slide 3) */
.hs-visual--iphone {
  min-height: 470px;
  align-items: flex-end;
}
.hs-corp-sleeve {
  position: absolute;
  left: 36px;
  bottom: 26px;
  width: 228px;
  height: 170px;
  border-radius: 26px;
  background: linear-gradient(140deg, #1a2432, #0f1724 58%, #1f2b3c 100%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 36px rgba(0,0,0,.45);
  transform: rotate(-11deg);
  z-index: 1;
}
.hs-corp-hand {
  position: absolute;
  left: 68px;
  bottom: 34px;
  width: 214px;
  height: 136px;
  border-radius: 38px 56px 40px 60px;
  background: linear-gradient(135deg, #f2ceb0, #ddb491 56%, #c99674 100%);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  transform: rotate(-10deg);
  z-index: 2;
}
.hs-corp-hand::before {
  content: '';
  position: absolute;
  right: -12px;
  top: 42px;
  width: 82px;
  height: 42px;
  border-radius: 26px;
  background: linear-gradient(135deg, #f2ceb0, #cf9e7f);
  transform: rotate(14deg);
}
.hs-iphone16 {
  position: relative;
  width: min(340px, 90vw);
  aspect-ratio: 9 / 19.5;
  border-radius: 42px;
  padding: 9px;
  background: linear-gradient(145deg, #dce6f5, #9eaec4 55%, #e7edf7);
  box-shadow: 0 26px 68px rgba(0,0,0,.5);
  border: 1px solid rgba(255,255,255,.42);
  transform: rotate(-8deg) translate(18px, -10px);
  z-index: 3;
}
.hs-iphone16-screen {
  width: 100%;
  height: 100%;
  border-radius: 34px;
  overflow: hidden;
  background: #0b141a;
  border: 1px solid rgba(255,255,255,.16);
  position: relative;
}
.hs-iphone16-island {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 112px;
  height: 30px;
  border-radius: 17px;
  background: #060a0d;
  z-index: 5;
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.07);
}
.hs-iphone16-side {
  position: absolute;
  right: -4px;
  width: 3px;
  border-radius: 99px;
  background: rgba(255,255,255,.62);
}
.hs-iphone16-side--up { top: 116px; height: 42px; }
.hs-iphone16-side--down { top: 170px; height: 56px; }

/* Photo frame (slide 1) */
.hs-photo-frame { position: relative; display: inline-block; }
.hs-photo {
  width: 100%;
  max-width: 440px;
  aspect-ratio: 1/1;
  object-fit: contain;
  object-position: center;
  border-radius: 24px;
  display: block;
  border: 1px solid rgba(255,255,255,.06);
  background: var(--bg2);
  filter: drop-shadow(0 24px 64px rgba(0,0,0,.55));
}

/* ── Floating cards (slide 1) ── */
.hs-fc {
  position: absolute;
  background: rgba(10,17,28,.88);
  backdrop-filter: blur(14px) saturate(1.5);
  -webkit-backdrop-filter: blur(14px) saturate(1.5);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  padding: 12px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  box-shadow: 0 8px 32px rgba(0,0,0,.45);
  animation: fc-float 4s ease-in-out infinite;
}
@keyframes fc-float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-7px); }
}
/* Instagram Insights */
.hs-fc--ig  { top: 8%; left: -56px; width: 162px; animation-delay: 0s; }
/* Meta Ads */
.hs-fc--ads { bottom: 14%; right: -48px; width: 158px; animation-delay: 1.6s; }
/* Remote tag */
.hs-fc--tag {
  bottom: 36%; left: -52px;
  display: flex; align-items: center; gap: 6px;
  color: var(--white); white-space: nowrap;
  animation-delay: 0.9s; font-size: 12px;
  padding: 8px 14px;
}
.hs-fc-top  { display: flex; align-items: center; gap: 6px; color: var(--muted); margin-bottom: 8px; }
.hs-fc-val  { font-family: var(--font-display); font-size: 20px; font-weight: 800; color: var(--white); line-height: 1; }
.hs-trend   { font-size: 11px; color: #4caf50; font-family: var(--font-mono); }
.hs-fc-lbl  { font-size: 10px; color: var(--muted); margin: 4px 0 8px; letter-spacing: .04em; }
.hs-bars    { display: flex; align-items: flex-end; gap: 3px; height: 32px; }
.hs-bars div          { flex: 1; background: linear-gradient(180deg, #e1306c, rgba(225,48,108,.3)); border-radius: 2px; min-height: 4px; }
.hs-fc-row3         { display: flex; gap: 8px; margin-top: 8px; }
.hs-fc-row3 > div   { flex: 1; text-align: center; }
.hs-mini-v          { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: var(--white); line-height: 1; }
.hs-mini-v--g       { color: var(--accent); }
.hs-mini-l          { font-size: 9px; color: var(--muted); letter-spacing: .05em; margin-top: 2px; }

/* ── Programme scene (slide 2) — kept for potential reuse ── */
.hs-visual--programme {
  min-height: 470px;
}

/* ── Packshot produit réel (slide 2) ── */
.hs-prod-frame {
  position: relative;
  width: min(460px, 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hs-prod-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 22px;
  display: block;
  object-fit: cover;
  object-position: center;
  box-shadow: 0 28px 70px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.08);
}
.hs-prod-access {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 16px;
  background: rgba(11,20,26,.85);
  border: 1px solid rgba(157,255,9,.28);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 99px;
  padding: 8px 18px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--accent);
  letter-spacing: .04em;
  white-space: nowrap;
}
.hs-program-scene {
  position: relative;
  width: min(500px, 100%);
  min-height: 430px;
  display: grid;
  place-items: center;
}
.hs-program-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(24px);
  pointer-events: none;
  opacity: .45;
}
.hs-program-orb--a {
  width: 180px;
  height: 180px;
  right: 4%;
  top: 8%;
  background: rgba(102,194,255,.55);
}
.hs-program-orb--b {
  width: 160px;
  height: 160px;
  left: 2%;
  bottom: 6%;
  background: rgba(157,255,9,.42);
}
.hs-program-device {
  width: min(440px, 92%);
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.2);
  background: linear-gradient(165deg, rgba(29,48,40,.95), rgba(20,36,30,.95));
  box-shadow: 0 24px 60px rgba(0,0,0,.5);
  transform: perspective(1100px) rotateY(-7deg) rotateX(2deg);
  overflow: hidden;
}
.hs-program-device-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.12);
  background: rgba(11,20,26,.75);
}
.hs-program-pill,
.hs-program-badge {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-radius: 99px;
  padding: 5px 10px;
}
.hs-program-pill {
  color: #8ad6ff;
  border: 1px solid rgba(138,214,255,.35);
  background: rgba(102,194,255,.12);
}
.hs-program-badge {
  color: #0e1b17;
  background: var(--accent);
  font-weight: 700;
}
.hs-program-image {
  width: 100%;
  aspect-ratio: 16/10;
  display: block;
  object-fit: contain;
  object-position: center;
  background: radial-gradient(circle at 80% 10%, rgba(102,194,255,.14), rgba(102,194,255,0) 50%), radial-gradient(circle at 12% 90%, rgba(157,255,9,.14), rgba(157,255,9,0) 50%), #10201b;
  padding: clamp(10px, 2vw, 14px);
}
.hs-program-fallback {
  width: 100%;
  aspect-ratio: 16/10;
  place-content: center;
  text-align: center;
  gap: 4px;
  background: #10201b;
}
.hs-program-fallback-big {
  font-family: var(--font-display);
  font-size: 58px;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}
.hs-program-fallback-small {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--muted);
}
.hs-program-glass {
  position: absolute;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(11,20,26,.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 10px 12px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.hs-program-glass--left {
  left: 0;
  top: 18%;
}
.hs-program-glass--right {
  right: 2%;
  bottom: 24%;
}
.hs-program-glass-k {
  display: block;
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1;
  color: var(--accent);
}
.hs-program-glass-v {
  display: block;
  margin-top: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(241,244,236,.75);
}
.hs-program-strip {
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.hs-program-strip span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(15,29,24,.78);
  color: rgba(241,244,236,.8);
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .05em;
  text-align: center;
  padding: 8px 10px;
}

/* ── WhatsApp mockup card (slide 3) ── */
.hs-coaching-card {
  background: #0b141a;
  border: none;
  border-radius: 0;
  overflow: hidden;
  width: 100%; max-width: none;
  box-shadow: none;
  min-height: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.hs-coaching-header {
  display: flex; align-items: center; gap: 12px;
  padding: 44px 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: #202c33;
}
.hs-coaching-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: #25d366; color: #0b141a;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 13px; font-weight: 800;
  flex-shrink: 0;
}
.hs-coaching-name   { font-size: 12px; font-weight: 700; line-height: 1.35; display: flex; align-items: center; gap: 7px; }
.hs-wa-logo {
  font-family: var(--font-mono);
  font-size: 9px;
  color: #25d366;
  border: 1px solid rgba(37,211,102,.35);
  border-radius: 999px;
  padding: 2px 6px;
  letter-spacing: .03em;
}
.hs-coaching-status { font-family: var(--font-mono); font-size: 9px; color: rgba(255,255,255,.55); display: flex; align-items: center; gap: 5px; }
.hs-dot-green       { width: 6px; height: 6px; border-radius: 50%; background: #4caf50; animation: hsPulse 2s infinite; flex-shrink: 0; }
.hs-coaching-dur {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 10px;
  color: rgba(255,255,255,.7);
}
.hs-coaching-body {
  padding: 14px;
  display: flex; flex-direction: column; gap: 8px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  flex: 1;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.03), transparent 36%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.02), transparent 44%),
    #0e1a21;
}
.hs-msg { max-width: 86%; padding: 8px 10px; border-radius: 9px; font-size: 11px; line-height: 1.5; box-shadow: 0 1px 1px rgba(0,0,0,.3); }
.hs-msg--left  { background: #202c33; color: #e9edef; border-radius: 0 8px 8px 8px; align-self: flex-start; }
.hs-msg--right { background: #005c4b; color: #e9edef; border-radius: 8px 0 8px 8px; align-self: flex-end; }
.hs-msg-meta {
  font-family: var(--font-mono);
  font-size: 9px;
  color: rgba(255,255,255,.5);
  margin-top: -4px;
}
.hs-msg-meta--left { align-self: flex-start; margin-left: 6px; }
.hs-msg-meta--right { align-self: flex-end; margin-right: 6px; }
.hs-coaching-steps {
  display: grid;
  grid-template-columns: 26px 1fr 26px;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  background: #202c33;
}
.hs-step-item {
  font-family: var(--font-mono); font-size: 10px;
  color: rgba(255,255,255,.55);
  background: #2a3942;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  padding: 7px 12px;
  text-align: left;
}
.hs-step-active { border-color: rgba(37,211,102,.25); color: rgba(255,255,255,.75); background: #2a3942; }
.hs-chat-plus,
.hs-chat-mic {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: #2a3942;
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.7);
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Support panel (slide 3 minimalist) ── */
.hs-visual--support {
  min-height: 430px;
}
.hs-support-panel {
  width: min(440px, 100%);
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.15);
  background: linear-gradient(165deg, rgba(21,35,30,.96), rgba(13,24,21,.96));
  box-shadow: 0 20px 54px rgba(0,0,0,.44);
  overflow: hidden;
}
.hs-support-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.12);
  background: rgba(11,20,26,.76);
}
.hs-support-pill,
.hs-support-time {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 5px 10px;
}
.hs-support-pill {
  color: #9dff09;
  border: 1px solid rgba(157,255,9,.3);
  background: rgba(157,255,9,.08);
}
.hs-support-time {
  color: #9dd5ff;
  border: 1px solid rgba(102,194,255,.3);
  background: rgba(102,194,255,.08);
}
.hs-support-chat {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  background: radial-gradient(circle at 10% 90%, rgba(157,255,9,.08), transparent 45%), radial-gradient(circle at 90% 10%, rgba(102,194,255,.08), transparent 40%), #0e1a17;
}
.hs-support-bubble {
  max-width: 88%;
  font-size: 13px;
  line-height: 1.55;
  border-radius: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.1);
}
.hs-support-bubble--left {
  align-self: flex-start;
  background: #1f322b;
  color: rgba(241,244,236,.92);
}
.hs-support-bubble--right {
  align-self: flex-end;
  background: #184235;
  color: #e9fbe4;
  border-color: rgba(157,255,9,.2);
}
.hs-support-foot {
  display: flex;
  gap: 8px;
  padding: 12px 14px 14px;
}
.hs-support-foot span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(241,244,236,.76);
}

/* ── Services grid (slide 4) ── */
.hs-services {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  width: 100%;
  align-items: stretch;
  max-width: 980px;
  margin: 0 auto;
}

/* Coaching value section (slide 3 premium pricing + impact) */
.hs-coaching-value {
  display: flex;
  gap: 20px;
  align-items: center;
  margin: 18px 0;
  padding: 16px;
  border-radius: 14px;
  border: 1px solid rgba(157,255,9,.2);
  background: linear-gradient(135deg, rgba(157,255,9,.08), transparent);
}
.hs-coaching-price {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hs-coaching-val {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  color: var(--accent);
}
.hs-coaching-cur {
  font-size: 12px;
  font-weight: 500;
  margin-left: 4px;
}
.hs-coaching-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(241,244,236,.68);
}
.hs-coaching-impact {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-left: 20px;
  border-left: 1px solid rgba(157,255,9,.25);
}
.hs-coaching-metric {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
  color: rgba(241,244,236,.94);
}
.hs-coaching-metric strong {
  color: var(--accent);
  font-size: 22px;
}

/* Slide 4 visual-first board */
.hs-services-visual {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
}
.hs-work-board {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(160deg, #0f1d1a, #1a2f29 58%, #10201b);
  min-height: 340px;
  box-shadow: 0 22px 58px rgba(0,0,0,.42);
}
.hs-work-board--minimal {
  min-height: 260px;
  padding: 20px;
  background: linear-gradient(160deg, #111f1b, #152925 55%, #0f1d19);
}
/* Impact metrics row (slide 4 top KPIs) */
.hs-work-impact-row {
  display: flex;
  gap: 24px;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(157,255,9,.15);
}
.hs-work-impact-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.hs-work-impact-num {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  color: var(--accent);
}
.hs-work-impact-unit {
  font-size: 11px;
  font-weight: 500;
  margin-left: 3px;
}
.hs-work-impact-lbl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(241,244,236,.68);
}
.hs-work-impact-sep {
  width: 1px;
  height: 44px;
  background: rgba(157,255,9,.15);
}
.hs-work-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.hs-work-mini-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  padding: 12px;
  color: rgba(241,244,236,.86);
}
.hs-work-mini-card span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.hs-work-main-img {
  width: 100%;
  height: 340px;
  object-fit: cover;
  object-position: center top;
  opacity: .88;
  filter: saturate(1.05) contrast(1.02);
}
.hs-work-kpi {
  position: absolute;
  background: rgba(14,27,23,.86);
  border: 1px solid rgba(157,255,9,.28);
  border-radius: 14px;
  padding: 10px 14px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.hs-work-kpi strong {
  display: block;
  font-family: var(--font-display);
  font-size: 20px;
  line-height: 1;
  color: var(--accent);
}
.hs-work-kpi span {
  display: block;
  margin-top: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: rgba(241,244,236,.75);
  letter-spacing: .05em;
  text-transform: uppercase;
}
.hs-work-kpi--left { left: 16px; top: 16px; }
.hs-work-kpi--right { right: 16px; top: 16px; }
.hs-work-strip {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.hs-work-strip span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: rgba(241,244,236,.84);
  letter-spacing: .05em;
  text-transform: uppercase;
  text-align: center;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(11,20,26,.78);
}
.hs-work-strip span svg { flex-shrink: 0; }

@media (max-width: 420px) {
  .hs-work-kpi--right { display: none; }
  .hs-work-kpi--left { left: 12px; top: 12px; }
  .hs-work-strip span { font-size: 9px; padding: 7px 8px; }
}
.hs-svc-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color .22s, transform .22s;
  min-height: 228px;
}
.hs-svc-card:hover { border-color: rgba(157,255,9,.3); transform: translateY(-3px); }
.hs-svc-icon {
  width: 44px; height: 44px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 4px; flex-shrink: 0;
}
.hs-svc-icon--ig       { background: rgba(225,48,108,.12); color: #f77782; }
.hs-svc-icon--ads      { background: rgba(24,119,242,.12);  color: #74b6f7; }
.hs-svc-icon--strategy { background: rgba(157,255,9,.1);    color: var(--accent); }
.hs-svc-icon--report   { background: rgba(52,211,153,.12);  color: #34d399; }
.hs-svc-title { font-size: 15px; font-weight: 700; line-height: 1.3; }
.hs-svc-desc  { font-size: 12px; color: var(--muted); line-height: 1.6; flex: 1; }
.hs-svc-link  {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .05em; text-transform: uppercase;
  color: var(--accent); text-decoration: none; margin-top: auto;
}
.hs-svc-link:hover { text-decoration: underline; }
.hs-services-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; padding-top: 8px; }

.hs-slide[data-idx="3"] .hs-text--center {
  max-width: 760px;
  margin: 0 auto;
}

/* ── Navigation bar ── */
.hs-nav-bar {
  position: absolute;
  bottom: 28px; left: 50%; transform: translateX(-50%);
  display: flex; align-items: center; gap: 14px;
  z-index: 10;
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 99px;
  padding: 8px 16px;
}
.hs-dots  { display: flex; gap: 8px; align-items: center; }
.hs-dot {
  width: 7px; height: 7px; border-radius: 50%;
  border: none; padding: 0;
  background: rgba(255,255,255,.25);
  cursor: pointer;
  transition: background .25s, width .3s cubic-bezier(.4,0,.2,1), border-radius .3s;
}
.hs-dot.is-active { background: var(--accent); width: 22px; border-radius: 4px; }
.hs-arrow {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.15);
  background: transparent;
  color: rgba(255,255,255,.65);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: border-color .2s, color .2s, background .2s;
  flex-shrink: 0;
}
.hs-arrow:hover { border-color: var(--accent); color: var(--accent); background: rgba(157,255,9,.08); }

/* ── Responsive ── */
@media (max-width: 1100px) {
  .hs-fc--ig  { left: -16px; }
  .hs-fc--ads { right: -16px; }
  .hs-fc--tag { left: -16px; }
}
@media (max-width: 900px) {
  /* ── Mobile/tablette : slider désactivé → hero statique, slide active uniquement ── */
  .hs {
    display: block;
    min-height: 0;
    height: auto;
    overflow: visible;
  }
  /* Toutes les slides cachées par défaut */
  .hs-slide {
    display: none;
    grid-area: unset;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    transition: none;
    min-height: 0;
    padding: 40px 0 56px;
    justify-content: flex-start;
  }
  /* Seule la slide active est affichée */
  .hs-slide.is-active { display: flex; }
  /* Navigation cachée */
  .hs-nav-bar { display: none; }
  /* Barre de progression cachée */
  .hs-progress-line { display: none; }
  /* Layout une colonne */
  .hs-inner {
    width: 100%;
    min-width: 0;
    margin-left: 0;
    transform: none;
    grid-template-columns: 1fr;
    gap: 24px;
  }
  /* Cartes flottantes masquées */
  .hs-fc--ig, .hs-fc--ads, .hs-fc--tag { display: none; }
  .hs-visual--programme { min-height: auto; }
  .hs-program-tools { width: 100%; }
  .hs-program-tools > div { flex-direction: column; }
  .hs-program-tools .btn-sm { width: 100%; justify-content: center; }
}
@media (max-width: 600px) {
  .btn {
    min-height: 48px;
    font-size: 14px;
    padding: 13px 18px;
  }
  /* Slider phone : padding réduit, visuel masqué */
  .hs-slide { padding: 28px 0 48px; }
  .hs-slide .hs-visual { display: none; }
  /* Services : 1 colonne sur phone */
  .hs-services { grid-template-columns: 1fr; gap: 12px; }
  .hs-support-panel { border-radius: 14px; }
  .hs-support-bubble { font-size: 12px; }
  .hs-support-foot { flex-direction: column; gap: 6px; }
  .hs-support-foot span { font-size: 10px; }
  .hs-coaching-value { 
    padding: 12px; 
    font-size: 14px;
    flex-direction: column;
    gap: 12px;
    border: 1px solid rgba(157,255,9,.15);
  }
  .hs-coaching-impact { 
    border: none; 
    padding: 0;
    border-top: 1px solid rgba(157,255,9,.2);
    padding-top: 12px;
  }
  .hs-coaching-metric { font-size: 12px; }
  .hs-coaching-metric strong { font-size: 18px; }
  .hs-coaching-val { font-size: 24px; }
  .hs-coaching-price { gap: 3px; }
  .hs-coaching-label { font-size: 9px; }
  .hs-work-board--minimal { padding: 14px; min-height: auto; display: flex; flex-direction: column; gap: 12px; }
  .hs-work-impact-row { margin-bottom: 0; padding-bottom: 12px; border-bottom: 1px solid rgba(157,255,9,.1); flex-direction: column; gap: 10px; align-items: flex-start; }
  .hs-work-impact-sep { display: none; }
  .hs-work-impact-num { font-size: 20px; }
  .hs-work-impact-lbl { font-size: 9px; }
  .hs-work-mini-grid { grid-template-columns: 1fr; gap: 8px; }
  .hs-work-mini-card { padding: 10px; gap: 6px; }
  .hs-program-tools { margin-top: 10px; padding-top: 10px; }
  .hs-program-tools .btn-sm { width: 100%; justify-content: center; padding: 10px 12px; font-size: 10px; }
  .hs-program-tools > div { flex-direction: column !important; gap: 6px !important; }
  .hs-btns { flex-direction: column; align-items: stretch; gap: 8px; margin-bottom: 12px; }
  .hs-btns .btn { width: 100%; justify-content: center; padding: 13px 18px; }
  .hs-iphone16 {
    width: min(260px, 88vw);
    transform: none;
    border-radius: 34px;
    padding: 7px;
  }
  .hs-iphone16-screen { border-radius: 28px; }
  .hs-iphone16-island { width: 96px; height: 25px; }
  .hs-coaching-header { padding-top: 38px; }
  .hs-coaching-card { max-width: 100%; min-height: 100%; }
  .hs-h2--full { font-size: clamp(28px, 9vw, 38px); }
  .hs-services { grid-template-columns: 1fr; gap: 12px; max-width: none; }
  .hs-svc-card { padding: 18px 16px; }
  .hs-nav-bar  { bottom: 14px; gap: 10px; padding: 7px 12px; }
  .hs-dot      { width: 9px; height: 9px; }
  .hs-dot.is-active { width: 24px; }
  .hs-arrow    { width: 38px; height: 38px; }
  .hs-chips    { gap: 6px; }
  .hs-chip     { font-size: 9px; padding: 4px 10px; }
  .hs-price    { font-size: 22px; }
  .hs-services-cta { flex-direction: column; }
  .hs-services-cta .btn { width: 100%; justify-content: center; }
  .hs-services-visual { max-width: 100%; }
  .hs-work-board { min-height: 280px; border-radius: 18px; }
  .hs-work-board--minimal { padding: 14px; min-height: 0; }
  .hs-work-main-img { height: 280px; }
  .hs-work-kpi strong { font-size: 16px; }
  .hs-work-kpi span { font-size: 9px; }
  .hs-work-strip { grid-template-columns: 1fr; }
}

/* ── 1920px+ — sections plus aérées ─────────────────── */
@media (min-width: 1440px) {
  .section { padding: 110px 0; }
  .container { padding: 0 48px; }
}

/* ============================================================
   COOKIE CONSENT BANNER
   ============================================================ */
#fs-cookie-banner {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  max-width: 760px;
  width: calc(100% - 32px);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 20px;
  box-shadow: 0 8px 32px rgba(0,0,0,.45);
  animation: cc-slide-up .35s cubic-bezier(.4,0,.2,1) both;
}
#fs-cookie-banner.fs-cc-hidden {
  animation: cc-slide-down .35s cubic-bezier(.4,0,.2,1) both;
}
@keyframes cc-slide-up {
  from { opacity: 0; transform: translateX(-50%) translateY(16px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
@keyframes cc-slide-down {
  from { opacity: 1; transform: translateX(-50%) translateY(0); }
  to   { opacity: 0; transform: translateX(-50%) translateY(16px); }
}
.fs-cc-text {
  flex: 1;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--muted);
  line-height: 1.65;
  min-width: 200px;
}
.fs-cc-link {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.fs-cc-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.fs-cc-btn {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 8px 18px;
  cursor: pointer;
  transition: opacity .2s;
  border: none;
}
.fs-cc-btn:hover { opacity: .8; }
.fs-cc-accept {
  background: var(--accent);
  color: #0e1b17;
}
.fs-cc-decline {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--line);
}
@media (max-width: 600px) {
  #fs-cookie-banner { flex-direction: column; gap: 12px; bottom: 16px; }
  .fs-cc-actions { width: 100%; }
  .fs-cc-btn { flex: 1; text-align: center; }
}

/* ── WhatsApp flottant ── */
.wa-fab {
  position: fixed;
  bottom: 28px;
  right: 24px;
  z-index: 999;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: #25d366;
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
  text-decoration: none;
}
.wa-fab:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(37,211,102,.6);
}
.wa-fab svg { width: 28px; height: 28px; fill: #fff; }
@media (max-width: 600px) {
  .wa-fab { bottom: 80px; right: 16px; width: 46px; height: 46px; }
  .wa-fab svg { width: 24px; height: 24px; }
}





