:root{
  --ink:#06070f;
  --ink-2:#0f1124;
  --ink-3:#1a1d3a;
  --line:rgba(255,255,255,.08);
  --line-dark:rgba(10,11,30,.08);
  --blue:#4f7cff;
  --blue-2:#6c9bff;
  --blue-light:#eaf0ff;
  --neon:#defe00;
  --neon-2:#defe00;
  --orange:#ff7a45;
  --green:#22c55e;
  --text:#1a1d2e;
  --text-2:#4a4f6b;
  --text-3:#7a7f95;
  --bg:#fafbff;
  --white:#ffffff;
  --radius:14px;
  --radius-lg:20px;
  --shadow:0 10px 30px rgba(15,23,42,.06);
  --shadow-lg:0 25px 60px rgba(15,23,42,.12);
  --ff-cond:"Barlow Condensed",sans-serif;
  --ff-serif:"Fraunces",serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,system-ui,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}

.wrap{max-width:1200px;margin:0 auto;padding:0 24px}

/* ===== NAV ===== */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-dark);
  transition:all .3s;
}
.nav-in{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 24px}
.logo{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:20px;letter-spacing:1.5px;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;line-height:1}
.logo .lmark{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;
  background:var(--ink);color:var(--neon);
  border-radius:7px;
  font-size:15px;font-weight:900;
  letter-spacing:0;
}
.logo em{background:var(--neon);color:var(--ink);font-style:normal;font-weight:900;padding:1px 5px;border-radius:3px}
.logo .lstu{color:var(--text-3);font-weight:600}
.nav-links{display:flex;gap:28px;list-style:none;margin-left:32px}
.nav-links a{font-size:14px;font-weight:500;color:var(--text-2);transition:color .2s}
.nav-links a:hover{color:var(--blue)}
.nav-cta{
  background:var(--ink);color:var(--white);
  padding:11px 22px;border-radius:10px;
  font-size:13px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;
  transition:all .2s;
  display:inline-flex;align-items:center;gap:8px;
  flex-shrink:0;white-space:nowrap;
}
.nav-cta:hover{background:var(--neon);color:#000;transform:translateY(-1px);box-shadow:0 6px 20px rgba(222,254,0,.4)}
.nav-cta-short{display:none}
@media (max-width:760px){
  .nav-cta-full{display:none}
  .nav-cta-short{display:inline}
  .nav-cta{padding:9px 14px;font-size:12px;letter-spacing:0}
}
@media (max-width:560px){
  .nav-cta{padding:8px 12px;font-size:11px}
  .nav-cta i{font-size:11px}
}
.nav-toggle{display:none}

/* ===== HERO - FUTURISTIC + FLOW FIELD + PHOTO ===== */
.hero{
  position:relative;
  min-height:100vh;
  background:#000;
  color:var(--white);
  overflow:hidden;
  display:flex;align-items:center;
  padding:120px 0 80px;
}
.hero-photo{
  position:absolute;inset:0;
  background:#000;
  z-index:0;
}
.hero-photo img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 20%;
  opacity:.55;
  filter:grayscale(.25) contrast(1.1) brightness(.75);
}
.hero-photo::after{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(6,7,15,.4) 0%,rgba(6,7,15,.2) 30%,rgba(6,7,15,.85) 80%,rgba(6,7,15,1) 100%),
    linear-gradient(90deg,rgba(6,7,15,.85) 0%,rgba(6,7,15,.3) 50%,rgba(6,7,15,.65) 100%);
}
#flowfield{
  position:absolute;inset:0;
  z-index:1;
  pointer-events:none;
  opacity:.55;
  mix-blend-mode:screen;
}
.hero-glow-1{
  position:absolute;
  top:20%;left:50%;
  width:800px;height:800px;
  background:radial-gradient(circle,rgba(222,254,0,.10),transparent 60%);
  filter:blur(60px);
  z-index:1;pointer-events:none;
}
.hero-glow-2{
  position:absolute;
  bottom:0;right:0;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(79,124,255,.18),transparent 60%);
  filter:blur(60px);
  z-index:1;pointer-events:none;
}

.hero .wrap{position:relative;z-index:3;width:100%}

.hero-content{max-width:880px}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;letter-spacing:2.5px;
  text-transform:uppercase;
  color:var(--neon);
  margin-bottom:30px;
  background:rgba(222,254,0,.06);
  border:1px solid rgba(222,254,0,.25);
  padding:8px 16px;
  border-radius:30px;
  backdrop-filter:blur(10px);
}
.eyebrow .live{
  width:7px;height:7px;border-radius:50%;
  background:var(--neon);
  box-shadow:0 0 12px var(--neon);
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.6;transform:scale(1.4)}
}

.hero h1{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:clamp(58px,11vw,160px);
  line-height:.85;
  letter-spacing:-3px;
  text-transform:uppercase;
  margin-bottom:32px;
  position:relative;
}
.hero h1 .line{display:block;overflow:hidden;position:relative}
.hero h1 .line span{display:inline-block}
.hero h1 .accent{
  background:linear-gradient(90deg,var(--neon) 0%,var(--neon-2) 50%,var(--neon) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:shine 9s linear infinite;
}
@keyframes shine{
  0%{background-position:0% center}
  100%{background-position:200% center}
}
.hero h1 .outline{
  -webkit-text-stroke:2px rgba(255,255,255,.4);
  -webkit-text-fill-color:transparent;
  color:transparent;
}

.hero-tag{
  font-size:clamp(15px,1.4vw,18px);
  color:rgba(255,255,255,.78);
  margin-bottom:40px;
  max-width:580px;
  line-height:1.55;
}
.hero-tag strong{color:var(--white);font-weight:600}
.hero-tag .neon-text{color:var(--neon);font-weight:700}

.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:50px}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 30px;
  border-radius:12px;
  font-weight:700;font-size:14px;
  letter-spacing:.5px;
  text-transform:uppercase;
  transition:all .25s;
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.btn-primary{
  background:var(--neon);
  color:#000;
  box-shadow:0 0 0 0 rgba(222,254,0,.5);
}
.btn-primary:hover{
  background:var(--neon-2);
  transform:translateY(-3px);
  box-shadow:0 15px 40px rgba(222,254,0,.4),0 0 0 4px rgba(222,254,0,.15);
}
.btn-ghost{
  background:rgba(255,255,255,.05);
  color:var(--white);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:var(--neon);color:var(--neon)}

.hero-stats{
  display:flex;gap:0;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:30px;
  max-width:680px;
}
.h-stat{
  flex:1;min-width:130px;
  padding:0 24px 0 0;
  border-right:1px solid rgba(255,255,255,.08);
}
.h-stat:last-child{border-right:none}
.h-stat:not(:first-child){padding-left:24px}
.h-stat-num{
  font-family:'Barlow Condensed',sans-serif;
  font-size:42px;font-weight:900;
  line-height:1;
  letter-spacing:-1px;
  color:var(--white);
  margin-bottom:4px;
}
.h-stat-num em{color:var(--neon);font-style:normal}
.h-stat-lbl{
  font-size:11px;
  color:rgba(255,255,255,.55);
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-weight:600;
}

/* Decorative racing stripe */
.race-stripe{
  position:absolute;
  top:0;right:5%;
  width:2px;height:100%;
  background:linear-gradient(180deg,transparent,var(--neon) 30%,var(--neon) 70%,transparent);
  z-index:2;
  opacity:.3;
}
.race-stripe-2{
  position:absolute;
  top:0;right:8%;
  width:1px;height:100%;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.3),transparent);
  z-index:2;
}

/* Vertical text */
.hero-vside{
  position:absolute;
  right:30px;top:50%;transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;
  font-size:11px;font-weight:600;
  letter-spacing:6px;
  color:rgba(255,255,255,.35);
  text-transform:uppercase;
  z-index:3;
}
.hero-vside .live-dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--neon);margin-right:14px;vertical-align:middle;
  box-shadow:0 0 10px var(--neon);
}

/* ===== MARQUEE - Perspective 3D ===== */
.marquee{
  background:var(--ink-2);
  color:rgba(255,255,255,.5);
  padding:24px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
  white-space:nowrap;
  perspective:600px;
  position:relative;
}
.marquee::before,.marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg,var(--ink-2),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--ink-2),transparent)}
.marquee-track{
  display:inline-flex;gap:50px;
  animation:marquee 58s linear infinite;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:20px;letter-spacing:1.5px;text-transform:uppercase;
}
.marquee-track span{display:inline-flex;align-items:center;gap:50px}
.marquee-track i{color:var(--neon);font-size:7px}
.marquee-track span:nth-child(2n) i{color:var(--blue-2)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== MARKER HIGHLIGHT (handcrafted underline / highlight) ===== */
.mark{position:relative;display:inline-block;padding:0 .15em;color:#000;z-index:1}
.mark::before{
  content:'';position:absolute;
  inset:.18em -.05em .12em -.05em;
  background:var(--neon);
  z-index:-1;
  transform:skew(-6deg) rotate(-1deg);
  border-radius:2px;
  box-shadow:0 0 0 1px rgba(0,0,0,.05);
}
.mark.blue::before{background:var(--blue-2)}
.mark.outline::before{
  background:transparent;
  border:2px solid var(--neon);
  border-radius:50% / 30%;
  inset:-.1em -.2em -.05em -.2em;
  transform:rotate(-1.5deg);
}

/* ===== BENTO GRID - Pour Qui ===== */
.bento{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:140px;
  gap:14px;
}
.bento-card{
  background:var(--white);
  border:1px solid var(--line-dark);
  border-radius:var(--radius);
  padding:24px;
  position:relative;
  overflow:hidden;
  transition:all .35s cubic-bezier(.22,1,.36,1);
  display:flex;flex-direction:column;justify-content:flex-end;
  cursor:default;
}
.bento-card::after{
  content:'';position:absolute;
  inset:auto -50% -50% auto;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,var(--bc,rgba(79,124,255,.15)),transparent 70%);
  transition:transform .5s,opacity .35s;
  opacity:.5;
  pointer-events:none;
}
.bento-card:hover{
  transform:translateY(-4px);
  border-color:var(--bc-line,var(--blue));
  box-shadow:var(--shadow-lg);
}
.bento-card:hover::after{transform:scale(1.4);opacity:.8}
.bento-card .bc-icon{
  width:42px;height:42px;border-radius:11px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--bc-bg,var(--blue-light));
  color:var(--bc-fg,var(--blue));
  font-size:18px;
  margin-bottom:auto;
}
.bento-card h3{font-size:16px;font-weight:700;margin-bottom:4px;letter-spacing:-.2px}
.bento-card p{font-size:13px;color:var(--text-3);margin:0;line-height:1.45}
.bento-tall{grid-row:span 2}
.bento-wide{grid-column:span 2}
.bento-feature{
  grid-column:span 2;grid-row:span 2;
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 100%);
  color:var(--white);
  border:1px solid var(--ink-3);
}
.bento-feature h3{color:var(--white);font-family:'Barlow Condensed',sans-serif;font-size:32px;font-weight:900;text-transform:uppercase;letter-spacing:-.5px;line-height:.95}
.bento-feature p{color:rgba(255,255,255,.7);font-size:14px}
.bento-feature .bc-icon{background:rgba(222,254,0,.12);color:var(--neon)}
.bento-feature .bc-stat{
  display:flex;gap:18px;margin-top:14px;flex-wrap:wrap;
}
.bento-feature .bc-stat div{
  font-size:11px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1.5px;
}
.bento-feature .bc-stat strong{
  display:block;color:var(--neon);font-family:'Barlow Condensed',sans-serif;
  font-size:26px;font-weight:900;letter-spacing:-.5px;
  margin-bottom:2px;
}

/* ===== TRADES CLOUD ===== */
.trades-cloud{
  margin-top:60px;
  padding:50px 40px;
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 100%);
  border-radius:var(--radius-lg);
  position:relative;overflow:hidden;
  text-align:center;
}
.trades-cloud::before{
  content:'';position:absolute;
  top:-50%;left:50%;transform:translateX(-50%);
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(222,254,0,.06),transparent 70%);
  filter:blur(40px);
  pointer-events:none;
}
.trades-cloud-head{
  margin-bottom:30px;
  position:relative;z-index:2;
}
.trades-cloud-head span{
  display:inline-block;
  font-family:'Geist Mono','Courier New',monospace;
  font-size:11px;font-weight:700;
  letter-spacing:3px;
  color:var(--neon);
  background:rgba(222,254,0,.06);
  border:1px solid rgba(222,254,0,.2);
  padding:8px 18px;border-radius:30px;
}
.trades-pills{
  display:flex;flex-wrap:wrap;
  justify-content:center;gap:8px;
  position:relative;z-index:2;
}
.trades-pills span{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.7);
  padding:7px 14px;
  border-radius:30px;
  font-size:13px;font-weight:500;
  transition:all .25s;
  cursor:default;
  white-space:nowrap;
}
.trades-pills span:hover{
  background:rgba(222,254,0,.08);
  border-color:var(--neon);
  color:var(--neon);
  transform:translateY(-2px);
}
.trades-pills span:last-child{
  background:var(--neon);
  color:#000;
  border-color:var(--neon);
  font-weight:700;
}
.trades-pills span:last-child:hover{
  background:var(--neon-2);transform:translateY(-2px) scale(1.04);
}
@media (max-width:560px){
  .trades-cloud{padding:30px 20px}
  .trades-pills span{font-size:12px;padding:6px 11px}
}

/* ===== TILT CARD effect on .proj ===== */
.proj{transition:transform .15s ease-out, box-shadow .35s, border-color .35s;will-change:transform;transform-style:preserve-3d}
.proj-img,.proj-body{transform:translateZ(0)}
.proj.tilting{transition:transform .05s linear, box-shadow .35s, border-color .35s}
.proj-shine{
  position:absolute;inset:0;
  background:radial-gradient(circle 250px at var(--mx,50%) var(--my,50%),rgba(255,255,255,.08),transparent 60%);
  pointer-events:none;opacity:0;transition:opacity .25s;mix-blend-mode:overlay;z-index:4;
}
.proj:hover .proj-shine{opacity:1}

/* ===== CUSTOM CURSOR (disabled - using native cursor) ===== */
/* The native cursor is shown; .cur-dot/.cur-ring/.cur-label are hidden via v2 override below */
.cur-dot{
  position:fixed;top:0;left:0;
  width:6px;height:6px;border-radius:50%;
  background:var(--neon);
  pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
  transition:width .25s,height .25s,background .25s;
  mix-blend-mode:difference;
  box-shadow:0 0 12px rgba(222,254,0,.4);
}
.cur-ring{
  position:fixed;top:0;left:0;
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.5);
  pointer-events:none;z-index:99998;
  transform:translate(-50%,-50%);
  transition:width .35s,height .35s,border-color .35s,background .35s;
  mix-blend-mode:difference;
}
.cur-dot.hover{width:0;height:0}
.cur-ring.hover{width:64px;height:64px;border-color:var(--neon);background:rgba(222,254,0,.05)}
.cur-ring.click{transform:translate(-50%,-50%) scale(.7)}
.cur-label{
  position:fixed;top:0;left:0;
  background:var(--neon);color:#000;
  font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:5px 10px;border-radius:30px;
  pointer-events:none;z-index:99997;
  transform:translate(20px,20px) scale(0);
  transition:transform .25s cubic-bezier(.22,1,.36,1);
  font-family:'Geist Mono','Courier New',monospace;
  white-space:nowrap;
}
.cur-label.show{transform:translate(20px,20px) scale(1)}
@media (hover:none){.cur-dot,.cur-ring,.cur-label{display:none}}

/* ===== GRAIN OVERLAY ===== */
.grain{
  position:fixed;inset:0;
  pointer-events:none;z-index:9990;
  opacity:.04;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}

/* ===== PRELOADER ===== */
#preloader{
  position:fixed;inset:0;z-index:99999;
  background:#000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .8s cubic-bezier(.22,1,.36,1),visibility 0s linear .8s;
}
#preloader.gone{opacity:0;visibility:hidden}
.pre-mark{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:clamp(70px,12vw,180px);
  color:var(--white);
  letter-spacing:-3px;
  line-height:.9;
  text-transform:uppercase;
  display:flex;gap:0;
  position:relative;
  margin-bottom:32px;
}
.pre-mark span{
  display:inline-block;
  transform:translateY(110%);
  animation:preRise 1s cubic-bezier(.22,1,.36,1) forwards;
}
.pre-mark span.neon{color:var(--neon);text-shadow:0 0 30px rgba(222,254,0,.5)}
@keyframes preRise{to{transform:translateY(0)}}
.pre-bar{
  width:240px;height:1px;
  background:rgba(255,255,255,.1);
  position:relative;overflow:hidden;
}
.pre-bar::before{
  content:'';position:absolute;
  top:0;left:0;height:100%;width:0;
  background:var(--neon);
  animation:preLoad 1.6s cubic-bezier(.65,0,.35,1) forwards .3s;
  box-shadow:0 0 12px var(--neon);
}
@keyframes preLoad{to{width:100%}}
.pre-meta{
  display:flex;justify-content:space-between;
  width:240px;margin-top:14px;
  font-family:'Geist Mono','Courier New',monospace;
  font-size:10px;color:rgba(255,255,255,.4);
  letter-spacing:2px;text-transform:uppercase;
}
.pre-pct{color:var(--neon)}

/* ===== TICKER (animated count-up) ===== */
.ticker[data-target]{font-variant-numeric:tabular-nums}

/* ===== MAGNETIC BUTTONS ===== */
.btn,.nav-cta,.price-cta,.form-submit{will-change:transform}

/* ===== CLIENT LOGOS / TRUSTBAR ===== */
#trustbar{
  background:var(--white);
  padding:50px 0;
  border-top:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
  overflow:hidden;
}
.trust-head{
  text-align:center;
  font-size:11px;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;color:var(--text-3);
  margin-bottom:36px;
}
.trust-track-wrap{
  position:relative;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.trust-track{
  display:inline-flex;gap:60px;
  animation:trust 50s linear infinite;
  font-family:'Barlow Condensed',sans-serif;
  white-space:nowrap;
}
.trust-track .tl{
  display:inline-flex;align-items:center;gap:10px;
  font-size:24px;font-weight:900;letter-spacing:1px;
  text-transform:uppercase;color:var(--text-2);
  transition:color .3s;
}
.trust-track .tl:hover{color:var(--ink)}
.trust-track .tl i{color:var(--text-3);font-size:18px}
.trust-track .tl em{font-style:italic;font-family:'Fraunces','Georgia',serif;font-weight:300}
@keyframes trust{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== TESTIMONIALS ===== */
#temoignages{
  background:var(--ink);color:var(--white);
  position:relative;overflow:hidden;
  padding:100px 0;
}
#temoignages::before{
  content:'';position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 20% 50%,rgba(222,254,0,.06),transparent 50%),
    radial-gradient(ellipse at 80% 50%,rgba(79,124,255,.05),transparent 50%);
  pointer-events:none;
}
#temoignages h2{color:var(--white)}
#temoignages .sec-desc{color:rgba(255,255,255,.65)}

