/* ─────────────────────────────────────────────────────────
   APAM · SITE DESIGN SYSTEM — v2 (refonte 2026)
   Fonts: Barlow Condensed (display italic) · Jost (body) · Lora (quotes)
   Direction: éditoriale, cinématique, instrument-de-bord, bleu accent
───────────────────────────────────────────────────────── */

:root{
  --bg:#080a0e; --bg-2:#0b0d13; --bg-3:#0e1018; --bg-4:#111420;
  --sf:#141720; --sf-2:#191d2c; --sf-3:#1d2233;
  --accent:#2563eb; --acc-2:#818cf8; --acc-d:rgba(37,99,235,.14); --acc-dd:rgba(37,99,235,.06);
  --text:#e4e8f2; --muted:#7a8399; --dim:#32384f;
  --border:rgba(255,255,255,.062); --bds:rgba(255,255,255,.10); --bds-2:rgba(255,255,255,.18);
  --white:#fff;
  --nav-h:72px;
  --side:clamp(20px,5.5vw,88px);
  --r:10px; --rl:18px; --rxl:24px;

  /* states */
  --ok:#22d77a; --warn:#f5a524; --danger:#ef4444;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--text);
  font-family:'Jost',system-ui,sans-serif;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
  min-height:100vh;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,textarea,select{font:inherit;color:inherit}

::-webkit-scrollbar{width:2px;height:2px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent)}
@media(hover:none){body{cursor:auto}*{cursor:auto !important}}

/* ─────────── CURSOR ─────────── */
.cur{position:fixed;pointer-events:none;z-index:9998;top:0;left:0;transform:translate(-50%,-50%);will-change:transform}
.cur-dot{width:5px;height:5px;background:var(--accent);border-radius:50%}
.cur-ring{width:30px;height:30px;border:1px solid rgba(37,99,235,.35);border-radius:50%;transition:width .22s,height .22s,border-color .22s}
body:has(a:hover) .cur-ring,
body:has(button:hover) .cur-ring,
body:has(input:focus) .cur-ring,
body:has(textarea:focus) .cur-ring,
body:has([data-cursor="hover"]:hover) .cur-ring{width:48px;height:48px;border-color:rgba(37,99,235,.6)}

.grain{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='512' height='512' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px}

.pg-bar{position:fixed;top:0;left:0;height:2px;z-index:9999;width:0%;
  background:linear-gradient(90deg,var(--accent),var(--acc-2));box-shadow:0 0 12px rgba(37,99,235,.6);transition:width .05s linear}

/* ─────────── NAV ─────────── */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:200;
  display:flex;align-items:center;padding:0 var(--side);gap:28px;
  border-bottom:1px solid transparent;transition:background .4s,border-color .4s}
.nav.s{background:rgba(8,10,14,.92);border-color:var(--border);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5)}
.nav-logo{display:inline-flex;align-items:center}
.nav-logo img{height:44px;opacity:0;transform:translateY(-10px) scale(.94);filter:blur(6px);animation:logoIn 1s cubic-bezier(.16,1,.3,1) .1s forwards}
@keyframes logoIn{to{opacity:1;transform:none;filter:blur(0)}}

.nav-links{list-style:none;display:flex;align-items:center;gap:28px;margin-left:auto}
.nav-links a{font-size:11px;font-weight:600;letter-spacing:.17em;text-transform:uppercase;color:rgba(255,255,255,.44);transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width .25s}
.nav-links a:hover,.nav-links a.on{color:#fff}
.nav-links a:hover::after,.nav-links a.on::after{width:100%}

.nav-item-drop{position:relative}
.nav-drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-8px);
  min-width:400px;background:rgba(9,12,20,.97);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border:1px solid var(--bds);padding:10px;display:flex;gap:8px;
  opacity:0;pointer-events:none;transition:opacity .24s cubic-bezier(.16,1,.3,1),transform .28s cubic-bezier(.16,1,.3,1);z-index:200}
