/* ═══════════════════════════════════════════════════════════════
   CRABZZZ.FR — LES ABYSSES v2
   DA : abysses assombries · encre bioluminescente · lanterne
   ═══════════════════════════════════════════════════════════════ */
:root {
  --abyss:   #010409;
  --abyss-2: #030b14;
  --bio:     #00ffc8;
  --elec:    #00a2ff;
  --crab:    #ff4d5a;
  --gold:    #ffc857;
  --foam:    #e8fbf4;
  --muted:   rgba(232,251,244,.55);
  --faint:   rgba(232,251,244,.38);
  --line:    rgba(0,255,200,.13);
  --card:    rgba(2,12,20,.55);
  --font-d:  'Unbounded', sans-serif;
  --font-b:  'Sora', sans-serif;
  --font-m:  'IBM Plex Mono', monospace;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
::selection { background:var(--bio); color:var(--abyss); }
body {
  background:var(--abyss);
  color:var(--foam);
  font-family:var(--font-b);
  overflow-x:hidden;
  min-height:100vh;
}
/* curseur custom : jamais pour tactile ni reduced-motion (lanterne JS absente) */
@media (hover:hover) and (pointer:fine) and (prefers-reduced-motion: no-preference) {
  body.lantern, body.lantern a, body.lantern button, body.lantern input { cursor:none; }
}
::-webkit-scrollbar { width:9px; }
::-webkit-scrollbar-track { background:var(--abyss); }
::-webkit-scrollbar-thumb { background:linear-gradient(var(--bio), var(--elec)); border-radius:6px; }
:focus-visible { outline:2px solid var(--bio); outline-offset:3px; border-radius:3px; }
section[tabindex="-1"], main[tabindex="-1"] { outline:none; }

/* ── CALQUES FIXES ─────────────────────────────── */
#fluid { position:fixed; inset:0; width:100%; height:100%; z-index:0; pointer-events:none; }
.grain {
  position:fixed; inset:-60%; width:220%; height:220%; z-index:96; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.028; animation:grainMove .5s steps(3) infinite;
}
@keyframes grainMove { 0%{transform:translate(0,0);} 33%{transform:translate(-3%,2%);} 66%{transform:translate(3%,-2%);} 100%{transform:translate(-2%,-3%);} }
.scanlines {
  position:fixed; inset:0; z-index:95; pointer-events:none;
  background:repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(0,255,200,.012) 3px, rgba(0,255,200,.012) 5px);
}
.vignette {
  position:fixed; inset:0; z-index:94; pointer-events:none;
  background:radial-gradient(ellipse at 50% 42%, transparent 48%, rgba(0,2,6,.72) 100%);
}
#pgbar {
  position:fixed; top:0; left:0; right:0; height:2px; z-index:9999;
  background:linear-gradient(90deg, var(--bio), var(--elec), var(--crab));
  transform-origin:left; transform:scaleX(0);
  box-shadow:0 0 10px rgba(0,255,200,.7);
}

/* ── LAMPE-TORCHE (lights off) ─────────────────── */
#lightsoff {
  position:fixed; inset:0; z-index:9000; pointer-events:none; opacity:0;
  transition:opacity .8s ease;
  background:radial-gradient(circle 210px at var(--lx,50%) var(--ly,50%),
    transparent 0%, rgba(0,2,5,.55) 40%, rgba(0,1,3,.985) 78%);
}
body.lights-off #lightsoff { opacity:1; }

