:root{
  color-scheme: dark;
  --bg0:#070b12;
  --bg1:#0b1220;
  --topbar-h: 72px;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.08);
  --stroke: rgba(255,255,255,.12);
  --text:#eaf1ff;
  --muted: rgba(234,241,255,.72);
  --muted2: rgba(234,241,255,.58);
  --accent:#22c55e;
  --accent2:#34d399;
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --radius: 18px;
  --radius2: 26px;
  --max: 1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-padding-top: calc(var(--topbar-h) + 18px)}
body{
  margin:0;
  font-family: "Space Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  background: radial-gradient(1000px 500px at 20% 0%, rgba(34,197,94,.18), transparent 60%),
              radial-gradient(900px 500px at 85% 15%, rgba(16,185,129,.12), transparent 55%),
              linear-gradient(180deg, var(--bg0), var(--bg1) 70%);
  color:var(--text);
  line-height:1.5;
  overflow-x:hidden;
}

body::before{
  content:"";
  position:fixed;
  inset:-60px;
  background-image:url("./assets/img/design-ref.png");
  background-size:cover;
  background-position:center;
  opacity:.14;
  filter: blur(26px) saturate(1.2);
  transform: scale(1.05);
  pointer-events:none;
  z-index:-2;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  background: radial-gradient(1200px 700px at 70% 40%, rgba(0,0,0,.0), rgba(0,0,0,.55) 65%),
              linear-gradient(180deg, rgba(7,11,18,.80), rgba(11,18,32,.92));
  pointer-events:none;
  z-index:-1;
}

a{color:inherit}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace}

.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

.skip-link{
  position:absolute;
  left:12px;
  top:12px;
  padding:10px 12px;
  background: rgba(0,0,0,.8);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  transform: translateY(-140%);
  transition: transform .2s ease;
  z-index:1000;
}
.skip-link:focus{transform: translateY(0)}

.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.section{padding:84px 0}

.topbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:50;
  backdrop-filter: blur(16px);
  background: rgba(7,11,18,.55);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 20px;
  min-height: var(--topbar-h);
  max-width:var(--max);
  margin:0 auto;
}

main{padding-top: var(--topbar-h)}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  white-space:nowrap;
  min-width: 210px;
}
.brandMark{
  color:var(--accent);
  font-weight:700;
  letter-spacing:.5px;
}
.brandName{font-weight:650}
.brandName,
.heroTitle,
.sectionHeader h2,
.card h3,
.panel h3{
  font-family: "Syne", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

.navToggle{
  display:none;
  background:transparent;
  border:1px solid var(--stroke);
  border-radius:12px;
  padding:10px 12px;
  color:var(--text);
}
.navToggleBars{
  display:block;
  width:18px;
  height:2px;
  background:currentColor;
  position:relative;
}
.navToggleBars::before,.navToggleBars::after{
  content:"";
  position:absolute;
  left:0;
  width:18px;height:2px;
  background:currentColor;
}
.navToggleBars::before{top:-6px}
.navToggleBars::after{top:6px}

.navLinks{
  display:flex;
  align-items:center;
  gap:18px;
  flex:1;
  justify-content:center;
}
.navLink{
  text-decoration:none;
  color:var(--muted);
  font-weight:540;
  font-size:14px;
  padding:10px 10px;
  border-radius:12px;
  transition: background .2s ease, color .2s ease;
}
.navLink:hover{background: rgba(255,255,255,.06); color:var(--text)}
.navLink.is-active{color:var(--text); background: rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.25)}

.navCtas{display:flex; align-items:center; gap:10px}
.iconBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;height:38px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.04);
  text-decoration:none;
  transition: transform .15s ease, background .2s ease, border-color .2s ease;
}
.iconBtn svg{width:18px;height:18px;opacity:.92}
.iconBtn:hover{transform: translateY(-1px); background: rgba(255,255,255,.06); border-color: rgba(34,197,94,.25)}

.pillBtn{
  text-decoration:none;
  border-radius: 999px;
  padding: 10px 14px;
  border: 1px solid rgba(34,197,94,.28);
  background: linear-gradient(180deg, rgba(34,197,94,.18), rgba(34,197,94,.10));
  color: var(--text);
  font-weight: 620;
  font-size: 14px;
  box-shadow: 0 10px 28px rgba(34,197,94,.12);
}
.pillBtn:hover{filter: brightness(1.08)}