.nav-drop::before{content:'';position:absolute;top:-5px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:9px;height:9px;background:rgba(9,12,20,.97);border-left:1px solid var(--bds);border-top:1px solid var(--bds)}
.nav-item-drop:hover .nav-drop{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.ndc{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;color:var(--white);padding:12px 10px;
  border:1px solid var(--border);background:var(--sf);transition:border-color .2s,background .2s}
.ndc:hover{border-color:rgba(37,99,235,.4);background:rgba(37,99,235,.08)}
.ndc img{height:52px;width:100%;object-fit:contain;filter:drop-shadow(0 6px 14px rgba(0,0,0,.55));transition:transform .38s cubic-bezier(.16,1,.3,1)}
.ndc:hover img{transform:translateY(-5px) scale(1.07)}
.ndc-name{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:17px;text-transform:uppercase;letter-spacing:-.01em}
.ndc-sub{font-size:8px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}

.nav-icons{display:flex;align-items:center;gap:10px}
.nav-ic{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--bds);border-radius:50%;transition:border-color .2s,background .2s}
.nav-ic:hover{border-color:var(--accent);background:var(--acc-d)}
.nav-ic svg{width:14px;height:14px;fill:rgba(255,255,255,.55)}
.nav-cta{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--white);border:1.5px solid var(--accent);padding:7px 20px;position:relative;overflow:hidden;transition:color .25s}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--accent);transform:translateX(-101%);transition:transform .25s cubic-bezier(.16,1,.3,1);z-index:-1}
.nav-cta:hover::before{transform:translateX(0)}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:8px;margin-left:auto;background:none;border:none}
.nav-burger b{display:block;width:22px;height:1.5px;background:rgba(255,255,255,.75)}

/* ─────────── MOBILE DRAWER ─────────── */
.m-drawer{position:fixed;inset:0;background:rgba(8,10,14,.97);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);z-index:300;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .35s,transform .35s cubic-bezier(.16,1,.3,1)}
.m-drawer.open{opacity:1;pointer-events:auto;transform:none}
.m-drawer-top{display:flex;align-items:center;justify-content:space-between;padding:18px var(--side);border-bottom:1px solid var(--border)}
.m-close{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--bds);border-radius:var(--r);font-size:20px;color:rgba(255,255,255,.6);transition:border-color .2s,color .2s}
.m-close:hover{border-color:var(--accent);color:#fff}
.m-nav{padding:32px var(--side);display:flex;flex-direction:column;gap:2px}
.m-nav a{color:rgba(255,255,255,.78);font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(38px,9vw,60px);line-height:1;text-transform:uppercase;padding:10px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;transition:color .2s}
.m-nav a:hover{color:var(--accent)}
.m-nav a .arr{font-size:18px;opacity:.28;transition:transform .2s,opacity .2s}
.m-nav a:hover .arr{transform:translateX(6px);opacity:.7}
.m-cta-wrap{padding:20px var(--side)}

/* ─────────── COMMONS ─────────── */
.sec{position:relative}
.wrap{max-width:1320px;margin:0 auto;padding:0 var(--side)}
.sp{padding:clamp(80px,12vh,140px) 0}
.sp-sm{padding:clamp(48px,8vh,86px) 0}

.kicker{font-size:9.5px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}
.kicker::before{content:'';width:22px;height:1px;background:var(--accent);flex-shrink:0}
.kicker--mut{color:rgba(255,255,255,.34)}
.kicker--mut::before{background:rgba(255,255,255,.34)}

.h1{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(60px,9vw,140px);line-height:.86;letter-spacing:-.015em;text-transform:uppercase;color:var(--white)}
.h2{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(44px,5.5vw,82px);line-height:.92;text-transform:uppercase;letter-spacing:-.01em;color:var(--white)}
.h3{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(28px,3.2vw,42px);line-height:.96;text-transform:uppercase;letter-spacing:-.005em;color:var(--white)}
.h4{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:20px;line-height:1.1;text-transform:uppercase;letter-spacing:.04em;color:var(--white)}

.outline{color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.3)}

.body-text{font-size:15px;line-height:1.78;color:var(--muted);max-width:580px}
.body-lg{font-size:17px;line-height:1.7;color:var(--text);max-width:640px}

