/* ---------- tokens ---------- */
:root{
  --paper:#ede6d6;
  --paper-2:#e4dcc8;
  --paper-3:#d9cfb6;
  --ink:#141210;
  --ink-2:#2a2620;
  --muted:#6b6355;
  --rule:#c9bfa5;
  --stamp:#0023ff;
  --stamp-dark:#001abd;
  --postal:#0023ff;
  --kraft:#8a6b3d;
  --ok:#141210;
  --max:1360px;
  --anim:1;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:"Inter Tight",system-ui,sans-serif;-webkit-font-smoothing:antialiased}
body{
  background:
    radial-gradient(1200px 700px at 10% -10%, rgba(0,35,255,.05), transparent 60%),
    radial-gradient(900px 600px at 110% 20%, rgba(0,35,255,.05), transparent 60%),
    var(--paper);
  background-attachment: fixed;
}

/* paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.08 0 0 0 0 0.07 0 0 0 0 0.06 0 0 0 0.12 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  mix-blend-mode:multiply; opacity:.55;
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:2;
  background:
    repeating-linear-gradient(0deg, rgba(20,18,16,.018) 0 1px, transparent 1px 4px);
  mix-blend-mode:multiply;
}
main{position:relative;z-index:3}

/* ---------- typography ---------- */
.serif{font-family:"Instrument Serif",Georgia,serif;font-weight:400;letter-spacing:-.01em}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;letter-spacing:0}
h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.025em;color:var(--ink)}
p{margin:0;line-height:1.55}
a{color:inherit;text-decoration:none}

/* ---------- layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 48px}
section{position:relative;border-top:1px solid var(--rule)}
section:not(.hero){min-height:100vh;display:flex;flex-direction:column;justify-content:center}
section:not(.hero)>.wrap{width:100%}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;display:inline-block}

/* rip / deckle edge divider */
.rip{height:14px;background:var(--paper);position:relative}
.rip svg{position:absolute;inset:0;width:100%;height:100%}

/* ---------- NAV ---------- */
nav.top{
  position:sticky;top:0;z-index:50;
  background:rgba(237,230,214,.85);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--rule);
}
nav.top .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:52px;width:auto;display:block}
.brand small{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase}
.navlinks{display:flex;gap:28px;font-size:14px;color:var(--ink-2)}
.navlinks a{position:relative;padding:4px 0}
.navlinks a:hover::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--ink)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 18px;border-radius:999px;border:1px solid var(--ink);
  background:var(--ink);color:var(--paper);font-size:13px;font-weight:500;
  transition:transform .2s, background .2s;
  cursor:pointer;
}
.btn:hover{transform:translate(1px,-1px);background:var(--stamp);border-color:var(--stamp)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.btn .dot{width:6px;height:6px;border-radius:50%;background:var(--stamp);box-shadow:0 0 0 3px rgba(0,35,255,.2)}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- HERO BADGE ---------- */
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--paper);
  border:1px solid var(--ink);
  color:var(--ink);
  font-family:"Inter Tight",sans-serif;font-size:13px;font-weight:500;
  padding:8px 16px;border-radius:999px;
  margin-bottom:24px;
}
.hero-badge::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--stamp);flex-shrink:0;
}

