/* =========================================================
   Lorenzo Donval — Dossier technique 2026
   Concept : planches d'architecte / blueprint
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --paper:#f1ede3;          /* blanc cassé chaud */
  --paper-2:#e8e3d5;
  --ink:#1b2a20;            /* vert forêt très foncé */
  --ink-soft:#56655a;
  --ink-faint:#9aa18d;
  --line:rgba(27,42,32,.14);
  --line-strong:rgba(27,42,32,.30);
  --accent:#2f5d3f;         /* vert forêt */
  --accent-2:#8a7a52;       /* ocre discret */
  --card:#f7f4ec;
  --card-edge:rgba(27,42,32,.12);

  --rail-w:236px;
  --maxw:1120px;

  --serifish:"Hanken Grotesk",system-ui,sans-serif;
  --display:"Space Grotesk","Hanken Grotesk",sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;

  --ease-out:cubic-bezier(.23,1,.32,1);
  --ease-io:cubic-bezier(.77,0,.175,1);

  --grid:46px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serifish);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .5s var(--ease-out), color .5s var(--ease-out);
}
body.is-loading{overflow:hidden;height:100vh}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
em{font-style:italic;color:var(--accent)}
::selection{background:var(--accent);color:var(--paper)}

/* ---------- Blueprint grid + grain ---------- */
.bp-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:var(--grid) var(--grid);
  -webkit-mask-image:radial-gradient(circle at 60% 30%,#000 0%,rgba(0,0,0,.55) 70%,rgba(0,0,0,.25) 100%);
          mask-image:radial-gradient(circle at 60% 30%,#000 0%,rgba(0,0,0,.55) 70%,rgba(0,0,0,.25) 100%);
  opacity:.9;
}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Progress ---------- */
#progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:90;transition:width .1s linear}

/* ---------- Loader ---------- */
.loader{position:fixed;inset:0;z-index:200;background:var(--paper);
  display:grid;place-items:center;transition:opacity .6s var(--ease-out),visibility .6s}
body:not(.is-loading) .loader{opacity:0;visibility:hidden}
.loader__sheet{width:min(86vw,420px);text-align:left;
  border:1px solid var(--line-strong);padding:26px;background:var(--card);
  box-shadow:0 30px 80px -40px rgba(0,0,0,.5)}
.loader__code{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);display:block}
.loader__title{display:block;font-family:var(--display);font-size:20px;font-weight:600;margin:6px 0 18px}
.loader__bar{height:3px;background:var(--line);overflow:hidden}
.loader__bar span{display:block;height:100%;width:0;background:var(--accent)}
.loader__pct{font-family:var(--mono);font-size:12px;color:var(--ink-soft);display:block;margin-top:10px}
.loader__pct b{color:var(--ink)}

/* ---------- Title-block rail (desktop sidebar) ---------- */
.rail{
  position:fixed;top:0;left:0;bottom:0;width:var(--rail-w);z-index:60;
  border-right:1px solid var(--line-strong);
  background:linear-gradient(180deg,var(--paper),var(--paper-2));
  display:flex;flex-direction:column;padding:26px 22px;
}
.rail__brand{display:flex;align-items:center;gap:12px;margin-bottom:40px}
.rail__brand-mark{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:.04em;
  border:1px solid var(--line-strong);padding:8px 10px;line-height:1}
.rail__brand-meta b{font-family:var(--display);font-size:14px;display:block;letter-spacing:.02em}
.rail__brand-meta i{font-family:var(--mono);font-style:normal;font-size:10px;color:var(--ink-soft);letter-spacing:.1em}

.rail__nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.rail__nav a{display:flex;align-items:baseline;gap:12px;padding:11px 10px;border-radius:4px;
  font-family:var(--display);font-size:15px;color:var(--ink-soft);position:relative;
  transition:color .25s var(--ease-out),background .25s var(--ease-out),padding-left .25s var(--ease-out)}