.testi-track-wrap{
  position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.testi-track{
  display:inline-flex;gap:24px;
  animation:testi 92s linear infinite;
  padding:10px 0;
}
.testi-track:hover{animation-play-state:paused}
.testi{
  flex:0 0 380px;
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:30px;
  display:flex;flex-direction:column;
  position:relative;
}
.testi-stars{color:var(--neon);font-size:14px;margin-bottom:14px;letter-spacing:2px}
.testi-quote{
  font-size:15px;line-height:1.6;color:rgba(255,255,255,.8);
  font-family:'Fraunces','Georgia',serif;
  font-style:italic;font-weight:300;
  margin-bottom:24px;
  flex:1;
}
.testi-quote::before{content:'"';color:var(--neon);font-size:36px;line-height:0;vertical-align:-12px;margin-right:6px}
.testi-author{
  display:flex;align-items:center;gap:14px;
  border-top:1px solid var(--line);
  padding-top:18px;
}
.testi-avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--neon),var(--blue));
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:16px;color:#000;
  letter-spacing:.5px;
  flex-shrink:0;
}
.testi-name{font-size:14px;font-weight:700;color:var(--white)}
.testi-role{font-size:12px;color:rgba(255,255,255,.5)}
@keyframes testi{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== H2 mask reveal ===== */
.h2-reveal{display:inline-block;overflow:hidden;line-height:.95}
.h2-reveal>span{display:inline-block;transform:translateY(110%);transition:transform 1s cubic-bezier(.22,1,.36,1)}
.reveal.in .h2-reveal>span{transform:translateY(0)}

/* ===== Smooth nav underlines ===== */
.nav-links a{position:relative}
.nav-links a::after{
  content:'';position:absolute;
  left:0;bottom:-6px;height:2px;width:0;
  background:var(--neon);
  transition:width .3s cubic-bezier(.22,1,.36,1);
}
.nav-links a:hover::after{width:100%}

/* ===== CMD-K palette ===== */
#cmdk{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(10px);
  display:flex;align-items:flex-start;justify-content:center;padding-top:14vh;
  opacity:0;visibility:hidden;
  transition:opacity .25s,visibility 0s linear .25s;
}
#cmdk.open{opacity:1;visibility:visible;transition:opacity .25s}
.cmdk-box{
  width:min(580px,92vw);
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
  overflow:hidden;
  transform:scale(.95);
  transition:transform .25s cubic-bezier(.22,1,.36,1);
}
#cmdk.open .cmdk-box{transform:scale(1)}
.cmdk-input{
  width:100%;
  background:transparent;border:none;outline:none;
  padding:18px 22px;
  color:var(--white);font-size:15px;
  border-bottom:1px solid var(--line);
  font-family:inherit;
}
.cmdk-input::placeholder{color:rgba(255,255,255,.35)}
.cmdk-list{max-height:340px;overflow-y:auto;padding:8px}
.cmdk-item{
  display:flex;align-items:center;gap:14px;
  padding:11px 14px;border-radius:10px;
  font-size:14px;color:rgba(255,255,255,.85);
  cursor:pointer;
}
.cmdk-item.active,.cmdk-item:hover{background:rgba(222,254,0,.08);color:var(--neon)}
.cmdk-item .ki{
  width:28px;height:28px;border-radius:7px;
  background:rgba(255,255,255,.05);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;color:rgba(255,255,255,.6);
}
.cmdk-item.active .ki,.cmdk-item:hover .ki{background:rgba(222,254,0,.12);color:var(--neon)}
.cmdk-item .kbd{
  margin-left:auto;
  font-family:'Geist Mono','Courier New',monospace;
  font-size:10px;color:rgba(255,255,255,.4);
  background:rgba(255,255,255,.04);
  padding:3px 7px;border-radius:5px;
  border:1px solid var(--line);
}
.cmdk-foot{
  border-top:1px solid var(--line);
  padding:10px 16px;
  display:flex;gap:18px;justify-content:flex-end;
  font-size:11px;color:rgba(255,255,255,.4);
  font-family:'Geist Mono','Courier New',monospace;
}
.cmdk-foot kbd{
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  border-radius:4px;padding:2px 6px;font-size:10px;
  margin-right:5px;
}

/* ===== LANGUAGE TOGGLE ===== */
.lang-toggle{
  display:inline-flex;align-items:center;
  background:rgba(0,0,0,.06);
  border:1px solid rgba(10,11,30,.18);
  border-radius:30px;
  padding:3px;
  margin-right:14px;
  font-family:'Geist Mono','Courier New',monospace;
  font-size:11px;font-weight:700;letter-spacing:1px;
}
.lang-toggle button{
  background:none;border:none;
  padding:6px 11px;border-radius:30px;
  cursor:pointer;
  color:var(--ink-3);
  transition:all .25s;
  font:inherit;text-transform:uppercase;
}
.lang-toggle button.active{
  background:var(--neon);color:var(--ink);
}
.lang-toggle button:hover:not(.active){color:var(--neon)}
@media (max-width:900px){
  .lang-toggle{margin-right:10px;padding:2px}
  .lang-toggle button{padding:5px 9px;font-size:10px}
}

/* ===== KEYBOARD HINT (bottom right) ===== */
.kbd-hint{
  position:fixed;bottom:24px;right:24px;
  background:rgba(0,0,0,.75);backdrop-filter:blur(12px);
  border:1px solid var(--line);
  padding:8px 14px;
  border-radius:30px;
  font-family:'Geist Mono','Courier New',monospace;
  font-size:11px;color:rgba(255,255,255,.6);
  z-index:80;display:flex;align-items:center;gap:10px;
  transition:transform .25s,opacity .25s;
}
.kbd-hint kbd{
  background:rgba(255,255,255,.08);
  border:1px solid var(--line);
  border-radius:4px;padding:2px 6px;
  font-size:10px;
}
@media (max-width:900px){.kbd-hint{display:none}}

/* ===== PROCESS LINE ===== */
.steps{position:relative}
.steps-line{
  position:absolute;
  top:46px;left:5%;right:5%;
  height:1px;background:var(--line-dark);
  z-index:0;
}
.steps-line-fill{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--blue),var(--neon));
  transition:width .8s cubic-bezier(.22,1,.36,1);
}
.reveal.in .steps-line-fill{width:100%}
.step{position:relative;z-index:2;background:rgba(255,255,255,0.55)}

/* ===== SECTION DIVIDER (diagonal) ===== */
.divider-diag{
  height:0;position:relative;z-index:5;
}
.divider-diag::before{
  content:'';position:absolute;
  top:-1px;left:0;right:0;height:80px;
  background:inherit;
  clip-path:polygon(0 100%,100% 0,100% 100%);
}

/* ===== SECTIONS ===== */
.sec{padding:100px 0;position:relative}
.sec-head{text-align:center;margin-bottom:60px;max-width:720px;margin-left:auto;margin-right:auto}
.sec-eyebrow{
  font-size:13px;font-weight:600;letter-spacing:2px;
  text-transform:uppercase;color:var(--blue);margin-bottom:14px;
}
.sec h2{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  font-size:clamp(36px,5vw,56px);
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.5px;
  margin-bottom:18px;
}
.sec h2 .accent{color:var(--neon)}
.sec:not(.bg-dark) h2 .accent{color:#0c0e1a;text-decoration:underline;text-decoration-color:var(--neon);text-underline-offset:6px;text-decoration-thickness:3px}
.sec-desc{font-size:17px;color:var(--text-2)}

/* ===== POUR QUI ===== */
.who-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;
}
.who-card{
  background:var(--white);
  border:1px solid var(--line-dark);
  border-radius:var(--radius);
  padding:24px;
  transition:all .25s;
  text-align:center;
}
.who-card:hover{
  border-color:var(--blue);
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.who-icon{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:var(--blue-light);
  color:var(--blue);
  border-radius:12px;
  margin:0 auto 14px;
  font-size:20px;
}
.who-card h3{font-size:15px;font-weight:700;margin-bottom:4px}
.who-card p{font-size:13px;color:var(--text-3);margin:0}

/* ===== INCLUS ===== */
.bg-dark{background:var(--ink);color:var(--white)}
.bg-dark .sec-eyebrow{color:var(--neon)}
.bg-dark .sec-desc{color:rgba(255,255,255,.7)}
.bg-dark h2{color:var(--white)}

.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.feat{
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:32px;
  transition:all .25s;
}
.feat:hover{border-color:var(--blue);transform:translateY(-4px)}
.feat-num{
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;color:var(--blue-2);
  font-weight:700;margin-bottom:18px;letter-spacing:1px;
}
.feat-icon{
  width:52px;height:52px;
  background:rgba(79,124,255,.12);
  color:var(--blue-2);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  margin-bottom:18px;
}
.feat h3{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--white)}
.feat p{font-size:14px;color:rgba(255,255,255,.65);line-height:1.6}

/* ===== FEATURE ACCORDION (interactive horizontal) ===== */
.feat-accord{
  display:flex;
  gap:10px;
  height:400px;
}
.fai-item{
  flex:0 0 68px;
  overflow:hidden;
  border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  cursor:default;
  transition:flex .55s cubic-bezier(.22,1,.36,1),background .3s ease,border-color .3s ease;
  position:relative;
}
.fai-item:hover{
  flex:5;
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.14);
}
.fai-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  height:100%;
  padding:22px 16px;
  position:relative;
}
.fai-num{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:2px;
  color:rgba(255,255,255,.85);
  position:absolute;
  top:16px;
  left:50%;
  transform:translateX(-50%);
  white-space:nowrap;
  transition:color .3s ease;
}
.fai-item:hover .fai-num{color:var(--neon)}
.fai-icon{
  width:44px;height:44px;
  border-radius:11px;
  background:rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
  color:rgba(255,255,255,.9);
  flex-shrink:0;
  transition:background .3s ease,color .3s ease;
}
.fai-item:hover .fai-icon{
  background:rgba(222,254,0,.14);
  color:var(--neon);
}
.fai-title-vert{
  writing-mode:vertical-rl;
  transform:translateX(-50%) rotate(180deg);
  font-size:10px;
  font-weight:700;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.85);
  white-space:nowrap;
  position:absolute;
  bottom:16px;
  left:50%;
  transition:opacity .2s ease;
}
.fai-item:hover .fai-title-vert{opacity:0}
.fai-body{
  max-height:0;
  overflow:hidden;
  opacity:0;
  text-align:center;
  margin-top:0;
  transition:opacity .18s ease, max-height .25s ease, margin-top .2s ease;
}
.fai-item:hover .fai-body{
  max-height:300px;
  opacity:1;
  margin-top:16px;
  transition-delay:.22s;
}
.fai-body h3{
  font-size:16px;
  font-weight:700;
  color:var(--white);
  margin-bottom:10px;
}
.fai-body p{
  font-size:13.5px;
  color:rgba(255,255,255,.6);
  line-height:1.65;
  max-width:300px;
}
@media(max-width:860px){
  .feat-accord{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    height:auto;
    gap:12px;
  }
  .feat-accord:has(.fai-item:hover) .fai-item{flex:unset}
  .feat-accord .fai-item:hover{flex:unset;background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14)}
  .fai-item{min-width:unset;border-radius:14px}
  .fai-title-vert{display:none}
  .fai-body{position:static;opacity:1;max-height:none;overflow:visible;transition:none;margin-top:14px}
  .fai-inner{padding:20px}
}
@media(max-width:560px){
  .feat-accord{grid-template-columns:1fr}
}

/* ===== OFFRE SIDE-BY-SIDE ===== */
#offre{padding:140px 0}
#offre .wrap{display:flex;align-items:center;gap:64px}
#offre .sec-head{width:300px;flex-shrink:0;text-align:left;margin-bottom:0}
#offre .sec-head h2{font-size:clamp(34px,3.4vw,52px);letter-spacing:-1.5px;max-width:none}
#offre .sec-head .sec-desc{font-size:16px;line-height:1.75}
#offre .feat-accord{flex:1;min-width:0;justify-content:flex-end}
@media(max-width:900px){
  #offre .wrap{flex-direction:column;gap:40px}
  #offre .sec-head{width:100%}
}

/* ===== PROCESS ===== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;position:relative}
.step{
  background:rgba(255,255,255,.7);
  border:1px solid rgba(12,14,26,.09);
  border-radius:var(--radius);
  padding:30px 24px;
  text-align:center;
  position:relative;
  display:flex;
  flex-direction:column;
}
.step-n{
  width:46px;height:46px;
  background:var(--ink);color:var(--white);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:20px;
  margin:0 auto 18px;
}
.step h3{font-size:17px;font-weight:700;margin-bottom:8px}
.step p{font-size:14px;color:var(--text-2)}
.step-time{
  display:inline-block;
  align-self:center;
  margin-top:auto;
  font-size:12px;color:#0c0e1a;font-weight:600;
  background:var(--neon);padding:4px 12px;border-radius:20px;
}

/* ===== TARIFS ===== */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1000px;margin:0 auto}
.price-grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,420px));justify-content:center}
.price{
  background:var(--white);
  border:1px solid var(--line-dark);
  border-radius:var(--radius-lg);
  padding:36px 30px;
  position:relative;
  transition:all .25s;
}
.price.featured{
  background:var(--ink);
  color:var(--white);
  border-color:var(--ink);
  transform:scale(1.03);
  box-shadow:var(--shadow-lg);
}
.price-tag{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--orange);color:var(--white);
  font-size:11px;font-weight:700;letter-spacing:1px;
  padding:5px 14px;border-radius:20px;text-transform:uppercase;
}
.price-name{
  font-family:'Barlow Condensed',sans-serif;
  font-size:22px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;
  margin-bottom:8px;
}
.price-desc{font-size:13px;color:var(--text-3);margin-bottom:22px;min-height:38px}
.price.featured .price-desc{color:rgba(255,255,255,.6)}
.price-amount{
  font-family:'Barlow Condensed',sans-serif;
  font-size:52px;font-weight:900;line-height:1;
  margin-bottom:6px;
}
.price-amount em{font-size:18px;color:var(--text-3);font-weight:600;font-style:normal;margin-left:4px}
.price.featured .price-amount em{color:rgba(255,255,255,.5)}
.price-tva{font-size:12px;color:var(--text-3);margin-bottom:24px}
.price.featured .price-tva{color:rgba(255,255,255,.5)}
.price ul{list-style:none;margin-bottom:28px}
.price li{
  font-size:14px;
  padding:9px 0;
  border-bottom:1px solid var(--line-dark);
  display:flex;align-items:flex-start;gap:10px;
}
.price.featured li{border-color:rgba(255,255,255,.08)}
.price li i{color:var(--green);margin-top:4px;flex-shrink:0}
.price-cta{
  display:block;text-align:center;
  padding:13px;border-radius:10px;
  font-weight:600;font-size:14px;
  transition:all .2s;
}
.price-cta.dark{background:var(--ink);color:var(--white)}
.price-cta.dark:hover{background:var(--blue)}
.price-cta.light{background:var(--blue);color:var(--white)}
.price-cta.light:hover{background:var(--blue-2)}

/* ===== PROJETS / GALERIE DÉMOS ===== */
#projets{background:#0a0c1f;color:var(--white);position:relative;overflow:hidden}
#projets::before{
  content:'';position:absolute;
  top:0;left:50%;transform:translateX(-50%);
  width:1200px;height:600px;
  background:radial-gradient(ellipse,rgba(222,254,0,.06),transparent 60%);
  filter:blur(50px);
  pointer-events:none;
}
#projets h2{color:var(--white)}
#projets .sec-desc{color:rgba(255,255,255,.65)}

.proj-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
  gap:24px;
  position:relative;z-index:2;
}
.proj{
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:all .35s var(--ease,cubic-bezier(.22,1,.36,1));
  display:block;
  position:relative;
}
.proj::before{
  content:'';position:absolute;
  top:0;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--c1,var(--neon)),var(--c2,var(--blue)));
  opacity:0;transition:opacity .3s;
  z-index:5;
}
.proj:hover{
  transform:translateY(-8px);
  border-color:var(--c1,var(--neon));
  box-shadow:0 25px 60px rgba(0,0,0,.5);
}
.proj:hover::before{opacity:1}

.proj-img{
  height:260px;
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:var(--proj-bg,linear-gradient(135deg,#1a1d2e,#2a3050));
}
.proj-img::after{
  content:'';position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4) 100%);
}
.proj-mini{
  font-family:var(--proj-font,'Barlow Condensed',sans-serif);
  font-size:46px;font-weight:300;
  color:rgba(255,255,255,.92);
  text-align:center;
  letter-spacing:-1px;
  font-style:italic;
  text-transform:uppercase;
  line-height:.95;
  padding:20px;
  position:relative;z-index:2;
}
.proj-mini.bold{font-style:normal;font-weight:900;letter-spacing:1px}
.proj-mini em{
  display:block;
  font-size:13px;
  font-family:'Geist Mono',monospace;
  color:var(--c1,var(--neon));
  font-style:normal;
  letter-spacing:3px;
  margin-top:14px;
  font-weight:500;
}
.proj-tag{
  position:absolute;top:14px;left:14px;
  background:rgba(0,0,0,.65);
  color:var(--c1,var(--neon));
  border:1px solid var(--c1,var(--neon));
  padding:5px 12px;border-radius:20px;
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  backdrop-filter:blur(10px);
  z-index:3;
}
.proj-num{
  position:absolute;top:14px;right:18px;
  font-family:'Geist Mono',monospace;
  font-size:11px;color:rgba(255,255,255,.4);
  letter-spacing:1px;z-index:3;
}
.proj-body{
  padding:26px;
}
.proj h3{
  font-family:'Barlow Condensed',sans-serif;
  font-size:22px;font-weight:800;letter-spacing:1px;
  text-transform:uppercase;
  margin-bottom:8px;color:var(--white);
}
.proj p{
  font-size:14px;
  color:rgba(255,255,255,.6);
  margin-bottom:20px;
  line-height:1.55;
}
.proj-meta{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:18px;
  border-top:1px solid var(--line);
}
.proj-tech{
  display:flex;gap:6px;flex-wrap:wrap;
}
.proj-tech span{
  font-size:10px;font-weight:600;letter-spacing:.5px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  padding:4px 10px;border-radius:20px;
  color:rgba(255,255,255,.6);
  text-transform:uppercase;
}
.proj-link{
  font-size:12px;
  color:var(--c1,var(--neon));
  font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:6px;
  transition:gap .2s;
}
.proj:hover .proj-link{gap:10px}

