/* ============================================================
   INK THE STUDIO — DESIGN SYSTEM  (css/ink-system.css)
   Langage visuel partagé par toutes les pages internes.
   Écrit d'un bloc. Zéro rustine. Un seul système.
   ------------------------------------------------------------
   Le homepage (index.html) reste autonome (WebGL lourd).
   Toutes les autres pages héritent de CE fichier.
============================================================ */

/* ---------- 1. TOKENS ---------- */
:root{
  /* Surfaces */
  --void:#060608;
  --carbon:#0b0b10;
  --panel:#101017;
  /* Encre */
  --paper:#EDEDF2;
  --body:#B7B7C1;
  --dim:#7E7E8A;
  --faint:#4A4A55;
  /* Lignes */
  --line:rgba(237,237,242,.08);
  --line-strong:rgba(237,237,242,.16);
  /* Accents */
  --ink:#4130F0;
  --ink-soft:rgba(65,48,240,.16);
  --plasma:#00E5FF;
  --plasma-soft:rgba(0,229,255,.12);
  --alert:#FF3B5C;
  --ok:#00E58C;
  --grad:linear-gradient(92deg,#8B7CFF 0%,#4E9FFF 46%,#00E5FF 100%);
  /* Type */
  --f-display:'Syne',system-ui,sans-serif;
  --f-body:'Instrument Sans',system-ui,sans-serif;
  --f-mono:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  /* Espacements */
  --gutter:clamp(20px,4.5vw,72px);
  --maxw:1560px;
  --sp-section:clamp(72px,10vh,150px);
  /* Motion */
  --e-out:cubic-bezier(.16,1,.3,1);
  --e-io:cubic-bezier(.76,0,.24,1);
  /* Rayons */
  --r-sm:4px;
  --r-md:6px;
  --r-lg:10px;
}

/* ---------- 2. RESET & BASE ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--void);
  color:var(--body);
  font-family:var(--f-body);
  font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  min-height:100vh;
}
body.locked{overflow:hidden}
::selection{background:var(--plasma);color:var(--void)}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:none;cursor:pointer;color:inherit}
img,svg,canvas,video{display:block;max-width:100%}
ul{list-style:none}
:focus-visible{outline:2px solid var(--plasma);outline-offset:4px;border-radius:2px}

h1,h2,h3,h4{
  font-family:var(--f-display);font-weight:700;
  text-transform:uppercase;line-height:1.04;
  letter-spacing:-.01em;color:var(--paper);
}
.g,.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- 3. AMBIANCE (fond léger, sans WebGL) ---------- */
.ambient{
  position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:var(--void);
}
.ambient::before,.ambient::after{
  content:"";position:absolute;border-radius:50%;filter:blur(90px);
  opacity:.55;will-change:transform;
}
.ambient::before{
  width:52vw;height:52vw;left:-8vw;top:-12vw;
  background:radial-gradient(circle,rgba(65,48,240,.42),transparent 62%);
  animation:drift1 26s ease-in-out infinite;
}
.ambient::after{
  width:46vw;height:46vw;right:-10vw;bottom:-14vw;
  background:radial-gradient(circle,rgba(0,229,255,.24),transparent 62%);
  animation:drift2 32s ease-in-out infinite;
}
.ambient .grid{
  position:absolute;inset:0;opacity:.5;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 90% at 50% 0%,#000 20%,transparent 75%);
  mask-image:radial-gradient(120% 90% at 50% 0%,#000 20%,transparent 75%);
}
@keyframes drift1{50%{transform:translate(6vw,8vh) scale(1.12)}}
@keyframes drift2{50%{transform:translate(-7vw,-6vh) scale(1.15)}}

.grain{
  position:fixed;inset:-100px;z-index:60;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  animation:grain 900ms steps(4) infinite;
}
@keyframes grain{0%{transform:translate(0,0)}25%{transform:translate(-38px,22px)}50%{transform:translate(24px,-30px)}75%{transform:translate(-14px,-18px)}100%{transform:translate(0,0)}}

/* ---------- 4. CURSEUR ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;z-index:200;pointer-events:none;border-radius:50%;transform:translate(-50%,-50%);display:none}
@media (pointer:fine){.cursor-dot,.cursor-ring{display:block}}
.cursor-dot{width:5px;height:5px;background:var(--plasma)}
.cursor-ring{width:34px;height:34px;border:1px solid rgba(237,237,242,.5);mix-blend-mode:difference;transition:width .35s var(--e-out),height .35s var(--e-out),border-color .35s,background-color .35s}
.cursor-ring.is-hover{width:60px;height:60px;border-color:var(--plasma);background:rgba(0,229,255,.06)}
.cursor-ring.is-press{width:22px;height:22px}
body.cursor-on,body.cursor-on a,body.cursor-on button{cursor:none}

/* ---------- 5. NAVIGATION (identique au homepage) ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:140;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--gutter);
  transition:transform .5s var(--e-out),background .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav::before{content:"";position:absolute;inset:0;bottom:-30px;z-index:-1;pointer-events:none;background:linear-gradient(180deg,rgba(6,6,8,.72) 0%,rgba(6,6,8,0) 100%);transition:opacity .4s}
.nav.is-scrolled::before{opacity:0}
.nav.is-scrolled{background:rgba(6,6,8,.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-color:var(--line)}
.nav.is-hidden{transform:translateY(-100%)}
body.locked .nav{transform:none!important}
.logo{font-family:var(--f-display);font-weight:800;font-size:17px;letter-spacing:.06em;color:var(--paper);position:relative;z-index:130}
.logo em{font-style:normal;color:var(--plasma);animation:blink 1.4s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
.nav-links{display:flex;gap:34px}
.nav-links a{font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--body);text-shadow:0 1px 10px rgba(6,6,8,.6);position:relative;padding:6px 0;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--plasma);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--e-out)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--paper)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
.nav-cta{margin-left:8px}
@media(max-width:980px){.nav-links,.nav .nav-cta{display:none}}

.burger{display:none;position:relative;z-index:130;width:44px;height:44px;margin-right:-8px}
.burger span{position:absolute;left:10px;right:10px;height:1.5px;background:var(--paper);transition:transform .45s var(--e-out),top .45s var(--e-out),opacity .3s}
.burger span:nth-child(1){top:17px}
.burger span:nth-child(2){top:26px}
.burger.is-open span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger.is-open span:nth-child(2){top:21px;transform:rotate(-45deg)}
@media(max-width:980px){.burger{display:block}}

.menu{position:fixed;inset:0;z-index:120;background:rgba(6,6,8,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;flex-direction:column;justify-content:center;padding:0 var(--gutter);clip-path:inset(0% 0% 100% 0%);visibility:hidden}
.menu a.menu-link{font-family:var(--f-display);font-weight:800;text-transform:uppercase;font-size:clamp(28px,7vw,54px);line-height:1.12;color:var(--paper);display:flex;align-items:baseline;gap:14px;max-width:100%;white-space:normal;overflow-wrap:break-word;opacity:0;transform:translateY(40px)}
.menu a.menu-link small{font-family:var(--f-mono);font-weight:400;font-size:11px;letter-spacing:.3em;color:var(--plasma)}
.menu-foot{position:absolute;bottom:28px;left:var(--gutter);right:var(--gutter);display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--dim)}

/* ---------- 6. BOUTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--f-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:17px 30px;border-radius:100px;position:relative;overflow:hidden;transition:color .35s,border-color .35s,background-color .35s,box-shadow .35s;will-change:transform}
.btn .arr{transition:transform .35s var(--e-out)}
.btn:hover .arr{transform:translateX(5px)}
.btn-primary{background:var(--paper);color:var(--void);font-weight:500}
.btn-primary::before{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--grad);opacity:0;transition:opacity .35s}
.btn-primary>span{position:relative;z-index:1}
.btn-primary:hover{color:#020204;box-shadow:0 0 42px rgba(0,229,255,.35)}
.btn-primary:hover::before{opacity:1}
.btn-ghost{border:1px solid var(--line-strong);color:var(--paper);background:rgba(6,6,8,.28);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.btn-ghost:hover{border-color:var(--plasma);color:var(--plasma);box-shadow:inset 0 0 24px rgba(0,229,255,.06)}
.btn-sm{padding:12px 22px;font-size:10.5px}
.btn-block{display:flex;width:100%;justify-content:center}

/* ---------- 7. RYTHME DE SECTION ---------- */
main{position:relative;z-index:10}
.section{position:relative;padding:var(--sp-section) var(--gutter);max-width:var(--maxw);margin:0 auto}
.section.narrow{max-width:1120px}
.veil{position:relative}
.veil::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent,rgba(6,6,8,.72) 12%,rgba(6,6,8,.72) 88%,transparent)}

