  :root {
    --bg: #ffffff;
    --bg-2: #f7f5f0;
    --bg-3: #ece9e2;
    --panel: #ffffff;
    --ink: #0f0f10;
    --ink-2: #3a3a40;
    --muted: #6d6b64;
    --rule: #e5e3dc;
    --rule-strong: #bfbcb2;
    --accent: #ff6b00;
    --accent-2: #e55c00;
    --hazard: #ffcc00;
    --alert: #ff3b3b;
    --ok: #4ade80;
    --display: "Oswald", "Impact", sans-serif;
    --sans: "Archivo", -apple-system, system-ui, sans-serif;
    --mono: "JetBrains Mono", "SF Mono", Consolas, monospace;
    --black: "Archivo Black", "Archivo", sans-serif;
  }

  * { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--sans);
    background: var(--bg);
    color: var(--ink);
    font-size: 15px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    background-image:
      radial-gradient(circle at 20% 10%, rgba(255,107,0,0.04), transparent 40%),
      radial-gradient(circle at 80% 90%, rgba(255,107,0,0.03), transparent 50%);
  }
  ::selection { background: var(--accent); color: var(--bg); }

  /* Blueprint grid overlay on body */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image:
      linear-gradient(rgba(242,240,234,0.025) 1px, transparent 1px),
      linear-gradient(90deg, rgba(242,240,234,0.025) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
    z-index: 1;
  }

  .display { font-family: var(--display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.01em; }
  .black { font-family: var(--black); text-transform: uppercase; letter-spacing: -0.02em; }
  .mono { font-family: var(--mono); text-transform: uppercase; font-size: 11px; letter-spacing: 0.08em; }

  .wrap { max-width: 1440px; margin: 0 auto; padding: 0 40px; position: relative; z-index: 2; }
  @media (max-width: 800px) { .wrap { padding: 0 20px; } }

  /* HAZARD STRIPES helper */
  .hazard-stripes {
    background-image: repeating-linear-gradient(
      -45deg,
      var(--hazard) 0,
      var(--hazard) 14px,
      #1a1a1a 14px,
      #1a1a1a 28px
    );
  }

  /* ============ TICKER ============ */
  .ticker {
    background: var(--accent);
    color: #1a1a1a;
    padding: 8px 0;
    overflow: hidden;
    font-family: var(--mono);
    font-weight: 600;
    position: relative;
    z-index: 50;
    border-bottom: 2px solid #1a1a1a;
  }
  .ticker-track {
    display: flex;
    gap: 40px;
    animation: scroll-x 36s linear infinite;
    white-space: nowrap;
    font-size: 11px;
    letter-spacing: 0.1em;
  }
  .ticker-item { display: inline-flex; align-items: center; gap: 10px; }
  .ticker-item::before {
    content: '▸';
    color: #1a1a1a;
    font-size: 10px;
  }
  @keyframes scroll-x {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
  }
  @keyframes pulse-ok {
    0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(74,222,128,0.6); }
    50% { opacity: 0.7; box-shadow: 0 0 0 8px rgba(74,222,128,0); }
  }
  @keyframes blink {
    0%, 70%, 100% { opacity: 1; }
    85% { opacity: 0.2; }
  }

  /* ============ NAV ============ */
  nav.top {
    position: sticky;
    top: 0;
    background: rgba(15,15,16,0.92);
    backdrop-filter: blur(10px) saturate(140%);
    border-bottom: 1px solid var(--rule);
    z-index: 300; /* au-dessus du drawer mobile */
    transition: background 0.25s ease, box-shadow 0.25s ease;
  }
  nav.top .row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0;
    gap: 24px;
    transition: padding 0.25s ease;
  }

  /* ── État scrollé : nav plus compacte ── */
  nav.top.scrolled {
    background: rgba(10,10,11,0.99);
    box-shadow: 0 4px 32px rgba(0,0,0,0.65), 0 0 0 1px rgba(255,255,255,0.05);
    border-bottom-color: rgba(255,255,255,0.06);
  }
  @media (min-width: 1025px) {
    nav.top.scrolled .row   { padding: 7px 0; }
    nav.top.scrolled .logo  { font-size: 14px; gap: 8px; }
    nav.top.scrolled .logo .small { display: none; }
    nav.top.scrolled .logo-mark  { width: 30px; height: 30px; font-size: 16px; }
  }
  .logo-mark { transition: width 0.25s ease, height 0.25s ease, font-size 0.25s ease; }
  .logo      { transition: font-size 0.25s ease, gap 0.25s ease; }
  .logo {
    display: flex; align-items: center; gap: 10px;
    color: #ffffff;
    text-decoration: none;
    font-family: var(--display);
    font-weight: 700;
    font-size: 18px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }
  .logo-mark {
    width: 40px; height: 40px;
    background: var(--accent);
    color: #0f0f10;
    display: grid; place-items: center;
    font-family: var(--black);
    font-size: 22px;
    position: relative;
    flex-shrink: 0;
  }
  .logo-mark::before,
  .logo-mark::after {
    content: '';
    position: absolute;
    background: #0f0f10;
  }
  .logo-mark::before { top:3px; left:3px; width:4px; height:4px; }
  .logo-mark::after { bottom:3px; right:3px; width:4px; height:4px; }
  .logo .small { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; color: rgba(255,255,255,0.45); text-transform: uppercase; display:block; line-height:1.1; font-weight:400;}

  .nav-links { display: flex; gap: 28px; align-items: center; }
  .nav-links a {
    color: rgba(255,255,255,0.75);
    text-decoration: none;
    font-family: var(--display);
    text-transform: uppercase;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.06em;
    transition: color 0.15s;
  }
  .nav-links a:hover { color: var(--accent); }
  .nav-phone {
    font-family: var(--mono) !important;
    font-size: 12px !important;
    letter-spacing: 0.05em !important;
    color: #ffffff !important;
    font-weight: 600 !important;
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
  }
  .nav-phone::before {
    content: '';
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--ok);
    animation: pulse-ok 2s ease infinite;
  }
  .nav-cta {
    background: var(--accent);
    color: #0f0f10 !important;
    padding: 11px 18px;
    font-weight: 700 !important;
    position: relative;
    clip-path: polygon(0 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
    padding-right: 28px;
  }
  .nav-cta:hover { background: var(--hazard); }

  /* Urgences — lien rouge pulsant */
  .nav-urgence {
    color: #ff4444 !important;
    font-family: var(--display) !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center;
    gap: 4px;
    transition: color 0.15s;
  }
  .nav-urgence:hover { color: var(--accent) !important; }

  /* ============ DROPDOWN NAV ============ */
  .nav-item { position: relative; display: flex; align-items: center; }

  .nav-toggle {
    background: none;
    border: none;
    cursor: pointer;
    color: rgba(255,255,255,0.75);
    font-family: var(--display);
    text-transform: uppercase;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.06em;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 5px;
    transition: color 0.15s;
    white-space: nowrap;
  }
  .nav-toggle:hover,
  .nav-item.open .nav-toggle { color: var(--accent); }
  .nav-arrow { font-size: 10px; transition: transform 0.2s; display: inline-block; }
  .nav-item.open .nav-arrow { transform: rotate(180deg); }

  .nav-dropdown {
    position: absolute;
    top: calc(100% + 16px);
    left: 50%;
    transform: translateX(-50%);
    background: #111113;
    border: 1px solid rgba(255,255,255,0.1);
    border-top: 2px solid var(--accent);
    padding: 24px;
    display: none;
    gap: 32px;
    min-width: 560px;
    z-index: 200;
    box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  }
  /* Mega-menu multi-colonnes */
  .nav-item.has-dropdown:not(:has(.nav-dropdown--compact)) .nav-dropdown,
  .nav-dropdown:not(.nav-dropdown--compact) {
    display: none;
    grid-template-columns: repeat(3, 1fr);
  }
  /* Dropdown compact colonne unique */
  .nav-dropdown--compact {
    display: none;
    flex-direction: column;
    min-width: 240px;
    padding: 16px 0;
    gap: 0;
    left: 0;
    transform: none;
  }

  .nav-item.open .nav-dropdown:not(.nav-dropdown--compact) { display: grid; }
  .nav-item.open .nav-dropdown--compact { display: flex; }

  /* Petite flèche vers le haut du dropdown */
  .nav-dropdown::before {
    content: '';
    position: absolute;
    top: -7px;
    left: 50%;
    transform: translateX(-50%);
    width: 12px; height: 12px;
    background: var(--accent);
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  }
  .nav-dropdown--compact::before { left: 24px; transform: none; }

  .nav-dropdown-head {
    display: block;
    font-family: var(--mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--accent);
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }
  .nav-dropdown-col { display: flex; flex-direction: column; gap: 0; }
  .nav-dropdown-col a,
  .nav-dropdown a {
    color: rgba(255,255,255,0.65) !important;
    font-family: var(--display) !important;
    font-size: 13px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.03em !important;
    text-decoration: none !important;
    padding: 7px 0 !important;
    border-bottom: 1px solid rgba(255,255,255,0.04) !important;
    transition: color 0.12s, padding-left 0.12s !important;
    display: block !important;
    font-weight: 500 !important;
  }
  .nav-dropdown--compact a {
    padding: 9px 24px !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  }
  .nav-dropdown-col a:last-child,
  .nav-dropdown a:last-child { border-bottom: none !important; }
  .nav-dropdown-col a:hover,
  .nav-dropdown a:hover {
    color: var(--accent) !important;
    padding-left: 8px !important;
  }
  .nav-dropdown--compact a:hover { padding-left: 32px !important; }

  /* ============ HAMBURGER MOBILE ============ */
  .nav-burger {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    margin-left: auto;
  }
  .nav-burger span {
    display: block;
    width: 24px;
    height: 2px;
    background: #fff;
    transition: all 0.2s;
    transform-origin: center;
  }
  .nav-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-burger.open span:nth-child(2) { opacity: 0; }
  .nav-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* ============ MOBILE DRAWER ============ */
  .nav-mobile {
    display: none;
    flex-direction: column;
    background: #0a0a0b;
    border-top: 2px solid var(--accent);
    padding: 16px 0;
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.3s ease;
  }
  .nav-mobile.open { max-height: 600px; }
  .nav-mobile a {
    color: rgba(255,255,255,0.75) !important;
    font-family: var(--display) !important;
    font-size: 15px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    text-decoration: none !important;
    padding: 14px 20px !important;
    border-bottom: 1px solid rgba(255,255,255,0.05) !important;
    display: block !important;
    transition: color 0.12s, background 0.12s !important;
  }
  .nav-mobile a:hover { color: var(--accent) !important; background: rgba(255,255,255,0.03) !important; }
  .nav-mobile .nav-cta {
    margin: 12px 20px;
    text-align: center;
    border: none !important;
  }

  /* ================================================================
     MOBILE NAV — barre compacte + drawer plein écran
     ================================================================ */
  @media (max-width: 1024px) {
    /* Masquer TOUS les liens desktop dans la barre */
    .nav-links { display: none; }
    /* Barre compacte : logo + burger uniquement */
    nav.top .row { padding: 10px 0; gap: 0; }
    /* Logo : masquer le sous-titre sur mobile */
    .logo .small { display: none; }
    .logo { font-size: 15px; gap: 8px; }
    .logo-mark { width: 34px; height: 34px; font-size: 18px; }
    /* Afficher le burger */
    .nav-burger { display: flex; margin-left: auto; }
    /* Ticker plus petit */
    .ticker { font-size: 10px; padding: 6px 0; }
  }

  /* Drawer plein écran — toujours en dehors de <nav> dans le DOM */
  .nav-mobile {
    display: none;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    height: 100dvh; /* dynamic viewport height — meilleur sur iOS */
    background: #0a0a0b;
    z-index: 250; /* sous la nav (300) pour que la barre reste visible */
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    transform: translateX(100%);
    transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
  }
  @media (max-width: 1024px) {
    .nav-mobile { display: flex; }
  }
  .nav-mobile.open {
    transform: translateX(0);
  }

  /* Téléphone en vedette */
  .nav-mobile-phone {
    display: flex !important;
    flex-direction: column !important;
    padding: 18px 24px !important;
    background: rgba(255,107,0,0.08) !important;
    border-bottom: 1px solid rgba(255,107,0,0.2) !important;
    border-left: 3px solid var(--accent) !important;
    text-decoration: none !important;
    gap: 3px !important;
  }
  .nm-phone-label {
    font-family: var(--mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: rgba(255,107,0,0.6);
  }
  .nm-phone-num {
    font-family: var(--display);
    font-size: 26px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.02em;
  }

  /* Accordéon */
  .nm-accordion { border-bottom: 1px solid rgba(255,255,255,0.07); }
  .nm-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: none;
    border: none;
    color: rgba(255,255,255,0.9);
    font-family: var(--display);
    font-size: 18px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 18px 24px;
    cursor: pointer;
    transition: color 0.15s;
    text-align: left;
  }
  .nm-toggle:active,
  .nm-toggle.open { color: var(--accent); }
  .nm-arrow {
    font-size: 14px;
    transition: transform 0.25s;
    display: inline-block;
    flex-shrink: 0;
    opacity: 0.5;
  }
  .nm-toggle.open .nm-arrow { transform: rotate(180deg); opacity: 1; }

  /* Sous-menu */
  .nm-sub {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease;
    background: rgba(0,0,0,0.4);
  }
  .nm-sub-head {
    display: block;
    font-family: var(--mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--accent);
    padding: 12px 28px 4px;
    opacity: 0.6;
  }
  .nm-sub a {
    display: block !important;
    color: rgba(255,255,255,0.6) !important;
    font-family: var(--display) !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    text-decoration: none !important;
    padding: 12px 28px !important;
    border-bottom: 1px solid rgba(255,255,255,0.04) !important;
    transition: color 0.12s, background 0.12s !important;
  }
  .nm-sub a:active { color: var(--accent) !important; background: rgba(255,107,0,0.06) !important; }

  /* Liens directs */
  .nm-link {
    display: block !important;
    color: rgba(255,255,255,0.85) !important;
    font-family: var(--display) !important;
    font-size: 18px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    text-decoration: none !important;
    padding: 18px 24px !important;
    border-bottom: 1px solid rgba(255,255,255,0.07) !important;
    transition: color 0.12s !important;
  }
  .nm-link.nav-urgence {
    color: var(--accent) !important;
    background: rgba(255,107,0,0.05) !important;
  }

  /* CTA pleine largeur en bas */
  .nm-cta {
    display: block !important;
    margin: 20px 24px 32px !important;
    padding: 18px 24px !important;
    text-align: center !important;
    border: none !important;
    border-radius: 0 !important;
    font-size: 15px !important;
    letter-spacing: 0.08em !important;
    clip-path: polygon(0 0, 100% 0, calc(100% - 10px) 100%, 0 100%) !important;
  }

  /* ============ HERO ============ */
  .hero {
    padding: 28px 0 36px;
    position: relative;
    overflow: hidden;
    background: #ffffff;
    color: var(--ink, #0f0f10);
  }
  .hero::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 55%; height: 100%;
    background: radial-gradient(ellipse at top right, rgba(255,107,0,0.04), transparent 60%);
    pointer-events: none;
  }

  .hero-meta {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 20px;
    padding: 7px 0;
    border-top: 2px solid var(--ink, #0f0f10);
    border-bottom: 1px solid var(--rule, #e5e3dc);
    margin-bottom: 22px;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
  }
  .hero-meta .live-tag {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--ok);
    color: #0f0f10;
    padding: 4px 10px;
    font-weight: 700;
  }
  .hero-meta .live-tag .dot {
    width: 6px; height: 6px; background: #0f0f10; border-radius: 50%;
    animation: blink 1.8s ease infinite;
  }
  .hero-meta .center { color: var(--muted, #6d6b64); text-align: center; }
  .hero-meta .right { color: var(--ink-2, #3a3a40); }

  .hero-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 40px;
    align-items: start;
  }
  @media (max-width: 1000px) {
    .hero-grid { grid-template-columns: 1fr; gap: 28px; }
    /* ops-panel : reprend toute la largeur, pas de décalage */
    .ops-panel { width: 100%; }
  }

  /* Hero responsive */
  @media (max-width: 700px) {
    .hero { padding: 20px 0 28px; }
    /* hero-meta : masquer le texte central long sur mobile */
    .hero-meta { grid-template-columns: auto auto; }
    .hero-meta .center { display: none; }
    .hero-meta .right { text-align: right; }
    /* Boutons CTA hero en colonne */
    .hero-ctas { flex-direction: column; gap: 10px; }
    .hero-ctas .btn { width: 100%; justify-content: center; }
    /* certif row */
    .certs-row { flex-wrap: wrap; gap: 8px; }
  }

  /* Hero title */
  .serial {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.15em;
    color: var(--accent);
    margin-bottom: 16px;
    text-transform: uppercase;
  }
  .serial::before { content:''; width: 32px; height: 1px; background: var(--accent); }

  h1.hero-title {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(30px, 3.8vw, 58px);
    line-height: 0.94;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    color: var(--ink, #0f0f10);
    margin-bottom: 14px;
  }
  h1.hero-title .stencil {
    position: relative;
    display: inline-block;
    color: var(--accent);
    padding: 0 0.05em;
  }
  h1.hero-title .stencil::before,
  h1.hero-title .stencil::after {
    content: '';
    position: absolute;
    left: -8px; right: -8px;
    height: 3px;
    background: var(--accent);
  }
  h1.hero-title .stencil::before { top: 0; }
  h1.hero-title .stencil::after { bottom: 0; }
  h1.hero-title .strike {
    position: relative;
    color: var(--muted);
    display: inline-block;
  }
  h1.hero-title .strike::after {
    content:'';
    position: absolute;
    left: -4px; right: -4px; top: 52%;
    height: 6px;
    background: var(--alert);
    transform: rotate(-2deg);
  }
  h1.hero-title .outline {
    -webkit-text-stroke: 2px var(--ink, #0f0f10);
    color: transparent;
  }

  .hero-lede {
    font-size: 15px;
    line-height: 1.5;
    color: var(--ink-2, #3a3a40);
    max-width: 520px;
    margin-bottom: 18px;
    font-weight: 400;
  }
  .hero-lede strong {
    background: var(--accent);
    color: #0f0f10;
    padding: 2px 6px;
    font-weight: 700;
  }

  .hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
  .btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 13px 22px;
    font-family: var(--display);
    font-size: 13px;
    font-weight: 700;
    border: none;
    cursor: pointer;
    text-decoration: none;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: all 0.15s ease;
    position: relative;
  }
  .btn-primary {
    background: var(--accent);
    color: #0f0f10;
    clip-path: polygon(0 0, 100% 0, calc(100% - 12px) 100%, 0 100%);
    padding-right: 32px;
  }
  .btn-primary:hover { background: var(--hazard); }
  .btn-ghost {
    background: transparent;
    color: var(--ink, #0f0f10);
    border: 1.5px solid var(--ink-2, #3a3a40);
  }
  .btn-ghost:hover { background: var(--ink, #0f0f10); color: #fff; border-color: var(--ink, #0f0f10); }
  .btn .arrow { transition: transform 0.2s; font-family: var(--mono); font-size: 14px; }
  .btn:hover .arrow { transform: translateX(4px); }

  /* Hero RHS: ops/form panel */
  .ops-panel {
    background: linear-gradient(160deg, #111113 0%, #17171b 50%, #1a1218 100%);
    border: 1px solid rgba(255,255,255,0.08);
    position: relative;
    overflow: hidden;
    box-shadow:
      0 32px 64px -20px rgba(0,0,0,0.7),
      inset 0 1px 0 rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.9); /* fix: texte clair sur fond sombre */
  }
  /* Exceptions pour les zones à fond clair dans le panel */
  .ops-spec { color: var(--ink); }
  .ops-spec .k { color: var(--muted); }
  /* Barre accent orange en haut */
  .ops-panel::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--accent) 0%, rgba(255,107,0,0.3) 60%, transparent 100%);
    z-index: 2;
  }
  /* Coin inférieur droit décoratif */
  .ops-panel::before {
    content: '';
    position: absolute;
    bottom: -1px; right: -1px;
    width: 40px; height: 40px;
    background: linear-gradient(135deg, transparent 50%, rgba(255,107,0,0.25) 50%);
    z-index: 1;
  }
  .ops-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 11px 16px;
    background: rgba(0,0,0,0.35);
    border-bottom: 1px solid rgba(255,255,255,0.07);
    font-family: var(--mono);
    font-size: 9.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
  }
  .ops-header .dots { display: inline-flex; gap: 5px; }
  .ops-header .dots span {
    width: 8px; height: 8px; border-radius: 50%;
    background: rgba(255,255,255,0.15);
  }
  .ops-header .dots .on { background: var(--ok); animation: pulse-ok 2s ease infinite; }
  .ops-header .label { color: rgba(255,255,255,0.35); }
  .ops-header .id { color: rgba(255,107,0,0.8); font-weight: 600; letter-spacing: 0.1em; }

  .ops-body { padding: 24px; }

  .ops-status {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    background: rgba(74,222,128,0.08);
    border: 1px solid rgba(74,222,128,0.25);
    margin-bottom: 20px;
    position: relative;
  }
  .ops-status::before {
    content: '';
    position: absolute;
    top: 0; left: 0; bottom: 0;
    width: 3px;
    background: var(--ok);
  }
  .ops-status .st-dot {
    width: 10px; height: 10px;
    background: var(--ok);
    border-radius: 50%;
    animation: pulse-ok 2s ease infinite;
  }
  .ops-status .st-txt {
    font-family: var(--display);
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }
  .ops-status .st-sub {
    font-family: var(--mono); font-size: 10px; color: var(--muted);
    letter-spacing: 0.08em; margin-left: auto;
  }

  .ops-title {
    font-family: var(--display);
    font-weight: 700;
    font-size: 28px;
    line-height: 1.05;
    text-transform: uppercase;
    margin-bottom: 4px;
  }
  .ops-title .alert {
    display: inline-block;
    background: var(--alert);
    color: #fff;
    padding: 2px 8px;
    font-size: 0.65em;
    letter-spacing: 0.08em;
    vertical-align: middle;
    margin-left: 6px;
    animation: blink 2s ease infinite;
  }
  .ops-sub {
    color: var(--muted);
    font-size: 12px;
    font-family: var(--mono);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 22px;
  }

  .ops-phone {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 16px;
    background: var(--accent);
    color: #0f0f10;
    margin-bottom: 20px;
    position: relative;
    gap: 16px;
  }
  .ops-phone::after {
    content: '';
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 14px;
    background: repeating-linear-gradient(
      -45deg,
      #0f0f10 0 6px,
      transparent 6px 12px
    );
  }
  .ops-phone .l {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 700;
    opacity: 0.8;
    display: block;
    margin-bottom: 2px;
  }
  .ops-phone .n {
    font-family: var(--display);
    font-weight: 700;
    font-size: 26px;
    letter-spacing: 0.04em;
    display: block;
  }
  .ops-phone .call-arrow {
    font-family: var(--black);
    font-size: 18px;
    margin-right: 18px;
  }

  .ops-specs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--rule);
  }
  .ops-spec {
    background: var(--bg-2);
    padding: 14px 12px;
  }
  .ops-spec .k {
    font-family: var(--mono); font-size: 9px; letter-spacing: 0.12em;
    color: var(--muted); text-transform: uppercase; margin-bottom: 4px;
  }
  .ops-spec .v {
    font-family: var(--display); font-weight: 700; font-size: 20px;
    text-transform: uppercase;
  }
  .ops-spec .v .u { color: var(--accent); font-size: 0.65em; margin-left: 2px; }

  /* Certs row */
  .certs-row {
    margin-top: 64px;
    padding: 24px 0;
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
    display: flex;
    align-items: center;
    gap: 32px;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .certs-row .lbl {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--muted);
  }
  .certs {
    display: flex; gap: 28px; align-items: center; flex-wrap: wrap;
  }
  .cert {
    display: flex; align-items: center; gap: 10px;
    font-family: var(--display);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--ink-2);
  }
  .cert .cert-mark {
    width: 34px; height: 34px;
    border: 1.5px solid var(--ink-2);
    display: grid; place-items: center;
    font-family: var(--mono);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--ink-2);
    transform: rotate(-4deg);
  }

  /* ============ STATS (blueprint / gauge style) ============ */
  .stats {
    padding: 64px 0;
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
    background: var(--bg-2);
    position: relative;
  }
  .stats::before, .stats::after {
    content: '';
    position: absolute;
    left: 0; right: 0;
    height: 10px;
    background: repeating-linear-gradient(
      -45deg,
      var(--accent) 0 10px,
      #0f0f10 10px 20px
    );
    opacity: 0.9;
  }
  .stats::before { top: 0; }
  .stats::after { bottom: 0; }

  .stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    padding: 20px 0;
  }
  @media (max-width: 900px) {
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
  }
  .stat {
    padding: 16px 28px;
    border-left: 1px dashed var(--rule-strong);
    position: relative;
  }
  .stat:first-child { border-left: none; padding-left: 0; }
  @media (max-width: 900px) {
    .stat { padding: 20px; border-left: none; border-bottom: 1px dashed var(--rule-strong); }
  }
  .stat .num {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(52px, 6vw, 92px);
    line-height: 0.95;
    letter-spacing: -0.01em;
    margin-bottom: 10px;
    color: var(--ink);
    display: flex;
    align-items: baseline;
    gap: 4px;
    text-transform: uppercase;
  }
  .stat .num .unit {
    font-size: 0.35em;
    color: var(--accent);
    font-weight: 600;
    letter-spacing: 0.02em;
  }
  .stat .label {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
    line-height: 1.5;
  }
  .stat .tag {
    display: inline-block;
    font-family: var(--mono);
    font-size: 9px;
    letter-spacing: 0.1em;
    padding: 2px 6px;
    background: var(--bg-3);
    color: var(--accent);
    border: 1px solid var(--rule-strong);
    margin-bottom: 6px;
  }

  /* ============ SECTION HEADERS ============ */
  .section {
    padding: 100px 0;
    position: relative;
  }
  .section-alt { background: var(--bg-2); }

  .section-header {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 48px;
    align-items: end;
    margin-bottom: 56px;
    padding-bottom: 20px;
    border-bottom: 1px dashed var(--rule-strong);
  }
  @media (max-width: 900px) { .section-header { grid-template-columns: 1fr; gap: 20px; } }

  .section-tag {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 6px 10px;
    background: var(--accent);
    color: #0f0f10;
    font-family: var(--mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    width: fit-content;
    margin-bottom: 16px;
  }
  .section-tag::before {
    content: '▸';
    font-size: 9px;
  }
  .section-title {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(40px, 5.5vw, 84px);
    line-height: 0.95;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    color: var(--ink);
  }
  .section-title .accent { color: var(--accent); }
  .section-title .outline {
    -webkit-text-stroke: 2px var(--ink);
    color: transparent;
  }
  .section-intro {
    font-size: 16px;
    line-height: 1.6;
    max-width: 480px;
    color: var(--ink-2);
    justify-self: end;
  }
  @media (max-width: 900px) { .section-intro { justify-self: start; } }

  /* ============ SERVICES ============ */
  /* Cartes services cliquables : <a> au lieu de <div> */
  a.service {
    color: inherit;
    text-decoration: none;
    display: flex;
    flex-direction: column;
  }

  .services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--rule-strong);
    border: 1px solid var(--rule-strong);
  }
  @media (max-width: 1100px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 600px) { .services-grid { grid-template-columns: 1fr; } }

  .service {
    padding: 28px 24px;
    background: var(--bg);
    min-height: 260px;
    display: flex;
    flex-direction: column;
    cursor: pointer;
    position: relative;
    transition: background 0.2s, color 0.2s;
    overflow: hidden;
  }
  .service .svc-bg {
    position: absolute;
    inset: 0;
    background: var(--accent);
    transform: translateY(101%);
    transition: transform 0.35s cubic-bezier(.7,0,.3,1);
  }
  .service:hover .svc-bg { transform: translateY(0); }
  .service:hover { color: #0f0f10; }
  .service > *:not(.svc-bg) { position: relative; z-index: 1; }

  .svc-top {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: auto;
  }
  .svc-num {
    font-family: var(--black);
    font-size: 42px;
    line-height: 0.9;
    color: var(--muted);
    opacity: 0.6;
  }
  .service:hover .svc-num { color: #0f0f10; opacity: 1; }
  .svc-pictogram {
    width: 36px; height: 36px;
    border: 1.5px solid var(--ink-2);
    display: grid; place-items: center;
    font-family: var(--mono);
    font-weight: 700;
    font-size: 14px;
    color: var(--ink-2);
  }
  .service:hover .svc-pictogram { border-color: #0f0f10; color: #0f0f10; }
  .svc-title {
    font-family: var(--display);
    font-weight: 700;
    font-size: 22px;
    line-height: 1.05;
    text-transform: uppercase;
    margin-top: 36px;
    margin-bottom: 8px;
    letter-spacing: -0.005em;
  }
  .svc-desc {
    font-size: 12px;
    line-height: 1.5;
    opacity: 0.7;
    margin-bottom: 16px;
  }
  .svc-meta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding-top: 12px;
    border-top: 1px dashed currentColor;
    opacity: 0.8;
  }
  .svc-meta .arrow { font-size: 14px; }
  .service:hover .svc-meta .arrow { transform: translateX(4px); }

  /* ============ MARQUEE ============ */
  .marquee-row {
    overflow: hidden;
    padding: 28px 0;
    border-top: 2px solid var(--accent);
    border-bottom: 2px solid var(--accent);
    background: var(--bg-2);
    position: relative;
  }
  .marquee-track {
    display: inline-flex;
    gap: 32px;
    animation: scroll-x 32s linear infinite;
    white-space: nowrap;
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(40px, 6vw, 80px);
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.01em;
  }
  .marquee-track .star {
    color: var(--accent);
    font-family: var(--mono);
    font-weight: 400;
  }
  .marquee-track .outline {
    -webkit-text-stroke: 2px var(--ink);
    color: transparent;
  }

  /* ============ DIAGNOSTIC ============ */
  .diag-wrap {
    background: var(--bg);
    border: 1px solid var(--rule-strong);
    padding: 48px;
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 48px;
    align-items: start;
    position: relative;
  }
  .diag-wrap::before {
    content: '';
    position: absolute;
    top: -1px; left: -1px; right: -1px;
    height: 4px;
    background: repeating-linear-gradient(
      -45deg,
      var(--accent) 0 8px,
      #0f0f10 8px 16px
    );
  }
  @media (max-width: 900px) { .diag-wrap { grid-template-columns: 1fr; padding: 32px 20px; gap: 32px; } }

  .diag-lhs .serial { margin-bottom: 20px; }
  .diag-lhs h2 {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(34px, 4vw, 56px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 20px;
    color: var(--ink);
  }
  .diag-lhs h2 .accent { color: var(--accent); }
  .diag-lhs p { color: var(--ink-2); font-size: 15px; line-height: 1.6; margin-bottom: 28px; max-width: 400px; }
  .diag-steps-list {
    list-style: none;
    counter-reset: step;
  }
  .diag-steps-list li {
    counter-increment: step;
    padding: 12px 0;
    border-top: 1px solid var(--rule);
    display: flex;
    align-items: center;
    gap: 14px;
    font-family: var(--display);
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--muted);
    transition: color 0.2s;
  }
  .diag-steps-list li::before {
    content: counter(step, decimal-leading-zero);
    font-family: var(--mono);
    font-size: 11px;
    opacity: 0.5;
    min-width: 22px;
  }
  .diag-steps-list li.active { color: var(--ink); }
  .diag-steps-list li.active::before { color: var(--accent); opacity: 1; }
  .diag-steps-list li.done::before { content: '✓'; color: var(--accent); }

  .diag-card {
    background: var(--bg-3);
    border: 1px solid var(--rule-strong);
    padding: 28px;
    min-height: 480px;
    display: flex;
    flex-direction: column;
    position: relative;
  }
  .diag-card .progress-track {
    height: 4px;
    background: var(--rule);
    margin-bottom: 20px;
    position: relative;
  }
  .diag-card .progress-fill {
    position: absolute; top: 0; left: 0; height: 100%;
    background: var(--accent);
    transition: width 0.4s ease;
  }
  .diag-card .step-meta {
    display: flex;
    justify-content: space-between;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 14px;
  }
  .diag-card .q-title {
    font-family: var(--display);
    font-weight: 700;
    font-size: 26px;
    line-height: 1.05;
    text-transform: uppercase;
    margin-bottom: 22px;
    color: var(--ink);
  }
  .diag-card .options { display: grid; gap: 8px; flex-grow: 1; }
  .diag-option {
    padding: 14px 16px;
    border: 1px solid var(--rule-strong);
    background: var(--bg-2);
    cursor: pointer;
    font-family: var(--display);
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    text-align: left;
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    transition: all 0.15s;
  }
  .diag-option:hover {
    border-color: var(--accent);
    background: var(--bg);
  }
  .diag-option.selected {
    border-color: var(--accent);
    background: rgba(255,107,0,0.12);
    color: var(--accent);
  }
  .diag-option .arrow {
    font-family: var(--mono);
    font-size: 14px;
    opacity: 0;
    transition: opacity 0.2s, transform 0.2s;
  }
  .diag-option:hover .arrow { opacity: 1; transform: translateX(4px); color: var(--accent); }
  .diag-option.selected .arrow { opacity: 1; color: var(--accent); }

  .diag-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--rule);
  }
  .diag-back {
    background: transparent; border: none; cursor: pointer;
    font-family: var(--mono); font-size: 11px;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--muted);
  }
  .diag-back:hover { color: var(--accent); }

  .diag-input-group { display: grid; gap: 10px; }
  .diag-input-group input {
    padding: 14px 16px;
    border: 1px solid var(--rule-strong);
    font-size: 14px;
    font-family: var(--sans);
    background: var(--bg-2);
    color: var(--ink);
    outline: none;
  }
  .diag-input-group input::placeholder { color: var(--muted); text-transform: uppercase; font-size: 12px; letter-spacing: 0.06em; }
  .diag-input-group input:focus { border-color: var(--accent); }

  .diag-result .badge {
    display: inline-flex;
    align-items: center; gap: 8px;
    background: rgba(74,222,128,0.12);
    color: var(--ok);
    padding: 5px 10px;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 16px;
    border: 1px solid rgba(74,222,128,0.3);
  }
  .diag-result .big-num {
    font-family: var(--display);
    font-weight: 700;
    font-size: 80px;
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 6px;
    color: var(--ink);
  }
  .diag-result .big-num .unit { color: var(--accent); font-size: 0.35em; }
  .diag-result p { color: var(--ink-2); font-size: 13px; line-height: 1.55; margin-bottom: 18px; }
  .diag-result .summary {
    background: var(--bg-2);
    border: 1px solid var(--rule-strong);
    padding: 14px 16px;
    font-size: 13px;
    display: grid;
    gap: 8px;
    margin-bottom: 18px;
  }
  .diag-result .summary .row { display: flex; justify-content: space-between; gap: 12px; }
  .diag-result .summary .k {
    font-family: var(--mono); font-size: 10px;
    letter-spacing: 0.1em; color: var(--muted); text-transform: uppercase;
  }
  .diag-result .summary .v { font-family: var(--display); font-weight: 600; text-transform: uppercase; text-align: right; font-size: 13px; }

  /* ============ SECTORS ============ */
  .sectors-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
  }
  @media (max-width: 1000px) { .sectors-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 540px)  { .sectors-grid { grid-template-columns: 1fr 1fr; gap: 8px; } }

  /* Cartes secteurs — cliquables avec photo de fond */
  a.sector-card {
    text-decoration: none;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  .sector-card {
    aspect-ratio: 4/5;
    background: var(--ink); /* fallback sombre */
    border: 1px solid rgba(255,255,255,0.1);
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.3s ease;
    color: #fff; /* texte toujours blanc sur photo sombre */
  }
  /* Image de fond via style inline sur .bg-pattern */
  .sector-card .bg-pattern {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center;
    background-color: #1a1a1a; /* fallback si image ne charge pas */
    z-index: 0;
    transition: opacity 0.3s ease, transform 0.4s ease;
  }
  /* Gradient sombre pour la lisibilité du texte sur l'image */
  .sector-card .bg-pattern::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(170deg, rgba(0,0,0,0.28) 0%, rgba(0,0,0,0.78) 100%);
  }
  /* Tous les éléments texte au-dessus de l'image */
  .sector-card > *:not(.bg-pattern) { position: relative; z-index: 1; }
  /* Zoom subtil de l'image au survol avant le fade orange */
  .sector-card:hover .bg-pattern { transform: scale(1.04); opacity: 0; }
  /* Sur hover : fond orange opaque + texte sombre */
  .sector-card:hover {
    background: var(--accent);
    color: #0f0f10;
    transform: translateY(-4px);
    border-color: var(--accent);
    box-shadow: 0 16px 40px -8px rgba(255,107,0,0.35);
  }
  .sector-card .top {
    display: flex; justify-content: space-between; align-items: center;
  }
  .sector-card .n {
    font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
    text-transform: uppercase; color: rgba(255,255,255,0.65);
    transition: color 0.2s;
  }
  .sector-card:hover .n { color: rgba(0,0,0,0.55); }
  .sector-card .tag {
    font-family: var(--mono); font-size: 9px; letter-spacing: 0.12em;
    padding: 2px 6px;
    border: 1px solid rgba(255,255,255,0.45);
    text-transform: uppercase;
    color: rgba(255,255,255,0.85);
    transition: all 0.2s;
  }
  .sector-card:hover .tag { border-color: rgba(0,0,0,0.35); color: rgba(0,0,0,0.65); }
  .sector-card .title {
    font-family: var(--display);
    font-weight: 700;
    font-size: 26px;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: -0.01em;
    color: #fff;
    transition: color 0.2s;
    text-shadow: 0 2px 8px rgba(0,0,0,0.5);
  }
  .sector-card:hover .title { color: #0f0f10; text-shadow: none; }
  .sector-card .sub {
    font-size: 11px; margin-top: 8px; line-height: 1.5;
    color: rgba(255,255,255,0.72);
    transition: color 0.2s;
  }
  .sector-card:hover .sub { color: rgba(0,0,0,0.65); }

  /* ============ PROCESS ============ */
  .process-section {
    background: var(--bg);
    position: relative;
    overflow: hidden;
  }
  .process-section::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 6px;
    background: repeating-linear-gradient(
      -45deg,
      var(--hazard) 0 10px,
      #0f0f10 10px 20px
    );
  }

  .process-track {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4px;
    background: var(--rule-strong);
    border: 1px solid var(--rule-strong);
  }
  @media (max-width: 900px) { .process-track { grid-template-columns: 1fr; } }
  .process-step {
    background: var(--bg-2);
    padding: 28px 24px;
    position: relative;
    overflow: hidden;
  }
  .process-step::before {
    content: counter(process-n, decimal-leading-zero);
    counter-increment: process-n;
    position: absolute;
    bottom: -30px; right: -10px;
    font-family: var(--black);
    font-size: 180px;
    line-height: 1;
    color: var(--rule-strong);
    opacity: 0.4;
    pointer-events: none;
  }
  .process-track { counter-reset: process-n; }
  .process-step > * { position: relative; z-index: 1; }
  .process-step .n {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .process-step .n::before {
    content:''; width: 18px; height: 1px; background: var(--accent);
  }
  .process-step h4 {
    font-family: var(--display);
    font-weight: 700;
    font-size: 22px;
    line-height: 1.05;
    text-transform: uppercase;
    margin-bottom: 10px;
  }
  .process-step p {
    font-size: 13px;
    line-height: 1.55;
    color: var(--ink-2);
  }

  /* ============ GUARANTEES ============ */
  .guarantees-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--rule-strong);
    border: 1px solid var(--rule-strong);
  }
  @media (max-width: 900px) { .guarantees-grid { grid-template-columns: 1fr; } }
  .guarantee {
    background: var(--bg);
    padding: 40px 28px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    position: relative;
  }
  .guarantee .stamp-wrap {
    display: flex; align-items: center; gap: 16px;
  }
  .guarantee .stamp {
    width: 72px; height: 72px;
    background: var(--accent);
    color: #0f0f10;
    display: grid; place-items: center;
    font-family: var(--black);
    font-size: 26px;
    text-transform: uppercase;
    position: relative;
    flex-shrink: 0;
  }
  .guarantee .stamp::before,
  .guarantee .stamp::after {
    content: ''; position: absolute; background: #0f0f10;
  }
  .guarantee .stamp::before { top: 4px; left: 4px; width: 6px; height: 6px; }
  .guarantee .stamp::after { bottom: 4px; right: 4px; width: 6px; height: 6px; }
  .guarantee .stamp-label {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
  }
  .guarantee h4 {
    font-family: var(--display);
    font-weight: 700;
    font-size: 22px;
    line-height: 1.1;
    text-transform: uppercase;
  }
  .guarantee p {
    font-size: 13px;
    line-height: 1.55;
    color: var(--ink-2);
  }
  .guarantee .contract-line {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
    padding-top: 12px;
    border-top: 1px dashed var(--rule-strong);
  }

  /* ============ FAQ ============ */
  .faq-list { display: grid; gap: 0; }
  .faq-item {
    border-top: 1px solid var(--rule-strong);
    padding: 20px 0;
    cursor: pointer;
  }
  .faq-item:last-child { border-bottom: 1px solid var(--rule-strong); }
  .faq-item summary {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 20px;
    list-style: none;
    font-family: var(--display);
    font-size: clamp(18px, 2.3vw, 28px);
    font-weight: 700;
    text-transform: uppercase;
    line-height: 1.1;
    color: var(--ink);
    letter-spacing: -0.005em;
  }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item[open] summary { color: var(--accent); }
  .faq-item .q-num {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
    font-weight: 400;
    min-width: 40px;
  }
  .faq-item .toggle {
    font-family: var(--display);
    font-size: 28px;
    line-height: 1;
    font-weight: 700;
    transition: transform 0.25s;
    color: var(--accent);
  }
  .faq-item[open] .toggle { transform: rotate(45deg); }
  .faq-item p {
    margin-top: 14px;
    padding-left: 60px;
    color: var(--ink-2);
    font-size: 14px;
    line-height: 1.6;
    max-width: 820px;
  }

  /* ============ FORM ============ */
  .form-section {
    background: var(--bg-2);
    border-top: 1px solid var(--rule-strong);
    border-bottom: 1px solid var(--rule-strong);
    position: relative;
  }
  .form-section::before, .form-section::after {
    content: '';
    position: absolute;
    left: 0; right: 0;
    height: 8px;
    background: repeating-linear-gradient(
      -45deg,
      var(--accent) 0 10px,
      #0f0f10 10px 20px
    );
  }
  .form-section::before { top: 0; }
  .form-section::after { bottom: 0; }
  .form-wrap {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 64px;
    align-items: start;
  }
  @media (max-width: 900px) { .form-wrap { grid-template-columns: 1fr; gap: 40px; } }
  .form-lhs .serial { margin-bottom: 20px; }
  .form-lhs h2 {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(40px, 5vw, 68px);
    line-height: 0.92;
    text-transform: uppercase;
    margin-bottom: 20px;
  }
  .form-lhs h2 .accent { color: var(--accent); }
  .form-lhs p {
    color: var(--ink-2);
    font-size: 16px;
    line-height: 1.6;
    max-width: 420px;
    margin-bottom: 28px;
  }
  .form-lhs .contact-block {
    padding: 16px 0;
    border-top: 1px solid var(--rule-strong);
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
  }
  .form-lhs .contact-block:last-of-type { border-bottom: 1px solid var(--rule-strong); }
  .form-lhs .contact-block .k {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
  }
  .form-lhs .contact-block .v {
    font-family: var(--display);
    font-weight: 700;
    font-size: 18px;
    text-align: right;
    text-transform: uppercase;
  }
  .form-lhs .contact-block .v.phone { color: var(--accent); font-size: 20px; letter-spacing: 0.04em; }

  .form-card {
    background: var(--bg);
    border: 1px solid var(--rule-strong);
    padding: 32px;
    position: relative;
  }
  .form-card::before {
    content: 'FORM-2026.04';
    position: absolute;
    top: -1px; right: 16px;
    background: var(--accent);
    color: #0f0f10;
    padding: 4px 10px;
    font-family: var(--mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
  }
  .form-card h3 {
    font-family: var(--display);
    font-size: 24px;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 6px;
    letter-spacing: -0.005em;
  }
  .form-card .sub {
    color: var(--muted);
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 24px;
  }

  .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .field { display: flex; flex-direction: column; gap: 5px; }
  .field.full { grid-column: 1 / -1; }
  .field label {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
  }
  .field input, .field textarea, .field select {
    padding: 12px 14px;
    border: 1px solid var(--rule-strong);
    font-size: 14px;
    font-family: var(--sans);
    background: var(--bg-2);
    color: var(--ink);
    outline: none;
    transition: border-color 0.15s;
  }
  .field input:focus, .field textarea:focus, .field select:focus { border-color: var(--accent); }
  .field textarea { resize: vertical; min-height: 70px; }

  .urgency-select {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 8px;
    margin-top: 4px;
  }
  .urgency-select label {
    border: 1px solid var(--rule-strong);
    padding: 12px 8px;
    text-align: center;
    cursor: pointer;
    font-family: var(--display);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--ink-2);
    transition: all 0.15s;
    background: var(--bg-2);
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: center;
    font-weight: 600;
  }
  .urgency-select label .ico-u { font-family: var(--mono); font-size: 14px; color: var(--accent); font-weight: 700; }
  .urgency-select label:hover { border-color: var(--accent); color: var(--ink); }
  .urgency-select input { display: none; }
  .urgency-select label:has(input:checked) {
    border-color: var(--accent);
    background: rgba(255,107,0,0.1);
    color: var(--ink);
  }

  .consent {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 11px;
    color: var(--muted);
    line-height: 1.5;
    margin-top: 14px;
    font-family: var(--mono);
    letter-spacing: 0.02em;
  }
  .consent input { margin-top: 3px; }

  .submit-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-top: 20px;
    flex-wrap: wrap;
  }
  .submit-row .legalz {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
  }

  /* ============ FOOTER EMERGENCY STRIP ============ */
  .footer-emergency {
    background: var(--accent);
    color: #0f0f10;
    padding: 12px 0;
    position: relative;
  }
  .footer-emergency::before {
    content: '';
    position: absolute; inset: 0;
    background: repeating-linear-gradient(
      -45deg, rgba(0,0,0,0.06) 0 8px, transparent 8px 16px
    );
    pointer-events: none;
  }
  .fe-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
  }
  .fe-left { display: flex; align-items: center; gap: 12px; }
  .fe-dot {
    width: 10px; height: 10px;
    background: #0f0f10; border-radius: 50%;
    animation: pulse-ok 2s ease infinite;
    flex-shrink: 0;
  }
  .fe-label {
    font-family: var(--mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
  }
  .fe-right { display: flex; align-items: center; gap: 20px; }
  .fe-phone {
    font-family: var(--display);
    font-weight: 700;
    font-size: 22px;
    color: #0f0f10;
    text-decoration: none;
    letter-spacing: 0.02em;
  }
  .fe-phone:hover { text-decoration: underline; }
  .fe-cta {
    background: #0f0f10;
    color: var(--accent);
    padding: 8px 18px;
    font-family: var(--display);
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    text-decoration: none;
    clip-path: polygon(0 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
    padding-right: 24px;
    transition: background 0.15s, color 0.15s;
  }
  .fe-cta:hover { background: #fff; color: var(--accent); }

  /* ============ FOOTER MAIN ============ */
  .site-footer {
    background: #0a0a0b;
    color: rgba(255,255,255,0.75);
    padding: 64px 0 0;
    border-top: 1px solid rgba(255,255,255,0.06);
    position: relative;
    overflow: hidden;
  }

  /* Grille principale */
  .footer-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr 1.2fr;
    gap: 40px;
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  @media (max-width: 1100px) { .footer-grid { grid-template-columns: 1fr 1fr 1fr; } }
  @media (max-width: 700px)  { .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; } }
  @media (max-width: 480px)  { .footer-grid { grid-template-columns: 1fr; } }

  /* Col 1 : Brand */
  .footer-brand-col { grid-column: 1; }
  @media (max-width: 1100px) { .footer-brand-col { grid-column: 1 / -1; } }
  .footer-logo { color: #fff !important; }
  .footer-logo .small { color: rgba(255,255,255,0.35) !important; }

  .footer-desc {
    font-size: 13px;
    line-height: 1.65;
    color: rgba(255,255,255,0.5);
    margin-top: 16px;
    max-width: 320px;
  }
  .footer-address {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-style: normal;
    font-size: 12px;
    color: rgba(255,255,255,0.4);
    font-family: var(--mono);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-top: 16px;
  }
  .footer-phone {
    color: var(--accent) !important;
    text-decoration: none;
    font-family: var(--display);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.02em;
    margin-top: 4px;
  }
  .footer-phone:hover { text-decoration: underline; }
  .footer-email-link {
    color: rgba(255,255,255,0.5) !important;
    text-decoration: none;
    font-size: 11px;
    text-transform: none;
    letter-spacing: 0.02em;
    font-family: var(--sans);
  }
  .footer-email-link:hover { color: var(--accent) !important; }

  /* Colonnes de liens */
  .footer-col h5 {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 16px;
    font-weight: 700;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,107,0,0.2);
  }
  .footer-col ul { list-style: none; display: grid; gap: 8px; }
  .footer-col a {
    color: rgba(255,255,255,0.55);
    text-decoration: none;
    font-family: var(--display);
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    transition: color 0.15s, padding-left 0.15s;
    display: block;
  }
  .footer-col a:hover { color: #fff; padding-left: 6px; }
  .footer-col .footer-see-all {
    color: var(--accent);
    font-size: 11px;
    font-family: var(--mono);
    letter-spacing: 0.06em;
    margin-top: 4px;
    padding-left: 0 !important;
  }
  .footer-col .footer-see-all:hover { color: #fff; padding-left: 0 !important; }

  /* ============ CERTIFICATIONS BAR ============ */
  .footer-certs-bar {
    display: flex;
    align-items: center;
    gap: 0;
    padding: 28px 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    flex-wrap: wrap;
  }
  .footer-cert-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 24px 10px 0;
    margin-right: 24px;
    border-right: 1px solid rgba(255,255,255,0.08);
  }
  .footer-cert-item:last-of-type { border-right: none; }
  .fci-mark {
    width: 38px; height: 38px;
    border: 1.5px solid rgba(255,107,0,0.5);
    display: grid; place-items: center;
    font-family: var(--mono);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--accent);
    flex-shrink: 0;
  }
  .fci-label {
    font-family: var(--mono);
    font-size: 9px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
    line-height: 1.5;
  }
  .footer-cert-item--cta { border-right: none; margin-left: auto; padding-right: 0; }
  .fci-link {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.3);
    text-decoration: none;
    transition: color 0.15s;
  }
  .fci-link:hover { color: var(--accent); }
  @media (max-width: 900px) {
    .footer-certs-bar { gap: 16px; }
    .footer-cert-item { border-right: none; margin-right: 0; padding-right: 16px; }
    .footer-cert-item--cta { margin-left: 0; }
  }

  /* ============ FOOTER GIANT TEXT ============ */
  .footer-giant {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(60px, 14vw, 220px);
    line-height: 0.85;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    padding: 24px 0 0;
    text-align: left;
    overflow: hidden;
    white-space: nowrap;
    opacity: 0.55;
  }
  .footer-giant .accent { color: var(--accent); }
  .footer-giant .outline {
    -webkit-text-stroke: 1.5px rgba(255,255,255,0.3);
    color: transparent;
  }

  /* ============ FOOTER BOTTOM ============ */
  .footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 18px 0 28px;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.25);
    flex-wrap: wrap;
    gap: 12px;
    border-top: 1px solid rgba(255,255,255,0.06);
  }
  .footer-bottom-links { display: flex; gap: 20px; flex-wrap: wrap; }
  .footer-bottom a {
    color: rgba(255,255,255,0.25);
    text-decoration: none;
    transition: color 0.15s;
  }
  .footer-bottom a:hover { color: rgba(255,255,255,0.65); }

  /* ============ TWEAKS PANEL ============ */
  .tweaks-panel {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background: var(--bg-3);
    border: 1px solid var(--accent);
    padding: 20px;
    z-index: 100;
    width: 280px;
    box-shadow: 0 20px 40px -15px rgba(0,0,0,0.6);
    display: none;
    color: var(--ink);
  }
  .tweaks-panel::before {
    content: 'TWEAKS.CFG';
    position: absolute;
    top: -1px; right: 16px;
    background: var(--accent);
    color: #0f0f10;
    padding: 3px 10px;
    font-family: var(--mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
  }
  .tweaks-panel.active { display: block; }
  .tweaks-panel h4 {
    font-family: var(--display);
    font-weight: 700;
    font-size: 16px;
    text-transform: uppercase;
    margin-bottom: 14px;
    margin-top: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .tweaks-panel .close-tw {
    background: none; border: none; font-size: 22px; cursor: pointer; line-height: 1; color: var(--ink);
  }
  .tw-field { margin-bottom: 12px; }
  .tw-field label {
    display: block;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 6px;
  }
  .tw-field select, .tw-field input[type="color"] {
    width: 100%;
    padding: 8px;
    border: 1px solid var(--rule-strong);
    background: var(--bg-2);
    color: var(--ink);
    font-family: var(--sans);
    font-size: 13px;
  }
  .tw-field input[type="color"] { height: 40px; padding: 4px; cursor: pointer; }
  .tw-toggle { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--ink-2); }

/* ================================================================== */
/* SINGLE VILLE — breadcrumb, intro, services, voisines              */
/* ================================================================== */

/* Breadcrumb */
.ville-breadcrumb {
  background: var(--bg-2);
  border-bottom: 1px solid var(--rule);
}
.ville-breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 8px;
  list-style: none;
  padding: 13px 0;
  font-size: 13px;
  color: var(--muted);
  flex-wrap: wrap;
}
.ville-breadcrumb a { color: var(--ink-2); text-decoration: none; }
.ville-breadcrumb a:hover { color: var(--accent); }
.ville-breadcrumb [aria-current="page"] { color: var(--ink); font-weight: 600; }