/* ===== FAQ ===== */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column}
.faq-item{
  border-bottom:1px solid rgba(255,255,255,.1);
  overflow:hidden;
}
.faq-list .faq-item:first-child{border-top:1px solid rgba(255,255,255,.1)}
.faq-item.open{}
.faq-q{
  padding:22px 0;
  font-size:16px;font-weight:500;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  cursor:pointer;
  color:rgba(255,255,255,.8);
  transition:color .2s;
}
.faq-q:hover{color:#fff}
.faq-q i{display:none}
.faq-icon{
  width:30px;height:30px;min-width:30px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:300;line-height:1;
  color:rgba(255,255,255,.55);
  font-style:normal;
  transition:all .25s;
}
.faq-icon::before{content:'+'}
.faq-item.open .faq-icon::before{content:'−'}
.faq-item.open .faq-icon{border-color:var(--neon);color:var(--neon);background:rgba(222,254,0,.08)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .35s ease,padding .35s ease;
  padding:0;
  font-size:15px;
  color:rgba(255,255,255,.55);
  line-height:1.7;
}
.faq-item.open .faq-a{max-height:350px;padding-bottom:24px}

/* ===== CONTACT ===== */
#contact{background:var(--ink);color:var(--white)}
#contact h2 .accent{color:var(--neon)!important;text-decoration:none}
#contact h2{color:var(--white)}
#contact .sec-desc{color:rgba(255,255,255,.7)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}

.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-row{
  display:flex;align-items:center;gap:18px;
  padding:20px;
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:all .2s;
}
.contact-row:hover{border-color:var(--blue);transform:translateX(4px)}
.contact-icon{
  width:46px;height:46px;
  background:rgba(79,124,255,.12);
  color:var(--blue-2);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.contact-row .label{font-size:12px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1px}
.contact-row .value{font-size:15px;font-weight:600}

.form-card{
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:36px;
}
.form-card h3{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;margin-bottom:8px;text-transform:uppercase}
.form-card p{font-size:14px;color:rgba(255,255,255,.6);margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field label{font-size:12px;color:rgba(255,255,255,.55);font-weight:500}
.form-field input,
.form-field textarea,
.form-field select{
  background:var(--ink);
  border:1px solid var(--line);
  border-radius:10px;
  padding:13px 14px;
  color:var(--white);
  font-size:14px;font-family:inherit;
  transition:border-color .2s;
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{outline:none;border-color:var(--blue)}
.form-field textarea{resize:vertical;min-height:100px}
.form-submit{
  width:100%;
  background:var(--blue);color:var(--white);
  padding:14px;border-radius:10px;
  font-weight:700;font-size:15px;
  transition:all .2s;
  margin-top:6px;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.form-submit:hover{background:var(--blue-2);transform:translateY(-2px)}
.form-note{font-size:12px;color:rgba(255,255,255,.4);text-align:center;margin-top:14px}

/* ===== FOOTER ===== */
footer{
  position:relative;
  background:var(--ink-2);
  color:rgba(255,255,255,.62);
  border-top:1px solid var(--line);
  overflow:hidden;
}
/* closing CTA band */
.foot-cta{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;padding:74px 0 58px;border-bottom:1px solid var(--line)}
.foot-avail{display:inline-flex;align-items:center;gap:9px;margin-bottom:18px;font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.6)}
.foot-avail .dot{width:7px;height:7px;border-radius:50%;background:#3ddc84;animation:footDot 1.8s ease-out infinite}
@keyframes footDot{0%{box-shadow:0 0 0 0 rgba(61,220,132,.6)}70%{box-shadow:0 0 0 8px rgba(61,220,132,0)}100%{box-shadow:0 0 0 0 rgba(61,220,132,0)}}
.foot-head{font-family:'Barlow Condensed',sans-serif;font-weight:900;text-transform:uppercase;font-size:clamp(36px,5.2vw,68px);line-height:.95;letter-spacing:-1px;color:var(--white);margin:0;max-width:16ch}
.foot-head em{font-style:normal;color:var(--neon)}
.foot-cta-btn{display:inline-flex;align-items:center;gap:11px;flex:none;background:var(--neon);color:#0a0b10;font-family:'Inter',sans-serif;font-weight:800;font-size:16px;padding:18px 30px;border-radius:99px;text-decoration:none;transition:transform .25s cubic-bezier(.22,1,.36,1),gap .25s,box-shadow .25s;box-shadow:0 12px 36px -12px rgba(222,254,0,.5)}
.foot-cta-btn:hover{transform:translateY(-3px);gap:16px;box-shadow:0 18px 46px -12px rgba(222,254,0,.72)}

/* columns */
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:48px;padding:72px 0 40px}
.foot-logo{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:24px;color:var(--white);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:16px;display:inline-flex;align-items:center;gap:10px;line-height:1}
.foot-logo .lmark{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--neon);color:#000;border-radius:8px;font-size:18px;font-weight:900}
.foot-logo em{color:var(--neon);font-style:normal;font-weight:900}
.foot-logo .lstu{color:rgba(255,255,255,.5);font-weight:600}
footer p{font-size:14px;line-height:1.6;max-width:42ch}
footer h4{color:var(--white);font-size:12px;font-weight:700;margin-bottom:16px;text-transform:uppercase;letter-spacing:1.5px}
footer ul{list-style:none;padding:0;margin:0}
footer li{margin-bottom:11px;font-size:14px}
footer .foot-grid a{color:rgba(255,255,255,.62);text-decoration:none;transition:color .2s}
footer .foot-grid a:hover{color:var(--neon)}
.foot-contact li{display:flex;align-items:center;gap:11px}
.foot-contact i{color:var(--neon);font-size:12px;width:15px;text-align:center;flex:none}
.foot-soc{display:flex;gap:10px;margin-top:20px}
.foot-soc a{width:38px;height:38px;background:var(--ink-3);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .25s}
.foot-soc a:hover{background:var(--neon);color:#0a0b10;transform:translateY(-3px)}

/* giant signature wordmark */
.foot-wordmark{font-family:'Barlow Condensed',sans-serif;font-weight:900;text-transform:uppercase;font-size:clamp(30px,8.6vw,116px);line-height:.82;letter-spacing:-1px;white-space:nowrap;text-align:center;margin:26px 0 6px;user-select:none;color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.13)}
.foot-wordmark em{font-style:normal;-webkit-text-stroke:0;color:var(--neon);text-shadow:0 0 34px rgba(222,254,0,.35)}

.foot-bot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;border-top:1px solid var(--line);padding:24px 0 32px;font-size:12.5px;color:rgba(255,255,255,.4)}
.foot-bot strong{color:rgba(255,255,255,.85)}
.foot-top{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.55);text-decoration:none;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;transition:color .2s}
.foot-top:hover{color:var(--neon)}
.foot-top i{transition:transform .25s}
.foot-top:hover i{transform:translateY(-3px)}

/* Roller hover on nav links */
footer .foot-grid .ft-link{
  overflow:hidden;
  display:inline-flex;
  flex-direction:column;
  height:1.3em;
  vertical-align:top;
  color:rgba(255,255,255,.62);
  text-decoration:none;
}
footer .foot-grid .ft-link span{
  display:block;
  transition:transform .38s cubic-bezier(.22,1,.36,1);
  white-space:nowrap;
}
footer .foot-grid .ft-link span:last-child{color:var(--neon)}
footer .foot-grid .ft-link:hover span{transform:translateY(-100%)}
/* Wordmark brightens on footer hover */
.foot-wordmark{transition:-webkit-text-stroke-color .5s ease}
footer:hover .foot-wordmark{-webkit-text-stroke-color:rgba(255,255,255,.28)}

@media(max-width:860px){
  .foot-grid{grid-template-columns:1fr;gap:30px;padding:48px 0 32px}
  .foot-wordmark{font-size:clamp(26px,9vw,80px)}
}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:translateY(0)}

/* ===== PHONE SHOWCASE - iPhone live preview inside the gallery ===== */
.phone-showcase{
  position:relative;z-index:3;max-width:1080px;margin:0 auto;
  padding:30px 24px 80px;
  display:grid;grid-template-columns:1fr 0.92fr;gap:64px;align-items:center;
}
.ps-copy .sec-eyebrow{color:var(--neon)}
.ps-copy h3{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;text-transform:uppercase;
  font-size:clamp(32px,3.6vw,50px);line-height:.96;letter-spacing:-.5px;color:#fff;margin:16px 0 18px;
}
.ps-copy h3 em{font-style:normal;color:var(--neon)}
.ps-copy>p{font-family:'Inter',sans-serif;font-size:16px;line-height:1.62;color:rgba(255,255,255,.64);max-width:40ch;margin:0 0 26px}
.ps-points{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:13px}
.ps-points li{font-family:'Inter',sans-serif;font-size:14.5px;color:rgba(255,255,255,.84);display:flex;align-items:center;gap:13px}
.ps-points li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--neon);box-shadow:0 0 10px var(--neon);flex:none}
.ps-cta{
  display:inline-flex;align-items:center;gap:10px;font-family:'Inter',sans-serif;font-weight:600;font-size:14px;
  color:var(--neon);text-decoration:none;border-bottom:1px solid rgba(222,254,0,.4);padding-bottom:3px;transition:gap .25s
}
.ps-cta:hover{gap:15px}

