:root{
  --bg:#f7f4ee;         
  --card:#ffffff;        
  --text:#1b1f2a;      
  --muted:#5d667a;
  --ring:#5173c2;
  --accent:#ff43a8;
  --ok:#2fb980;
  --border:rgba(17,20,40,.12);
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --radius:16px; --radius-lg:24px; --maxw:1100px;
  --icon-filter: none;
  --lt-h: 34px; --lt-pad: 4px;
  --lt-bg: color-mix(in oklab, var(--card), black 6%);
  --lt-bd: var(--border);
  --lt-txt: var(--text);
  --lt-fr: #60a5fa;  
  --lt-en: #73e2a7;
}
:root :where(.card,.tile,.modal-dialog,.stud-card,.job,.vol,.study,.pers-slider):not(.btn.primary){
  background:var(--card) !important;
  border-color:var(--border) !important;
}
:root :where(.pill,.badge,.tl-item,.timeline-wrap,.tl-scale,.hover-pop){
  border-color:var(--border) !important;
}
[data-theme="dark"]{
  --bg:#0b0b10;
  --card:#11121a;
  --text:#e6e8ef;
  --muted:#a9afc3;
  --border:rgba(255,255,255,.08);
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --icon-filter: invert(1) brightness(2);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Inter,sans-serif;background:radial-gradient(1000px 600px at 10% -10%, rgba(42,212,255,.07), transparent 60%), radial-gradient(900px 500px at 110% 10%, rgba(255,67,168,.06), transparent 60%), var(--bg); color:var(--text)}
a{color:inherit;text-decoration:none}
#studies-modal .modal-dialog{max-width: 900px;width: clamp(320px, 92vw, 900px);}
.wrap{max-width:var(--maxw);margin-inline:auto;padding:24px}
.stud-grid{display: grid;gap: 16px;grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));}
.stud-logo:empty{display: none;}
.card-base,
.study,
.vol,
.job,
.stud-card {background: var(--card);border: 1px solid var(--border);border-radius: 14px;padding: 14px 16px;}
.stud-logo{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--card);border:1px solid var(--border);overflow:hidden}
.stud-logo img{
    width:100%;
    height:100%;
    object-fit:contain;
    border-radius:12px;
}
.stud-title{font-weight:700;margin:0}
.stud-meta{font-size:12px;color:var(--muted)}
.stud-desc{font-size:13px;color:var(--text);opacity:.95}
.actions .btn.linkedin {display: flex;align-items: center;justify-content: center;padding: 8px 12px;}
.actions .btn.linkedin:hover {color: #0a66c2;}
.tl-scale{position:relative;height:28px;margin-bottom:10px;border-bottom:1px dashed rgba(255,255,255,.12)}
.tl-scale .tick{position:absolute;bottom:-8px;font-size:11px;color:var(--muted);transform:translateX(-50%)}
.tl-grid{position:relative;isolation:isolate}
.tl-row{position:relative;height:44px;margin:8px 0}
.tl-row-label{position:absolute;left:0;top:50%;transform:translateY(-50%);font-size:12px;color:var(--muted)}
.tl-lane{position:relative;margin-left:110px;height:100%}
.tl-item{position:absolute;top:6px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 10px;border:1px solid rgba(255,255,255,.10);cursor:pointer;transition:transform .15s ease, box-shadow .15s ease}
.tl-item .label{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.9;transition:font-size .15s ease, opacity .15s ease}
.tl-item:hover{box-shadow:0 6px 18px rgba(0,0,0,.35);z-index:2}
.tl-item:hover .label{font-size:13px;opacity:1}
.tl-etudes{background:rgba(42,212,255,.18);box-shadow:inset 0 0 0 2px rgba(42,212,255,.45)}
.tl-emploi{background:rgba(255,67,168,.16);box-shadow:inset 0 0 0 2px rgba(255,67,168,.45)}
.tl-stage{background:rgba(154,255,107,.18);box-shadow:inset 0 0 0 2px rgba(154,255,107,.45)}
.tl-asso{background:rgba(255,209,102,.18);box-shadow:inset 0 0 0 2px rgba(255,209,102,.5)}
.tl-tooltip{position:absolute;padding:8px 10px;border-radius:10px;background: var(--card) !important;border: 1px solid var(--border) !important;font-size:12px;color: var(--text) !important;pointer-events:none;transform:translate(-50%,-8px);white-space:nowrap;box-shadow:var(--shadow);display:none;z-index:5}
.tile.click-hint{cursor: pointer;transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;border-color: rgba(255,255,255,.16);animation: tilePulse 2.6s ease-in-out infinite;}
.tile.click-hint:hover{ transform: translateY(-2px); box-shadow: var(--shadow); }
.tile.click-hint:focus-visible{ outline: 2px solid var(--ring); outline-offset: 2px; }
.tile.click-hint .hint {
  position: absolute;
  top: 8px;
  right: 8px;
  font-size: 10px;              
  padding: 2px 6px;            
  border-radius: 999px;
  background: rgba(47,185,128,0.12); 
  color: var(--ok);             
  border: 1px solid var(--ok);
  box-shadow: none;           
  font-weight: 600;
}
@keyframes tilePulse {
  0%   { box-shadow: 0 0 0 0 rgba(107, 185, 71, 0.75) inset; }
  50%  { box-shadow: 0 0 0 4px rgba(107, 185, 71, 0.65) inset; }
  100% { box-shadow: 0 0 0 0 rgba(107, 185, 71, 0.75) inset; }
}

.study h4{margin:0 0 4px 0;font-size:16px}
.study .row{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:13px}

.vol h4{margin:0 0 4px 0;font-size:16px}
.vol .row{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:13px}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.55);z-index:1000;padding: 20px;overflow: auto}
.modal.open{display:flex}
.band .cats{display: grid;gap: 10px;grid-template-columns: 1fr;}
.modal-dialog{max-width:720px;width:clamp(320px,90vw,720px);background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:20px;box-shadow:var(--shadow);padding:18px 18px 20px;  max-height: calc(100vh - 40px);overflow: auto;-webkit-overflow-scrolling: touch}
.modal-close{all:unset;cursor:pointer;font-size:22px;line-height:1;position:absolute;margin-left:-8px;margin-top:-10px;right:20px;top:20px;opacity:.8}
.modal-dialog-gallery {background-color: #000000 !important;}

.job h4{margin:0 0 4px 0;font-size:16px}
.job .row{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:13px}
.jobs-mini{
  display:grid;
  gap:12px;
  grid-template-columns: 1fr;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--card);
  padding:12px;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  cursor: pointer;
}
.job-mini:hover{transform: translateY(-1px);box-shadow: var(--shadow);border-color: rgba(0,0,0,.12);}
@media (min-width: 640px){.proj-media.multi{grid-template-columns: 1fr 1fr;}}
@media (min-width: 720px){ .band .cats{ grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1024px){ .band .cats{ grid-template-columns: repeat(4,1fr); } }
@media (min-width: 720px){.jobs-mini{ grid-template-columns: 1fr 1fr; }}
@media (max-width: 720px){.tl-row{height:40px}.tl-item{height:28px}.tl-lane{margin-left:86px}}
@media (max-width:720px){ .stud-grid{grid-template-columns:1fr} }
@media (max-width: 600px) {.proj-zoom-hint { display: none; }}
@media (max-width: 1000px) {.proj-split-wrapper {flex-direction: column;align-items: center;}.proj-split-wrapper.is-split .proj-panel-right {width: clamp(320px, 90vw, 720px);}.proj-panel-right-inner {width: clamp(320px, 90vw, 720px);}}
@media (pointer: coarse){ .lang-seg .seg{ padding:10px 16px } }
@media (max-width:380px){ .lang-seg .seg{ padding:7px 12px; font-size:12px } }
@media (prefers-reduced-motion: reduce){.lang-toggle, .lang-toggle .knob{ transition:none !important; }}
@media (min-width: 900px){.tl-controls{ display:none; } }
@media (min-width: 560px){.contact-grid{ grid-template-columns: 1fr 1fr; }}
@media (min-width: 900px){.list-compact.cols-2{ columns:2; column-gap:22px; }.list-compact.cols-3{ columns:3; column-gap:22px; }}
@media (max-width: 900px){.pers-card[data-key="dessin"] .pers-gallery{grid-template-columns: repeat(2, 1fr);}}
@media (max-width: 560px){.pers-card[data-key="dessin"] .pers-gallery{grid-template-columns: 1fr;}}
@media (max-width: 900px){.pers-grid{ grid-template-columns: repeat(3, 1fr); }}
@media (max-width: 560px){.pers-grid{ grid-template-columns: repeat(2, 1fr); }}
@media (max-width: 560px){.pers-gallery{ grid-template-columns: 1fr; }}
@media (max-width: 1100px){.tiles{grid-template-columns:repeat(3,1fr)} .hero-grid{grid-template-columns:1fr}}
@media (max-width: 640px){.tiles{grid-template-columns:1fr 1fr}}
@media (max-width:900px){ .view .lab-grid{ grid-template-columns:1fr; } }
.job-mini .avatar{
  width:40px; height:40px; border-radius:10px; display:grid; place-items:center;
  font-weight:800; font-size:12px; opacity:.9;
  background:var(--card); border:1px solid var(--border); overflow:hidden;
}
.job-mini .avatar img{ width:100%; height:100%; object-fit:cover; }
.job-mini .title{ margin:0; font-weight:700; font-size:14px; letter-spacing:.2px; }
.job-mini .meta{ margin:3px 0 0 0; font-size:12px; color:var(--muted); display:flex; flex-wrap:wrap; gap:8px; }
.job-mini .desc{ margin:8px 0 0 0; font-size:13px; color:var(--text); opacity:.95; }
.job-mini .tags{ margin-top:8px; display:flex; flex-wrap:wrap; gap:6px; }
.job-mini .pill{ font-size:11.5px; padding:3px 8px; }
.job-mini:active{transform: translateY(0);}
.badge{display:inline-block;font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.12);margin-left:8px}
.badge.now {
  border: 1px solid var(--ok);
  background: rgba(47,185,128,0.12);
  color: var(--ok);
  font-weight: 600;
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 10px;
  box-shadow: none;
}
.badge.en-cours{border:1px solid var(--ring);box-shadow:0 0 0 3px rgba(42,212,255,.18) inset}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0}
.pers-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.pers-tab{all:unset;cursor:pointer;font-size:13px;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);opacity:.9}
.pers-tab[aria-selected="true"]{border-color: var(--ok);box-shadow: 0 0 0 3px rgba(47,185,128,.25);}
.pers-slider{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:#0f1017}
.pers-track{display:flex;transition:transform .4s ease}
.pers-card{min-width:100%;padding:16px 16px 18px 16px}
.pers-card h4{margin:0 0 6px 0}
.pers-card p{margin:0;color:var(--muted)}
.pers-dots{display:flex;gap:6px;pointer-events:auto;}
.pers-dot[aria-current="true"]{background: var(--ok);border-color: transparent;}
.pers-btn:hover{background:rgba(0,0,0,.5)}
.pers-prev{left:10px}
.pers-next{right:10px}
.proj-card{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.pers-dot{width:8px; height:8px;border-radius:50%;background:rgba(255,255,255,.28);border:1px solid rgba(255,255,255,.35);cursor:pointer;}
.pers-nav{position:absolute;left:0;right:0;bottom:8px;display:flex;justify-content:center;align-items:center;gap:14px;pointer-events:none;}
.pers-btn{
  all:unset;
  cursor:pointer;
  pointer-events:auto;
  width:28px;
  height:28px;
  border-radius:50%;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(0,0,0,.35);
  font-size:16px;
  line-height:1;
}
.proj-card img{
  width: 100%;
  height: auto;
  max-height: 48vh;
  object-fit: contain;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow);
}
header{display:flex;align-items:center;gap:20px;justify-content:space-between}
h1{font-size:20px;margin:0}
.proj-card h4{margin:0}
.proj-card p{margin:0;color:var(--muted)}
.brand{display:flex;align-items:center;gap:14px}
.logo {width: 70px;height: 70px;border-radius: 12px;overflow: hidden;display: grid;place-items: center;background: none;box-shadow: 0 2px 10px rgba(0,0,0,.25);}
.logo img {
    width:100%;
    height:100%;
    object-fit:contain;
}
.view .lab-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; align-items:stretch; }
.view .lab-grid .band{grid-column: 1 / -1;}
.view .stack{ display:flex; flex-direction:column; gap:16px; }
.view .stack .card{ height:100%; }
.tagline{font-size:13px;color:var(--muted)}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.btn {
  padding: 6px 8px;
  border: none;
  background: transparent;
  color: var(--text);
  font-weight: 600;
  opacity: 0.95;
  transition: opacity 0.2s ease, color 0.2s ease;
  box-shadow: none;
}
.btn:hover {
  opacity: 1;
  color: var(--ring);
  border: none;
  background: transparent;
}
.hero{margin-top:24px;background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow)}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px}
.hero h2{margin:0 0 6px 0;font-size:28px;letter-spacing:.2px}
.pill{font-size:13px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);color:var(--muted)}
.switcher{display:flex;gap:8px;flex-wrap:wrap}
.chip{cursor:pointer;font-size:13px;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.10);opacity:.85}
.chip.active {border-color: var(--text);box-shadow: none;opacity: 1;font-weight: 600;}
.tiles{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:18px}
.tile{background:var(--card);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:14px;min-height:120px;position:relative;overflow:hidden}
.tile h3{margin:0;font-size:16px}
.tile p{margin:6px 0 0 0;color:var(--muted);font-size:13px}
.tile .meta{position:absolute;bottom:10px;left:14px;display:flex;gap:8px;flex-wrap:wrap;}
.view{margin-top:22px}
.card{background:var(--card);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
:focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:8px}
.proj-media{display: grid;grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));gap: 12px;width: 100%;}
.proj-media img{
  width: 100%;
  height: 140px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.rot-track{ display:flex; transition: transform .4s ease; will-change: transform; }
.rot-slide{ min-width:100%; }
.rotator .dot{width:8px; height:8px;border-radius:50%;background:rgba(255,255,255,.28);border:1px solid rgba(255,255,255,.35);cursor:pointer;}
.rotator .btn:hover{ background:rgba(0,0,0,.5); }
.rotator .dots{display:flex;gap:6px;pointer-events:auto;}
.rotator  { position:relative; overflow:hidden; border-radius:16px; }
.rotator .dot[aria-current="true"]{background:var(--accent);border-color:transparent;}
.rotator .prev{ left:10px; }
.rotator .next{ right:10px; }
.rotator .nav{position:absolute;left:0; right:0; bottom:6px;display:flex;justify-content:center;align-items:center;gap:14px;pointer-events:none;}
.rotator .btn{
  all:unset;
  cursor:pointer;
  pointer-events:auto;
  width:28px; height:28px;
  border-radius:50%;
  display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(0,0,0,.35);
  font-size:16px; line-height:1;
}
.rot-slide .card{ margin:0; }
.hint-pop {
  cursor: help;
  position: relative;
  display: inline-block;
  color: var(--color-primary);
  font-weight: 600; 
  border-bottom: 2px dashed var(--color-primary); 
  text-decoration: none; 
  transition: all 0.2s ease; 
}
.hint-pop:focus {color: #4a74ce; background-color: var(--color-primary);border-radius: 4px;padding: 0 2px;}
.hover-pop{
  position: fixed;
  z-index: 3000;
  display: none;
  max-width: min(340px, 85vw);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  box-shadow: var(--shadow);
  padding: 10px;
  color: var(--text);
  background:var(--card) !important;
}
.hover-pop .hp-media{width: 100%;height: 140px;border-radius: 10px;object-fit: cover;border: 1px solid rgba(255,255,255,.08);margin-bottom: 8px;}
.hover-pop .hp-title{ margin:0 0 4px 0; font-weight:700; font-size:14px; }
.hover-pop .hp-text{ margin:0; font-size:13px; color: var(--muted); }
.btn.ghost{ background:transparent !important; }
.btn.tiny{ padding:8px 10px; font-size:14px; }
.btn.theme-toggle{ opacity:.75; }
.btn.theme-toggle:hover{ opacity:1; }
.pers-icons{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:14px;
}
.pers-icons img{
  display:block;
  width:auto;
  height:auto;
  max-width:72px;
  max-height:72px;
  object-fit:contain;
  border-radius:14px;
  padding:10px;
  border:1px solid var(--border);
  background:var(--card);
}
.pers-gallery{
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 1fr;
  margin-top: 12px;
}
.pers-gallery img{
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  background: var(--card);
  padding: 6px;
  max-height: 220px;
}
.pers-grid{
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, 1fr);
  margin-top: 10px;
}
.pers-grid img{
  width: 90%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  transition: transform .18s ease, box-shadow .18s ease;
  will-change: transform;
  background: var(--card);
}
.pers-grid img:hover{
  transform: scale(1.06);
  box-shadow: 0 8px 26px rgba(0,0,0,.25);
  z-index: 1;
}
#persona-modal .pers-zoom-overlay{
  cursor: zoom-out;
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.85);
  z-index: 50;
  padding: 20px;
  border-radius: inherit;
}
.pers-zoom-close{
  all:unset; cursor:pointer;
  position:absolute; top:12px; right:12px;
  width:32px; height:32px; border-radius:50%;
  display:grid; place-items:center;
  font-size:20px; line-height:1;
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.25);
}
.pers-zoom-nav{
  all:unset; cursor:pointer;
  position:absolute; top:50%; transform:translateY(-50%);
  width:38px; height:38px; border-radius:50%;
  display:grid; place-items:center;
  font-size:22px; background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.25);
}
.pers-zoom-nav.prev{ left:12px; }
.pers-zoom-nav.next{ right:12px; }
.pers-zoom-hint{
  position:absolute; left:50%; bottom:10px; transform:translateX(-50%);
  font-size:12px; color:#fff; opacity:.8;
  background:rgba(0,0,0,.35); padding:4px 8px; border-radius:10px;
}
#persona-modal .pers-zoom-overlay img{
  max-width: 95%;
  max-height: 90%;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
  object-fit: contain;
  background: var(--card);
}
.pers-trackcard{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--card);
  margin-top:10px;
}
.pers-trackcard .logo{
  width:44px; height:44px;
  border-radius:10px;
  overflow:hidden;
  display:grid; place-items:center;
  background:#0f1017;
  border:1px solid var(--border);
}
.pers-trackcard .logo img{ width:100%; height:100%; object-fit:contain; }
.pers-trackcard .info{ flex:1; min-width:0; }
.pers-trackcard .info h5{ margin:0 0 2px 0; font-size:14px; }
.pers-trackcard .meta{ display:flex; gap:8px; flex-wrap:wrap; color:var(--muted); font-size:12px; }
.pers-trackcard .actions{ display:flex; gap:8px; flex-wrap:wrap; margin-top:6px; }
.pers-trackcard .title-link{font-weight:600; text-decoration:underline;}
.btn.micro{
  padding: 4px 8px;
  font-size: 12px;
  opacity: .9;
  background: transparent;
  border-color: var(--border);
  box-shadow: none;
}
.btn.micro:hover{opacity: 1;text-decoration: underline;}
.pers-card[data-key="dessin"] .pers-gallery{grid-template-columns: repeat(3, 1fr);}
.card{--card-title: 15.5px;--card-sub: 12.5px;--card-text: 13.5px;}
.card .card-head{display:flex; flex-direction:column; gap:2px;margin:0 0 8px 0;}
.card .card-title{margin:0;font-weight:700;letter-spacing:.2px;font-size:var(--card-title);}
.card .card-subtitle{margin:0;color:var(--muted);font-size:var(--card-sub);}
.hr-soft{
  height:1px; width:100%;
  background:linear-gradient(to right, transparent, var(--border), transparent);
  margin:6px 0 8px 0;
  border-radius:999px;
}
.card p{
  margin:6px 0 0 0;
  font-size:var(--card-text);
  line-height:1.55;
  color:var(--text);
  opacity:.95;
}
.list-compact{
  margin:6px 0 0 0;
  padding-left:18px;
  font-size:var(--card-text);
  line-height:1.45;
  color:var(--text);
}
.list-compact li{ margin:4px 0; }
.pill.comp{
  font-size:12.5px;
  padding:5px 9px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.02);
  color:var(--text);
  opacity:.92;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
  margin: 4px 6px 0 0;
  display: inline-block;
  white-space: nowrap;
}
.pill.comp:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(0,0,0,.08);
  background:rgba(255,255,255,.05);
}
.card .logo-row{ margin-top:10px; }
.card .logo-row img{
  max-width:60px; max-height:60px; padding:8px;
  border-radius:12px; border:1px solid var(--border);
  background:var(--card);
}
#proj-zoom-overlay{
  cursor: zoom-out;
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.85);
  z-index: 2000;
  padding: 20px;
}
#proj-zoom-overlay img{
  max-width: 95%;
  max-height: 90%;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
  object-fit: contain;
  background: var(--card);
}
#proj-zoom-overlay .close{
  all:unset; cursor:pointer;
  position:absolute; top:12px; right:12px;
  width:32px; height:32px; border-radius:50%;
  display:grid; place-items:center;
  font-size:20px; line-height:1;
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.25);
}
#proj-modal .proj-card{align-items: flex-start !important;text-align: left !important;max-width: 780px;margin-inline: auto;gap: 10px;}
#proj-modal .proj-card h4{margin: 4px 0 2px 0;letter-spacing: .2px;}
#proj-modal .proj-card em{color: var(--muted);font-style: italic;}
#proj-modal .proj-card p{margin: 6px 0 0 0;line-height: 1.55;color: var(--text);opacity: .95;}
#proj-modal .proj-card ul{margin: 8px 0 0 18px;padding-left: 18px;list-style: disc outside;}
#proj-modal .proj-card li{ margin: 6px 0; line-height: 1.5; }
#proj-modal .proj-media{gap: 12px !important;margin-bottom: 6px;}
#proj-modal .proj-media img{border-radius: 12px;border: 1px solid var(--border);box-shadow: var(--shadow);}
#proj-modal .list-compact li:hover::after {opacity: 1;right: 4px;}
#proj-modal .list-compact li:hover {background: rgba(255, 255, 255, 0.05);color: var(--ring);transform: translateX(4px);}
#proj-modal .list-compact li {cursor: pointer;padding: 6px 10px;margin: 4px -10px;border-radius: 8px;transition: all 0.2s ease;position: relative;}
#proj-modal .list-compact li::after {content: '›';position: absolute;right: 10px;opacity: 0;color: var(--ring);transition: all 0.2s ease;font-weight: bold;font-size: 18px;top: 50%;transform: translateY(-50%);}
#proj-modal {padding: 20px;overflow-x: hidden;}
#contact-modal .modal-dialog{max-width: 640px;width: clamp(320px, 92vw, 640px);font-size: 14px;line-height: 1.45; }
.contact-grid{
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
  margin-top: 6px;
}
.contact-item{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--card);
}
.contact-item .icon{
  width: 36px; height: 36px;
  border-radius: 10px;
  display: grid; place-items: center;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent);
  font-size: 18px;
}
.contact-item .label{
  margin: 0; font-size: 12px; color: var(--muted);
}
.contact-item .value{
  margin: 0; font-weight: 600; letter-spacing: .2px;
}
.contact-item .btn.micro{ margin-left: auto; }
.contact-actions{display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px;}
.timeline-wrap.dragging{ cursor: grabbing;}
.timeline-wrap{position:relative;background:linear-gradient(180deg, rgba(255,255,255,.02), transparent);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;box-shadow:var(--shadow);overflow: auto; -webkit-overflow-scrolling: touch;cursor: grab}
.tl-zoom{transform-origin: left top;transition: transform .12s ease;min-width: 900px;}
.tl-controls{display:flex; gap:8px; align-items:center;margin: 0 0 8px 0;}
.tl-controls .btn.micro{ padding: 4px 8px; font-size: 12px; }
.tl-controls .pill{ font-size: 11.5px; padding: 3px 8px; }
.lang-toggle{
  display:inline-grid; grid-template-columns:1fr auto 1fr; gap:8px;
  align-items:center; height:var(--lt-h); padding:0 var(--lt-pad);
  border-radius:999px; border:1px solid var(--lt-bd); background:var(--lt-bg);
  color:var(--lt-txt); cursor:pointer; position:relative;
  box-shadow: 0 6px 18px rgba(0,0,0,.15) inset, var(--shadow);
  transition:transform .15s ease, box-shadow .2s ease, background .2s;
}
.lang-toggle:active{ transform: translateY(1px) scale(.99); }
.lang-toggle:focus-visible{ outline:2px solid var(--ring); outline-offset:2px; }
.lang-toggle .option{ font:600 12px/1 ui-sans-serif,system-ui; opacity:.8; letter-spacing:.02em; user-select:none; }
.lang-toggle .knob{
  width:calc(var(--lt-h) - 2*var(--lt-pad));
  height:calc(var(--lt-h) - 2*var(--lt-pad));
  border-radius:50%;
  background: linear-gradient(180deg, #1b222c, #0b0f14);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 6px 16px rgba(0,0,0,.35);
  transition:transform .25s cubic-bezier(.2,.8,.2,1), background .25s, border-color .25s;
  will-change: transform;
}
.lang-toggle[data-lang="fr"] .knob{
  transform: translateX(0);
  background: radial-gradient(120% 120% at 10% 10%, rgba(96,165,250,.35), transparent 40%), linear-gradient(180deg, #1b222c, #0b0f14);
  border-color: color-mix(in oklab, var(--lt-fr), black 60%);
}
.lang-toggle[data-lang="en"] .knob{
  transform: translateX(calc(100% + 8px));
  background: radial-gradient(120% 120% at 90% 10%, rgba(115,226,167,.35), transparent 40%), linear-gradient(180deg, #1b222c, #0b0f14);
  border-color: color-mix(in oklab, var(--lt-en), black 60%);
}
.lang-toggle[data-lang="fr"] .option-fr{ opacity:1; filter: drop-shadow(0 0 6px rgba(96,165,250,.35)); }
.lang-toggle[data-lang="en"] .option-en{ opacity:1; filter: drop-shadow(0 0 6px rgba(115,226,167,.35)); }
.lang-seg {
  display: inline-flex; 
  gap: 4px; 
  padding: 0; 
  border: none; 
  background: transparent;
  box-shadow: none;
}
.lang-seg .seg {
  appearance: none; border: 0; background: transparent; cursor: pointer;
  padding: 4px 6px; 
  font: 600 13px/1 ui-sans-serif, system-ui;
  color: var(--text); 
  opacity: 0.5;
  transition: opacity 0.2s ease;
}
.lang-seg .seg:hover {
  opacity: 0.8;
}
.lang-seg .seg.is-active {
  opacity: 1; 
  background: transparent;
  box-shadow: none;
  border-bottom: 2px solid var(--text);
  border-radius: 0;
}
.lang-seg:focus-within{ outline:2px solid var(--ring, #9bdbff); outline-offset:3px; border-color:transparent; }
.persona-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:14px;
margin-top:12px;
}
.persona-card{
background:var(--card);
border:1px solid var(--border);
border-radius:16px;
padding:18px;
cursor:pointer;
text-align:center;
transition:all .2s ease;
}
.persona-card:hover{
transform:translateY(-4px);
box-shadow:var(--shadow);
}
.persona-icon{
font-size:28px;
margin-bottom:6px;
}
.persona-detail-card{
margin-top:20px;
padding:16px;
border-radius:16px;
border:1px solid var(--border);
background:var(--card);
}
.persona-gallery{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
gap:10px;
margin-top:12px;
}
.persona-gallery img{
width:100%;
border-radius:10px;
}
.basket-easter-egg {
  position: relative;
  display: inline-block;
  margin: 0 0 14px 0;
  color: var(--muted);
  cursor: pointer;
}
.basket-easter-egg .reveal-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0;
  overflow: hidden;
  background: var(--card);
  transition: width 1.5s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
}
.basket-easter-egg .reveal-text {color: #007A33; font-weight: 700;}
.basket-easter-egg:hover .reveal-wrapper {width: 100%;}
.basket-easter-egg:hover .ball {opacity: 1;left: 100%;transform: rotate(1080deg);}
.basket-easter-egg .ball {
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -12px;
  font-size: 20px;
  opacity: 0;
  pointer-events: none;
  z-index: 2;
  transition: left 1.5s cubic-bezier(0.4, 0, 0.2, 1), transform 1.5s linear, opacity 0.3s ease;
}
.persona-card.tribune-glow {
  box-shadow: 0 0 25px 8px rgba(0, 122, 51, 0.8), inset 0 0 15px rgba(0, 122, 51, 0.4) !important;
  border-color: #007A33 !important;
  transform: scale(1.05) translateY(-4px);
  transition: all 0.2s ease-in-out;
  z-index: 10;
}
.csp-image-container {display: none;width: 100%;text-align: center;}
.csp-card-image {max-width: 80%;height: auto;margin-top: 10px;}
.csp-image-container.visible {display: block !important;}
.csp-logo {height: 1.2em;vertical-align: middle;margin-left: 6px;display: inline-block;}
.csp-text-container {display: none;width: 100%;text-align: center;font-size: 14px;line-height: 1.5;}
.csp-text-container.visible {display: block !important;}
.csp-socios-logo {height: 60px;margin-bottom: 15px; object-fit: contain; }
.csp-socios-text {font-size: 14px;line-height: 1.5;font-weight: 500;}
.original-content.hidden,
.persona-icon.hidden,
.persona-card h4.hidden,
#gallery-trigger.hidden {display: none !important;}
#persona-modal.beublanc-backdrop {
  background-image: 
    linear-gradient(rgba(4, 25, 12, 0.88), rgba(4, 25, 12, 0.88)),
    url('Logo_CSP.png'), 
    url('Logo_CSP.png') !important;
  background-color: #020c06 !important; 
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: center, 10% center, 90% center !important;
  background-size: 100%, 25vw, 25vw !important; 
}
#bbl-stadium-logo {
  display: block;
  height: 85px;
  margin: 0 auto 16px auto;
  object-fit: contain;
}
.persona-card.csp-card-green {
  background-color: #007A33 !important;
  border-color: #007A33 !important;
  display: flex;
  align-items: center;
  justify-content: center;
}
.persona-card.csp-card-green .csp-text-container {
  color: #ffffff !important;
  font-weight: 500;
}
.csp-socios-container {
  display: none;
  width: 100%;
  text-align: center;
  padding: 10px;
  color: #ffffff !important;
}
.csp-socios-container.visible {
  display: flex !important;
  flex-direction: column; 
  align-items: center; 
  justify-content: center;
}
#gallery-content {
  display: flex;
  height: 100%;
  position: relative;
  overflow: hidden;
  justify-content: center;
  align-items: center;
  gap: 40px; 
  padding: 40px; 
}
#drawing-viewer {
  flex: 0 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  max-width: 60%;
  height: 100%;
}
#gallery-drawing {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  box-shadow: 0 0 10px 2px rgba(255, 255, 255, 0.05);
}
#drawing-info {
  flex: 0 0 auto;
  width: 350px; 
  max-height: 80%; 
  background-color: transparent; 
  color: #eeeeee;
  overflow-y: auto;
  border-left: none; 
}
#drawing-title {
  font-size: 1.8em;
  font-weight: 700;
  margin-bottom: 0.6em;
  color: #ffffff;
}
#drawing-description {
  font-size: 15px;
  line-height: 1.6;
}
#gallery-quit-btn {
  background-color: transparent;
  color: #ffffff;
  border: 1px solid #ffffff;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 10;
  font-weight: 500;
  transition: background-color 0.2s;
}
#gallery-quit-btn:hover {background-color: rgba(255, 255, 255, 0.1);}
#gallery-list {
  flex: 0 0 250px;
  background-color: #080808; 
  border-right: 1px solid #222222;
  padding: 60px 20px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow-y: auto;
}
.gallery-item {
  color: #aaaaaa;
  font-size: 15px;
  padding: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}