/* ── LANTERNE (curseur) ────────────────────────── */
#cursor, #cursor-ring, #cursor-halo { display:none; }
@media (hover:hover) and (pointer:fine) and (prefers-reduced-motion: no-preference) {
  body.lantern #cursor {
    display:block; position:fixed; width:6px; height:6px; border-radius:50%;
    background:var(--bio); z-index:99999; pointer-events:none;
    transform:translate(-50%,-50%);
    box-shadow:0 0 12px var(--bio), 0 0 36px rgba(0,255,200,.6);
    transition:background .3s;
  }
  body.lantern #cursor-ring {
    display:block; position:fixed; width:34px; height:34px; border-radius:50%;
    border:1.5px solid rgba(0,255,200,.4); z-index:99998; pointer-events:none;
    transform:translate(-50%,-50%);
    transition:width .35s cubic-bezier(.2,.9,.3,1.4), height .35s cubic-bezier(.2,.9,.3,1.4), border-color .3s, background .3s;
  }
  body.lantern #cursor-halo {
    display:block; position:fixed; width:340px; height:340px; border-radius:50%;
    z-index:1; pointer-events:none; transform:translate(-50%,-50%);
    background:radial-gradient(circle, rgba(0,255,200,.075), rgba(0,162,255,.03) 45%, transparent 70%);
  }
  body.lantern.cursor-hover #cursor { background:var(--crab); box-shadow:0 0 14px var(--crab), 0 0 40px rgba(255,77,90,.6); }
  body.lantern.cursor-hover #cursor-ring { width:58px; height:58px; border-color:rgba(255,77,90,.6); background:rgba(255,77,90,.06); }
}

/* ── LOADER / BOOT ─────────────────────────────── */
#loader {
  position:fixed; inset:0; z-index:100000;
  background:var(--abyss);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:24px; transition:opacity .6s ease, visibility .6s;
}
#loader.done { opacity:0; visibility:hidden; }
.boot-crab {
  font-family:var(--font-m); font-size:clamp(9px,1.9vw,14px); line-height:1.3;
  color:var(--bio); text-align:center; white-space:pre;
  text-shadow:0 0 22px rgba(0,255,200,.6), 0 0 60px rgba(0,255,200,.22);
  animation:crabPulse 2.2s ease-in-out infinite;
}
@keyframes crabPulse { 0%,100%{opacity:.92;} 50%{opacity:1; filter:brightness(1.35);} }
.boot-log {
  font-family:var(--font-m); font-size:11.5px; letter-spacing:.04em;
  color:var(--muted); height:78px; overflow:hidden; text-align:left;
  width:min(440px,86vw); line-height:1.75;
}
.boot-log .ok { color:var(--bio); }
.boot-log .warn { color:var(--gold); }
.boot-bar-wrap { width:min(360px,78vw); height:2px; background:rgba(0,255,200,.1); overflow:hidden; border-radius:2px; }
#boot-bar { height:100%; width:0%; background:linear-gradient(90deg, var(--bio), var(--elec)); box-shadow:0 0 16px var(--bio); }
#boot-pct { font-family:var(--font-m); font-size:11px; letter-spacing:.4em; color:var(--muted); }
.boot-skip { font-family:var(--font-m); font-size:9.5px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; }
#boot-access {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-d); font-weight:800; font-size:clamp(20px,4.6vw,46px);
  letter-spacing:.12em; color:var(--bio); background:var(--abyss);
  opacity:0; pointer-events:none;
  text-shadow:0 0 40px rgba(0,255,200,.8);
}

