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

:root {
  --max-w:     1280px;
  --gutter:    48px;
  --bg:        #0c1318;
  --surface:   #111111;
  --card:      #272727;
  --border:    rgba(255,255,255,0.08);
  --border-lt: rgba(255,255,255,0.04);
  --white:     #f0ede8;
  --muted:     rgb(177,177,177);
  --dimmed:    rgba(240,237,232);
  --accent:    #c8ff00;
  --accent-bg: rgba(200,255,0,0.08);
  --accent-bd: rgba(200,255,0,0.22);
}

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--white);
  font-family: 'Inter', sans-serif;
  font-weight: 300;
  font-size: 15px;
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ─────────────────────────────────────────
   TYPOGRAPHY NORMALIZATION
───────────────────────────────────────── */
body { font-weight: 300; }

h1, h2, h3,
.logo, .f-logo,
.hero-h1, .s-title, .contact-h,
.s-label-tag, .srv-idx, .srv-name,
.proj-num, .proj-name, .proj-tag,
.proc-tag, .proc-t,
.price-top, .price-name,
.nav-links a, .nav-btn,
.cta-primary, .cta-ghost,
.fl, .f-links a {
  text-transform: uppercase;
}

/* "textes" en minuscule */
.hero-desc, .s-desc, .srv-txt, .proc-d, .price-desc, .price-feats li,
.proj-sub, .testi-q, .testi-rl, .ci span, .f-copy

/* ─────────────────────────────────────────
   BRAND (LOGO + WORDMARK)
───────────────────────────────────────── */
.logo.brand, .f-logo.brand {
  display:flex;
  align-items:center;
  gap:14px;
}
.brand-mark {
  flex:0 0 auto;
  color: var(--white);
  height: 34px;
  width: 34px;
}
.brand-text {
  display:inline-flex;
  align-items:baseline;
  gap:2px;
  margin-left: 5px;
}
.accent {
  color: var(--accent);
}
@media (max-width: 768px){
  .brand-mark{ height:28px; width:28px; }
  .logo.brand{ gap:12px; }
}

/* ─────────────────────────────────────────
   HERO Z-INDEX
───────────────────────────────────────── */
#hero .hero-grid, #hero .hero-glow { z-index:0; }
#hero > * { position:relative; z-index:2; }

/* ─────────────────────────────────────────
   NOISE OVERLAY
───────────────────────────────────────── */
body::after {
  content:'';
  position:fixed; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none; z-index:9000;
}

/* ─────────────────────────────────────────
   NAVIGATION
───────────────────────────────────────── */
nav {
  position: fixed; inset:0 0 auto;
  z-index: 500;
  padding: 0 max(var(--gutter), calc((100% - var(--max-w)) / 2));
  height: 64px;
  display: flex; align-items:center; justify-content:space-between;
  border-bottom: 1px solid transparent;
  transition: background .4s, border-color .4s, backdrop-filter .4s;
}
nav.stuck {
  background: rgba(10,10,10,.82);
  backdrop-filter: blur(18px) saturate(1.4);
  border-color: var(--border);
}
.logo {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .5px;
  text-transform: uppercase;
  color: var(--white);
  text-decoration: none;
  display: flex; align-items:center; gap:2px;
}
.logo em { color: var(--accent); font-style:normal; }
.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a {
  color: var(--muted);
  text-decoration:none;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  transition: color .2s;
}
.nav-links a:hover { color: var(--white); }
.nav-btn {
  background: var(--accent);
  color: #000;
  padding: 9px 20px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .8px;
  text-transform: uppercase;
  text-decoration: none;
  transition: opacity .2s, transform .2s;
}
.nav-btn:hover { opacity:.88; transform:translateY(-1px); }

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
#hero {
  height: 100vh;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.hero-grid {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-glow {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

#hero > *:not(.hero-grid):not(.hero-glow):not(#heroParticles) {
  position: relative;
  z-index: 2;
}

#heroParticles {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index:1;
  pointer-events:none;
  opacity:.9;
}

