/* ═══════════════════════════════
   BASE
═══════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#080807;--bg2:#0d0c0a;--bg3:#131210;
  --cream:#ede6d8;--cream-dim:#8a8275;
  --copper:#c4873a;--copper-l:#e8a85a;--copper-dim:rgba(196,135,58,.12);
  --glow:rgba(196,135,58,.18);
  --border:rgba(237,230,216,.07);--border-h:rgba(196,135,58,.3);
  --r:12px;--r2:18px;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --ease-out:cubic-bezier(0,0,.2,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--cream);font-family:'Syne',sans-serif;overflow-x:hidden;cursor:none}

/* Custom scrollbar */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--copper);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--copper-l)}
html{scrollbar-color:var(--copper) var(--bg);scrollbar-width:thin}

/* Grain overlay */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9997;opacity:.04;
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='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
mix-blend-mode:overlay}

/* Scanlines helper */
.scanlines{position:absolute;inset:0;opacity:.022;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(237,230,216,.9) 3px,rgba(237,230,216,.9) 4px);pointer-events:none;z-index:0}

/* ═══════════════════════════════
   CURSOR — Diamond reticle
═══════════════════════════════ */
.c-diamond{position:fixed;top:0;left:0;width:10px;height:10px;background:var(--cream);clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);transform:translate(-50%,-50%);pointer-events:none;z-index:10002;transition:width .15s,height .15s,background .15s}
.c-frame{position:fixed;top:0;left:0;width:30px;height:30px;transform:translate(-50%,-50%);pointer-events:none;z-index:10001;transition:width .28s var(--ease),height .28s var(--ease)}
.c-tl,.c-tr,.c-bl,.c-br{position:absolute;width:6px;height:6px;border-color:rgba(237,230,216,.55);border-style:solid;transition:border-color .2s,width .28s var(--ease),height .28s var(--ease)}
.c-tl{top:0;left:0;border-width:1px 0 0 1px}
.c-tr{top:0;right:0;border-width:1px 1px 0 0}
.c-bl{bottom:0;left:0;border-width:0 0 1px 1px}
.c-br{bottom:0;right:0;border-width:0 1px 1px 0}
body.h .c-diamond{width:14px;height:14px;background:var(--copper)}
body.h .c-frame{width:42px;height:42px}
body.h .c-tl,body.h .c-tr,body.h .c-bl,body.h .c-br{border-color:var(--copper);width:8px;height:8px}
@media(hover:none){.c-diamond,.c-frame{display:none}body{cursor:auto}}

/* ═══════════════════════════════
   NAV
═══════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:22px 52px;display:flex;align-items:center;justify-content:space-between;transition:background .5s,padding .4s}
nav.sc{background:rgba(8,8,7,.93);backdrop-filter:blur(20px);padding:13px 52px;border-bottom:1px solid var(--border)}
.nlogo{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;color:var(--cream);text-decoration:none;letter-spacing:.04em;display:flex;align-items:center;gap:10px}
.nlogo-badge{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--copper);letter-spacing:.18em;text-transform:uppercase;padding:3px 8px;border:1px solid rgba(196,135,58,.3);border-radius:100px}
.nlinks{display:flex;gap:26px;list-style:none;align-items:center}
.nlinks a{color:var(--cream-dim);text-decoration:none;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;transition:color .3s;position:relative;padding-bottom:4px}
/* Active underline indicator */
.nlinks a::after{content:'';position:absolute;bottom:0;left:0;height:1px;background:var(--copper);width:0;transition:width .5s var(--ease)}
.nlinks a.active{color:var(--cream)}
.nlinks a.active::after{width:55%}
.nlinks a:hover{color:var(--cream)}
.nlinks a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}
.lang{display:flex;align-items:center;background:rgba(237,230,216,.04);border:1px solid var(--border);border-radius:100px;padding:3px;gap:2px}
.lb{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:100px;border:none;background:none;color:var(--cream-dim);cursor:none;transition:background .25s,color .25s}
.lb.on{background:var(--copper);color:var(--bg);font-weight:700}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px;z-index:1100}
.burger span{display:block;width:22px;height:1.5px;background:var(--cream);border-radius:2px;transition:transform .3s,opacity .3s}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mob-menu{display:none;position:fixed;inset:0;z-index:1050;background:rgba(8,8,7,.97);backdrop-filter:blur(24px);flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:opacity .35s}
.mob-menu.open{opacity:1;pointer-events:all}
.mob-menu a{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,7vw,48px);font-weight:300;color:var(--cream-dim);text-decoration:none;transition:color .3s}
.mob-menu a:hover{color:var(--copper)}
.mob-close{position:absolute;top:24px;right:24px;width:40px;height:40px;border-radius:50%;border:1px solid rgba(237,230,216,.15);background:none;color:var(--cream-dim);display:flex;align-items:center;justify-content:center;cursor:none;transition:border-color .3s,color .3s,transform .4s var(--spring);z-index:2}
.mob-close:hover{border-color:var(--copper);color:var(--copper);transform:rotate(90deg)}