/* device frame */
.ps-stage{display:flex;justify-content:center;perspective:1700px}
.device-phone{
  position:relative;width:296px;height:604px;border-radius:54px;flex:none;
  background:linear-gradient(150deg,#262833,#0b0c11 55%,#1b1d25);
  padding:13px;
  box-shadow:0 55px 95px -32px rgba(0,0,0,.9),0 0 0 1px rgba(255,255,255,.06),inset 0 0 0 2px rgba(255,255,255,.04);
  transform:rotateY(-7deg) rotateZ(-1.2deg);transform-style:preserve-3d;
}
@media(prefers-reduced-motion:no-preference){
  .device-phone{animation:phoneFloat 7.5s ease-in-out infinite}
}
@keyframes phoneFloat{
  0%,100%{transform:translateY(0) rotateZ(-1.2deg) rotateY(-7deg) rotateX(2deg)}
  50%{transform:translateY(-15px) rotateZ(.8deg) rotateY(-3deg) rotateX(1deg)}
}
.device-phone::before{content:"";position:absolute;right:-3px;top:158px;width:3px;height:66px;border-radius:0 2px 2px 0;background:linear-gradient(#42454f,#15161c)}
.device-phone::after{content:"";position:absolute;left:-3px;top:132px;width:3px;height:34px;border-radius:2px 0 0 2px;background:linear-gradient(#42454f,#15161c);box-shadow:0 50px 0 #2c2f38,0 100px 0 #2c2f38}
.phone-screen{position:relative;width:100%;height:100%;border-radius:42px;overflow:hidden;background:#0a0b10}
.phone-island{position:absolute;top:13px;left:50%;transform:translateX(-50%);width:94px;height:27px;background:#000;border-radius:15px;z-index:7}
.phone-glare{position:absolute;inset:0;border-radius:42px;z-index:8;pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.10) 0%,transparent 22%,transparent 78%,rgba(255,255,255,.05) 100%)}
.phone-scroll{position:absolute;inset:0;overflow:hidden;z-index:1}

/* ---- mock site inside the phone (Dumont BTP) - animated ---- */
.mock{font-family:'Inter',sans-serif;color:#fff;background:#0a0b10;--am:#ffb83d}
.mock-status{display:flex;align-items:center;justify-content:space-between;padding:15px 24px 7px;font-size:12px;font-weight:600;color:#fff;position:relative;z-index:3}
.mock-status .ms-dots{display:flex;align-items:center;gap:5px}
.mock-status .ms-dots i{font-size:10px;color:#fff}
.mock-nav{display:flex;align-items:center;justify-content:space-between;padding:4px 18px 12px;position:relative;z-index:3}
.mock-brand{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:17px;letter-spacing:.5px;text-transform:uppercase}
.mock-brand b{color:var(--am)}
.mock-callbtn{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;color:#0a0b10;background:var(--am);padding:6px 11px;border-radius:99px}

/* caution-stripe strip (animated) */
.mock-tape{height:14px;background:repeating-linear-gradient(45deg,var(--am) 0 14px,#0a0b10 14px 28px);background-size:39.6px 39.6px;animation:tapeMove 1.1s linear infinite;opacity:.9}
@keyframes tapeMove{to{background-position:39.6px 0}}

/* hero */
.mock-hero{position:relative;padding:26px 22px 30px;overflow:hidden;background:linear-gradient(180deg,#101218,#0a0b10)}
.mock-hero .glow{position:absolute;top:-40%;right:-30%;width:90%;height:90%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,184,61,.34),transparent 65%);filter:blur(18px);animation:heroGlow 4.5s ease-in-out infinite}
@keyframes heroGlow{0%,100%{opacity:.55;transform:scale(1)}50%{opacity:1;transform:scale(1.18)}}
.mock-badge{position:relative;display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--am);background:rgba(255,184,61,.12);border:1px solid rgba(255,184,61,.34);padding:5px 11px;border-radius:99px;margin-bottom:15px}
.mock-badge .pulse{width:6px;height:6px;border-radius:50%;background:#3ddc84;box-shadow:0 0 0 0 rgba(61,220,132,.7);animation:livePulse 1.6s ease-out infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(61,220,132,.7)}70%{box-shadow:0 0 0 7px rgba(61,220,132,0)}100%{box-shadow:0 0 0 0 rgba(61,220,132,0)}}
.mock-hero h1{position:relative;font-family:'Barlow Condensed',sans-serif;font-weight:900;text-transform:uppercase;font-size:33px;line-height:.9;letter-spacing:-.6px;margin:0 0 12px}
.mock-hero h1 em{font-style:normal;color:var(--am)}
.mock-hero h1 .ln{display:block;transform:translateY(12px);animation:heroLine .6s cubic-bezier(.22,1,.36,1) forwards}
.mock-hero h1 .ln:nth-child(2){animation-delay:.12s}
@keyframes heroLine{to{transform:none}}
.mock-cta{position:relative;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--am);color:#0a0b10;font-weight:800;font-size:14px;padding:14px;border-radius:13px;text-align:center;overflow:hidden}
.mock-cta::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.6),transparent);transform:skewX(-18deg);animation:ctaSheen 2.8s ease-in-out infinite}
@keyframes ctaSheen{0%,60%{left:-60%}100%{left:130%}}

/* animated stat band */
.mock-stats{display:grid;grid-template-columns:repeat(3,1fr);background:#101218;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.mock-stats .st{padding:15px 6px;text-align:center;border-right:1px solid rgba(255,255,255,.06)}
.mock-stats .st:last-child{border-right:none}
.mock-stats .stn{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:24px;color:var(--am);line-height:1}
.mock-stats .stl{font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:rgba(255,255,255,.5);margin-top:3px}

/* marquee */
.mock-marquee{overflow:hidden;background:var(--am);color:#0a0b10}
.mock-marquee .mm{display:inline-flex;white-space:nowrap;font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:1px;padding:8px 0;animation:mmScroll 9s linear infinite}
.mock-marquee .mm span{padding:0 14px}
@keyframes mmScroll{to{transform:translateX(-50%)}}

.mock-sec{padding:22px}
.mock-sec h2{font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;font-size:13px;letter-spacing:1.5px;color:rgba(255,255,255,.45);margin:0 0 14px;display:flex;align-items:center;gap:8px}
.mock-sec h2::before{content:"";width:18px;height:2px;background:var(--am)}
.mock-services{display:flex;flex-direction:column;gap:10px}
.mock-srv{position:relative;display:flex;align-items:center;gap:13px;padding:14px;background:#13151c;border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden}
.mock-srv .snum{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:13px;color:var(--am);opacity:.5}
.mock-srv .si{width:38px;height:38px;border-radius:11px;background:rgba(255,184,61,.13);color:var(--am);display:flex;align-items:center;justify-content:center;font-size:15px;flex:none}
.mock-srv .st{font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;font-size:16px;letter-spacing:.3px;line-height:1}
.mock-srv .sd{font-size:11px;color:rgba(255,255,255,.5);margin-top:3px}
.mock-srv .sarr{margin-left:auto;color:rgba(255,255,255,.3);font-size:11px}

/* réalisations - horizontal duotone tiles */
.mock-gal{display:flex;gap:11px;padding:0 22px 4px;overflow-x:auto;scrollbar-width:none}
.mock-gal::-webkit-scrollbar{display:none}
.mock-tile{position:relative;flex:none;width:135px;height:96px;border-radius:13px;overflow:hidden;display:flex;align-items:flex-end;padding:11px}
.mock-tile::before{content:"";position:absolute;inset:0;background:var(--tile,linear-gradient(135deg,#2a2d36,#15161c));mix-blend-mode:normal}
.mock-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.7))}
.mock-tile .tcap{position:relative;z-index:2;font-size:10.5px;font-weight:700;line-height:1.2}
.mock-tile .ttag{position:absolute;top:9px;left:9px;z-index:2;font-size:8.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:#0a0b10;background:var(--am);padding:3px 7px;border-radius:6px}

/* review card */
.mock-review{margin:0 22px;padding:16px;border-radius:15px;background:#13151c;border:1px solid rgba(255,255,255,.07)}
.mock-review .rv-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.mock-review .rv-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--am),#ff7a45);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-weight:900;color:#0a0b10;font-size:15px}
.mock-review .rv-name{font-size:12.5px;font-weight:700}
.mock-review .rv-stars{color:var(--am);font-size:10px;letter-spacing:1px}
.mock-review .rv-q{font-size:12px;line-height:1.5;color:rgba(255,255,255,.78)}
.mock-review .rv-g{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:10px;color:rgba(255,255,255,.4)}

.mock-zone{margin:22px;padding:20px;border-radius:16px;background:linear-gradient(135deg,#1a1c24,#101218);border:1px solid rgba(255,255,255,.07)}
.mock-zone h3{font-family:'Barlow Condensed',sans-serif;font-weight:900;text-transform:uppercase;font-size:18px;margin:0 0 4px}
.mock-zone p{font-size:11.5px;color:rgba(255,255,255,.55);margin:0 0 14px}
.mock-chips{display:flex;flex-wrap:wrap;gap:7px}
.mock-chips span{font-size:11px;font-weight:600;color:rgba(255,255,255,.8);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);padding:5px 10px;border-radius:99px}
.mock-band{position:relative;margin:0 22px 30px;padding:26px 22px;border-radius:18px;background:var(--am);color:#0a0b10;text-align:center;overflow:hidden}
.mock-band::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(0,0,0,.07) 0 10px,transparent 10px 20px)}
.mock-band>*{position:relative}
.mock-band h3{font-family:'Barlow Condensed',sans-serif;font-weight:900;text-transform:uppercase;font-size:22px;line-height:.95;margin:0 0 6px}
.mock-band p{font-size:12px;font-weight:600;opacity:.75;margin:0 0 16px}
.mock-band .bb{display:inline-flex;align-items:center;gap:8px;background:#0a0b10;color:#fff;font-weight:800;font-size:13px;padding:12px 22px;border-radius:11px}
.mock-foot{padding:22px;text-align:center;font-size:10.5px;color:rgba(255,255,255,.32);background:#070810}
.mock-actionbar{position:absolute;left:0;right:0;bottom:0;z-index:6;display:flex;gap:9px;padding:11px 14px 16px;
  background:linear-gradient(0deg,#0a0b10 65%,transparent);}
.mock-actionbar a{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;font-weight:800;font-size:13px;padding:13px;border-radius:12px}
.mock-actionbar .ab-call{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.14)}
.mock-actionbar .ab-devis{background:var(--am);color:#0a0b10}
@media(prefers-reduced-motion:reduce){
  .mock-tape,.mock-hero .glow,.mock-badge .pulse,.mock-hero h1 .ln,.mock-cta::after,.mock-marquee .mm{animation:none}
  .mock-hero h1 .ln{transform:none}
}

/* scroll-reveal for the in-phone sections - dynamic & staggered (JS-armed) */
.mock.phone-anim .mock-reveal{opacity:0;transition:opacity .5s ease, transform .6s cubic-bezier(.34,1.45,.5,1)}
.mock.phone-anim .mock-reveal.in{opacity:1;transform:none}
/* per-section entrance directions */
.mock.phone-anim .mock-sec{transform:translateX(-26px)}
.mock.phone-anim .mock-gal{transform:translateY(28px)}
.mock.phone-anim .mock-review{transform:translateX(-32px) rotate(-2deg)}
.mock.phone-anim .mock-zone{transform:translateY(34px) scale(.9)}
.mock.phone-anim .mock-band{transform:translateY(34px) scale(.9)}
/* animated bar in section headers */
.mock.phone-anim .mock-sec h2::before{width:0;transition:width .5s .15s cubic-bezier(.22,1,.36,1)}
.mock.phone-anim .mock-sec.in h2::before{width:18px}
/* staggered stat pop */
.mock.phone-anim .mock-stats .st{opacity:0;transform:translateY(22px) scale(.55);transition:opacity .4s ease, transform .55s cubic-bezier(.34,1.7,.5,1)}
.mock.phone-anim .mock-stats.in .st{opacity:1;transform:none}
.mock.phone-anim .mock-stats.in .st:nth-child(2){transition-delay:.1s}
.mock.phone-anim .mock-stats.in .st:nth-child(3){transition-delay:.2s}
/* staggered service cards sliding in */
.mock.phone-anim .mock-sec .mock-srv{opacity:0;transform:translateX(40px);transition:opacity .4s ease, transform .55s cubic-bezier(.34,1.5,.55,1)}
.mock.phone-anim .mock-sec.in .mock-srv{opacity:1;transform:none}
.mock.phone-anim .mock-sec.in .mock-srv:nth-child(2){transition-delay:.09s}
.mock.phone-anim .mock-sec.in .mock-srv:nth-child(3){transition-delay:.18s}
/* staggered gallery tiles popping in */
.mock.phone-anim .mock-gal .mock-tile{opacity:0;transform:scale(.7) translateY(16px);transition:opacity .4s ease, transform .55s cubic-bezier(.34,1.6,.6,1)}
.mock.phone-anim .mock-gal.in .mock-tile{opacity:1;transform:none}
.mock.phone-anim .mock-gal.in .mock-tile:nth-child(2){transition-delay:.1s}
.mock.phone-anim .mock-gal.in .mock-tile:nth-child(3){transition-delay:.2s}

@media(max-width:860px){
  .phone-showcase{grid-template-columns:1fr;gap:36px;text-align:center;padding-bottom:64px}
  .ps-copy>p{margin-left:auto;margin-right:auto}
  .ps-points{align-items:center}
  .ps-points li{justify-content:center}
}

/* ===== MARQUEE override neon ===== */
.marquee-track i{color:var(--neon)}

/* ===== GLOBE SECTION ===== */
#ou{
  background:radial-gradient(ellipse at center,#0a0c1f 0%,#06070f 70%);
  position:relative;
  overflow:hidden;
}
#ou::before{
  content:'';position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 70% 50%,rgba(222,254,0,.06),transparent 50%),
    radial-gradient(circle at 30% 50%,rgba(79,124,255,.05),transparent 50%);
  pointer-events:none;
}
.globe-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:60px;
  align-items:center;
  position:relative;z-index:2;
}
.globe-text h2{
  font-size:clamp(40px,5.5vw,72px);
  line-height:.95;
  margin-bottom:20px;
}
.globe-text p{
  font-size:17px;
  color:rgba(255,255,255,.7);
  margin-bottom:30px;
  max-width:480px;
}
.globe-text strong{color:var(--white);font-weight:600}
.loc-coords{
  display:flex;flex-direction:column;gap:10px;
  border-top:1px solid var(--line);
  padding-top:24px;
  font-family:'Courier New',monospace;
  font-size:13px;
  color:rgba(255,255,255,.55);
  letter-spacing:1px;
}
.loc-coords strong{
  color:var(--neon);
  font-weight:700;
  font-family:'Courier New',monospace;
  margin-right:10px;
}

.globe-wrap{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  max-width:560px;
  margin:0 auto;
  display:flex;align-items:center;justify-content:center;
}
#cobe-globe{
  width:100%!important;
  height:100%!important;
  contain:layout paint size;
  cursor:grab;
}
#cobe-globe:active{cursor:grabbing}

.globe-pulse{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-130%);
  display:flex;align-items:center;gap:10px;
  background:rgba(6,7,15,.85);
  backdrop-filter:blur(12px);
  border:1px solid rgba(222,254,0,.4);
  padding:8px 14px;
  border-radius:30px;
  font-size:12px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--white);
  box-shadow:0 0 30px rgba(222,254,0,.3);
  pointer-events:none;
  white-space:nowrap;
  opacity:0;
  transition:opacity .35s ease;
}
.globe-pulse::before{
  content:'';
  width:8px;height:8px;border-radius:50%;
  background:var(--neon);
  box-shadow:0 0 10px var(--neon);
  animation:pulse 1.6s ease-in-out infinite;
}
.globe-pulse::after{
  content:'';
  position:absolute;
  left:11px;top:50%;
  width:8px;height:8px;border-radius:50%;
  border:2px solid var(--neon);
  transform:translateY(-50%);
  animation:ring 1.6s ease-out infinite;
  pointer-events:none;
}
@keyframes ring{
  0%{transform:translateY(-50%) scale(1);opacity:.8}
  100%{transform:translateY(-50%) scale(3.5);opacity:0}
}

/* ===== MOBILE ===== */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-toggle{display:block;color:var(--text);font-size:22px}
  .hero{padding:100px 0 60px;min-height:auto}
  .hero h1{font-size:18vw;letter-spacing:-2px}
  .hero-vside{display:none}
  .race-stripe,.race-stripe-2{display:none}
  .hero-stats{flex-wrap:wrap;gap:0}
  .h-stat{flex:1 1 50%;padding:14px 16px!important;border-right:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
  .h-stat:nth-child(2){border-right:none}
  .h-stat:nth-last-child(-n+2){border-bottom:none}
  .h-stat-num{font-size:32px}
  .sec{padding:70px 0}
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .form-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .price.featured{transform:none}
  .hero-photo img{object-position:center 30%;opacity:.35}
  .globe-grid{grid-template-columns:1fr;gap:30px;text-align:center}
  .globe-text p{margin:0 auto 30px}
  .loc-coords{align-items:center}
  .globe-wrap{max-width:340px}
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto}
  .bento-feature,.bento-tall,.bento-wide{grid-column:span 2;grid-row:auto}
  .bento-card{min-height:140px}
}
@media(max-width:560px){
  .sec h2{font-size:36px}
  .form-card{padding:24px}
  .btn{padding:14px 22px;font-size:13px}
  .hero-tag{font-size:14px}
}

/* ===== Mobile nav comprehensive fix ===== */
@media (max-width:760px){
  nav{padding:12px 0}
  .nav-in{padding:0 14px;gap:8px}
  .logo{font-size:15px;letter-spacing:1px;gap:6px;flex-shrink:1;min-width:0}
  .logo .lmark{width:26px;height:26px;font-size:13px;flex-shrink:0}
  .lang-toggle{margin-right:6px;padding:2px;flex-shrink:0}
  .lang-toggle button{padding:4px 7px;font-size:9px;letter-spacing:.5px}
}
@media (max-width:560px){
  .logo .lstu{display:none}     /* hide "STUDIOS" word */
  .logo{font-size:13px}
  .logo em{margin:0 2px}
}
@media (max-width:420px){
  .logo .lmark{width:24px;height:24px;font-size:12px}
  .nav-in{padding:0 10px}
}

/* ===== Hero / sections mobile polish ===== */
@media (max-width:560px){
  .wrap{padding:0 18px}
  .hero{padding:90px 0 50px}
  .hero h1{font-size:16vw;letter-spacing:-1.5px;line-height:.9}
  .hero-tag{font-size:13px;line-height:1.5}
  .hero-cta{flex-direction:column;align-items:stretch;width:100%;gap:10px}
  .hero-cta .btn{width:100%;justify-content:center}
  .hero-stats{padding-top:22px;gap:0}
  .h-stat{flex:1 1 50%;padding:12px 14px!important}
  .h-stat-num{font-size:26px}
  .h-stat-lbl{font-size:9px;letter-spacing:1px}
  .eyebrow{font-size:10px;letter-spacing:1.5px;padding:6px 12px}
  .sec{padding:55px 0}
  .sec-head{margin-bottom:36px}
  .sec h2{font-size:32px;line-height:1.05}
  .sec-eyebrow{font-size:11px;letter-spacing:1.5px}
  .sec-desc{font-size:15px}
  .marquee-track{font-size:15px;letter-spacing:1px}
  .feat,.bento-card,.who-card,.testi{padding:22px 20px}
  .feat h3,.bento-card h3{font-size:15px}
  .feat p,.bento-card p{font-size:13px}
  .price{padding:28px 22px}
  .price-amount{font-size:42px}
  .price-name{font-size:19px}
  .price li{font-size:13px;padding:8px 0}
  .step{padding:24px 18px}
  .step h3{font-size:15px}
  .testi{flex-basis:280px;padding:24px}
  .testi-quote{font-size:14px}
  .trades-pills span{font-size:11px;padding:5px 9px}
  .trades-cloud{padding:30px 18px;margin-top:40px}
  .trades-cloud-head span{font-size:10px;letter-spacing:2px;padding:6px 14px}
  .form-card{padding:22px 18px}
  .contact-row{padding:16px}
  .foot-grid{gap:24px}
  .kbd-hint{display:none}
}

/* ============================================================
   v2 EDITORIAL OVERRIDES - less AI, more pro, scroll-rich
   ============================================================ */
:root{
  --serif:'Fraunces',Georgia,serif;
  --mono:'DM Mono',ui-monospace,monospace;
}

/* Kill AI tells */
.grain{display:none}
#flowfield{display:none!important}
.race-stripe,.race-stripe-2{display:none}
.cur-dot,.cur-ring,.cur-label{display:none!important}
.kbd-hint,#cmdk{display:none!important}

/* Mobile menu button + drawer */
.nav-toggle{display:none;background:transparent;border:1px solid var(--line);width:42px;height:42px;border-radius:10px;cursor:pointer;align-items:center;justify-content:center;color:var(--text);font-size:18px;transition:background .2s,border-color .2s}
.nav-toggle:hover{background:rgba(0,0,0,.04);border-color:var(--text-2)}
.nav-toggle.open{background:var(--text);color:#fff;border-color:var(--text)}
.nav-mobile-cta{display:none}
body.menu-open{overflow:hidden}

/* Hero v2: editorial */
.hero{padding:80px 0 100px;min-height:auto}
.hero .wrap{position:relative;z-index:5}
.hero-content{max-width:none}
.hero .eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  background:transparent;border:none;border-top:1px solid rgba(255,255,255,.18);
  padding:18px 0 0;display:flex;align-items:center;gap:12px;
  margin-bottom:36px;width:100%;max-width:560px;color:rgba(255,255,255,.7);border-radius:0;
}
.hero .eyebrow .live{position:static;width:6px;height:6px;background:var(--neon);box-shadow:0 0 0 4px rgba(222,254,0,.18)}
.hero h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(56px,8.4vw,148px);line-height:.95;letter-spacing:-3px;
  text-transform:none;margin:0 0 36px;color:var(--white);
  font-variation-settings:"opsz" 144;max-width:14ch;
}
.hero h1 .line{display:block;margin:0;overflow:hidden}
.hero h1 .line > span{
  display:inline-block;font-family:var(--serif);font-weight:300;letter-spacing:-3px;
  text-transform:none;-webkit-text-stroke:0;color:var(--white);
  background:transparent;-webkit-text-fill-color:initial;text-shadow:none;
}
.hero h1 .line > span.outline{-webkit-text-stroke:0;color:rgba(255,255,255,.32);font-style:italic;font-weight:400}
.hero h1 .line > span.accent{color:var(--white);background:transparent;font-weight:500;font-style:italic;position:relative}
.hero h1 .line > span.accent::after{
  content:"";display:block;height:5px;width:100%;
  background:var(--neon);margin-top:-12px;transform:translateY(8px);border-radius:2px;
}
.hero-tag{font-family:'Inter',sans-serif;font-size:18px;line-height:1.55;color:rgba(255,255,255,.78);max-width:54ch;margin:0 0 36px}
.hero-tag .mark{background:transparent;color:var(--neon);font-weight:600;padding:0;border-radius:0}
.hero-tag .mark::before{display:none!important}
.hero-tag .mark.outline{color:var(--neon)}
.hero-tag strong{color:var(--white);font-weight:600}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:64px}
.hero-cta .btn{font-family:'Inter',sans-serif;font-weight:600;letter-spacing:0;text-transform:none;font-size:15px;padding:16px 24px;border-radius:999px;transition:transform .25s,background .25s,color .25s,border-color .25s}
.hero-cta .btn-primary{background:var(--neon);color:#0c0e1a;border:1px solid var(--neon);box-shadow:none}
.hero-cta .btn-primary:hover{transform:translateY(-2px);background:#fff;color:#0c0e1a;border-color:#fff}
.hero-cta .btn-ghost{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.25)}
.hero-cta .btn-ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.14);padding-top:28px;max-width:780px}
.h-stat{padding:0 24px 0 0;border-right:1px solid rgba(255,255,255,.14);background:transparent}
.h-stat:nth-child(2),.h-stat:nth-child(3){padding-left:24px}
.h-stat:last-child{border-right:none;padding-left:24px}
.h-stat-num{font-family:var(--serif);font-weight:400;font-size:38px;line-height:1;letter-spacing:-1px;color:var(--white);margin-bottom:6px}
.h-stat-num em{font-family:var(--mono);font-style:normal;font-size:14px;font-weight:400;margin-left:4px;color:rgba(255,255,255,.55);letter-spacing:0}
.h-stat-lbl{font-family:var(--mono);font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.55)}
.hero-vside{font-family:var(--mono);font-size:10px;letter-spacing:2px;color:rgba(255,255,255,.4)}
.hero-photo{opacity:.5;mix-blend-mode:luminosity;filter:contrast(.95) saturate(.6)}
.hero-photo::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 30% 50%,rgba(6,7,15,.95) 30%,rgba(6,7,15,.4) 70%,rgba(6,7,15,.85));z-index:1}

/* Section eyebrows + h2 - editorial */
.sec-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-2);display:inline-flex;align-items:center;gap:8px}
.sec-eyebrow::before{content:none}
.sec h2,#trustbar h2,#temoignages h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,5.4vw,72px);line-height:1.02;letter-spacing:-2px;text-transform:none;
  font-variation-settings:"opsz" 144;max-width:18ch;
}
.sec h2 .accent,#temoignages h2 .accent{font-style:italic;font-weight:400;color:var(--blue)}
#offre h2 .accent,#temoignages h2 .accent,#faq h2 .accent{color:var(--neon)!important}
#temoignages h2{color:var(--white)}

/* Trustbar - calmer */
#trustbar{padding:48px 0 32px;background:transparent;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-head{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-2);margin-bottom:20px}
.trust-track .tl{font-family:var(--mono);font-size:13px;letter-spacing:.5px;text-transform:none;color:var(--text-2);opacity:.85}

/* Marquee - calmer */
.marquee{padding:14px 0;background:transparent;border:none;font-family:var(--mono);font-size:12px;letter-spacing:.5px;color:var(--text-2);text-transform:none}