/* ── NAV ───────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:16px clamp(16px,5vw,72px);
  display:flex; justify-content:space-between; align-items:center; gap:14px;
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  background:rgba(1,4,9,.66);
  border-bottom:1px solid rgba(0,255,200,.08);
  transition:transform .45s ease, visibility .45s;
}
nav.hidden { transform:translateY(-100%); visibility:hidden; }
.nav-logo {
  font-family:var(--font-d); font-weight:800; font-size:15px; letter-spacing:.05em;
  color:var(--foam); display:flex; align-items:center; gap:9px; text-decoration:none;
  white-space:nowrap;
}
.nav-logo .crab-ico { font-size:17px; filter:drop-shadow(0 0 8px rgba(255,77,90,.8)); animation:crabWiggle 4s ease-in-out infinite; display:inline-block; }
@keyframes crabWiggle { 0%,100%{transform:rotate(0);} 20%{transform:rotate(-14deg);} 40%{transform:rotate(10deg);} 60%{transform:rotate(-6deg);} 80%{transform:rotate(3deg);} }
.nav-logo em { font-style:normal; color:var(--bio); text-shadow:0 0 18px rgba(0,255,200,.6); }
.nav-links { display:flex; gap:28px; list-style:none; }
.nav-links a {
  color:var(--muted); text-decoration:none; font-family:var(--font-m);
  font-size:10.5px; letter-spacing:.2em; text-transform:uppercase;
  transition:color .3s, text-shadow .3s; white-space:nowrap; padding:6px 0;
}
.nav-links a::before { content:'▸ '; color:transparent; transition:color .3s; }
.nav-links a:hover { color:var(--bio); text-shadow:0 0 14px rgba(0,255,200,.7); }
.nav-links a:hover::before { color:var(--crab); }
.nav-links a[aria-current="page"] { color:var(--bio); }
.nav-links a[aria-current="page"]::before { color:var(--crab); }
.nav-status {
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-m); font-size:10px; letter-spacing:.16em;
  color:var(--muted); text-transform:uppercase; white-space:nowrap;
}
.dot-live { width:8px; height:8px; border-radius:50%; background:var(--bio); box-shadow:0 0 10px var(--bio); animation:pulse 1.8s ease-in-out infinite; }
@keyframes pulse { 0%,100%{transform:scale(1); opacity:1;} 50%{transform:scale(1.5); opacity:.55;} }
@media (max-width:900px){
  nav { padding:12px 14px; }
  .nav-status { display:none; }
  .nav-links { gap:14px; overflow-x:auto; scrollbar-width:none; }
  .nav-links::-webkit-scrollbar { display:none; }
  .nav-links a { font-size:9px; letter-spacing:.12em; }
}

/* ── STRUCTURE COMMUNE ─────────────────────────── */
main { position:relative; z-index:2; }
.wrap { padding:clamp(80px,11vh,140px) clamp(18px,6vw,84px); max-width:1500px; margin:0 auto; }
.wrap-tight { padding-top:clamp(110px,14vh,160px); }
.sec-tag {
  font-family:var(--font-m); font-size:11px; letter-spacing:.38em; text-transform:uppercase;
  color:var(--crab); margin-bottom:18px; display:flex; align-items:center; gap:14px;
}
.sec-tag::before { content:''; width:36px; height:1px; background:var(--crab); box-shadow:0 0 8px var(--crab); flex:none; }
.sec-title {
  font-family:var(--font-d); font-weight:800;
  font-size:clamp(28px,4.6vw,62px); line-height:1.08; letter-spacing:-.01em;
  margin-bottom:22px;
}
.sec-title .g { color:var(--bio); text-shadow:0 0 34px rgba(0,255,200,.4); }
.sec-title .r { color:var(--crab); text-shadow:0 0 30px rgba(255,77,90,.45); }
.lead { max-width:56ch; color:var(--muted); font-size:clamp(14px,1.3vw,16.5px); font-weight:300; line-height:1.85; }
.lead strong { color:var(--foam); font-weight:600; }
.lead .hl { color:var(--bio); font-weight:600; }

/* système de reveal (IntersectionObserver + CSS) */
.reveal { opacity:0; transform:translateY(42px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); transition-delay:var(--rd,0s); }
.reveal.in { opacity:1; transform:none; }
html.no-js .reveal, html.reduced .reveal { opacity:1; transform:none; transition:none; }