.rail__nav a span{font-family:var(--mono);font-size:11px;color:var(--ink-faint);transition:color .25s}
.rail__nav a::before{content:"";position:absolute;left:0;top:50%;width:0;height:1px;background:var(--accent);transition:width .3s var(--ease-out)}
.rail__nav a:hover{color:var(--ink);padding-left:16px}
.rail__nav a.active{color:var(--ink)}
.rail__nav a.active span{color:var(--accent)}
.rail__nav a.active::before{width:8px}
.rail__nav a.active{padding-left:16px}

.rail__foot{margin-top:auto;display:flex;flex-direction:column;gap:14px;padding-top:20px;border-top:1px solid var(--line)}
.rail__theme{display:flex;align-items:center;gap:9px;background:none;border:1px solid var(--line-strong);
  color:var(--ink);font-family:var(--mono);font-size:11px;letter-spacing:.08em;padding:9px 12px;cursor:pointer;
  border-radius:4px;transition:transform .16s var(--ease-out),border-color .25s}
.rail__theme:hover{border-color:var(--accent)}
.rail__theme:active{transform:scale(.97)}
.rail__theme-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}
.rail__status{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;color:var(--ink-soft);letter-spacing:.04em}
.rail__scale{font-family:var(--mono);font-size:9.5px;color:var(--ink-faint);letter-spacing:.16em}

.pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);position:relative;flex:none}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--accent);animation:pulse 2s var(--ease-out) infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(3.4);opacity:0}}

/* ---------- Mobile top bar + drawer ---------- */
.topbar,.drawer{display:none}
@media (max-width:900px){
  .rail{display:none}
  .topbar{display:flex;position:fixed;top:0;left:0;right:0;z-index:70;align-items:center;justify-content:space-between;
    padding:14px 18px;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line-strong)}
  .topbar__brand{font-family:var(--display);font-weight:700;font-size:16px;display:flex;gap:6px;align-items:center}
  .topbar__brand span{color:var(--accent)}
  .topbar__burger{background:none;border:0;width:30px;height:22px;position:relative;cursor:pointer}
  .topbar__burger span{position:absolute;left:0;right:0;height:2px;background:var(--ink);transition:transform .3s var(--ease-out),opacity .2s}
  .topbar__burger span:nth-child(1){top:2px}
  .topbar__burger span:nth-child(2){top:10px}
  .topbar__burger span:nth-child(3){top:18px}
  body.menu-open .topbar__burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  body.menu-open .topbar__burger span:nth-child(2){opacity:0}
  body.menu-open .topbar__burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .drawer{display:flex;flex-direction:column;gap:4px;position:fixed;inset:0;z-index:65;
    background:var(--paper);padding:90px 28px 40px;
    transform:translateY(-100%);transition:transform .5s var(--ease-io);visibility:hidden}
  body.menu-open .drawer{transform:translateY(0);visibility:visible}
  .drawer a{font-family:var(--display);font-size:30px;font-weight:600;padding:12px 0;border-bottom:1px solid var(--line);display:flex;gap:14px;align-items:baseline}
  .drawer a span{font-family:var(--mono);font-size:13px;color:var(--accent)}
  .drawer__theme{margin-top:24px;align-self:flex-start;background:none;border:1px solid var(--line-strong);color:var(--ink);
    font-family:var(--mono);font-size:12px;padding:11px 16px;border-radius:4px;cursor:pointer}
}

/* ---------- Sheet / layout ---------- */
.sheet{position:relative;z-index:2;margin-left:var(--rail-w);padding:0 clamp(20px,5vw,72px)}
@media (max-width:900px){.sheet{margin-left:0;padding:0 20px}}

.planche{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,11vh,140px) 0;border-top:1px dashed var(--line-strong)}
.planche:first-of-type{border-top:0}

