:root {
  --noir:     #09090f; --card:     #13131e; --bord:     #1e1e2e;
  --or:       #c9a84c; --or-c:     #e2c97e; --or-s:     #7a6128;
  --blanc:    #f4efe4; --gris:     #9e9a90; --gris-c:   #d4cfc4;
  --bleu:     #3a6ea8; --bleu-c:   #5b8fc9;
  --ft:'Playfair Display',Georgia,serif;
  --fe:'Cormorant Garamond',Georgia,serif;
  --fc:'Inter',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--noir);color:var(--blanc);font-family:var(--fc);font-weight:300;line-height:1.7;overflow-x:hidden}
::selection{background:var(--or-s);color:var(--blanc)}
a{color:var(--or);text-decoration:none;transition:color .3s}
a:hover{color:var(--or-c)}
img{max-width:100%;display:block;height:auto}

/* NAV */
nav#nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.85rem 3rem;display:flex;align-items:center;justify-content:space-between;background:rgba(9,9,15,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,168,76,.18);box-shadow:0 2px 24px rgba(0,0,0,.5);transition:padding .3s var(--ease)}
nav#nav.scrolled{padding:.65rem 3rem}
.logo{font-family:var(--ft);font-size:1.2rem;color:var(--blanc);letter-spacing:.05em;white-space:nowrap}.logo span{color:var(--or)}
.nav-links{display:flex;gap:.1rem;list-style:none;align-items:center;flex-wrap:nowrap}
.nav-links a{font-size:.82rem;letter-spacing:.04em;color:var(--gris-c);position:relative;padding:.4rem .7rem;border-radius:2px;transition:color .25s,background .25s}
.nav-links a:hover{color:var(--blanc);background:rgba(255,255,255,.05)}
.nav-links a.active{color:var(--or)}
.nav-links a.active::after{content:'';display:block;position:absolute;bottom:2px;left:.7rem;right:.7rem;height:1px;background:var(--or)}
.nav-cta{border:1px solid rgba(201,168,76,.5)!important;color:var(--or)!important;padding:.38rem .9rem!important;border-radius:2px;transition:all .3s!important;background:transparent!important}
.nav-cta:hover{background:var(--or)!important;color:var(--noir)!important;border-color:var(--or)!important}
.nav-cta.active{background:var(--or)!important;color:var(--noir)!important;border-color:var(--or)!important}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.burger span{display:block;width:24px;height:1px;background:var(--blanc);transition:.3s}

