/* ══════════════════════════════════════════════════
   SARREINFO — Dark Cyberpunk · v3 High Contrast + FX
   ══════════════════════════════════════════════════ */
/* Fonts locales : voir /fonts/fonts.css (RGPD) */

:root {
  --bg:        #030712;
  --bg2:       #060f20;
  --bg3:       #0c1a35;
  --card:      rgba(12,24,48,0.92);
  --card-solid: #0c1830;
  --cyan:      #00e5ff;
  --cyan-dim:  rgba(0,229,255,0.1);
  --cyan-med:  rgba(0,229,255,0.2);
  --green:     #00ff88;
  --green-dim: rgba(0,255,136,0.08);
  --purple:    #a78bfa;
  --purple-dim:rgba(167,139,250,0.1);
  --orange:    #ff6b00;
  --orange-dim:rgba(255,107,0,0.1);
  --text:      #f1f5f9;        /* light — was too dark */
  --text-sub:  #cbd5e1;        /* body paragraphs */
  --text-muted:#8ba4c4;        /* captions, secondary */
  --text-faint:#3d5a80;        /* decorative only */
  --border:    rgba(0,229,255,0.12);
  --border-hover:rgba(0,229,255,0.4);
  --glow-cyan: 0 0 20px rgba(0,229,255,0.45),0 0 60px rgba(0,229,255,0.15);
  --glow-green:0 0 20px rgba(0,255,136,0.45),0 0 60px rgba(0,255,136,0.1);
  --glow-orange:0 0 24px rgba(255,107,0,0.55),0 0 70px rgba(255,107,0,0.2);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.6;
}