/* ---------- Section head (drawing title) ---------- */
.phead{display:flex;align-items:center;gap:16px;margin-bottom:30px}
.phead__no{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--accent)}
.phead__line{flex:1;height:1px;background:var(--line-strong);position:relative}
.phead__line::before,.phead__line::after{content:"";position:absolute;width:1px;height:7px;background:var(--line-strong);top:-3px}
.phead__line::before{left:0}.phead__line::after{right:0}
.phead__name{font-family:var(--display);font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}

.lede-h{font-family:var(--display);font-weight:600;font-size:clamp(30px,5.2vw,58px);line-height:1.04;
  letter-spacing:-.02em;margin:0 0 50px;max-width:18ch}
.lede-h .u{text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:6px;text-decoration-thickness:2px}

/* ---------- HERO ---------- */
.hero{max-width:var(--maxw);margin:0 auto;padding:clamp(96px,16vh,180px) 0 clamp(50px,8vh,90px)}
.hero__head{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:clamp(28px,5vh,54px)}
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--ink-soft);
  border:1px solid var(--line);padding:6px 11px;border-radius:3px;display:flex;align-items:center;gap:7px}
.tag--live{color:var(--ink)}

.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,4vw,56px);align-items:center}
@media (max-width:820px){.hero__grid{grid-template-columns:1fr;gap:38px}}

.hero__title{margin:0;font-family:var(--display);font-weight:700;line-height:.92;letter-spacing:-.03em;
  font-size:clamp(56px,11vw,138px)}
.hero__title-row{display:block;overflow:hidden}
.hero__title-row--out span{color:transparent;-webkit-text-stroke:1.4px var(--ink)}
.hero__title-row span{display:block;transform:translateY(110%);transition:transform .9s var(--ease-io)}
body:not(.is-loading) .hero__title-row span{transform:translateY(0)}
body:not(.is-loading) .hero__title-row--out span{transition-delay:.08s}

.hero__role{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:22px 0 26px;
  font-family:var(--mono);font-size:clamp(14px,1.8vw,18px);color:var(--ink)}
.hero__role-sep{color:var(--accent)}
.hero__role-2{color:var(--accent)}

.hero__lede{max-width:46ch;font-size:clamp(16px,1.9vw,19px);color:var(--ink);margin:0 0 30px}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-weight:500;font-size:15px;
  padding:13px 20px;border-radius:5px;cursor:pointer;border:1px solid var(--ink);
  transition:transform .16s var(--ease-out),background .3s var(--ease-out),color .3s var(--ease-out)}
.btn svg{transition:transform .3s var(--ease-out)}
.btn:hover svg{transform:translate(2px,-2px)}
.btn:active{transform:scale(.97)}
.btn--solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--solid:hover{background:var(--accent);border-color:var(--accent)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}

/* hero photo frame */
.hero__right{display:flex;justify-content:center}
.frame{position:relative;margin:0;width:min(100%,340px);border:1px solid var(--line-strong);padding:12px;background:var(--card)}
.frame img{width:100%;aspect-ratio:351/401;object-fit:cover;filter:grayscale(.18) contrast(1.03)}
.frame figcaption{font-family:var(--mono);font-size:11px;color:var(--ink-soft);margin-top:9px;letter-spacing:.04em}
.frame figcaption b{color:var(--accent)}
.frame__crop{position:absolute;width:13px;height:13px;border:1.5px solid var(--accent)}
.frame__crop--tl{top:-6px;left:-6px;border-right:0;border-bottom:0}
.frame__crop--tr{top:-6px;right:-6px;border-left:0;border-bottom:0}
.frame__crop--bl{bottom:-6px;left:-6px;border-right:0;border-top:0}
.frame__crop--br{bottom:-6px;right:-6px;border-left:0;border-top:0}
.frame__dim{position:absolute;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--ink-faint);display:flex;align-items:center;gap:6px}
.frame__dim--v{left:-58px;top:50%;transform:rotate(-90deg) translateX(50%);transform-origin:right center}
.frame__dim--v i{width:34px;height:1px;background:var(--line-strong)}
.frame__dim--h{bottom:-26px;left:50%;transform:translateX(-50%)}
.frame__dim--h i{width:60px;height:1px;background:var(--line-strong)}
@media (max-width:820px){.frame__dim{display:none}}