.gallery-item:hover {
  background-color: rgba(255, 255, 255, 0.05);
  color: #ffffff;
}
.gallery-item.active {
  color: #ffffff;
  font-weight: 600;
  background-color: rgba(255, 255, 255, 0.08);
}
.gallery-item.active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 12px;
  right: 12px;
  height: 2px;
  background-color: #ffffff;
}
#drawing-viewer {max-width: 55%;}
#gallery-quit-btn {
  position: static; 
  margin-bottom: 30px; 
  width: 100%; 
  border-color: #444444; 
  color: #aaaaaa;
}
#gallery-quit-btn:hover {
  border-color: #ffffff;
  color: #ffffff;
  background-color: transparent;
}
.proj-slider-container {overflow: hidden;position: relative;width: 100%;}
.proj-slider-track {display: flex;width: 200%; transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1); }
.proj-pane {width: 50%;flex-shrink: 0;}
.proj-pane.main-pane {padding-right: 15px;}
.proj-pane.detail-pane {padding-left: 15px;}
.proj-split-wrapper {
  display: flex;
  flex-direction: row;
  gap: 0;
  justify-content: center;
  align-items: flex-start;
  transition: gap 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  width: 100%;
}
.proj-panel-left {
  max-width: 720px;
  width: clamp(320px, 90vw, 720px);
  background: var(--card);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 20px;
  box-shadow: var(--shadow);
  padding: 18px 18px 20px;
  position: relative;
  flex-shrink: 0;
  transition: transform 0.4s ease;
}
.proj-panel-right {
  max-height: calc(100vh - 40px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.proj-panel-right-inner {
  width: clamp(320px, 40vw, 500px);
  padding: 18px 18px 20px;
  box-sizing: border-box;
  position: relative;
  overflow-y: auto; 
  height: 100%;
}
.proj-panel-right-inner::-webkit-scrollbar {width: 6px;}
.proj-panel-right-inner::-webkit-scrollbar-thumb {background: var(--border);border-radius: 10px;}
.proj-split-wrapper.is-split .proj-panel-right {width: clamp(320px, 40vw, 500px);opacity: 1;border-color: rgba(255, 255, 255, 0.08);}
.proj-panel-right {
  will-change: width, opacity;
  width: 0;
  opacity: 0;
  overflow: hidden;
  background: var(--card);
  border: 1px solid transparent;
  border-radius: 20px;
  box-shadow: var(--shadow);
  transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  flex-shrink: 0;
}
.proj-split-wrapper.is-split {gap: 20px;}
.detail-carousel {
  position: relative;
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  margin: 12px 0;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  background: var(--card);
}
.detail-carousel-track {
  display: flex;
  transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  will-change: transform;
}
.detail-carousel-slide {
  min-width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.detail-carousel-slide img {
  width: 100%;
  height: auto;
  max-height: 250px;
  object-fit: contain;
  display: block;
}
.detail-carousel-nav {
  position: absolute;
  top: 50%;
  width: 100%;
  display: flex;
  justify-content: space-between;
  transform: translateY(-50%);
  pointer-events: none;
  padding: 0 8px;
  box-sizing: border-box;
}
.detail-carousel-btn {
  pointer-events: auto;
  background: rgba(0, 0, 0, 0.5);
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  transition: background 0.2s;
}
.detail-carousel-btn:hover {
  background: rgba(0, 0, 0, 0.8);
}
.detail-carousel-dots {
  position: absolute;
  bottom: 8px;
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 6px;
}
.detail-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  cursor: pointer;
  border: none;
  padding: 0;
  transition: background 0.2s;
}
.detail-dot.active {
  background: var(--ring); 
}
.proj-zoom-container {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 95%;
  max-height: 95vh;
}
#proj-zoom-overlay img {
  max-width: 100%;
  max-height: 75vh;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
  object-fit: contain;
  background: var(--card);
}
.proj-zoom-text {
  margin-top: 16px;
  background: var(--card);
  color: var(--text);
  padding: 14px 24px;
  border-radius: 12px;
  border: 1px solid var(--border);
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
  max-width: 800px;
  text-align: center;
  font-size: 14px;
  line-height: 1.5;
  display: none;
}
.proj-zoom-nav {
  all: unset; 
  cursor: pointer;
  position: absolute; 
  top: 50%; 
  transform: translateY(-50%);
  width: 44px; 
  height: 44px; 
  border-radius: 50%;
  display: grid; 
  place-items: center;
  font-size: 28px; 
  background: rgba(0, 0, 0, 0.5); 
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.2);
  z-index: 2001;
  transition: background 0.2s;
}
.proj-zoom-nav:hover {
  background: rgba(0, 0, 0, 0.9);
}
.proj-zoom-nav.prev { left: 20px; }
.proj-zoom-nav.next { right: 20px; }
.proj-zoom-hint {
  position: absolute; 
  left: 50%; 
  bottom: 15px; 
  transform: translateX(-50%);
  font-size: 13px; 
  color: #fff; 
  opacity: 0.7;
  background: rgba(0, 0, 0, 0.5); 
  padding: 6px 14px; 
  border-radius: 12px;
  z-index: 2001;
  pointer-events: none;
}