/* ---------- HERO ---------- */
.hero{
  padding:40px 0 56px;border-top:none;overflow:hidden;
  min-height:calc(100vh - 71px); /* 71px = hauteur de la nav */
  display:flex;flex-direction:column;justify-content:center;
}
.hero-grid{display:grid;grid-template-columns: minmax(0,1.1fr) minmax(0,.9fr);gap:56px;align-items:center}
.hero-left{min-width:0}
.h-meta{display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.h-meta span{display:inline-flex;align-items:center;gap:8px}
.h-meta .bar{height:1px;width:48px;background:var(--rule)}

h1.display{
  font-family:"Instrument Serif",Georgia,serif;
  font-weight:400;
  font-size: clamp(44px, 6.4vw, 96px);
  line-height:.95;
  letter-spacing:-.025em;
  color:var(--ink);
  word-break:normal;
  overflow-wrap:break-word;
  hyphens:auto;
}
h1.display em{font-style:italic;color:var(--stamp)}
h1.display .u{position:relative;display:inline}
h1.display .u::after{
  content:"";position:absolute;left:-4px;right:-4px;bottom:4px;height:10px;
  background:rgba(0,35,255,.18);z-index:-1;transform:rotate(-.6deg);
}
.hero-sub{max-width:520px;margin-top:20px;color:var(--ink-2);font-size:22px;line-height:1.4;font-family:"Instrument Serif",Georgia,serif;font-weight:400}
.hero-sub em{font-style:italic;color:var(--stamp)}
.hero-sub .u-sub{position:relative;display:inline}
.hero-sub .u-sub::after{content:"";position:absolute;left:-3px;right:-3px;bottom:3px;height:8px;background:rgba(0,35,255,.15);z-index:-1;transform:rotate(-.4deg)}
.hero-sub--muted{font-family:"Inter Tight",sans-serif;font-size:15px;color:var(--muted);margin-top:14px;line-height:1.55}
.hero-cta{display:flex;gap:14px;margin-top:32px;align-items:center;flex-wrap:wrap}
.cta-note{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.1em}

/* hero right */
.hero-right{position:relative;padding-bottom:8px}
.hero-visual{position:relative;overflow:visible;padding:20px 50px 40px 60px}

.hero-photo{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  object-position:center 15%;
  display:block;
  border-radius:24px;
  box-shadow:0 32px 72px -16px rgba(20,18,16,.3), 0 2px 8px rgba(20,18,16,.08);
  outline:1px solid var(--rule);
  outline-offset:8px;
}

/* orbit items */
.orbit-item{position:absolute;filter:drop-shadow(0 10px 22px rgba(20,18,16,.22))}
.orbit-item img{display:block;width:100%;height:auto}

.orbit-flyer{width:130px;bottom:-24px;left:-50px; animation:bob-flyer 4.8s ease-in-out infinite}
.orbit-doc  {width:72px; top:36px;    right:-28px; animation:bob-doc   4.2s ease-in-out .5s infinite}
.orbit-mail {width:72px; bottom:70px; right:-28px; animation:bob-mail  5s   ease-in-out 1.1s infinite}

@keyframes bob-flyer{0%,100%{transform:rotate(-10deg) translateY(0)}  50%{transform:rotate(-10deg) translateY(-12px)}}
@keyframes bob-doc  {0%,100%{transform:rotate(8deg)   translateY(0)}  50%{transform:rotate(8deg)   translateY(-13px)}}
@keyframes bob-mail {0%,100%{transform:rotate(-5deg)  translateY(0)}  50%{transform:rotate(-5deg)  translateY(-10px)}}


/* ticker strip under flyer */
.ticker{
  margin-top:26px;border:1px solid var(--rule);background:rgba(255,253,247,.6);
  padding:14px 18px;display:flex;gap:28px;align-items:center;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);
  overflow:hidden;
}
.ticker .live{display:inline-flex;align-items:center;gap:8px;color:var(--stamp)}
.ticker .live .pulse{width:8px;height:8px;border-radius:50%;background:var(--stamp);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.ticker-track{display:flex;gap:28px;white-space:nowrap;animation:slide calc(40s / var(--anim)) linear infinite}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- SECTIONS shared ---------- */
.section-head{display:flex;justify-content:space-between;align-items:flex-end;padding:40px 0 28px;gap:40px;flex-wrap:wrap}
.section-head h2{
  font-family:"Instrument Serif",Georgia,serif;font-weight:400;
  font-size:clamp(34px,4.4vw,66px);line-height:1;letter-spacing:-.02em;max-width:760px;
}
.section-head h2 em{font-style:italic;color:var(--stamp)}
.section-head aside{max-width:380px;color:var(--muted);font-size:14px;line-height:1.55}

/* ---------- SERVICES ---------- */
.services{padding-bottom:0}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.svc{
  padding:32px 26px 36px;border-right:1px solid var(--rule);
  position:relative;min-height:240px;display:flex;flex-direction:column;justify-content:space-between;
  transition:background .3s;
  cursor:default;
}
.svc:last-child{border-right:none}
.svc:hover{background:rgba(255,253,247,.5)}
.svc .num{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;color:var(--muted)}
.svc h3{font-family:"Instrument Serif",serif;font-weight:400;font-size:36px;letter-spacing:-.02em;margin-top:14px;line-height:1}
.svc h3 em{font-style:italic;color:var(--stamp)}
.svc p{color:var(--ink-2);font-size:15px;line-height:1.55;margin-top:18px}
.svc .tag{
  margin-top:24px;display:inline-flex;align-items:center;gap:8px;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  border:1px dashed var(--rule);padding:6px 10px;width:max-content;
}
.svc .tag::before{content:"";width:6px;height:6px;background:var(--stamp);border-radius:50%}
.svc .glyph{height:88px;margin-top:-6px;margin-bottom:14px;display:flex;align-items:center;justify-content:flex-start}
.svc .glyph svg{height:100%;width:auto}

/* ---------- STATS ---------- */
.stats{padding:0}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--ink)}
.stat{padding:36px 26px;border-right:1px solid var(--rule);position:relative}
.stat:last-child{border-right:none}
.stat .num{
  font-family:"Instrument Serif",serif;font-weight:400;font-size:72px;letter-spacing:-.04em;line-height:.9;color:var(--ink);
}
.stat .suffix{font-family:"Inter Tight",sans-serif;font-size:32px;color:var(--stamp);font-weight:500;margin-left:4px}
.stat .label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:14px}
.stat .sub{font-size:13px;color:var(--ink-2);margin-top:6px;line-height:1.4}