/* title block */
.titleblock{display:grid;grid-template-columns:repeat(5,1fr);margin-top:clamp(40px,7vh,72px);
  border:1px solid var(--line-strong);background:var(--card)}
@media (max-width:820px){.titleblock{grid-template-columns:repeat(2,1fr)}}
.tb__cell{padding:15px 16px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:5px}
.tb__cell:last-child{border-right:0}
@media (max-width:820px){.tb__cell{border-bottom:1px solid var(--line)}}
.tb__k{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--ink-faint);text-transform:uppercase}
.tb__v{font-family:var(--display);font-size:14.5px;font-weight:500;display:flex;align-items:center;gap:7px}
.tb__cell--acc{background:color-mix(in srgb,var(--accent) 12%,transparent)}
.tb__cell--acc .tb__v{color:var(--accent)}

.hero__scroll{display:block;text-align:center;margin-top:46px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink-faint);animation:bob 2.4s var(--ease-io) infinite}
@keyframes bob{50%{transform:translateY(6px)}}

/* ---------- PROFIL : section drawing ---------- */
.section-drawing{display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:stretch}
@media (max-width:760px){.section-drawing{grid-template-columns:1fr}}
.pillar{padding:30px clamp(20px,3vw,40px);border:1px solid var(--line-strong);background:var(--card)}
.pillar--alt{border-left:0}
@media (max-width:760px){.pillar--alt{border-left:1px solid var(--line-strong);border-top:0}}
.pillar header{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}
.pillar__id{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--accent)}
.pillar h3{font-family:var(--display);font-size:clamp(24px,3vw,34px);font-weight:600;margin:0}
.pillar p{margin:0 0 18px;color:var(--ink-soft)}
.ticks{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.ticks li{font-family:var(--mono);font-size:13px;padding-left:22px;position:relative;color:var(--ink)}
.ticks li::before{content:"▸";position:absolute;left:0;color:var(--accent)}
.axis{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 6px}
@media (max-width:760px){.axis{flex-direction:row;padding:14px 0}}
.axis__line{flex:1;width:1px;background:var(--line-strong)}
@media (max-width:760px){.axis__line{width:auto;height:1px}}
.axis__node{font-family:var(--display);font-size:26px;color:var(--accent);padding:10px 0}

/* ---------- PARCOURS : elevation ---------- */
.elev{list-style:none;margin:0;padding:0;position:relative}
.elev::before{content:"";position:absolute;left:160px;top:6px;bottom:6px;width:1px;background:var(--line-strong)}
@media (max-width:680px){.elev::before{left:8px}}
.lvl{display:grid;grid-template-columns:160px 1fr;gap:30px;padding:18px 0;position:relative}
@media (max-width:680px){.lvl{grid-template-columns:1fr;gap:6px;padding-left:32px}}
.lvl__yr{font-family:var(--mono);font-size:12px;color:var(--ink-soft);text-align:right;padding-top:3px;padding-right:20px;letter-spacing:.02em}
@media (max-width:680px){.lvl__yr{text-align:left;padding-right:0}}
.lvl__body{position:relative}
.lvl__body::before{content:"";position:absolute;left:-40px;top:7px;width:11px;height:11px;border-radius:50%;
  background:var(--paper);border:1.5px solid var(--ink-soft);transition:border-color .3s,background .3s}
@media (max-width:680px){.lvl__body::before{left:-32px}}
.lvl--now .lvl__body::before{border-color:var(--accent);background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 20%,transparent)}
.lvl h3{font-family:var(--display);font-size:clamp(17px,2.2vw,21px);font-weight:600;margin:0 0 5px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.lvl p{margin:0;color:var(--ink-soft);font-size:15.5px;max-width:60ch}
.badge{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--accent);border:1px solid var(--accent);
  padding:3px 8px;border-radius:20px;text-transform:uppercase}