/* Global link reset — override browser default blue */
a { color:var(--cyan); text-decoration:none; }
a:hover { color:#fff; }

/* Dot grid */
body::before {
  content:''; position:fixed; inset:0;
  background-image:radial-gradient(rgba(0,229,255,0.06) 1px, transparent 1px);
  background-size:30px 30px;
  z-index:-3; pointer-events:none;
  animation:gridDrift 60s linear infinite;
}
@keyframes gridDrift {
  from { background-position:0 0; }
  to   { background-position:30px 30px; }
}

h1,h2,h3,h4,h5 { font-family:'Space Grotesk',sans-serif; line-height:1.15; }
p { color:var(--text-sub); }

@media(prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
}

/* ── Scrollbar ─────────────────────────────────── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--cyan); border-radius:3px; }

/* ══════════════════════════════════════════════════
   CYBER BAR
   ══════════════════════════════════════════════════ */
.cyber-bar {
  background:linear-gradient(90deg,#021a0c,#043318,#021a0c);
  background-size:200% 100%;
  animation:cyberBarFlow 6s ease infinite;
  border-bottom:1px solid rgba(0,255,136,0.25);
  color:#86efac; font-size:.78rem; font-family:'JetBrains Mono',monospace;
  padding:.45rem 1.5rem; text-align:center;
  display:flex; align-items:center; justify-content:center; gap:.75rem;
  position:relative; z-index:60; letter-spacing:.04em; overflow:hidden;
}
@keyframes cyberBarFlow { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }
.cyber-dot {
  width:8px; height:8px; background:var(--green);
  border-radius:50%; flex-shrink:0;
  box-shadow:0 0 8px rgba(0,255,136,1), 0 0 20px rgba(0,255,136,0.6);
  animation:cyberPulse 2s ease-in-out infinite;
}
@keyframes cyberPulse {
  0%,100% { transform:scale(1); opacity:1; box-shadow:0 0 8px rgba(0,255,136,1),0 0 20px rgba(0,255,136,0.6); }
  50%      { transform:scale(0.7); opacity:.5; box-shadow:none; }
}
.cyber-bar a { color:var(--green); font-weight:700; text-decoration:none; transition:color 150ms; }
.cyber-bar a:hover { color:#fff; text-shadow:0 0 10px rgba(0,255,136,0.8); }

/* ══════════════════════════════════════════════════
   NAVBAR
   ══════════════════════════════════════════════════ */
.navbar {
  position:sticky; top:0; z-index:50;
  background:rgba(3,7,18,0.88);
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  border-bottom:1px solid rgba(0,229,255,0.1);
  transition:background 300ms, box-shadow 300ms;
}
.navbar.scrolled { background:rgba(3,7,18,0.97); box-shadow:0 4px 40px rgba(0,0,0,.6); }
.nav-inner {
  max-width:1360px; margin:0 auto; padding:0 1.5rem;
  height:72px; display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  display:flex; align-items:center; gap:.85rem;
  text-decoration:none; flex-shrink:0;
}
.nav-logo img {
  height:52px; width:auto; /* PLUS GRAND */
  filter:brightness(1.15) drop-shadow(0 0 12px rgba(0,229,255,0.5));
  transition:filter 200ms, transform 200ms;
}
.nav-logo:hover img { filter:brightness(1.3) drop-shadow(0 0 18px rgba(0,229,255,0.8)); transform:scale(1.04); }
.nav-logo-fallback {
  font-family:'Space Grotesk',sans-serif; font-size:1.5rem; font-weight:800;
  color:#fff; letter-spacing:-.03em;
}
.nav-logo-fallback span { color:var(--cyan); text-shadow:var(--glow-cyan); }

.nav-links { display:flex; align-items:center; gap:.1rem; list-style:none; }
.nav-links a, .btn-client, .btn-rdv { white-space:nowrap; }
.nav-links a {
  color:rgba(255,255,255,.65); text-decoration:none;
  font-size:.875rem; font-weight:500; padding:.45rem .9rem;
  border-radius:8px; transition:color 180ms, background 180ms;
  position:relative; letter-spacing:.01em;
}
.nav-links a:hover { color:#fff; background:rgba(0,229,255,.07); }
.nav-links a.active { color:var(--cyan); text-shadow:0 0 12px rgba(0,229,255,.4); }
.nav-links a.active::after {
  content:''; position:absolute; bottom:-4px; left:50%; transform:translateX(-50%);
  width:22px; height:2px; background:var(--cyan);
  border-radius:1px; box-shadow:var(--glow-cyan);
}
.btn-client {
  display:inline-flex !important; align-items:center; gap:.4rem;
  background:linear-gradient(135deg,#ff6b00,#e05500) !important;
  color:#fff !important; padding:.5rem 1.1rem !important;
  border-radius:8px !important; font-weight:700 !important;
  font-size:.82rem !important; letter-spacing:.02em;
  box-shadow:0 0 20px rgba(255,107,0,.4) !important;
  transition:box-shadow 200ms, transform 130ms !important;
  position:relative; overflow:hidden;
}
.btn-client::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  border-radius:8px;
}
.btn-client:hover {
  box-shadow:0 0 35px rgba(255,107,0,.65) !important;
  transform:translateY(-1px) !important;
}

.nav-hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:.5rem; border:none; background:transparent;
}
.nav-hamburger span {
  display:block; width:22px; height:2px; background:#fff;
  border-radius:1px; transition:transform 300ms,opacity 200ms;
}
.mobile-nav {
  display:none; background:rgba(6,15,32,.98);
  border-top:1px solid var(--border); padding:1rem 1.5rem 1.5rem;
  backdrop-filter:blur(20px);
}
.mobile-nav.open { display:block; animation:slideDown 200ms ease; }
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:none} }
.mobile-nav a {
  display:block; color:var(--text-sub); text-decoration:none;
  padding:.7rem 0; font-size:.9rem; font-weight:500;
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:color 180ms, padding-left 180ms;
}
.mobile-nav a:hover,.mobile-nav a.active { color:var(--cyan); padding-left:.5rem; }
.mobile-nav .btn-client { margin-top:.75rem; border-bottom:none !important; display:inline-flex !important; padding-left:1.1rem !important; }

/* Bouton Ticket (nav) — pilule fantôme, complète les 2 pilules pleines */
.btn-ticket {
  display:inline-flex !important; align-items:center; gap:.4rem;
  background:rgba(0,229,255,.06) !important;
  color:var(--cyan) !important; padding:.5rem 1.05rem !important;
  border:1px solid rgba(0,229,255,.3) !important;
  border-radius:999px !important; font-weight:700 !important;
  font-size:.82rem !important; letter-spacing:.02em; white-space:nowrap;
  transition:background 250ms, border-color 250ms, box-shadow 450ms var(--ease-spring, ease), transform 450ms var(--ease-spring, ease) !important;
}
.btn-ticket:hover {
  background:rgba(0,229,255,.12) !important;
  border-color:rgba(0,229,255,.6) !important;
  box-shadow:0 0 18px rgba(0,229,255,.25);
  transform:translateY(-1px);
}
.btn-ticket:active { transform:scale(.96); }
.btn-ticket svg { transition:transform 450ms var(--ease-spring, ease); }
.btn-ticket:hover svg { transform:rotate(-8deg) scale(1.1); }
.mobile-nav .btn-ticket { border-bottom:1px solid rgba(0,229,255,.3) !important; display:inline-flex !important; margin-top:.5rem; padding-left:1.05rem !important; }

/* Bouton Rendez-vous (nav) */
.btn-rdv {
  display:inline-flex !important; align-items:center; gap:.4rem;
  background:linear-gradient(135deg,#00e5ff,#00a8cc) !important;
  color:#020d24 !important; padding:.5rem 1.1rem !important;
  border-radius:8px !important; font-weight:700 !important;
  font-size:.82rem !important; letter-spacing:.02em;
  box-shadow:0 0 20px rgba(0,229,255,.35) !important;
  transition:box-shadow 200ms, transform 130ms !important;
}
.btn-rdv:hover { box-shadow:0 0 30px rgba(0,229,255,.55) !important; transform:translateY(-1px); }
.mobile-nav .btn-rdv { border-bottom:none !important; display:inline-flex !important; padding-left:1.1rem !important; }

/* ══════════════════════════════════════════════════
   SCROLL REVEAL — enhanced
   ══════════════════════════════════════════════════ */
.reveal {
  opacity:0; transform:translateY(40px);
  transition:opacity 800ms cubic-bezier(.22,1,.36,1), transform 800ms cubic-bezier(.22,1,.36,1),
             filter 600ms ease;
  filter:blur(4px);
}
.reveal.visible { opacity:1; transform:none; filter:blur(0); }

.reveal-left {
  opacity:0; transform:translateX(-50px);
  transition:opacity 800ms cubic-bezier(.22,1,.36,1), transform 800ms cubic-bezier(.22,1,.36,1),
             filter 600ms ease;
  filter:blur(4px);
}
.reveal-left.visible { opacity:1; transform:none; filter:blur(0); }

.reveal-right {
  opacity:0; transform:translateX(50px);
  transition:opacity 800ms cubic-bezier(.22,1,.36,1), transform 800ms cubic-bezier(.22,1,.36,1),
             filter 600ms ease;
  filter:blur(4px);
}
.reveal-right.visible { opacity:1; transform:none; filter:blur(0); }

.reveal-scale {
  opacity:0; transform:scale(0.88);
  transition:opacity 700ms cubic-bezier(.22,1,.36,1), transform 700ms cubic-bezier(.22,1,.36,1);
}
.reveal-scale.visible { opacity:1; transform:none; }

.stagger-1{transition-delay:80ms}  .stagger-2{transition-delay:160ms}
.stagger-3{transition-delay:240ms} .stagger-4{transition-delay:320ms}
.stagger-5{transition-delay:400ms} .stagger-6{transition-delay:480ms}

/* ══════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:'Space Grotesk',sans-serif; font-weight:700;
  font-size:.9rem; padding:.85rem 1.85rem; border-radius:10px;
  border:none; cursor:pointer; text-decoration:none;
  transition:transform 130ms, box-shadow 200ms;
  letter-spacing:.02em; position:relative; overflow:hidden;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);
  pointer-events:none;
}
.btn:active { transform:scale(.97); }

.btn-cyan {
  background:var(--cyan); color:#030712;
  box-shadow:0 4px 24px rgba(0,229,255,.45);
}
.btn-cyan:hover { transform:translateY(-3px); box-shadow:0 8px 40px rgba(0,229,255,.7); }

.btn-green {
  background:var(--green); color:#030712;
  box-shadow:0 4px 24px rgba(0,255,136,.45);
}
.btn-green:hover { transform:translateY(-3px); box-shadow:0 8px 40px rgba(0,255,136,.7); }

.btn-orange {
  background:linear-gradient(135deg,#ff6b00,#e05500); color:#fff;
  box-shadow:0 4px 24px rgba(255,107,0,.45);
}
.btn-orange:hover { transform:translateY(-3px); box-shadow:0 8px 40px rgba(255,107,0,.7); }

.btn-ghost {
  background:transparent; color:var(--cyan);
  border:1.5px solid rgba(0,229,255,.3);
}
.btn-ghost:hover { border-color:var(--cyan); background:var(--cyan-dim); transform:translateY(-3px); box-shadow:0 0 20px rgba(0,229,255,.2); }

.btn-dark {
  background:rgba(255,255,255,.07); color:#fff;
  border:1.5px solid rgba(255,255,255,.15);
}
.btn-dark:hover { background:rgba(255,255,255,.12); transform:translateY(-3px); }

/* ══════════════════════════════════════════════════
   NEON TEXT + GRADIENTS
   ══════════════════════════════════════════════════ */
.neon-cyan   { color:var(--cyan);   text-shadow:var(--glow-cyan); }
.neon-green  { color:var(--green);  text-shadow:var(--glow-green); }
.neon-orange { color:var(--orange); text-shadow:var(--glow-orange); }

.text-gradient-cyber {
  background:linear-gradient(135deg,#00e5ff 0%,#00ff88 50%,#a78bfa 100%);
  background-size:200% 200%;
  animation:gradientShift 4s ease infinite;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
@keyframes gradientShift { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }

.text-shimmer {
  background:linear-gradient(90deg,#fff 0%,var(--cyan) 40%,#fff 60%,var(--cyan) 100%);
  background-size:200% 100%;
  animation:shimmerMove 3s linear infinite;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
@keyframes shimmerMove { from{background-position:200% center} to{background-position:-200% center} }

.border-glow-anim {
  position:relative;
}
.border-glow-anim::before {
  content:''; position:absolute; inset:-1px; border-radius:inherit;
  background:linear-gradient(135deg,var(--cyan),var(--purple),var(--green),var(--cyan));
  background-size:300% 300%;
  animation:borderRotate 3s linear infinite;
  z-index:-1; padding:1px;
}
@keyframes borderRotate { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }

/* ══════════════════════════════════════════════════
   SECTION HEADERS
   ══════════════════════════════════════════════════ */
.section-tag {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:'JetBrains Mono',monospace; font-size:.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.14em; color:var(--cyan);
  margin-bottom:1rem;
}
.section-tag::before { content:'//'; color:rgba(0,229,255,.35); margin-right:.25rem; }
.section-tag.tag-green  { color:var(--green); }
.section-tag.tag-green::before { color:rgba(0,255,136,.35); }
.section-tag.tag-orange { color:var(--orange); }
.section-tag.tag-orange::before { color:rgba(255,107,0,.35); }
.section-tag.tag-purple { color:var(--purple); }
.section-tag.tag-purple::before { color:rgba(167,139,250,.35); }
.section-tag.tag-red    { color:#f87171; }
.section-tag.tag-red::before { color:rgba(248,113,113,.35); }
.section-title {
  font-size:clamp(1.9rem,4vw,3.1rem); font-weight:800; color:#fff;
  margin-bottom:1.1rem; line-height:1.1; letter-spacing:-.03em;
}
.section-sub { color:var(--text-sub); max-width:580px; font-size:1rem; line-height:1.75; text-align:center; margin-left:auto; margin-right:auto; }

/* ══════════════════════════════════════════════════
   CARDS — 3D TILT + GLOW
   ══════════════════════════════════════════════════ */
.card {
  background:var(--card);
  border:1px solid rgba(0,229,255,.12);
  border-radius:18px; padding:2rem;
  transition:border-color 250ms, box-shadow 250ms;
  cursor:default; position:relative; overflow:hidden;
  transform-style:preserve-3d;
  will-change:transform;
}
.card::before {
  content:''; position:absolute; inset:0; border-radius:18px;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(0,229,255,.08) 0%, transparent 55%);
  opacity:0; transition:opacity 300ms; pointer-events:none;
}
.card:hover::before { opacity:1; }
.card:hover {
  border-color:rgba(0,229,255,.35);
  box-shadow:0 25px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(0,229,255,.15), inset 0 1px 0 rgba(255,255,255,.05);
}

.card-icon {
  width:52px; height:52px; border-radius:14px;
  display:flex; align-items:center; justify-content:center; margin-bottom:1.25rem;
}
.card-icon svg { width:26px; height:26px; }
.icon-cyan   { background:rgba(0,229,255,.1);  border:1px solid rgba(0,229,255,.2); }
.icon-cyan   svg { color:var(--cyan); }
.icon-green  { background:rgba(0,255,136,.08); border:1px solid rgba(0,255,136,.2); }
.icon-green  svg { color:var(--green); }
.icon-orange { background:rgba(255,107,0,.1);  border:1px solid rgba(255,107,0,.2); }
.icon-orange svg { color:var(--orange); }
.icon-purple { background:rgba(167,139,250,.1);border:1px solid rgba(167,139,250,.2); }
.icon-purple svg { color:var(--purple); }

/* ══════════════════════════════════════════════════
   ANIMATED NEON BORDER CARD
   ══════════════════════════════════════════════════ */
.card-neon {
  background:var(--card);
  border-radius:18px; padding:2rem;
  position:relative; overflow:hidden;
}
.card-neon::before {
  content:''; position:absolute; inset:0; border-radius:18px;
  padding:1px;
  background:linear-gradient(135deg,rgba(0,229,255,.3),rgba(0,229,255,.05) 40%,rgba(167,139,250,.2) 60%,rgba(0,229,255,.3));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  pointer-events:none;
}

/* ══════════════════════════════════════════════════
   PAGE HERO (sub-pages)
   ══════════════════════════════════════════════════ */
.page-hero {
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  padding:5.5rem 1.5rem 4.5rem;
  text-align:center; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 25% 50%, rgba(0,229,255,.07) 0%,transparent 55%),
             radial-gradient(ellipse at 80% 20%, rgba(167,139,250,.07) 0%,transparent 45%);
}
/* Animated scan line */
.page-hero::after {
  content:''; position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,229,255,.4),transparent);
  animation:scanLine 4s ease-in-out infinite;
  top:0;
}
@keyframes scanLine { 0%{top:0;opacity:0} 10%{opacity:1} 90%{opacity:1} 100%{top:100%;opacity:0} }
.page-hero-inner { position:relative; z-index:1; max-width:760px; margin:0 auto; }
.breadcrumb {
  display:flex; align-items:center; justify-content:center;
  gap:.5rem; font-size:.75rem; font-family:'JetBrains Mono',monospace;
  color:var(--text-faint); margin-bottom:2rem; letter-spacing:.04em;
}
.breadcrumb a { color:var(--text-faint); text-decoration:none; transition:color 150ms; }
.breadcrumb a:hover { color:var(--cyan); }
.breadcrumb span { color:var(--cyan); font-weight:700; }
.breadcrumb svg { opacity:.4; }
.page-hero .section-title { color:#fff; }

/* ══════════════════════════════════════════════════
   FLOATING PARTICLES (CSS only extra)
   ══════════════════════════════════════════════════ */
.float-orb {
  position:absolute; border-radius:50%; pointer-events:none; filter:blur(60px);
  animation:floatOrb var(--d,8s) ease-in-out infinite alternate;
}
@keyframes floatOrb {
  from { transform:translate(0,0) scale(1); }
  to   { transform:translate(var(--tx,30px),var(--ty,-40px)) scale(1.1); }
}

/* ══════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════ */
.footer {
  background:var(--bg2); border-top:1px solid var(--border);
  padding:5.5rem 1.5rem 2rem;
}
.footer-inner { max-width:1360px; margin:0 auto; }
.footer-grid {
  display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:3.75rem; margin-bottom:3.5rem;
}
.footer-logo { margin-bottom:1.25rem; display:flex; align-items:center; }
.footer-logo img { height:46px; filter:brightness(1.1) drop-shadow(0 0 10px rgba(0,229,255,.4)); }
.footer-logo-text {
  font-family:'Space Grotesk',sans-serif; font-size:1.35rem; font-weight:800;
  color:#fff; letter-spacing:-.03em;
}
.footer-logo-text span { color:var(--cyan); text-shadow:var(--glow-cyan); }
.footer-desc { font-size:.875rem; line-height:1.75; color:var(--text-sub); max-width:290px; }
.footer h4 {
  font-family:'JetBrains Mono',monospace; color:var(--cyan); font-size:.64rem;
  font-weight:700; text-transform:uppercase; letter-spacing:.2em; margin-bottom:1.4rem;
  display:inline-flex; align-items:center;
  background:rgba(0,229,255,.06); border:1px solid rgba(0,229,255,.14);
  border-radius:999px; padding:.3rem .8rem;
}
.footer ul { list-style:none; }
.footer ul li { margin-bottom:.7rem; }
.footer ul a {
  color:var(--text-sub); text-decoration:none; font-size:.875rem;
  transition:color 180ms, padding-left 180ms;
  display:inline-flex; align-items:center;
}
.footer ul a:hover { color:var(--cyan); padding-left:.25rem; }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.05); padding-top:1.5rem; margin-top:1.5rem;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
  font-size:.75rem; font-family:'JetBrains Mono',monospace; color:var(--text-muted);
}
.footer-bottom-links { display:flex; gap:1.5rem; }
.footer-bottom-links a { color:var(--text-muted); text-decoration:none; transition:color 150ms; }
.footer-bottom-links a:hover { color:var(--cyan); }

/* ══════════════════════════════════════════════════
   UTILITY
   ══════════════════════════════════════════════════ */
.container { max-width:1360px; margin:0 auto; padding:0 1.5rem; }
.section { padding:6rem 1.5rem; }
.section-dark { background:var(--bg2); }
.text-center { text-align:center; }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }

.badge-tag {
  display:inline-flex; align-items:center; gap:.4rem;
  font-family:'JetBrains Mono',monospace; font-size:.7rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em; padding:.3rem .8rem;
  border-radius:20px;
}
.tag-cyan   { background:var(--cyan-dim);  color:var(--cyan);   border:1px solid rgba(0,229,255,.2); }
.tag-green  { background:var(--green-dim); color:var(--green);  border:1px solid rgba(0,255,136,.2); }
.tag-orange { background:var(--orange-dim);color:var(--orange); border:1px solid rgba(255,107,0,.2); }
.tag-purple { background:var(--purple-dim);color:var(--purple); border:1px solid rgba(167,139,250,.2); }

.divider-neon {
  height:1px; background:linear-gradient(90deg,transparent,rgba(0,229,255,.35),transparent);
  margin:0;
}

/* ── Scroll to top ─────────────────────────────────────────── */
.scroll-top-btn {
  position:fixed; bottom:5.75rem; right:1.5rem; z-index:9996;
  width:44px; height:44px; border-radius:50%;
  background:rgba(0,229,255,.12); border:1.5px solid rgba(0,229,255,.3);
  color:var(--cyan); display:flex; align-items:center; justify-content:center;
  cursor:pointer; opacity:0; pointer-events:none;
  transform:translateY(12px);
  transition:opacity 250ms, transform 250ms, background 180ms;
  backdrop-filter:blur(8px);
}
.scroll-top-btn.visible { opacity:1; pointer-events:auto; transform:translateY(0); }
.scroll-top-btn:hover { background:rgba(0,229,255,.22); border-color:var(--cyan); }
/* ── Bouton téléphone flottant (mobile) ────────────────────── */
.phone-float {
  display:none;
  position:fixed; bottom:5.5rem; left:1.5rem; z-index:200;
  width:52px; height:52px; border-radius:50%;
  background:var(--orange); color:#fff;
  align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(255,107,0,.5);
  transition:transform 200ms, box-shadow 200ms;
}
.phone-float:hover { color:#fff; transform:scale(1.1); box-shadow:0 8px 36px rgba(255,107,0,.7); }
@media(max-width:768px){
  .phone-float { display:flex; }
}

/* WhatsApp float */
.wa-float {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:200;
  width:56px; height:56px; background:#25d366; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 24px rgba(37,211,102,.45);
  transition:transform 200ms, box-shadow 200ms;
  animation:waPop 3s ease infinite;
}
.wa-float:hover { transform:scale(1.12); box-shadow:0 8px 40px rgba(37,211,102,.7); }
@keyframes waPop {
  0%,90%,100%{transform:scale(1)} 93%{transform:scale(1.08)} 96%{transform:scale(.98)} 98%{transform:scale(1.04)}
}

/* ══════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════ */
@media(max-width:1200px) {
  .footer-grid { grid-template-columns:1fr 1fr; }
  .grid-4 { grid-template-columns:repeat(2,1fr); }
}
/* Le menu complet (9 liens + 2 boutons) ne tient pas sous 1280px → hamburger */
@media(max-width:1280px) {
  .nav-links,.nav-right { display:none; }
  .nav-hamburger { display:flex; }
}
@media(max-width:768px) {
  .section { padding:4rem 1.25rem; }
  .grid-2,.grid-3 { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:2.25rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .grid-4 { grid-template-columns:1fr 1fr; }
}
@media(max-width:480px) { .grid-4 { grid-template-columns:1fr; } }

/* ══════════════════════════════════════════════════
   UTILITIES — v1
   ══════════════════════════════════════════════════ */

/* ── Couleurs texte ─────────────────────────────── */
.text-white  { color:#fff; }
.text-light  { color:var(--text); }          /* #f1f5f9 */
.text-body   { color:var(--text-sub); }      /* #cbd5e1 */
.text-muted  { color:var(--text-muted); }    /* #8ba4c4 — minimum lisible sur fond dark */
.text-faint  { color:#64748b; }              /* décoratif uniquement */
.text-cyan   { color:var(--cyan); }
.text-green  { color:var(--green); }
.text-orange { color:var(--orange); }
.text-purple { color:var(--purple); }

/* ── Typographie ────────────────────────────────── */
.font-mono    { font-family:'JetBrains Mono',monospace; }
.font-grotesk { font-family:'Space Grotesk',sans-serif; }
.text-xs      { font-size:.7rem; }
.text-sm      { font-size:.82rem; }
.text-base    { font-size:.9rem; }
.fw-700       { font-weight:700; }
.fw-800       { font-weight:800; }
.uppercase    { text-transform:uppercase; }
.ls-wide      { letter-spacing:.08em; }
.lh-relaxed   { line-height:1.7; }

/* ── Flex ───────────────────────────────────────── */
.flex           { display:flex; }
.flex-col       { flex-direction:column; }
.flex-wrap      { flex-wrap:wrap; }
.items-center   { align-items:center; }
.items-start    { align-items:flex-start; }
.justify-center { justify-content:center; }
.justify-between{ justify-content:space-between; }
.gap-1          { gap:.5rem; }
.gap-2          { gap:1rem; }
.gap-3          { gap:1.5rem; }
.gap-4          { gap:2.5rem; }
.shrink-0       { flex-shrink:0; }
.flex-1         { flex:1; }

/* ── Espacements ────────────────────────────────── */
.mt-1 { margin-top:.5rem; }
.mt-2 { margin-top:1rem; }
.mt-3 { margin-top:1.5rem; }
.mt-4 { margin-top:2rem; }
.mt-5 { margin-top:2.5rem; }
.mt-6 { margin-top:3rem; }
.mb-1 { margin-bottom:.5rem; }
.mb-2 { margin-bottom:1rem; }
.mb-3 { margin-bottom:1.5rem; }
.mb-4 { margin-bottom:2rem; }
.mb-5 { margin-bottom:2.5rem; }
.mb-6 { margin-bottom:3rem; }
.ml-auto { margin-left:auto; }
.mx-auto { margin-left:auto; margin-right:auto; }

/* ── Misc ───────────────────────────────────────── */
.nowrap          { white-space:nowrap; }
.overflow-hidden { overflow:hidden; }
.relative        { position:relative; }
.w-full          { width:100%; }
.text-center     { text-align:center; }
/* Center inline-flex section-tag when inside a text-center parent */
.text-center .section-tag, .page-hero-inner .section-tag { margin-left:auto; margin-right:auto; }

/* ── Inline-flex helpers ────────────────────────── */
.inline-flex     { display:inline-flex; }
.py-8            { padding-top:4rem; padding-bottom:4rem; }
.self-start      { align-self:flex-start; }
.how-it-works-title { font-size:1.05rem; }

/* ── Cyber bar — CERT-FR ticker ─────────────────────── */
.cb-wrap       { position:relative; height:1.3em; min-width:0; width:min(700px,60vw); }
.cb-item       { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; gap:.65rem; transition:opacity .8s ease; white-space:nowrap; overflow:hidden; }
.cb-level      { font-family:'JetBrains Mono',monospace; font-size:.67rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em; }
.cb-title-link { color:#cbd5e1; text-decoration:none; font-size:.78rem; overflow:hidden; text-overflow:ellipsis; transition:color 150ms; }
.cb-title-link:hover { color:#fff; }
.cb-title      { color:#cbd5e1; font-size:.78rem; overflow:hidden; text-overflow:ellipsis; }
.cb-meta       { font-family:'JetBrains Mono',monospace; font-size:.67rem; color:#64748b; }
.cb-sep        { color:#3d5a80; }
.cb-certfr     { color:#86efac; }
.cb-stat-link  { font-size:.72rem; font-family:'JetBrains Mono',monospace; color:var(--cyan); text-decoration:none; }
.cb-status     { font-size:.78rem; color:#cbd5e1; }
.cb-status-warn { color:#fbbf24; }
.hidden        { display:none; }

/* ── Cybersécurité — CERT-FR components ─────────────── */
.cert-link {
  display:inline-flex; align-items:center; gap:.35rem;
  font-family:'JetBrains Mono',monospace; font-size:.7rem; font-weight:700;
  color:var(--cyan); text-decoration:none; text-transform:uppercase; letter-spacing:.06em;
  transition:gap 180ms;
}
.cert-link:hover { gap:.6rem; }
.cert-source-link {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:'JetBrains Mono',monospace; font-size:.72rem; color:#64748b;
  text-decoration:none; border:1px solid var(--border); border-radius:8px;
  padding:.45rem .9rem; transition:border-color 180ms, color 180ms;
}
.cert-source-link:hover { border-color:rgba(0,229,255,.3); color:var(--cyan); }
.cert-empty { grid-column:1/-1; text-align:center; padding:2.5rem; }
.cert-empty .tlevel { justify-content:center; margin-bottom:1rem; }

/* ── Section backgrounds (page-specific but reusable) ── */
.section-cyber-bg  { background:linear-gradient(160deg,#020617,#011a0d); }
.section-voip-bg   { background:linear-gradient(160deg,#0d0520,#1a0a40); }
.section-cta-dark  { background:linear-gradient(160deg,#020617,#050e1f); }
.section-cta-par   { background:linear-gradient(135deg,#020617,#050e1f); border-top:1px solid var(--border); padding:5rem 1.5rem; text-align:center; position:relative; overflow:hidden; }
.cta-radial-overlay { position:absolute; inset:0; background:radial-gradient(ellipse at center,rgba(0,229,255,.05) 0%,transparent 65%); }
.cta-inner { position:relative; z-index:1; }
.section-cta-tel   { background:#020617; border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:2rem 0; }

/* ── Ghost button white variant ───────────────────── */
.btn-ghost-white { color:#fff !important; border-color:rgba(255,255,255,.25) !important; }

/* ── Telecom — feature lists ──────────────────────── */
.tel-feat-list { list-style:none; display:flex; flex-direction:column; gap:.4rem; }
.tel-feat-list li { display:flex; align-items:center; gap:.5rem; font-size:.8rem; color:#8ba4c4; font-family:'JetBrains Mono',monospace; }
.tel-feat-list li::before { content:'→'; flex-shrink:0; }
.tfl-orange::before { color:var(--orange); }
.tfl-cyan::before   { color:var(--cyan); }
.tfl-purple::before { color:var(--purple); }
/* Top border variants for sdwan cards */
.tel-card-orange { border-top:3px solid var(--orange); }
.tel-card-cyan   { border-top:3px solid var(--cyan); }
.tel-card-purple { border-top:3px solid var(--purple); }
/* VoIP stat */
.voip-stat { text-align:center; padding:1.5rem; }
.voip-stat-n { font-family:'Space Grotesk',sans-serif; font-size:1.8rem; font-weight:800; color:var(--purple); margin-bottom:.35rem; }

/* ── Témoignages ──────────────────────────────────── */
.testi-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; margin-top:3.5rem;
}
.testi-card {
  background:var(--card); border:1px solid var(--border); border-radius:18px;
  padding:2rem; display:flex; flex-direction:column; gap:1.25rem;
  transition:transform 200ms, border-color 200ms, box-shadow 200ms;
  position:relative; overflow:hidden;
}
.testi-card::before {
  content:'"'; position:absolute; top:-10px; right:1.5rem;
  font-size:7rem; line-height:1; color:rgba(0,229,255,.06);
  font-family:'Space Grotesk',sans-serif; font-weight:800; pointer-events:none;
}
.testi-card:hover { transform:translateY(-5px); box-shadow:0 20px 50px rgba(0,0,0,.3); }
.testi-stars { display:flex; gap:3px; }
.testi-text {
  color:var(--text-sub); font-size:.92rem; line-height:1.8;
  flex:1; font-style:italic;
}
.testi-author { display:flex; align-items:center; gap:.85rem; margin-top:.25rem; }
.testi-avatar {
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-family:'Space Grotesk',sans-serif; font-size:.9rem; font-weight:800;
  border:1.5px solid;
}
.testi-name { color:#fff; font-size:.88rem; font-weight:700; }
.testi-role { color:var(--text-muted); font-size:.75rem; font-family:'JetBrains Mono',monospace; margin-top:.15rem; }
@media(max-width:768px) { .testi-grid { grid-template-columns:1fr; } }

/* ── Image break — bande photo pleine largeur ─────── */
.img-break {
  position:relative; height:320px;
  background-size:cover; background-position:center;
  background-attachment:fixed;          /* parallax léger */
  overflow:hidden;
}
.img-break-overlay {
  position:absolute; inset:0;
  background:linear-gradient(160deg,rgba(3,7,18,.72) 0%,rgba(3,7,18,.58) 100%);
}
.img-break-inner {
  position:relative; z-index:1; height:100%;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; text-align:center; padding:2rem 1.5rem;
  gap:.75rem;
}
.img-break-stat {
  font-family:'Space Grotesk',sans-serif; font-size:clamp(2.8rem,5vw,4.5rem);
  font-weight:800; color:#fff; line-height:1; letter-spacing:-.04em;
}
.img-break-stat span { color:var(--cyan); text-shadow:var(--glow-cyan); }
.img-break-label {
  font-family:'JetBrains Mono',monospace; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.12em; color:white;
}
.img-break-quote {
  font-size:clamp(1.1rem,2.5vw,1.6rem); font-weight:700; color:#fff;
  max-width:700px; line-height:1.35; letter-spacing:-.02em;
}
.img-break-quote span { color:var(--cyan); }
/* Désactive le parallax sur mobile (ne fonctionne pas sur iOS) */
@media(max-width:768px) {
  .img-break { background-attachment:scroll; height:240px; }
}

/* ── Contact ──────────────────────────────────────── */
.cmethod-static { cursor:default; }

/* ── Skip-link accessibilité ── */
.skip-link {
  position: absolute; top: -60px; left: 1rem; z-index: 10000;
  background: var(--cyan, #00e5ff); color: #030d1f;
  padding: .6rem 1.2rem; border-radius: 0 0 8px 8px;
  font-weight: 700; text-decoration: none; font-size: .9rem;
  transition: top .2s ease;
}
.skip-link:focus { top: 0; }

/* ══════════════════════════════════════════════════
   PREMIUM POLISH — haptic motion & high-end finish
   (12 principes d'animation + design haut de gamme)
   ══════════════════════════════════════════════════ */
:root {
  --ease-spring: cubic-bezier(.32,.72,0,1);   /* masse + inertie */
  --ease-expo:   cubic-bezier(.16,1,.3,1);    /* sortie fluide */
  --shadow-ambient: 0 1px 2px rgba(0,0,0,.3), 0 8px 24px rgba(0,0,0,.25), 0 24px 64px rgba(0,0,0,.25);
}

/* ── Typographie : titres plus tendus, sous-titres plus lisibles ── */
.section-title { letter-spacing:-.04em; }
.section-sub   { font-size:1.04rem; }

/* ── Respiration : les sections prennent de l'air ── */
.section { padding:7.5rem 1.5rem; }
@media(max-width:768px){ .section { padding:4.5rem 1.25rem; } }

/* ── Eyebrow tags : pastille pilule haut de gamme ── */
.section-tag {
  background:rgba(0,229,255,.06);
  border:1px solid rgba(0,229,255,.16);
  border-radius:999px; padding:.32rem .85rem;
  letter-spacing:.2em; font-size:.66rem;
}
.section-tag.tag-green  { background:rgba(0,255,136,.05);  border-color:rgba(0,255,136,.16); }
.section-tag.tag-orange { background:rgba(255,107,0,.06);  border-color:rgba(255,107,0,.18); }
.section-tag.tag-purple { background:rgba(167,139,250,.06);border-color:rgba(167,139,250,.18); }
.section-tag.tag-red    { background:rgba(248,113,113,.05);border-color:rgba(248,113,113,.16); }

/* ── Boutons : pilules, squash & stretch, follow-through ── */
.btn {
  border-radius:999px;
  padding:.9rem 2rem;
  transition:transform 450ms var(--ease-spring), box-shadow 450ms var(--ease-spring), background 250ms;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18), 0 4px 18px rgba(0,0,0,.35);
}
.btn:active { transform:scale(.97); transition-duration:120ms; }
.btn svg {
  transition:transform 450ms var(--ease-spring);
}
.btn:hover svg { transform:translateX(2px) translateY(-1px); }
.btn-cyan:hover   { transform:translateY(-2px) scale(1.015); box-shadow:inset 0 1px 0 rgba(255,255,255,.25), 0 10px 36px rgba(0,229,255,.45); }
.btn-green:hover  { transform:translateY(-2px) scale(1.015); box-shadow:inset 0 1px 0 rgba(255,255,255,.25), 0 10px 36px rgba(0,255,136,.45); }
.btn-orange:hover { transform:translateY(-2px) scale(1.015); box-shadow:inset 0 1px 0 rgba(255,255,255,.2),  0 10px 36px rgba(255,107,0,.5); }
.btn-ghost:hover  { transform:translateY(-2px); }

/* Boutons nav : mêmes pilules physiques */
.btn-client, .btn-rdv {
  border-radius:999px !important;
  transition:transform 450ms var(--ease-spring), box-shadow 450ms var(--ease-spring) !important;
}
.btn-client:active, .btn-rdv:active { transform:scale(.96); transition-duration:120ms !important; }
.btn-rdv svg { transition:transform 450ms var(--ease-spring); }
.btn-rdv:hover svg { transform:translateX(2px) translateY(-1px) scale(1.08); }

/* ── Cartes : double-bezel, hairline + highlight interne, ombre ambiante ── */
.card {
  border-radius:20px;
  border:1px solid rgba(255,255,255,.07);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05), 0 1px 2px rgba(0,0,0,.3);
  transition:border-color 450ms var(--ease-expo), box-shadow 450ms var(--ease-expo), transform 450ms var(--ease-spring);
}
.card:hover {
  transform:translateY(-4px);
  border-color:rgba(0,229,255,.28);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), var(--shadow-ambient), 0 0 0 1px rgba(0,229,255,.1);
}

/* ── Reveal : arrivée plus physique (slow-out long) ── */
.reveal, .reveal-left, .reveal-right {
  transition:opacity 900ms var(--ease-expo), transform 900ms var(--ease-expo), filter 700ms var(--ease-expo);
}
.reveal-scale { transition:opacity 800ms var(--ease-spring), transform 800ms var(--ease-spring); }

/* ── Liens nav : soulignement fluide (anticipation) ── */
.nav-links a:not(.btn-client):not(.btn-rdv):not(.btn-ticket) { position:relative; }
.nav-links a:not(.btn-client):not(.btn-rdv):not(.btn-ticket)::after {
  content:''; position:absolute; left:50%; bottom:-2px; width:0; height:2px;
  background:var(--cyan); border-radius:2px; transform:none; box-shadow:none;
  transition:width 450ms var(--ease-expo), left 450ms var(--ease-expo);
}
.nav-links a:not(.btn-client):not(.btn-rdv):not(.btn-ticket):hover::after,
.nav-links a.active:not(.btn-client):not(.btn-rdv):not(.btn-ticket)::after {
  width:calc(100% - 1.8rem); left:.9rem; transform:none;
}

/* ── Flottants : apparition avec overshoot léger ── */
.fc-wa, .fc-tel { transition:transform 450ms var(--ease-spring), box-shadow 450ms var(--ease-spring); }
.fc-wa:hover  { transform:scale(1.1) rotate(-4deg); }
.fc-tel:hover { transform:translateY(-2px) scale(1.04); }
.scroll-top-btn { transition:opacity 450ms var(--ease-expo), transform 450ms var(--ease-spring), background 180ms, border-color 180ms; }
.scroll-top-btn:hover { transform:translateY(-3px); }

/* ── Images & cartes blog/portfolio : zoom doux au survol ── */
.bcard img, .pcard img { transition:transform 900ms var(--ease-expo); }
.bcard:hover img, .pcard:hover img { transform:scale(1.045); }

/* ── Accessibilité : on respecte prefers-reduced-motion (déjà géré plus haut) ── */

/* ══════════════════════════════════════════════════
   MOTION LAYER 2 — chorégraphie & micro-interactions
   ══════════════════════════════════════════════════ */

/* ── Entrée de page : la navbar descend, le contenu monte ── */
@keyframes navDrop { from { transform:translateY(-100%); opacity:0; } to { transform:translateY(0); opacity:1; } }
.navbar { animation:navDrop 700ms var(--ease-expo) both; }

@keyframes pageRise { from { opacity:0; transform:translateY(14px); } to { opacity:1; transform:translateY(0); } }
main, .page-hero, .rdv-wrap { animation:pageRise 800ms 120ms var(--ease-expo) both; }

/* ── Sheen : reflet qui balaie les boutons pleins au survol ── */
.btn-cyan, .btn-orange, .btn-green, .btn-client, .btn-rdv { position:relative; overflow:hidden; }
.btn-cyan::before, .btn-orange::before, .btn-green::before, .btn-rdv::before {
  content:''; position:absolute; top:0; bottom:0; left:-80%; width:50%;
  background:linear-gradient(105deg, transparent, rgba(255,255,255,.35), transparent);
  transform:skewX(-20deg); pointer-events:none;
  transition:left 700ms var(--ease-expo);
}
.btn-cyan:hover::before, .btn-orange:hover::before, .btn-green:hover::before, .btn-rdv:hover::before { left:130%; }

/* ── Titres de section : trait qui se dessine à l'apparition ── */
.section-title.reveal { position:relative; }
.section-title.reveal::after {
  content:''; display:block; height:3px; width:64px; margin-top:.9rem;
  background:linear-gradient(90deg, var(--cyan), transparent);
  border-radius:2px; transform:scaleX(0); transform-origin:left;
  transition:transform 900ms 350ms var(--ease-expo);
}
.section-title.reveal.visible::after { transform:scaleX(1); }
/* centré quand le titre est centré */
.section-title.reveal.mx-auto::after,
.page-hero .section-title.reveal::after,
.text-center .section-title.reveal::after,
[style*="text-align:center"] .section-title.reveal::after { margin-left:auto; margin-right:auto; transform-origin:center; background:linear-gradient(90deg, transparent, var(--cyan), transparent); }

/* ── Icônes de cartes : rebond élastique au survol ── */
.card .card-icon { transition:transform 550ms var(--ease-spring); }
.card:hover .card-icon { transform:translateY(-5px) rotate(-4deg) scale(1.07); }

/* ── Badges hero : pastilles qui respirent ── */
@keyframes dotPulse { 0%,100% { box-shadow:0 0 0 0 rgba(0,255,136,.5); } 50% { box-shadow:0 0 0 5px rgba(0,255,136,0); } }
.hbadge-dot { animation:dotPulse 2.4s ease-in-out infinite; }

/* ── WhatsApp : anneau de sonar périodique ── */
@keyframes waPing { 0% { box-shadow:0 4px 20px rgba(37,211,102,.4), 0 0 0 0 rgba(37,211,102,.45); }
  70% { box-shadow:0 4px 20px rgba(37,211,102,.4), 0 0 0 14px rgba(37,211,102,0); }
  100% { box-shadow:0 4px 20px rgba(37,211,102,.4), 0 0 0 0 rgba(37,211,102,0); } }
.fc-wa { animation:waPing 3.2s var(--ease-expo) infinite; }

/* ── Halos des page-hero : dérive lente (vivant mais discret) ── */
@keyframes glowDrift { 0%,100% { transform:translate(0,0) scale(1); } 50% { transform:translate(4%,6%) scale(1.08); } }
.page-hero::before { animation:glowDrift 12s ease-in-out infinite; }
.page-hero::after  { animation:glowDrift 16s ease-in-out infinite reverse; }

/* ── Barre de progression de lecture (haut de page) ── */
#scroll-progress {
  position:fixed; top:0; left:0; height:2px; width:100%;
  background:linear-gradient(90deg, var(--cyan), var(--green));
  transform:scaleX(0); transform-origin:left;
  z-index:10000; pointer-events:none;
  box-shadow:0 0 10px rgba(0,229,255,.5);
}

/* ── Lignes de tableaux & liens footer : glissement subtil ── */
footer a { transition:color 250ms, transform 350ms var(--ease-spring); display:inline-block; }
footer a:hover { transform:translateX(3px); }

/* reduced-motion : tout est déjà neutralisé par la règle globale */

/* ── Vignettes blog/portfolio : voile dégradé pour la lisibilité ── */
.bcard-img::before {
  content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(to top, rgba(3,7,18,.55) 0%, transparent 55%);
  opacity:.7; transition:opacity 600ms var(--ease-expo);
}
.bcard:hover .bcard-img::before { opacity:1; }
.pcard-img-overlay { transition:opacity 600ms var(--ease-expo); }
.pcard:hover .pcard-img-overlay { opacity:.85; }