/* ---------- PROCESS ---------- */
.process{padding-bottom:0}
.proc-layout{display:grid;grid-template-columns:280px 1fr;gap:48px;border-top:1px solid var(--ink);padding-top:24px}
.proc-steps{display:flex;flex-direction:column;gap:2px}
.proc-step{
  padding:18px 16px;border:1px dashed transparent;border-left:1px solid var(--rule);
  cursor:pointer;display:flex;align-items:baseline;gap:14px;transition:all .2s;
}
.proc-step:hover{background:rgba(255,253,247,.5)}
.proc-step.active{border:1px dashed var(--ink);background:rgba(255,253,247,.9)}
.proc-step .n{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);width:32px}
.proc-step.active .n{color:var(--stamp)}
.proc-step .t{font-family:"Instrument Serif",serif;font-size:24px;letter-spacing:-.01em}
.proc-step.active .t{color:var(--ink)}
.proc-detail{
  position:relative;min-height:300px;
  background:rgba(255,253,247,.5);border:1px solid var(--rule);padding:44px;
}
.proc-detail .ph{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  display:flex;justify-content:space-between;border-bottom:1px dashed var(--rule);padding-bottom:14px;
}
.proc-detail h3{font-family:"Instrument Serif",serif;font-weight:400;font-size:44px;letter-spacing:-.02em;line-height:1;margin-top:22px}
.proc-detail h3 em{font-style:italic;color:var(--stamp)}
.proc-detail .body{margin-top:22px;max-width:640px;font-size:16.5px;color:var(--ink-2);line-height:1.6}
.proc-detail .body strong{color:var(--ink);font-weight:600}
.proc-detail .kpis{display:flex;gap:32px;margin-top:34px;flex-wrap:wrap}
.proc-detail .kpi{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.proc-detail .kpi b{display:block;font-family:"Instrument Serif",serif;font-size:38px;color:var(--ink);font-weight:400;letter-spacing:-.02em;margin-top:4px;text-transform:none}
.proc-detail .corner{position:absolute;top:20px;right:20px;font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.2em;color:var(--muted);writing-mode:vertical-rl;transform:rotate(180deg)}

/* ---------- MAP ---------- */
.map-section{padding-bottom:0}
.map-wrap{display:grid;grid-template-columns:1.3fr .7fr;gap:48px;border-top:1px solid var(--ink);padding-top:24px}
.map-box{position:relative;background:rgba(255,253,247,.4);border:1px solid var(--rule);padding:32px;overflow:hidden}
.map-svg{width:100%;height:auto;display:block;aspect-ratio:4/3}
.map-corner{position:absolute;font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--muted);letter-spacing:.2em;text-transform:uppercase}
.map-corner.tl{top:16px;left:20px}
.map-corner.tr{top:16px;right:20px}
.map-corner.bl{bottom:16px;left:20px}
.map-corner.br{bottom:16px;right:20px}
.city-card{border:1px solid var(--rule);padding:22px;background:rgba(255,253,247,.5);cursor:pointer;transition:all .2s}
.city-card:hover,.city-card.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.city-card:hover .pop,.city-card.active .pop{color:rgba(237,230,214,.7)}
.city-card + .city-card{margin-top:12px}
.city-card .row{display:flex;justify-content:space-between;align-items:baseline}
.city-card h4{font-family:"Instrument Serif",serif;font-weight:400;font-size:30px;letter-spacing:-.02em}
.city-card .code{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.12em}
.city-card:hover .code,.city-card.active .code{color:rgba(237,230,214,.7)}
.city-card .region{font-size:13px;color:var(--muted);margin-top:4px}
.city-card:hover .region,.city-card.active .region{color:rgba(237,230,214,.8)}
.city-card .pop{margin-top:14px;padding-top:12px;border-top:1px dashed var(--rule);font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;justify-content:space-between}