.hero-pill {
  display:inline-flex; align-items:center; gap:8px;
  background: var(--accent-bg);
  border: 1px solid var(--accent-bd);
  padding: 5px 14px 5px 10px;
  border-radius: 100px;
  font-size: 11px; font-weight:500;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 40px;
  width: fit-content;
  animation: fadeUp .7s ease .1s both;
}
.hero-pill-dot {
  width:6px; height:6px;
  background:var(--accent); border-radius:50%;
  animation: blink 2.2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.75)} }

.hero-h1 {
  font-size: clamp(58px, 9.5vw, 80px);
  font-weight: 700;
  line-height: .9;
  letter-spacing: -3px;
  text-transform: uppercase;
  animation: none;
}
.hero-h1 .ghost { color: var(--muted); }
.hero-h1 .hi    { color: var(--accent); }
.hero-h1 span {
  display: inline-block;
}
.hero-h1 .r {
  transition-duration: 1s;
}
.hero-foot {
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-top: 64px;
  animation: fadeUp .7s ease .4s both;
}
.hero-desc {
  max-width: 360px;
  color: var(--muted);
  font-size: 14px; font-weight:300; line-height:1.75;
}
.hero-ctas { display:flex; gap:12px; align-items:center; }
.cta-primary {
  background: var(--accent);
  color:#000;
  padding:14px 28px;
  border-radius:5px;
  font-size:12px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase;
  text-decoration:none;
  transition: opacity .2s, transform .2s, box-shadow .2s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cta-primary:hover { opacity:.9; transform:translateY(-2px); box-shadow:0 10px 36px rgba(200,255,0,.28); }
.cta-ghost {
  display:inline-flex; align-items:center; gap:10px;
  color: var(--muted);
  text-decoration:none;
  font-size:12px; font-weight:500;
  letter-spacing:.8px; text-transform:uppercase;
  transition: color .2s;
}
.cta-ghost:hover { color:var(--white); }
.cta-ghost .icon {
  width:34px; height:34px;
  border:1px solid var(--border);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:14px;
  transition: border-color .2s, transform .2s;
}
.cta-ghost:hover .icon { border-color:var(--white); transform:translateX(3px); }

@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

/* ─────────────────────────────────────────
   MARQUEE
───────────────────────────────────────── */
.ticker {
  background: var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:16px 0;
  overflow:hidden;
}
.ticker-inner {
  display:flex; gap:56px;
  animation: ticker 24s linear infinite;
  width: max-content;
}
.ticker-item {
  display:flex; align-items:center; gap:14px;
  font-size:11px; font-weight:500;
  letter-spacing:2px; text-transform:uppercase;
  color: var(--muted); flex-shrink:0;
}
.ticker-sep { width:4px;height:4px;background:var(--accent);border-radius:50%; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ─────────────────────────────────────────
   SHARED SECTION CHROME
───────────────────────────────────────── */
section { padding: 128px max(var(--gutter), calc((100% - var(--max-w)) / 2)); }

.s-head {
  display:flex; align-items:flex-start; gap:48px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 80px;
}
.s-label {
  flex-shrink:0;
  padding-top:6px;
}
.s-label-tag {
  font-size:10px; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  color: var(--accent);
  display:flex; align-items:center; gap:8px;
}
.s-label-tag::before {
  content:'';
  width:16px;height:1px;background:var(--accent);
}
.s-label-num {
  font-size:10px; font-weight:300;
  letter-spacing:1.5px; color:var(--dimmed);
  margin-top:6px; padding-left:24px;
}
.s-title {
  flex:1;
  font-size: clamp(34px, 5vw, 62px);
  font-weight: 700;
  letter-spacing: -1.5px;
  line-height: .95;
  text-transform: uppercase;
}
.s-desc {
  max-width:280px;
  color:var(--muted);
  font-size:13px; font-weight:300; line-height:1.75;
  padding-top:8px;
}

/* reveal */
.r { opacity:0; transform:translateY(36px); transition: opacity .75s cubic-bezier(.16,1,.3,1), transform .75s cubic-bezier(.16,1,.3,1); }
.r.d1{transition-delay:.1s} .r.d2{transition-delay:.2s} .r.d3{transition-delay:.3s} .r.d4{transition-delay:.4s}
.r.on { opacity:1; transform:translateY(0); }

/* ─────────────────────────────────────────
   SERVICES
───────────────────────────────────────── */
.srv-grid {
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap:2px;
}
.srv-card {
  padding:44px 36px;
  display:flex; flex-direction:column; justify-content:space-between;
  min-height:320px;
  position:relative;
  overflow:hidden;
  border-radius: 5px;
  background: #1a1a1a;
}
.srv-card > * {
  position: relative;
  z-index: 1;
}
.srv-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.6s cubic-bezier(.16, 1, .3, 1);
}
.srv-card:hover::after {
  transform: scale(1.08);
}
.srv-card::before {
  content:'';
  position:absolute; bottom:0;left:0;right:0;height:1.5px;
  background:var(--accent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .45s cubic-bezier(.16,1,.3,1);
  z-index: 2;
}
.srv-card:hover::before { transform:scaleX(1); }
.srv-idx {
  font-size:10px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--dimmed); margin-bottom:28px;
}

/* Images des cartes services — chemins relatifs depuis assets/css/ */
.srv-card:nth-child(1)::after,
.srv-card:nth-child(2)::after,
.srv-card:nth-child(3)::after{
  background-image: repeating-radial-gradient(
    circle at top left,
    transparent 0px,
    transparent 28px,
    rgba(255,255,255,0.02) 29px,
    transparent 30px
  ),
  linear-gradient(145deg, #2a2a2a 0%, #1a1a1a 60%, #111111 100%);
}


.srv-icon { font-size:32px; color: var(--accent); margin-bottom:16px; opacity:1; }
.srv-name {
  font-size:18px; font-weight:700;
  letter-spacing:-0.3px; text-transform:uppercase;
  margin-bottom:10px;
}
.srv-txt { color:#fff; font-size:13px; font-weight:300; line-height:1.75; }
.srv-badge {
  margin-top:32px; align-self:flex-start;
  background:#c8ff00;
  border:1px solid var(--border);
  padding:5px 13px; border-radius:100px;
  font-size:10px; font-weight:500;
  letter-spacing:1px; text-transform:uppercase;
  color:#000;
}

/* ─────────────────────────────────────────
   PROJECTS
───────────────────────────────────────── */
.proj-card {
  position: relative;
  overflow: hidden;
  min-height: 420px;
  border-radius: 5px;
}
.proj-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(30%) brightness(.9);
  transition: transform .7s cubic-bezier(.16,1,.3,1), filter .6s ease;
  z-index: 0;
}
.proj-left {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.proj-sub {
  margin-top: auto;
}
.proj-card:hover .proj-img {
  transform: scale(1.05);
  filter: grayscale(0%) brightness(.85);
}
.proj-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.55) 0%,
    rgba(0,0,0,.35) 40%,
    rgba(0,0,0,.10) 70%,
    rgba(0,0,0,0) 100%
  );
  z-index: 1;
  pointer-events: none;
}
.proj-body {
  position: absolute;
  inset:0;
  padding: 40px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  z-index: 2;
  color: #fff;
}
.proj-name {
  font-size: 12px;
  font-weight: 700;
  color: #c8ff00;
  letter-spacing: -0.4px;
  margin-bottom: 6px;
}
.proj-sub {
  font-size: 13px;
  color: rgba(255,255,255,.75);
}
.proj-meta {
  align-items: flex-end;
}
.proj-tag {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  color: #c8ff00;
  font-size: 12px;
}
.proj-year {
  color: rgba(255,255,255,.6);
}
.proj-grid {
  display: grid;
  gap: 2px;
  grid-template-columns: 1fr;
}
@media (min-width: 900px){
  .proj-grid{
    grid-template-columns: repeat(3, 1fr);
  }
}
.proj-link {
  position:absolute; top:20px; right:20px;
  width:38px; height:38px;
  background-color:#c8ff00;
  border:1px solid var(--border);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:15px; color: #000;
  opacity: 1;
  transform: none;
  transition: opacity .3s, transform .3s;
  text-decoration:none;
  z-index: 5;
}