.hero{padding-top: 30px}
.heroGrid{
  display:grid;
  grid-template-columns: 1.25fr .9fr;
  gap: 28px;
  align-items: stretch;
}
.heroCopy{
  padding: 26px 24px;
  border-radius: var(--radius2);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.kicker{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:14px}
.dot{width:10px;height:10px;border-radius:50%;background: radial-gradient(circle at 30% 30%, var(--accent2), var(--accent)); box-shadow: 0 0 0 6px rgba(34,197,94,.12)}
.heroTitle{
  margin: 14px 0 10px;
  font-size: clamp(34px, 4vw, 54px);
  line-height:1.05;
  letter-spacing: -0.02em;
}
.accent{color:var(--accent)}
.muted{color:var(--muted)}
.heroSubtitle{margin:0; color:var(--muted); font-size:12px !important; max-width: 62ch}

.heroActions{display:flex; gap:12px; flex-wrap:wrap; margin-top: 18px}
.primaryBtn,.ghostBtn,.textBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 640;
  font-size: 14px;
  border: 1px solid transparent;
}
.primaryBtn{
  background: linear-gradient(180deg, rgba(34,197,94,.95), rgba(34,197,94,.72));
  color: #051009;
  box-shadow: 0 14px 40px rgba(34,197,94,.22);
}
.primaryBtn:hover{filter: brightness(1.06)}
.ghostBtn{
  background: rgba(255,255,255,.04);
  border-color: var(--stroke);
  color: var(--text);
}
.ghostBtn:hover{border-color: rgba(34,197,94,.25); background: rgba(255,255,255,.06)}
.textBtn{
  background: transparent;
  color: var(--muted);
  padding-left: 6px;
  padding-right: 6px;
}
.textBtn:hover{color: var(--text)}

.heroBadges{
  margin: 18px 0 0;
  padding: 0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.badge{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.035);
  color: var(--muted);
  font-size: 13px;
}

.heroCard{
  border-radius: var(--radius2);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  padding: 18px;
  position: relative;
  overflow:hidden;
}
.portraitWrap{position:relative; border-radius: 22px; background: rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); overflow:hidden}
.portrait{
  width:100%;
  height:auto;
  display:block;
  transform: translateY(12px);
  filter: saturate(1.05) contrast(1.02);
}
.glow{
  position:absolute;
  inset:-60px -60px auto -60px;
  height: 260px;
  background: radial-gradient(circle at 30% 40%, rgba(34,197,94,.55), transparent 60%);
  filter: blur(24px);
  opacity:.55;
  pointer-events:none;
}