/* Intro locale */
.ville-intro { padding: 80px 0; }
.ville-intro-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 60px;
  align-items: start;
}
.ville-intro-text .serial { display: block; margin-bottom: 16px; }
.ville-intro h2 {
  font-family: var(--display);
  font-size: clamp(30px, 4vw, 50px);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.05;
  margin-bottom: 24px;
}
.ville-intro h2 .accent { color: var(--accent); }
.ville-intro-lead {
  font-size: 17px;
  line-height: 1.7;
  font-weight: 500;
  margin-bottom: 16px;
}
.ville-intro-body {
  color: var(--ink-2);
  line-height: 1.75;
  margin-bottom: 32px;
}
.ville-intro-trust {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
}
.vit-item { display: flex; flex-direction: column; gap: 4px; }
.vit-num {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
}
.vit-label {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

/* CTA card sticky */
.ville-intro-cta-card {
  background: var(--ink);
  color: #fff;
  padding: 28px;
  position: sticky;
  top: 88px;
}
.vicc-label {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.4);
  margin-bottom: 16px;
  display: block;
}
.vicc-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 15px;
  margin-bottom: 8px;
}
.dot-green {
  width: 8px; height: 8px;
  background: var(--ok);
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(74,222,128,0.25);
}
.vicc-delay {
  color: rgba(255,255,255,0.55);
  font-size: 14px;
  margin-bottom: 24px;
}
.vicc-btn {
  display: block;
  background: var(--accent);
  color: #0f0f10;
  padding: 14px 20px;
  font-family: var(--display);
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
  text-align: center;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
  transition: background 0.15s;
}
.vicc-btn:hover { background: var(--accent-2); color: #fff; }
.vicc-phone {
  display: block;
  text-align: center;
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  font-family: var(--mono);
  font-size: 13px;
  padding: 8px 0;
}
.vicc-phone:hover { color: #fff; }

/* Services ville */
.ville-services { padding: 80px 0; background: var(--bg-2); }
.ville-section-head { margin-bottom: 48px; }
.ville-section-head h2 {
  font-family: var(--display);
  font-size: clamp(26px, 3.5vw, 42px);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.08;
  margin-top: 12px;
}
.ville-section-head h2 .accent { color: var(--accent); }
.ville-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}
.vs-card {
  background: var(--bg);
  padding: 28px;
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  gap: 12px;
  border-left: 3px solid transparent;
  transition: border-color 0.15s, background 0.15s;
}
.vs-card:hover { border-left-color: var(--accent); background: var(--panel); }
.vs-card--urgent { background: var(--ink); color: #fff; }
.vs-card--urgent:hover { background: #1a1a1e; border-left-color: var(--accent); }
.vs-icon { font-size: 28px; line-height: 1; }
.vs-card h3 {
  font-family: var(--display);
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin: 0;
}
.vs-card p { font-size: 13px; color: var(--ink-2); line-height: 1.65; margin: 0; flex: 1; }
.vs-card--urgent p { color: rgba(255,255,255,0.65); }
.vs-link {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: auto;
}

/* Villes voisines */
.ville-voisines { padding: 80px 0; }
.ville-section-head--center { text-align: center; }
.vv-desc { color: var(--muted); font-size: 15px; margin-top: 12px; }
.vv-desc a { color: var(--ink); text-decoration: underline; }
.ville-voisines-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
  gap: 2px;
  margin-top: 40px;
}
.vv-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 20px;
  background: var(--bg-2);
  text-decoration: none;
  color: var(--ink-2);
  border-left: 3px solid transparent;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.vv-card:hover { background: var(--ink); color: #fff; border-left-color: var(--accent); }
.vv-arrow { font-size: 13px; color: var(--rule-strong); transition: color 0.15s; }
.vv-card:hover .vv-arrow { color: var(--accent); }
.vv-name { font-weight: 600; font-size: 15px; }
.vv-label {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}
.vv-card:hover .vv-label { color: rgba(255,255,255,0.4); }

/* Responsive ville */
@media (max-width: 960px) {
  .ville-intro-grid { grid-template-columns: 1fr; gap: 40px; }
  .ville-intro-cta-card { position: static; }
  .ville-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 580px) {
  .ville-intro, .ville-services, .ville-voisines { padding: 56px 0; }
  .ville-services-grid { grid-template-columns: 1fr; }
  .ville-intro-trust { gap: 20px; }
}

/* ================================================================== */
/* HUB ZONES D'INTERVENTION                                           */
/* ================================================================== */

/* Hero */
.hub-hero {
  background: var(--ink);
  color: #fff;
  padding: 120px 0 80px;
  position: relative;
  overflow: hidden;
}
.hub-hero::before {
  content: 'ZONES';
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--display);
  font-size: clamp(100px, 18vw, 220px);
  font-weight: 700;
  color: rgba(255,255,255,0.03);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
}
.hub-hero-inner { max-width: 760px; }
.hub-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,107,0,0.15);
  border: 1px solid rgba(255,107,0,0.35);
  color: var(--accent);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 5px 14px;
  margin-bottom: 28px;
}
.hub-badge .dot {
  width: 7px; height: 7px;
  background: var(--accent);
  border-radius: 50%;
  animation: pulse-dot 1.6s ease-in-out infinite;
}
.hub-hero h1 {
  font-family: var(--display);
  font-size: clamp(36px, 6vw, 64px);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.05;
  margin-bottom: 20px;
}
.hub-hero h1 .accent { color: var(--accent); }
.hub-lead {
  font-size: 17px;
  color: rgba(255,255,255,0.72);
  line-height: 1.65;
  max-width: 620px;
  margin-bottom: 44px;
}
.hub-stats {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}
.hub-stat { display: flex; flex-direction: column; gap: 4px; }
.hub-stat-n {
  font-family: var(--display);
  font-size: 30px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
}
.hub-stat-l {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}