/* titre héro par lettres */
.hero-title {
  font-family:var(--font-d); font-weight:900;
  font-size:clamp(36px,7vw,100px); line-height:1.03; letter-spacing:-.01em;
  margin-bottom:28px;
}
.hero-title .ln { display:block; overflow:hidden; padding-bottom:.09em; margin-bottom:-.09em; }
.hero-title .ch { display:inline-block; transform:translateY(115%) rotate(4deg); opacity:0; animation:chIn 1s cubic-bezier(.16,.9,.24,1) forwards; animation-delay:calc(var(--i)*.03s + var(--ld,0s)); }
html.no-js .hero-title .ch, html.reduced .hero-title .ch { transform:none; opacity:1; animation:none; }
@keyframes chIn { to { transform:translateY(0) rotate(0); opacity:1; } }
.hero-title .g-ink, .hero-title .g .ch {
  background:linear-gradient(100deg, var(--bio) 10%, var(--elec) 55%, var(--bio) 90%);
  background-size:220% 100%;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation-name:chIn, shimmer; animation-duration:1s, 5.5s;
  animation-timing-function:cubic-bezier(.16,.9,.24,1), linear;
  animation-iteration-count:1, infinite;
  animation-fill-mode:forwards, none;
  animation-delay:calc(var(--i)*.03s + var(--ld,0s)), 0s;
  filter:drop-shadow(0 3px 10px rgba(0,2,6,.7)) drop-shadow(0 0 26px rgba(0,255,200,.3));
}
html.no-js .hero-title .g .ch, html.reduced .hero-title .g .ch { animation:shimmer 5.5s linear infinite; }
@keyframes shimmer { to { background-position:-220% 0; } }
.hero-title .r { color:var(--crab); filter:drop-shadow(0 0 22px rgba(255,77,90,.5)); }

.hero-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-m); font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--bio); border:1px solid var(--line); border-radius:99px;
  padding:8px 18px; margin-bottom:26px;
  background:rgba(0,255,200,.045); backdrop-filter:blur(6px);
}
.hero-tag::before { content:''; width:7px; height:7px; border-radius:50%; background:var(--crab); box-shadow:0 0 8px var(--crab); animation:pulse 2s infinite; flex:none; }

/* ── BOUTONS ───────────────────────────────────── */
.btn {
  font-family:var(--font-m); font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  padding:15px 28px; border-radius:4px; border:1px solid transparent;
  background:none; color:var(--foam); position:relative; overflow:hidden;
  transition:color .35s, box-shadow .35s, border-color .35s;
  display:inline-block; text-decoration:none; text-align:center; will-change:transform;
}
.btn-primary { border-color:var(--bio); color:var(--bio); box-shadow:0 0 24px rgba(0,255,200,.12); }
.btn-primary::after {
  content:''; position:absolute; inset:0; background:var(--bio);
  transform:scaleX(0); transform-origin:right; transition:transform .4s cubic-bezier(.7,0,.2,1); z-index:-1;
}
.btn-primary:hover { color:var(--abyss); box-shadow:0 0 48px rgba(0,255,200,.45); }
.btn-primary:hover::after { transform:scaleX(1); transform-origin:left; }
.btn-ghost { border-color:rgba(232,251,244,.18); color:var(--muted); }
.btn-ghost:hover { border-color:var(--crab); color:var(--crab); box-shadow:0 0 28px rgba(255,77,90,.22); }

/* ── TAGS / BADGES ─────────────────────────────── */
.tags { display:flex; flex-wrap:wrap; gap:8px; }
.tag {
  font-family:var(--font-m); font-size:10.5px; letter-spacing:.1em;
  padding:5px 12px; border-radius:99px; border:1px solid var(--line);
  color:var(--bio); background:rgba(0,255,200,.05);
}
.tag.r { color:var(--crab); border-color:rgba(255,77,90,.3); background:rgba(255,77,90,.06); }
.tag.b { color:var(--elec); border-color:rgba(0,162,255,.3); background:rgba(0,162,255,.06); }
.tag.y { color:var(--gold); border-color:rgba(255,200,87,.3); background:rgba(255,200,87,.06); }