.lvl--base .lvl__body::before{border-style:dashed}

/* ---------- RÉALISATIONS : projects ---------- */
.project{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(24px,4vw,56px);align-items:center;
  padding:clamp(34px,5vh,64px) 0;border-bottom:1px dashed var(--line)}
.project--rev{grid-template-columns:1.1fr .9fr}
.project--rev .project__info{order:2}
@media (max-width:840px){.project,.project--rev{grid-template-columns:1fr;gap:26px}.project--rev .project__info{order:0}}
.project__no{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--accent)}
.project__info h3{font-family:var(--display);font-size:clamp(23px,3.2vw,34px);font-weight:600;line-height:1.08;margin:10px 0 14px}
.project__info p{color:var(--ink-soft);margin:0 0 20px;max-width:46ch}
.chips{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0}
.chips li{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink);
  border:1px solid var(--line-strong);padding:6px 11px;border-radius:3px;transition:border-color .25s,color .25s}
.chips li:hover{border-color:var(--accent);color:var(--accent)}
.chips--lg li{font-size:13px;padding:8px 14px}

.project__plates{display:flex;flex-direction:column;gap:14px}
.plate{position:relative;margin:0;border:1px solid var(--line-strong);padding:8px;background:var(--card);overflow:hidden}
.plate img{width:100%;object-fit:cover;aspect-ratio:16/10;filter:contrast(1.02);
  transition:transform .8s var(--ease-out);clip-path:inset(0 0 100% 0)}
.plate.seen img{clip-path:inset(0 0 0 0)}
.plate:hover img{transform:scale(1.03)}
.plate--sm img{aspect-ratio:21/9}
.plate__tag{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  color:var(--paper);background:color-mix(in srgb,var(--ink) 82%,transparent);padding:4px 9px;border-radius:3px}
.project--rev .project__plates,.project--mono .project__plates{flex-direction:row;flex-wrap:wrap}
.project--rev .plate,.project--mono .plate{flex:1 1 46%;min-width:46%}
.plate--poster img{aspect-ratio:1/1}
@media (max-width:840px){.project--rev .project__plates{flex-direction:column}}

/* console schema (project 3) */
.project--mono{grid-template-columns:.9fr 1.1fr}
.console{width:100%;border:1px solid var(--line-strong);background:var(--card);padding:20px;position:relative}
.console__tag{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--accent);display:block;margin-bottom:18px}
.console__faders{display:grid;grid-template-columns:repeat(12,1fr);gap:10px;height:150px;align-items:end}
.console__faders span{position:relative;height:100%;background:var(--line);border-radius:2px}
.console__faders span::after{content:"";position:absolute;left:-3px;right:-3px;height:14px;border-radius:2px;
  background:var(--accent);bottom:calc(var(--p,.5) * (100% - 14px));transform:scaleY(0);transform-origin:bottom;
  transition:transform .6s var(--ease-out),bottom .8s var(--ease-out)}
.console.seen .console__faders span::after{transform:scaleY(1)}
.console__vu{display:flex;gap:5px;margin-top:18px}
.console__vu i{flex:1;height:6px;background:var(--line);border-radius:2px;animation:vu 1.1s var(--ease-io) infinite}
.console__vu i:nth-child(2){animation-delay:.1s}.console__vu i:nth-child(3){animation-delay:.2s}
.console__vu i:nth-child(4){animation-delay:.3s}.console__vu i:nth-child(5){animation-delay:.15s}
.console__vu i:nth-child(6){animation-delay:.25s}.console__vu i:nth-child(7){animation-delay:.05s}
@keyframes vu{50%{background:var(--accent)}}
@media (prefers-reduced-motion:reduce){.console__vu i{animation:none}}