/* ─────────────────────────────────────────
   PROCESS
───────────────────────────────────────── */
#process { background: var(--surface); }
.proc-list { display:flex; flex-direction:column; }
.proc-row {
  display:grid;
  grid-template-columns: 56px 1fr 100px;
  align-items:center; gap:36px;
  padding:44px 0;
  border-bottom:1px solid var(--border);
  transition:padding-left .3s ease;
}
.proc-row:first-child { border-top:1px solid var(--border); }
.proc-row:hover { padding-left:16px; }
.proc-n {
  font-size:52px; font-weight:700;
  letter-spacing:-2px; color:rgba(255, 255, 255, 0.418);
  transition: color .3s;
  line-height:1;
}
.proc-row:hover .proc-n { color:rgba(200,255,0,.418); }
.proc-tag {
  font-size:10px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--accent); margin-bottom:8px;
}
.proc-t {
  font-size:22px; font-weight:700;
  letter-spacing:-.4px; text-transform:uppercase;
  margin-bottom:8px;
}
.proc-d {
  font-size:13px; font-weight:300;
  color:var(--muted); line-height:1.7;
  max-width:520px;
}
.proc-dur {
  text-align:right;
}
.proc-dur strong {
  display:block;
  font-size:26px; font-weight:700;
  letter-spacing:-1px; color:var(--white);
}
.proc-dur span {
  font-size:11px; font-weight:300;
  color:var(--muted); letter-spacing:.5px;
}