.label{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--dim);margin-bottom:clamp(24px,4vh,40px)}
.label::before{content:"//";color:var(--plasma);letter-spacing:0}
.label .tick{width:7px;height:7px;background:var(--plasma);animation:blink 1.2s steps(2) infinite}

h1.title{font-family:var(--f-display);font-weight:800;font-size:clamp(2.4rem,7vw,5.6rem);line-height:.98;letter-spacing:-.018em;color:var(--paper)}
h2.title{font-size:clamp(2rem,5.4vw,4.4rem);line-height:1.02;margin-bottom:clamp(18px,3vh,30px);max-width:20ch}
.lead{max-width:56ch;font-size:clamp(15px,1.4vw,18px);color:var(--body)}
.eyebrow{font-family:var(--f-mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--plasma);display:block;margin-bottom:10px}

/* En-tête de page interne */
.page-hero{padding:calc(var(--sp-section) + 40px) var(--gutter) clamp(40px,6vh,70px);max-width:var(--maxw);margin:0 auto;position:relative}
.page-hero .lead{margin-top:22px}
.crumbs{font-family:var(--f-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--dim);margin-bottom:26px}
.crumbs a{color:var(--dim);transition:color .3s}
.crumbs a:hover{color:var(--plasma)}
.crumbs span{color:var(--faint);margin:0 8px}