/* ═══════════════════════════════
   HERO
═══════════════════════════════ */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 52px 88px;position:relative;overflow:hidden}
.h-ambient{position:absolute;inset:0;background:radial-gradient(ellipse 65% 55% at 72% 38%,rgba(196,135,58,.07) 0%,transparent 65%),radial-gradient(ellipse 45% 45% at 12% 75%,rgba(196,135,58,.04) 0%,transparent 60%);will-change:transform}
.h-year{position:absolute;top:140px;right:52px;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--cream-dim);letter-spacing:.22em;text-transform:uppercase;writing-mode:vertical-rl;opacity:0;animation:fu .8s var(--ease-out) 1.2s forwards}
.h-eye{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--copper);margin-bottom:24px;z-index:1;position:relative;opacity:0;animation:fu .8s var(--ease-out) .1s forwards;min-height:1.4em}
/* Typewriter cursor */
.tw-cursor{display:inline-block;width:2px;height:.85em;background:var(--copper);vertical-align:middle;margin-left:2px;animation:twblink 1s ease-in-out infinite}
@keyframes twblink{0%,100%{opacity:1}50%{opacity:0}}
.h-name{font-family:'Cormorant Garamond',serif;font-size:clamp(52px,9.5vw,148px);font-weight:300;line-height:.9;letter-spacing:-.03em;z-index:1;position:relative;opacity:0;animation:fu 1s var(--ease-out) .3s forwards}
.h-name em{font-style:italic;color:var(--copper-l)}
.h-name .ghost{-webkit-text-stroke:1px rgba(237,230,216,.15);color:transparent}
.h-sub{max-width:520px;margin-top:36px;font-size:15px;line-height:1.75;color:var(--cream-dim);z-index:1;position:relative;opacity:0;animation:fu .9s var(--ease-out) .65s forwards}
.h-sub strong{color:var(--cream);font-weight:500}
.h-actions{display:flex;gap:16px;align-items:center;margin-top:44px;z-index:1;position:relative;opacity:0;animation:fu .9s var(--ease-out) .85s forwards}
/* Main CTA */
.btn-main{background:var(--copper);color:var(--bg);padding:14px 32px;border-radius:100px;font-weight:700;font-size:12px;letter-spacing:.09em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:transform .25s var(--spring),box-shadow .3s;border:none;cursor:none;font-family:'Syne',sans-serif;position:relative;overflow:hidden}
.btn-main:hover{transform:scale(1.06)}
/* Pulse ring around CTA */
.btn-main.pulse::before{content:'';position:absolute;inset:-4px;border-radius:100px;border:2px solid var(--copper);animation:pulse-ring 2.2s ease-out infinite;pointer-events:none}
.btn-main.pulse::after{content:'';position:absolute;inset:-10px;border-radius:100px;border:1px solid rgba(196,135,58,.35);animation:pulse-ring 2.2s ease-out .6s infinite;pointer-events:none}
@keyframes pulse-ring{0%{transform:scale(1);opacity:.9}100%{transform:scale(1.22);opacity:0}}
/* Bounce animation — runs until user clicks */
@keyframes btn-bounce{0%,20%,50%,80%,100%{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}
.btn-main.pulse.bouncing{animation:btn-bounce 2.4s cubic-bezier(.36,.07,.19,.97) infinite}
.btn-main.pulse.bouncing:hover{animation:none;transform:scale(1.06)}
.btn-ghost{color:var(--cream-dim);font-size:12px;letter-spacing:.09em;text-transform:uppercase;text-decoration:none;transition:color .3s;display:inline-flex;align-items:center;gap:10px;cursor:none;padding:14px 0;white-space:nowrap}
.btn-ghost svg{flex-shrink:0;width:16px;height:16px;transition:transform .3s}
.btn-ghost:hover{color:var(--cream)}
.btn-ghost:hover svg{transform:translateX(6px)}
/* Separator between CTA and ghost link */
.h-actions .sep{width:1px;height:18px;background:rgba(237,230,216,.15);flex-shrink:0;margin:0 4px}
/* Scroll indicator — minimal, no text */
.h-scroll{position:absolute;bottom:40px;left:52px;display:flex;align-items:center;gap:14px;z-index:1;opacity:0;animation:fu 1s var(--ease-out) 1.3s forwards}
.h-scroll-line{width:36px;height:1px;background:linear-gradient(to right,transparent,var(--copper));animation:sp 2s ease-in-out infinite}
.h-scroll-dot{width:5px;height:5px;border-radius:50%;background:var(--copper);opacity:.6;animation:sp 2s ease-in-out .5s infinite}
@keyframes sp{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes fu{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
/* Hero floating number */
.h-float{position:absolute;right:52px;bottom:88px;font-family:'Cormorant Garamond',serif;font-size:clamp(120px,18vw,240px);font-weight:300;color:rgba(196,135,58,.04);line-height:1;pointer-events:none;z-index:0;letter-spacing:-.05em;animation:fu 1.5s var(--ease-out) 1s forwards;opacity:0}

/* ═══════════════════════════════
   SECTIONS
═══════════════════════════════ */
.sec{padding:110px 52px;position:relative}
.sec-ch{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--copper);display:flex;align-items:center;gap:14px;margin-bottom:14px;position:relative;z-index:1}
.sec-ch::before{content:'';width:22px;height:1px;background:var(--copper)}
.sec-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(36px,5vw,72px);font-weight:300;line-height:1.02;letter-spacing:-.015em;position:relative;z-index:1}
.sec-ttl em{font-style:italic;color:var(--copper-l)}
.div-line{height:1px;background:linear-gradient(to right,transparent,var(--copper) 30%,var(--copper) 70%,transparent);opacity:.18;margin:0 52px}

/* ═══════════════════════════════
   VEDETTE (featured) — FIRST
═══════════════════════════════ */
#vedette{padding:0;position:relative;overflow:hidden;min-height:92vh;display:flex;align-items:center}
.ved-bg{position:absolute;inset:0;background:linear-gradient(180deg,var(--bg) 0%,transparent 15%,transparent 85%,var(--bg) 100%),linear-gradient(to right,rgba(8,8,7,.95) 0%,rgba(8,8,7,.5) 55%,rgba(8,8,7,.95) 100%),radial-gradient(ellipse 90% 80% at 70% 50%,rgba(196,135,58,.1) 0%,transparent 65%)}
.ved-content{position:relative;z-index:1;padding:100px 52px;max-width:680px}
.ved-num{font-family:'Cormorant Garamond',serif;font-size:110px;font-weight:300;color:rgba(196,135,58,.05);line-height:1;margin-bottom:-12px;transition:color .5s}
#vedette:hover .ved-num{color:rgba(196,135,58,.09)}
.ved-eye{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--copper);margin-bottom:20px;display:flex;align-items:center;gap:14px}
.ved-eye::before{content:'';width:24px;height:1px;background:var(--copper)}
.ved-title{font-family:'Cormorant Garamond',serif;font-size:clamp(46px,7vw,104px);font-weight:300;line-height:.92;letter-spacing:-.025em;margin-bottom:26px}
.ved-title em{font-style:italic;color:var(--copper-l)}
.ved-desc{font-size:15px;color:var(--cream-dim);line-height:1.75;max-width:480px;margin-bottom:32px}
.ved-techs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px}
.ved-tech{font-family:'JetBrains Mono',monospace;font-size:9px;padding:5px 12px;border-radius:100px;border:1px solid rgba(196,135,58,.3);color:var(--copper);letter-spacing:.1em;text-transform:uppercase}
.ved-mock{position:absolute;right:0;top:0;bottom:0;width:48%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.ved-mb{width:88%;aspect-ratio:16/10;border-radius:var(--r2);border:1px solid var(--border);background:linear-gradient(135deg,#0a0f1a,#0d1422,#080c14);position:relative;overflow:hidden;transform:perspective(900px) rotateY(-6deg) rotateX(3deg);box-shadow:0 40px 80px rgba(0,0,0,.5),0 0 80px rgba(196,135,58,.06);transition:transform .7s var(--ease);will-change:transform}
#vedette:hover .ved-mb{transform:perspective(900px) rotateY(-2deg) rotateX(1deg)}
/* Vedette background video */
.ved-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.75;border-radius:0;z-index:0}
.ved-shine{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.04) 0%,transparent 50%)}
.ved-lbl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:56px;font-style:italic;color:rgba(196,135,58,.1)}
.ved-hud{position:absolute;bottom:18px;left:18px;right:18px;display:flex;gap:7px}
.ved-bar{height:3px;border-radius:2px;background:rgba(196,135,58,.22);flex:1;position:relative;overflow:hidden}
.ved-bar::after{content:'';position:absolute;top:0;left:0;height:100%;background:var(--copper);border-radius:2px;animation:hp 3s ease-in-out infinite}
.ved-bar:nth-child(1)::after{width:65%}
.ved-bar:nth-child(2)::after{width:40%;animation-delay:.5s}
.ved-bar:nth-child(3)::after{width:80%;animation-delay:1s}
@keyframes hp{0%,100%{opacity:.6}50%{opacity:1}}
.ved-corner{position:absolute;top:12px;right:12px;font-family:'JetBrains Mono',monospace;font-size:9px;color:rgba(196,135,58,.35);letter-spacing:.1em}
.ved-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}