/* ─────────────────────────────────────────
   PRICING
───────────────────────────────────────── */
#pricing { background: var(--bg); }
.price-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
}
.price-card {
  background:var(--card);
  padding:44px 36px;
  border-radius: 5px;
  display:flex; flex-direction:column;
}
.price-card.best { background:var(--accent); }
.price-card.best * { color:#000 !important; }
.price-card.best .feat-ok { color:#000 !important; }
.price-top {
  font-size:10px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--muted); margin-bottom:28px;
}
.price-name {
  font-size:26px; font-weight:700;
  letter-spacing:-.5px; text-transform:uppercase;
  margin-bottom:8px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.price-desc {
  font-size:13px; font-weight:300;
  color:var(--muted); line-height:1.65;
  margin-bottom:36px;
}
.price-card.best .price-desc { color:rgba(0,0,0,.55) !important; }
.price-amt {
  font-size:46px; font-weight:700;
  letter-spacing:-2.5px; line-height:1;
  margin-bottom:36px;
}
.price-feats {
  list-style:none;
  display:flex; flex-direction:column; gap:12px;
  flex:1; margin-bottom:36px;
}
.price-feats li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; font-weight:300;
  color:var(--muted); line-height:1.55;
}
.price-card.best .price-feats li { color:rgba(0,0,0,.6) !important; }
.feat-ok { color:var(--accent); font-weight:700; flex-shrink:0; }
.price-btn {
  background:rgba(255,255,255,.07);
  border:1px solid var(--border);
  color:var(--white);
  padding:14px; border-radius:5px;
  font-size:12px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase;
  text-decoration:none; text-align:center;
  display:block;
  transition: background .2s;
}
.price-btn:hover { background:rgba(255,255,255,.13); }
.price-card.best .price-btn {
  background:#000 !important;
  border-color:#000 !important;
  color:#fff !important;
}

/* ─────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────── */
#testimonials { background: var(--surface) }
.testi-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2px;
}
.testi-card { background:var(--bg); padding:44px 40px; border-radius: 5px;}
.testi-card.hero-card {
  grid-column:span 2;
  background:var(--bg);
  display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center;
}
.testi-stars { font-size:12px; color:var(--accent); letter-spacing:3px; margin-bottom:20px; }
.testi-q {
  font-size:clamp(17px,2vw,26px);
  font-weight:500; line-height:1.4;
  margin-bottom:32px; letter-spacing:-.3px;
}
.testi-q::before { content:'\201C'; color:var(--accent); font-size: 60px;}
.testi-who { display:flex; align-items:center; gap:14px; }
.testi-av {
  width:44px; height:44px; border-radius:50%;
  background:black;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; color:var(--accent);
  flex-shrink:0;
}
.testi-nm { font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:.3px; margin-bottom:3px; }
.testi-rl { font-size:12px; font-weight:300; color:var(--muted); }
.testi-right {
  border-left:1px solid var(--border);
  padding-left:72px;
}
.testi-stat { margin-bottom:40px; }
.testi-stat-val {
  font-size:60px; font-weight:700;
  letter-spacing:-3px; line-height:1;
  color:var(--accent); margin-bottom:8px;
}
.testi-stat-lbl { font-size:12px; font-weight:300; color:var(--muted); letter-spacing:.3px; }