/* ---------- 8. CARTES ---------- */
.card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r-md);background:linear-gradient(165deg,rgba(255,255,255,.035),rgba(255,255,255,.008));padding:clamp(24px,2.6vw,38px);transition:border-color .4s,transform .5s var(--e-out),background .4s;--mx:50%;--my:50%}
.card::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .45s;background:radial-gradient(340px circle at var(--mx) var(--my),rgba(0,229,255,.10),transparent 60%)}
.card:hover{border-color:rgba(0,229,255,.35);transform:translateY(-5px)}
.card:hover::before{opacity:1}
.card-glyph{font-family:var(--f-mono);font-size:13px;color:var(--plasma);border:1px solid rgba(0,229,255,.3);border-radius:var(--r-sm);padding:8px 11px;background:var(--plasma-soft);display:inline-block}
.card h3{font-family:var(--f-display);font-weight:700;font-size:clamp(19px,1.55vw,23px);line-height:1.15;color:var(--paper);margin:22px 0 12px;text-transform:uppercase}
.card p{font-size:14px;line-height:1.6;color:var(--body)}
.card-foot{margin-top:20px;padding-top:16px;border-top:1px solid var(--line);font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}

/* ---------- 9. MARQUEE ---------- */
.marquee{overflow:hidden;white-space:nowrap;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:inline-flex;align-items:center;will-change:transform;animation:scrollX 34s linear infinite}
.marquee[data-dir="rev"] .marquee-track{animation-direction:reverse;animation-duration:40s}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollX{to{transform:translateX(-50%)}}
.mq-item{display:inline-flex;align-items:center;gap:26px;padding:0 26px;font-family:var(--f-display);font-weight:700;text-transform:uppercase;font-size:clamp(18px,2.4vw,30px);color:var(--dim);transition:color .3s}
.mq-item:hover{color:var(--paper)}
.mq-item::after{content:"\2726";font-size:.5em;color:var(--plasma)}