.orbits{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.bubble{
  position:absolute;
  width: 64px;
  height: 64px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: radial-gradient(circle at 30% 25%, rgba(255,255,255,.10), rgba(255,255,255,.04));
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 46px rgba(0,0,0,.35);
  display:grid;
  place-items:center;
  transform: translate3d(0,0,0);
  animation: floaty 6.5s ease-in-out infinite;
}
.bImg{
  width: 30px;
  height: 30px;
  display:block;
  object-fit: contain;
  filter: grayscale(1) brightness(0) invert(1) contrast(1.05) drop-shadow(0 12px 22px rgba(0,0,0,.25));
}
.bubble::after{
  content:"";
  position:absolute;
  inset:-14px;
  border-radius: 999px;
  background: radial-gradient(circle at 50% 45%, rgba(34,197,94,.18), transparent 60%);
  filter: blur(10px);
  opacity:.45;
  z-index:-1;
}
/* Bulles groupées à gauche du portrait */
.b6{left: 14%; top: 4%; width: 58px; height: 58px; animation-delay: -1.8s}
.b1{left: 6%; top: 18%; width: 64px; height: 64px; animation-delay: -1.1s}
.b2{left: 28%; top: 30%; width: 72px; height: 72px; animation-delay: -2.6s}
.b3{left: 10%; top: 56%; width: 62px; height: 62px; animation-delay: -3.4s}
.b4{left: 34%; top: 64%; width: 76px; height: 76px; animation-delay: -0.3s}
.b5{left: 18%; bottom: 6%; width: 66px; height: 66px; animation-delay: -4.2s}
.b6{left: 22%; top: 6%; width: 58px; height: 58px; animation-delay: -1.8s}

@keyframes floaty{
  0%,100%{transform: translate3d(0,0,0)}
  50%{transform: translate3d(0,-8px,0)}
}

@media (max-width: 980px){
  .bubble{width: 54px; height: 54px}
  .b6{left: 18%}
  .b1{left: 6%}
  .b2{left: 22%; width: 60px; height: 60px}
  .b3{left: 8%}
  .b4{left: 26%; width: 62px; height: 62px}
  .b5{left: 14%}
}
.stats{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
}
.stat{
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
}
.statValue{font-weight:760; letter-spacing:-.02em}
.statLabel{color:var(--muted2); font-size: 13px; margin-top: 2px}

.sectionHeader{margin-bottom: 18px}
.sectionHeader h2{margin:0; font-size: 26px; letter-spacing:-.01em}
.sectionHeader p{margin:10px 0 0; color: var(--muted); max-width: 70ch}

.cardsGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.projectsSection{position:relative}

/* Carousel */
.carousel{
  position:relative;
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.carViewport{
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling: touch;
}
.carViewport::-webkit-scrollbar{height:10px}
.carViewport::-webkit-scrollbar-thumb{background: rgba(255,255,255,.10); border-radius: 999px}
.carViewport::-webkit-scrollbar-track{background: rgba(255,255,255,.04)}
.carTrack{
  display:flex;
  gap: 14px;
  padding: 16px;
  align-items:stretch;
}
.slide{
  scroll-snap-align: start;
  flex: 0 0 min(380px, 86vw);
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.10);
  overflow:hidden;
  cursor:pointer;
  color: inherit;
  padding:0;
  text-align:left;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.slide.is-featured{flex-basis: min(520px, 92vw)}
.slide:hover{transform: translateY(-2px); border-color: rgba(34,197,94,.22)}
.slideMedia{
  position:relative;
  height: 220px;
  background: rgba(0,0,0,.10);
  isolation:isolate;
}
.slideMedia::before{
  content:"";
  position:absolute;
  inset:-30px;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  filter: blur(18px) saturate(1.05);
  opacity: .55;
  z-index:0;
}
.slideMedia::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.55));
  z-index:1;
}
.slideMedia img{
  position:relative;
  z-index:2;
  width:100%;
  height:100%;
  object-fit: contain;
  display:block;
  padding: 10px;
  image-rendering: auto;
}
.slideBody{padding: 14px 14px 16px}
.slideTop{display:flex; justify-content:space-between; gap:10px; align-items:baseline; flex-wrap:wrap}
.slideName{margin:0; font-size: 16px; letter-spacing:-.01em; font-family:"Syne", ui-sans-serif, system-ui}
.slideYear{color: var(--muted2); font-size: 12px}
.slideCompany{margin-top: 6px; color: var(--muted2); font-size: 12px}
.slideDesc{margin: 10px 0 0; color: var(--muted); font-size: 13px}
.slideStacks{margin-top: 12px; display:flex; flex-wrap:wrap; gap:8px}

.carBtn{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(7,11,18,.60);
  color: var(--text);
  font-size: 26px;
  line-height: 1;
  cursor:pointer;
  z-index:5;
  backdrop-filter: blur(10px);
}
.carBtn.prev{left: 10px}
.carBtn.next{right: 10px}
.carBtn:hover{border-color: rgba(34,197,94,.22)}

.carDots{
  margin-top: 10px;
  display:flex;
  gap: 8px;
  flex-wrap:wrap;
  justify-content:center;
}
.dotBtn{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  cursor:pointer;
  padding:0;
}
.dotBtn.is-active{
  background: rgba(34,197,94,.85);
  border-color: rgba(34,197,94,.35);
  box-shadow: 0 10px 22px rgba(34,197,94,.18);
}

/* Modal */
.modal{position:fixed; inset:0; z-index:200; display:block}
.modal[hidden]{display:none}
.modalBackdrop{position:absolute; inset:0; background: rgba(0,0,0,.62); backdrop-filter: blur(6px)}
.modalDialog{
  position:relative;
  max-width: 980px;
  margin: 7vh auto;
  padding: 0;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(7,11,18,.88);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.modalClose{
  position:absolute;
  right: 14px;
  top: 14px;
  width: 38px;
  height: 38px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-size: 22px;
  cursor:pointer;
}
.modalBody{display:grid; grid-template-columns: 1.1fr .9fr}
.modalMedia{background: rgba(0,0,0,.18)}
.modalMedia img{width:100%; height:100%; object-fit: contain; display:block; min-height: 420px; background: rgba(0,0,0,.22)}
.modalContent{padding: 18px 18px 20px}
.modalKicker{color: var(--muted2); font-size: 13px}
.modalTitle{margin:6px 0 0; font-size: 22px; letter-spacing:-.02em; font-family:"Syne", ui-sans-serif, system-ui}
.modalTop{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  flex-wrap:wrap;
  padding-right: 56px; /* réserve l'espace du bouton fermer */
}
.modalLinks{display:flex; gap:10px; flex-wrap:wrap}
.modalDesc{margin: 12px 0 0; color: var(--muted); font-size: 14px}
.modalStacks{margin-top: 14px; display:flex; flex-wrap:wrap; gap:8px}
.linkBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border-radius: 14px;
  padding: 10px 12px;
  font-weight: 680;
  font-size: 13px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
}
.linkBtn.primary{
  border-color: rgba(34,197,94,.22);
  background: linear-gradient(180deg, rgba(34,197,94,.18), rgba(34,197,94,.10));
}