/* ---------- SAVOIR-FAIRE ---------- */
.skillset{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.5vw,26px)}
@media (max-width:680px){.skillset{grid-template-columns:1fr}}
.skillgrp{border:1px solid var(--line-strong);background:var(--card);padding:clamp(22px,3vw,34px)}
.skillgrp__k{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--accent);display:block}
.skillgrp__note{font-size:14px;color:var(--ink-soft);margin:7px 0 22px}
.tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:9px}
.tags li{font-family:var(--display);font-size:14.5px;font-weight:500;color:var(--ink);
  border:1px solid var(--line-strong);padding:9px 14px;border-radius:5px;
  transition:border-color .25s var(--ease-out),color .25s var(--ease-out),background .25s var(--ease-out)}
.tags li:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}

.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);
  margin-top:clamp(30px,4vw,48px);padding-top:clamp(28px,3vw,40px);border-top:1px dashed var(--line-strong)}
@media (max-width:680px){.meta-grid{grid-template-columns:1fr;gap:32px}}
.meta-block .skillgrp__k{margin-bottom:14px}
.langs{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.langs li{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--line)}
.langs li:last-child{border-bottom:0}
.langs li b{font-family:var(--display);font-size:17px;font-weight:600}
.langs li em{font-family:var(--mono);font-size:12px;color:var(--ink-soft);font-style:normal;letter-spacing:.04em}

/* ---------- CONTACT ---------- */
.planche--contact{text-align:left}
.contact__title{font-family:var(--display);font-weight:700;font-size:clamp(34px,7vw,82px);line-height:1;letter-spacing:-.03em;margin:0 0 18px}
.contact__sub{font-size:clamp(16px,2vw,20px);color:var(--ink-soft);margin:0 0 36px;max-width:40ch}
.contact__open{display:inline-flex;align-items:center;gap:14px;cursor:pointer;
  font-family:var(--display);font-weight:600;font-size:clamp(17px,2.4vw,22px);color:var(--paper);
  background:var(--ink);border:0;padding:18px 28px;border-radius:7px;
  transition:transform .16s var(--ease-out),background .3s}