/* PAGE HEADER (sous-pages) */
.page-header{background:linear-gradient(135deg,#09090f,#12101a 50%,#0d0c14);padding:9rem 3rem 4rem;border-bottom:1px solid var(--bord);position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(201,168,76,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.025) 1px,transparent 1px);background-size:80px 80px;pointer-events:none}
.page-header-in{max-width:1200px;margin:0 auto;position:relative;z-index:2}
.page-h1{font-family:var(--ft);font-size:clamp(2.2rem,4vw,3.5rem);font-weight:400;color:var(--blanc);margin-top:.5rem}
.page-h1 em{font-style:italic;color:var(--or-c)}
.page-subtitle{font-family:var(--fe);font-size:1.1rem;font-style:italic;color:var(--gris-c);margin-top:.9rem;max-width:560px;line-height:1.6}

/* HERO */
#hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#09090f,#12101a 50%,#0d0c14)}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(201,168,76,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.03) 1px,transparent 1px);background-size:80px 80px;pointer-events:none}
.hero-glow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.05) 0%,transparent 70%);top:50%;right:5%;transform:translateY(-50%);pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:8rem 3rem 5rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;width:100%}
.hero-eyebrow{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--or);margin-bottom:1.3rem;display:flex;align-items:center;gap:1rem}
.hero-eyebrow::before{content:'';display:block;width:34px;height:1px;background:var(--or);flex-shrink:0}
h1{font-family:var(--ft);font-size:clamp(2.8rem,5.2vw,5rem);font-weight:400;line-height:1.08;color:var(--blanc)}
h1 em{font-style:italic;color:var(--or-c)}
.hero-tagline{font-family:var(--fe);font-size:1.2rem;font-style:italic;color:var(--gris-c);margin:1.6rem 0 1rem;line-height:1.55;max-width:480px}
.hero-doubles{display:flex;gap:1rem;margin-bottom:2.2rem;flex-wrap:wrap}
.hero-badge-double{display:flex;align-items:center;gap:.6rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.2);padding:.5rem 1rem;border-radius:2px;font-size:.72rem;letter-spacing:.08em;color:var(--or-c)}
.hero-badge-double .hbd-ico{font-size:1rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1.7rem;font-size:.75rem;letter-spacing:.13em;text-transform:uppercase;font-weight:500;border-radius:2px;transition:all .35s var(--ease);cursor:pointer;border:none;font-family:var(--fc)}
.btn-or{background:var(--or);color:var(--noir)}.btn-or:hover{background:var(--or-c);color:var(--noir);transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.3)}
.btn-ghost{background:transparent;color:var(--blanc);border:1px solid rgba(244,239,228,.28)}.btn-ghost:hover{border-color:var(--or);color:var(--or);transform:translateY(-2px)}
.hero-portrait{position:relative;display:flex;justify-content:center;align-items:center}
.portrait-wrap{position:relative;width:390px;height:510px}
.portrait-wrap img{width:100%;height:100%;object-fit:cover;border-radius:3px;filter:grayscale(12%) contrast(1.04)}
.portrait-wrap::before{content:'';position:absolute;inset:0;border-radius:3px;box-shadow:inset 0 0 0 1px rgba(201,168,76,.25);z-index:1;pointer-events:none}
.portrait-wrap::after{content:'';position:absolute;bottom:0;left:0;right:0;height:35%;background:linear-gradient(transparent,rgba(9,9,15,.6));border-radius:0 0 3px 3px;z-index:1;pointer-events:none}
.hero-scroll{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.45rem;color:var(--gris);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;animation:sc 2s ease-in-out infinite}
.hero-scroll-bar{width:1px;height:36px;background:linear-gradient(var(--or),transparent)}
@keyframes sc{0%,100%{opacity:.4;transform:translateX(-50%) translateY(0)}50%{opacity:1;transform:translateX(-50%) translateY(5px)}}

/* COMMUN */
.sec{padding:7rem 3rem;max-width:1200px;margin:0 auto}
.sec-dark{background:#0b0b14}
.sec-card{background:var(--card)}
.sep{width:100%;height:1px;background:var(--bord)}
.lbl{font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;color:var(--or);margin-bottom:.9rem;display:flex;align-items:center;gap:.8rem}
.lbl::before{content:'';display:block;width:26px;height:1px;background:var(--or);flex-shrink:0}
.h2{font-family:var(--ft);font-size:clamp(1.9rem,3.3vw,2.7rem);font-weight:400;line-height:1.2;color:var(--blanc)}
.h2 em{font-style:italic;color:var(--or-c)}
.intro-txt{font-family:var(--fe);font-size:1.1rem;color:var(--gris-c);line-height:1.75;font-style:italic}

/* ANIM */
.anim{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.anim.in{opacity:1;transform:translateY(0)}
.anim-l{opacity:0;transform:translateX(-16px);transition:opacity .55s ease,transform .55s ease}
.anim-l.in{opacity:1;transform:translateX(0)}

/* BIO / À PROPOS */
#apropos .bio-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:5rem;align-items:start;margin-top:3.5rem}
.parcours-txt{font-size:.93rem;color:var(--gris-c);line-height:1.85;margin-bottom:1.2rem}
.parcours-txt strong{color:var(--or-c);font-weight:500}
.parcours-txt em{font-style:italic}
.formation-bloc{margin-top:2.5rem}
.formation-titre{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--or);margin-bottom:.85rem}
.formation-liste{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.formation-liste li{padding-left:1.1rem;border-left:2px solid var(--or-s)}
.fi{font-size:.88rem;color:var(--blanc);font-weight:400;display:block}
.fo{font-size:.73rem;color:var(--gris);display:block;margin-top:.15rem}
.langues{display:flex;gap:.8rem;margin-top:1.5rem;flex-wrap:wrap}
.langue-tag{background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.18);padding:.3rem .85rem;border-radius:2px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--or-c)}

