/*
Theme Name: Cie L'An 01 v2
Theme URI: https://cielan01.fr
Author: Compagnie l'An 01
Description: Theme sur-mesure du site de la Compagnie l'An 01 (refonte v2). Sidebar fixe, charte or/noir, gabarit Spectacle duplicable. Contenus pilotes par champs (ACF).
Version: 0.1.0
Requires PHP: 8.1
License: GPL-2.0-or-later
Text Domain: cielan01
*/

/* ===== POLICES (Akzidenz Grotesk, licence webfont detenue par la compagnie) ===== */
@font-face{font-family:'Akzidenz';src:url('assets/fonts/AkzidenzGrotesk-Light.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Akzidenz';src:url('assets/fonts/AkzidenzGrotesk-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Akzidenz';src:url('assets/fonts/AkzidenzGrotesk-Italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Akzidenz';src:url('assets/fonts/AkzidenzGrotesk-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Akzidenz';src:url('assets/fonts/AkzidenzGrotesk-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Akzidenz';src:url('assets/fonts/AkzidenzGrotesk-Super.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}

/* ===== TOKENS (charte cartblanch 2019) ===== */
:root{
  --or:#E9B400; --or-txt:#A67C00; --noir:#000; --noir-doux:#141414;
  --gris-txt:#444; --gris-faible:#8a8a8a; --gris-ligne:#e6e6e6; --gris-bg:#f4f4f2;
  --sidebar-w:248px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Akzidenz','Helvetica Neue',Arial,sans-serif;color:var(--noir);background:#fff;line-height:1.5;-webkit-font-smoothing:antialiased}

/* ===== LAYOUT ===== */
.shell{display:flex;min-height:100vh}
.sb{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);padding:30px 26px;border-right:1px solid var(--gris-ligne);position:sticky;top:0;height:100vh;overflow-y:auto;background:#fff;z-index:40}
.sb__logo img{width:140px;display:block}
.sb__logo{margin-bottom:18px;cursor:pointer;background:none;border:none;padding:0;display:block}
.sb__star{color:var(--or);font-size:22px;line-height:1;margin:2px 0 22px;background:none;border:none;cursor:pointer;display:block;text-decoration:none}
.sb__star.active{color:var(--noir)}
.sb__group{margin-bottom:22px}
/* Detache le cluster bas (LANGUE + INTRANET) du reste du menu. */
.sb__lang{margin-top:44px}
.sb__head{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--or-txt);margin-bottom:10px;font-weight:700}
.sb a{display:block;text-decoration:none;color:var(--noir);font-size:15px;padding:5px 0;position:relative;transition:color .15s,padding .15s;cursor:pointer}
.sb a:hover{padding-left:10px;color:var(--or-txt)}
.sb a.active{font-weight:700}
.sb a.active::before{content:"";position:absolute;left:-26px;top:50%;transform:translateY(-50%);width:4px;height:18px;background:var(--or)}
.sb__year{color:var(--gris-faible);margin-right:8px;font-variant-numeric:tabular-nums}
.sb__creations a{display:flex;gap:0;align-items:baseline}
.sb__social{display:flex;gap:14px}
.sb__social a{font-size:13px;color:var(--gris-txt)}
.sb__intranet{display:inline-flex;align-items:center;gap:5px;margin-top:16px;color:var(--gris-faible);font-size:12px;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;font-weight:500}
.sb__intranet::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--or)}
.sb__intranet:hover{color:var(--noir)}

.content{flex:1;min-width:0;display:flex;flex-direction:column}
.main{flex:1;padding:34px clamp(36px,5vw,90px) 60px;min-width:0}

.ptitle{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);margin-bottom:6px;font-weight:700}
.phead{font-size:clamp(28px,4vw,44px);font-weight:900;letter-spacing:-.01em;line-height:1.05;margin-bottom:24px}
.sec{margin-top:42px}
.sec__h{font-size:15px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;border-bottom:2px solid var(--noir);padding-bottom:9px;margin-bottom:20px}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;padding:11px 20px;border-radius:3px;text-decoration:none;border:1.5px solid var(--noir);color:var(--noir);background:transparent;cursor:pointer;transition:.15s}
.btn:hover{background:var(--noir);color:#fff}
.btn--solid{background:var(--noir);color:#fff}.btn--solid:hover{background:var(--or);color:var(--noir);border-color:var(--or)}
.btn--or{background:var(--or);border-color:var(--or);color:var(--noir)}.btn--or:hover{background:var(--noir);border-color:var(--noir);color:#fff}

/* footer */
.ft{border-top:1px solid var(--gris-ligne);padding:22px clamp(36px,5vw,90px);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.ft__cr{font-size:12px;color:var(--gris-faible)}
.ft a{font-size:12px;color:var(--gris-faible);text-decoration:none}.ft a:hover{color:var(--noir)}

/* burger mobile */
.topbar{display:none;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--gris-ligne);position:sticky;top:0;background:#fff;z-index:50}
.topbar img{width:108px}
.burger{background:none;border:none;cursor:pointer;color:var(--or);padding:4px;display:inline-flex;align-items:center;line-height:0}
.sb__close{display:none}

/* poster / affiche */
.poster-ph{aspect-ratio:3/4;background:linear-gradient(160deg,#1f1f1f,#000);border-radius:4px;display:flex;align-items:flex-end;padding:20px;color:#fff;font-weight:900;font-size:26px;line-height:1}
.poster-img{width:100%;border-radius:4px;display:block}

/* generic prose */
.prose{max-width:820px}
/* Texte courant justifie (demande Romain). Cesure FR activee (lang=fr force cote PHP) pour eviter les grands trous entre les mots. */
.prose p,.lh p,.ml-body p,.sp-synopsis,.tl-text,.home-fdesc,.pep-intro,.il-lead{text-align:justify;-webkit-hyphens:auto;hyphens:auto}
.prose p{font-size:16px;line-height:1.75;color:#222;margin-bottom:18px}
.exergue{max-width:820px;margin:34px 0;padding:4px 0 4px 28px;border-left:3px solid var(--or);font-size:23px;line-height:1.4;font-weight:300}
.exergue cite{display:block;font-size:13px;color:var(--gris-txt);margin-top:12px;font-style:normal}

/* fiche / listes cle-valeur */
.fiche{max-width:760px}
.fiche__row{display:grid;grid-template-columns:190px 1fr;gap:16px;padding:10px 0;border-bottom:1px solid var(--gris-ligne)}
.fiche__k{font-size:14px;color:#888}.fiche__v{font-size:16px;line-height:1.5}

/* galerie */
.tl-gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;max-width:1000px;margin-top:16px}
.tl-gal a,.tl-gal div{aspect-ratio:4/3;border-radius:4px;background:#2c2c2c;cursor:zoom-in;display:block;overflow:hidden}
.tl-gal img{width:100%;height:100%;object-fit:cover;display:block}

/* video */
.video{max-width:560px;aspect-ratio:16/9;background:var(--noir);border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;border:none;width:100%}
.video iframe{width:100%;height:100%;border:0;border-radius:5px}
.video .play{width:58px;height:58px;border-radius:50%;background:var(--or);color:var(--noir);display:flex;align-items:center;justify-content:center;font-size:18px;padding-left:3px}

/* tags spectacle */
.sp-tags{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0 22px}
.sp-tag{font-size:11px;text-transform:uppercase;font-weight:600;padding:5px 11px;border-radius:20px;border:1px solid var(--noir)}
.sp-tag--solid{background:var(--noir);color:#fff;border-color:var(--noir)}
.sp-tag--or{background:var(--or);color:var(--noir);border-color:var(--or)}
.sp-head{display:grid;grid-template-columns:1fr 340px;gap:44px;align-items:start}
.sp-sub{font-size:18px;font-style:italic;color:var(--gris-txt)}
.sp-theme{color:#888;font-size:14px;margin-top:4px}
.sp-synopsis{font-size:16px;line-height:1.7;max-width:820px;margin-top:6px}
.sp-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}
.sp-poster-cap{font-size:12px;color:#888;margin-top:8px;text-align:center}
.poster-link{display:block;cursor:zoom-in}
.poster-link:hover .poster-img{opacity:.92}

/* --- Lightbox (affiche + galerie) ------------------------------------- */
.lb{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center}
.lb.on{display:flex}
.lb__backdrop{position:absolute;inset:0;background:rgba(8,8,8,.93);cursor:zoom-out}
.lb__stage{position:relative;z-index:2;margin:0;max-width:92vw;max-height:84vh;display:flex;align-items:center;justify-content:center}
.lb__img{max-width:92vw;max-height:84vh;width:auto;height:auto;display:block;border-radius:3px;box-shadow:0 10px 50px rgba(0,0,0,.6);user-select:none;-webkit-user-drag:none}
.lb--protected .lb__img{pointer-events:none}
.lb__close{position:absolute;top:18px;right:22px;z-index:3;background:none;border:none;color:#fff;font-size:38px;line-height:1;cursor:pointer;opacity:.85;transition:opacity .15s,color .15s}
.lb__close:hover{opacity:1;color:var(--or)}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:none;border:none;color:#fff;font-size:54px;line-height:1;cursor:pointer;padding:10px 18px;opacity:.8;transition:opacity .15s,color .15s}
.lb__nav:hover{opacity:1;color:var(--or)}
.lb__prev{left:8px}.lb__next{right:8px}
.lb__bar{position:absolute;left:0;right:0;bottom:22px;z-index:3;display:flex;align-items:center;justify-content:center;gap:18px}
.lb__count{color:#bbb;font-size:13px;letter-spacing:.06em}
.lb__dl{display:inline-flex;align-items:center;gap:8px;background:var(--or);color:var(--noir);font-weight:700;font-size:13px;padding:9px 18px;border-radius:3px;text-decoration:none;transition:.15s}
.lb__dl:hover{background:#fff}
@media(max-width:640px){.lb__nav{font-size:40px;padding:6px 10px}.lb__close{font-size:32px;top:12px;right:14px}}

/* Vignettes video (ouvrent la lightbox) */
.video-tiles{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;max-width:760px}
.video-tile{position:relative;width:240px;max-width:100%;aspect-ratio:16/9;border:none;padding:0;border-radius:5px;overflow:hidden;cursor:pointer;background:#1a1a1a;display:block}
.video-tile__img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s,opacity .2s}
.video-tile:hover .video-tile__img{transform:scale(1.04);opacity:.85}
.video-tile--noimg{background:linear-gradient(160deg,#242424,#000)}
.video-tile__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:var(--or);color:var(--noir);display:flex;align-items:center;justify-content:center;padding-left:2px;box-shadow:0 2px 12px rgba(0,0,0,.45);transition:transform .15s}
.video-tile__play svg{display:block}
/* Repli : triangle "play" en CSS pur si le span est vide (cas ou WP kses
   a strippe le SVG du contenu d'une page, ex. references-xy). */
.video-tile__play:empty::before{content:"";width:0;height:0;border-style:solid;border-width:9px 0 9px 14px;border-color:transparent transparent transparent currentColor;margin-left:3px}
.video-tile:hover .video-tile__play{transform:translate(-50%,-50%) scale(1.1)}
/* Lightbox en mode video */
.lb__video{position:relative;z-index:2;display:none;width:min(92vw,1080px)}
.lb.lb--video .lb__video{display:block}
.lb.lb--video .lb__stage,.lb.lb--video .lb__nav,.lb.lb--video .lb__bar{display:none}
.lb__videowrap{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:3px;overflow:hidden}
.lb__iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

@media(max-width:820px){
  .sb{display:none}.topbar{display:flex}
  .shell{flex-direction:column}
  .sp-head{grid-template-columns:1fr;gap:22px}.poster-ph{max-width:260px}
  .sb.open{display:block;position:fixed;inset:0;width:100%;height:100vh;height:100dvh;background:#fff;z-index:60;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:24px 26px 104px}
  .sb.open a.active::before{display:none}
  .sb.open .sb__close{display:block;position:fixed;top:13px;right:14px;background:none;border:none;color:var(--noir);cursor:pointer;padding:6px;line-height:0;z-index:2}
}

.lang-sw{display:flex;gap:6px}
/* Traduction Google : on masque toute la "chrome" Google, on garde nos boutons. */
.skiptranslate{display:none !important}
iframe.skiptranslate,.goog-te-banner-frame{display:none !important;visibility:hidden !important}
#goog-gt-tt,.goog-tooltip,.goog-tooltip:hover,.goog-te-balloon-frame{display:none !important}
.goog-text-highlight{background:none !important;box-shadow:none !important}
body{top:0 !important;position:static !important}
.lang{background:none;border:1px solid var(--gris-ligne);border-radius:3px;font-family:inherit;font-size:12px;letter-spacing:.05em;padding:5px 10px;cursor:pointer;color:var(--gris-faible);transition:.15s}
.lang:hover{border-color:var(--noir);color:var(--noir)}
.lang.on{background:var(--noir);color:#fff;border-color:var(--noir);font-weight:700}

/* ===== ACCUEIL ===== */
.home-manifest{display:flex;align-items:center;gap:24px;padding:14vh 0 12vh;justify-content:center;min-height:62vh}
.home-best{width:110px;height:auto;margin:0 auto 26px;display:block}
.home-mbody{text-align:center;max-width:820px}
.home-quote{font-size:clamp(24px,3vw,38px);font-weight:300;line-height:1.28}
.home-quote::before{content:"\00AB\00A0";color:var(--or-txt)}.home-quote::after{content:"\00A0\00BB";color:var(--or-txt)}
.home-cite{display:block;margin-top:14px;font-size:14px;color:var(--gris-txt)}.home-cite i{font-style:italic}
.home-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}
.home-dots span{width:7px;height:7px;border-radius:50%;background:#d8d8d8;cursor:pointer}.home-dots span.on{background:var(--or)}
.home-arrow{background:none;border:none;font-size:28px;color:#cfcfcf;cursor:pointer;padding:8px}.home-arrow:hover{color:var(--or-txt)}
.home-rule{border:none;border-top:1px solid var(--gris-ligne)}
.home-feat{padding:40px 0 10px}
.home-fgrid{display:grid;grid-template-columns:280px 1fr;gap:38px;align-items:start;margin-top:14px}
.home-ftitle{font-size:32px;font-weight:900;letter-spacing:-.01em;line-height:1}
.home-fsub{font-size:13px;color:var(--or-txt);text-transform:uppercase;letter-spacing:.08em;margin:10px 0 14px;font-weight:700}
.home-fdesc{color:var(--gris-txt);font-size:15px;line-height:1.65;max-width:480px}
.home-dates{margin-top:24px;border-top:2px solid var(--noir)}
.home-dh{font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--or-txt);font-weight:700;padding:10px 0 4px}
.home-date{display:grid;grid-template-columns:78px 110px 1fr;gap:2px 14px;padding:8px 0;border-bottom:1px solid var(--gris-ligne);align-items:baseline}
.home-date .d{font-variant-numeric:tabular-nums;font-weight:700;font-size:15px;white-space:nowrap}
.home-date .t{font-size:15px;white-space:nowrap;color:var(--noir)}
.home-date .v{font-size:15px;font-weight:600;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.home-date .l{grid-column:1 / -1;font-size:12px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:0}
.home-cta{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.home-poster-link{display:block;text-decoration:none}

/* ===== EQUIPE ===== */
.team-cat{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);font-weight:700;border-bottom:2px solid var(--noir);padding-bottom:6px;margin:30px 0 18px}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.flip{perspective:1000px;cursor:pointer}
.flip__in{position:relative;width:100%;aspect-ratio:1;transition:transform .5s cubic-bezier(.4,.1,.2,1);transform-style:preserve-3d}
.flip:hover .flip__in,.flip.flipped .flip__in{transform:rotateY(180deg)}
.flip--static{cursor:default}
.flip--static:hover .flip__in{transform:none}
.flip__f{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:5px;overflow:hidden}
.flip__front{filter:grayscale(1);background:#a8a8a8}
.flip__front img{width:100%;height:100%;object-fit:cover;display:block}
.flip__back{background:var(--noir);color:#fff;transform:rotateY(180deg);padding:16px;display:flex;flex-direction:column;justify-content:space-between}
.flip__back .role{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--or);font-weight:700}
.flip__back .bio{font-size:12px;line-height:1.5;color:#ddd;margin-top:6px;flex:1}
.flip__back .mail{font-size:12px;color:var(--or);text-decoration:none;font-weight:500;margin-top:8px;word-break:break-all}
.flip__nm{font-size:14px;font-weight:700;margin-top:9px}.flip__rl{font-size:11px;color:#999;text-transform:uppercase}
.cards2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:8px 0 26px}
.card-l{background:var(--gris-bg);border-radius:5px;padding:24px;font-size:15px;line-height:1.8}
.card-d{background:var(--noir);color:#fff;border-radius:5px;padding:24px;position:relative;overflow:hidden;font-size:15px;line-height:1.8}
.card-d .role{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--or);margin-bottom:12px;font-weight:700;position:relative}
.card-d .best{position:absolute;right:-20px;bottom:-20px;width:120px;opacity:.18}
.card-d a,.card-l a{color:var(--or-txt);text-decoration:none;font-weight:700}.card-d a{color:var(--or)}
.team-hint{color:var(--gris-txt);font-size:14px;max-width:520px;margin:-12px 0 8px}

/* ===== ESPACE PRO ===== */
.pro-login{max-width:460px;background:var(--gris-bg);border-radius:6px;padding:30px 32px}
.pro-lead{font-size:16px;color:var(--gris-txt);max-width:560px;margin:-12px 0 24px}
.pro-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap;margin-bottom:6px}
.pro-sp{margin-top:30px}
.pro-sp__h{font-size:15px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;border-bottom:2px solid var(--noir);padding-bottom:9px;margin-bottom:8px}
.pro-doc{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--gris-ligne)}
.pro-doc .n{font-weight:700;font-size:15px}
.pro-doc .meta{font-size:12px;color:var(--gris-faible)}
.pro-vh{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);font-weight:700;margin:20px 0 12px}
.pro-empty{color:var(--gris-faible);font-size:14px;padding:10px 0}
.pro-msg{padding:12px 16px;border-radius:5px;margin:14px 0;font-size:14px;max-width:560px}
.pro-msg.ok{background:#eaf6ec;color:#1a7f37}
.pro-msg.err{background:#fdecea;color:#b3261e}
.pro-logout{font-size:13px;color:var(--gris-faible);text-decoration:none}
.pro-logout:hover{color:var(--noir)}

/* ===== INFOLETTRE ===== */
.il{max-width:560px}
.il-lead{font-size:17px;color:var(--gris-txt);margin:-12px 0 28px}
.il-card{background:var(--gris-bg);border-radius:6px;padding:30px 32px;position:relative;overflow:hidden}
.il-card .best{position:absolute;right:-22px;bottom:-22px;width:120px;opacity:.12}
.il-f{display:block;width:100%;background:#fff;border:1px solid #ddd;border-radius:4px;padding:13px 14px;font-size:15px;font-family:inherit;margin-bottom:12px}
.il-f:focus{outline:none;border-color:var(--or);box-shadow:0 0 0 3px rgba(233,180,0,.18)}
.il-rgpd{font-size:12px;color:#888;line-height:1.55;margin-top:16px;max-width:420px}
.il-act{display:flex;justify-content:flex-end;margin-top:18px}
.il-archive{margin-top:30px}
.il-archive a{color:var(--noir);font-weight:700;border-bottom:2px solid var(--or);text-decoration:none}
.il-msg{margin-top:16px;font-size:14px;font-weight:700}
.il-msg.ok{color:#1a7f37}.il-msg.err{color:#b3261e}

/* ===== HISTOIRE DU LOGO ===== */
.lh{max-width:760px}
.lh-best{width:220px;margin:8px 0 32px;display:block}
.lh p{font-size:16px;line-height:1.8;color:#222;margin-bottom:18px}
.lh-sign{margin-top:28px;font-style:italic;font-size:14px;color:var(--gris-txt)}
.lh-sign a{color:var(--or-txt)}

/* ===== PEPITES (mur de post-it) ===== */
.pep-info{display:flex;gap:14px;background:#fffdf2;border-left:3px solid var(--or);border-radius:0 5px 5px 0;padding:14px 18px;font-size:13px;color:#5a4d00;line-height:1.55;max-width:760px;margin-bottom:24px}
.pep-intro{font-size:15px;line-height:1.7;color:#333;max-width:640px}
.pep-sh{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;border-bottom:2px solid var(--or);padding-bottom:5px;display:inline-block;margin:26px 0 16px}
/* Mise en page en GRILLE reguliere (et non plus en masonry columns), pour un rendu
   100% deterministe : toutes les pepites s'affichent dans l'ordre de saisie, alignees
   par rangee. Plus de redistribution surprise selon la taille des images. */
.pep-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:34px 18px;align-items:start}
.pep-session{position:relative}
.pep-note{margin:0;cursor:zoom-in;display:block;position:relative;padding-top:8px;--rot:0deg}
/* Rotation aleatoire portee par .pep-paper (visuelle, n'affecte pas le flux columns) ;
   variable --rot pour pouvoir AJOUTER un scale au survol SANS ecraser la rotation
   (sinon le retour a rotate(0) faisait "clignoter" la carte). */
.pep-note:nth-child(3n){--rot:-2deg}
.pep-note:nth-child(3n+1){--rot:1.4deg}
.pep-note:nth-child(3n+2){--rot:-.8deg}
.pep-note:nth-child(5n){--rot:2.2deg}
.pep-paper{background:#fffef8;padding:10px;border-radius:2px;box-shadow:2px 4px 12px rgba(0,0,0,.13);transition:transform .2s,box-shadow .2s;transform-origin:top center;display:block;will-change:transform;transform:rotate(var(--rot))}
.pep-note:hover{z-index:5}
.pep-note:hover .pep-paper{transform:rotate(var(--rot)) scale(1.04);box-shadow:4px 8px 22px rgba(0,0,0,.22)}
.pep-note::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:15px;height:15px;border-radius:50%;background:var(--or);box-shadow:0 1px 3px rgba(0,0,0,.35);z-index:6}
.pep-scan{width:100%;border-radius:1px;display:block;background:#e4e4e4;aspect-ratio:4/3;overflow:hidden}
/* Hauteur deterministe AVANT chargement des images -> aucun reflow columns en cascade. */
.pep-scan img{width:100%;height:100%;object-fit:cover;display:block;border-radius:1px}
.pep-scan.tall{aspect-ratio:3/4}.pep-scan.wide{aspect-ratio:3/2}

@media(max-width:820px){
  .pep-wall{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:24px 14px}
  .pep-paper{transform:none!important}
}

/* ===== MENTIONS LEGALES ===== */
.ml{max-width:720px}
.ml-toc{background:var(--gris-bg);border-radius:6px;padding:20px 24px;margin-bottom:32px}
.ml-toc__h{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);font-weight:700;margin-bottom:12px}
.ml-toc ol{list-style:none;counter-reset:ml;columns:2;column-gap:32px}
.ml-toc li{counter-increment:ml;margin:5px 0}
.ml-toc a{text-decoration:none;color:var(--noir);font-size:14px;display:flex;gap:8px}
.ml-toc a::before{content:counter(ml,decimal-leading-zero);color:var(--or-txt);font-size:12px;font-weight:700}
.ml-body h2,.ml-body h3{font-size:15px;font-weight:700;text-transform:uppercase;margin:26px 0 8px;scroll-margin-top:20px}
.ml-body p{font-size:14px;line-height:1.7;color:#333;margin-bottom:8px}
.ml-body a{color:var(--or-txt);text-decoration:none;font-weight:700}

/* ===== TIMELINE MEDIATION ===== */
.pep-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:22px 0 18px}
.tl{position:relative;margin-top:14px;padding-left:30px}
.tl::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--gris-ligne)}
.tl-p{position:relative;padding:20px 0 28px}
.tl-p::before{content:"";position:absolute;left:-27px;top:28px;width:12px;height:12px;border-radius:50%;background:var(--or);border:3px solid #fff;box-shadow:0 0 0 1px var(--gris-ligne)}
.tl-y{font-variant-numeric:tabular-nums;font-size:13px;font-weight:700;color:var(--or-txt)}
.tl-t{font-size:21px;font-weight:700;margin:4px 0 14px}
.tl-meta{display:grid;grid-template-columns:130px 1fr;gap:4px 14px;max-width:680px;margin-bottom:14px}
.tl-meta dt{font-size:12px;color:#888}.tl-meta dd{font-size:14px;line-height:1.5}
.tl-text{font-size:15px;line-height:1.7;color:#333;max-width:680px}
.tl-audio{margin-top:14px;display:flex;align-items:center;gap:14px;background:var(--gris-bg);border-radius:5px;padding:12px 16px;max-width:480px}
.tl-audio audio{width:100%}
.tl-empty{color:var(--gris-faible);font-size:14px;padding:16px 0}

/* ===== LIGNE ARTISTIQUE : liste des creations ===== */
.crea-list{max-width:820px}
.crea-row{display:grid;grid-template-columns:64px 1fr auto;gap:16px;padding:12px 0;border-bottom:1px solid var(--gris-ligne);text-decoration:none;color:var(--noir);align-items:baseline}
.crea-row:hover{color:var(--or-txt)}
.crea-row .y{color:#999;font-variant-numeric:tabular-nums}
.crea-row .t{font-weight:700}
.crea-row .a{font-size:13px;color:var(--gris-faible)}

/* ===== PARTENAIRES ===== */
.pt-collabs{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;max-width:900px}
.pt-collab{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border:1px solid var(--gris-ligne);border-radius:5px;text-decoration:none;color:var(--noir);transition:.15s}
.pt-collab:hover{border-color:var(--or);background:#fffdf5}
.pt-collab .who{font-weight:700;font-size:15px}.pt-collab .role{font-size:12px;color:#888}
/* Icone lien externe : SVG monochrome jaune charte (remplace l'emoji bleu). */
.ext-ico{display:inline-block;vertical-align:-1px;flex:0 0 auto}
.pt-arrow{color:var(--or);display:inline-flex}
.il-archive .ext-ico,.sb__intranet .ext-ico{color:var(--or)}
.pt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;max-width:900px}
.pt-logo{aspect-ratio:16/9;background:#f4f4f2;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#888;text-align:center;padding:0 12px;filter:grayscale(1);transition:.2s;text-decoration:none}
.pt-logo:hover{filter:grayscale(0);color:var(--noir)}
.pt-logo img{max-width:100%;max-height:100%;object-fit:contain}

/* ===== CALENDRIER ===== */
.cal-fb{display:flex;flex-direction:column;gap:12px;margin-bottom:26px}
.cal-fg{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.cal-fl{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);font-weight:700;width:74px;flex:0 0 auto}
.chip{border:1px solid #ccc;font-size:13px;padding:7px 14px;border-radius:20px;display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:background .15s,color .15s,border-color .15s;background:none;font-family:inherit;font-weight:500;color:var(--noir)}
.chip:hover{border-color:var(--noir)}
.chip.on{background:var(--noir);color:#fff;border-color:var(--noir)}
.chip:focus{outline:none}
.cal-select{font-family:inherit;font-size:14px;font-weight:500;padding:8px 34px 8px 16px;border:1px solid #ccc;border-radius:20px;background:#fff;color:var(--noir);cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%23000' stroke-width='1.6'/></svg>");background-repeat:no-repeat;background-position:right 13px center}
.cal-select:hover{border-color:var(--noir)}
.cal-select:focus{outline:none;border-color:var(--or);box-shadow:0 0 0 3px rgba(233,180,0,.18)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex:0 0 auto}
.dot--outline{border:1.5px solid var(--noir);background:transparent}
.cal-season{display:none}
.cal-season.on{display:block}
.cal-m{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);border-bottom:2px solid var(--noir);padding-bottom:6px;margin:24px 0 4px;font-weight:700}
.cal-row{display:grid;grid-template-columns:120px 14px 1fr auto;gap:14px;padding:13px 0;border-bottom:1px solid var(--gris-ligne);align-items:center}
.cal-row .d{font-variant-numeric:tabular-nums;font-size:13px;color:var(--gris-faible)}
.cal-row .d strong{color:var(--noir);font-weight:700;font-size:14px}
.cal-h{color:var(--gris-faible);font-weight:400}
.cal-row .l{font-size:12px;color:#888}
.cal-row--residence{background:var(--gris-bg);margin:0 -10px;padding-left:10px;padding-right:10px}
.cal-row--annule{opacity:.5;text-decoration:line-through}
.cal-pub{font-size:11px;color:var(--gris-faible);text-transform:uppercase;letter-spacing:.06em;margin-left:6px}
.cal-empty{color:var(--gris-faible);font-size:14px;padding:16px 0}

@media(max-width:820px){
  .home-fgrid{grid-template-columns:1fr;gap:22px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .cards2{grid-template-columns:1fr}
  .cal-row{grid-template-columns:96px 12px 1fr;gap:10px}
  .cal-row .l{display:none}
}

/* ===== PAGE BONUS / REFERENCES (x, y et moi ?) ===== */
.refs{max-width:780px}
/* Chapitres (rubriques du sommaire) : bien detaches les uns des autres. */
.refs h2{font-size:21px;font-weight:700;margin:74px 0 24px;scroll-margin-top:64px}
.refs h2:first-child{margin-top:8px}
.refs h3{font-size:17px;font-weight:700;margin:34px 0 12px;padding-left:12px;border-left:3px solid var(--or);scroll-margin-top:64px}
.refs p{margin:0 0 12px;line-height:1.6;font-size:15px}
/* Bouton de telechargement (depliant) en fin du bloc contacts. */
.refs-dl{margin:26px 0 12px}
.refs-dl a{display:inline-block;background:var(--or);color:var(--noir);font-weight:700;font-size:14px;padding:10px 18px;border-radius:4px;text-decoration:none}
.refs-dl a:hover{background:var(--noir);color:#fff}
.refs a{color:var(--or-txt);font-weight:700;text-decoration:none}
.refs a:hover{color:var(--noir);text-decoration:underline}

/* Catalogue de ressources en vignettes (page bonus references) */
.refs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:44px 16px;margin:10px 0 8px}
.rc{display:flex;flex-direction:column;gap:8px}
.rc-img{display:block;aspect-ratio:3/4;border-radius:5px;overflow:hidden;background:var(--gris-bg);border:1px solid var(--gris-ligne)}
.rc-img img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);transition:transform .25s,filter .25s}
.rc:hover .rc-img img{filter:grayscale(0)}
a.rc-img:hover img{transform:scale(1.05)}
.rc-t{font-size:13px;line-height:1.35;color:var(--noir);text-decoration:none;font-weight:600}
a.rc-t:hover{color:var(--or-txt);text-decoration:underline}
.rc-more{font-size:12px;margin-top:-2px}
.rc-more a{color:var(--or-txt);font-weight:700;text-decoration:none;margin-right:10px}
.rc-more a:hover{text-decoration:underline}
@media(max-width:820px){.refs-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}

/* ===== PAGE 404 ===== */
.e404{max-width:680px;margin-top:40px}
.e404__lead{font-size:17px;line-height:1.7;color:#444;margin:18px 0 32px}
.e404__actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:50px}
.e404__nav{padding-top:32px;border-top:1px solid var(--gris-ligne)}
.e404__nav-h{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);font-weight:700;margin-bottom:14px}
.e404__nav ul{list-style:none;padding:0;margin:0;display:flex;gap:24px;flex-wrap:wrap}
.e404__nav a{text-decoration:none;color:var(--noir);font-size:15px;border-bottom:1px solid transparent;padding-bottom:2px;transition:.15s}
.e404__nav a:hover{color:var(--or-txt);border-bottom-color:var(--or)}

/* ===== PAGE CGV (slug = cgv) ===== */
.cgv{max-width:1100px;font-family:'Akzidenz','Helvetica Neue',Arial,sans-serif}
.cgv-body, .cgv-body *{font-family:'Akzidenz','Helvetica Neue',Arial,sans-serif}

/* Sommaire elargi : 2 colonnes, plus de largeur, plus aere */
.cgv-toc{background:var(--gris-bg);border-radius:6px;padding:24px 30px;margin-bottom:36px}
.cgv-toc__h{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or-txt);font-weight:700;margin-bottom:14px}
.cgv-toc ol{list-style:none;counter-reset:cgv;columns:2;column-gap:40px}
.cgv-toc li{counter-increment:cgv;margin:6px 0;break-inside:avoid}
.cgv-toc a{text-decoration:none;color:var(--noir);font-size:14px;display:flex;gap:8px;line-height:1.35}
.cgv-toc a::before{content:counter(cgv,decimal-leading-zero);color:var(--or-txt);font-size:12px;font-weight:700;flex-shrink:0}
.cgv-toc a:hover{color:var(--or-txt)}

/* Corps : h2 en casse normale (pas de majuscules forcees), tailles harmonisees */
.cgv-body h2{font-size:18px;font-weight:700;color:var(--noir);text-transform:none;margin:36px 0 12px;letter-spacing:0;scroll-margin-top:20px;line-height:1.3}
.cgv-body h2:first-child{margin-top:0}
.cgv-body p{font-size:15px;line-height:1.7;color:#222;margin:0 0 12px;text-align:justify;-webkit-hyphens:auto;hyphens:auto}
.cgv-body ul{font-size:15px;line-height:1.7;color:#222;margin:0 0 12px;padding-left:22px}
.cgv-body li{margin:4px 0}
.cgv-body strong{font-weight:700}
.cgv-body em{font-style:italic;color:#444}
.cgv-body a{color:var(--or-txt);text-decoration:none;font-weight:700}
.cgv-body a:hover{text-decoration:underline}

@media(max-width:820px){
  .cgv-toc ol{columns:1}
}