/* ── CARTES ────────────────────────────────────── */
.icard {
  position:relative; border:1px solid var(--line); border-radius:14px;
  padding:38px 32px; background:var(--card); overflow:hidden;
  backdrop-filter:blur(8px);
  transition:border-color .4s, transform .25s ease-out;
  --mx:50%; --my:50%; will-change:transform;
}
.icard::before {
  content:''; position:absolute; inset:0; border-radius:14px; pointer-events:none;
  background:radial-gradient(420px circle at var(--mx) var(--my), rgba(0,255,200,.1), transparent 46%);
  opacity:0; transition:opacity .4s;
}
.icard:hover::before { opacity:1; }
.icard:hover { border-color:rgba(0,255,200,.45); }
.icard-num {
  position:absolute; top:20px; right:24px;
  font-family:var(--font-d); font-weight:800; font-size:50px;
  color:transparent; -webkit-text-stroke:1px rgba(0,255,200,.18);
}
.icard-ico { font-size:29px; margin-bottom:18px; display:inline-block; filter:drop-shadow(0 0 14px rgba(0,255,200,.5)); }
.icard h3 { font-family:var(--font-d); font-weight:600; font-size:18px; margin-bottom:13px; }
.icard p { color:var(--muted); font-size:14px; font-weight:300; line-height:1.75; margin-bottom:20px; }
a.icard { display:block; text-decoration:none; color:inherit; }
.icard .go { font-family:var(--font-m); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--bio); }
.icard .go::after { content:' →'; transition:margin-left .3s; }
.icard:hover .go::after { margin-left:6px; }

/* ── STATS ─────────────────────────────────────── */
.stats {
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:rgba(0,255,200,.018);
}
.stat { padding:40px 18px; text-align:center; border-right:1px solid var(--line); }
.stat:last-child { border-right:none; }
.stat-num { font-family:var(--font-d); font-weight:800; font-size:clamp(28px,4.2vw,52px); color:var(--bio); text-shadow:0 0 30px rgba(0,255,200,.45); }
.stat-num .unit { font-size:.45em; color:var(--crab); vertical-align:14%; margin-left:2px; }
.stat-lbl { margin-top:8px; font-family:var(--font-m); font-size:9.5px; letter-spacing:.28em; text-transform:uppercase; color:var(--muted); }
@media (max-width:820px){ .stats{grid-template-columns:repeat(2,1fr);} .stat:nth-child(2){border-right:none;} .stat:nth-child(-n+2){border-bottom:1px solid var(--line);} }

/* ── MARQUEE ───────────────────────────────────── */
.marquee { overflow:hidden; padding:24px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.mq-track { display:flex; gap:36px; width:max-content; animation:mq 30s linear infinite; }
html.reduced .mq-track { animation:none; }
@keyframes mq { to { transform:translateX(-33.334%); } }
.mq-track span {
  font-family:var(--font-d); font-weight:700; font-size:clamp(14px,1.9vw,22px);
  letter-spacing:.14em; color:transparent;
  -webkit-text-stroke:1px rgba(0,255,200,.3);
  text-transform:uppercase; white-space:nowrap;
}
.mq-track span.solid { color:var(--faint); -webkit-text-stroke:0; }
.mq-track .sep { color:var(--crab); -webkit-text-stroke:0; }

/* ── TERMINAUX ─────────────────────────────────── */
.term {
  background:rgba(1,8,14,.82); border:1px solid var(--line); border-radius:12px;
  backdrop-filter:blur(14px); overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.65), 0 0 60px rgba(0,255,200,.05);
}
.term-bar { display:flex; align-items:center; gap:8px; padding:12px 16px; background:rgba(0,255,200,.04); border-bottom:1px solid var(--line); }
.tdot { width:11px; height:11px; border-radius:50%; flex:none; }
.term-title { margin-left:10px; font-family:var(--font-m); font-size:11px; color:var(--muted); letter-spacing:.08em; }
.term-body {
  padding:16px 18px; font-family:var(--font-m); font-size:12.5px; line-height:1.85;
  min-height:300px; max-height:360px; overflow:hidden; white-space:pre-wrap; word-break:break-word;
}
.term-body .p { color:var(--bio); }
.term-body .c { color:var(--foam); }
.term-body .dim { color:var(--muted); }
.term-body .run { color:var(--bio); }
.term-body .red { color:var(--crab); }
.term-body .yel { color:var(--gold); }
.term-caret { display:inline-block; width:8px; height:15px; background:var(--bio); vertical-align:-2px; animation:blink 1s step-end infinite; box-shadow:0 0 8px var(--bio); }
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:0;} }