/* PILLIERS */
.pilliers{display:flex;flex-direction:column;gap:1.2rem}
.pill{background:var(--card);border:1px solid var(--bord);border-top:2px solid var(--or-s);padding:1.6rem 1.5rem;border-radius:2px;transition:border-color .35s,transform .35s}
.pill:hover{border-top-color:var(--or);transform:translateY(-4px)}
.pill-ico{font-size:1.3rem;margin-bottom:.75rem}
.pill h3{font-family:var(--ft);font-size:.96rem;color:var(--or-c);margin-bottom:.55rem}
.pill p{font-size:.83rem;color:var(--gris-c);line-height:1.7}

/* ACTIVITÉS */
#activites{background:#0b0b14;padding:7rem 0}
.exp-in{max-width:1200px;margin:0 auto;padding:0 3rem}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem}
.exp-card{background:var(--card);border:1px solid var(--bord);border-radius:3px;padding:2rem 1.6rem;transition:transform .35s,box-shadow .35s}
.exp-card:hover{transform:translateY(-5px);box-shadow:0 12px 35px rgba(0,0,0,.4)}
.exp-card-ico{font-size:1.6rem;margin-bottom:1rem}
.exp-card-titre{font-family:var(--ft);font-size:1rem;color:var(--or-c);margin-bottom:1rem;font-weight:600}
.exp-card ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.exp-card li{font-size:.82rem;color:var(--gris-c);padding-left:1rem;position:relative;line-height:1.5}
.exp-card li::before{content:'›';position:absolute;left:0;color:var(--or-s);font-weight:600}
.exp-cta{display:inline-flex;align-items:center;gap:.45rem;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--or);margin-top:1.25rem;transition:gap .3s,color .3s;text-decoration:none}
.exp-cta:hover{gap:.85rem;color:var(--or-c)}.exp-cta::after{content:'→'}

/* CTA BAND */
.cta-band{background:linear-gradient(135deg,#12101a,#0d0b14);border-top:1px solid var(--bord);border-bottom:1px solid var(--bord);padding:3.8rem 3rem}
.cta-band-in{max-width:1200px;margin:0 auto;text-align:center}
.cta-band-ttl{font-family:var(--ft);font-size:clamp(1.2rem,2.5vw,1.55rem);font-weight:400;color:var(--blanc);margin-bottom:.4rem}
.cta-band-ttl em{font-style:italic;color:var(--or-c)}
.cta-band-sub{font-size:.8rem;color:var(--gris);margin-bottom:1.9rem}
.cta-band-btns{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center}

/* GALERIE */
#galerie{background:var(--noir);padding:7rem 0}
.gal-in{max-width:1200px;margin:0 auto;padding:0 3rem}
.gal-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin:2.2rem 0 1.8rem}
.gal-tab{padding:.42rem 1rem;border:1px solid var(--bord);background:none;color:var(--gris);font-family:var(--fc);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:all .3s}
.gal-tab.active,.gal-tab:hover{border-color:var(--or);color:var(--or);background:rgba(201,168,76,.06)}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2.5rem}
.gal-item{position:relative;overflow:hidden;border-radius:2px;cursor:pointer;aspect-ratio:4/3;background:var(--card)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease),filter .5s}
.gal-item:hover img{transform:scale(1.05);filter:brightness(1.1)}
.gal-cap{position:absolute;bottom:0;left:0;right:0;padding:1.4rem 1rem .8rem;background:linear-gradient(transparent,rgba(9,9,15,.85));opacity:0;transition:opacity .35s}
.gal-item:hover .gal-cap{opacity:1}
.gal-cap .oe{font-family:var(--ft);font-size:.88rem;font-style:italic;color:var(--blanc);display:block}
.gal-cap .co{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--or);display:block;margin-top:.2rem}
/* Section thématique dans la galerie */
.gal-section{margin-bottom:3rem}
.gal-section-hd{margin-bottom:1.4rem}
.gal-section-hd h3{font-family:var(--ft);font-size:1.1rem;color:var(--blanc);font-weight:400}
.gal-section-hd p{font-size:.83rem;color:var(--gris-c);margin-top:.35rem;line-height:1.65}