.contact__open:hover{background:var(--accent)}
.contact__open:active{transform:scale(.98)}
.contact__open svg{transition:transform .3s var(--ease-out)}
.contact__open:hover svg{transform:translate(3px,-3px)}
.contact__open-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 28%,transparent)}
.contact__open:hover .contact__open-dot{background:var(--paper);box-shadow:0 0 0 4px color-mix(in srgb,var(--paper) 30%,transparent)}
.contact__quick{margin-top:26px;display:flex;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.contact__quick a{border-bottom:1px solid var(--line-strong);padding-bottom:2px;transition:color .25s,border-color .25s}
.contact__quick a:hover{color:var(--accent);border-color:var(--accent)}

/* ---------- FOOTER ---------- */
.foot{position:relative;z-index:2;margin-left:var(--rail-w);border-top:1px solid var(--line-strong);
  padding:clamp(40px,7vh,80px) clamp(20px,5vw,72px) 30px}
@media (max-width:900px){.foot{margin-left:0}}
.foot__giant{font-family:var(--display);font-weight:700;line-height:.86;letter-spacing:-.03em;
  font-size:clamp(48px,15vw,180px);max-width:var(--maxw);margin:0 auto}
.foot__giant span{display:block}
.foot__giant--out{color:transparent;-webkit-text-stroke:1.4px var(--ink-soft)}
.foot__giant sub{font-size:.3em;-webkit-text-stroke:0;color:var(--accent);vertical-align:super}
.foot__bar{max-width:var(--maxw);margin:36px auto 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;color:var(--ink-soft);letter-spacing:.04em;padding-top:20px;border-top:1px solid var(--line)}
.foot__bar a:hover{color:var(--accent)}

/* ---------- Reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-reveal].seen{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .hero__title-row span{transform:none}
}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:20px;
  visibility:hidden;opacity:0;transition:opacity .3s var(--ease-out),visibility .3s}
.modal.open{visibility:visible;opacity:1}
.modal__backdrop{position:absolute;inset:0;background:color-mix(in srgb,var(--ink) 50%,transparent);backdrop-filter:blur(6px)}
.modal__card{position:relative;width:min(94vw,500px);background:var(--card);border:1px solid var(--line-strong);
  border-radius:10px;padding:0 0 26px;box-shadow:0 50px 120px -50px rgba(0,0,0,.6);
  transform:scale(.94);opacity:0;transition:transform .35s var(--ease-out),opacity .35s var(--ease-out);transform-origin:center}
.modal.open .modal__card{transform:scale(1);opacity:1}
.modal__bar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.modal__code{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--accent)}
.modal__x{background:none;border:1px solid var(--line);width:30px;height:30px;border-radius:5px;color:var(--ink);cursor:pointer;
  transition:transform .16s var(--ease-out),border-color .25s,background .25s}
.modal__x:hover{border-color:var(--accent);color:var(--accent)}
.modal__x:active{transform:scale(.92)}
.modal__title{font-family:var(--display);font-size:28px;font-weight:600;margin:22px 24px 6px}
.modal__intro{margin:0 24px 22px;color:var(--ink-soft);font-size:15px}
.modal__list{list-style:none;margin:0;padding:0 24px}
.modal__list li{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.modal__k{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--ink-faint);text-transform:uppercase;min-width:84px}
.modal__v{font-family:var(--display);font-size:15px;font-weight:500;flex:1}
.copyrow{cursor:pointer;transition:padding-left .25s var(--ease-out)}
.copyrow:hover{padding-left:6px}
.copyrow__act{font-family:var(--mono);font-size:10px;color:var(--accent);border:1px solid var(--accent);padding:4px 9px;border-radius:4px;opacity:.65;transition:opacity .25s}
.copyrow:hover .copyrow__act{opacity:1}
.modal__cta{display:flex;gap:10px;margin:24px 24px 0;flex-wrap:wrap}
.modal__cta .btn{flex:1;justify-content:center}
.modal__cv-link{color:var(--accent)!important;border-bottom:1px solid var(--line-strong);
  padding-bottom:1px;transition:border-color .25s}
.modal__cv-link:hover{border-color:var(--accent)}
.modal__cv-btn{display:flex;justify-content:center;margin:10px 24px 22px;font-size:14px}

/* ---------- CV : aperçu intégré + téléchargement ---------- */
.cv{margin-top:54px;border:1px solid var(--line-strong);background:var(--card);
  box-shadow:0 40px 90px -55px rgba(0,0,0,.55)}
.cv__head{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding:15px 18px;border-bottom:1px solid var(--line-strong)}
.cv__k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.cv__acts{display:flex;gap:10px;flex-wrap:wrap}
.cv__acts .btn{font-size:13px;padding:10px 16px}
.cv__frame{display:block;width:100%;height:min(82vh,820px);border:0;background:var(--paper-2)}
.cv__fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  height:100%;min-height:320px;padding:40px;text-align:center;
  font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
@media (max-width:680px){
  .cv__head{flex-direction:column;align-items:stretch}
  .cv__acts{justify-content:stretch}
  .cv__acts .btn{flex:1;justify-content:center}
  .cv__frame{height:72vh}
}

/* toast */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(160%);z-index:130;
  visibility:hidden;
  background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:13px;padding:13px 20px;border-radius:7px;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.5);transition:transform .45s var(--ease-out),visibility .45s}
.toast.show{transform:translateX(-50%) translateY(0);visibility:visible}