/* Form feedback states */
.form-feedback{display:flex;gap:10px;align-items:flex-start;margin-top:14px;padding:14px 16px;border-radius:12px;font-size:14px;line-height:1.5}
.form-feedback[hidden]{display:none!important}
.form-feedback i{flex-shrink:0;margin-top:2px;font-size:18px}
.form-feedback-ok{background:rgba(80,200,120,.12);border:1px solid rgba(80,200,120,.4);color:#7ee2a3}
.form-feedback-ok strong{color:#bff5d2}
.form-feedback-err{background:rgba(255,90,90,.12);border:1px solid rgba(255,90,90,.4);color:#ffabab}
.form-feedback-err strong{color:#ffd1d1}
.form-feedback-err a{color:#fff;text-decoration:underline}
.form-submit .btn-spinner{display:none;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .7s linear infinite;margin:0 4px}
.form-submit.loading .btn-spinner{display:inline-block}
.form-submit.loading .btn-label,.form-submit.loading > i.fa-paper-plane{opacity:.6}
@keyframes spin{to{transform:rotate(360deg)}}

/* Scroll progress bar */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--neon);z-index:9998;transition:width .15s linear;pointer-events:none}

/* Scroll reveal utilities */
.fx-fade{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform .9s cubic-bezier(.22,.61,.36,1)}
.fx-fade.in{opacity:1;transform:none}
.fx-words{display:inline-block}
.fx-words .w{display:inline-block;opacity:0;transform:translateY(.4em) rotateX(40deg);transition:opacity .55s ease,transform .65s cubic-bezier(.22,.61,.36,1);transform-origin:50% 100%}
.fx-words.in .w{opacity:1;transform:none}
.fx-img-reveal{position:relative;overflow:hidden}
.fx-img-reveal::after{content:"";position:absolute;inset:0;background:#0c0e1a;transform-origin:right center;transform:scaleX(1);transition:transform 1s cubic-bezier(.77,0,.18,1)}
.fx-img-reveal.in::after{transform:scaleX(0)}
.fx-card{opacity:0;transform:translateY(28px) scale(.985);transition:opacity .8s ease,transform .9s cubic-bezier(.22,.61,.36,1)}
.fx-card.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  .fx-fade,.fx-words .w,.fx-card{transition:none!important;opacity:1!important;transform:none!important}
  .fx-img-reveal::after{display:none}
  /* Freeze every continuous loop for users who ask for less motion */
  .marquee-track,.trust-track,.testi-track,.mm-track,
  .hero h1 .accent,.hm-badge-1,.hm-badge-2,.hm-badge-3,
  .eyebrow .live,.globe-pulse,.globe-pulse::after,
  .cinematic-rail-hint,.cinematic-rail-hint i,.sxp-hint,
  .is-k::before,.ii-cursor,.globe-text .blip{
    animation:none!important;
  }
}

/* Mobile menu - FULL-SCREEN overlay, editorial big-type */
@media(max-width:900px){
  .nav-links{
    display:flex!important;
    position:fixed;
    inset:0;
    width:100vw;
    height:100dvh;
    flex-direction:column;
    align-items:stretch;
    justify-content:center;
    gap:0;
    padding:90px 28px max(40px,env(safe-area-inset-bottom)) 28px;
    background:#06070f;
    color:#fafbff;
    transform:translateX(100%);
    transition:transform .55s cubic-bezier(.7,0,.2,1);
    z-index:95;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    pointer-events:none;       /* not interactive when off-screen */
    visibility:hidden;          /* fully hidden when closed */
  }
  .nav-links.open{
    pointer-events:auto;
    visibility:visible;
  }
  .nav-links::before{
    content:"- MENU";
    position:absolute;
    top:30px;
    left:28px;
    font-family:var(--mono);
    font-size:11px;
    letter-spacing:2px;
    text-transform:uppercase;
    color:rgba(255,255,255,.45);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links li{
    width:100%;
    list-style:none;
    border-bottom:1px solid rgba(255,255,255,.1);
    opacity:0;
    transform:translateY(20px);
    transition:opacity .45s ease,transform .5s cubic-bezier(.22,.61,.36,1);
  }
  .nav-links.open li{opacity:1!important;transform:none!important}
  .nav-links.open li:nth-child(1){transition-delay:.12s}
  .nav-links.open li:nth-child(2){transition-delay:.16s}
  .nav-links.open li:nth-child(3){transition-delay:.20s}
  .nav-links.open li:nth-child(4){transition-delay:.24s}
  .nav-links.open li:nth-child(5){transition-delay:.28s}
  .nav-links.open li:nth-child(6){transition-delay:.32s}
  .nav-links.open li:nth-child(7){transition-delay:.40s}
  .nav-links li:last-child{border-bottom:none;margin-top:24px}
  .nav-links a{
    display:flex;
    align-items:baseline;
    justify-content:space-between;
    padding:22px 0;
    font-family:var(--serif);
    font-weight:300;
    font-size:42px;
    line-height:1;
    letter-spacing:-1.5px;
    text-transform:none;
    color:#fafbff;
    font-variation-settings:"opsz" 144;
    transition:color .25s,transform .35s cubic-bezier(.22,.61,.36,1);
  }
  .nav-links a::after{
    content:"→";
    font-size:18px;
    color:rgba(255,255,255,.4);
    font-family:var(--mono);
    transform:translateX(-8px);
    opacity:0;
    transition:transform .3s,opacity .3s,color .25s;
  }
  .nav-links a:hover,
  .nav-links a:active{
    color:var(--neon);
    transform:translateX(6px);
  }
  .nav-links a:hover::after,
  .nav-links a:active::after{opacity:1;transform:translateX(0);color:var(--neon)}
  .nav-mobile-cta{
    display:flex!important;
    align-items:center;
    justify-content:space-between!important;
    gap:10px;
    background:var(--neon)!important;
    color:#0c0e1a!important;
    padding:20px 24px!important;
    border-radius:999px;
    font-family:'Inter',sans-serif!important;
    font-size:15px!important;
    font-weight:600!important;
    letter-spacing:0!important;
    text-transform:none!important;
  }
  .nav-mobile-cta:hover,
  .nav-mobile-cta:active{transform:none!important;color:#0c0e1a!important}
  .nav-mobile-cta::after{display:none}
  /* Lock body behind */
  body.menu-open{overflow:hidden;height:100dvh}
  /* Burger button on top of overlay (X icon when open) */
  body.menu-open nav{background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  body.menu-open .logo,body.menu-open .lang-toggle{visibility:hidden}
  body.menu-open .nav-toggle{
    background:transparent!important;
    border-color:rgba(255,255,255,.3)!important;
    color:#fafbff!important;
  }
  /* FORCE white text in mobile menu regardless of nav theme */
  .nav-links a,
  nav.theme-light .nav-links a{
    color:#fafbff!important;
  }
  .nav-links a:hover,
  .nav-links a:active,
  nav.theme-light .nav-links a:hover,
  nav.theme-light .nav-links a:active{
    color:var(--neon)!important;
  }
  /* Mobile CTA always neon-on-dark - higher specificity beats .nav-links a */
  .nav-links a.nav-mobile-cta,
  nav.theme-light .nav-links a.nav-mobile-cta{
    color:#0c0e1a!important;
    background:var(--neon)!important;
  }
  /* Hide WhatsApp when menu is open so it doesn't overlap */
  body.menu-open .wa-float{display:none!important}
  /* Bottom footer inside menu */
  .nav-links::after{
    content:"BOURG-EN-BRESSE · 01 · FRANCE";
    position:absolute;
    bottom:max(20px,env(safe-area-inset-bottom));
    left:50%;
    transform:translateX(-50%);
    font-family:var(--mono);
    font-size:9px;
    letter-spacing:2px;
    text-transform:uppercase;
    color:rgba(255,255,255,.35);
    opacity:0;
    transition:opacity .4s ease .65s;
  }
  .nav-links.open::after{opacity:1}
  .nav-toggle{display:inline-flex;z-index:100;position:relative}
  .nav-in > .nav-cta{display:none}
  .hero h1{font-size:14vw;letter-spacing:-1.5px;max-width:none}
  .hero .eyebrow{max-width:none}
  .hero-tag{font-size:16px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:0;border:none;padding-top:0}
  .h-stat{padding:18px 0!important;border-right:1px solid rgba(255,255,255,.14)!important;border-bottom:1px solid rgba(255,255,255,.14)}
  .h-stat:nth-child(even){border-right:none!important}
  .h-stat:nth-last-child(-n+2){border-bottom:none}
  .h-stat-num{font-size:30px}
  .sec h2,#temoignages h2{font-size:42px;letter-spacing:-1px}
}

/* ============================================================
   v3 - Lenis-style polish: floating CTA, theme switch, photo
   ============================================================ */

/* Bigger photo, less hidden - feels more "studio" */
.hero-photo{opacity:.78;mix-blend-mode:normal;filter:contrast(1) saturate(1)}
.hero-photo::after{
  background:linear-gradient(90deg,rgba(6,7,15,.95) 0%,rgba(6,7,15,.7) 40%,rgba(6,7,15,.15) 75%,rgba(6,7,15,.6) 100%);
}
.hero-photo img{object-position:center 25%;filter:contrast(1.05) brightness(.92)}

/* Floating "Devis" pill - always visible while scrolling */
.float-cta{
  position:fixed;
  bottom:24px;right:24px;
  z-index:80;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  border-radius:999px;
  background:var(--neon);
  color:#0c0e1a;
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:14px;
  letter-spacing:.2px;
  text-decoration:none;
  box-shadow:0 8px 32px rgba(222,254,0,.35),0 2px 8px rgba(0,0,0,.2);
  transform:translateY(140%);
  transition:transform .5s cubic-bezier(.22,.61,.36,1),box-shadow .25s,scale .15s;
  opacity:0;
}
.float-cta.visible{transform:translateY(0);opacity:1}
.float-cta:hover{box-shadow:0 12px 40px rgba(222,254,0,.5),0 4px 12px rgba(0,0,0,.25);scale:1.04}
.float-cta i{font-size:13px;transition:transform .25s}
.float-cta:hover i{transform:translateX(3px)}
.float-cta-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;height:22px;
  border-radius:50%;
  background:#0c0e1a;
  color:var(--neon);
  font-size:11px;
}
@media(max-width:560px){
  .float-cta{bottom:16px;right:16px;padding:12px 18px;font-size:13px}
}

/* Section theme switching: nav goes light on light sections, dark on dark */
nav{transition:background .35s ease,backdrop-filter .35s ease,border-color .35s ease}
nav.theme-light{background:rgba(255,255,255,.85);backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px)}
nav.theme-light .logo,nav.theme-light .nav-links a,nav.theme-light .lang-toggle button{color:#0c0e1a}
nav.theme-light .nav-cta{background:#0c0e1a;color:#fff}
nav.theme-light .nav-toggle{border-color:rgba(0,0,0,.15);color:#0c0e1a}

/* Background color shifts at section boundaries (subtle) */
body{transition:background-color .55s ease}

/* Hero is dark, FAQ is light - nav theme tracks this naturally via JS */

/* ============================================================
   MANIFESTO - personal section, no neon, magazine-feel
   ============================================================ */
.manifesto{
  background:#f8f6f1;
  color:#0c0e1a;
  padding:120px 0 140px;
  position:relative;
  overflow:hidden;
}
.manifesto::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,0,0,.12),transparent);
}
.manifesto-wrap{
  display:grid;
  grid-template-columns:42% 1fr;
  gap:80px;
  align-items:center;
  max-width:1100px;
}
.manifesto-card{
  position:relative;
  aspect-ratio:4/5;
  background:#0c0e1a;
  color:#fafbff;
  overflow:hidden;
  border-radius:3px;
  transform:rotate(-1.2deg);
  box-shadow:0 30px 60px -20px rgba(0,0,0,.35),0 8px 20px -8px rgba(0,0,0,.22);
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  font-family:'DM Mono',monospace;
}
.manifesto-card::before,
.manifesto-card::after{
  content:"";
  position:absolute;
  width:18px;height:18px;
  border:1px solid rgba(255,255,255,.25);
}
.manifesto-card::before{top:14px;left:14px;border-right:none;border-bottom:none}
.manifesto-card::after{bottom:14px;right:14px;border-left:none;border-top:none}
.mc-top{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.mc-label::before{content:"- "}
.mc-num{font-weight:500;color:rgba(255,255,255,.75)}
.mc-mark{
  font-family:'Fraunces',Georgia,serif;
  font-size:clamp(140px,18vw,220px);
  line-height:.85;
  letter-spacing:-8px;
  font-weight:300;
  font-style:italic;
  text-align:center;
  margin:0 0 -10px;
  color:#fafbff;
  font-variation-settings:"opsz" 144;
  position:relative;
}
.mc-mark::after{
  content:"";
  position:absolute;
  bottom:18px;
  left:50%;
  transform:translateX(-50%);
  width:42px;height:2px;
  background:var(--neon);
}
.mc-mid{
  display:flex;align-items:center;gap:12px;
  margin:0 0 22px;
}
.mc-line{flex:1;height:1px;background:rgba(255,255,255,.18)}
.mc-tag{
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.mc-meta{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px 18px;
  margin:0 0 22px;
  font-size:11px;
}
.mc-meta > div{
  display:flex;
  justify-content:space-between;
  border-bottom:1px dashed rgba(255,255,255,.12);
  padding-bottom:6px;
}
.mc-k{color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:1px;font-size:9px}
.mc-v{color:#fafbff;font-weight:500}
.mc-bottom{
  display:flex;align-items:center;justify-content:center;gap:14px;
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.55);
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:14px;
}
.mc-dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.4)}
.mc-stamp{font-weight:500}
.manifesto-eyebrow{
  font-family:'DM Mono',monospace;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(12,14,26,.55);
  margin-bottom:24px;
}
.manifesto-quote{
  font-family:'Fraunces',Georgia,serif;
  font-weight:400;
  font-size:clamp(28px,3.4vw,44px);
  line-height:1.2;
  letter-spacing:-1px;
  color:#0c0e1a;
  margin:0 0 28px;
  font-variation-settings:"opsz" 144;
}
.manifesto-quote em{font-style:italic;font-weight:500}
.manifesto-body{
  font-family:'Inter',sans-serif;
  font-size:17px;
  line-height:1.65;
  color:rgba(12,14,26,.78);
  max-width:46ch;
  margin:0 0 36px;
}
.manifesto-body strong{color:#0c0e1a;font-weight:600}
.manifesto-sign{
  display:flex;
  flex-direction:column;
  gap:4px;
  border-top:1px solid rgba(12,14,26,.15);
  padding-top:18px;
  max-width:300px;
}
.ms-name{
  font-family:'Fraunces',Georgia,serif;
  font-style:italic;
  font-weight:500;
  font-size:22px;
  color:#0c0e1a;
}
.ms-role{
  font-family:'DM Mono',monospace;
  font-size:11px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(12,14,26,.55);
}
@media(max-width:780px){
  .manifesto{padding:80px 0}
  .manifesto-wrap{grid-template-columns:1fr;gap:48px}
  .manifesto-card{max-width:320px;margin:0 auto;transform:rotate(-1deg);padding:26px 22px}
  .mc-mark{font-size:140px;letter-spacing:-6px}
  .mc-meta{grid-template-columns:1fr;gap:6px}
  .manifesto-quote{font-size:28px}
  .manifesto-body{font-size:16px}
}

/* ============================================================
   CINEMATIC + LAMP - Aceternity-style intro for the gallery
   ============================================================ */
.sec-cinematic{
  background:#06070f;
  padding:0 0 120px;
  position:relative;
  overflow:hidden;
}

/* Lamp intro */
.lamp-intro{
  position:relative;
  width:100%;
  min-height:520px;
  background:#06070f;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  isolation:isolate;
}
.lamp-cone{
  position:absolute;
  top:0;
  width:60%;
  height:100%;
  pointer-events:none;
  filter:blur(70px);
  opacity:0;
  animation:lampIn 1.6s .15s cubic-bezier(.22,.61,.36,1) forwards;
}
.lamp-cone-l{
  left:-10%;
  background:conic-gradient(from 70deg at top right,transparent 0%,var(--neon) 25%,transparent 60%);
  transform-origin:top right;
}
.lamp-cone-r{
  right:-10%;
  background:conic-gradient(from -70deg at top left,transparent 40%,var(--neon) 75%,transparent 100%);
  transform-origin:top left;
}
@keyframes lampIn{
  0%{opacity:0;transform:scaleX(.4)}
  100%{opacity:.7;transform:scaleX(1)}
}
.lamp-bar{
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:0;
  height:2px;
  background:var(--neon);
  box-shadow:0 0 18px var(--neon),0 0 36px var(--neon),0 0 72px rgba(222,254,0,.6);
  animation:lampBar 1.4s .1s cubic-bezier(.22,.61,.36,1) forwards;
  z-index:2;
}
@keyframes lampBar{
  0%{width:0}
  100%{width:60%}
}
.lamp-glow{
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%) translateY(-40%);
  width:480px;
  height:300px;
  background:radial-gradient(ellipse at center top,rgba(222,254,0,.55) 0%,rgba(222,254,0,.2) 30%,transparent 60%);
  filter:blur(40px);
  pointer-events:none;
  opacity:0;
  animation:lampGlow 1.6s .25s ease-out forwards;
  z-index:1;
}
@keyframes lampGlow{
  0%{opacity:0}
  100%{opacity:1}
}
.lamp-content{
  position:relative;
  z-index:5;
  text-align:center;
  padding:160px 24px 80px;
  max-width:780px;
}
.lamp-eyebrow{
  display:inline-flex!important;
  margin-bottom:28px;
  color:rgba(255,255,255,.55);
  justify-content:center;
}
.lamp-eyebrow::before{background:rgba(255,255,255,.55)!important}
.lamp-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(48px,7vw,96px);
  line-height:1;
  letter-spacing:-2.5px;
  color:#fff;
  margin:0 0 24px;
  font-variation-settings:"opsz" 144;
  max-width:none!important;
}
.lamp-title .accent{
  font-style:italic;
  color:var(--neon)!important;
  font-weight:400;
}
.lamp-desc{
  font-family:'Inter',sans-serif;
  font-size:16px;
  line-height:1.6;
  color:rgba(255,255,255,.65);
  max-width:52ch;
  margin:0 auto;
}

/* Cinematic rail - HORIZONTAL scroll with snap (awwwards-tier) */
.cinematic-rail{
  display:flex;
  flex-direction:row;
  gap:0;
  margin:0;
  position:relative;
  z-index:5;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:rgba(222,254,0,.3) transparent;
  padding:0 0 24px;
}
.cinematic-rail::-webkit-scrollbar{height:4px;background:transparent}
.cinematic-rail::-webkit-scrollbar-thumb{background:rgba(222,254,0,.4);border-radius:999px}
.cinematic-rail::-webkit-scrollbar-thumb:hover{background:var(--neon)}
.cinematic-rail .proj{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  align-items:stretch;
  flex:0 0 100vw;
  min-width:100vw;
  max-width:100vw;
  min-height:75vh;
  max-height:80vh;
  scroll-snap-align:start;
  scroll-snap-stop:always;
  background:transparent!important;
  border-radius:0;
  overflow:hidden;
  border-right:1px solid rgba(255,255,255,.08);
  border-top:none;
  border-bottom:none;
  text-decoration:none;
  transition:background .4s ease;
}
.cinematic-rail .proj:last-child{border-right:none}
.cinematic-rail .proj:hover{background:rgba(255,255,255,.02)!important}

/* Horizontal scroll hint */
.cinematic-rail-hint{
  position:absolute;
  bottom:30px;
  left:50%;
  transform:translateX(-50%);
  z-index:6;
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
  padding:8px 16px;
  background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  pointer-events:none;
  animation:hintPulse 2s ease-in-out infinite;
}
.cinematic-rail-hint i{font-size:12px;animation:hintArrow 1.5s ease-in-out infinite}
.hint-en{display:none}
html[lang="en"] .hint-fr{display:none}
html[lang="en"] .hint-en{display:inline}
@keyframes hintPulse{
  0%,100%{opacity:.6}
  50%{opacity:1}
}
@keyframes hintArrow{
  0%,100%{transform:translateX(0)}
  50%{transform:translateX(4px)}
}
.sec-cinematic{position:relative}
.cinematic-rail .proj-img{
  position:relative;
  aspect-ratio:auto;
  min-height:100%;
  background:var(--proj-bg)!important;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border-radius:0;
  margin:0;
  padding:60px 40px;
  transition:transform .8s cubic-bezier(.22,.61,.36,1);
}
.cinematic-rail .proj:hover .proj-img{transform:scale(1.015)}
.cinematic-rail .proj-tag{
  top:24px;left:24px;
  font-family:var(--mono);
  font-size:10px;letter-spacing:1.8px;
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.85);
  padding:6px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
}
.cinematic-rail .proj-num{
  top:24px;right:24px;
  font-family:var(--mono);
  font-size:10px;letter-spacing:1.5px;
  color:rgba(255,255,255,.5);
}
.cinematic-rail .proj-mini{
  font-family:var(--proj-font,'Barlow Condensed',sans-serif);
  font-size:clamp(28px,4vw,56px);
  font-weight:300;
  line-height:.95;
  text-align:center;
  letter-spacing:-1.5px;
  color:#fff;
  max-width:90%;
  word-wrap:break-word;
  overflow-wrap:break-word;
  hyphens:auto;
}
.cinematic-rail .proj-mini em{
  display:block;
  margin-top:14px;
  font-family:var(--mono);
  font-style:normal;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:400;
}
.cinematic-rail .proj-body{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:64px 64px;
  background:transparent!important;
  border:none;
  color:#fafbff;
}
.cinematic-rail .proj-body h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(36px,4.5vw,60px);
  line-height:1;
  letter-spacing:-1.5px;
  margin:0 0 20px;
  color:#fff;
  font-variation-settings:"opsz" 144;
}
.cinematic-rail .proj-body p{
  font-family:'Inter',sans-serif;
  font-size:16px;
  line-height:1.65;
  color:rgba(255,255,255,.7);
  margin:0 0 32px;
  max-width:46ch;
}
.cinematic-rail .proj-meta{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
  margin-top:auto;
  padding-top:32px;
  border-top:1px solid rgba(255,255,255,.1);
  flex-wrap:wrap;
}
.cinematic-rail .proj-tech{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.cinematic-rail .proj-tech span{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
  padding:6px 10px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  background:transparent;
}
.cinematic-rail .proj-link{
  font-family:'Inter',sans-serif;
  font-size:14px;
  font-weight:600;
  color:var(--neon);
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:gap .25s ease;
}
.cinematic-rail .proj:hover .proj-link{gap:14px}
.cinematic-cta{
  text-align:center;
  margin:80px auto 0;
  padding:0 24px;
}

@media(max-width:780px){
  .lamp-intro{min-height:380px}
  .lamp-content{padding:120px 24px 60px}
  .cinematic-rail .proj{grid-template-columns:1fr}
  .cinematic-rail .proj:nth-child(even){direction:ltr}
  .cinematic-rail .proj-body{padding:40px 24px}
  .cinematic-rail .proj-body h3{font-size:32px}
}

/* ============================================================
   CHAPTER COUNTER - fixed corner UI (Motto-style)
   ============================================================ */
.chapter-counter{
  display:none!important;
  position:fixed;
  bottom:24px;
  left:24px;
  z-index:75;
  display:flex;
  align-items:baseline;
  gap:6px;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.4);
  backdrop-filter:blur(12px) saturate(1.4);
  -webkit-backdrop-filter:blur(12px) saturate(1.4);
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.1);
  pointer-events:none;
  transition:opacity .3s,color .3s,background .3s,border-color .3s;
}
.chapter-counter .cc-num{font-weight:500;color:var(--neon)}
.chapter-counter .cc-sep{opacity:.4}
.chapter-counter .cc-total{opacity:.6}
.chapter-counter .cc-lbl{
  margin-left:8px;
  padding-left:10px;
  border-left:1px solid rgba(255,255,255,.18);
  font-weight:500;
}
/* Light theme variant */
nav.theme-light ~ .chapter-counter,body:has(nav.theme-light) .chapter-counter{
  background:rgba(255,255,255,.6);
  color:rgba(12,14,26,.8);
  border-color:rgba(0,0,0,.08);
}
@media(max-width:560px){
  .chapter-counter{display:none}
}