/* Zones grid */
.hub-zones {
  padding: 80px 0 60px;
  background: var(--bg);
}
.hub-zone {
  margin-bottom: 60px;
  border-top: 2px solid var(--ink);
  padding-top: 32px;
}
.hub-zone-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.hub-zone-icon {
  font-size: 24px;
  line-height: 1;
}
.hub-zone-head h2 {
  font-family: var(--display);
  font-size: 20px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0;
  flex: 1;
}
.hub-zone-count {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted);
  background: var(--bg-2);
  padding: 3px 10px;
  letter-spacing: 0.06em;
}

/* Grille des villes */
.hub-ville-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 2px;
  list-style: none;
}
.hub-ville-item a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  background: var(--bg-2);
  text-decoration: none;
  color: var(--ink-2);
  font-size: 14px;
  font-weight: 500;
  transition: background 0.15s, color 0.15s;
  border-left: 3px solid transparent;
}
.hub-ville-item a:hover {
  background: var(--ink);
  color: #fff;
  border-left-color: var(--accent);
}
.hub-ville-item a:hover .hvi-arrow { color: var(--accent); }
.hvi-arrow {
  font-size: 13px;
  color: var(--rule-strong);
  transition: color 0.15s, transform 0.15s;
  flex-shrink: 0;
}
.hub-ville-item a:hover .hvi-arrow { transform: translateX(3px); }
.hvi-name { flex: 1; }