/* ---------- WHY ---------- */
.why{padding-bottom:0}
.why-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;border-top:1px solid var(--ink);padding-top:24px;align-items:start}
.why h2{font-family:"Instrument Serif",serif;font-weight:400;font-size:clamp(44px,5vw,78px);line-height:1;letter-spacing:-.025em}
.why h2 em{font-style:italic;color:var(--stamp)}
.why-body{font-size:17px;line-height:1.6;color:var(--ink-2)}
.why-body p + p{margin-top:18px}
.why-body strong{color:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.chip{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--rule);padding:8px 12px;color:var(--ink-2)}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- CONTACT ---------- */
.contact{padding:0;background:var(--ink);color:var(--paper);border-top:none}
.contact .wrap{position:relative;padding-top:56px;padding-bottom:56px;text-align:center}
.contact-eyebrow{color:rgba(237,230,214,.6);justify-content:center}
.contact h2{font-family:"Instrument Serif",serif;font-weight:400;font-size:clamp(44px,6vw,96px);line-height:.95;letter-spacing:-.03em;color:var(--paper);margin-top:24px}
.contact h2 em{font-style:italic;color:#4d6dff}
.contact-cta{margin-top:52px;display:flex;flex-direction:column;align-items:center;gap:20px}
.btn-contact{
  display:inline-flex;align-items:center;gap:14px;
  padding:20px 44px;border-radius:999px;
  background:var(--paper);color:var(--ink);
  font-family:"Inter Tight",sans-serif;font-size:17px;font-weight:600;
  text-decoration:none;border:none;cursor:pointer;
  transition:transform .25s, background .25s, color .25s;
}
.btn-contact:hover{background:var(--stamp);color:var(--paper);transform:translate(1px,-3px)}
.btn-contact .arrow{transition:transform .25s}
.btn-contact:hover .arrow{transform:translateX(4px)}
.contact-cta-note{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(237,230,214,.4)}


/* ---------- FOOTER ---------- */
footer{padding:40px 0 32px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
footer .wrap{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed;bottom:28px;right:28px;z-index:200;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.4), 0 1px 4px rgba(0,0,0,.15);
  transition:transform .22s ease, box-shadow .22s ease;
  animation:wa-bob 3s ease-in-out infinite;
}
.wa-float::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:#25D366;z-index:-1;
  animation:wa-ring 2.2s ease-out infinite;
}
.wa-float svg{width:30px;height:30px;display:block;position:relative}
.wa-float:hover{
  transform:scale(1.12) translateY(-3px);
  box-shadow:0 10px 32px rgba(37,211,102,.55), 0 2px 8px rgba(0,0,0,.15);
  animation:none;
}
.wa-float:hover::before{animation:none;opacity:0}
@keyframes wa-ring{
  0%  {transform:scale(1);  opacity:.6}
  100%{transform:scale(1.9);opacity:0}
}
@keyframes wa-bob{
  0%,100%{transform:translateY(0)}
  50%    {transform:translateY(-5px)}
}

/* ---------- Tweaks panel ---------- */
.tweaks{
  position:fixed;bottom:24px;right:24px;z-index:200;
  background:var(--ink);color:var(--paper);border-radius:14px;padding:16px 20px;
  box-shadow:0 20px 50px -10px rgba(0,0,0,.35);min-width:280px;
  display:none;
}
.tweaks.on{display:block}
.tweaks h5{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;color:rgba(237,230,214,.7);font-weight:500}
.tweaks .row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;font-size:13px}
.tweaks input[type=range]{accent-color:#4d6dff;width:140px}
.tweaks .val{font-family:"JetBrains Mono",monospace;font-size:11px;color:rgba(237,230,214,.6);min-width:44px;text-align:right}

/* ---------- Responsive ---------- */
@media (max-width: 960px){
  .wrap{padding:0 24px}
  .hero-grid{grid-template-columns:minmax(0,1fr);min-height:auto;gap:40px}
  .svc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .svc:nth-child(2){border-right:none}
  .svc:nth-child(-n+2){border-bottom:1px solid var(--rule)}
  .stat-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--rule)}
  .proc-layout,.map-wrap,.why-grid,.contact-grid{grid-template-columns:minmax(0,1fr);gap:32px}
  .navlinks{display:none}
}