/* ---------- 10. LISTE / STATS ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat{padding:22px 10px;border:1px solid var(--line);border-radius:var(--r-md);background:rgba(255,255,255,.015)}
.stat b{display:block;font-family:var(--f-display);font-weight:800;font-size:clamp(24px,3.4vw,44px);line-height:1;color:var(--paper);font-variant-numeric:tabular-nums}
.stat b small{font-size:.45em;color:var(--plasma);font-weight:700}
.stat span{display:block;margin-top:10px;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--dim)}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}

.ticks{display:flex;gap:12px 30px;flex-wrap:wrap;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim)}
.ticks li{display:flex;gap:9px;align-items:center}
.ticks li::before{content:"[\2713]";color:var(--plasma)}

/* ---------- 11. FORMULAIRE (compatible main.js / Web3Forms) ---------- */
.form-shell{border:1px solid var(--line);border-radius:var(--r-lg);background:linear-gradient(160deg,rgba(16,16,23,.85),rgba(8,8,10,.92));padding:clamp(24px,3.5vw,48px)}
.field{position:relative;margin-bottom:22px}
.field label{display:block;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:9px}
.field input,.field textarea,.field select{width:100%;background:rgba(255,255,255,.02);border:1px solid var(--line-strong);border-radius:var(--r-sm);color:var(--paper);font-family:var(--f-body);font-size:15px;padding:14px 16px;transition:border-color .3s,box-shadow .3s;appearance:none}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--plasma);box-shadow:0 0 0 3px var(--plasma-soft)}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2300E5FF' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.tags{display:flex;flex-wrap:wrap;gap:10px}
.tag{position:relative}
.tag input{position:absolute;opacity:0;pointer-events:none}
.tag .tag-content{display:inline-flex;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:10px 16px;border:1px solid var(--line-strong);border-radius:100px;color:var(--dim);cursor:pointer;transition:all .3s;user-select:none}
.tag input:checked+.tag-content{border-color:var(--plasma);color:var(--plasma);background:var(--plasma-soft)}
.tag input:focus-visible+.tag-content{outline:2px solid var(--plasma);outline-offset:3px}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}
.form-status{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;color:var(--dim);margin-top:14px;min-height:1.2em}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;color:var(--dim);margin:6px 0 22px}
.consent a{color:var(--plasma)}

