/* ---------- TOKENS ---------- */
  :root{
    --bg:#F5F0E8;
    --ink:#2C1810;
    --gold:#8B5A2B;
    --beige:#D4B896;
    --muted:#7A6B5A;
    --rule:rgba(140,123,107,0.28);
    --maxw:1240px;
    --gutter:clamp(20px, 5vw, 72px);
  }

  *,*::before,*::after{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--bg);
    color:var(--ink);
    font-family:'DM Sans', system-ui, sans-serif;
    font-weight:400;
    font-size:17px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none;}
  ::selection{background:var(--gold);color:var(--ink);}

  /* ---------- A11Y : SKIP LINK ---------- */
  .skip-link{
    position:absolute;left:-9999px;top:-9999px;
    z-index:999;padding:14px 22px;
    background:var(--ink);color:var(--bg);
    font-family:'Poppins', sans-serif;font-weight:500;font-size:13px;
    text-decoration:none;border-radius:4px;
  }
  .skip-link:focus{
    left:16px;top:16px;
    outline:2px solid var(--gold);outline-offset:3px;
  }

  /* ---------- A11Y : FOCUS-VISIBLE GLOBAL ---------- */
  a:focus-visible,
  button:focus-visible,
  [tabindex]:focus-visible,
  input:focus-visible,
  textarea:focus-visible{
    outline:2px solid var(--gold);
    outline-offset:3px;
    border-radius:2px;
  }
  /* Override for trigger that had its own focus-visible */
  .lang-trigger:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}

  /* ---------- A11Y : VISITED LINKS (subtle nuance) ---------- */
  a:visited:not(.cta):not(.nav-mark):not(.nav-icon):not(.back-to-top):not(.skip-link){
    /* keep ink color; modern UX rarely uses purple visited; we use a soft shift */
    color:inherit;
  }

  /* ---------- LOADER ---------- */
  .loader{
    position:fixed;inset:0;background:var(--bg);z-index:1000;
    display:flex;align-items:center;justify-content:center;
    animation:loaderAutoHide 2.4s forwards;
    transition:opacity .4s ease, visibility .4s ease;
  }
  /* JS adds .hide as soon as the page loads; animation:none lets it override the
     running keyframes (which otherwise win the cascade). The 2.4s animation stays
     only as a fallback if JS never runs. */
  .loader.hide{animation:none;opacity:0;visibility:hidden;pointer-events:none;}
  @keyframes loaderAutoHide{
    0%, 70%{opacity:1;visibility:visible;}
    100%{opacity:0;visibility:hidden;pointer-events:none;}
  }
  .loader-mark{
    font-family:'Poppins', sans-serif;
    font-weight:700;font-size:48px;color:var(--ink);
    letter-spacing:-0.02em;
    position:relative;
  }
  .loader-mark::after{
    content:"";position:absolute;left:0;right:0;bottom:-12px;
    height:1px;background:var(--gold);
    transform-origin:left;transform:scaleX(0);
    animation:loadbar .8s ease forwards;
  }
  @keyframes loadbar{to{transform:scaleX(1);}}

  /* ---------- CURSOR ACCENT ---------- */
  .cursor-accent{
    position:fixed;top:0;left:0;
    width:14px;height:14px;border-radius:50%;
    background:var(--gold);
    pointer-events:none;z-index:9999;
    transform:translate3d(-50%,-50%,0);
    transition:width .22s ease, height .22s ease, opacity .22s ease, background .22s ease;
    opacity:0;
    mix-blend-mode:multiply;
  }
  .cursor-accent.is-visible{opacity:0.55;}
  .cursor-accent.is-hover{
    width:38px;height:38px;opacity:0.32;
  }
  @media (hover:none), (pointer:coarse){
    .cursor-accent{display:none;}
  }

  /* ---------- PARTICLES ---------- */
  .particles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
  .particle{
    position:absolute;width:2px;height:2px;border-radius:50%;
    background:var(--ink);
    animation:drift linear infinite;
  }
  @keyframes drift{
    0%{transform:translate(0,0);}
    100%{transform:translate(var(--dx, 40px), var(--dy, -120px));}
  }

  /* ---------- NAV ---------- */
  .nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    padding:22px var(--gutter);
    display:flex;align-items:center;justify-content:space-between;
    transition:background .3s ease, backdrop-filter .3s ease;
  }
  .nav.scrolled{
    background:rgba(245,240,232,0.92);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
  }
  .nav-mark{
    font-family:'Poppins', sans-serif;
    font-weight:700;font-size:22px;letter-spacing:-0.02em;
  }
  .nav-mark span{color:var(--gold);}
  .nav-links{
    display:flex;gap:36px;align-items:center;
    font-family:'Poppins', sans-serif;font-size:13px;font-weight:500;
    letter-spacing:0.06em;text-transform:uppercase;
  }
  .nav-links a{position:relative;color:var(--ink);opacity:.78;transition:opacity .2s;}
  .nav-links a:hover{opacity:1;}
  .nav-links a::after{
    content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;
    background:var(--gold);transform-origin:left;transform:scaleX(0);
    transition:transform .25s ease;
  }
  .nav-links a:hover::after{transform:scaleX(1);}

  /* ---------- NAV "PLUS" DROPDOWN ---------- */
  .nav-more{position:relative;display:inline-flex;align-items:center;}
  .nav-more-trigger{
    display:inline-flex;align-items:center;gap:6px;
    font-family:'Poppins', sans-serif;font-size:13px;font-weight:500;
    letter-spacing:0.06em;text-transform:uppercase;
    color:var(--ink);opacity:.78;
    background:none;border:none;padding:0;cursor:pointer;
    transition:opacity .2s ease;
  }
  .nav-more-trigger:hover,
  .nav-more.open .nav-more-trigger{opacity:1;}
  .nav-more-chevron{width:9px;height:6px;transition:transform .2s ease;}
  .nav-more.open .nav-more-chevron{transform:rotate(180deg);}
  .nav-more-menu{
    position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%);
    list-style:none;padding:6px;margin:0;
    background:var(--bg);border:1px solid var(--ink);
    border-radius:14px;min-width:176px;
    box-shadow:0 8px 24px rgba(44,24,16,0.10);
    z-index:60;display:flex;flex-direction:column;gap:2px;
  }
  .nav-more-menu[hidden]{display:none;}
  .nav-more-menu li{margin:0;}
  .nav-more-menu a{
    display:block;padding:9px 14px;border-radius:9px;
    font-family:'Poppins', sans-serif;font-size:12px;font-weight:500;
    letter-spacing:0.05em;text-transform:uppercase;
    color:var(--ink);opacity:.82;
    transition:background .15s ease, opacity .15s ease;
  }
  .nav-more-menu a::after{display:none;}
  .nav-more-menu a:hover{background:rgba(44,24,16,0.06);opacity:1;}

  .lang-dropdown{position:relative;}

  /* ---------- NAV CONTACT ICONS (LinkedIn + Email) ---------- */
  .nav-contact{
    display:flex;align-items:center;gap:14px;
    margin-right:16px;
  }
  .nav-icon{
    width:18px;height:18px;
    display:inline-flex;align-items:center;justify-content:center;
    color:var(--ink);opacity:.7;transition:opacity .2s ease, color .2s ease;
  }
  .nav-icon svg{width:100%;height:100%;}
  .nav-icon:hover{opacity:1;color:var(--gold);}

  /* ---------- BACK TO TOP BUTTON ---------- */
  .back-to-top{
    position:fixed;bottom:24px;right:24px;
    width:44px;height:44px;
    background:var(--ink);color:var(--bg);
    border:none;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;
    opacity:0;visibility:hidden;transform:translateY(8px);
    transition:opacity .25s ease, visibility .25s ease, transform .25s ease, background .2s ease;
    z-index:40;
    box-shadow:0 2px 12px rgba(44,24,16,0.18);
  }
  .back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0);}
  .back-to-top:hover{background:var(--gold);}
  .back-to-top svg{width:18px;height:18px;}

  /* ---------- MOBILE MENU : LANG SWITCHER ---------- */
  .mobile-menu-lang{
    display:flex;gap:12px;align-items:center;
    margin-top:36px;
    padding-top:28px;
    border-top:1px solid var(--rule);
  }
  .mobile-lang-btn{
    background:transparent;
    border:1px solid var(--rule);
    border-radius:999px;
    padding:8px 18px;
    font-family:'Poppins', sans-serif;font-weight:600;font-size:12px;
    letter-spacing:0.15em;color:var(--ink);
    cursor:pointer;transition:all .2s ease;
    min-width:56px;
  }
  .mobile-lang-btn:hover{border-color:var(--gold);color:var(--gold);}
  .mobile-lang-btn.active{
    background:var(--ink);color:var(--bg);border-color:var(--ink);
  }
  .lang-trigger{
    display:inline-flex;align-items:center;gap:8px;
    border:1px solid var(--ink);border-radius:999px;
    padding:6px 12px 6px 10px;
    font-family:'Poppins', sans-serif;font-size:12px;font-weight:600;
    letter-spacing:0.08em;background:transparent;cursor:pointer;
    color:var(--ink);transition:background .2s ease, color .2s ease;
  }
  .lang-trigger:hover{background:var(--ink);color:var(--bg);}
  .lang-flag{display:inline-flex;align-items:center;line-height:1;}
  .lang-flag-svg{width:18px;height:12px;border-radius:1.5px;display:block;}
  .lang-chevron{width:10px;height:7px;transition:transform .2s ease;}
  .lang-dropdown.open .lang-chevron{transform:rotate(180deg);}
  .lang-menu{
    position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);
    list-style:none;padding:6px;margin:0;
    background:var(--bg);border:1px solid var(--ink);
    border-radius:14px;min-width:88px;
    box-shadow:0 4px 16px rgba(44,24,16,0.08);
    z-index:60;
  }
  .lang-menu[hidden]{display:none;}
  .lang-opt{
    display:flex;align-items:center;gap:8px;
    padding:7px 12px;border-radius:999px;cursor:pointer;
    font-family:'Poppins', sans-serif;font-size:12px;font-weight:600;
    letter-spacing:0.08em;color:var(--ink);
    transition:background .15s ease, color .15s ease;
    outline:none;
  }
  .lang-opt:hover, .lang-opt:focus-visible{background:rgba(44,24,16,0.06);}
  .lang-opt.active{background:var(--ink);color:var(--bg);}

  /* ---------- LAYOUT ---------- */
  section{
    position:relative;
    padding:clamp(80px,12vh,140px) var(--gutter);
    max-width:var(--maxw);
    margin:0 auto;
  }
  .eyebrow{
    font-family:'Poppins', sans-serif;
    font-size:12px;font-weight:500;
    letter-spacing:0.22em;text-transform:uppercase;
    color:var(--muted);
    display:inline-flex;align-items:center;gap:14px;
    margin-bottom:28px;
  }
  .eyebrow::before{
    content:"";width:36px;height:1px;background:var(--gold);
  }
  h2.section-title{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:clamp(32px,4.2vw,52px);line-height:1.08;
    letter-spacing:-0.02em;margin:0 0 18px;
    color:var(--ink);
  }
  .section-lede{
    font-family:'DM Sans', sans-serif;
    font-size:clamp(17px,1.4vw,20px);
    color:var(--muted);
    margin:0 0 56px;text-wrap:pretty;
  }

  /* ---------- HERO ---------- */
  .hero{
    min-height:100dvh;
    max-width:var(--maxw);margin:0 auto;
    padding:140px var(--gutter) 80px;
    display:grid;grid-template-columns:1fr 1fr;gap:60px;
    align-items:center;
    position:relative;z-index:1;
  }
  .hero-left{position:relative;}
  .hero-eyebrow{
    font-family:'Poppins', sans-serif;font-size:12px;font-weight:500;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);
    margin-bottom:32px;display:flex;align-items:center;gap:14px;
    opacity:0;animation:fadeUp .6s ease forwards .2s;
  }
  .hero-eyebrow::before{content:"";width:48px;height:1px;background:var(--gold);}
  .hero-name{
    font-family:'Poppins', sans-serif;font-weight:700;
    font-size:clamp(48px,11vw,128px);line-height:.96;
    letter-spacing:-0.035em;margin:0 0 8px;color:var(--ink);
    position:relative;
    text-shadow:
      0 1px 0 rgba(44,24,16,.04),
      0 2px 0 rgba(44,24,16,.03),
      0 3px 0 rgba(44,24,16,.025),
      0 4px 0 rgba(44,24,16,.02),
      0 6px 18px rgba(44,24,16,.08);
    opacity:0;animation:fadeUp .8s ease forwards .35s;
  }
  .hero-name .ln{display:block;}
  .hero-name .shimmer{
    background:linear-gradient(90deg,
      var(--ink) 0%,
      var(--ink) 40%,
      var(--gold) 50%,
      var(--ink) 60%,
      var(--ink) 100%);
    background-size:200% 100%;
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    animation:shimmer 5.5s ease-in-out infinite;
  }
  @keyframes shimmer{
    0%,100%{background-position:200% 0;}
    50%{background-position:-100% 0;}
  }
  .hero-title{
    font-family:'Poppins', sans-serif;font-weight:500;
    font-size:clamp(15px,1.3vw,18px);letter-spacing:0.04em;
    color:var(--ink);margin:20px 0 0;line-height:1.4;
    display:flex;flex-direction:column;align-items:flex-start;gap:6px;
    opacity:0;animation:fadeUp .6s ease forwards .55s;
  }
  .hero-location{
    font-weight:400;font-size:0.85em;color:var(--muted);
  }
  .hero-tagline{
    font-family:'DM Sans', sans-serif;font-weight:300;
    font-size:clamp(14px,1.2vw,16px);line-height:1.6;
    margin:36px 0 48px;color:var(--ink);
    opacity:0;animation:fadeUp .7s ease forwards .7s;
  }
  .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px;
    opacity:0;animation:fadeUp .6s ease forwards .9s;}
  .cta{
    font-family:'Poppins', sans-serif;font-weight:500;font-size:14px;
    letter-spacing:0.04em;padding:14px 28px;border-radius:6px;
    transition:all .25s ease;cursor:pointer;
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
  }
  .cta-primary{background:var(--ink);color:var(--bg);}
  .cta-primary:hover{background:var(--gold);color:var(--ink);}
  .cta-primary:active{transform:scale(0.97) translateY(1px);}
  .cta-secondary{background:transparent;color:var(--ink);border:1px solid var(--ink);}
  .cta-secondary:hover{background:var(--ink);color:var(--bg);}
  .cta-secondary:active{transform:scale(0.97) translateY(1px);}
  .cta svg{width:14px;height:14px;}

  /* ---------- AVATAR ---------- */
  .hero-right{
    position:relative;display:flex;align-items:center;justify-content:center;
    min-height:520px;
    opacity:0;animation:fadeIn 1s ease forwards .4s;
  }
  .hero-illus{
    position:relative;width:min(560px,100%);aspect-ratio:1;
    display:flex;align-items:center;justify-content:center;
  }
  .hero-illus svg{width:100%;height:100%;display:block;}

  /* ---------- SCROLL CUE ---------- */
  .scroll-cue{
    position:absolute;left:var(--gutter);bottom:42px;
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);
    display:flex;align-items:center;gap:14px;
    opacity:0;animation:fadeUp .6s ease forwards 1.8s;
  }
  .scroll-cue .line{
    width:36px;height:1px;background:var(--muted);position:relative;overflow:hidden;
  }
  .scroll-cue .line::after{
    content:"";position:absolute;inset:0;background:var(--ink);
    transform:translateX(-100%);animation:trickle 2.5s ease-in-out infinite;
  }
  @keyframes trickle{
    0%{transform:translateX(-100%);}
    50%{transform:translateX(0);}
    100%{transform:translateX(100%);}
  }

  /* ---------- À PROPOS ---------- */
  .about-grid{
    display:grid;grid-template-columns:1fr;gap:0;align-items:start;
  }
  .about-body p{text-align:justify;hyphens:auto;}
  .about-body p{
    font-size:clamp(18px,1.5vw,22px);line-height:1.55;
    margin:0 0 22px;color:var(--ink);font-weight:400;
    text-wrap:pretty;
  }
  .about-meta{
    margin-top:36px;display:flex;flex-wrap:wrap;gap:36px 56px;
    padding-top:32px;border-top:1px solid var(--rule);
  }
  .meta-item .k{
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
    margin-bottom:6px;
  }
  .meta-item .v{
    font-family:'Poppins', sans-serif;font-size:15px;font-weight:500;color:var(--ink);
  }

  /* ---------- COMPÉTENCES ---------- */
  .skills-list{
    margin-top:48px;
    border-top:1px solid var(--rule);
  }
  .skill-row{
    display:grid;grid-template-columns:80px 1fr;gap:32px;
    padding:28px 0;
    border-bottom:1px solid var(--rule);
    align-items:baseline;
  }
  .skill-row-num{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:13px;letter-spacing:0.22em;
    color:var(--gold);
  }
  .skill-row-title{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:14px;letter-spacing:0.16em;text-transform:uppercase;
    color:var(--ink);
    margin:0 0 12px;
  }
  .skill-row-stack{
    font-size:16px;line-height:1.7;color:var(--muted);
    margin:0;text-wrap:pretty;
  }
  .skill-row-stack strong{
    font-weight:600;color:var(--ink);
  }
  .skills-additional{
    margin-top:28px;
    display:flex;flex-wrap:wrap;gap:14px 20px;
    font-size:14.5px;color:var(--muted);
    align-items:baseline;
  }
  .skills-additional-label{
    font-family:'Poppins', sans-serif;font-weight:500;
    font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
    color:var(--ink);
  }
  .skills-additional-list{
    color:var(--muted);
  }

  /* ---------- TIMELINE STATS & IMPACT ---------- */
  .t-stats{
    display:flex;flex-wrap:nowrap;align-items:stretch;
    gap:0;
    margin:20px 0 0;
  }
  .t-stat{
    display:flex;flex-direction:column;gap:7px;
    padding:0 22px;
    border-left:1px solid var(--rule);
    flex:1 1 0;min-width:0;
  }
  .t-stat:first-child{padding-left:0;border-left:none;}
  .t-stat-num{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:20px;letter-spacing:-0.01em;
    color:var(--gold);line-height:1;
  }
  .t-stat-lab{
    font-family:'DM Sans', sans-serif;font-size:14px;line-height:1.32;
    color:var(--ink);text-wrap:pretty;
  }
  .t-impact{
    margin:18px 0 0;padding-top:16px;
    border-top:1px solid var(--rule);
    font-family:'DM Sans', sans-serif;font-size:15px;line-height:1.6;
    color:var(--muted);text-wrap:pretty;
  }
  .t-impact-eyebrow{
    font-family:'Poppins', sans-serif;font-size:10px;font-weight:600;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);
    display:block;margin-bottom:8px;
  }

  /* ---------- EXPERIENCE TIMELINE ---------- */
  .timeline{
    position:relative;padding-left:42px;
  }
  .timeline::before{
    content:"";position:absolute;left:12px;top:8px;bottom:8px;
    width:1px;background:var(--rule);
  }
  .t-item{position:relative;padding-bottom:56px;}
  .t-item:last-child{padding-bottom:0;}
  .t-icon{
    position:absolute;left:-42px;top:0;
    width:26px;height:26px;border-radius:50%;
    background:var(--bg);border:1px solid var(--ink);
    display:flex;align-items:center;justify-content:center;
  }
  .t-icon svg{width:13px;height:13px;}
  .t-date{
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
    margin-bottom:8px;
  }
  .t-role{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:22px;
    color:var(--ink);margin:0 0 4px;letter-spacing:-0.01em;
  }
  .t-org{
    font-family:'DM Sans', sans-serif;font-size:14px;font-style:italic;
    color:var(--gold);margin-bottom:14px;
  }
  .t-desc{
    color:var(--ink);font-size:16px;line-height:1.62;
    text-wrap:pretty;margin:0;

  }
  .t-bullets{
    list-style:none;padding:0;margin:0;
  }
  .t-bullets li{
    position:relative;
    padding-left:22px;
    color:var(--ink);font-size:16px;line-height:1.62;
    margin-bottom:10px;
    text-wrap:pretty;

  }
  .t-bullets li:last-child{margin-bottom:0;}
  .t-bullets li::before{
    content:"•";
    position:absolute;
    left:4px;
    top:0;
    color:var(--gold);
    font-size:18px;
    line-height:1.62;
  }

  /* ---------- PROJETS ---------- */
  .projects-stack{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
    perspective:1800px;
  }
  .project{
    background:#FAF5ED;
    padding:24px 26px;
    border-radius:6px;
    display:flex;flex-direction:column;gap:0;
    transform-style:preserve-3d;
    transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease;
    box-shadow:0 1px 0 rgba(44,24,16,0.04);
    position:relative;
  }
  .project::before{
    content:"";position:absolute;inset:0;border-radius:6px;
    background:linear-gradient(135deg, rgba(139,90,43,0.06) 0%, rgba(139,90,43,0) 35%);
    pointer-events:none;
  }
  .project:hover{
    box-shadow:0 18px 50px -25px rgba(44,24,16,0.25);
  }
  .project-num{
    font-family:'Poppins', sans-serif;font-weight:700;font-size:11px;
    color:var(--gold);letter-spacing:0.12em;margin-bottom:12px;
    text-transform:uppercase;
    line-height:1;
    display:flex;align-items:center;gap:10px;
  }
  .project-num::after{content:"";flex:1;height:1px;background:var(--rule);max-width:40px;}
  .project-head{
    display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap;
    margin-bottom:12px;
  }
  .project-title{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:clamp(16px,1.4vw,20px);line-height:1.25;
    margin:0;color:var(--ink);letter-spacing:-0.01em;
    flex:1 1 auto;
    text-wrap:balance;
  }
  .pill{
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:600;
    letter-spacing:0.1em;text-transform:uppercase;
    padding:5px 12px;border-radius:999px;
    background:var(--gold);color:var(--ink);
    display:inline-flex;align-items:center;gap:6px;
    white-space:nowrap;
  }
  .pill.dot::before{
    content:"";width:5px;height:5px;border-radius:50%;background:var(--ink);
    animation:blink 1.6s ease-in-out infinite;
  }
  @keyframes blink{0%,100%{opacity:1;}50%{opacity:.35;}}
  .project-desc{
    color:var(--ink);font-size:14px;line-height:1.58;
    margin:0 0 16px;text-wrap:pretty;
    flex:1;

  }
  .tools-row{
    display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;
  }

  .tool{
    font-family:'Poppins', sans-serif;font-size:10px;font-weight:600;
    letter-spacing:0.08em;text-transform:uppercase;
    padding:4px 10px;border-radius:999px;
    background:var(--gold);color:var(--ink);
  }
  .gh-link{
    font-family:'Poppins', sans-serif;font-size:12px;font-weight:500;
    color:var(--ink);display:inline-flex;align-items:center;gap:8px;
    border-bottom:1px solid var(--ink);padding-bottom:2px;
    transition:color .2s, border-color .2s;
  }
  .gh-link:hover{color:var(--gold);border-color:var(--gold);}
  .gh-link svg{width:13px;height:13px;}

  /* ---------- PROJECTS — line variant for "Autres travaux" ---------- */

  /* ---------- PROJECT HERO — full-width featured spotlight (inherits standard card look) ---------- */
  .project.project-hero{
    grid-column:1 / -1;
    transform:none !important;
  }
  .project.project-hero .project-title{max-width:48ch;}
  .project.project-hero .project-desc{max-width:68ch;}

  /* ---------- PROJECTS — line variant for "Autres travaux" ---------- */
  .project.project-line{
    grid-column:1 / -1;
    background:transparent;
    padding:26px 0 28px;
    border-radius:0;
    border-top:1px solid var(--rule);
    box-shadow:none !important;
    transform:none !important;
    display:block;
    transition:none;
  }
  .project.project-line:hover{
    background:transparent;
    box-shadow:none !important;
  }
  .project.project-line::before{content:none;}
  .project-subcategory + .project.project-line{border-top:none;}
  .project.project-line .project-body{display:flex;flex-direction:column;}
  .project.project-line .project-num{display:none;}
  .project.project-line .project-head{margin:0 0 10px;display:block;}
  .project.project-line .project-title{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:clamp(17px,1.5vw,21px);letter-spacing:-0.01em;line-height:1.3;
    color:var(--ink);margin:0;
    text-wrap:balance;
    transition:color .2s ease;
  }
  .project.project-line:hover .project-title{color:var(--gold);}
  .project.project-line .project-desc{
    display:block;
    font-family:'DM Sans', sans-serif;font-size:15px;line-height:1.55;
    color:var(--muted);margin:0 0 16px;text-wrap:pretty;
  }
  .project.project-line .tools-row{
    margin:0 0 14px;flex-wrap:wrap;gap:6px;justify-content:flex-start;
  }
  .project.project-line .tool{white-space:nowrap;}
  .project.project-line .docs-row{
    margin:0;justify-content:flex-start;gap:20px;flex-wrap:wrap;
  }
  @media (max-width: 900px){
    .project.project-line{padding:22px 0 24px;}
    .project.project-line .project-title{white-space:normal;text-overflow:clip;}
    .project.project-line .docs-row{justify-content:flex-start;flex-wrap:wrap;}
  }


  .project-body{display:flex;flex-direction:column;flex:1;}

  .project-fictif{
    position:absolute;top:24px;right:14px;
    font-family:'Poppins',sans-serif;font-size:7.5px;font-weight:500;
    letter-spacing:0.12em;text-transform:uppercase;
    color:var(--muted);opacity:0.7;
    z-index:2;
    white-space:nowrap;
    line-height:1;
  }

  /* ---------- PROJECT CATEGORIES ---------- */
  .project-category{
    grid-column:1 / -1;
    padding:20px 0 12px;
    margin-top:16px;
    border-bottom:1px solid var(--ink);
    display:flex;align-items:baseline;gap:16px;
  }
  .project-category:first-child{margin-top:0;}
  .project-category-label{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:clamp(16px,1.6vw,20px);letter-spacing:-0.02em;color:var(--ink);
  }
  .project-category-count{
    font-family:'Poppins',sans-serif;font-size:10px;font-weight:500;
    letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
    margin-left:auto;text-align:right;
  }
  .project-subcategory{
    grid-column:1 / -1;
    display:flex;align-items:center;gap:12px;
    padding:14px 0 6px;
  }
  .project-subcategory-label{
    font-family:'Poppins',sans-serif;font-size:10px;font-weight:600;
    letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);
  }
  .project-subcategory::after{
    content:"";flex:1;height:1px;background:var(--rule);
  }
  .projects-see-more{
    grid-column:1 / -1;
    display:flex;justify-content:flex-end;
    padding:8px 0 0;
  }
  .see-more-link{
    display:inline-flex;align-items:center;gap:10px;
    font-family:'Poppins',sans-serif;font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;
    color:var(--ink);opacity:.72;
    padding:8px 14px;border:1px solid var(--rule);border-radius:999px;
    transition:opacity .2s ease, border-color .2s ease, background .2s ease;
  }
  .see-more-link:hover{
    opacity:1;border-color:var(--gold);background:rgba(139,90,43,0.05);
  }
  .see-more-link svg{width:14px;height:14px;color:var(--gold);transition:transform .25s ease;}
  .see-more-link:hover svg{transform:translateX(3px);}

  /* ---------- DOCS ROW ---------- */
  .docs-row{
    display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;
    margin-top:4px;
  }

  /* ---------- FORMATION ---------- */
  .edu-grid{
    display:flex;flex-direction:column;gap:56px;
  }
  .edu-items{
    display:block;
  }
  .edu-col h3{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:14px;
    letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);
    margin:0 0 24px;display:flex;align-items:center;gap:14px;
  }
  .edu-col h3::after{content:"";flex:1;height:1px;background:var(--rule);}
  .edu-item{padding:18px 0;border-top:1px solid var(--rule);}
  .edu-item:first-of-type{border-top:none;padding-top:0;}
  .edu-item:last-child{padding-bottom:0;}
  .edu-title{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:17px;
    color:var(--ink);margin:0 0 4px;letter-spacing:-0.005em;
  }
  .edu-org{font-style:italic;color:var(--gold);font-size:13px;margin-bottom:4px;}
  .edu-date{
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);
    margin-bottom:8px;
  }
  .edu-desc{color:var(--muted);font-size:14px;line-height:1.55;margin:0;}

  /* ---------- CONTACT ---------- */
  .contact{padding-bottom:80px;}
  .contact-intro{
    font-family:'DM Sans', sans-serif;font-weight:300;
    font-size:clamp(20px,2vw,28px);line-height:1.4;
    margin:0 0 30px;color:var(--ink);text-wrap:pretty;max-width:62ch;
  }

  .contact-intents{
    display:flex;flex-direction:column;gap:0;
    max-width:920px;
  }

  .contact-intent{
    padding:22px 0;
    border-top:0px solid var(--rule);
  }
  .contact-intent:last-child{border-bottom:0px solid var(--rule);}

  .contact-intent-label{
    font-family:'Poppins', sans-serif;font-weight:500;font-size:11px;
    letter-spacing:0.22em;text-transform:uppercase;
    color:var(--gold);margin:0 0 12px;
  }

  .contact-intent-link{
    display:inline-flex;align-items:center;gap:12px;
    color:var(--ink);text-decoration:none;
    font-family:'Poppins', sans-serif;font-weight:500;
    font-size:clamp(16px,1.4vw,19px);
    line-height:1.2;width:fit-content;
    transition:color .25s ease, gap .25s ease;
  }
  .contact-intent-icon{
    display:inline-flex;align-items:center;justify-content:center;
    width:18px;height:18px;
    color:var(--ink);transition:color .25s ease;flex-shrink:0;
  }
  .contact-intent-icon svg{width:100%;height:100%;}
  .contact-intent-arrow{
    width:14px;height:14px;
    transition:transform .25s ease;flex-shrink:0;color:var(--gold);
  }
  .contact-intent-link:hover{color:var(--gold);gap:16px;}
  .contact-intent-link:hover .contact-intent-icon{color:var(--gold);}
  .contact-intent-link:hover .contact-intent-arrow{transform:translateX(4px);}

  /* SECONDARY pair layout */
  .contact-intent-pair{
    display:flex;flex-wrap:wrap;gap:18px 40px;
  }

  /* ---------- SUBSTACK FEATURE ---------- */
  .substack-card{
    margin-top:48px;padding:32px 36px;
    border-radius:6px;
    background:#FAF5ED;
    display:flex;align-items:flex-start;gap:28px;
    max-width:640px;
  }
  .substack-icon{
    flex-shrink:0;width:44px;height:44px;border-radius:8px;
    background:var(--ink);display:flex;align-items:center;justify-content:center;
  }
  .substack-icon svg{width:26px;height:26px;}
  .substack-body{}
  .substack-label{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:13px;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);
    margin-bottom:6px;
  }
  .substack-title{
    font-family:'Poppins', sans-serif;font-weight:700;
    font-size:clamp(20px,2.2vw,28px);letter-spacing:-0.02em;
    color:var(--ink);margin:0 0 8px;line-height:1.1;
  }
  .substack-desc{
    font-family:'DM Sans', sans-serif;font-size:15px;line-height:1.5;
    color:var(--muted);margin:0 0 16px;max-width:44ch;
  }
  .substack-link{
    font-family:'Poppins', sans-serif;font-size:13px;font-weight:500;
    color:var(--ink);display:inline-flex;align-items:center;gap:8px;
    border-bottom:1px solid var(--ink);padding-bottom:2px;
    transition:color .2s, border-color .2s;
  }
  .substack-link:hover{color:var(--gold);border-color:var(--gold);}
  .substack-link svg{width:12px;height:12px;}

  /* ---------- SUBSTACK ARTICLE LIST ---------- */
  .substack-articles{
    margin-top:56px;
  }
  .substack-articles-eyebrow{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:11px;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);
    margin:0 0 20px;
  }
  .substack-article{
    display:block;
    padding:32px 0 34px;
    border-top:1px solid var(--rule);
    position:relative;
  }
  .substack-article:last-of-type{
    border-bottom:1px solid var(--rule);
  }
  .substack-article-meta{
    display:flex;align-items:center;gap:10px;
    margin-bottom:14px;
  }
  .substack-article-topic{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:10.5px;
    letter-spacing:0.22em;text-transform:uppercase;
    color:var(--gold);
  }
  .substack-article-sep{
    color:var(--muted);font-size:11px;opacity:0.6;
  }
  .substack-article-date{
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);
  }
  .substack-article-title{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:clamp(17px,1.5vw,21px);letter-spacing:-0.01em;line-height:1.3;
    color:var(--ink);margin:0 0 10px;
    text-wrap:balance;
    transition:color .2s ease;
  }
  .substack-article:hover .substack-article-title{color:var(--gold);}
  .substack-article-desc{
    font-family:'DM Sans', sans-serif;font-size:15px;line-height:1.55;
    color:var(--muted);margin:0 0 14px;text-wrap:pretty;
  }
  .substack-article-link{
    font-family:'Poppins', sans-serif;font-size:11.5px;font-weight:600;
    letter-spacing:0.16em;text-transform:uppercase;
    color:var(--ink);display:inline-flex;align-items:center;gap:10px;
    transition:gap .25s ease, color .2s;
  }
  .substack-article-link svg{width:11px;height:11px;transition:transform .25s ease;}
  .substack-article:hover .substack-article-link{color:var(--gold);}
  .substack-article:hover .substack-article-link svg{transform:translateX(4px);}

  .substack-see-more{
    grid-column:1 / -1;
    display:flex;justify-content:flex-end;
    padding:20px 0 0;
  }

  /* ---------- FOOTER (centered hero-style) ---------- */
  footer{
    background:rgba(44, 24, 16, 0.04);
    border-radius:36px 36px 0 0;
    margin:0;padding:0;
    position:relative;
  }
  .footer-inner{
    max-width:var(--maxw);
    margin:0 auto;
    padding:clamp(72px, 10vh, 120px) var(--gutter) 56px;
    display:flex;flex-direction:column;align-items:center;text-align:center;
  }

  .footer-tag{
    margin:0 0 56px;max-width:60ch;
  }
  .footer-tag-line{
    font-family:'DM Sans', sans-serif;font-weight:400;
    font-size:clamp(16px, 1.3vw, 19px);line-height:1.55;
    color:var(--ink);margin:0;
  }
  .footer-tag-sub{
    font-weight:300;color:var(--muted);
    margin-top:6px;
  }

  .footer-grid{
    display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:56px;
    width:100%;max-width:760px;
    padding:0 0 48px;
    border-bottom:1px solid var(--rule);
  }
  .footer-col{
    display:flex;flex-direction:column;align-items:center;text-align:center;
  }
  .footer-col-title{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:11px;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);
    margin:0 0 18px;
  }
  .footer-col ul{
    list-style:none;padding:0;margin:0;
    display:flex;flex-direction:column;gap:11px;align-items:center;
  }
  .footer-col a{
    font-family:'DM Sans', sans-serif;font-size:14.5px;
    color:var(--ink);
    display:inline-flex;align-items:center;gap:8px;
    transition:color .2s ease;
    position:relative;
  }
  .footer-col a::after{
    content:"";position:absolute;left:0;right:0;bottom:-2px;
    height:1px;background:var(--gold);
    transform:scaleX(0);transform-origin:center;
    transition:transform .25s ease;
  }
  .footer-col a:hover{color:var(--gold);}
  .footer-col a:hover::after{transform:scaleX(1);}
  .footer-icon{
    display:inline-flex;align-items:center;justify-content:center;
    width:14px;height:14px;color:var(--muted);
    transition:color .2s ease;
  }
  .footer-icon svg{width:100%;height:100%;}
  .footer-col a:hover .footer-icon{color:var(--gold);}

  .footer-copy{
    margin-top:36px;
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
    display:flex;flex-direction:column;gap:8px;align-items:center;
  }

  /* ---------- REVEALS ---------- */
  .reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease-out, transform .6s ease-out;}
  .reveal.in{opacity:1;transform:translateY(0);}
  .reveal-delay-1{transition-delay:.08s;}
  .reveal-delay-2{transition-delay:.16s;}
  .reveal-delay-3{transition-delay:.24s;}

  /* ---------- ACCESSIBILITY : reduced motion ---------- */
  @media (prefers-reduced-motion: reduce){
    *, *::before, *::after{
      animation-duration:0.01ms !important;
      animation-iteration-count:1 !important;
      transition-duration:0.01ms !important;
      scroll-behavior:auto !important;
    }
    .reveal{opacity:1;transform:none;}
    .particles, .cursor-accent{display:none !important;}
    .loader{animation:none;opacity:0;visibility:hidden;}
  }

  /* lang fade */
  body.lang-switching [data-fr],
  body.lang-switching [data-en],
  body.lang-switching [data-ht]{opacity:0;transition:opacity .2s ease;}

  @keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
  @keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

  /* ---------- PROJECT "EN SAVOIR PLUS" CTA ---------- */
  /* Sits in .docs-row, aligned right of the GitHub link. Matches .gh-link style. */
  .project-more{
    background:transparent;border:0;padding:0 0 2px;
    font-family:'Poppins', sans-serif;font-size:12px;font-weight:500;
    color:var(--ink);
    display:inline-flex;align-items:center;gap:8px;
    border-bottom:1px solid var(--ink);
    cursor:pointer;
    transition:color .2s, border-color .2s, gap .2s;
    margin-left:auto;
  }
  .project-more:hover{color:var(--gold);border-color:var(--gold);gap:12px;}
  .project-more .arr{transition:transform .25s ease;display:inline-block;}
  .project-more:hover .arr{transform:translateX(3px);}

  /* ---------- MODAL OVERLAY ---------- */
  .modal-overlay{
    position:fixed;inset:0;z-index:200;
    background:rgba(28, 16, 10, 0.62);
    backdrop-filter:blur(6px);
    -webkit-backdrop-filter:blur(6px);
    opacity:0;visibility:hidden;
    transition:opacity .35s ease, visibility .35s ease;
    display:flex;align-items:center;justify-content:center;
    padding:24px;
  }
  .modal-overlay.open{opacity:1;visibility:visible;}

  .modal{
    position:relative;
    width:min(720px, 100%);
    max-height:min(86vh, 720px);
    background:var(--bg);
    border-radius:10px;
    box-shadow:
      0 30px 80px -20px rgba(28,16,10,.55),
      0 0 0 1px rgba(139,90,43,0.18);
    overflow:hidden;
    display:flex;flex-direction:column;
    transform:translateY(24px) scale(0.97);
    opacity:0;
    transition:transform .42s cubic-bezier(.2,.7,.2,1), opacity .35s ease;
  }
  .modal-overlay.open .modal{transform:translateY(0) scale(1);opacity:1;}

  /* faint top hairline in gold — REMOVED on request */
  .modal::before{ content:none; }

  /* background SVG illustration — transparent watermark */
  .modal-bg-illus{
    position:absolute;
    right:-40px;bottom:-40px;
    width:340px;height:340px;
    pointer-events:none;
    opacity:0.07;
    color:var(--ink);
    z-index:0;
  }
  .modal-bg-illus svg{width:100%;height:100%;display:block;}

  /* close button */
  .modal-close{
    position:absolute;top:18px;right:18px;
    width:36px;height:36px;border-radius:50%;
    background:transparent;border:1px solid var(--rule);
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    color:var(--ink);transition:all .2s ease;z-index:5;
    padding:0;
  }
  .modal-close:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);}
  .modal-close svg{width:14px;height:14px;}

  /* header */
  .modal-header{
    padding:36px 44px 20px;
    position:relative;z-index:2;
    flex:0 0 auto;
  }
  .modal-eyebrow{
    font-family:'Poppins', sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);
    display:inline-flex;align-items:center;gap:14px;margin-bottom:14px;
  }
  .modal-eyebrow::before{
    content:"";width:28px;height:1px;background:var(--gold);
  }
  .modal-title{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:clamp(22px, 2.4vw, 28px);line-height:1.18;
    letter-spacing:-0.018em;
    color:var(--ink);margin:0;padding-right:48px;
    text-wrap:balance;
  }

  /* tabs */
  .modal-tabs{
    display:flex;gap:0;
    padding:0 44px;
    border-bottom:1px solid var(--rule);
    position:relative;z-index:2;
    overflow-x:auto;
    overflow-y:hidden;
    flex:0 0 auto;
    scrollbar-width:none;
  }
  .modal-tabs::-webkit-scrollbar{display:none;}
  .modal-tab{
    background:transparent;border:none;
    padding:14px 0;margin-right:28px;
    font-family:'Poppins', sans-serif;font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);
    cursor:pointer;position:relative;
    white-space:nowrap;
    transition:color .2s ease;
  }
  .modal-tab:hover{color:var(--ink);}
  .modal-tab.active{color:var(--ink);font-weight:600;}
  .modal-tab::after{
    content:"";position:absolute;left:0;right:0;bottom:-1px;
    height:2px;background:var(--gold);
    transform:scaleX(0);transform-origin:center;
    transition:transform .3s ease;
  }
  .modal-tab.active::after{transform:scaleX(1);}

  /* content body — scrollable */
  .modal-body{
    padding:28px 44px 24px;
    overflow-y:auto;
    flex:1 1 auto;
    min-height:0;
    position:relative;z-index:2;
    scrollbar-width:thin;
    scrollbar-color:var(--rule) transparent;
  }
  .modal-body::-webkit-scrollbar{width:6px;}
  .modal-body::-webkit-scrollbar-thumb{background:var(--rule);border-radius:3px;}

  .tab-panel{
    display:none;
    animation:tabFade .3s ease;
  }
  .tab-panel.active{display:block;}
  @keyframes tabFade{
    from{opacity:0;transform:translateY(6px);}
    to{opacity:1;transform:translateY(0);}
  }
  .tab-panel p{
    font-family:'DM Sans', sans-serif;
    font-size:15.5px;line-height:1.65;
    color:var(--ink);margin:0 0 14px;
    text-wrap:pretty;
  }
  .tab-panel p:last-child{margin-bottom:0;}
  .tab-panel .panel-label{
    font-family:'Poppins', sans-serif;font-size:10px;font-weight:600;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);
    margin-bottom:10px;
  }

  /* outils tab — méthodes section */
  .modal-methodes{margin:0 0 24px;padding:0 0 22px;border-bottom:1px solid var(--rule);}
  .modal-methodes-label{
    font-family:'Poppins',sans-serif;font-size:10px;font-weight:600;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);
    margin:0 0 12px;
    display:flex;align-items:center;gap:10px;
  }
  .modal-methodes-label::before{
    content:"";width:18px;height:1px;background:var(--gold);
  }
  .modal-methodes-row{
    display:flex;flex-wrap:wrap;gap:8px;
  }
  .modal-methodes-row .tool{
    background:transparent;
    border:1px solid var(--gold);
    color:var(--ink);
  }

  /* outils tab — list of tools with role */
  .tools-list{list-style:none;padding:0;margin:0;}
  .tools-list li{
    display:grid;grid-template-columns:140px 1fr;gap:18px;
    padding:12px 0;border-top:1px solid var(--rule);
    align-items:baseline;
  }
  .tools-list li:first-child{border-top:none;padding-top:0;}
  .tools-list .t-name{
    font-family:'Poppins', sans-serif;font-weight:600;font-size:13px;
    color:var(--ink);letter-spacing:0.02em;
  }
  .tools-list .t-role{
    font-family:'DM Sans', sans-serif;font-size:14px;color:var(--muted);
    line-height:1.5;text-wrap:pretty;
  }
  .tools-phase{margin-bottom:22px;}
  .tools-phase:last-child{margin-bottom:0;}
  .tools-phase-label{
    font-family:'Poppins',sans-serif;font-size:10px;font-weight:600;
    letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);
    margin:0 0 12px;
    display:flex;align-items:center;gap:10px;
  }
  .tools-phase-label::before{
    content:"";width:18px;height:1px;background:var(--gold);
  }

  /* chiffres tab — key figures */
  .stats-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
    gap:28px 32px;
    margin:0;padding:8px 0 0;
  }
  .stat-cell{
    display:flex;flex-direction:column;gap:8px;
    padding:0 0 0 16px;
    border-left:1px solid var(--rule);
    position:relative;
  }
  .stat-cell .num{
    font-family:'Poppins', sans-serif;font-weight:700;
    font-size:clamp(28px, 3.4vw, 38px);line-height:1;
    letter-spacing:-0.02em;color:var(--ink);
  }
  .stat-cell .lab{
    font-family:'Poppins', sans-serif;font-size:10px;font-weight:500;
    letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);
    line-height:1.4;
  }
  .stat-cell .sub{
    font-family:'DM Sans', sans-serif;font-size:13px;color:var(--muted);
    line-height:1.5;text-wrap:pretty;margin-top:2px;
  }
  .stats-cta{
    display:inline-flex;align-items:center;gap:10px;
    margin-top:28px;padding-top:20px;
    border-top:1px solid var(--rule);
    width:100%;
    font-family:'Poppins', sans-serif;font-size:13px;font-weight:500;
    letter-spacing:0.04em;
    color:var(--ink);
    transition:color .2s ease, gap .2s ease;
    text-decoration:none;
  }
  .stats-cta .lead{
    font-family:'DM Sans', sans-serif;font-size:11px;font-weight:400;
    letter-spacing:0.18em;text-transform:uppercase;
    color:var(--muted);margin-right:4px;
  }
  .stats-cta .arr{
    display:inline-block;transition:transform .2s ease;
    font-size:15px;line-height:1;color:var(--gold);
  }
  .stats-cta:hover{color:var(--gold);gap:14px;}
  .stats-cta:hover .arr{transform:translate(2px,-2px);}

  /* footer — always-visible GitHub */
  .modal-footer{
    padding:18px 44px 22px;
    border-top:1px solid var(--rule);
    display:flex;align-items:center;justify-content:space-between;gap:18px;
    background:rgba(245,240,232,0.7);
    position:relative;z-index:2;
    flex-wrap:wrap;
  }
  .modal-fictif-tag{
    font-family:'Poppins',sans-serif;font-size:10px;font-weight:500;
    letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
  }
  .modal-github{
    font-family:'Poppins', sans-serif;font-size:13px;font-weight:500;
    color:var(--ink);display:inline-flex;align-items:center;gap:10px;
    border:1px solid var(--ink);
    padding:8px 16px;border-radius:6px;
    transition:all .2s ease;
    margin-left:auto;
  }
  .modal-github:hover{background:var(--ink);color:var(--bg);}
  .modal-github svg{width:14px;height:14px;}

  /* responsive */
  @media (max-width: 640px){
    .modal-overlay{padding:16px;align-items:center;}
    .modal{max-height:88vh;width:100%;}
    .modal-header{padding:30px 24px 16px;}
    .modal-tabs{padding:0 24px;}
    .modal-tab{margin-right:20px;font-size:11px;}
    .modal-body{padding:22px 24px 18px;}
    .modal-footer{padding:14px 24px 18px;}
    .modal-bg-illus{width:220px;height:220px;right:-30px;bottom:-30px;}
    .tools-list li{grid-template-columns:1fr;gap:4px;}
    .modal-title{font-size:20px;padding-right:36px;}
  }

  /* prevent body scroll when modal open */
  body.modal-open, body.menu-open{overflow:hidden;}

  /* ---------- MOBILE MENU ---------- */
  .hamburger{
    display:none;
    flex-direction:column;justify-content:center;align-items:center;
    gap:5px;width:36px;height:36px;cursor:pointer;
    background:transparent;border:0;padding:0;
    position:relative;z-index:60;
  }
  .hamburger span{
    display:block;width:22px;height:1.5px;
    background:var(--ink);border-radius:2px;
    transition:transform .3s ease, opacity .3s ease;
    transform-origin:center;
  }
  .hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
  .hamburger.open span:nth-child(2){opacity:0;}
  .hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
  .mobile-menu{
    position:fixed;top:0;left:0;right:0;bottom:0;z-index:49;
    background:var(--bg);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:32px;
    padding-top:80px;
    opacity:0;pointer-events:none;
    transition:opacity .3s ease;
  }
  .mobile-menu.open{opacity:1;pointer-events:all;}
  .mobile-menu a{
    font-family:'Poppins', sans-serif;font-weight:600;
    font-size:clamp(24px,6vw,36px);letter-spacing:-0.01em;
    color:var(--ink);text-decoration:none;
    position:relative;
  }
  .mobile-menu a::after{
    content:"";position:absolute;left:0;right:0;bottom:-4px;
    height:1px;background:var(--gold);
    transform:scaleX(0);transform-origin:left;
    transition:transform .25s ease;
  }
  .mobile-menu a:hover::after{transform:scaleX(1);}

  /* ---------- TOUCH DEVICES: kill sticky :hover ---------- */
  /* On touch devices, tapping a button triggers :hover and it persists
     until the user taps elsewhere. Force-revert every hover rule so
     buttons/links return to their default state immediately after tap. */
  @media (hover: none){
    .nav-links a:hover{opacity:.78;}
    .nav-links a:hover::after{transform:scaleX(0);}
    .cta-primary:hover{background:var(--ink);color:var(--bg);}
    .cta-secondary:hover{background:transparent;color:var(--ink);}
    .cta-primary:active,
    .cta-secondary:active{transform:none;}
    .project:hover{box-shadow:none;}
    .gh-link:hover{color:inherit;border-color:currentColor;}
    .project.project-line:hover .project-title{color:inherit;}
    .contact-link:hover,
    .contact-link:hover .c-icon{color:inherit;}
    .contact-link:hover .c-label{border-color:currentColor;}
    .substack-link:hover{color:inherit;border-color:currentColor;}
    .substack-article:hover .substack-article-title{color:inherit;}
    .substack-article:hover .substack-article-link{color:inherit;}
    .substack-article:hover .substack-article-link svg{transform:none;}
    .project-more:hover{color:inherit;border-color:currentColor;gap:8px;}
    .project-more:hover .arr{transform:none;}
    .modal-close:hover{
      background:transparent;color:var(--ink);border-color:var(--ink);
    }
    .modal-tab:hover{color:inherit;}
    .stats-cta:hover{color:var(--gold);gap:10px;}
    .stats-cta:hover .arr{transform:none;}
    .modal-github:hover{background:transparent;color:var(--ink);}
    .mobile-menu a:hover::after{transform:scaleX(0);}
  }

  /* ---------- RESPONSIVE ---------- */
  @media (max-width: 1100px){
    .projects-stack{grid-template-columns:repeat(2,1fr);}
  }
  @media (max-width: 560px){
    .projects-stack{grid-template-columns:1fr !important;}
  }
  @media (max-width: 900px){
    .hero{grid-template-columns:1fr;gap:48px;padding-top:120px;min-height:auto;}
    .hero-right{order:-1;min-height:340px;}
    .hero-illus{width:min(320px,80%);}
    .annot{display:none;}
    .nav-links{display:none;}
    .about-grid{grid-template-columns:1fr;gap:0;}
    .project{padding:18px 18px;}
    .projects-stack{grid-template-columns:repeat(2,1fr);gap:14px;perspective:none;}
    .edu-grid{gap:40px;}
    .edu-items{grid-template-columns:1fr;}
    .footer-grid{gap:32px;}
    .scroll-cue{display:none;}
    .hamburger{display:flex;}
    /* contact icons stay visible on mobile, grouped to the right with the lang pill + burger */
    .nav-contact{display:flex;margin-left:auto;margin-right:10px;gap:6px;}
    .nav-icon{width:34px;height:34px;}      /* larger tap target */
    .nav-icon svg{width:18px;height:18px;}  /* keep icon visually 18px, centered */
    .lang-dropdown{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);margin:0;}  /* centrée dans la nav */
    .lang-menu{left:50%;right:auto;transform:translateX(-50%);}  /* centré sous la pastille */
    .particles{display:none;}
    .back-to-top{bottom:18px;right:18px;width:40px;height:40px;}
  }
  @media (max-width: 580px){
    .skill-row{grid-template-columns:1fr;gap:8px;padding:24px 0;}
    .footer-grid{grid-template-columns:1fr;gap:36px;}
    .skill-row-num{font-size:11px;}
  }
  @media (min-width:901px){
    .mobile-pills{display:none;}
  }

  /* ---------- PRINT STYLES ---------- */
  @media print{
    *, *::before, *::after{
      background:transparent !important;
      color:#000 !important;
      box-shadow:none !important;
      text-shadow:none !important;
    }
    body{font-size:11pt;line-height:1.5;color:#000;background:#fff;}
    .nav, .mobile-menu, .hamburger, .particles, .cursor-accent,
    .scroll-cue, .loader, .back-to-top, .lang-dropdown,
    .nav-contact, .skip-link, .modal-overlay{display:none !important;}
    main, section{page-break-inside:avoid;break-inside:avoid;}
    h1, h2, h3{page-break-after:avoid;break-after:avoid;}
    a{color:#000 !important;text-decoration:underline;}
    a[href^="http"]::after{content:" (" attr(href) ")";font-size:9pt;color:#444;}
    .project-fictif, .modal-fictif-tag{border:1px solid #000;}
  }