/* ─────────────────────────────────────────
   TEAM
───────────────────────────────────────── */
#team { background: var(--surface); }
.team-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.team-photo-side {
  position: relative;
}
.team-photo-frame {
  position: relative;
  overflow: hidden;
  border-radius: 5px;
  background: var(--accent);
  max-width: 420px;
}
.team-photo-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(160deg, var(--card) 0%, #1e1e1e 100%);
  font-size: 96px;
  color: var(--border);
  letter-spacing: -4px;
}
.team-photo-badge {
  position: absolute;
  bottom: 24px;
  left: 24px;
  background: rgba(10,10,10,.82);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.team-badge-dot {
  width: 7px; height: 7px;
  background: var(--accent);
  border-radius: 50%;
  animation: pulse-team 2s infinite;
}
@keyframes pulse-team {
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.8)}
}
.team-badge-text {
  font-size: 12px;
  font-weight: 500;
  color: var(--white);
  letter-spacing: .3px;
}
.team-role {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--accent);
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
}
.team-role::before {
  content: '';
  width: 16px; height: 1px;
  background: var(--accent);
}
.team-name {
  font-size: clamp(38px, 5vw, 68px);
  font-weight: 700;
  letter-spacing: -2px;
  line-height: .95;
  text-transform: uppercase;
  margin-bottom: 32px;
}
.team-name em {
  font-style: italic;
  font-weight: 300;
  color: var(--muted);
}
.team-bio {
  color: var(--muted);
  font-size: 14px;
  font-weight: 300;
  line-height: 1.85;
  margin-bottom: 40px;
  max-width: 440px;
}
.team-skills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 40px;
}
.team-skill {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 6px 16px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .5px;
  color: var(--muted);
  text-transform: uppercase;
}
.team-stats {
  display: flex;
  gap: 40px;
  padding-top: 36px;
  border-top: 1px solid var(--border);
}
.team-stat-val {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -1.5px;
  line-height: 1;
  color: var(--white);
  margin-bottom: 5px;
}
.team-stat-val span { color: var(--accent); }
.team-stat-lbl {
  font-size: 11px;
  font-weight: 300;
  color: var(--muted);
  letter-spacing: .3px;
}
@media(max-width:900px){
  .team-wrap { grid-template-columns:1fr; gap:44px; }
  .team-photo-frame { max-width:100%; }
  .team-stats { gap:28px; }
}