.iterm-out {
  padding:16px 18px 6px; font-family:var(--font-m); font-size:12.5px; line-height:1.8;
  overflow-y:auto; white-space:pre-wrap; word-break:break-word;
}
.iterm-out::-webkit-scrollbar { width:5px; }
.iterm-out .ok{color:var(--bio);} .iterm-out .err{color:var(--crab);} .iterm-out .warn{color:var(--gold);} .iterm-out .dim{color:var(--muted);} .iterm-out .blue{color:var(--elec);}
.iterm-row { display:flex; align-items:center; padding:4px 18px 14px; }
.iterm-ps { font-family:var(--font-m); font-size:12.5px; color:var(--bio); white-space:nowrap; }
.iterm-in { flex:1; background:none; border:none; outline:none; color:var(--foam); font-family:var(--font-m); font-size:12.5px; caret-color:var(--bio); }

/* ── CONSTELLATION ─────────────────────────────── */
#netcv-box {
  position:relative; height:min(74vh,700px); margin-top:26px;
  border:1px solid var(--line); border-radius:16px; overflow:hidden;
  background:radial-gradient(ellipse at center, rgba(0,26,34,.4), rgba(1,4,9,.75));
}
#netcv { width:100%; height:100%; display:block; touch-action:pan-y; }
#net-tip {
  position:absolute; pointer-events:none; z-index:5; opacity:0;
  background:rgba(1,8,14,.94); border:1px solid rgba(0,255,200,.4); border-radius:8px;
  padding:10px 14px; font-family:var(--font-m); font-size:11.5px; line-height:1.7;
  box-shadow:0 8px 32px rgba(0,0,0,.6), 0 0 24px rgba(0,255,200,.15);
  transition:opacity .2s; white-space:nowrap;
}
#net-tip .t-name { color:var(--bio); font-weight:600; letter-spacing:.06em; }
#net-tip .t-ip { color:var(--muted); }
#net-tip .t-st { color:var(--crab); font-size:10px; letter-spacing:.2em; text-transform:uppercase; }
.net-legend { display:flex; gap:24px; flex-wrap:wrap; margin-top:18px; font-family:var(--font-m); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.net-legend span { display:flex; align-items:center; gap:8px; }
.net-legend i { width:9px; height:9px; border-radius:50%; flex:none; }
.net-hint { margin-top:10px; font-family:var(--font-m); font-size:10.5px; color:var(--faint); letter-spacing:.08em; }

/* ── STACK ─────────────────────────────────────── */
.stack-layout { display:grid; grid-template-columns:1.2fr .8fr; gap:52px; margin-top:52px; align-items:start; }
.bar-item { margin-bottom:22px; }
.bar-top { display:flex; justify-content:space-between; margin-bottom:9px; font-family:var(--font-m); font-size:12.5px; }
.bar-name { color:var(--foam); letter-spacing:.04em; }
.bar-pct { color:var(--bio); }
.bar-track { height:5px; background:rgba(0,255,200,.08); border-radius:4px; overflow:hidden; }
.bar-fill {
  height:100%; width:0; border-radius:4px;
  background:linear-gradient(90deg, var(--elec), var(--bio));
  box-shadow:0 0 14px rgba(0,255,200,.55);
  transition:width 1.4s cubic-bezier(.2,.8,.2,1); transition-delay:var(--rd,0s);
}
.bar-item.in .bar-fill { width:var(--pct); }
html.no-js .bar-fill, html.reduced .bar-item .bar-fill { width:var(--pct); transition:none; }
.sinfo {
  border:1px solid var(--line); border-radius:14px; padding:26px;
  background:var(--card); margin-bottom:18px; position:relative; overflow:hidden;
  backdrop-filter:blur(8px);
}
.sinfo::after {
  content:''; position:absolute; top:0; left:-80%; width:60%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(0,255,200,.05), transparent);
  animation:sheen 5s ease-in-out infinite;
}
html.reduced .sinfo::after { animation:none; }
@keyframes sheen { 0%,60%{left:-80%;} 100%{left:130%;} }
.si-lbl { font-family:var(--font-m); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--crab); margin-bottom:10px; }
.si-val { font-family:var(--font-d); font-weight:700; font-size:21px; margin-bottom:6px; }
.si-sub { color:var(--muted); font-size:13px; font-weight:300; margin-bottom:15px; }
@media (max-width:980px){ .stack-layout{grid-template-columns:1fr;} }