.btns{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;letter-spacing:.12em;text-transform:uppercase;padding:12px 24px;position:relative;overflow:hidden;transition:color .25s;white-space:nowrap;border:1.5px solid transparent}
.btn--fill{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn--fill::before{content:'';position:absolute;inset:0;background:#fff;transform:translateX(-101%);transition:transform .25s cubic-bezier(.16,1,.3,1);z-index:-1}
.btn--fill:hover{color:var(--accent)}
.btn--fill:hover::before{transform:translateX(0)}
.btn--ghost{color:rgba(255,255,255,.62);border-color:var(--bds-2)}
.btn--ghost:hover{color:#fff;border-color:rgba(255,255,255,.3)}
.btn--outline{color:var(--accent);border-color:var(--accent)}
.btn--outline:hover{background:var(--accent);color:#fff}
.btn--lg{padding:16px 32px;font-size:16px}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(4px)}

/* ─────────── PAGE HERO (sub-pages) ─────────── */
.ph{position:relative;padding:calc(var(--nav-h) + clamp(60px,12vh,140px)) 0 clamp(48px,8vh,90px);overflow:hidden;border-bottom:1px solid var(--border)}
.ph::before{content:'';position:absolute;inset:0;
  background:
    radial-gradient(42% 30% at 14% 8%, rgba(37,99,235,.12), transparent 70%),
    radial-gradient(30% 24% at 84% 28%, rgba(255,255,255,.04), transparent 72%);
  pointer-events:none}
.ph-grid{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(37,99,235,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.025) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(160deg,rgba(0,0,0,.6) 10%,transparent 70%);
  -webkit-mask-image:linear-gradient(160deg,rgba(0,0,0,.6) 10%,transparent 70%)}
.ph-inner{position:relative;z-index:1}
.ph-bcrumb{font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.34);display:flex;align-items:center;gap:10px;margin-bottom:20px}
.ph-bcrumb a{color:rgba(255,255,255,.34);transition:color .2s}
.ph-bcrumb a:hover{color:#fff}
.ph-bcrumb .sep{opacity:.5}
.ph-bcrumb .cur{position:static;transform:none;color:var(--accent)}
.ph-title{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:clamp(64px,10vw,160px);line-height:.86;letter-spacing:-.02em;text-transform:uppercase;color:#fff}
.ph-sub{font-size:clamp(13px,1.4vw,16px);font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:18px}
.ph-meta{display:flex;flex-wrap:wrap;gap:32px;margin-top:36px;padding-top:28px;border-top:1px solid var(--border)}
.ph-meta-item{display:flex;flex-direction:column;gap:5px}
.ph-meta-lbl{font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.34)}
.ph-meta-val{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:18px;letter-spacing:.04em;color:#fff}

/* ─────────── TICKER ─────────── */
.ticker{overflow:hidden;background:var(--accent);padding:11px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.ticker-track{display:flex;width:max-content;animation:tick 42s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-item{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-style:italic;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.85);padding:0 24px;white-space:nowrap;display:flex;align-items:center;gap:24px}
.ticker-item::after{content:'✦';opacity:.35;font-size:8px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─────────── CARDS ─────────── */
.card{background:var(--sf);border:1px solid var(--border);border-radius:var(--rl);padding:28px;transition:border-color .3s,transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s}
.card:hover{border-color:rgba(37,99,235,.32);transform:translateY(-4px);box-shadow:0 28px 60px rgba(0,0,0,.45)}

.tag{display:inline-block;font-size:8.5px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);background:var(--acc-d);border:1px solid rgba(37,99,235,.18);padding:4px 10px;border-radius:100px}
.tag--muted{color:rgba(255,255,255,.6);background:rgba(255,255,255,.04);border-color:var(--bds)}

/* ─────────── REVEALS ─────────── */
[data-r]{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
[data-r].on{opacity:1;transform:none}
[data-r="l"]{transform:translateX(-42px)}[data-r="l"].on{transform:none}
[data-r="r"]{transform:translateX(42px)}[data-r="r"].on{transform:none}
[data-r="s"]{opacity:0;transform:scale(.92);filter:blur(12px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1),filter 1s}
[data-r="s"].on{opacity:1;transform:none;filter:blur(0)}
[data-r="clip"]{clip-path:inset(0 100% 0 0 round 2px);opacity:1!important;transform:none!important;transition:clip-path 1.1s cubic-bezier(.16,1,.3,1)}
[data-r="clip"].on{clip-path:inset(0 0% 0 0 round 2px)}
[data-r="blur"]{opacity:0;filter:blur(16px);transform:translateY(12px);transition:opacity 1s,filter 1s,transform 1s}
[data-r="blur"].on{opacity:1;filter:blur(0);transform:none}
[data-d="1"]{transition-delay:.12s}[data-d="2"]{transition-delay:.24s}[data-d="3"]{transition-delay:.36s}[data-d="4"]{transition-delay:.48s}[data-d="5"]{transition-delay:.6s}[data-d="6"]{transition-delay:.72s}[data-d="7"]{transition-delay:.84s}

/* ─────────── FORMS ─────────── */
.field{display:flex;flex-direction:column;gap:8px;position:relative}
.field-lbl{font-size:9.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:8px}
.field-lbl .req{color:var(--accent);font-size:8px}
.field input,.field textarea,.field select{
  width:100%;background:rgba(255,255,255,.025);border:1px solid var(--bds);border-radius:var(--r);padding:14px 16px;color:#fff;font-size:14px;
  transition:border-color .25s,background .25s,box-shadow .25s;
}
.field input:hover,.field textarea:hover,.field select:hover{border-color:rgba(255,255,255,.18)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);background:rgba(37,99,235,.04);box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.field textarea{resize:vertical;min-height:120px;font-family:inherit}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-hint{font-size:11px;color:var(--muted);line-height:1.5}

/* ─────────── FOOTER ─────────── */
.footer{background:var(--bg-2);border-top:1px solid var(--border);padding:60px var(--side) 24px;position:relative}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(37,99,235,.4),transparent)}
.footer-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--border)}
.footer-brand img{height:54px;margin-bottom:18px;opacity:.92}
.footer-tag{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:24px;text-transform:uppercase;line-height:1;letter-spacing:-.01em;color:var(--white);margin-bottom:12px}
.footer-desc{font-size:13px;line-height:1.75;color:var(--muted);max-width:280px}
.footer-coords{margin-top:18px;display:flex;flex-direction:column;gap:6px}
.footer-coords-val{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:14px;letter-spacing:.08em;color:rgba(255,255,255,.65)}
.footer-coords-frq{font-size:9px;font-weight:800;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-top:4px}

.footer-col h5{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col a{font-size:13px;color:rgba(255,255,255,.5);transition:color .2s,padding .2s}
.footer-col a:hover{color:#fff;padding-left:4px}

.footer-bottom{max-width:1320px;margin:0 auto;padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-legal{display:flex;flex-wrap:wrap;gap:18px}
.footer-legal a{font-size:11px;color:rgba(255,255,255,.32);letter-spacing:.04em;transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.7)}
.footer-credit{font-size:11px;color:var(--dim);letter-spacing:.05em}

/* ─────────── UTILITIES ─────────── */
.eyebrow-line{display:flex;align-items:center;gap:12px;font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--accent)}
.eyebrow-line::before{content:'';width:28px;height:1px;background:var(--accent)}

.dot-divider{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.25);display:inline-block;vertical-align:middle;margin:0 8px}

.fade-mask-b{mask-image:linear-gradient(to bottom,#000 70%,transparent);-webkit-mask-image:linear-gradient(to bottom,#000 70%,transparent)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}

/* ─────────── RESPONSIVE ─────────── */
@media(max-width:980px){
  .nav-links,.nav-icons,.nav-cta{display:none}
  .nav-burger{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
}
@media(max-width:600px){
  .footer-grid{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .ph-meta{gap:18px}
  .ph-meta-item{flex:1 1 40%}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  [data-r],[data-r="clip"]{opacity:1 !important;transform:none !important;filter:none !important;clip-path:none !important}
}
