/* AXONE — instance du template LUMEN (tokens résolus depuis l'intake). */
:root{
  --bg:#08090C; --bg2:#10131A; --ink:#EAEEF5;
  --ink-dim:color-mix(in srgb,var(--ink) 62%,transparent);
  --ink-faint:color-mix(in srgb,var(--ink) 30%,transparent);
  --accent:#6366F1; --gold:#22D3EE;
  --line:color-mix(in srgb,var(--ink) 12%,transparent);
  --serif:"Fraunces",Georgia,serif; --sans:"Space Grotesk",system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.6;overflow-x:hidden}
body.loading{overflow:hidden;height:100vh}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--accent);color:#fff}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:.98;letter-spacing:-.02em}
.wrap{width:min(1280px,92vw);margin-inline:auto}
.eyebrow{font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);font-weight:500}
.dim{color:var(--ink-dim)}
.grain{position:fixed;inset:-200%;width:500%;height:500%;pointer-events:none;z-index:9000;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");animation:grain 8s steps(6) infinite}
@keyframes grain{0%{transform:translate(0,0)}10%{transform:translate(-5%,-5%)}30%{transform:translate(3%,-8%)}50%{transform:translate(-6%,4%)}70%{transform:translate(5%,5%)}90%{transform:translate(-3%,2%)}100%{transform:translate(0,0)}}
.blob{position:fixed;border-radius:50%;filter:blur(90px);opacity:.5;pointer-events:none;z-index:0}
.blob--1{width:46vw;height:46vw;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 55%,#000),transparent 70%);top:-10vw;right:-8vw;animation:drift 18s var(--ease) infinite alternate}
.blob--2{width:38vw;height:38vw;background:radial-gradient(circle,color-mix(in srgb,var(--gold) 40%,#000),transparent 70%);bottom:-12vw;left:-6vw;animation:drift 22s var(--ease) infinite alternate-reverse}
@keyframes drift{to{transform:translate(6vw,4vw) scale(1.15)}}
.cur,.cur-d{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;mix-blend-mode:difference;transform:translate(-50%,-50%)}
.cur{width:7px;height:7px;background:#fff}
.cur-d{width:42px;height:42px;border:1px solid rgba(255,255,255,.6);transition:width .3s var(--ease),height .3s var(--ease),background .3s}
.cur-d.is-hover{width:74px;height:74px;background:rgba(255,255,255,.1);border-color:transparent}
.cur-d .lbl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;opacity:0;transition:opacity .3s;color:#fff;mix-blend-mode:difference}
.cur-d.is-hover .lbl{opacity:1}
@media(hover:none){.cur,.cur-d{display:none}}
.loader{position:fixed;inset:0;z-index:9500;background:var(--bg);display:flex;align-items:flex-end;justify-content:space-between;padding:6vw;font-family:var(--serif)}
.loader__num{font-size:clamp(4rem,18vw,16rem);line-height:.8;color:var(--ink)}
.loader__lab{font-family:var(--sans);font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);padding-bottom:1.5vw}
.loader.done{transform:translateY(-100%);transition:transform 1s var(--ease)}
.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.6rem clamp(1rem,4vw,3rem);transition:background .4s,padding .4s,backdrop-filter .4s}
.nav.scrolled{background:color-mix(in srgb,var(--bg) 70%,transparent);backdrop-filter:blur(14px);padding-block:1rem;border-bottom:1px solid var(--line)}
.nav__brand{font-family:var(--serif);font-size:1.4rem;letter-spacing:-.01em}
.nav__brand b{color:var(--accent);font-weight:400}
.nav__links{display:flex;gap:2.2rem;align-items:center;font-size:.86rem}
.nav__links a{position:relative;color:var(--ink-dim);transition:color .3s}
.nav__links a:not(.pill)::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--accent);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:not(.pill):hover::after{width:100%}
.pill{border:1px solid var(--ink-faint);border-radius:100px;padding:.6rem 1.3rem;color:var(--ink)!important;transition:background .35s,color .35s,border-color .35s}
.pill:hover{background:var(--accent);border-color:var(--accent);color:#fff!important}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:0 clamp(1rem,4vw,3rem);z-index:1}
.hero__eyebrow{margin-bottom:2rem;overflow:hidden}
.hero h1{font-size:clamp(2.8rem,10.5vw,11rem);font-weight:300}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%)}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:400}
.hero__foot{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-top:clamp(2rem,5vw,4rem);flex-wrap:wrap}
.hero__sub{max-width:44ch;font-size:1.05rem;color:var(--ink-dim)}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}
.btn{position:relative;display:inline-flex;align-items:center;gap:.6rem;padding:1rem 1.8rem;border-radius:100px;font-size:.9rem;font-weight:500;cursor:pointer;border:1px solid transparent;overflow:hidden;will-change:transform}
.btn span{position:relative;z-index:1}
.btn--solid{background:var(--accent);color:#fff}
.btn--solid::before{content:"";position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .45s var(--ease);z-index:0}
.btn--solid:hover{color:#08090C}
.btn--solid:hover::before{transform:translateY(0)}
.btn--ghost{border-color:var(--ink-faint);color:var(--ink)}.btn--ghost:hover{border-color:var(--ink)}
.scrollcue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-faint);display:flex;flex-direction:column;align-items:center;gap:.6rem}
.scrollcue .bar{width:1px;height:42px;background:linear-gradient(var(--accent),transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.marquee{border-block:1px solid var(--line);padding:1.6rem 0;overflow:hidden;white-space:nowrap}
.marquee__track{display:inline-flex;gap:3rem;animation:scrollx 28s linear infinite;will-change:transform}
.marquee__track span{font-family:var(--serif);font-size:clamp(1.4rem,4vw,2.6rem);color:var(--ink-faint);display:inline-flex;align-items:center;gap:3rem}
.marquee__track span::after{content:"✦";color:var(--accent);font-size:.8em}
@keyframes scrollx{to{transform:translateX(-50%)}}
.sec{padding:clamp(5rem,12vw,11rem) 0;position:relative;z-index:1}
.reveal{opacity:0;transform:translateY(40px)}
.sec__label{display:flex;align-items:center;gap:1rem;margin-bottom:3rem;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim)}
.sec__label::before{content:"";width:46px;height:1px;background:var(--accent)}
.manifesto{font-family:var(--serif);font-weight:300;font-size:clamp(1.8rem,5.2vw,4.4rem);line-height:1.06;letter-spacing:-.02em;max-width:20ch}
.manifesto .w{display:inline-block;opacity:.16;transition:opacity .5s var(--ease)}
.manifesto em{font-style:italic;color:var(--accent)}
.svc{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc__cell{background:var(--bg);padding:clamp(2rem,4vw,3.4rem);position:relative;overflow:hidden;transition:background .5s}
.svc__cell::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--accent);transition:width .5s var(--ease)}
.svc__cell:hover{background:var(--bg2)}.svc__cell:hover::after{width:100%}
.svc__n{font-family:var(--serif);font-size:.95rem;color:var(--accent)}
.svc__cell h3{font-size:clamp(1.5rem,2.6vw,2.1rem);margin:1.4rem 0 .8rem;font-weight:400}
.svc__cell p{color:var(--ink-dim);font-size:.96rem;max-width:38ch}
.projects{position:relative}
.ph{height:100vh;display:flex;align-items:center;overflow:hidden}
.ph__track{display:flex;gap:clamp(1.5rem,3vw,3rem);padding-inline:clamp(1rem,4vw,3rem);will-change:transform}
.card{position:relative;flex:0 0 auto;width:clamp(300px,42vw,560px);height:70vh;border-radius:18px;overflow:hidden;border:1px solid var(--line);display:flex;flex-direction:column;justify-content:flex-end;padding:2.4rem}
.card__art{position:absolute;inset:0;z-index:0}
.card__art::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(4,5,8,.88),rgba(4,5,8,.2) 55%,transparent)}
.card__idx{position:absolute;top:1.8rem;right:2rem;font-family:var(--serif);font-size:clamp(3rem,6vw,5rem);color:rgba(255,255,255,.85);z-index:1;line-height:1}
.card__body{position:relative;z-index:1}
.card__meta{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.card h3{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:#fff}
.card__more{margin-top:1rem;font-size:.82rem;color:rgba(255,255,255,.7);display:inline-flex;align-items:center;gap:.5rem}
.card__more .ar{transition:transform .4s var(--ease)}.card:hover .card__more .ar{transform:translateX(8px)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;border-top:1px solid var(--line);padding-top:4rem}
.stat .num{font-family:var(--serif);font-size:clamp(2.6rem,7vw,5.5rem);font-weight:300;line-height:1;background:linear-gradient(120deg,var(--ink),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lab{margin-top:.8rem;color:var(--ink-dim);font-size:.9rem}
.quote{font-family:var(--serif);font-weight:300;font-size:clamp(1.6rem,4.4vw,3.4rem);line-height:1.18;letter-spacing:-.02em;max-width:22ch;margin-inline:auto;text-align:center}
.quote em{font-style:italic;color:var(--accent)}
.quote__by{margin-top:2.4rem;text-align:center;font-family:var(--sans);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim)}
.about{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,6vw,6rem);align-items:center}
.about__media{position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.about__media svg{position:absolute;inset:0;width:100%;height:100%}
.about h2{font-size:clamp(2rem,5vw,4rem);font-weight:300;margin-bottom:1.6rem}
.about p{color:var(--ink-dim);max-width:46ch;margin-bottom:1.2rem}
.ctaband{text-align:center;padding-block:clamp(6rem,14vw,12rem)}
.ctaband h2{font-size:clamp(2.6rem,9vw,8rem);font-weight:300;line-height:.95}
.ctaband h2 em{font-style:italic;color:var(--accent)}
.ctaband .btn{margin-top:3rem}
.footer{border-top:1px solid var(--line);padding:4rem 0 2.5rem}
.footer__grid{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.footer__brand{font-family:var(--serif);font-size:2rem}
.footer a{color:var(--ink-dim);transition:color .3s}.footer a:hover{color:var(--accent)}
.footer__col{display:flex;flex-direction:column;gap:.6rem;font-size:.92rem}
.footer__legal{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);font-size:.78rem;color:var(--ink-faint);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
@media(max-width:860px){.nav__links{position:fixed;inset:0;background:var(--bg2);flex-direction:column;justify-content:center;font-size:1.6rem;gap:2rem;transform:translateX(100%);transition:transform .5s var(--ease)}.nav__links.open{transform:none}.burger{display:flex;z-index:210}.svc{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr);gap:2.5rem}.about{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.hero h1 .line>span{transform:none}.manifesto .w{opacity:1}}