/* ── GRILLES ───────────────────────────────────── */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:980px){ .grid-3{grid-template-columns:repeat(2,1fr);} }
@media (max-width:640px){ .grid-2,.grid-3{grid-template-columns:1fr;} }

/* ── SERVICES ──────────────────────────────────── */
.svc {
  position:relative; border:1px solid var(--line); border-radius:14px;
  padding:28px 24px; background:var(--card); overflow:hidden; backdrop-filter:blur(8px);
  transition:border-color .4s, transform .3s, box-shadow .4s;
  text-decoration:none; color:inherit; display:block; --mx:50%; --my:50%;
}
.svc::before {
  content:''; position:absolute; inset:0; border-radius:14px; pointer-events:none;
  background:radial-gradient(300px circle at var(--mx) var(--my), rgba(0,255,200,.09), transparent 46%);
  opacity:0; transition:opacity .4s;
}
.svc:hover::before { opacity:1; }
a.svc:hover { border-color:rgba(0,255,200,.5); transform:translateY(-6px); box-shadow:0 18px 44px rgba(0,0,0,.5), 0 0 34px rgba(0,255,200,.1); }
.svc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.svc-ico { font-size:24px; filter:drop-shadow(0 0 12px rgba(0,255,200,.5)); }
.svc-state { display:flex; align-items:center; gap:7px; font-family:var(--font-m); font-size:9.5px; letter-spacing:.2em; text-transform:uppercase; }
.svc-state i { width:8px; height:8px; border-radius:50%; flex:none; }
.svc-state.on { color:var(--bio); } .svc-state.on i { background:var(--bio); box-shadow:0 0 8px var(--bio); animation:pulse 2s infinite; }
.svc-state.off { color:var(--faint); } .svc-state.off i { background:var(--faint); }
.svc-state.priv { color:var(--gold); } .svc-state.priv i { background:var(--gold); box-shadow:0 0 8px var(--gold); }
.svc h3 { font-family:var(--font-d); font-weight:600; font-size:16px; margin-bottom:7px; }
.svc .svc-url { font-family:var(--font-m); font-size:11.5px; color:var(--bio); margin-bottom:10px; word-break:break-all; }
.svc .svc-url.locked { color:var(--faint); }
.svc p { color:var(--muted); font-size:13px; font-weight:300; line-height:1.7; }
.svc-cat { margin:44px 0 18px; font-family:var(--font-m); font-size:11px; letter-spacing:.34em; text-transform:uppercase; color:var(--crab); display:flex; align-items:center; gap:14px; }
.svc-cat::after { content:''; height:1px; flex:1; background:linear-gradient(90deg, rgba(255,77,90,.4), transparent); }