/* ============================================================
   CHAPTER BREAK - full-screen typographic divider (chainzoku-style)
   ============================================================ */
.chapter-break{
  background:#06070f;
  color:#fff;
  padding:140px 0;
  position:relative;
  overflow:hidden;
}
.chapter-break-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
  position:relative;
}
.cb-num{
  font-family:var(--serif);
  font-size:clamp(120px,18vw,260px);
  font-weight:300;
  font-style:italic;
  line-height:1;
  letter-spacing:-8px;
  color:rgba(255,255,255,.08);
  margin:0 0 -.3em;
  font-variation-settings:"opsz" 144;
}
.cb-num em{
  font-style:normal;
  color:var(--neon);
  font-weight:400;
}
.cb-title{
  font-family:var(--serif);
  font-size:clamp(48px,7vw,100px);
  font-weight:300;
  line-height:1;
  letter-spacing:-2px;
  color:#fff;
  margin:0 0 28px;
  font-variation-settings:"opsz" 144;
  position:relative;
}
.cb-title em{font-style:italic;font-weight:400;color:var(--neon)}
.cb-desc{
  font-family:'Inter',sans-serif;
  font-size:18px;
  line-height:1.55;
  color:rgba(255,255,255,.65);
  max-width:48ch;
  margin:0;
}
.cb-marquee{
  position:absolute;
  bottom:0;
  left:0;right:0;
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:clamp(80px,13vw,200px);
  line-height:1;
  letter-spacing:-4px;
  color:rgba(255,255,255,.04);
  white-space:nowrap;
  pointer-events:none;
  transform:translateY(35%);
  font-variation-settings:"opsz" 144;
}
@media(max-width:780px){
  .chapter-break{padding:80px 0}
}

/* ============================================================
   MEGA MARQUEE - full-bleed scrolling type (Motto/Chainzoku)
   ============================================================ */