/* LIGHTBOX */
.lb{display:none;position:fixed;inset:0;z-index:2000;background:rgba(5,5,10,.94);align-items:center;justify-content:center;backdrop-filter:blur(8px)}
.lb.open{display:flex}
.lb-img{max-width:90vw;max-height:82vh;object-fit:contain;border-radius:3px;box-shadow:0 30px 80px rgba(0,0,0,.8)}
.lb-close{position:absolute;top:1.4rem;right:1.8rem;font-size:1.7rem;color:var(--gris-c);cursor:pointer;background:none;border:none;line-height:1;transition:color .2s}
.lb-close:hover{color:var(--or)}
.lb-info{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);text-align:center;max-width:600px;width:90vw}
.lb-info .oe{font-family:var(--ft);font-size:1.05rem;font-style:italic;color:var(--blanc)}
.lb-info .co{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--or);margin-top:.3rem}
.lb-desc{font-size:.8rem;color:var(--gris-c);margin-top:.5rem;line-height:1.6}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:2rem;color:var(--gris-c);cursor:pointer;background:rgba(9,9,15,.5);border:none;width:48px;height:58px;display:flex;align-items:center;justify-content:center;transition:all .2s;border-radius:2px}
.lb-nav:hover{color:var(--or);background:rgba(9,9,15,.8)}
.lb-prev{left:1rem}.lb-next{right:1rem}