/* ═══════════════════════════════
   PROJECTS — 3-column stagger
═══════════════════════════════ */
#projects{overflow:hidden}
#projects .sec-header{margin-bottom:60px;position:relative;z-index:1}

/* 3 explicit columns with different top offsets */
.scatter-stage{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0 16px;
  align-items:start;
  position:relative;z-index:1;
}
.scatter-col{display:flex;flex-direction:column;gap:16px}
.scatter-col:nth-child(1){padding-top:0}
.scatter-col:nth-child(2){padding-top:60px}
.scatter-col:nth-child(3){padding-top:28px}

/* Cards */
.proj-card{
  border-radius:var(--r2);border:1px solid var(--border);background:var(--bg2);overflow:hidden;cursor:none;
  transition:border-color .45s,box-shadow .45s,transform .45s var(--ease);
  position:relative;
}
/* Slight rotation per card — applied directly */
.proj-card:nth-child(odd){transform:rotate(-.5deg)}
.proj-card:nth-child(even){transform:rotate(.4deg)}
.proj-card:hover{
  transform:rotate(0deg) scale(1.018)!important;
  border-color:var(--border-h);
  box-shadow:0 8px 60px var(--glow),0 24px 55px rgba(0,0,0,.5);
  z-index:10;
}

/* ─── Card internals ─── */
.pc-head{padding:22px 22px 14px}
.pc-tag{display:inline-flex;align-items:center;gap:6px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:var(--copper);background:var(--copper-dim);padding:4px 11px;border-radius:100px;margin-bottom:12px}
.pc-tag::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--copper)}
.pc-title{font-family:'Cormorant Garamond',serif;font-size:clamp(19px,1.9vw,30px);font-weight:400;line-height:1.1;margin-bottom:6px}
.pc-year{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--cream-dim);letter-spacing:.15em}
.pc-visual{width:100%;aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.pc-vi{position:absolute;inset:0;background-size:200% 200%;background-position:center;transition:transform .6s var(--ease)}
.proj-card:hover .pc-vi{animation:gscan 5s ease-in-out infinite}
@keyframes gscan{0%{background-position:0% 0%}50%{background-position:100% 100%}100%{background-position:0% 0%}}
.pc-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s var(--ease);z-index:2;pointer-events:none}
.proj-card.vid-active .pc-video{opacity:1}
.pc-vlabel{position:relative;z-index:3;font-family:'Cormorant Garamond',serif;font-size:clamp(22px,3vw,42px);font-style:italic;font-weight:300;color:rgba(237,230,216,.1);letter-spacing:-.02em;transition:opacity .4s;pointer-events:none;text-align:center;padding:0 12px}
.proj-card.vid-active .pc-vlabel{opacity:0}
.pc-visual::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,8,7,.68) 100%);z-index:1;pointer-events:none}
.pc-body{padding:12px 22px 18px}
.pc-desc{font-size:12.5px;color:var(--cream-dim);line-height:1.65;margin-bottom:11px}
.pc-pills{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:11px}
.pp{font-size:10px;padding:3px 9px;border-radius:100px;border:1px solid var(--border);color:var(--cream-dim);letter-spacing:.04em;transition:border-color .3s,color .3s}
.proj-card:hover .pp{border-color:rgba(196,135,58,.22);color:rgba(237,230,216,.65)}
.pc-foot{display:flex;align-items:center;justify-content:space-between;padding:11px 22px;border-top:1px solid var(--border)}
.pc-foot-txt{font-family:'JetBrains Mono',monospace;font-size:9.5px;color:var(--cream-dim);letter-spacing:.07em}
.pc-foot-txt.hi{color:var(--copper)}
.pc-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--cream-dim);background:none;transition:background .3s,border-color .3s,color .3s,transform .3s var(--spring);cursor:none}
.proj-card:hover .pc-btn{background:var(--copper);border-color:var(--copper);color:var(--bg);transform:rotate(-45deg)}