/* ---------- 12. PRICING ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:stretch}
.price{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r-lg);background:linear-gradient(165deg,rgba(255,255,255,.035),rgba(255,255,255,.006));padding:clamp(26px,2.4vw,38px);position:relative;overflow:hidden;transition:border-color .4s,transform .5s var(--e-out)}
.price:hover{transform:translateY(-6px);border-color:rgba(0,229,255,.3)}
.price.featured{border-color:rgba(0,229,255,.4)}
.price.featured::after{content:"RECOMMANDÉ";position:absolute;top:16px;right:-30px;transform:rotate(45deg);background:var(--grad);color:var(--void);font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;padding:5px 34px;font-weight:600}
.price .p-tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--plasma);margin-bottom:14px}
.price h3{font-family:var(--f-display);font-size:clamp(20px,2vw,26px);color:var(--paper);text-transform:uppercase;margin-bottom:6px}
.price .p-sub{font-size:13.5px;color:var(--dim);margin-bottom:22px;min-height:2.4em}
.price .p-amount{font-family:var(--f-display);font-weight:800;font-size:clamp(34px,4vw,52px);line-height:1;color:var(--paper);margin-bottom:6px}
.price .p-amount small{font-size:.4em;color:var(--dim);font-weight:500;letter-spacing:.05em}
.price .p-note{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;color:var(--plasma);margin-bottom:24px}
.price ul.p-feats{display:flex;flex-direction:column;gap:12px;margin-bottom:30px;flex-grow:1}
.price ul.p-feats li{display:flex;gap:11px;font-size:14px;color:var(--body);line-height:1.4}
.price ul.p-feats li::before{content:"\2713";color:var(--plasma);font-weight:700;flex-shrink:0}
.price ul.p-feats li.muted{color:var(--faint)}
.price ul.p-feats li.muted::before{content:"\2013";color:var(--faint)}
@media(max-width:900px){.price-grid{grid-template-columns:1fr}}

/* ---------- 13. FAQ ---------- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{list-style:none;cursor:pointer;padding:22px 40px 22px 0;position:relative;font-family:var(--f-display);font-weight:700;font-size:clamp(16px,1.7vw,20px);color:var(--paper);text-transform:uppercase;letter-spacing:.005em;transition:color .3s}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--f-mono);font-size:22px;color:var(--plasma);transition:transform .35s var(--e-out)}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq summary:hover{color:var(--plasma)}
.faq .faq-body{padding:0 40px 24px 0;color:var(--body);font-size:15px;line-height:1.7;max-width:74ch}
.faq .faq-body strong{color:var(--paper)}

/* ---------- 14. FOOTER ---------- */
.site-footer{position:relative;z-index:10;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(6,6,8,.9) 30%);padding:54px var(--gutter) 30px;margin-top:var(--sp-section)}
.foot-grid{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap}
.foot-nav{display:flex;gap:26px;flex-wrap:wrap}
.foot-nav a{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);transition:color .3s}
.foot-nav a:hover{color:var(--plasma)}
.foot-base{max-width:var(--maxw);margin:40px auto 0;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--dim)}
.foot-base b{color:var(--paper);font-weight:500}
.foot-base .ok{color:var(--plasma)}

/* ---------- 15. REVEALS ---------- */
[data-reveal] .w{display:inline-block;overflow:hidden;vertical-align:top}
[data-reveal] .wi{display:inline-block;transform:translateY(112%);transition:transform 1s var(--e-out)}
/* FIX : le split JS enveloppe chaque mot dans un inline-block (.wi), et background-clip:text
   ne se propage pas aux enfants inline-block → les mots en dégradé (.g) devenaient invisibles.
   On réapplique donc le dégradé directement sur chaque mot. (Même fix que dans index.html.) */
[data-reveal] .g .wi{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
[data-reveal].in .wi{transform:translateY(0)}
.fade{opacity:0;transform:translateY(26px);transition:opacity .9s var(--e-out),transform .9s var(--e-out)}
.fade.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(24px);transition:opacity .8s var(--e-out),transform .8s var(--e-out)}
.stagger.in>*{opacity:1;transform:none}

/* ---------- 16. HUD (optionnel) ---------- */
.hud{position:fixed;z-index:80;pointer-events:none;font-family:var(--f-mono);font-size:10px;letter-spacing:.28em;color:var(--dim);text-transform:uppercase}
.hud-coords{right:var(--gutter);bottom:22px}
.hud-loc{left:var(--gutter);bottom:22px}
.hud-loc b{color:var(--paper);font-weight:500}
@media(max-width:760px){.hud{display:none}}

/* ---------- 17. RESPONSIVE & MOTION ---------- */
@media(max-width:640px){
  .foot-grid{flex-direction:column;gap:22px}
  .foot-base{flex-direction:column;gap:8px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important}
  html{scroll-behavior:auto}
  .marquee-track{animation:none;transform:none}
  .grain,.ambient::before,.ambient::after{animation:none}
  [data-reveal] .wi,.fade,.stagger>*{transform:none;opacity:1}
}