.card{
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  padding: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
}
.cardAlt{background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02))}
.card h3{margin:0 0 8px; font-size: 18px}
.card p{margin:0 0 12px; color: var(--muted)}
.miniList{margin:0; padding-left: 18px; color: var(--muted)}
.cardLink{
  display:inline-flex;
  margin-top: 12px;
  color: var(--accent2);
  text-decoration:none;
  font-weight: 650;
}
.cardLink:hover{text-decoration:underline}
.tags{display:flex; flex-wrap:wrap; gap:8px}
.tag{
  font-size: 12px;
  color: var(--muted);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding: 6px 10px;
  border-radius: 999px;
}

.aboutGrid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
}
.panel{
  border-radius: var(--radius);
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.10);
  padding: 18px;
  box-shadow: 0 16px 54px rgba(0,0,0,.22);
}
.panel h3{margin:0 0 12px}

.skills{display:grid; gap:10px}
.skill{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
  padding: 12px;
}
.skillTop{display:flex; justify-content:space-between; gap:10px; align-items:baseline}
.skillName{font-weight:700}
.skillVal{color:var(--muted2); font-size: 13px}
.bar{
  margin-top: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow:hidden;
}
.bar > i{
  display:block;
  height:100%;
  width: 0%;
  background: linear-gradient(90deg, rgba(34,197,94,.75), rgba(52,211,153,.95));
  border-radius: 999px;
  box-shadow: 0 10px 22px rgba(34,197,94,.18);
}

.timeline{display:grid; gap:10px}
.item{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
  padding: 12px;
}
.itemTop{display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap}
.itemTitle{font-weight:740}
.itemMeta{color:var(--muted2); font-size: 13px}
.itemSub{color:var(--muted); margin-top: 6px; font-size: 14px}

.langs{display:grid; gap:10px}
.langRow{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
  padding: 12px;
}
.langTop{display:flex; justify-content:space-between; gap:10px; align-items:baseline}
.langName{font-weight:700}
.langVal{color:var(--muted2); font-size: 13px}
.langBar{
  margin-top: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow:hidden;
}
.langBar > i{
  display:block;
  height:100%;
  width: 0%;
  background: linear-gradient(90deg, rgba(34,197,94,.65), rgba(52,211,153,.90));
  border-radius: 999px;
}

.chips{display:flex; flex-wrap:wrap; gap:10px}
.chip{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.035);
  color: var(--muted);
  font-size: 13px;
}

.notice{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
  padding: 12px;
  color: var(--muted);
  font-size: 13px;
}
.notice strong{color: var(--text)}
.notice code{color: var(--text)}

.contactGrid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 16px;
}
.contactCard h3{margin:0 0 8px}
.contactActions{display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px}
.mutedSmall{color: var(--muted2); font-size: 13px}

.footer{
  padding: 26px 0 42px;
  border-top: 1px solid rgba(255,255,255,.06);
  background: rgba(0,0,0,.10);
}
.footerInner{display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap}

@media (max-width: 980px){
  .navLinks{justify-content:flex-start}
  .heroGrid{grid-template-columns: 1fr}
  .cardsGrid{grid-template-columns: 1fr}
  .carTrack{padding: 12px}
  .modalBody{grid-template-columns: 1fr}
  .modalDialog{margin: 6vh 12px}
  .modalMedia img{min-height: 240px}
  .aboutGrid{grid-template-columns: 1fr}
  .contactGrid{grid-template-columns: 1fr}
  .stats{grid-template-columns: 1fr 1fr 1fr}
}

@media (max-width: 780px){
  .brand{min-width:auto}
  .navToggle{display:inline-flex}
  .navLinks{
    position:absolute;
    left: 14px;
    right: 14px;
    top: calc(var(--topbar-h) - 8px);
    flex-direction:column;
    align-items:stretch;
    gap: 6px;
    padding: 10px;
    border-radius: 18px;
    background: rgba(7,11,18,.92);
    border:1px solid rgba(255,255,255,.10);
    box-shadow: var(--shadow);
    display:none;
  }
  .navLinks.is-open{display:flex}
  .navLink{padding:12px 12px}
  .nav{position:relative}
  .navCtas{margin-left:auto}
}

@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important; transition:none !important; animation:none !important}
}

