/* ── index.css — CSS spécifique à la page d'accueil ── */

html,body{height:100%}

/* ── VIDEO BG ── */
.video-wrap{
  position:fixed;inset:0;z-index:0;overflow:hidden;
}
.video-wrap video{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.55) saturate(1.1);
}
/* overlay gradient — sombre en bas comme MindHyve */
.video-wrap::after{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(to bottom,
      rgba(2,12,20,.15) 0%,
      rgba(2,12,20,.05) 30%,
      rgba(2,12,20,.55) 70%,
      rgba(2,12,20,.92) 100%
    ),
    linear-gradient(to right,
      rgba(2,12,20,.6) 0%,
      transparent 50%,
      transparent 100%
    );
}

/* grain (opacity différente sur index) */
.grain{opacity:.3}

/* ── HERO ── */
.hero{
  position:relative;z-index:10;
  min-height:100vh;
  display:flex;flex-direction:column;
  justify-content:flex-end;
  padding:0 56px 90px;
}

.hero-content{max-width:780px;}

.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 12px;border-radius:4px;
  background:rgba(96,165,250,.08);
  border:1px solid rgba(96,165,250,.25);
  font-size:11px;font-weight:500;
  color:var(--cyan);letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:24px;
  opacity:0;animation:up .9s cubic-bezier(.16,1,.3,1) forwards .4s;
}
.badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 6px var(--cyan);
  animation:blink 2s ease-in-out infinite;
}

.hero-title{
  font-family:'Outfit',sans-serif;font-weight:800;
  font-size:clamp(44px,5.2vw,76px);
  line-height:.98;letter-spacing:-.035em;
  margin-bottom:24px;
}
.line{display:block;overflow:hidden;white-space:nowrap}
.line-inner{
  display:block;
  opacity:0;transform:translateY(105%);
  animation:line-up .9s cubic-bezier(.16,1,.3,1) forwards;
}
.l1 .line-inner{animation-delay:.6s}
.l2 .line-inner{animation-delay:.75s}
.l3 .line-inner{animation-delay:.9s}

.grad{
  background:linear-gradient(90deg,#93c5fd 0%,#60a5fa 40%,#c7d2fe 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero-desc{
  font-size:16px;font-weight:300;line-height:1.7;
  color:var(--muted);max-width:460px;margin-bottom:40px;
  opacity:0;animation:up .9s cubic-bezier(.16,1,.3,1) forwards 1.05s;
}

.hero-ctas{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;animation:up .9s cubic-bezier(.16,1,.3,1) forwards 1.2s;
}

/* btn-primary override pour index (border-radius 100px) */
.btn-primary{
  padding:13px 26px;border-radius:100px;
  box-shadow:0 0 30px rgba(96,165,250,.4);
}
.btn-primary:hover{box-shadow:0 0 50px rgba(96,165,250,.55)}
.btn-primary svg{width:16px;height:16px}

.btn-ghost{
  padding:13px 26px;border-radius:100px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.05);
  color:rgba(200,220,255,.7);
}
.btn-ghost:hover{border-color:rgba(255,255,255,.3);color:var(--white);background:rgba(255,255,255,.08)}

/* ── SCROLL INDICATOR ── */
.scroll-hint{
  position:absolute;right:56px;bottom:90px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  opacity:0;animation:up .9s ease forwards 1.5s;
}
.scroll-hint span{
  font-size:10px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.2);writing-mode:vertical-rl;
}
.scroll-line{
  width:1px;height:56px;
  background:linear-gradient(to bottom,rgba(96,165,250,.5),transparent);
  position:relative;overflow:hidden;
}
.scroll-line::after{
  content:'';position:absolute;top:-100%;left:0;
  width:1px;height:50%;
  background:linear-gradient(to bottom,transparent,var(--cyan));
  animation:drip 2.4s ease-in-out infinite 1.6s;
}

/* ── CLIENTS ── */
.clients{
  position:relative;z-index:10;
  padding:44px 0;
  background:rgba(2,12,20,.9);
  border-top:1px solid rgba(255,255,255,.06);
}
.clients-label{
  text-align:center;font-size:10px;font-weight:500;
  letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.18);margin-bottom:28px;
}
.track-wrap{overflow:hidden;position:relative}
.track-wrap::before,.track-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.track-wrap::before{left:0;background:linear-gradient(to right,rgba(2,12,20,.9),transparent)}
.track-wrap::after{right:0;background:linear-gradient(to left,rgba(2,12,20,.9),transparent)}
.clients-track{
  display:flex;gap:52px;align-items:center;width:max-content;
  animation:marquee 28s linear infinite;
}
.client-item{
  display:flex;align-items:center;gap:9px;
  opacity:.22;filter:grayscale(1);
  transition:opacity .3s,filter .3s;white-space:nowrap;
}
.client-item:hover{opacity:.65;filter:none}
.client-item .ci{
  width:28px;height:28px;border-radius:6px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:grid;place-items:center;font-size:14px;
}
.client-item .cn{
  font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;
  color:var(--white);letter-spacing:-.01em;
}

@media(max-width:900px){
  nav{grid-template-columns:1fr 1fr;padding:0 20px}
  .nav-links{display:none}
  .hero{padding:0 24px 72px}
  .scroll-hint{display:none}
}