/* ============================================================
   15. CONTENU HÉRITÉ — articles, pages légales, pages locales
   (permet de migrer ces pages vers ink-system sans toucher
   à leur contenu HTML, donc sans risque pour le SEO)
============================================================ */
.container{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.tech-label{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--plasma);margin-bottom:16px;max-width:100%;overflow-wrap:anywhere}
.ink-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.subtitle{max-width:56ch;font-size:clamp(15px,1.4vw,18px);color:var(--body);line-height:1.65}

/* ---- Pages légales (CGV, confidentialité) ---- */
.legal-main{position:relative;z-index:5}
.legal-container{max-width:880px;margin:0 auto;padding:calc(var(--sp-section) + 40px) var(--gutter) var(--sp-section)}
.legal-container>h1{font-family:var(--f-display);font-weight:800;font-size:clamp(1.9rem,4.6vw,3.4rem);line-height:1.04;letter-spacing:-.015em;color:var(--paper);margin-bottom:clamp(28px,5vh,48px)}
.legal-content h2{font-family:var(--f-display);font-weight:700;font-size:clamp(17px,1.8vw,22px);text-transform:uppercase;letter-spacing:.01em;color:var(--paper);margin:clamp(34px,5vh,52px) 0 14px;padding-top:clamp(22px,3vh,32px);border-top:1px solid var(--line)}
.legal-content h2:first-child{margin-top:0;padding-top:0;border-top:none}
.legal-content p{font-size:15px;line-height:1.75;color:var(--body);margin-bottom:14px}
.legal-content strong{color:var(--paper);font-weight:600}
.legal-content a{color:var(--plasma);text-decoration:none;border-bottom:1px solid rgba(0,229,255,.3);transition:border-color .3s}
.legal-content a:hover{border-color:var(--plasma)}
.legal-content ul{margin:0 0 14px 18px}
.legal-content li{font-size:15px;line-height:1.75;color:var(--body);margin-bottom:6px}