/* CARROUSEL AUTO */
.caro-section{background:#0c0c15;padding:2.6rem 0;overflow:hidden;border-top:1px solid var(--bord);border-bottom:1px solid var(--bord)}
.caro-label{text-align:center;font-size:.58rem;letter-spacing:.38em;text-transform:uppercase;color:var(--or-s);margin-bottom:1.3rem}
.caro-mask{overflow:hidden;position:relative}
.caro-mask::before,.caro-mask::after{content:'';position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.caro-mask::before{left:0;background:linear-gradient(to right,#0c0c15,transparent)}
.caro-mask::after{right:0;background:linear-gradient(to left,#0c0c15,transparent)}
.caro-track{display:flex;gap:.85rem;width:max-content;animation:caro-scroll 42s linear infinite}
.caro-track:hover{animation-play-state:paused}
.caro-item{position:relative;height:162px;flex-shrink:0;border-radius:2px;overflow:hidden;border:1px solid rgba(201,168,76,.08);transition:border-color .35s}
.caro-item:hover{border-color:rgba(201,168,76,.35)}
.caro-item img{height:162px;width:auto;display:block;object-fit:cover;filter:grayscale(18%) brightness(.82);transition:filter .45s var(--ease),transform .45s var(--ease)}
.caro-item:hover img{filter:grayscale(0%) brightness(1.04);transform:scale(1.07)}
.caro-cap{position:absolute;bottom:0;left:0;right:0;padding:.9rem .75rem .5rem;background:linear-gradient(transparent,rgba(9,9,15,.85));opacity:0;transition:opacity .3s;font-size:.6rem;letter-spacing:.11em;text-transform:uppercase;color:var(--or);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.caro-item:hover .caro-cap{opacity:1}
@keyframes caro-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.caro-track{animation:none}}

/* STABAT MATER */
.stab-section{background:#0b0b14;padding:5rem 3rem;border-top:1px solid var(--bord);border-bottom:1px solid var(--bord)}
.stab-inner{max-width:860px;margin:0 auto;text-align:center}
.stab-titre{font-family:var(--ft);color:var(--blanc);font-size:clamp(1rem,2vw,1.3rem);font-weight:400;margin:.4rem 0 2.2rem;letter-spacing:.04em;font-style:italic}
.stab-audio-wrap{margin-bottom:2.8rem}
.stab-audio-lbl{font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--or-s);margin-bottom:.9rem}
.stab-audio-wrap audio{width:100%;max-width:460px;opacity:.9}
.stab-caro-wrap{position:relative;display:flex;align-items:center;gap:1rem}
.stab-viewport{overflow:hidden;flex:1;border-radius:2px;border:1px solid rgba(201,168,76,.1)}
.stab-track{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.stab-slide{min-width:100%;aspect-ratio:3/2;overflow:hidden}
.stab-slide img{width:100%;height:100%;object-fit:contain;background:#0b0b14;filter:brightness(.92);transition:filter .4s}
.stab-slide img:hover{filter:brightness(1)}
.stab-btn{background:rgba(201,168,76,.1);border:1px solid var(--or-s);color:var(--or);font-size:1.8rem;width:2.8rem;height:2.8rem;border-radius:50%;cursor:pointer;flex-shrink:0;line-height:1;transition:background .2s;display:flex;align-items:center;justify-content:center}
.stab-btn:hover{background:rgba(201,168,76,.25)}
.stab-dots{margin-top:1rem;display:flex;justify-content:center;gap:.45rem;flex-wrap:wrap}
.stab-dot{width:6px;height:6px;border-radius:50%;background:var(--bord);border:1px solid var(--or-s);cursor:pointer;padding:0;transition:background .2s}
.stab-dot.act{background:var(--or)}

/* VIDEOS */
#videos{background:#0b0b14;padding:7rem 3rem}
.vid-inner{max-width:1200px;margin:0 auto}
.vid-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:2.8rem}
.vid-card{background:var(--card);border:1px solid var(--bord);border-radius:3px;overflow:hidden;transition:transform .35s,box-shadow .35s}
.vid-card:hover{transform:translateY(-4px);box-shadow:0 14px 38px rgba(0,0,0,.5)}
.vid-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden}
.vid-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}
.vid-meta{padding:1.1rem 1.4rem}
.vid-titre{font-family:var(--ft);font-size:.96rem;color:var(--blanc);margin-bottom:.25rem}
.vid-sub{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--or)}
.yt-facade{position:absolute;top:0;left:0;width:100%;height:100%;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#000}
.yt-facade img{width:100%;height:100%;object-fit:cover;opacity:.82;transition:opacity .4s}
.yt-facade:hover img{opacity:1}
.yt-play-btn{position:absolute;width:68px;height:68px;border-radius:50%;background:rgba(201,168,76,.9);pointer-events:none;transition:transform .3s,background .3s}
.yt-facade:hover .yt-play-btn{transform:scale(1.1);background:var(--or)}
.yt-play-btn::after{content:'';position:absolute;top:50%;left:54%;transform:translate(-50%,-50%);border-style:solid;border-width:11px 0 11px 22px;border-color:transparent transparent transparent var(--noir)}
.yt-unavail{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;background:var(--card);padding:1.5rem;text-align:center}
.yt-unavail p{font-size:.82rem;color:var(--gris);line-height:1.6}
.yt-unavail a{color:var(--or);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(201,168,76,.3);padding:.5rem 1.2rem;border-radius:2px;transition:all .3s}
.yt-unavail a:hover{background:rgba(201,168,76,.08);color:var(--or-c)}
.vid-add-note{font-size:.78rem;color:var(--gris);font-style:italic;margin-top:2rem;text-align:center;padding:1.2rem;border:1px dashed var(--bord);border-radius:2px}

/* PREUVES / RÉPERTOIRE */
#preuves{background:var(--noir);padding:7rem 0}
.pr-in{max-width:1200px;margin:0 auto;padding:0 3rem}
.cards-hl{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-top:3rem}
.pcard{background:linear-gradient(135deg,var(--card),#1a1525);border:1px solid var(--bord);border-left:3px solid var(--or);padding:2.2rem;border-radius:2px;position:relative;overflow:hidden}
.pcard::before{content:'';position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle at top right,rgba(201,168,76,.05),transparent 70%)}
.pcard-yr{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--or);margin-bottom:.7rem}
.pcard-h{font-family:var(--ft);font-size:1.28rem;color:var(--blanc);margin-bottom:.35rem;font-weight:400}
.pcard-lieu{font-size:.8rem;color:var(--gris);margin-bottom:.8rem}
.pcard-desc{font-size:.87rem;color:var(--gris-c);line-height:1.75}
.roles-wrap{margin-top:3.5rem}
.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-top:1.3rem}
.role{background:var(--card);border:1px solid var(--bord);padding:1.3rem;border-radius:2px;transition:border-color .3s,transform .3s}
.role:hover{border-color:var(--or-s);transform:translateY(-3px)}
.role-oe{font-family:var(--ft);font-size:.9rem;font-style:italic;color:var(--or-c);margin-bottom:.25rem}
.role-co{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gris)}

/* PROJETS */
#projets{background:var(--card);padding:7rem 3rem}
#projets .sec-inner{max-width:1200px;margin:0 auto}
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3.2rem}
.pj{background:var(--noir);border:1px solid var(--bord);border-radius:3px;overflow:hidden;transition:transform .35s,box-shadow .35s}
.pj:hover{transform:translateY(-5px);box-shadow:0 0 30px rgba(201,168,76,.08)}
.pj-img{height:190px;overflow:hidden}
.pj-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.pj:hover .pj-img img{transform:scale(1.05)}
.pj-img-placeholder{height:190px;display:flex;align-items:center;justify-content:center}
.pj-head{padding:1.5rem 1.7rem 1rem;border-bottom:1px solid var(--bord)}
.pj-tag{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--or);background:rgba(201,168,76,.08);padding:.25rem .7rem;border-radius:20px;display:inline-block;margin-bottom:.7rem}
.pj-nom{font-family:var(--ft);font-size:1.25rem;color:var(--blanc);font-weight:400;margin-bottom:.25rem}
.pj-sub{font-size:.77rem;color:var(--gris)}
.pj-body{padding:1.3rem 1.7rem 1.7rem}
.pj-body p{font-size:.87rem;color:var(--gris-c);line-height:1.8;margin-bottom:1rem}
.pj-link{font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:var(--or);display:inline-flex;align-items:center;gap:.45rem;transition:gap .3s}
.pj-link:hover{gap:.9rem;color:var(--or-c)}.pj-link::after{content:'→'}

/* AGENDA */
#agenda{background:linear-gradient(180deg,var(--noir),#0e0e18);padding:7rem 3rem}
#agenda .sec-inner{max-width:1200px;margin:0 auto}
.ag-liste{margin-top:2.5rem}
.ag-item{display:grid;grid-template-columns:95px 1fr auto;gap:2rem;align-items:center;padding:1.6rem 0;border-bottom:1px solid var(--bord);transition:all .3s}
.ag-item:first-child{border-top:1px solid var(--bord)}
.ag-item:hover{background:rgba(201,168,76,.03);padding-left:1rem;margin-left:-1rem;padding-right:1rem}
.ag-date .jour{font-family:var(--ft);font-size:1.8rem;font-weight:700;color:var(--or);line-height:1}
.ag-date .mois{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris);margin-top:2px}
.ag-ev-titre{font-family:var(--ft);font-size:1rem;color:var(--blanc);margin-bottom:.28rem}
.ag-lieu{font-size:.77rem;color:var(--gris);display:flex;align-items:center;gap:.45rem}
.ag-lieu::before{content:'◈';color:var(--or-s);font-size:.56rem}
.ag-role{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--or);background:rgba(201,168,76,.08);padding:.2rem .65rem;border-radius:20px;white-space:nowrap}