/* ── TIMELINE (à propos) ───────────────────────── */
.tl { position:relative; margin-top:50px; padding-left:34px; }
.tl::before { content:''; position:absolute; left:8px; top:6px; bottom:6px; width:1px; background:linear-gradient(var(--bio), var(--elec), transparent); box-shadow:0 0 8px rgba(0,255,200,.4); }
.tl-item { position:relative; padding-bottom:38px; }
.tl-item::before {
  content:''; position:absolute; left:-30px; top:6px; width:9px; height:9px; border-radius:50%;
  background:var(--bio); box-shadow:0 0 12px var(--bio);
}
.tl-item:last-child { padding-bottom:0; }
.tl-date { font-family:var(--font-m); font-size:10.5px; letter-spacing:.26em; color:var(--crab); text-transform:uppercase; margin-bottom:8px; }
.tl-item h3 { font-family:var(--font-d); font-weight:600; font-size:17px; margin-bottom:8px; }
.tl-item p { color:var(--muted); font-size:14px; font-weight:300; line-height:1.75; max-width:58ch; }

/* ── CONTACT ───────────────────────────────────── */
.ccard {
  border:1px solid var(--line); border-radius:14px; padding:32px 26px;
  background:var(--card); position:relative; overflow:hidden; backdrop-filter:blur(8px);
  transition:border-color .4s, transform .4s, box-shadow .4s;
  text-decoration:none; color:inherit; display:block;
}
.ccard:hover { border-color:rgba(255,77,90,.5); transform:translateY(-8px); box-shadow:0 22px 50px rgba(0,0,0,.5), 0 0 40px rgba(255,77,90,.12); }
.ccard-ico { font-size:25px; margin-bottom:16px; display:inline-block; filter:drop-shadow(0 0 12px rgba(0,255,200,.5)); }
.ccard-type { font-family:var(--font-m); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--crab); margin-bottom:9px; }
.ccard-val { font-family:var(--font-d); font-weight:600; font-size:15px; margin-bottom:8px; word-break:break-word; }
.ccard-sub { color:var(--muted); font-size:12.5px; font-weight:300; }

/* ── FOOTER ────────────────────────────────────── */
footer {
  position:relative; z-index:2; border-top:1px solid var(--line);
  padding:46px clamp(18px,6vw,84px);
  display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap;
  background:rgba(1,4,9,.72);
}
.f-logo { font-family:var(--font-d); font-weight:800; font-size:15px; }
.f-logo em { font-style:normal; color:var(--bio); }
.f-quote { font-family:var(--font-m); font-size:11.5px; color:var(--faint); font-style:italic; letter-spacing:.04em; }
.f-right { display:flex; align-items:center; gap:9px; font-family:var(--font-m); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }

/* ── EASTER EGGS ───────────────────────────────── */
#crabrave { position:fixed; inset:0; z-index:100001; pointer-events:none; overflow:hidden; display:none; }
#crabrave.on { display:block; }
.rave-crab { position:absolute; top:-70px; will-change:transform; animation:crabFall linear forwards; }
@keyframes crabFall { to { transform:translateY(115vh) rotate(720deg); } }
#crabrave .rave-flash { position:absolute; inset:0; background:radial-gradient(circle, rgba(255,77,90,.16), transparent 70%); animation:raveFlash .5s ease-in-out infinite alternate; }
@keyframes raveFlash { from{opacity:.3;} to{opacity:1;} }
#matrixcv { position:fixed; inset:0; z-index:100000; pointer-events:none; display:none; }

/* ── SCROLL HINT ───────────────────────────────── */
.scroll-hint {
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:var(--font-m); font-size:9.5px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--faint);
}
.scroll-hint .wire { width:1px; height:42px; background:linear-gradient(var(--bio), transparent); position:relative; overflow:hidden; }
.scroll-hint .wire::after { content:''; position:absolute; left:0; top:-40%; width:100%; height:40%; background:var(--bio); box-shadow:0 0 8px var(--bio); animation:wireDrop 1.8s ease-in infinite; }
@keyframes wireDrop { to { top:110%; } }

/* ── REDUCED MOTION ────────────────────────────── */
@media (prefers-reduced-motion:reduce) {
  *, *::before, *::after { animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  html { scroll-behavior:auto; }
}