/* ---- Articles de blog ---- */
.article-main{position:relative;z-index:5}
.article-container{max-width:820px;margin:0 auto;padding:calc(var(--sp-section) + 40px) var(--gutter) var(--sp-section)}
.article-header h1{font-family:var(--f-display);font-weight:800;font-size:clamp(1.9rem,4.4vw,3.3rem);line-height:1.06;letter-spacing:-.015em;color:var(--paper)}
.article-meta{display:flex;flex-wrap:wrap;gap:10px 26px;margin:26px 0 clamp(30px,5vh,46px);padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.article-body p{font-size:clamp(15px,1.15vw,17px);line-height:1.8;color:var(--body);margin-bottom:20px}
.article-body h2{font-family:var(--f-display);font-weight:700;font-size:clamp(19px,2vw,26px);color:var(--paper);text-transform:uppercase;letter-spacing:.005em;margin:clamp(34px,5vh,50px) 0 16px}
.article-body strong{color:var(--paper);font-weight:600}
.article-body em{color:var(--paper)}
.article-body a{color:var(--plasma);text-decoration:none;border-bottom:1px solid rgba(0,229,255,.3)}
.article-body ul{margin:0 0 20px 4px;list-style:none}
.article-body ul li{position:relative;padding-left:26px;font-size:clamp(15px,1.15vw,17px);line-height:1.75;color:var(--body);margin-bottom:12px}
.article-body ul li::before{content:"[\2713]";position:absolute;left:0;top:1px;font-family:var(--f-mono);font-size:11px;color:var(--plasma)}
.article-cta{margin-top:clamp(40px,6vh,64px);padding:clamp(28px,3.5vw,44px);border:1px solid var(--line);border-radius:var(--r-md);background:linear-gradient(165deg,rgba(255,255,255,.035),rgba(255,255,255,.008));text-align:center}
.article-cta h3{font-family:var(--f-display);font-weight:700;font-size:clamp(19px,2vw,26px);color:var(--paper);text-transform:uppercase;margin-bottom:12px}
.article-cta p{color:var(--body);font-size:15px;line-height:1.65;margin-bottom:22px}

/* ---- Pages locales (agence-web-*) ---- */
.local-hero{padding:calc(var(--sp-section) + 40px) 0 clamp(36px,5vh,56px)}
.local-hero h1{font-family:var(--f-display);font-weight:800;font-size:clamp(1.9rem,4.8vw,3.8rem);line-height:1.04;letter-spacing:-.015em;color:var(--paper);max-width:22ch}
.local-tagline{margin-top:16px;font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--plasma)}
.local-intro,.local-positioning{margin-top:18px;max-width:70ch;font-size:clamp(15px,1.2vw,17px);line-height:1.75;color:var(--body)}
.local-intro strong,.local-positioning strong{color:var(--paper)}
.local-cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.local-context,.local-services,.local-faq,.local-cta-section{padding:clamp(44px,7vh,84px) 0}
.local-context-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,3vw,48px)}
@media(max-width:900px){.local-context-grid{grid-template-columns:1fr}}
.local-context-block{border:1px solid var(--line);border-radius:var(--r-md);background:linear-gradient(165deg,rgba(255,255,255,.03),rgba(255,255,255,.006));padding:clamp(22px,2.6vw,34px)}
.local-context-block h2,.local-services h2,.local-faq h2,.local-cta-section h2{font-family:var(--f-display);font-weight:700;font-size:clamp(19px,2.3vw,28px);line-height:1.12;text-transform:uppercase;color:var(--paper);margin-bottom:14px}
.local-context-block p,.local-services>.container>p{font-size:15px;line-height:1.7;color:var(--body)}
.local-verticals,.local-neighborhoods{margin-top:16px;list-style:none}
.local-verticals li,.local-neighborhoods li{position:relative;padding-left:24px;font-family:var(--f-mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);line-height:2.2}
.local-verticals li::before,.local-neighborhoods li::before{content:"[\2713]";position:absolute;left:0;font-size:10px;color:var(--plasma)}
.local-services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:26px}
@media(max-width:1100px){.local-services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.local-services-grid{grid-template-columns:1fr}}
.local-service-card{border:1px solid var(--line);border-radius:var(--r-md);background:linear-gradient(165deg,rgba(255,255,255,.035),rgba(255,255,255,.008));padding:22px;transition:border-color .4s,transform .5s var(--e-out)}
.local-service-card:hover{border-color:rgba(0,229,255,.35);transform:translateY(-4px)}
.local-service-card h3{font-family:var(--f-display);font-weight:700;font-size:16px;text-transform:uppercase;color:var(--paper);margin-bottom:10px}
.local-service-card p{font-size:13.5px;line-height:1.65;color:var(--body)}
.local-service-card strong{color:var(--plasma)}
.local-services-cta{margin-top:28px}
.faq-list{border-top:1px solid var(--line);margin-top:22px}
.faq-item{border-bottom:1px solid var(--line);padding:4px 0}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 40px 20px 0;position:relative;font-family:var(--f-display);font-weight:700;font-size:clamp(15px,1.5vw,18px);color:var(--paper);text-transform:uppercase;transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--f-mono);font-size:20px;color:var(--plasma);transition:transform .35s var(--e-out)}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-item summary:hover{color:var(--plasma)}
.faq-item p{padding:0 40px 20px 0;color:var(--body);font-size:14.5px;line-height:1.7;max-width:74ch}
.faq-item strong{color:var(--paper)}
.local-cta-section{text-align:center}
.local-cta-inner p{max-width:56ch;margin:0 auto 26px;font-size:15px;line-height:1.7;color:var(--body)}
.local-cta-inner .tech-label{justify-content:center}

