/* ============ RESET & BASE ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'DM Sans',sans-serif;
  background:#080808;
  color:#F0F0F0;
  line-height:1.6;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;
}
:root{
  --bg:#080808;
  --bg-2:#0D0D0D;
  --bg-3:#050505;
  --surface:#111111;
  --accent:#FF6B35;
  --accent-soft:rgba(255,107,53,.6);
  --gold:#FFC36B;
  --magenta:#FF4D9D;
  --violet:#9B6BFF;
  --text:#F0F0F0;
  --muted:#6B6B6B;
  --border:rgba(255,255,255,.06);
  --border-2:rgba(255,255,255,.12);
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea{font:inherit;color:inherit;background:none;border:0;outline:0;width:100%}

/* Noise grain overlay */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  opacity:.035;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* Typography */
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.05;color:var(--text)}
.mono{font-family:'JetBrains Mono',monospace;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
p{color:#C8C8C8}

/* Container */
.wrap{width:100%;max-width:1240px;margin-inline:auto;padding-inline:24px}
@media(min-width:768px){.wrap{padding-inline:40px}}

/* Selection */
::selection{background:var(--accent);color:#080808}

/* Focus */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

/* Reading progress bar */
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:200;transition:width .1s linear;box-shadow:0 0 12px var(--accent)}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:background .25s,backdrop-filter .25s,border-color .25s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{background:rgba(8,8,8,.72);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom-color:var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.15rem;letter-spacing:-.02em}
.brand svg{flex:0 0 auto}
.brand img{flex:0 0 auto;height:32px;width:auto;display:block}
.brand span em{color:var(--accent);font-style:normal}
.nav-links{display:none;gap:36px;align-items:center}
.nav-links a{font-size:.92rem;color:#BDBDBD;transition:color .2s;position:relative}
.nav-links a:hover{color:#fff}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--accent);transition:width .25s ease}
.nav-links a:hover::after{width:100%}
.nav-cta{display:none}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 22px;border-radius:999px;
  font-size:.9rem;font-weight:500;
  transition:transform .2s,box-shadow .25s,background .25s,border-color .25s;
  border:1px solid transparent;
  white-space:nowrap;
}
.btn-primary{background:var(--accent);color:#0A0A0A;font-weight:600}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 0 4px rgba(255,107,53,.18),0 8px 30px rgba(255,107,53,.35)}
.btn-ghost{border-color:var(--border-2);color:#EFEFEF}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.btn svg{width:14px;height:14px}
.burger{display:flex;flex-direction:column;gap:5px;padding:10px;border-radius:8px;border:1px solid var(--border)}
.burger span{display:block;width:22px;height:1.5px;background:#EAEAEA;transition:transform .25s,opacity .2s}
.burger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
@media(min-width:1024px){
  .nav-links{display:flex}
  .nav-cta{display:inline-flex!important}
  .burger{display:none}
}

/* Mobile overlay menu */
.menu-overlay{
  position:fixed;inset:0;z-index:90;
  background:rgba(8,8,8,.96);backdrop-filter:blur(24px);
  opacity:0;pointer-events:none;transition:opacity .3s;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:30px;
}
.menu-overlay.is-open{opacity:1;pointer-events:auto}
.menu-overlay a{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.7rem,7vw,2.4rem);font-weight:600;color:#EFEFEF}
.menu-overlay a:hover{color:var(--accent)}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:100vh;
  padding:140px 0 140px;
  display:flex;align-items:center;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.08) 1px, transparent 0);
  background-size:32px 32px;
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%, black 30%, transparent 75%);
  mask-image:radial-gradient(ellipse 70% 60% at 50% 40%, black 30%, transparent 75%);
  z-index:0;
}
.hero::after{
  content:"";position:absolute;left:50%;top:38%;transform:translate(-50%,-50%);
  width:900px;height:900px;max-width:120vw;
  background:radial-gradient(circle, rgba(255,107,53,.22) 0%, rgba(255,107,53,0) 60%);
  filter:blur(20px);z-index:0;pointer-events:none;
}
.hero-inner{position:relative;z-index:2;max-width:1000px}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:999px;
  border:1px solid var(--border-2);
  background:rgba(255,255,255,.02);
  font-family:'JetBrains Mono',monospace;font-size:.7rem;
  text-transform:uppercase;letter-spacing:.16em;color:#D1D1D1;
  margin-bottom:32px;
}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:#10B981;box-shadow:0 0 0 0 rgba(16,185,129,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.7)}70%{box-shadow:0 0 0 10px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}

.hero h1{
  font-size:clamp(2.6rem,6.4vw,5.4rem);
  font-weight:800;letter-spacing:-.035em;
  line-height:1;margin-bottom:28px;
  max-width:14ch;
}
.hero h1 em{font-style:normal;background:linear-gradient(95deg,var(--accent),var(--gold) 30%,var(--magenta) 65%,var(--violet));background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:heroShimmer 7s ease-in-out infinite}
@keyframes heroShimmer{50%{background-position:100% 0}}
.hero h1 .line{display:block}
.hero-sub{font-size:clamp(1.05rem,2vw,1.3rem);color:#A8A8A8;max-width:640px;margin-bottom:44px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-meta{margin-top:60px;display:flex;flex-wrap:wrap;gap:30px 50px;color:var(--muted)}
.hero-meta div{display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em}
.hero-meta svg{width:14px;height:14px;color:var(--accent)}

.scroll-ind{position:absolute;bottom:24px;right:32px;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px;z-index:2}
.scroll-ind .bar{width:1px;height:36px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollPulse 1.8s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(.4);opacity:.5}50%{transform:scaleY(1);opacity:1}}

/* ---- Hero : aura magique + étincelles ---- */
.hero-aura{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-aura .ha{position:absolute;border-radius:50%;filter:blur(130px)}
.hero-aura .ha1{width:46vw;height:46vw;background:rgba(255,107,53,.16);top:-16%;left:-12%;animation:haBreathe 13s ease-in-out infinite}
.hero-aura .ha2{width:42vw;height:42vw;background:rgba(155,107,255,.14);bottom:-18%;right:-12%;animation:haBreathe 16s ease-in-out infinite reverse}
.hero-aura .ha3{width:32vw;height:32vw;background:rgba(255,77,157,.10);top:28%;right:24%;animation:haBreathe 18s ease-in-out infinite}
@keyframes haBreathe{50%{transform:scale(1.14)}}
#heroFx{position:absolute;inset:0;width:100%;height:100%}

/* ---- Fond magique pleine page (pages internes) ---- */
.bg-fx{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.bg-fx .ha{position:absolute;border-radius:50%;filter:blur(140px)}
.bg-fx .ha1{width:46vw;height:46vw;background:rgba(255,107,53,.14);top:-16%;left:-12%;animation:haBreathe 14s ease-in-out infinite}
.bg-fx .ha2{width:42vw;height:42vw;background:rgba(155,107,255,.12);bottom:-18%;right:-12%;animation:haBreathe 17s ease-in-out infinite reverse}
.bg-fx .ha3{width:34vw;height:34vw;background:rgba(255,77,157,.09);top:34%;right:22%;animation:haBreathe 19s ease-in-out infinite}
#bgFx{position:absolute;inset:0;width:100%;height:100%}

/* ============ BRAND BANNER ============ */
.brand-banner{background:#0A0A0A;border-block:1px solid var(--border);padding:80px 0;text-align:center}
.brand-name{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:clamp(2.2rem,6vw,4rem);letter-spacing:-.02em;color:#8a8a8a}

/* ============ SECTIONS ============ */
section{position:relative;z-index:2}
.section{padding:120px 0}
.section-head{max-width:780px;margin-bottom:64px}
.section-head .mono{margin-bottom:20px;display:block;color:var(--accent)}
.section-head h2{font-size:clamp(2rem,5vw,3.4rem);font-weight:700;margin-bottom:20px}
.section-head h2 em{color:var(--accent);font-style:normal}
.section-head p{font-size:1.05rem;color:#A8A8A8;max-width:600px}

/* ============ SERVICES ============ */
.services-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.services-grid{grid-template-columns:repeat(3,1fr)}}
.services-grid-2{max-width:920px}
@media(min-width:1100px){.services-grid-2{grid-template-columns:repeat(2,1fr)}}
.card{
  position:relative;
  padding:36px 32px;border-radius:8px;
  background:rgba(17,17,17,.55);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--border);
  transition:transform .3s ease,border-color .3s,box-shadow .35s;
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:8px;padding:1px;
  background:linear-gradient(135deg,rgba(255,107,53,.4),transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.card:hover{transform:scale(1.015);border-color:rgba(255,107,53,.35);box-shadow:0 0 0 1px rgba(255,107,53,.15),0 30px 60px -20px rgba(255,107,53,.15)}
.card:hover::before{opacity:1}
.card .icon-wrap{width:48px;height:48px;border-radius:8px;border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--accent)}
.card .icon-wrap svg{width:22px;height:22px}
.card h3{font-size:1.35rem;margin-bottom:14px}
.card p{font-size:.95rem;color:#A8A8A8;margin-bottom:22px}
.card ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.card ul li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:#C8C8C8}
.card ul li::before{content:"";flex:0 0 auto;width:5px;height:5px;border-radius:50%;background:var(--accent);margin-top:9px}
.tag{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;padding:6px 12px;border-radius:4px;border:1px solid var(--border-2);color:#D8D8D8;background:rgba(255,255,255,.02)}

/* ============ PROCESS ============ */
.process{background:#0D0D0D;border-block:1px solid var(--border)}
.steps{display:grid;grid-template-columns:1fr;gap:36px;position:relative}
@media(min-width:768px){.steps{grid-template-columns:repeat(2,1fr);gap:40px}}
@media(min-width:1100px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{position:relative;padding:8px 0}
.step .num{font-family:'Space Grotesk',sans-serif;font-size:4rem;font-weight:700;color:#1A1A1A;line-height:1;margin-bottom:18px;background:linear-gradient(135deg,rgba(255,107,53,.7),rgba(255,107,53,.15));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.step .ico{width:36px;height:36px;border:1px solid var(--border-2);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--accent)}
.step .ico svg{width:18px;height:18px}
.step h3{font-size:1.2rem;margin-bottom:10px}
.step p{font-size:.92rem;color:#A0A0A0}
@media(min-width:1100px){
  .step:not(:last-child)::after{
    content:"";position:absolute;top:30px;right:-22px;
    width:36px;border-top:1.5px dashed rgba(255,107,53,.3);
  }
}

/* ============ RÉALISATIONS ============ */
.works{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:900px){.works{grid-template-columns:1.4fr 1fr;grid-template-rows:auto auto}}
.work{
  position:relative;display:flex;flex-direction:column;justify-content:space-between;
  padding:38px 32px;border-radius:10px;
  border:1px solid var(--border);
  min-height:280px;overflow:hidden;
  transition:transform .35s,border-color .35s,box-shadow .35s;
}
.work-1{grid-row:span 2;min-height:580px;background:radial-gradient(circle at 80% 10%,rgba(255,107,53,.18),transparent 55%),#0F0F0F}
.work-2{background:radial-gradient(circle at 100% 100%,rgba(255,107,53,.10),transparent 60%),#0E0E0E}
.work-3{background:radial-gradient(circle at 0% 100%,rgba(255,107,53,.10),transparent 60%),#0E0E0E}
.work:hover{transform:translateY(-4px);border-color:rgba(255,107,53,.3);box-shadow:0 30px 60px -30px rgba(255,107,53,.25)}
.work .cat{font-family:'JetBrains Mono',monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:18px}
.work h3{font-size:clamp(1.4rem,3vw,2rem);margin-bottom:14px}
.work-1 h3{font-size:clamp(1.8rem,4vw,2.8rem)}
.work p{font-size:.95rem;color:#A8A8A8;margin-bottom:24px;max-width:520px}
.work .tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.work .arrow{position:absolute;top:32px;right:32px;width:42px;height:42px;border-radius:50%;border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;color:#EEE;transition:background .25s,border-color .25s,transform .25s}
.work:hover .arrow{background:var(--accent);border-color:var(--accent);color:#0A0A0A;transform:rotate(-45deg)}
.work .arrow svg{width:16px;height:16px}

/* ============ ABOUT ============ */
.about-grid{display:grid;grid-template-columns:1fr;gap:60px;align-items:center}
@media(min-width:900px){.about-grid{grid-template-columns:1.1fr 1fr;gap:80px}}
.about p{color:#B5B5B5;margin-bottom:18px}
.about p strong{color:#F5F5F5;font-weight:500}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;padding:40px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.012)}
.stat .num{font-family:'Space Grotesk',sans-serif;font-size:clamp(2.4rem,5vw,3.6rem);font-weight:700;color:var(--accent);line-height:1}
.stat .lbl{margin-top:10px;font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}

/* ============ TESTIMONIALS ============ */
.testi-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:768px){.testi-grid{grid-template-columns:repeat(3,1fr)}}
.testi{padding:34px 30px;border:1px solid var(--border);border-radius:10px;background:rgba(17,17,17,.4);backdrop-filter:blur(10px);transition:border-color .25s,transform .25s}
.testi:hover{border-color:rgba(255,107,53,.3);transform:translateY(-3px)}
.stars{display:flex;gap:3px;margin-bottom:18px;color:var(--accent)}
.stars svg{width:14px;height:14px}
.testi q{display:block;font-style:italic;font-size:1rem;color:#DCDCDC;margin-bottom:22px;line-height:1.55;quotes:"\201C" "\201D"}
.testi-author{display:flex;align-items:center;gap:14px}
.avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.95rem;color:#0A0A0A;flex:0 0 auto}
.av-1{background:linear-gradient(135deg,#FF6B35,#F59E0B)}
.av-2{background:linear-gradient(135deg,#10B981,#06B6D4)}
.av-3{background:linear-gradient(135deg,#A78BFA,#EC4899)}
.testi-author .name{font-weight:500;color:#F2F2F2;font-size:.95rem}
.testi-author .role{font-size:.8rem;color:var(--muted);font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.1em}

/* ============ FAQ ============ */
.faq-list{max-width:880px;display:flex;flex-direction:column;gap:10px}
.faq-item{border:1px solid var(--border);border-radius:8px;background:rgba(17,17,17,.3);transition:background .25s,border-color .25s}
.faq-item[open]{background:rgba(255,107,53,.04);border-color:rgba(255,107,53,.25)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:22px 24px;gap:20px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;color:#F0F0F0}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .plus{flex:0 0 auto;width:22px;height:22px;position:relative;transition:transform .3s}
.faq-item .plus::before,.faq-item .plus::after{content:"";position:absolute;background:var(--accent);left:50%;top:50%}
.faq-item .plus::before{width:12px;height:1.5px;transform:translate(-50%,-50%)}
.faq-item .plus::after{width:1.5px;height:12px;transform:translate(-50%,-50%);transition:transform .3s}
.faq-item[open] .plus::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item .answer{padding:0 24px 24px;color:#B5B5B5;font-size:.95rem;line-height:1.65;max-width:720px}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:50px}
@media(min-width:900px){.contact-grid{grid-template-columns:1fr 1.1fr;gap:80px}}
.contact-info{display:flex;flex-direction:column;gap:30px}
.contact-info h2{font-size:clamp(2rem,4.5vw,3rem);margin-bottom:16px}
.contact-info h2 em{color:var(--accent);font-style:normal}
.contact-info > p{color:#B5B5B5;font-size:1.02rem;max-width:480px;margin-bottom:14px}
.contact-list{display:flex;flex-direction:column;gap:18px;margin-top:8px}
.contact-list a{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);transition:color .2s,border-color .2s}
.contact-list a:hover{color:var(--accent);border-color:rgba(255,107,53,.4)}
.contact-list .ic{width:38px;height:38px;border:1px solid var(--border-2);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--accent);flex:0 0 auto}
.contact-list .ic svg{width:16px;height:16px}
.contact-list .lbl{font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);display:block;margin-bottom:3px}

.form{background:rgba(17,17,17,.55);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:12px;padding:36px;display:flex;flex-direction:column;gap:18px;position:relative;overflow:hidden}
.form::before{content:"";position:absolute;inset:0;border-radius:12px;padding:1px;background:linear-gradient(135deg,rgba(255,107,53,.35),transparent 55%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
.field input,.field textarea{padding:14px 16px;border:1px solid var(--border-2);border-radius:6px;background:rgba(0,0,0,.4);transition:border-color .2s,background .2s}
.field input:focus,.field textarea:focus{border-color:var(--accent);background:rgba(255,107,53,.04)}
.field textarea{resize:vertical;min-height:140px;font-family:inherit}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.row-2{grid-template-columns:1fr}}
.honeypot{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;opacity:0}
.form-foot{display:flex;flex-direction:column;gap:16px;margin-top:6px}
.form-msg{font-size:.85rem;min-height:18px;color:var(--muted)}
.form-msg.is-err{color:#F87171}
.form-msg.is-ok{color:#10B981}
.rgpd{font-size:.78rem;color:var(--muted);line-height:1.5}
.rgpd a{color:#9A9A9A;text-decoration:underline;text-underline-offset:3px}
.rgpd a:hover{color:var(--accent)}

/* ============ FOOTER ============ */
footer{background:#050505;border-top:1px solid var(--border);padding:80px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:50px;margin-bottom:60px}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:40px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-brand{grid-column:span 1}
@media(max-width:900px){.foot-brand{grid-column:1/-1}}
.foot-brand p{margin-top:18px;color:#888;font-size:.92rem;max-width:280px}
.foot-col h4{font-family:'JetBrains Mono',monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:#9A9A9A;font-weight:500;margin-bottom:20px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.foot-col a{font-size:.92rem;color:#B5B5B5;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-base{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:30px;border-top:1px solid var(--border);font-size:.82rem;color:var(--muted);flex-wrap:wrap}
.foot-base address{font-style:normal}

/* ============ LEGAL ============ */
.legal{padding:160px 0 120px;background:#0A0A0A;border-top:1px solid var(--border)}
.legal h2{font-size:clamp(2rem,4.5vw,2.8rem);margin-bottom:14px}
.legal h2 em{color:var(--accent);font-style:normal}
.legal .lead{font-family:'JetBrains Mono',monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:18px;display:block}
.legal-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:50px}
@media(min-width:900px){.legal-grid{grid-template-columns:repeat(2,1fr)}}
.legal-block{padding:32px;border:1px solid var(--border);border-radius:10px;background:rgba(17,17,17,.4)}
.legal-block:last-child{grid-column:1/-1}
.legal-block h3{font-family:'Space Grotesk',sans-serif;font-size:1.2rem;font-weight:600;margin-bottom:18px;color:#F0F0F0;display:flex;align-items:center;gap:10px}
.legal-block h3 .num{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--accent);background:rgba(255,107,53,.1);padding:4px 8px;border-radius:4px;letter-spacing:.1em}
.legal-block p,.legal-block li{font-size:.92rem;color:#B5B5B5;line-height:1.7}
.legal-block ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px}
.legal-block dl{display:grid;grid-template-columns:auto 1fr;gap:8px 18px}
.legal-block dt{font-family:'JetBrains Mono',monospace;font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;padding-top:4px}
.legal-block dd{color:#D8D8D8;font-size:.94rem}
.placeholder{color:#8A8A8A;font-family:'JetBrains Mono',monospace;font-size:.85rem;padding:2px 6px;background:rgba(255,255,255,.04);border-radius:3px}
.legal-block.sub{margin-top:24px;border-color:rgba(255,107,53,.2);background:rgba(255,107,53,.03)}
.legal-block h4{font-family:'Space Grotesk',sans-serif;font-size:1rem;font-weight:600;margin:18px 0 10px;color:#EAEAEA}

/* ============ PAGE HERO (pages internes) ============ */
.page-hero{position:relative;padding:160px 0 70px;overflow:hidden;border-bottom:1px solid var(--border)}
.page-hero .ha{position:absolute;border-radius:50%;filter:blur(130px);pointer-events:none;z-index:0}
.page-hero .pa1{width:40vw;height:40vw;background:rgba(255,107,53,.14);top:-20%;left:-10%}
.page-hero .pa2{width:34vw;height:34vw;background:rgba(155,107,255,.12);top:-10%;right:-8%}
.page-hero .inner{position:relative;z-index:2;max-width:820px}
.page-hero .lead{display:block;margin-bottom:16px;color:var(--accent)}
.page-hero h1{font-size:clamp(2.2rem,5.5vw,3.8rem);font-weight:800;letter-spacing:-.03em;margin-bottom:18px}
.page-hero h1 em{font-style:normal;background:linear-gradient(95deg,var(--accent),var(--gold) 30%,var(--magenta) 65%,var(--violet));background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:heroShimmer 7s ease-in-out infinite}
.page-hero p{font-size:1.05rem;color:#A8A8A8;max-width:620px}
.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:.85rem;margin-bottom:30px;transition:color .2s}
.back-link:hover{color:var(--accent)}
.back-link::before{content:"\2190";font-size:1rem}

/* ============ TEASERS (accueil) ============ */
.teasers{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:860px){.teasers{grid-template-columns:repeat(2,1fr)}}
.teaser{position:relative;display:flex;flex-direction:column;justify-content:space-between;gap:26px;padding:40px 36px;border-radius:12px;border:1px solid var(--border);background:rgba(17,17,17,.5);overflow:hidden;transition:transform .3s,border-color .3s,box-shadow .35s}
.teaser::before{content:"";position:absolute;inset:0;border-radius:12px;padding:1px;background:linear-gradient(135deg,rgba(255,107,53,.4),transparent 60%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s;pointer-events:none}
.teaser:hover{transform:translateY(-4px);border-color:rgba(255,107,53,.35);box-shadow:0 30px 60px -30px rgba(255,107,53,.22)}
.teaser:hover::before{opacity:1}
.teaser .mono{color:var(--accent);margin-bottom:16px;display:block}
.teaser h3{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:14px}
.teaser p{font-size:.98rem;color:#A8A8A8;margin-bottom:8px}
.teaser .more{display:inline-flex;align-items:center;gap:10px;color:#EFEFEF;font-weight:500;font-size:.95rem;transition:gap .2s,color .2s}
.teaser:hover .more{color:var(--accent);gap:16px}
.teaser .more svg{width:16px;height:16px}

/* ============ REVEAL ANIMATIONS ============ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.is-in{opacity:1;transform:none}
.fade-up{opacity:0;transform:translateY(16px);animation:fadeUp .7s ease forwards}
@keyframes fadeUp{to{opacity:1;transform:none}}
.fade-up.d1{animation-delay:.1s}
.fade-up.d2{animation-delay:.2s}
.fade-up.d3{animation-delay:.35s}
.fade-up.d4{animation-delay:.5s}
.fade-up.d5{animation-delay:.65s}

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

/* ============ SMALL UTILITIES ============ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