/* CTA bande finale */
.hub-cta {
  background: var(--accent);
  padding: 60px 0;
}
.hub-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.hub-cta h2 {
  font-family: var(--display);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 700;
  text-transform: uppercase;
  color: #0f0f10;
  margin-bottom: 8px;
}
.hub-cta p {
  color: rgba(0,0,0,0.6);
  font-size: 15px;
}
.hub-cta-btns {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  flex-shrink: 0;
}
.hub-cta .btn-primary {
  background: #0f0f10;
  color: #fff;
  padding: 14px 28px;
  font-family: var(--display);
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  text-decoration: none;
  letter-spacing: 0.05em;
  transition: background 0.15s;
}
.hub-cta .btn-primary:hover { background: #1f1f22; }
.hub-cta .btn-phone {
  background: transparent;
  color: #0f0f10;
  border: 2px solid rgba(0,0,0,0.35);
  padding: 14px 28px;
  font-family: var(--display);
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.05em;
  transition: border-color 0.15s;
}
.hub-cta .btn-phone:hover { border-color: #0f0f10; }

/* Responsive */
@media (max-width: 640px) {
  .hub-hero { padding: 100px 0 60px; }
  .hub-stats { gap: 24px; }
  .hub-ville-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
  .hub-cta-inner { flex-direction: column; align-items: flex-start; }
}


/* ════════════════════════════════════════════════════════════════════════
   SINGLE-ZONE_SERVICE — pages service × ville
   ════════════════════════════════════════════════════════════════════════ */

/* Hero urgence variant */
.hero--urgence .hero-meta { border-color: rgba(220,38,38,0.4); }
.hero--urgence .live-tag { color: #ef4444; }
.hero--urgence .stencil { color: #ef4444; }

/* Intro section */
.zs-intro { padding: 80px 0; background: #fff; }
.zs-intro-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 60px;
  align-items: start;
}
.zs-intro-text h2 {
  font-family: var(--display);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: #0f0f10;
  margin: 12px 0 20px;
}
.zs-intro-text p {
  font-size: 16px;
  line-height: 1.7;
  color: #444;
  max-width: 560px;
}
.zs-checklist {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.zs-checklist li {
  font-size: 14px;
  color: #333;
  display: flex;
  gap: 8px;
  align-items: baseline;
}

/* Aside card */
.vicc-card {
  background: #0f0f10;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 4px;
  overflow: hidden;
}
.vicc-header {
  padding: 10px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.vicc-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.vicc-service {
  font-family: var(--display);
  font-size: 20px;
  font-weight: 800;
  text-transform: uppercase;
  color: #fff;
  letter-spacing: 0.04em;
}
.vicc-city {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.5);
}
.vicc-delay {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--accent);
  letter-spacing: 0.06em;
}
.vicc-tel {
  display: block;
  padding: 12px 16px;
  background: rgba(255,255,255,0.06);
  color: #fff;
  font-family: var(--display);
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  letter-spacing: 0.04em;
  border: 1px solid rgba(255,255,255,0.12);
  transition: background 0.15s;
}
.vicc-tel:hover { background: rgba(255,255,255,0.1); }
.vicc-cta {
  display: block;
  padding: 14px 16px;
  background: var(--accent);
  color: #0f0f10;
  font-family: var(--display);
  font-size: 14px;
  font-weight: 800;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  transition: opacity 0.15s;
}
.vicc-cta:hover { opacity: 0.88; }
.vicc-note {
  font-family: var(--mono);
  font-size: 10px;
  color: rgba(255,255,255,0.35);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Grille services croisés */
.zs-cross-services { padding: 80px 0; background: var(--bg-2, #f8f8f8); }
.zs-services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 40px;
}
.zs-service-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 20px 16px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 4px;
  text-decoration: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  position: relative;
}
.zs-service-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.zs-service-card--urgent { border-left: 3px solid #ef4444; }
.zs-sc-icon { font-size: 24px; }
.zs-sc-label {
  font-family: var(--display);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #0f0f10;
}
.zs-sc-city {
  font-size: 12px;
  color: #666;
}
.zs-sc-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: #ef4444;
  color: #fff;
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 6px;
  border-radius: 2px;
}

/* Responsive zone_service */
@media (max-width: 900px) {
  .zs-intro-grid { grid-template-columns: 1fr; }
  .zs-intro-aside { display: none; }
}
@media (max-width: 640px) {
  .zs-services-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ════════════════════════════════════════════════════════════════════
   ENTREPRISES — fiche + archive + hub
   ════════════════════════════════════════════════════════════════════ */

.ent-data { display: grid; gap: 8px; padding: 16px; }
.ent-data dt {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.5);
  margin: 0;
}
.ent-data dd {
  font-family: var(--display);
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 8px;
}

/* Hub villes/secteurs */
.hub-villes-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
  margin-top: 32px;
}
.hub-ville-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 4px;
  text-decoration: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.hub-ville-item:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}
.hub-vi-name {
  font-family: var(--display);
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #0f0f10;
}
.hub-vi-count {
  font-family: var(--mono);
  font-size: 11px;
  color: #666;
  letter-spacing: 0.04em;
}

/* Liste entreprises */
.hub-entreprises-list { padding: 60px 0; }
.ent-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  margin-top: 32px;
}
.ent-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 4px;
  text-decoration: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.ent-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 14px rgba(0,0,0,0.05);
}
.ent-card-name {
  font-family: var(--display);
  font-size: 14px;
  font-weight: 700;
  color: #0f0f10;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.ent-card-naf {
  font-size: 12px;
  color: #555;
  line-height: 1.3;
}
.ent-card-meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: 10px;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 4px;
}
.ent-pagination {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}
.ent-pagination .nav-links {
  display: flex;
  gap: 6px;
}
.ent-pagination a, .ent-pagination span {
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 12px;
  border: 1px solid rgba(0,0,0,0.12);
  text-decoration: none;
  color: #0f0f10;
  border-radius: 3px;
}
.ent-pagination .current {
  background: var(--accent);
  border-color: var(--accent);
  color: #0f0f10;
  font-weight: 700;
}