/* Gradient themes */
.g1{background:linear-gradient(135deg,#0a0d1f,#121828,#060c18)}
.g2{background:linear-gradient(135deg,#0e1a10,#1a2e12,#0a120c)}
.g3{background:linear-gradient(135deg,#0f0a1f,#181025,#0a0815)}
.g4{background:linear-gradient(135deg,#1a130a,#251c0e,#120e06)}
.g5{background:linear-gradient(135deg,#0a1520,#0d1e2a,#060f1a)}
.g6{background:linear-gradient(135deg,#1f0a0a,#2e1010,#180808)}
.g7{background:linear-gradient(135deg,#0a1a14,#102818,#060e0a)}
.g8{background:linear-gradient(135deg,#12100a,#201c10,#0e0c08)}
.g9{background:linear-gradient(135deg,#0a0f1a,#0e1528,#060a12)}
.g10{background:linear-gradient(135deg,#100a18,#1a1025,#0c0810)}

/* ═══════════════════════════════
   ABOUT
═══════════════════════════════ */
#about{background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 50%,var(--bg) 100%)}
.about-wrap{display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:start;margin-top:66px}
.about-left{position:sticky;top:120px}
.aportrait{width:100%;aspect-ratio:5/6;border-radius:var(--r2);background:linear-gradient(145deg,#161310,#221d15,#161310);border:1px solid var(--border);position:relative;overflow:hidden;transition:border-color .4s,box-shadow .4s}
.aportrait:hover{border-color:var(--border-h);box-shadow:0 0 60px var(--glow)}
.ap-glyph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:150px;font-style:italic;color:rgba(196,135,58,.06);transition:color .4s}
.aportrait:hover .ap-glyph{color:rgba(196,135,58,.11)}
.ap-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(237,230,216,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(237,230,216,.025) 1px,transparent 1px);background-size:40px 40px}
.ap-foot{position:absolute;bottom:0;left:0;right:0;padding:26px;background:linear-gradient(transparent,rgba(8,8,7,.8))}
.ap-name{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:600}
.ap-role{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--copper);letter-spacing:.2em;text-transform:uppercase;margin-top:4px}
.about-right{display:flex;flex-direction:column;gap:44px}
.ab{opacity:.3;transform:translateX(16px);transition:opacity .6s,transform .6s}
.ab.vis{opacity:1;transform:translateX(0)}
.ab-n{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--copper);letter-spacing:.22em;margin-bottom:9px}
.ab-h{font-family:'Cormorant Garamond',serif;font-size:clamp(23px,2.5vw,38px);font-weight:400;line-height:1.1;margin-bottom:13px}
.ab-p{font-size:14px;color:var(--cream-dim);line-height:1.8}
.ab-div{height:1px;background:linear-gradient(to right,var(--border),transparent)}

/* ═══════════════════════════════
   SKILLS BENTO
═══════════════════════════════ */
#skills .bento{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;margin-top:54px;position:relative;z-index:1}
.bc{border-radius:var(--r2);border:1px solid var(--border);background:var(--bg3);overflow:hidden;transition:border-color .4s,transform .4s var(--ease),box-shadow .4s}
.bc:hover{border-color:var(--border-h);box-shadow:0 0 50px var(--glow);transform:translateY(-3px)}
.s4{grid-column:span 4}.s6{grid-column:span 6}.s8{grid-column:span 8}
.bp{padding:24px}
.bc-stat{text-align:center;padding:28px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%}
.bsn{font-family:'Cormorant Garamond',serif;font-size:50px;font-weight:300;line-height:1;color:var(--cream)}
.bsn span{color:var(--copper)}
.bsl{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-dim);margin-top:8px}
.blbl{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--copper);margin-bottom:11px}
.sklist{display:flex;flex-wrap:wrap;gap:7px}
.sk{font-size:11px;padding:5px 12px;border-radius:100px;border:1px solid var(--border);color:var(--cream-dim);transition:all .3s}
.bc:hover .sk:nth-child(odd){border-color:rgba(196,135,58,.35);color:var(--copper)}
.bc:hover .sk:nth-child(even){border-color:rgba(237,230,216,.15);color:var(--cream)}
.bc-q{padding:30px;display:flex;flex-direction:column;justify-content:center;height:100%}
.bc-q q{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:400;line-height:1.45;font-style:italic;color:var(--cream);quotes:none}
.bc-q cite{display:block;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--copper);margin-top:13px}

/* ═══════════════════════════════
   CONTACT
═══════════════════════════════ */
#contact{text-align:center;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(196,135,58,.055) 0%,transparent 65%)}
.ct-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(42px,8vw,112px);font-weight:300;line-height:.9;letter-spacing:-.025em;margin:26px 0 40px}
.ct-ttl em{font-style:italic;color:var(--copper-l)}
.ct-sub{font-size:15px;color:var(--cream-dim);max-width:360px;margin:0 auto 42px;line-height:1.75}
.ct-mail{font-family:'Cormorant Garamond',serif;font-size:clamp(16px,2vw,26px);color:var(--cream);text-decoration:none;border-bottom:1px solid rgba(237,230,216,.18);padding-bottom:3px;transition:color .3s,border-color .3s}
.ct-mail:hover{color:var(--copper);border-color:var(--copper)}
.ct-soc{display:flex;gap:14px;justify-content:center;margin-top:44px}
.soc{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--cream-dim);text-decoration:none;transition:border-color .3s,color .3s,transform .3s var(--spring),box-shadow .3s}
.soc svg{width:18px;height:18px;fill:currentColor}
.soc:hover{border-color:var(--copper);color:var(--copper);transform:scale(1.18) translateY(-2px);box-shadow:0 0 22px var(--glow)}
.ct-av{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:32px}
.ct-av::before{content:'';width:6px;height:6px;border-radius:50%;background:#4caf77;box-shadow:0 0 10px #4caf77;animation:bk 2s ease-in-out infinite}
@keyframes bk{0%,100%{opacity:.5}50%{opacity:1}}

/* ═══════════════════════════════
   FOOTER
═══════════════════════════════ */
footer{padding:26px 52px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.ft-c{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--cream-dim);letter-spacing:.08em}
.ft-l{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--cream);text-decoration:none}
.ft-l span{color:var(--copper)}

/* ═══════════════════════════════
   SCROLL REVEAL
═══════════════════════════════ */
.rv{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.rv.vis{opacity:1;transform:translateY(0)}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}
.rvl{opacity:0;transform:translateX(-26px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.rvl.vis{opacity:1;transform:translateX(0)}

/* ═══════════════════════════════
   MODAL — project details + inline carousel
═══════════════════════════════ */
.mo{position:fixed;inset:0;z-index:5000;background:rgba(5,5,4,.97);backdrop-filter:blur(26px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.mo.open{opacity:1;pointer-events:all}
.mb{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);width:92%;max-width:780px;max-height:90vh;overflow-y:auto;transform:scale(.93) translateY(16px);transition:transform .4s var(--spring);position:relative;display:flex;flex-direction:column}
.mo.open .mb{transform:scale(1) translateY(0)}
.mb-inner{padding:48px 48px 36px}
.mcl{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:none;color:var(--cream-dim);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:none;transition:border-color .3s,color .3s,transform .3s;z-index:2}
.mcl:hover{border-color:var(--copper);color:var(--copper);transform:rotate(90deg)}
.m-tag-wrap{margin-bottom:14px}
.m-t{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,4vw,48px);font-weight:400;line-height:1.05;margin-bottom:24px}

/* ─── Inline mini-carousel in modal ─── */
.m-car{width:100%;aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;position:relative;margin-bottom:28px;background:var(--bg3);border:1px solid var(--border)}
.m-car-stage{width:100%;height:100%;position:relative;overflow:hidden}
.m-car-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s var(--ease),transform .6s var(--ease);transform:scale(1.02)}
.m-car-slide.active{opacity:1;transform:scale(1)}
.m-car-slide.leaving{opacity:0;transform:scale(.97)}
.m-car-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.m-car-slide video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.m-car-ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(5,5,4,.75) 100%)}
.m-car-cap{position:absolute;bottom:38px;left:22px;right:60px;font-size:13px;color:var(--cream);font-family:'Cormorant Garamond',serif;font-style:italic}
.m-car-prev,.m-car-next{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;border:1px solid rgba(237,230,216,.18);background:rgba(5,5,4,.6);color:var(--cream-dim);display:flex;align-items:center;justify-content:center;cursor:none;z-index:5;transition:border-color .3s,color .3s,background .3s}
.m-car-prev:hover,.m-car-next:hover{border-color:var(--copper);color:var(--copper)}
.m-car-prev{left:10px}
.m-car-next{right:10px}
/* Progress circle */
.m-car-prog{position:absolute;bottom:10px;right:12px;width:28px;height:28px;z-index:5}
.m-car-prog svg{width:28px;height:28px}
.m-car-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:5}
.m-car-dot{width:4px;height:4px;border-radius:50%;background:rgba(237,230,216,.3);cursor:none;transition:background .3s,transform .3s var(--spring)}
.m-car-dot.on{background:var(--copper);transform:scale(1.4)}

.m-b{font-size:14px;color:var(--cream-dim);line-height:1.85}
.m-b p+p{margin-top:14px}
.m-techs{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}
.m-tp{font-family:'JetBrains Mono',monospace;font-size:9px;padding:5px 12px;border-radius:100px;border:1px solid rgba(196,135,58,.3);color:var(--copper);letter-spacing:.1em;text-transform:uppercase}
.m-foot{padding:20px 48px 28px;display:flex;gap:12px;align-items:center;flex-wrap:wrap;border-top:1px solid var(--border)}
.btn-play{display:inline-flex;align-items:center;gap:8px;background:none;border:1px solid var(--border);color:var(--cream-dim);padding:12px 22px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;cursor:none;transition:border-color .3s,color .3s,background .3s;font-family:'Syne',sans-serif}
.btn-play:hover{border-color:var(--copper);color:var(--copper);background:rgba(196,135,58,.07)}
.btn-play svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
/* Disabled state when no WebGL available */
.btn-play.disabled{opacity:.22;filter:grayscale(.5);pointer-events:none;border-style:dashed}

/* ═══════════════════════════════
   WEBGL MODAL
═══════════════════════════════ */
.wgl-ov{position:fixed;inset:0;z-index:7000;background:rgba(5,5,4,.98);backdrop-filter:blur(30px);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.wgl-ov.open{opacity:1;pointer-events:all}
.wgl-frame{width:min(94vw,1100px);aspect-ratio:16/9;border-radius:var(--r2);overflow:hidden;border:1px solid var(--border);background:var(--bg3);position:relative}
.wgl-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px}
.wgl-placeholder .mono{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;color:var(--copper);text-transform:uppercase}
.wgl-placeholder .ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,4vw,52px);font-style:italic;color:var(--cream);opacity:.7}
.wgl-close{position:absolute;top:-50px;right:0;width:34px;height:34px;border-radius:50%;border:1px solid rgba(237,230,216,.2);background:none;color:var(--cream-dim);display:flex;align-items:center;justify-content:center;cursor:none;transition:border-color .3s,color .3s,transform .3s}
.wgl-close:hover{border-color:var(--copper);color:var(--copper);transform:rotate(90deg)}
@keyframes wgl-load {
  0%   { width: 0%; margin-left: 0 }
  50%  { width: 70%; margin-left: 0 }
  100% { width: 0%; margin-left: 100% }
}
/* Le wglFrame doit être en position relative pour l'iframe absolue */
.wgl-frame { position: relative; }

/* ═══════════════════════════════
   LANG DISPLAY
═══════════════════════════════ */
.fr-t,.en-t{display:none}
html[lang="fr"] .fr-t{display:revert}
html[lang="en"] .en-t{display:revert}
html[lang="fr"] .fr-flex{display:flex!important}
html[lang="en"] .en-flex{display:flex!important}
html[lang="fr"] .fr-iflex{display:inline-flex!important}
html[lang="en"] .en-iflex{display:inline-flex!important}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media(max-width:1100px){
  .scatter-stage{grid-template-columns:repeat(2,1fr)}
  .scatter-col:nth-child(3){display:none}
  /* redistribute col3 cards — handled by JS reshuffle */
}
@media(max-width:900px){
  nav{padding:18px 28px}nav.sc{padding:13px 28px}
  .nlinks{display:none}.burger{display:flex}.mob-menu{display:flex}
  .sec{padding:80px 32px}
  #hero{padding:0 32px 72px}
  .h-year{right:28px}
  .h-scroll{left:32px}
  .div-line{margin:0 32px}
  .scatter-stage{grid-template-columns:1fr 1fr}
  .scatter-col:nth-child(3){display:none}
  .about-wrap{grid-template-columns:1fr 1fr;gap:40px}
  .ved-mock{display:none}.ved-content{padding:80px 32px;max-width:100%}#vedette{min-height:auto}
  .s4{grid-column:span 6}.s6{grid-column:span 6}.s8{grid-column:span 12}
  footer{padding:22px 32px}
  .mb-inner,.m-foot{padding:32px 26px 24px}
  .m-foot{padding:16px 26px 24px}
}
@media(max-width:640px){
  nav{padding:16px 20px}nav.sc{padding:12px 20px}
  .nlogo-badge{display:none}
  .sec{padding:64px 20px}
  #hero{padding:0 20px 64px;justify-content:center;padding-top:100px}
  .h-year{display:none}
  .h-scroll{left:20px}
  .div-line{margin:0 20px}
  .scatter-stage{grid-template-columns:1fr}
  .scatter-col:nth-child(2),.scatter-col:nth-child(3){padding-top:0!important}
  .proj-card:nth-child(n){transform:none!important}
  .proj-card:hover{transform:scale(1.01)!important}
  .about-wrap{grid-template-columns:1fr;gap:40px}.about-left{position:static}.aportrait{aspect-ratio:4/3}
  #skills .bento{grid-template-columns:1fr 1fr;gap:10px}.s4,.s6,.s8{grid-column:span 2}
  .ct-ttl{font-size:clamp(36px,11vw,60px)}.ct-soc{gap:10px}.soc{width:40px;height:40px}
  footer{padding:20px;flex-direction:column;gap:10px;text-align:center}
  .mb-inner,.m-foot{padding:24px 18px 20px}
  .h-float{display:none}
  .wgl-frame{aspect-ratio:4/3}
}
@media(max-width:400px){
  .sec{padding:52px 16px}
  #hero{padding:80px 16px 52px}
  .h-name{font-size:clamp(44px,13vw,74px)}
  .h-sub{font-size:14px}
  .h-actions{flex-direction:column;align-items:flex-start;gap:14px}
  #skills .bento{grid-template-columns:1fr}.s4,.s6,.s8{grid-column:span 1}
  .div-line{margin:0 16px}
}