/* CONTACT */
#contact{background:var(--card);padding:7rem 0}
.ct-in{max-width:1200px;margin:0 auto;padding:0 3rem;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.ct-portrait{border-radius:3px;overflow:hidden;margin-top:2rem;height:310px}
.ct-portrait img{width:100%;height:100%;object-fit:cover;filter:grayscale(18%)}
.ct-mail{display:flex;align-items:center;gap:.9rem;margin-bottom:.85rem}
.ct-mail .ico{width:33px;height:33px;background:rgba(201,168,76,.09);border:1px solid var(--or-s);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:.78rem;flex-shrink:0}
.ct-mail a{font-size:.86rem;color:var(--gris-c)}.ct-mail a:hover{color:var(--or)}
.ct-socials{display:flex;gap:.75rem;margin-top:1.6rem}
.soc{width:38px;height:38px;border:1px solid var(--bord);border-radius:2px;display:flex;align-items:center;justify-content:center;color:var(--gris);font-size:.75rem;font-weight:500;transition:all .3s;font-family:var(--fc)}
.soc:hover{border-color:var(--or);color:var(--or);background:rgba(201,168,76,.06)}
.form-g{margin-bottom:1.3rem}
.form-g label{display:block;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris);margin-bottom:.5rem}
.form-g input,.form-g textarea,.form-g select{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--bord);border-radius:2px;padding:.78rem 1rem;color:var(--blanc);font-family:var(--fc);font-size:.86rem;font-weight:300;outline:none;transition:border-color .3s}
.form-g input:focus,.form-g textarea:focus,.form-g select:focus{border-color:var(--or-s)}
.form-g textarea{min-height:125px;resize:vertical}
.form-g select option{background:var(--card)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-msg{font-size:.85rem;padding:.8rem 1rem;border-radius:2px;margin-top:.8rem;text-align:center;display:none}
.form-msg:not(:empty){display:block}
.form-msg-ok{background:rgba(100,200,100,.08);border:1px solid rgba(100,200,100,.25);color:#7dd87d}
.form-msg-err{background:rgba(220,80,80,.08);border:1px solid rgba(220,80,80,.25);color:#e08080}

/* FOOTER */
footer{background:#060608;padding:2.2rem 3rem;border-top:1px solid var(--bord)}
.ft-in{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.3rem}
.ft-logo{font-family:var(--ft);font-size:1rem;color:var(--blanc)}.ft-logo span{color:var(--or)}
.ft-links{display:flex;gap:1.8rem;list-style:none}
.ft-links a{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gris)}.ft-links a:hover{color:var(--or)}
.ft-copy{font-size:.7rem;color:var(--or-s)}

/* RESPONSIVE */
@media(max-width:1100px){
  .exp-grid{grid-template-columns:1fr 1fr}
  .cards-hl{grid-template-columns:1fr}
  .roles-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:3rem;padding-top:7rem}
  .hero-portrait{order:-1}
  .portrait-wrap{width:300px;height:400px}
  #apropos .bio-grid{grid-template-columns:1fr;gap:3rem}
  .vid-grid{grid-template-columns:1fr}
  .ct-in{grid-template-columns:1fr;gap:3rem}
}
@media(max-width:768px){
  nav#nav{padding:1rem 1.5rem}nav#nav.scrolled{padding:.65rem 1.5rem}
  .nav-links{display:none}.burger{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(9,9,15,.97);align-items:center;justify-content:center;gap:2.5rem;font-size:1.2rem;z-index:999}
  .sec{padding:4rem 1.5rem}
  #activites,.sec-dark{padding:4rem 0}.exp-in{padding:0 1.5rem}
  #galerie{padding:4rem 0}.gal-in{padding:0 1.5rem}
  #videos{padding:4rem 1.5rem}
  #preuves{padding:4rem 0}.pr-in{padding:0 1.5rem}
  #projets{padding:4rem 1.5rem}.proj-grid{grid-template-columns:1fr}
  #agenda{padding:4rem 1.5rem}
  #contact{padding:4rem 0}.ct-in{padding:0 1.5rem}
  .hero-inner{padding:6rem 1.5rem 4rem}
  h1{font-size:2.6rem}
  .exp-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr}
  .gal-item{aspect-ratio:3/2}
  .roles-grid{grid-template-columns:1fr}
  .ag-item{grid-template-columns:78px 1fr}.ag-role{display:none}
  .ft-in{flex-direction:column;text-align:center}
  .ft-links{flex-wrap:wrap;justify-content:center;gap:1.2rem}
  .cta-band{padding:2.8rem 1.5rem}.cta-band-btns{flex-direction:column;align-items:center}
  .page-header{padding:7rem 1.5rem 3rem}
  .stab-section{padding:4rem 1.5rem}.stab-btn{width:2.2rem;height:2.2rem;font-size:1.4rem}
}

/* NAVIGATION INTER-PAGES */
.page-nav{background:var(--card);border-top:1px solid var(--bord);padding:1.8rem 3rem}
.page-nav-in{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:2rem}
.page-nav-in.next-only{justify-content:flex-end}
.page-nav-in.prev-only{justify-content:flex-start}
.page-nav-link{display:flex;flex-direction:column;gap:.2rem;color:inherit}
.page-nav-link:hover{color:inherit}
.page-nav-dir{font-size:.56rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gris)}
.page-nav-title{font-family:var(--ft);font-size:.98rem;color:var(--blanc);transition:color .3s}
.page-nav-link:hover .page-nav-title{color:var(--or)}
.page-nav-prev .page-nav-title::before{content:'← ';color:var(--or-s)}
.page-nav-next{text-align:right}
.page-nav-next .page-nav-title::after{content:' →';color:var(--or-s)}
@media(max-width:768px){
  .page-nav{padding:1.3rem 1.5rem}
  .page-nav-title{font-size:.85rem}
}