/* ─────────────────────────────────────────
   CONTACT
───────────────────────────────────────── */
#contact { background:var(--bg); }
.contact-wrap {
  display:grid; grid-template-columns:1fr 1fr;
  gap:88px; align-items:start;
}
.contact-h {
  font-size:clamp(38px,6vw,76px);
  font-weight:700; letter-spacing:-2.5px; line-height:.92;
  text-transform:uppercase; margin-bottom:36px;
}
.contact-h .thin { font-weight:300; color:var(--muted); }
.contact-infos { display:flex; flex-direction:column; gap:18px; margin-top:48px; }
.ci {
  display:flex; align-items:center; gap:10px;
  font-size:13px; font-weight:300; color:var(--muted);
}
.ci-icon {
  width:38px; height:38px; border:1px solid var(--border);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:14px; flex-shrink:0;
}
.ci div {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;     /* Empêche l'icône de s'écraser si le texte est long */
}
.ci svg {
  display: block;
}
.form { display:flex; flex-direction:column; gap:14px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fg { display:flex; flex-direction:column; gap:7px; }
.fl {
  font-size:10px; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  color:var(--muted);
}
.fi {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:7px;
  padding:14px 18px;
  color:var(--white);
  font-family:'Inter',sans-serif;
  font-size:14px; font-weight:300;
  outline:none; resize:none;
  transition:border-color .2s;
}
.fi:focus { border-color:rgba(200,255,0,.38); }
.fi::placeholder { color:rgba(240, 237, 232, 0.44); }
.fsub {
  background:var(--accent); color:#000;
  border:none; border-radius:5px;
  padding:16px 36px; width:100%;
  font-family:'Inter',sans-serif;
  font-size:12px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase;
  cursor:pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: opacity .2s, transform .2s, box-shadow .2s;
}
.fsub:hover { opacity:.9; transform:translateY(-2px); box-shadow:0 12px 36px rgba(200,255,0,.22); }

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
footer {
  background: #c8ff00;
  color: #000;
  border-top:1px solid var(--border);
  padding:72px max(var(--gutter), calc((100% - var(--max-w)) / 2)) 0;
}
.footer-top {
  display:grid;
  grid-template-columns:auto auto 1fr;
  gap:48px;
  padding-bottom:56px;
  width: 100%;
}
.f-logo-img {
  height:100px; width:auto; display:block; margin-bottom:20px;
}
.f-logo-name {
  color:var(--white);
}
.f-logo { font-size:14px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; }
.f-logo em { color:var(--accent); font-style:normal; }
.f-logo svg { display: block; margin-bottom: 16px; }
.footer-col-logo { width:fit-content;}
.footer-col-links h4 {
  font-size:10px; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  color:var(--bg);
  display:flex; align-items:center; gap:8px;
  margin-bottom:24px;
}
.footer-col-links h4::before {
  content:''; width:16px; height:1px; background:var(--bg);
}
.f-links {
  list-style:none;
  display:flex; flex-direction:column; gap:14px;
}
.f-links a {
  font-size:13px; font-weight:300;
  color:var(--bg); text-decoration:none;
  letter-spacing:.3px;
  transition:color .2s, padding-left .2s;
  display:inline-block;
}
.f-links a:hover { color:var(--bg); padding-left:6px; }
.footer-bottom {
  border-top:1px solid var(--bg);
  padding:24px 0;
  display:flex; align-items:center; justify-content:space-between;
}
.footer-col-extra {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}
.f-copy {
  font-size:11px; font-weight:300;
  color:var(--bg); letter-spacing:.3px;
}
.f-copy em { color:var(--bg); font-style:normal; }

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media(max-width:900px){
  nav { padding:0 20px; }
  .nav-links,.nav-btn { display:none; }
  section { padding:80px 20px; }
  #hero { padding:0 20px 64px; }
  .hero-foot { flex-direction:column; align-items:flex-start; gap:28px; }
  .s-head { flex-direction:column; gap:24px; }
  .srv-grid,.price-grid { grid-template-columns:1fr; }
  .proj-grid { grid-template-columns:1fr; }
  .proj-card.wide { grid-column:span 1; }
  .proc-row { grid-template-columns:44px 1fr; }
  .proc-dur { display:none; }
  .testi-grid { grid-template-columns:1fr; }
  .testi-card.hero-card { grid-column:1; display:flex; flex-direction:column; gap:36px; }
  .testi-right { border-left:none; padding-left:0; border-top:1px solid var(--border); padding-top:36px; }
  .contact-wrap { grid-template-columns:1fr; gap:48px; }
  .form-row { grid-template-columns:1fr; }
  footer { padding:48px 20px 0; }
  .footer-top { grid-template-columns:1fr 1fr; gap:40px; }
  .footer-bottom { flex-direction:column; gap:12px; text-align:center; }
  .footer-col-logo { grid-column: 1 / -1; width: 100%;display: flex;
  justify-content: center; /* Centre horizontalement */
  align-items: center;     /* Centre verticalement */}
  body { cursor:auto; }
  .cursor-dot,.cursor-circle { display:none; }
}
