
    /* ==============================================
       VARIABLES DARK / LIGHT
       ============================================== */
    [data-theme="dark"] {
      --bg: #080808;
      --bg2: #0e0e0e;
      --card: rgba(255,255,255,0.03);
      --card-solid: #111;
      --text: #f1f1f1;
      --muted: #94a3b8;
      --muted2: #64748b;
      --accent: #00ff87;
      --accent2: #f97316;
      --accent3: #a855f7;
      --accent-glow: rgba(0,255,135,0.12);
      --border: rgba(255,255,255,0.07);
      --border2: rgba(255,255,255,0.14);
      --nav-bg: rgba(8,8,8,0.8);
      --shadow: rgba(0,0,0,0.5);
    }
    [data-theme="light"] {
      --bg: #f8fafc;
      --bg2: #f1f5f9;
      --card: rgba(0,0,0,0.03);
      --card-solid: #fff;
      --text: #0f172a;
      --muted: #475569;
      --muted2: #94a3b8;
      --accent: #059669;
      --accent2: #ea580c;
      --accent3: #7c3aed;
      --accent-glow: rgba(5,150,105,0.1);
      --border: rgba(0,0,0,0.07);
      --border2: rgba(0,0,0,0.14);
      --nav-bg: rgba(248,250,252,0.8);
      --shadow: rgba(0,0,0,0.08);
    }
    :root { --radius: 14px; --nav-h: 60px; }

    /* ==============================================
       RESET + BASE
       ============================================== */
    *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
    html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}
    body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden;cursor:none;transition:background .4s,color .4s}
    a{color:var(--accent);text-decoration:none;transition:color .3s}
    a:hover{opacity:.85}
    h1,h2,h3,.section-title{font-family:'Space Grotesk',sans-serif}
    .mono{font-family:'Space Mono',monospace}
    .container{max-width:1100px;margin:0 auto;padding:0 24px}
    section{padding:100px 0}
    .section-title{font-size:2rem;font-weight:700;margin-bottom:8px}
    .section-sub{color:var(--muted);font-size:1rem;margin-bottom:48px;max-width:560px}
    .dot{color:var(--accent)}

    /* ==============================================
       LOADER
       ============================================== */
    .loader{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:99999;transition:opacity .5s,visibility .5s}
    .loader.hidden{opacity:0;visibility:hidden}
    .loader-txt{font-family:'Space Grotesk',sans-serif;font-size:4.5rem;font-weight:700;color:var(--accent);animation:lPulse .8s ease-in-out infinite alternate}
    @keyframes lPulse{from{opacity:.3;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}

    /* ==============================================
       CURSEUR CUSTOM + TRAÎNE DE 8 POINTS
       ============================================== */
    .cur-dot{position:fixed;width:10px;height:10px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:9998;box-shadow:0 0 14px var(--accent),0 0 28px rgba(0,255,135,.25);transition:transform .08s}
    .cur-trail{position:fixed;border-radius:50%;pointer-events:none;z-index:9997;background:var(--accent)}

    /* ==============================================
       BARRE DE PROGRESSION SCROLL
       ============================================== */
    .scroll-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent3));width:0;z-index:10001}

    /* ==============================================
       SCROLL REVEAL
       ============================================== */
    .rv{opacity:0;transition:opacity .8s,transform .8s}.rv-up{transform:translateY(40px)}.rv-l{transform:translateX(-40px)}.rv-r{transform:translateX(40px)}.rv.vis{opacity:1;transform:translate(0)}

    /* ==============================================
       NAVBAR
       ============================================== */
    nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:var(--nav-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:1000;display:flex;align-items:center;transition:background .4s}
    .nav-in{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1100px;margin:0 auto;padding:0 24px}
    .nav-logo{font-family:'Space Grotesk',sans-serif;font-size:1.25rem;font-weight:700;color:var(--text);cursor:none}
    .nav-logo span{color:var(--accent)}
    .nav-links{display:flex;gap:24px;list-style:none;align-items:center}
    .nav-links a{color:var(--muted);font-size:.82rem;font-weight:500;cursor:none;position:relative}
    .nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:2px;background:var(--accent);transition:width .3s}
    .nav-links a:hover{color:var(--text);opacity:1}
    .nav-links a:hover::after{width:100%}
    .theme-btn{background:var(--card);border:1px solid var(--border);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:none;color:var(--text);font-size:1rem;transition:all .3s}
    .theme-btn:hover{border-color:var(--accent);transform:rotate(180deg)}
    .ham{display:none;flex-direction:column;gap:5px;cursor:none;background:none;border:none;padding:4px}
    .ham span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}
    .ham.on span:nth-child(1){transform:translateY(7px) rotate(45deg)}
    .ham.on span:nth-child(2){opacity:0}
    .ham.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

    /* ==============================================
       BOUTONS
       ============================================== */
    .btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:50px;font-size:.9rem;font-weight:600;cursor:none;transition:all .3s;border:none;font-family:inherit;position:relative;overflow:hidden}
    .btn-p{background:var(--accent);color:#080808;box-shadow:0 4px 20px rgba(0,255,135,.2)}
    .btn-p::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.15);border-radius:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s}
    .btn-p:hover::before{width:300px;height:300px}
    .btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,255,135,.3)}
    .btn-o{background:transparent;color:var(--text);border:1px solid var(--border2)}
    .btn-o:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

    /* ==============================================
       HERO
       ============================================== */
    .hero{min-height:100vh;display:flex;align-items:center;padding-top:var(--nav-h);position:relative;overflow:hidden}
    #pCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
    .aurora{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;transition:opacity .6s}
    .au1{width:600px;height:600px;background:#3b82f6;opacity:.08;top:-15%;left:-10%;animation:auF 12s ease-in-out infinite}
    .au2{width:500px;height:500px;background:#a855f7;opacity:.06;top:10%;right:-8%;animation:auF 16s ease-in-out infinite;animation-delay:-4s}
    .au3{width:400px;height:400px;background:#06b6d4;opacity:.05;bottom:-10%;left:25%;animation:auF 20s ease-in-out infinite;animation-delay:-8s}
    @keyframes auF{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(60px,-40px) scale(1.05)}50%{transform:translate(-30px,50px) scale(.95)}75%{transform:translate(-50px,-20px) scale(1.02)}}
    [data-theme="light"] .aurora{opacity:0!important}
    .hero-content{position:relative;z-index:1;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
    .hero::after {
      content: '';
      position: absolute;
      top: 0; right: 0;
      width: 55%; height: 100%;
      background-image:
        linear-gradient(rgba(0,255,135,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,255,135,0.025) 1px, transparent 1px);
      background-size: 40px 40px;
      pointer-events: none;
      z-index: 0;
    }
    .hero-left{max-width:640px}
    .hero h1{font-size:clamp(2.1rem,4.8vw,3.7rem);font-weight:700;line-height:1.08;letter-spacing:-1.6px;margin-bottom:12px;background:linear-gradient(90deg,#00ff87,#a855f7,#00ff87);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:hGrad 4s linear infinite}
    @keyframes hGrad{0%{background-position:0% 50%}100%{background-position:200% 50%}}
    .hero-tag{font-family:'Space Mono',monospace;font-size:.78rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted2);margin-bottom:14px}
    .hero-intro{font-size:1rem;line-height:1.7;color:var(--muted);margin-bottom:26px;max-width:560px}
    .hero-quote{font-size:.85rem;color:var(--muted2);font-style:italic;border-left:2px solid var(--accent);padding-left:14px;margin-bottom:20px;max-width:460px}
    .hero-typing{font-size:clamp(.98rem,2vw,1.15rem);color:var(--accent);font-weight:500;min-height:1.8em;margin-bottom:14px;font-family:'Space Grotesk',sans-serif}
    .cblink{display:inline-block;width:2px;height:1.1em;background:var(--accent);margin-left:2px;vertical-align:text-bottom;animation:bl 1s step-end infinite}
    @keyframes bl{0%,100%{opacity:1}50%{opacity:0}}
    .hero-loc{color:var(--muted);font-size:.92rem;margin-bottom:20px}
    .tickers{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
    .tick{font-family:'Space Mono',monospace;font-size:.75rem;padding:6px 14px;border-radius:6px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;gap:6px}
    .tick .arrow{font-weight:700}
    .tick .arrow.green{color:#00ff87;animation:tickBl 1.5s ease-in-out infinite}
    .tick .arrow.orange{color:#f97316;animation:tickBl 2s ease-in-out infinite}
    .tick .arrow.purple{color:#a855f7;animation:tickBl 1.8s ease-in-out infinite}
    @keyframes tickBl{0%,100%{opacity:1}50%{opacity:.3}}
    .hero-btns{display:flex;gap:12px;flex-wrap:wrap}
    .photo-ring{width:180px;height:180px;border-radius:50%;flex-shrink:0;animation:none;border:3px solid var(--accent);background:transparent}
    .photo-inner {
      width: 100%;
      height: 100%;
      border-radius: 50%;
      background: #080808;
      overflow: hidden;
      display: block;
    }
    .photo-ring,
    .photo-inner,
    .photo-inner img {
      animation: none !important;
    }
    .photo-inner img {
      transform: none !important;
    }
    .hero-profile {
      position: relative;
      z-index: 2;
      isolation: isolate;
      flex-shrink: 0;
    }
    .hero-profile,
    .hero-profile .photo-ring,
    .hero-profile .photo-inner,
    .hero-profile img {
      animation: none !important;
    }
    .hero-profile .photo-ring,
    .hero-profile .photo-inner {
      transform: rotate(0deg) !important;
    }
    .hero-profile img {
      transform: rotate(0deg) scale(1) !important;
    }

    /* ==============================================
       ABOUT
       ============================================== */
    .memo{background:var(--card);border:1px solid var(--accent);border-radius:var(--radius);padding:28px;font-family:'Space Mono',monospace;font-size:.85rem;line-height:1.9;color:var(--muted);margin-bottom:36px;position:relative}
    .memo-head{color:var(--accent);font-weight:700;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}
    .memo p{margin-bottom:8px}
    .memo strong{color:var(--text)}

    .about-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;max-width:980px;margin:0 auto 28px}
    .about-wrap p{color:var(--muted);line-height:1.75;margin:0 0 14px}
    .about-wrap p:last-of-type{margin-bottom:18px}
    .about-hi{display:flex;flex-wrap:wrap;gap:8px}
    .about-hi .badge{background:rgba(0,255,136,0.08);border-color:rgba(0,255,136,0.18)}
    .stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:36px}
    .stat-c{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-align:center;transition:border-color .3s,transform .3s;display:flex;flex-direction:column;align-items:center;gap:6px}
    .stat-c:hover{border-color:var(--accent);transform:translateY(-3px)}
    .stat-num{font-family:'Space Mono',monospace;font-size:2rem;font-weight:700;color:var(--accent);line-height:1.2}
    .stat-lab{font-size:.78rem;color:var(--muted);margin-top:4px}
    .stat-icon{color:var(--accent);opacity:.6;margin-bottom:2px}
    .about-lang-block{display:flex;justify-content:center;margin-bottom:36px;width:100%}
    .lang-bars{width:100%;max-width:420px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
    .lang-item{margin-bottom:16px;width:100%;max-width:380px}
    .lang-item:last-child{margin-bottom:0}
    .lang-head{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:5px;font-size:.88rem;font-weight:500}
    .lang-pct{font-family:'Space Mono',monospace;color:var(--accent);font-size:.82rem}
    .lang-bg{height:6px;background:var(--border);border-radius:50px;overflow:hidden}
    .lang-fill{height:100%;border-radius:50px;background:var(--accent);width:0%;transition:width 1.2s cubic-bezier(.25,.8,.25,1)}

    /* ==============================================
       SKILLS
       ============================================== */
    .radar-wrap{display:flex;gap:40px;align-items:center;flex-wrap:wrap;margin-bottom:40px;justify-content:center}
    .radar-svg{width:320px;height:320px;flex-shrink:0}
    .radar-poly{fill:rgba(0,255,135,.15);stroke:var(--accent);stroke-width:2;stroke-dasharray:1000;stroke-dashoffset:1000;transition:stroke-dashoffset 1.5s ease}
    .radar-poly.drawn{stroke-dashoffset:0}
    .radar-grid{fill:none;stroke:var(--border2);stroke-width:1}
    .radar-axis{stroke:var(--border);stroke-width:1}
    .radar-label{font-family:'Space Mono',monospace;font-size:11px;fill:var(--muted);text-anchor:middle}
    .badges-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
    .badge-group{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}
    .badge-group h4{font-size:.95rem;margin-bottom:12px}
    .badges{display:flex;flex-wrap:wrap;gap:6px}
    .badge{padding:5px 12px;border-radius:50px;font-size:.75rem;font-weight:500;background:var(--accent-glow);color:var(--accent);border:1px solid rgba(0,255,135,.15)}
    .badge.o{background:rgba(249,115,22,.08);color:var(--accent2);border-color:rgba(249,115,22,.15)}
    .badge.v{background:rgba(168,85,247,.08);color:var(--accent3);border-color:rgba(168,85,247,.15)}

    /* ==============================================
       EXPERIENCE — Timeline
       ============================================== */
    .tl{position:relative;padding:20px 0}
    .tl-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--border);transform:translateX(-50%)}
    .tl-fill{position:absolute;left:50%;top:0;width:2px;height:0%;background:var(--accent);transform:translateX(-50%);transition:height .3s linear;box-shadow:0 0 8px var(--accent-glow)}
    .tl-item{position:relative;width:50%;padding:0 48px 48px 0}
    .tl-item:nth-child(odd){left:0;text-align:right;padding:0 48px 48px 0}
    .tl-item:nth-child(even){left:50%;text-align:left;padding:0 0 48px 48px}
    .tl-dot{position:absolute;top:6px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:2px solid var(--border);z-index:2;transition:border-color .5s,background .5s,box-shadow .5s}
    .tl-item:nth-child(odd) .tl-dot{right:-8px}
    .tl-item:nth-child(even) .tl-dot{left:-8px}
    .tl-item.vis .tl-dot{border-color:var(--accent);background:var(--accent);box-shadow:0 0 12px var(--accent-glow)}
    .exp-c{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:26px;backdrop-filter:blur(10px);opacity:0;transform:translateY(20px);transition:all .6s}
    .tl-item:nth-child(odd) .exp-c{transform:translateX(-20px)}
    .tl-item:nth-child(even) .exp-c{transform:translateX(20px)}
    .tl-item.vis .exp-c{opacity:1;transform:translate(0)}
    .exp-c:hover{border-color:var(--accent);box-shadow:0 8px 32px var(--shadow)}
    .exp-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
    .exp-date{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--muted);letter-spacing:.5px}
    .exp-tag{font-family:'Space Mono',monospace;font-size:.65rem;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:50px;font-weight:700}
    .exp-tag.current{background:rgba(0,255,135,.12);color:#00ff87;border:1px solid rgba(0,255,135,.2)}
    .exp-co{font-size:1.1rem;font-weight:700;margin-bottom:2px}
    .exp-role{color:var(--accent);font-weight:600;font-size:.92rem;margin-bottom:4px}
    .tl-item:nth-child(odd) .exp-role:has(img){display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:4px}
    .exp-loc{color:var(--muted);font-size:.82rem;margin-bottom:12px}
    .exp-ul{list-style:none;display:flex;flex-direction:column;gap:6px}
    .exp-ul li{color:var(--muted);font-size:.88rem;padding-left:18px;position:relative}
    .exp-ul li::before{content:'▹';position:absolute;left:0;color:var(--accent)}

    /* ==============================================
       PASSIONS & INTERESTS
       ============================================== */
    .read-grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:stretch;max-width:1040px;margin:0 auto}
    @media (min-width:700px){
      .read-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px 20px}
    }
    @media (min-width:1200px){
      .read-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px 28px;max-width:1100px}
    }
    .read-card{background:rgba(0,255,135,.03);border:1px solid rgba(0,255,135,.12);border-radius:16px;padding:24px 22px 22px;backdrop-filter:blur(12px);position:relative;transition:box-shadow .25s,border-color .25s;display:flex;flex-direction:column;min-height:100%;height:100%;box-shadow:0 8px 32px var(--shadow)}
    .read-card--accent-p{background:rgba(168,85,247,.04);border-color:rgba(168,85,247,.18)}
    .read-card--accent-p:hover{box-shadow:0 12px 40px rgba(168,85,247,.15)}
    .read-card:hover{box-shadow:0 16px 48px var(--accent-glow);border-color:rgba(0,255,135,.25)}
    .read-badge{position:absolute;top:12px;right:12px;font-family:'Space Mono',monospace;font-size:.6rem;color:#00ff87;letter-spacing:1px;text-transform:uppercase;animation:tickBl 2s ease-in-out infinite}
    .read-card--accent-p .read-badge{color:#a855f7}
    .read-icon{font-size:2.4rem;margin-bottom:10px;display:inline-block;animation:iconBounce 3s ease-in-out infinite}
    .read-icon--logo{font-size:0;width:52px;height:52px;padding:4px;background:var(--card);border:1px solid var(--border);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box}
    .read-icon--logo img{width:100%;height:100%;object-fit:contain;border-radius:50%;display:block}
    @keyframes iconBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
    .read-card h4{font-family:'Space Mono',monospace;font-size:.88rem;margin-bottom:8px}
    .read-meta-lab{font-size:.62rem;color:var(--muted2);text-transform:uppercase;letter-spacing:1.2px;font-family:'Space Mono',monospace;margin-bottom:8px}
    .read-details{font-size:.76rem;color:var(--muted);line-height:1.55;margin-top:8px;margin-bottom:0}
    .read-tagline{margin-top:auto;padding-top:14px;margin-bottom:0;border-top:1px solid var(--border);font-family:'Space Grotesk',sans-serif;font-size:.82rem;font-style:italic;font-weight:500;line-height:1.45;color:var(--accent3)}
    .read-card--accent-p .read-tagline{color:var(--accent3)}
    .read-card ul{list-style:none;font-size:.78rem;color:var(--muted);display:flex;flex-direction:column;gap:4px}
    .read-card ul li::before{content:'→ ';color:var(--accent);display:inline-block;transition:transform .2s ease}
    .read-card--accent-p ul li::before{color:#a855f7}

    /* ==============================================
       SELECTED WORK
       ============================================== */
    .pf-layout{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center}
    .donut-w{position:relative;width:220px;height:220px}
    .donut{width:220px;height:220px;border-radius:50%;background:conic-gradient(#1d4ed8 0% 65%,#f97316 65% 90%,#8b5cf6 90% 95%,#00ff87 95% 100%);display:flex;align-items:center;justify-content:center}
    .donut-hole{width:130px;height:130px;border-radius:50%;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:background .4s}
    .donut-big{font-family:'Space Mono',monospace;font-size:1.5rem;font-weight:700}
    .donut-sm{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
    .pf-legend{display:flex;flex-direction:column;gap:12px}
    .leg-item{display:flex;align-items:center;gap:10px}
    .leg-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}
    .leg-info{flex:1}
    .leg-name{font-weight:600;font-size:.88rem}
    .leg-pct{font-family:'Space Mono',monospace;font-size:.78rem;color:var(--muted)}
    .leg-bar-bg{height:4px;background:var(--border);border-radius:50px;margin-top:3px}
    .leg-bar{height:100%;border-radius:50px;width:0;transition:width 1s cubic-bezier(.25,.8,.25,1)}
    .pf-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
    .pf-b{padding:5px 12px;border-radius:50px;font-size:.72rem;font-weight:500;background:var(--card);border:1px solid var(--border);color:var(--muted)}
    .bullish{color:#00ff87;border-color:rgba(0,255,135,.3);animation:tickBl 2s ease-in-out infinite}
    .pf-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}

    /* Selected Work */
    .sw-heading{font-family:'Space Grotesk',sans-serif;font-size:1.25rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:2px;margin:56px 0 8px}
    .sw-sub{color:var(--muted);font-size:.9rem;margin-bottom:28px;max-width:600px}
    .sw-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
    .sw-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;gap:10px}
    .sw-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 8px 32px var(--shadow)}
    .sw-icon{font-size:1.8rem}
    .sw-card h4{font-size:1rem;font-weight:700;color:var(--text);margin:0}
    .sw-card p{color:var(--muted);font-size:.87rem;line-height:1.65;margin:0;flex:1}
    .sw-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
    .pf-sc{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;text-align:center;transition:all .3s}
    .pf-sc:hover{border-color:var(--accent);transform:translateY(-2px)}
    .pf-sv{font-family:'Space Mono',monospace;font-size:1.2rem;font-weight:700;color:var(--accent)}
    .pf-sl{font-size:.75rem;color:var(--muted);margin-top:2px}

    /* ==============================================
       CONTACT
       ============================================== */
    .ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
    .ct-text p{color:var(--muted);margin-bottom:20px;font-size:.95rem}
    .ct-avail{display:inline-flex;align-items:center;gap:8px;font-family:'Space Mono',monospace;font-size:.8rem;color:#00ff87;margin-bottom:16px}
    .ct-avail .pulse{width:8px;height:8px;background:#00ff87;border-radius:50%;animation:pDot 2s ease-in-out infinite}
    @keyframes pDot{0%,100%{box-shadow:0 0 0 0 rgba(0,255,135,.4)}50%{box-shadow:0 0 0 6px rgba(0,255,135,0)}}
    .ct-simple{max-width:600px;margin:0 auto;text-align:center}
    .ct-lead{color:var(--muted);font-size:1rem;line-height:1.7;margin:16px 0 32px}
    .ct-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
    .ct-links{display:flex;flex-direction:column;gap:10px}
    .ct-links-row{flex-direction:row;justify-content:center;gap:12px}
    .ct-link{display:inline-flex;align-items:center;gap:12px;color:var(--muted);font-size:.92rem;padding:13px 18px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);transition:all .3s;cursor:none}
    .ct-link:hover{color:var(--accent);border-color:var(--accent);transform:translateX(6px);box-shadow:0 4px 16px var(--shadow)}
    .ct-link svg{width:18px;height:18px}
    .ct-form{display:flex;flex-direction:column;gap:12px}
    .fg{display:flex;flex-direction:column;gap:4px}
    .fg label{font-size:.8rem;font-weight:500;color:var(--muted)}
    .fg input,.fg textarea{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-size:.9rem;color:var(--text);font-family:inherit;transition:border-color .3s,box-shadow .3s;outline:none;cursor:none}
    .fg input:focus,.fg textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
    .fg textarea{resize:vertical;min-height:100px}

    /* ==============================================
       FOOTER
       ============================================== */
    footer{border-top:1px solid var(--border);padding:40px 0 28px;text-align:center}
    footer p{color:var(--muted);font-size:.78rem}
    .ft-name{font-size:1rem;font-weight:700;color:var(--text)!important;letter-spacing:.02em;margin-bottom:4px}
    .ft-role{font-size:.8rem;color:var(--muted2)!important;margin-bottom:20px}
    .ft-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 28px;margin-bottom:20px}
    .ft-meta a,.ft-meta span{color:var(--muted);font-size:.8rem;display:inline-flex;align-items:center;gap:5px;text-decoration:none;transition:color .25s}
    .ft-meta a:hover{color:var(--accent)}
    .ft-meta svg{width:14px;height:14px;flex-shrink:0}
    .ft-avail{color:var(--accent)!important;font-size:.78rem;display:inline-flex;align-items:center;gap:6px}
    .ft-avail::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;animation:pulseGlow 2s ease-in-out infinite}
    .ft-copy{font-size:.72rem;color:var(--muted)!important;opacity:.55;margin-top:4px}
    .ft-links{display:none}

    /* ==============================================
       BACK TO TOP
       ============================================== */
    .btt{position:fixed;bottom:28px;right:28px;width:42px;height:42px;border-radius:50%;background:var(--accent);color:#080808;border:none;cursor:none;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(12px);transition:all .3s;box-shadow:0 4px 16px rgba(0,255,135,.2);z-index:999}
    .btt.vis{opacity:1;visibility:visible;transform:translateY(0)}
    .btt:hover{transform:translateY(-2px)}

    /* ==============================================
       CONFETTI + EASTER MSG
       ============================================== */
    .confetti-c{position:fixed;inset:0;pointer-events:none;z-index:99998;overflow:hidden}
    .conf{position:absolute;width:10px;height:10px;top:-10px;opacity:0;animation:cFall 3s ease-in forwards}
    @keyframes cFall{0%{opacity:1;transform:translateY(0) rotate(0)}100%{opacity:0;transform:translateY(100vh) rotate(720deg)}}
    .e-msg{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);background:var(--card-solid);border:2px solid var(--accent);border-radius:var(--radius);padding:28px 42px;font-family:'Space Grotesk',sans-serif;font-size:1.2rem;font-weight:700;text-align:center;z-index:99999;box-shadow:0 20px 60px var(--shadow);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
    .e-msg.show{transform:translate(-50%,-50%) scale(1)}

    /* ==============================================
       TILT 3D + GLARE
       ============================================== */
    .tilt-c{transform-style:preserve-3d;will-change:transform}
    .tilt-g{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:3;opacity:0;transition:opacity .3s;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 60%)}
    .tilt-c:hover .tilt-g{opacity:1}

    /* ==============================================
       SERVICES
       ============================================== */
    .srv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,320px));gap:20px;justify-content:center}
    .srv-card{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius);padding:30px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:relative;overflow:hidden;transition:all .3s}
    .srv-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;transform:scaleX(0);transform-origin:left;transition:transform .4s}
    .srv-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:0 12px 40px var(--shadow)}
    .srv-card:hover::after{transform:scaleX(1)}
    [data-theme="light"] .srv-card{background:rgba(0,0,0,.04)}
    .srv-card.green::after{background:linear-gradient(90deg,#00ff87,#059669)}
    .srv-card.green:hover{border-color:var(--accent);box-shadow:0 12px 40px rgba(0,255,135,.15)}
    .srv-card.orange::after{background:linear-gradient(90deg,#f97316,#fb923c)}
    .srv-card.violet::after{background:linear-gradient(90deg,#a855f7,#c084fc)}
    .srv-price{display:inline-block;font-family:'Space Mono',monospace;font-size:.72rem;font-weight:700;letter-spacing:.5px;padding:4px 12px;border-radius:50px;margin-bottom:16px}
    .srv-price.green{background:rgba(0,255,135,.1);color:#00ff87;border:1px solid rgba(0,255,135,.2)}
    .srv-price.orange{background:rgba(249,115,22,.1);color:#f97316;border:1px solid rgba(249,115,22,.2)}
    .srv-price.violet{background:rgba(168,85,247,.1);color:#a855f7;border:1px solid rgba(168,85,247,.2)}
    .srv-price.cyan{background:rgba(0,188,212,.12);color:#00bcd4;border:1px solid rgba(0,188,212,.25)}
    .srv-icon{font-size:2rem;margin-bottom:12px;display:inline-block}
    .srv-card h3{font-size:1.1rem;font-weight:700;margin-bottom:6px}
    .srv-card p{color:var(--muted);font-size:.88rem;margin-bottom:18px;line-height:1.6}
    .srv-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:50px;font-size:.82rem;font-weight:600;cursor:none;transition:all .3s;border:none;font-family:inherit;text-decoration:none}
    .srv-btn.green{background:var(--accent);color:#080808;box-shadow:0 4px 16px rgba(0,255,135,.15)}
    .srv-btn.green:hover{box-shadow:0 6px 24px rgba(0,255,135,.25);transform:translateY(-2px);opacity:1}
    .srv-btn.orange{background:#f97316;color:#fff;box-shadow:0 4px 16px rgba(249,115,22,.15)}
    .srv-btn.orange:hover{box-shadow:0 6px 24px rgba(249,115,22,.25);transform:translateY(-2px);opacity:1}
    .srv-btn.violet{background:#a855f7;color:#fff;box-shadow:0 4px 16px rgba(168,85,247,.15)}
    .srv-btn.violet:hover{box-shadow:0 6px 24px rgba(168,85,247,.25);transform:translateY(-2px);opacity:1}
    .srv-btn.cyan{background:#00bcd4;color:#052026;box-shadow:0 4px 16px rgba(0,188,212,.18)}
    .srv-btn.cyan:hover{box-shadow:0 6px 24px rgba(0,188,212,.28);transform:translateY(-2px);opacity:1}

    /* ==============================================
       NEWSLETTER BAND
       ============================================== */
    .nl-band{background:linear-gradient(180deg,rgba(0,255,135,.05) 0%,transparent 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center}
    .nl-band h2{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;margin-bottom:10px}
    .nl-band .nl-sub{color:var(--muted);font-size:1rem;margin-bottom:28px;max-width:520px;margin-left:auto;margin-right:auto}
    .nl-form{display:flex;gap:10px;max-width:460px;margin:0 auto 16px}
    .nl-form input{flex:1;background:var(--card);border:1px solid var(--border);border-radius:50px;padding:12px 20px;font-size:.9rem;color:var(--text);font-family:inherit;outline:none;transition:border-color .3s,box-shadow .3s;cursor:none}
    .nl-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
    .nl-form button{padding:12px 28px;border-radius:50px;background:var(--accent);color:#080808;font-weight:700;font-size:.88rem;border:none;cursor:none;font-family:inherit;transition:all .3s;white-space:nowrap}
    .nl-form button:hover{box-shadow:0 6px 24px rgba(0,255,135,.25);transform:translateY(-2px)}
    .nl-badge{font-family:'Space Mono',monospace;font-size:.7rem;color:var(--muted);letter-spacing:.5px}

    /* ==============================================
       LANGUAGE SWITCHER
       ============================================== */
    html[data-lang="en"] [data-lang="fr"]{display:none!important}
    html[data-lang="fr"] [data-lang="en"]{display:none!important}
    .lang-sw{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-left:8px}
    .lang-sw button{background:transparent;border:none;color:var(--muted);font-family:'Space Mono',monospace;font-size:.72rem;font-weight:700;padding:5px 10px;cursor:none;transition:all .3s;letter-spacing:.5px}
    .lang-sw button.active{background:var(--accent);color:#080808}
    .lang-sw button:hover:not(.active){color:var(--text);background:var(--card)}

    /* ==============================================
       RESPONSIVE
       ============================================== */
    @media(max-width:768px){
      .nav-links{position:fixed;top:var(--nav-h);left:0;right:0;background:var(--nav-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;padding:20px;gap:16px;border-bottom:1px solid var(--border);transform:translateY(-120%);opacity:0;pointer-events:none;transition:transform .3s,opacity .3s}
      .nav-links.open{transform:translateY(0);opacity:1;pointer-events:all}
      .ham{display:flex}
      .hero::after{display:none}
      .hero-content{display:flex;flex-direction:column-reverse;align-items:center;gap:24px}
      .hero-left{text-align:center;width:100%}
      .photo-ring{width:140px;height:140px;margin:0 auto}
      .tickers{justify-content:center}
      .tick{flex:0 1 calc(50% - 8px);justify-content:center}
      .hero-btns{flex-direction:column;align-items:stretch;gap:10px}
      .hero-btns .btn{justify-content:center;width:100%}
      .hero-quote{margin-left:auto;margin-right:auto}
      .badges-grid{grid-template-columns:1fr}
      .passion-logos{gap:8px}
      .passion-logos img{width:20px;height:20px}
      .ct-grid,.pf-layout{grid-template-columns:1fr}
      .pf-layout{justify-items:center}
      .pf-legend{width:100%;max-width:300px}
      .stat-cards,.pf-stats{grid-template-columns:1fr}
      .srv-grid{grid-template-columns:1fr}
      .tl-line,.tl-fill{left:6px;transform:none}
      .tl-item,.tl-item:nth-child(odd),.tl-item:nth-child(even){left:0;width:100%;text-align:left;padding:0 0 32px 36px}
      .tl-dot,.tl-item:nth-child(odd) .tl-dot,.tl-item:nth-child(even) .tl-dot{left:0;right:auto}
      .tl-item:nth-child(odd) .exp-c,.tl-item:nth-child(even) .exp-c{transform:translateY(20px)}
      .tl-item.vis .exp-c{transform:translate(0)}
      .tl-item:nth-child(odd) .exp-role:has(img){justify-content:flex-start}
      .radar-wrap{flex-direction:column}
      .radar-svg{width:260px;height:260px}
      section{padding:72px 0;overflow-x:hidden}
      .cur-dot,.cur-trail{display:none}
      body{cursor:auto}
      a,.btn,.ct-link,.theme-btn,.ham,.btt,.lang-sw button{cursor:pointer}
      .lang-sw{margin-left:0;align-self:center}
      .nl-form{flex-direction:column}
      .nl-form button{width:100%}
      .btn,.ct-link,.srv-btn,.lang-sw button,.theme-btn{min-height:44px}
      .memo{font-size:.78rem;overflow-x:auto}
    }
    @media(max-width:480px){
      .stat-cards{grid-template-columns:1fr}
      .hero-quote{font-size:.8rem}
      .tickers{flex-direction:column;align-items:center}
      .tick{width:100%;max-width:240px;justify-content:center}
      .read-grid{grid-template-columns:1fr!important;max-width:none;gap:18px}
      .badges-grid{grid-template-columns:1fr}
    }

    /* ── PULSE badge OPEN TO ── */
    .tick:last-child{animation:pulseGreen 2s ease-in-out infinite}
    @keyframes pulseGreen{0%,100%{box-shadow:0 0 0 0 rgba(0,255,135,.4)}50%{box-shadow:0 0 0 8px rgba(0,255,135,0)}}

    /* ── HOVER cards compétences ── */
    .badge-group:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 0 20px rgba(0,255,135,.15)}

    /* ── HOVER liens passions (→ tool) ── */
    .read-card ul li:hover::before{transform:translateX(4px)}

    /* ── BADGE logo alignement ── */
    .badge-logo{display:inline-flex;align-items:center}

    /* ── PASSION logos row responsive ── */
    .passion-logos img{opacity:.75;transition:opacity .2s,transform .2s;filter:grayscale(20%)}
    .passion-logos img:hover{opacity:1;transform:scale(1.15);filter:grayscale(0%)}

    /* exp-status (perso timeline) */
    .exp-status{font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
    .exp-status.active{color:#00ff87}
    .exp-status.closed{color:var(--muted)}

    /* ── Version switcher in navbar ── */
    .nav-version-sw { display: flex; align-items: center; gap: 2px; }
    .nav-ver {
      font-family: 'Space Mono', monospace;
      font-size: .65rem; letter-spacing: 1.5px; text-transform: uppercase;
      color: var(--muted2); text-decoration: none;
      padding: 4px 8px; border-radius: 6px;
      border: 1px solid transparent;
      transition: color .2s, border-color .2s;
    }
    .nav-ver:hover { color: var(--text); }
    .nav-ver.active {
      color: var(--accent); border-color: rgba(0,255,135,.2);
      background: rgba(0,255,135,.04);
    }
    .nav-ver-sep { color: var(--muted2); font-size: .65rem; opacity: .5; pointer-events: none; }
    @media (max-width: 768px) { .nav-version-sw { display: none; } }