.mega-marquee{
  background:#06070f;
  color:#fafbff;
  padding:80px 0;
  overflow:hidden;
  position:relative;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mega-marquee.mm-light{
  background:var(--bg);
  color:#0c0e1a;
  border-color:rgba(0,0,0,.06);
}
.mega-marquee::before,
.mega-marquee::after{
  content:"";
  position:absolute;
  top:0;bottom:0;
  width:120px;
  z-index:2;
  pointer-events:none;
}
.mega-marquee::before{
  left:0;
  background:linear-gradient(90deg,#06070f,transparent);
}
.mega-marquee::after{
  right:0;
  background:linear-gradient(-90deg,#06070f,transparent);
}
.mega-marquee.mm-light::before{background:linear-gradient(90deg,#f4f6fc,transparent)}
.mega-marquee.mm-light::after{background:linear-gradient(-90deg,#f4f6fc,transparent)}
.mm-track{
  display:flex;
  gap:0;
  white-space:nowrap;
  animation:mmScroll 66s linear infinite;
  will-change:transform;
}
.mm-track > span{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(60px,9vw,140px);
  line-height:1;
  letter-spacing:-3px;
  padding:0 32px;
  font-variation-settings:"opsz" 144;
}
.mm-track > span em{
  font-style:italic;
  font-weight:400;
  color:var(--neon);
}
.mega-marquee.mm-light .mm-track > span em{color:#0c0e1a;font-style:italic}
@keyframes mmScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
/* Pause on hover for accessibility */
.mega-marquee:hover .mm-track{animation-play-state:paused}
@media(max-width:780px){
  .mega-marquee{padding:50px 0}
  .mm-track > span{font-size:60px;letter-spacing:-2px}
}

/* ============================================================
   SCROLL EXPANSION - frame grows from small to fullscreen
   ============================================================ */
.scroll-xp{
  height:280vh;
  position:relative;
  background:#06070f;
}
.sxp-pin{
  position:sticky;
  top:0;
  height:100vh;
  width:100%;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  isolation:isolate;
}
.sxp-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 50% 80%,rgba(222,254,0,.08),transparent 60%),
    radial-gradient(ellipse at 30% 30%,rgba(79,124,255,.06),transparent 50%),
    #06070f;
  z-index:0;
}
.sxp-text{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  text-align:center;
  z-index:5;
  width:90%;
  max-width:780px;
  pointer-events:none;
}
.sxp-text-top{top:120px}
.sxp-text-bottom{bottom:120px}
.sxp-eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  margin-bottom:18px;
  display:inline-block;
}
.sxp-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(48px,7vw,96px);
  line-height:1;
  letter-spacing:-2px;
  color:#fafbff;
  margin:0;
  font-variation-settings:"opsz" 144;
}
.sxp-title em{font-style:italic;color:var(--neon);font-weight:400}
.sxp-desc{
  font-family:'Inter',sans-serif;
  font-size:18px;
  line-height:1.5;
  color:rgba(255,255,255,.65);
  margin:0;
}
.sxp-desc em{font-style:italic;color:var(--neon);font-weight:500}

/* The expanding frame - now a giant M logo placeholder */
.sxp-frame{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  width:30vw;
  max-width:480px;
  aspect-ratio:1/1;
  z-index:3;
  transform:scale(var(--sxp-scale,1));
  transform-origin:center center;
  transition:transform 80ms linear;
  will-change:transform;
}
.sxp-logo{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
}
.sxp-logo-mark{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(160px,24vw,360px);
  line-height:.8;
  letter-spacing:-12px;
  color:var(--neon);
  /* Sharp text - only a very subtle glow halo behind */
  text-shadow:0 0 60px rgba(222,254,0,.18);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:geometricPrecision;
}
.sxp-logo-line{
  display:block;
  width:60px;
  height:2px;
  background:rgba(255,255,255,.4);
  margin:18px 0 14px;
}
.sxp-logo-tag{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
}

/* Scroll hint at the bottom */
.sxp-hint{
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
  z-index:5;
  pointer-events:none;
  animation:sxpHintBob 2s ease-in-out infinite;
}
.sxp-hint i{font-size:14px}
@keyframes sxpHintBob{
  0%,100%{transform:translateX(-50%) translateY(0);opacity:.5}
  50%{transform:translateX(-50%) translateY(6px);opacity:1}
}
.sxp-window{
  width:100%;
  height:100%;
  background:var(--bg);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 60px 120px -30px rgba(0,0,0,.6),0 30px 80px -30px rgba(222,254,0,.12);
}
.sxp-bar{
  display:flex;
  align-items:center;
  gap:6px;
  background:#0c0e1a;
  padding:10px 14px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.sxp-dot{
  width:10px;height:10px;border-radius:50%;
}
.sxp-dot:nth-child(1){background:#ff5f57}
.sxp-dot:nth-child(2){background:#febc2e}
.sxp-dot:nth-child(3){background:#28c841}
.sxp-url{
  margin-left:auto;margin-right:auto;
  font-family:var(--mono);
  font-size:11px;
  color:rgba(255,255,255,.45);
  letter-spacing:.5px;
}
.sxp-screen{
  height:calc(100% - 38px);
  background:linear-gradient(180deg,#fafbff 0%,#f4f6fc 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:6%;
}
.sxp-content{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:18px;
  width:100%;
  max-width:78%;
}
.sxp-eyebrow-mini{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:1.8px;
  text-transform:uppercase;
  color:rgba(12,14,26,.5);
}
.sxp-h{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(36px,5vw,72px);
  line-height:.95;
  letter-spacing:-2px;
  color:#0c0e1a;
  font-variation-settings:"opsz" 144;
}
.sxp-h em{font-style:italic;font-weight:500}
.sxp-row{
  display:flex;
  gap:10px;
  width:100%;
}
.sxp-card{
  flex:1;
  aspect-ratio:1.1/1;
  border-radius:8px;
  position:relative;
  overflow:hidden;
}
.sxp-card-1{background:linear-gradient(135deg,#defe00,#a8c700)}
.sxp-card-2{background:linear-gradient(135deg,#4f7cff,#2c4dad)}
.sxp-card-3{background:linear-gradient(135deg,#ff7a45,#cc4a1a)}
.sxp-cta{
  display:inline-flex;
  background:#0c0e1a;
  color:#fafbff;
  padding:14px 22px;
  border-radius:999px;
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:14px;
}

@media(max-width:780px){
  .scroll-xp{height:200vh}
  .sxp-frame{width:80vw}
  .sxp-text-top,.sxp-text-bottom{padding:0 24px}
}

/* ============================================================
   HERO MOCKUP - browser window preview on the right
   ============================================================ */
.hero-mockup{
  position:absolute;
  right:5%;
  top:50%;
  width:42%;
  max-width:580px;
  transform:translateY(-50%) rotate(-2deg);
  z-index:3;
  pointer-events:none;
  opacity:0;
  animation:hmFadeIn 1.4s cubic-bezier(.22,.61,.36,1) .8s forwards;
}
@keyframes hmFadeIn{
  0%{opacity:0;transform:translateY(-30%) rotate(-2deg) scale(.92)}
  100%{opacity:1;transform:translateY(-50%) rotate(-2deg) scale(1)}
}
.hm-window{
  background:var(--bg);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  overflow:hidden;
  box-shadow:
    0 50px 100px -20px rgba(0,0,0,.6),
    0 30px 60px -30px rgba(222,254,0,.15),
    inset 0 1px 0 rgba(255,255,255,.06);
  transform-style:preserve-3d;
}
.hm-bar{
  display:flex;
  align-items:center;
  gap:6px;
  background:#0c0e1a;
  padding:10px 14px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.hm-dot{
  width:10px;height:10px;
  border-radius:50%;
  background:rgba(255,255,255,.18);
}
.hm-dot:nth-child(1){background:#ff5f57}
.hm-dot:nth-child(2){background:#febc2e}
.hm-dot:nth-child(3){background:#28c841}
.hm-url{
  margin-left:auto;
  margin-right:auto;
  font-family:var(--mono);
  font-size:10px;
  color:rgba(255,255,255,.4);
  letter-spacing:.5px;
}
.hm-screen{
  background:linear-gradient(180deg,#fafbff 0%,#f4f6fc 100%);
  padding:18px;
  min-height:340px;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.hm-nav{
  display:flex;
  align-items:center;
  gap:8px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(12,14,26,.08);
}
.hm-logo{
  font-family:var(--display);
  font-weight:900;
  font-size:14px;
  color:#0c0e1a;
  width:24px;
  height:24px;
  border-radius:6px;
  background:#0c0e1a;
  color:var(--neon);
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.hm-link{
  width:38px;height:6px;
  background:rgba(12,14,26,.18);
  border-radius:3px;
}
.hm-cta{
  margin-left:auto;
  width:64px;height:24px;
  background:#0c0e1a;
  border-radius:999px;
}
.hm-hero{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:8px 4px;
}
.hm-eyebrow{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(12,14,26,.45);
}
.hm-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:34px;
  line-height:.95;
  letter-spacing:-1.5px;
  color:#0c0e1a;
  font-variation-settings:"opsz" 144;
  margin:4px 0 6px;
}
.hm-title em{
  font-style:italic;
  font-weight:500;
  position:relative;
}
.hm-title em::after{
  content:"";
  display:block;
  height:2px;
  width:78%;
  background:var(--neon);
  margin-top:-3px;
}
.hm-tag{
  display:block;
  height:6px;
  width:65%;
  background:rgba(12,14,26,.14);
  border-radius:3px;
}
.hm-tag:nth-of-type(2){width:50%}
.hm-button{
  display:inline-flex;
  align-self:flex-start;
  align-items:center;
  background:var(--neon);
  color:#0c0e1a;
  padding:9px 14px;
  border-radius:999px;
  font-family:'Inter',sans-serif;
  font-size:11px;
  font-weight:600;
  margin-top:8px;
}
.hm-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  padding-top:10px;
  border-top:1px solid rgba(12,14,26,.08);
}
.hm-card{
  aspect-ratio:1.2/1;
  background:linear-gradient(135deg,rgba(12,14,26,.06),rgba(12,14,26,.12));
  border-radius:6px;
  position:relative;
  overflow:hidden;
}
.hm-card::after{
  content:"";
  position:absolute;
  bottom:6px;left:6px;
  width:60%;height:4px;
  background:rgba(12,14,26,.2);
  border-radius:2px;
}
.hm-card:nth-child(1)::before{
  content:"";
  position:absolute;
  inset:6px 6px 14px;
  background:linear-gradient(135deg,#defe00,#a8c700);
  border-radius:4px;
  opacity:.4;
}
.hm-card:nth-child(2)::before{
  content:"";
  position:absolute;
  inset:6px 6px 14px;
  background:linear-gradient(135deg,#4f7cff,#2c4dad);
  border-radius:4px;
  opacity:.4;
}
.hm-card:nth-child(3)::before{
  content:"";
  position:absolute;
  inset:6px 6px 14px;
  background:linear-gradient(135deg,#ff7a45,#cc4a1a);
  border-radius:4px;
  opacity:.4;
}

/* Floating badges */
.hm-badge{
  position:absolute;
  background:rgba(12,14,26,.85);
  backdrop-filter:blur(12px) saturate(1.4);
  -webkit-backdrop-filter:blur(12px) saturate(1.4);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:14px 18px;
  display:flex;
  flex-direction:column;
  gap:2px;
  color:#fafbff;
  box-shadow:0 18px 40px -10px rgba(0,0,0,.5);
}
.hb-num{
  font-family:var(--serif);
  font-weight:400;
  font-size:32px;
  line-height:1;
  letter-spacing:-1px;
  color:var(--neon);
  font-variation-settings:"opsz" 144;
}
.hb-num em{font-family:var(--mono);font-style:normal;font-size:14px;color:rgba(255,255,255,.55);letter-spacing:0;margin-left:2px}
.hb-lbl{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.hm-badge-1{
  top:-2%;
  left:-12%;
  transform:rotate(-4deg);
  animation:floatA 9s ease-in-out infinite;
}
.hm-badge-2{
  bottom:8%;
  right:-10%;
  transform:rotate(3deg);
  animation:floatB 10.5s ease-in-out infinite;
}
.hm-badge-3{
  bottom:-5%;
  left:12%;
  transform:rotate(-6deg);
  flex-direction:row;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  animation:floatC 8.5s ease-in-out infinite;
}
.hm-badge-3 i{color:var(--neon);font-size:14px}
@keyframes floatA{0%,100%{transform:rotate(-4deg) translateY(0)}50%{transform:rotate(-4deg) translateY(-5px)}}
@keyframes floatB{0%,100%{transform:rotate(3deg) translateY(0)}50%{transform:rotate(3deg) translateY(-6px)}}
@keyframes floatC{0%,100%{transform:rotate(-6deg) translateY(0)}50%{transform:rotate(-6deg) translateY(-4px)}}

@media(max-width:1100px){
  .hero-mockup{display:none}
}

/* ============================================================
   INTRO STAGE - animated self-presentation
   ============================================================ */
.intro-stage{
  background:#f8f6f1;
  color:#0c0e1a;
  padding:140px 0 160px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.intro-noise{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  opacity:.06;
  mix-blend-mode:multiply;
  pointer-events:none;
  z-index:0;
}
.intro-inner{
  position:relative;
  z-index:2;
  max-width:1100px;
  margin:0 auto;
  padding:0 48px;
}
.intro-stamp{
  position:absolute;
  top:48px;right:48px;
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);
  font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(12,14,26,.55);
  z-index:5;
}
.is-line{width:24px;height:1px;background:rgba(12,14,26,.4)}
.is-k{color:#c91e1e;font-weight:600;display:flex;align-items:center;gap:6px}
.is-k::before{content:"";width:6px;height:6px;background:#c91e1e;border-radius:50%;animation:recBlink 1.4s ease-in-out infinite}
@keyframes recBlink{0%,100%{opacity:1}50%{opacity:.3}}
.is-dot{width:3px;height:3px;background:rgba(12,14,26,.4);border-radius:50%}

/* 1. Greet "Bonjour." - full descender room, no clipping */
.intro-greet{
  margin-bottom:64px;
  padding-bottom:.35em; /* generous room for J descender + breathing */
  overflow:visible;
  line-height:1.2;
}
.ig-word{
  display:inline-block;
  font-family:var(--serif);
  font-weight:300;
  font-style:italic;
  font-size:clamp(64px,11vw,180px);
  line-height:1.15;
  letter-spacing:-4px;
  color:#0c0e1a;
  font-variation-settings:"opsz" 144;
  position:relative;
  padding-bottom:.2em;
  transform:translateY(40px);
  opacity:0;
  transition:transform 1.2s cubic-bezier(.2,.7,.2,1) .15s,opacity .9s ease .15s;
  /* No clip-path - was cutting descenders */
}
.intro-stage.in .ig-word{transform:translateY(0);opacity:1}
.ig-dot{color:var(--neon);font-style:normal;font-weight:400;display:inline-block;transform:scale(0);transition:transform .5s cubic-bezier(.6,-0.4,.4,1.4) 1.1s}
.intro-stage.in .ig-dot{transform:scale(1)}

/* 2. Identity headline */
.intro-id{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(36px,5vw,64px);
  line-height:1.1;
  letter-spacing:-1.5px;
  color:#0c0e1a;
  margin:0 0 80px;
  font-variation-settings:"opsz" 144;
  max-width:none;
  display:flex;
  flex-wrap:wrap;
  gap:.3em;
  align-items:baseline;
}
.intro-id .ii-static{
  opacity:0;transform:translateY(20px);
  transition:opacity .7s ease .8s,transform .7s ease .8s;
}
.intro-stage.in .intro-id .ii-static{opacity:1;transform:none}
.intro-id .ii-typed{
  font-style:italic;
  font-weight:500;
  color:#0c0e1a;
  position:relative;
}
.ii-cursor{
  display:inline-block;
  font-weight:300;
  font-style:normal;
  color:var(--neon);
  animation:cursorBlink 1.1s steps(2) infinite;
  margin-left:2px;
}
@keyframes cursorBlink{0%,49%{opacity:1}50%,100%{opacity:0}}

/* 3. Facts list - staggered fade-up */
.intro-facts{
  list-style:none;padding:0;margin:0 0 96px;
  border-top:1px solid rgba(12,14,26,.12);
}
.intro-facts .if{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:32px;
  align-items:baseline;
  padding:24px 0;
  border-bottom:1px solid rgba(12,14,26,.12);
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s ease,transform .9s cubic-bezier(.22,.61,.36,1);
}
.intro-stage.in .if{opacity:1;transform:none}
.intro-stage.in .if[data-delay="0"]{transition-delay:1.1s}
.intro-stage.in .if[data-delay="1"]{transition-delay:1.25s}
.intro-stage.in .if[data-delay="2"]{transition-delay:1.4s}
.intro-stage.in .if[data-delay="3"]{transition-delay:1.55s}
.intro-stage.in .if[data-delay="4"]{transition-delay:1.7s}
.intro-stage.in .if[data-delay="5"]{transition-delay:1.85s}
.if-k{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(12,14,26,.45);
  font-weight:500;
}
.if-v{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(20px,2.4vw,30px);
  line-height:1.2;
  letter-spacing:-.5px;
  color:#0c0e1a;
  font-variation-settings:"opsz" 144;
}
.if-v em{font-style:italic;font-weight:500;color:#0c0e1a}
.if-blip{
  display:inline-block;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--neon);
  box-shadow:0 0 0 1.5px #0c0e1a, 0 0 0 5px rgba(222,254,0,.3);
  animation:blip 1.6s ease-in-out infinite;
  margin-right:6px;
  vertical-align:middle;
}
@keyframes blip{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.7);opacity:.6}}
.if-dot{
  display:inline-block;
  width:10px;height:10px;
  border-radius:50%;
  background:var(--neon);
  box-shadow:0 0 0 1.5px #0c0e1a;
  vertical-align:middle;
  margin:0 8px;
  font-size:0;
}

/* 4. Closing quote + signature */
.intro-close{
  display:grid;
  grid-template-columns:1fr auto;
  gap:64px;
  align-items:end;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .9s ease 2.1s,transform .9s ease 2.1s;
}
.intro-stage.in .intro-close{opacity:1;transform:none}
.ic-quote{
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:clamp(22px,2.6vw,34px);
  line-height:1.35;
  color:rgba(12,14,26,.85);
  margin:0;
  max-width:50ch;
  font-variation-settings:"opsz" 144;
  position:relative;
}
.ic-q-mark{
  font-style:normal;
  color:var(--neon);
  font-weight:500;
  font-size:1.3em;
  display:inline-block;
  transform:translateY(.1em);
}
/* Decorative neon quotation marks flanking the closing line - inline, so they
   stay locked to the first/last word with no fragile absolute positioning. */
.ic-quote .ig-quote{
  font-family:var(--serif);
  font-weight:700;
  font-style:normal;
  font-size:2.4em;          /* large, prominent pull-quote marks */
  line-height:0;            /* big glyph doesn't expand the line box */
  color:var(--neon);
  text-shadow:0 1px 0 rgba(12,14,26,.18);  /* slight edge definition vs cream */
}
.ic-quote .ig-open{vertical-align:-.30em;margin-right:.04em}  /* opening “ before "Un" */
.ic-quote .ig-close{vertical-align:-.30em;margin-left:.04em}  /* closing ” after "lendemain." */
.ic-sign{
  display:flex;
  flex-direction:column;
  gap:4px;
  border-left:1px solid rgba(12,14,26,.2);
  padding-left:24px;
}
.ic-name{
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size:24px;
  color:#0c0e1a;
}
.ic-role{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(12,14,26,.55);
}

@media(max-width:780px){
  .intro-stage{padding:80px 0}
  .intro-inner{padding:0 24px}
  .intro-stamp{top:24px;right:24px}
  .intro-greet{margin-bottom:40px}
  .ig-word{font-size:64px;letter-spacing:-2px}
  .intro-id{margin-bottom:48px}
  .intro-id .ii-static{font-size:32px}
  .intro-facts .if{grid-template-columns:1fr;gap:6px}
  .if-v{font-size:20px}
  .intro-close{grid-template-columns:1fr;gap:24px}
  .ic-sign{border-left:none;padding-left:0;border-top:1px solid rgba(12,14,26,.2);padding-top:16px}
}

/* ============================================================
   POUR QUI v3 - editorial audience list (replaces bento)
   ============================================================ */
.sec-audience,#process{
  background:#f8f6f1!important;
  color:#0c0e1a;
  padding:140px 0 160px;
}
.sec-audience [hidden]{display:none!important}
.sec-audience .sec-head{margin-bottom:80px}
.sec-audience .sec-eyebrow{color:rgba(12,14,26,.55)}
.sec-audience h2{color:#0c0e1a}
/* Accent underline via an absolutely-positioned ::after bar - the SAME proven method
   as .ai-title em ("vous") and conceptually like .ai-link ("on en parle"). The reveal
   animation wraps each word in an inline-block .w span, and text-decoration does not
   paint under atomic inline-block descendants (it showed only in the spaces between
   words, or nothing for a single word). An absolute ::after bar spans left:0/right:0
   across the whole accent, ignoring the word-wrappers entirely. */
.sec-audience h2 .accent,#process h2 .accent{color:#0c0e1a;font-style:italic;font-weight:400;text-decoration:none!important;background:none!important;position:relative;padding-bottom:0}
.sec-audience h2 .accent::after,#process h2 .accent::after{content:"";position:absolute;left:0;right:0;bottom:.02em;height:7px;background:var(--neon);z-index:-1}
/* Underline fix: the word-reveal mask (.h2-reveal{overflow:hidden}) was clipping the
   accent underline, which sits below the text baseline. Relax the clip for these two
   headings; guard the pre-reveal state with opacity:0 so the translated-down words
   don't peek while the mask is open. */
.sec-audience .h2-reveal,#process .h2-reveal{overflow:visible}
.sec-audience .h2-reveal>span,#process .h2-reveal>span{opacity:0;transition:transform 1s cubic-bezier(.22,1,.36,1),opacity .9s ease}
.sec-audience .reveal.in .h2-reveal>span,#process .reveal.in .h2-reveal>span{opacity:1}
.sec-audience .sec-desc{color:rgba(12,14,26,.7);max-width:54ch}

.audience-list{
  list-style:none;
  margin:0;padding:0;
  border-top:1px solid rgba(12,14,26,.12);
}
.audience-item{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:48px;
  align-items:start;
  padding:42px 0 44px;
  border-bottom:1px solid rgba(12,14,26,.12);
  position:relative;
  transition:background .35s ease;
}
.audience-item:hover{background:rgba(12,14,26,.02)}
.audience-item:hover .ai-title{transform:translateX(8px)}
.ai-num{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:2px;
  color:rgba(12,14,26,.45);
  padding-top:14px;
  font-weight:500;
}
.ai-content{max-width:64ch}
.ai-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(28px,3.6vw,44px);
  line-height:1.1;
  letter-spacing:-1.2px;
  color:#0c0e1a;
  margin:0 0 14px;
  font-variation-settings:"opsz" 144;
  transition:transform .4s cubic-bezier(.22,.61,.36,1);
}
.ai-title em{
  font-style:italic;
  font-weight:500;
  color:#0c0e1a;
  position:relative;
  white-space:nowrap;
}
.ai-title em::after{
  content:"";
  position:absolute;
  bottom:.05em;
  left:0;right:0;
  height:6px;
  background:var(--neon);
  z-index:-1;
  opacity:.45;
}
.ai-desc{
  font-family:'Inter',sans-serif;
  font-size:16px;
  line-height:1.65;
  color:rgba(12,14,26,.7);
  margin:0;
}
.ai-desc strong{color:#0c0e1a;font-weight:600}
.ai-link{
  color:#0c0e1a;
  text-decoration:underline;
  text-decoration-color:var(--neon);
  text-decoration-thickness:3px;
  text-underline-offset:3px;
  font-weight:500;
}
.ai-link:hover{text-decoration-thickness:5px}
@media(max-width:780px){
  .audience-item{grid-template-columns:1fr;gap:12px;padding:32px 0}
  .ai-num{padding-top:0}
}

/* ============================================================
   TARIFS v4 - high-appeal editorial tiers (replaces v3)
   ============================================================ */
.sec-tarifs{background:var(--ink)!important;color:#fafbff;padding:140px 0 160px;position:relative;overflow:hidden}
.sec-tarifs .wrap{position:relative;z-index:1}
.sec-tarifs::before{
  content:'';position:absolute;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(222,254,0,.22) 0%,transparent 70%);
  top:-220px;left:-220px;
  filter:blur(90px);
  animation:tarBlob1 18s ease-in-out infinite;
  pointer-events:none;z-index:0;
}
.sec-tarifs::after{
  content:'';position:absolute;
  width:580px;height:580px;border-radius:50%;
  background:radial-gradient(circle,rgba(222,254,0,.16) 0%,transparent 70%);
  bottom:-180px;right:-120px;
  filter:blur(100px);
  animation:tarBlob2 24s ease-in-out infinite;
  pointer-events:none;z-index:0;
}
@keyframes tarBlob1{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(80px,-50px) scale(1.07)}
  66%{transform:translate(-40px,50px) scale(.94)}
}
@keyframes tarBlob2{
  0%,100%{transform:translate(0,0) scale(1)}
  40%{transform:translate(-60px,40px) scale(1.1)}
  75%{transform:translate(55px,-30px) scale(.91)}
}
.sec-tarifs .sec-head{margin-bottom:72px;text-align:center}
.sec-tarifs .sec-eyebrow{color:rgba(255,255,255,.4)}
.sec-tarifs h2{color:#fafbff;max-width:none}
.sec-tarifs h2 .accent{color:var(--neon)!important;font-style:italic;font-weight:400;text-decoration:none!important}
.sec-tarifs .sec-desc{color:rgba(255,255,255,.6);max-width:54ch}

.tarifs-rail{
  display:grid;
  grid-template-columns:1fr 1.08fr 1fr;
  gap:0;
  align-items:stretch;
  perspective:1400px;
}
.tier{
  position:relative;
  padding:46px 38px 44px;
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.1);
  border-right:none;
  display:flex;
  flex-direction:column;
  transition:box-shadow .35s, transform .5s cubic-bezier(.22,1,.36,1);
  transform-style:preserve-3d;
  will-change:transform;
}
.tier:first-child{border-radius:6px 0 0 6px}
.tier:last-child{border-right:1px solid rgba(255,255,255,.1);border-radius:0 6px 6px 0}

/* keep all card content above the spotlight/shine layers */
.tier>*:not(.tier-clip):not(.tier-spot):not(.tier-beam):not(.tier-flag){position:relative;z-index:2}
.tier-flag{z-index:6}

/* ---- Tarifs motion ---- */
.tier:not(.tier-featured):hover{box-shadow:0 28px 56px -30px rgba(222,254,0,.18)}
.tier.is-tilting{transition:box-shadow .35s}
.tier-clip{position:absolute;inset:0;border-radius:8px;overflow:hidden;pointer-events:none;z-index:1}
.tier-shine{position:absolute;top:0;left:0;width:55%;height:100%;transform:translateX(-160%);
  background:linear-gradient(105deg,transparent 0%,rgba(222,254,0,.16) 50%,transparent 100%)}

/* Static top-center glow on hover */
.tier-spot{
  position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1;
  opacity:0;transition:opacity .5s ease;
  background:radial-gradient(280px circle at 50% 0%,
    rgba(79,124,255,.12), transparent 70%);
}
.tier-featured .tier-spot{
  background:radial-gradient(280px circle at 50% 0%,
    rgba(222,254,0,.15), transparent 70%);
}
.tier:hover .tier-spot{opacity:1}

/* Border beam (21st.dev-style) - light traveling around the featured card edge */
@property --beam-angle{syntax:'<angle>';inherits:false;initial-value:0deg}
.tier-beam{
  position:absolute;inset:-1px;border-radius:9px;padding:1.8px;pointer-events:none;z-index:1;
  filter:drop-shadow(0 0 6px rgba(222,254,0,.55));
  background:conic-gradient(from var(--beam-angle),
    transparent 0deg, transparent 235deg,
    rgba(222,254,0,.3) 285deg, var(--neon) 322deg, #ffffff 340deg, var(--neon) 358deg, transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask-composite:exclude;
}
@media (prefers-reduced-motion:no-preference){
  .tier-beam{animation:beamSpin 4.5s linear infinite}
  .tier-flag{animation:tierFlagPulse 2.8s ease-in-out infinite}
  .tier-featured::after{animation:tierRingBreathe 3.6s ease-in-out infinite}
}
@keyframes beamSpin{to{--beam-angle:360deg}}
@keyframes tierFlagPulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.055)}}
@keyframes tierRingBreathe{0%,100%{box-shadow:inset 0 0 0 1.5px rgba(222,254,0,.45)}50%{box-shadow:inset 0 0 0 1.5px rgba(222,254,0,.9)}}

/* Featured - lifted, neon-ringed, yellow-tinted glass */
.tier-featured{
  background:rgba(222,254,0,.07);
  color:#fafbff;
  border:1px solid rgba(222,254,0,.25)!important;
  margin:-18px 0;
  padding:64px 38px 50px;
  border-radius:8px;
  box-shadow:0 30px 70px -24px rgba(222,254,0,.22);
  z-index:2;
}
.tier-featured::after{
  content:"";position:absolute;inset:0;border-radius:8px;pointer-events:none;
  box-shadow:inset 0 0 0 1.5px rgba(222,254,0,.5);
}

.tier-flag{
  position:absolute;top:0;left:50%;transform:translate(-50%,-50%);
  background:var(--neon);color:#0c0e1a;
  font-family:var(--mono);font-size:10px;letter-spacing:1.8px;text-transform:uppercase;
  padding:7px 16px;border-radius:999px;font-weight:500;white-space:nowrap;
  box-shadow:0 6px 18px -4px rgba(222,254,0,.6);
}
.tier-flag::before{content:"\2605 "}

.tier-head{margin-bottom:22px}
.tier-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.tier-num{font-family:var(--mono);font-size:11px;letter-spacing:2px;color:rgba(255,255,255,.35)}
.tier-name{
  font-family:var(--serif);font-weight:300;font-size:40px;line-height:1;letter-spacing:-1.2px;
  color:#fafbff;margin:0 0 12px;font-variation-settings:"opsz" 144;
}
.tier-desc{font-family:'Inter',sans-serif;font-size:14px;line-height:1.55;color:rgba(255,255,255,.55);margin:0;min-height:44px}

/* Price */
.tier-price{display:flex;align-items:flex-start;gap:6px;margin:0 0 4px}
.tp-num{
  font-family:var(--serif);font-weight:300;font-size:78px;line-height:.92;letter-spacing:-2px;
  color:#fafbff;font-variation-settings:"opsz" 144;
}
.tp-cur{
  font-family:var(--serif);font-weight:300;font-size:30px;line-height:1;color:rgba(255,255,255,.5);
  margin-top:8px;
}
.tp-quote{
  font-family:var(--serif);font-weight:300;font-size:46px;line-height:1;letter-spacing:-1.5px;
  color:#fafbff;font-variation-settings:"opsz" 144;white-space:nowrap;font-style:italic;
  padding:14px 0 16px;
}
.tier-meta{
  font-family:var(--mono);font-size:10px;letter-spacing:1.1px;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin:0 0 28px;
}

/* List */
.tier-incl{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(255,255,255,.38);padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:6px;
}
.tier-list{list-style:none;padding:0;margin:0 0 34px;flex:1}
.tier-list li{
  font-family:'Inter',sans-serif;font-size:14px;line-height:1.45;color:rgba(255,255,255,.72);
  padding:12px 0 12px 28px;position:relative;
}
.tier-list li>i{display:none}
.tier-list li::before{
  content:"\2713";position:absolute;left:0;top:12px;font-size:13px;font-weight:700;color:var(--neon);
}
.tier-list li.inherit{font-weight:600;color:rgba(255,255,255,.9)}
.tier-list li.inherit::before{content:"\271A";color:var(--neon)}
.tier-list li strong{color:#fff;font-weight:600}

/* CTA */
.tier-cta{
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;letter-spacing:.2px;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  background:transparent;color:rgba(255,255,255,.8);border:1.5px solid rgba(255,255,255,.22);
  padding:15px 22px;border-radius:999px;text-decoration:none;
  transition:background .25s,color .25s,border-color .25s,gap .25s;margin-top:auto;
}
.tier-cta:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.4);gap:13px}
.tier-cta i{font-size:11px}
.tier-featured .tier-cta{background:var(--neon);color:#0c0e1a;border-color:var(--neon)}
.tier-featured .tier-cta:hover{background:#fff;border-color:#fff;color:#0c0e1a}
.tier-note{
  font-family:var(--mono);font-size:10px;letter-spacing:.6px;text-transform:uppercase;
  color:rgba(255,255,255,.38);text-align:center;margin-top:14px;
}
.tier-note::before{content:"\2713";color:var(--neon);margin-right:6px;font-weight:700}

.tarifs-foot{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin:56px auto 0;font-family:var(--mono);font-size:11px;letter-spacing:1.2px;
  text-transform:uppercase;color:rgba(255,255,255,.42);
}
.tarifs-foot i{color:rgba(255,255,255,.55)}

@media(max-width:900px){
  .tarifs-rail{grid-template-columns:1fr}
  .tier,.tier:first-child,.tier:last-child{border-radius:6px;border-right:1px solid rgba(255,255,255,.1);margin-bottom:14px}
  .tier-featured{margin:0 0 14px;border:1px solid rgba(222,254,0,.25)!important}
}

/* Lenis scroll behavior fix (Lenis disables native smooth scrolling) */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-scrolling iframe{pointer-events:none}

/* ===== WHATSAPP FLOATING BUTTON ===== */
.wa-float{
  position:fixed;bottom:90px;right:24px;z-index:999;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.45);
  transition:transform .25s,box-shadow .25s;
  text-decoration:none;
}
.wa-float:hover{transform:scale(1.12);box-shadow:0 12px 32px rgba(37,211,102,.6)}
.wa-float i{font-size:26px;color:#fff;line-height:1}
.wa-float .wa-tooltip{
  position:absolute;right:70px;top:50%;transform:translateY(-50%);
  background:#0c0e1a;color:#fff;
  font-size:12px;font-weight:600;letter-spacing:.4px;
  padding:7px 14px;border-radius:8px;
  white-space:nowrap;opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.wa-float:hover .wa-tooltip{opacity:1}
.wa-float .wa-tooltip::after{
  content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);
  border:6px solid transparent;border-left-color:#0c0e1a;
}

/* ===== MOBILE STICKY CTA BAR ===== */
.mob-cta-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:998;
  background:rgba(6,7,15,.96);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-top:1px solid rgba(255,255,255,.1);
  padding:10px 16px 12px;
  padding-bottom:calc(10px + env(safe-area-inset-bottom));
  gap:10px;
}
.mob-cta-bar a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 16px;border-radius:10px;
  font-size:13px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;text-decoration:none;
  transition:transform .2s,opacity .2s;
}
.mob-cta-bar a:active{transform:scale(.97);opacity:.85}
.mob-cta-call{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15)}
.mob-cta-devis{background:var(--neon);color:#000}
@media(max-width:760px){
  .mob-cta-bar{display:flex}
  .wa-float{bottom:90px}
  section#contact,footer{padding-bottom:80px}
}

/* ============================================================
   SHOWCASE REDESIGN - sdemo-* classes
   ============================================================ */

/* Hero */
.sdemo-hero{background:var(--ink);padding:160px 0 80px;position:relative}
.sdemo-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:rgba(255,255,255,.07)}
.sdemo-hl{font-size:clamp(48px,7vw,96px);font-weight:300;color:#fff;line-height:1;margin:16px 0 20px;font-family:var(--serif);text-transform:none;letter-spacing:-2px;font-variation-settings:"opsz" 144}
.sdemo-hl em{color:var(--neon);font-style:italic;font-family:var(--serif);font-weight:400}
.sdemo-sub{color:rgba(255,255,255,.42);font-size:16px;max-width:360px;line-height:1.65;margin:0}

/* Grid wrapper */
.sdemo-grid-sec{background:var(--ink);padding:0 0 120px}
.sdemo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:420px;
  gap:3px;
  max-width:1600px;margin:0 auto;
}
/* Alternating bento pattern: wide / narrow / narrow / wide / wide / narrow */
.sdemo-grid>.sdc:nth-child(1){grid-column:span 2}
.sdemo-grid>.sdc:nth-child(4){grid-column:span 2}
.sdemo-grid>.sdc:nth-child(5){grid-column:span 2}

/* Card base */
.sdc{
  display:block;text-decoration:none;position:relative;overflow:hidden;
  background:var(--proj-bg,#111);
  border:1px solid rgba(255,255,255,.055);
  cursor:pointer;
}
/* Outward glow on hover */
.sdc:hover{
  border-color:rgba(255,255,255,.14);
  box-shadow:0 0 0 1px var(--c1,#defe00),0 20px 80px -20px rgba(0,0,0,.8);
  z-index:2;
}

/* Ambient inner glow - mouse-tracking */
.sdc::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at var(--gx,50%) var(--gy,50%),var(--c1,#defe00) 0%,transparent 55%);
  opacity:.07;
  transition:opacity .4s ease;
  pointer-events:none;
  z-index:0;
  filter:blur(40px);
}
.sdc:hover::after{opacity:.18}

/* Preview: always-visible centre content */
.sdc-preview{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;
  transition:transform .6s cubic-bezier(.22,1,.36,1);
  z-index:1;
}
.sdc:hover .sdc-preview{transform:scale(1.04)}
.sdc-num{
  position:absolute;top:20px;right:24px;
  font-family:var(--ff-cond);font-size:11px;font-weight:700;letter-spacing:2px;
  color:rgba(255,255,255,.18);text-transform:uppercase;
}
.sdc-mini{
  text-align:center;font-size:clamp(28px,4vw,52px);font-weight:300;color:#fff;
  line-height:1.05;font-family:var(--serif);letter-spacing:-1.5px;
  font-variation-settings:"opsz" 144;
}
.sdc-mini em{
  display:block;font-size:clamp(14px,1.6vw,18px);font-weight:400;font-style:italic;
  color:var(--c1,#defe00);letter-spacing:0;margin-top:8px;text-transform:none;
  font-variation-settings:"opsz" 144;
}
.sdc-mini.serif{
  font-weight:400;
}


/* Hover overlay */
.sdc-overlay{
  position:absolute;inset:0;
  background:rgba(6,7,15,.9);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px;gap:14px;
  opacity:0;transition:opacity .3s ease;
  text-align:center;
  z-index:2;
}
.sdc:hover .sdc-overlay{opacity:1}
.sdc-overlay-tag{
  font-size:10px;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;color:var(--c1,#defe00);
}
.sdc-overlay h3{
  font-size:clamp(24px,3vw,40px);font-weight:300;color:#fff;
  margin:0;font-family:var(--serif);letter-spacing:-1.5px;
  font-variation-settings:"opsz" 144;
}
.sdc-overlay p{
  color:rgba(255,255,255,.6);font-size:14px;line-height:1.65;
  max-width:340px;margin:0;
}
.sdc-chips{display:flex;gap:7px;flex-wrap:wrap;justify-content:center}
.sdc-chips span{
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:5px 12px;border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.55);border-radius:999px;
}
.sdc-cta-btn{
  display:inline-flex;align-items:center;gap:10px;padding:13px 26px;
  background:var(--c1,#defe00);color:var(--ink);
  font-size:14px;font-weight:700;letter-spacing:0;
  border-radius:999px;margin-top:4px;
  transition:transform .2s ease,box-shadow .2s ease;
}
.sdc-cta-btn:hover{transform:scale(1.04);box-shadow:0 0 24px -4px var(--c1,#defe00)}

/* Card footer strip (always visible) */
.sdc-foot{
  position:absolute;bottom:0;left:0;right:0;
  padding:14px 20px;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 100%);
  display:flex;align-items:flex-end;justify-content:space-between;
  z-index:2;
}
.sdc-tag{
  font-size:10px;font-weight:700;letter-spacing:2.5px;
  text-transform:uppercase;color:rgba(255,255,255,.4);
}
.sdc-title{
  font-size:15px;font-weight:700;color:#fff;
  margin:0;font-family:var(--ff-cond);text-transform:uppercase;letter-spacing:.5px;
}
/* Mouse-following border glow (Northstrix style) */
.sdc::before{
  content:'';
  position:absolute;
  inset:-1px;
  padding:1.5px;
  border-radius:0;
  background:radial-gradient(180px circle at var(--gx,-200%) var(--gy,50%),var(--c1,#defe00),transparent 65%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:0;
  transition:opacity .3s ease;
  pointer-events:none;
  z-index:10;
}
.sdc:hover::before{opacity:1}

/* Fix: sdemo-grid has id=projets which picks up index #projets blue bg */
.sdemo-grid-sec#projets{background:var(--ink)}
.sdemo-grid-sec#projets::before{display:none}

/* Responsive */
@media(max-width:768px){
  .sdemo-grid{grid-template-columns:1fr;gap:3px}
  .sdemo-grid>.sdc:first-child,.sdemo-grid>.sdc:last-child{grid-column:1;aspect-ratio:4/3}
  .sdemo-grid>.sdc:first-child .sdc-preview,
  .sdemo-grid>.sdc:last-child  .sdc-preview{flex-direction:column;gap:24px}
  .sdemo-grid>.sdc:first-child .sdc-mini,
  .sdemo-grid>.sdc:last-child  .sdc-mini{text-align:center}
  .sdemo-grid>.sdc{aspect-ratio:4/3}
}

/* ===== SHOWCASE ENTRANCE ANIMATION ===== */
.sdc{
  opacity:0;
  transform:translateY(36px);
}
.sdc.sdemo-in{
  opacity:1;
  transform:translateY(0);
  transition:
    opacity .75s cubic-bezier(.22,1,.36,1) var(--sd,0s),
    transform .75s cubic-bezier(.22,1,.36,1) var(--sd,0s),
    border-color .2s,box-shadow .25s;
}

/* ===== PRICING HERO ===== */
.ptarifs-hero{
  background:var(--ink);
  padding:140px 0 100px;
  text-align:center;
}
.pt-eyebrow{
  color:rgba(255,255,255,.4);
  letter-spacing:2px;
  font-size:11px;
  font-family:var(--mono,'Geist Mono','Courier New',monospace);
  text-transform:uppercase;
  display:block;
  margin-bottom:20px;
}
.ptarifs-hl{
  font-family:var(--serif);
  font-size:clamp(52px,8vw,108px);
  font-weight:300;
  color:#fff;
  line-height:1;
  letter-spacing:-3px;
  font-variation-settings:"opsz" 144;
  margin:0 0 28px;
  text-transform:none;
}
.ptarifs-hl em{
  color:var(--neon);
  font-style:italic;
  font-family:var(--serif);
  font-weight:400;
  font-variation-settings:"opsz" 144;
}
.ptarifs-sub{
  font-size:clamp(15px,1.8vw,18px);
  color:rgba(255,255,255,.5);
  max-width:46ch;
  margin:0 auto;
  line-height:1.65;
  font-family:'Inter',sans-serif;
}

/* ===== 3-STEP PROCESS STRIP ===== */
.ptarifs-steps{
  display:flex;
  gap:0;
  margin-bottom:56px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:8px;
  overflow:hidden;
}
.ptarifs-step{
  flex:1;
  display:flex;
  align-items:center;
  gap:16px;
  padding:22px 26px;
  border-right:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.ptarifs-step:last-child{border-right:none}
.pts-num{
  font-family:var(--mono,'Geist Mono','Courier New',monospace);
  font-size:11px;
  letter-spacing:2px;
  color:var(--neon);
  background:rgba(222,254,0,.12);
  border-radius:50%;
  width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.pts-text{display:flex;flex-direction:column;gap:1px}
.pts-text strong{font-size:13px;font-weight:600;color:#fafbff;font-family:'Inter',sans-serif}
.pts-text span{font-size:11px;color:rgba(255,255,255,.45);font-family:'Inter',sans-serif}

/* ===== TRUST STRIP ===== */
.ptarifs-trust{
  display:flex;
  gap:0;
  margin-top:64px;
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:48px;
  justify-content:space-around;
  text-align:center;
}
.pt-stat{display:flex;flex-direction:column;gap:6px;align-items:center}
.pt-stat-num{
  font-family:var(--serif);
  font-size:clamp(36px,4vw,52px);
  font-weight:300;
  color:#fafbff;
  letter-spacing:-2px;
  font-variation-settings:"opsz" 144;
  line-height:1;
}
.pt-stat-label{
  font-size:12px;
  font-family:'Inter',sans-serif;
  color:rgba(255,255,255,.42);
  text-transform:uppercase;
  letter-spacing:1.5px;
}

/* Responsive */
@media(max-width:700px){
  .ptarifs-steps{flex-direction:column}
  .ptarifs-step{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .ptarifs-step:last-child{border-bottom:none}
  .ptarifs-trust{gap:24px;flex-wrap:wrap}
}

/* ===== SUBTLE CENTER GLOW on tier cards (static, no mouse tracking) ===== */
.tier-glow{
  position:absolute;inset:0;
  border-radius:inherit;
  background:radial-gradient(60% 40% at 50% 0%,rgba(255,255,255,.05) 0%,transparent 100%);
  opacity:0;
  transition:opacity .4s ease;
  pointer-events:none;
  z-index:0;
}
.tier-featured .tier-glow{
  background:radial-gradient(60% 40% at 50% 0%,rgba(222,254,0,.09) 0%,transparent 100%);
}
.tier:hover .tier-glow{opacity:1}

/* ===== COMPARISON TABLE ===== */
.pc-wrap{padding:72px 0 0}
.pc-header{margin-bottom:40px}
.pc-title{
  font-family:var(--serif);
  font-size:clamp(26px,3.5vw,44px);
  font-weight:300;
  letter-spacing:-1.5px;
  color:#fafbff;
  margin:12px 0 0;
  font-variation-settings:"opsz" 144;
  line-height:1.1;
}
.pc-title em{font-style:italic;font-weight:400;color:var(--neon)}
.pc-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid rgba(255,255,255,.1)}
.pc-table{width:100%;border-collapse:collapse;font-size:14px}
.pc-table thead th{
  padding:18px 20px;
  text-align:center;
  font-weight:700;
  font-size:14px;
  color:#fafbff;
  border-bottom:2px solid rgba(255,255,255,.1);
  vertical-align:bottom;
  line-height:1.3;
}
.pc-feat-col{text-align:left!important;width:42%}
.pc-col-pro{background:rgba(222,254,0,.07)}
.pc-table small{
  display:block;
  font-size:11px;
  font-weight:400;
  color:rgba(255,255,255,.4);
  margin-top:4px;
  letter-spacing:.3px;
}
.pc-table tbody tr{transition:background .15s}
.pc-table tbody tr:hover{background:rgba(255,255,255,.04)}
.pc-table tbody td{
  padding:12px 20px;
  border-bottom:1px solid rgba(255,255,255,.07);
  text-align:center;
  color:rgba(255,255,255,.5);
  font-size:14px;
}
.pc-table tbody td:first-child{
  text-align:left;
  color:rgba(255,255,255,.82);
  font-weight:500;
}
.pc-table td.yes{color:var(--neon);font-size:13px}
.pc-col-pro.yes{color:var(--neon)}
.pc-table td.no{color:rgba(255,255,255,.18);font-size:16px}
.pc-table td.pc-val{
  color:#fafbff;
  font-weight:600;
  font-size:13px;
}
.pc-sep td{
  padding:16px 20px 6px;
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.3);
  border-bottom:none;
  background:rgba(255,255,255,.03);
}
.pc-sep:hover{background:rgba(255,255,255,.03)!important}
.pc-table tbody tr:last-child td{border-bottom:none}
@media(max-width:700px){
  .pc-table{font-size:12px}
  .pc-table thead th,.pc-table tbody td{padding:9px 10px}
  .pc-feat-col{width:38%}
  .pc-wrap{padding:48px 0 0}
}
@media(max-width:560px){
  .faq-q{font-size:15px;padding:18px 0}
  .faq-icon{width:26px;height:26px;min-width:26px;font-size:16px}
}