/* ============================================================
   16. CAS CLIENTS (realisation-*.html)
============================================================ */
.page-main{position:relative;z-index:5}
.page-header{max-width:880px;margin:0 auto;padding-top:calc(var(--sp-section) + 40px)}
.page-main>.container{max-width:920px;margin:0 auto;padding-inline:var(--gutter);padding-bottom:var(--sp-section)}
.page-header h1{font-family:var(--f-display);font-weight:800;font-size:clamp(1.9rem,4.6vw,3.6rem);line-height:1.04;letter-spacing:-.015em;color:var(--paper);margin:6px 0 20px}
.page-header .subtitle{margin-bottom:26px}
.case-tags{display:flex;flex-wrap:wrap;gap:8px}
.case-tags .tech-label{border:1px solid var(--line-strong);border-radius:100px;padding:7px 13px;margin-bottom:0;font-size:9.5px;letter-spacing:.14em;color:var(--dim)}
.cs-meta{display:grid;gap:8px;margin-top:6px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cs-meta span{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--dim);line-height:1.6}
.cs-meta strong{color:var(--plasma);font-weight:500}
.cs-meta a{color:var(--plasma);text-decoration:none;border-bottom:1px solid rgba(0,229,255,.3)}
.cs-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:clamp(30px,5vh,48px) 0}
@media(max-width:760px){.cs-stats{grid-template-columns:1fr}}
.cs-stat{border:1px solid var(--line);border-radius:var(--r-md);background:rgba(255,255,255,.015);padding:22px 18px}
.cs-stat-num{display:block;font-family:var(--f-display);font-weight:800;font-size:clamp(26px,3vw,40px);line-height:1;color:var(--paper);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.cs-stat-label{display:block;margin-top:10px;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);line-height:1.7}
.cs-section{margin-top:clamp(40px,6vh,64px)}
.cs-section h2{font-family:var(--f-display);font-weight:700;font-size:clamp(19px,2.2vw,28px);line-height:1.12;text-transform:uppercase;color:var(--paper);margin-bottom:16px}
.cs-section p{font-size:clamp(15px,1.15vw,16.5px);line-height:1.75;color:var(--body);margin-bottom:16px}
.cs-section strong{color:var(--paper);font-weight:600}
.cs-features{list-style:none;margin:4px 0 16px}
.cs-features li{position:relative;padding-left:26px;font-size:clamp(14.5px,1.1vw,16px);line-height:1.7;color:var(--body);margin-bottom:12px}
.cs-features li::before{content:"[\2713]";position:absolute;left:0;top:2px;font-family:var(--f-mono);font-size:11px;color:var(--plasma)}
.cs-features strong{color:var(--paper)}
.cs-section table{width:100%;border-collapse:collapse;font-family:var(--f-mono);font-size:12.5px}
.cs-section th,.cs-section td{padding:12px 14px;border-bottom:1px solid var(--line);color:var(--body)}
.cs-section th{color:var(--plasma);text-transform:uppercase;letter-spacing:.1em;font-size:10px;text-align:left}
.browser-mock{display:flex;align-items:center;gap:7px;padding:10px 14px;border:1px solid var(--line);border-bottom:none;border-radius:var(--r-md) var(--r-md) 0 0;background:rgba(255,255,255,.02)}
.browser-mock .dot{width:9px;height:9px;border-radius:50%;background:var(--line-strong)}
.browser-mock .dot:first-child{background:rgba(255,59,92,.55)}
.browser-url{margin-left:10px;font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.cs-shot{margin-top:clamp(40px,6vh,64px)}
.cs-shot-frame{border:1px solid var(--line);border-radius:0 0 var(--r-md) var(--r-md);overflow:hidden;background:rgba(255,255,255,.01)}
.cs-shot-caption{margin-top:12px;font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.page-cta{margin-top:clamp(48px,7vh,80px);padding:clamp(30px,4vw,52px);border:1px solid var(--line);border-radius:var(--r-lg);background:linear-gradient(165deg,rgba(255,255,255,.035),rgba(255,255,255,.008));text-align:center}
.page-cta h2{font-family:var(--f-display);font-weight:700;font-size:clamp(20px,2.4vw,30px);line-height:1.12;text-transform:uppercase;color:var(--paper);margin-bottom:14px}
.page-cta .subtitle{margin:0 auto 24px}
