:root{
--c-bg:#f2f0eb;--c-surface:#fbfaf7;--c-ink:#1e2530;--c-muted:#64748b;--c-line:#dcd9d1;
--c-accent:#475569;--c-accent-ink:#fff;--c-ok:#3f7d58;--c-danger:#9b3030;
--fs-caption:.694rem;--fs-small:.833rem;--fs-body:1rem;--fs-h6:1.2rem;--fs-h4:1.728rem;--fs-h3:2.074rem;--fs-h2:2.488rem;--fs-h1:2.986rem;
--lh-tight:1.15;--lh-body:1.65;--ff-display:"Fraunces",Georgia,"Times New Roman",serif;
--ff-body:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:24px;--sp-6:32px;--sp-7:48px;--sp-8:64px;--sp-9:96px;
--r-sm:8px;--r-md:12px;--r-lg:18px;--shadow:0 1px 2px rgba(30,37,48,.05),0 10px 30px -16px rgba(30,37,48,.22);--maxw:1200px;
}
*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--c-bg);color:var(--c-ink);font-family:var(--ff-body);font-size:var(--fs-body);line-height:var(--lh-body);-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--ff-display);line-height:var(--lh-tight);letter-spacing:-.02em;font-weight:600;margin:0}
a{color:var(--c-accent)}img{max-width:100%;display:block}
:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
/* login */
.auth{min-height:100dvh;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr)}
.card{display:flex;flex-direction:column;justify-content:center;max-width:420px;width:100%;margin:0 auto;padding:var(--sp-8) var(--sp-7)}
.eyebrow{font-size:var(--fs-small);letter-spacing:.14em;text-transform:uppercase;color:var(--c-muted);margin:0 0 var(--sp-2)}
.auth h1{font-size:var(--fs-h1);margin:0 0 var(--sp-3)}
.sub{color:var(--c-muted);margin:0 0 var(--sp-6)}
label{display:block;font-size:var(--fs-small);font-weight:600;margin:var(--sp-4) 0 var(--sp-1)}
input{width:100%;padding:12px 14px;border:1px solid var(--c-line);border-radius:var(--r-sm);background:#fff;font:inherit}
input:focus{outline:2px solid #cfd6df;border-color:var(--c-accent)}
.btn{margin-top:var(--sp-6);width:100%;padding:13px;border:none;border-radius:var(--r-sm);background:var(--c-accent);color:var(--c-accent-ink);font:inherit;font-weight:600;cursor:pointer}
.btn:hover{background:#3a4658}.btn:disabled{opacity:.6;cursor:wait}
.err{background:#f6e7e7;border:1px solid #e0bcbc;color:var(--c-danger);padding:9px 12px;border-radius:var(--r-sm);font-size:var(--fs-small);margin:var(--sp-4) 0 0}
.help{margin-top:var(--sp-6);font-size:var(--fs-small);color:var(--c-muted)}
.logocol{display:flex;align-items:center;justify-content:flex-end;padding:24px 0 24px 24px;background:var(--c-bg)}
.logocol img{max-height:46vh;width:auto;max-width:100%;object-fit:contain}
.aside{position:relative;background:#000;overflow:hidden}
.aside::before{content:"";position:absolute;inset:0;background:url("/medias/bg/accueil.jpg") center/cover no-repeat}



@media(max-width:1100px){.auth{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.logocol{display:none}}
@media(max-width:720px){.auth{grid-template-columns:1fr}.logocol{display:flex;align-items:center;justify-content:flex-end;padding:24px 0 24px 24px;background:var(--c-bg)}.card{margin:0 auto;padding:var(--sp-8) var(--sp-5)}}
/* espace */
.bar{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);background:var(--c-surface);border-bottom:1px solid var(--c-line);position:sticky;top:0;z-index:5}
.brand{font-family:var(--ff-display);font-weight:600;font-size:var(--fs-h6);margin-right:auto}
.brand span{color:var(--c-muted);font-weight:400}
.right{display:flex;align-items:center;gap:var(--sp-4)}
.who{font-size:var(--fs-small);color:var(--c-muted)}
.linkbtn{background:none;border:none;color:var(--c-accent);font:inherit;font-size:var(--fs-small);cursor:pointer;padding:4px}
.linkbtn.danger{color:var(--c-danger)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:var(--sp-7) var(--sp-5) var(--sp-9)}
.state{text-align:center;color:var(--c-muted);padding:var(--sp-9) var(--sp-4)}
.head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4);margin-bottom:var(--sp-6)}
.head h1{font-size:var(--fs-h2)}
.filters{display:flex;gap:var(--sp-2);flex-wrap:wrap}
.filters button{border:1px solid var(--c-line);background:#fff;border-radius:999px;padding:6px 14px;font:inherit;font-size:var(--fs-small);color:var(--c-muted);cursor:pointer}
.filters button.on{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:var(--sp-5)}
.item{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;display:flex;flex-direction:column;text-align:left;padding:0;font:inherit;color:inherit;transition:transform .15s ease,box-shadow .15s ease}
.item:hover{transform:translateY(-2px);box-shadow:0 1px 2px rgba(30,37,48,.05),0 16px 36px -18px rgba(30,37,48,.3)}
.thumb{aspect-ratio:16/9;background:#e7e3da;display:flex;align-items:center;justify-content:center;color:var(--c-muted)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb .ic{font-size:var(--fs-h2);font-family:var(--ff-display)}
.meta{padding:var(--sp-4)}
.meta h3{font-family:var(--ff-body);font-size:var(--fs-body);font-weight:600;letter-spacing:0;margin:0 0 var(--sp-2)}
.pills{display:flex;gap:4px;flex-wrap:wrap}
.pill{font-size:var(--fs-caption);font-weight:600;padding:2px 8px;border-radius:999px;background:#e7e3da;color:var(--c-accent)}
.type{font-size:var(--fs-caption);color:var(--c-muted);text-transform:uppercase;letter-spacing:.06em}
dialog{border:none;border-radius:var(--r-lg);padding:0;max-width:min(960px,94vw);width:100%;box-shadow:0 30px 80px -20px rgba(0,0,0,.5)}
dialog::backdrop{background:rgba(20,24,31,.6)}
#viewer{background:#000}
#vBody iframe,#vBody embed{width:100%;height:min(76vh,540px);border:0;display:block}
.close{position:absolute;top:10px;right:12px;background:rgba(0,0,0,.55);color:#fff;border:none;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:16px;z-index:2}
#pwdDlg{background:var(--c-surface);padding:var(--sp-6)}
#pwdDlg h2{font-size:var(--fs-h4);margin:0 0 var(--sp-4)}
.actions{display:flex;gap:var(--sp-3);justify-content:flex-end;margin-top:var(--sp-5)}
.btn.ghost{background:#fff;color:var(--c-ink);border:1px solid var(--c-line);margin-top:0}
#pwdDlg .btn{margin-top:0;width:auto}
.muted{color:var(--c-muted)}
@media(max-width:560px){.wrap{padding:var(--sp-5) var(--sp-4) var(--sp-8)}.head h1{font-size:var(--fs-h3)}}

/* ===== Mode administrateur dans l'espace ===== */
.adminbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 24px;
  background:#1e2530;color:#fff;font-size:var(--fs-small)}
.adminbar .ab-tag{font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:var(--fs-caption);
  background:rgba(255,255,255,.12);padding:3px 10px;border-radius:999px;margin-right:auto}
.adminbar .ab-btn{background:#475569;color:#fff;border:none;border-radius:7px;padding:7px 13px;
  font:inherit;font-size:var(--fs-small);font-weight:600;cursor:pointer;text-decoration:none;display:inline-block}
.adminbar .ab-btn:hover{background:#5a6b82;text-decoration:none}
.adminbar .ab-btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.3)}
.adminbar .ab-toggle{display:inline-flex;align-items:center;gap:6px;color:#cbd5e1;cursor:pointer}
.adminbar .ab-toggle input{width:auto}

.item-admin{display:flex;gap:6px;padding:0 var(--sp-4) var(--sp-4);flex-wrap:wrap}
.item-admin .mini{flex:1;min-width:64px;border:1px solid var(--c-line);background:#fff;border-radius:7px;
  padding:6px 8px;font:inherit;font-size:var(--fs-caption);font-weight:600;color:var(--c-accent);cursor:pointer}
.item-admin .mini:hover{background:#f0eee8}
.item-admin .mini.danger{color:var(--c-danger);border-color:#e3c4c4}
.item.is-hidden{opacity:.6}
.pill.off{background:#efe3e3;color:#9b3030}

/* éditeur ressource */
#edDlg{background:var(--c-surface);padding:var(--sp-6);max-width:min(640px,94vw)}
#edDlg h2{font-size:var(--fs-h4);margin:0 0 var(--sp-4)}
#edDlg label{display:block;font-size:var(--fs-small);font-weight:600;margin:var(--sp-3) 0 var(--sp-1)}
#edDlg input[type=text],#edDlg input:not([type]),#edDlg input[type=file],#edDlg select,#edDlg #ed-titre,#edDlg #ed-desc,#edDlg #ed-yt{
  width:100%;padding:10px 12px;border:1px solid var(--c-line);border-radius:var(--r-sm);font:inherit;background:#fff}
.ed-row{display:flex;gap:12px;flex-wrap:wrap}
.ed-disc{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}
.ed-discitem{display:inline-flex!important;align-items:center;gap:6px;font-weight:500!important;margin:0!important}
.ed-discitem input{width:auto}
.ed-check{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-weight:500}
.ed-check input{width:auto}

/* onglets connexion/inscription */
.authtabs{display:flex;gap:6px;background:#e9e6de;padding:5px;border-radius:10px;margin-bottom:18px}
.authtabs .atab{flex:1;border:none;background:none;padding:9px;border-radius:7px;font:inherit;font-size:.88rem;font-weight:600;color:var(--c-muted);cursor:pointer}
.authtabs .atab.on{background:#fff;color:var(--c-ink);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.ok{background:#eaf3ee;border:1px solid #bcdcc8;color:#3f7d58;padding:9px 12px;border-radius:8px;font-size:.83rem;margin:10px 0 0}

/* groupe logo + connexion dans la colonne gauche, collé à droite contre l'image */
.leftwrap{display:flex;align-items:stretch;justify-content:flex-end;gap:8px}
.leftwrap .logocol{flex:0 0 auto}
.leftwrap .card{margin:0}
@media(max-width:720px){.leftwrap{flex-direction:column;justify-content:center}.leftwrap .logocol{display:none}}

/* bouton mot de passe oublié — visible, pleine largeur sous le bouton connexion */
.forgot-btn{display:block;width:100%;margin-top:14px;background:none;border:none;color:#c0392b;font:inherit;font-size:1.05rem;font-weight:700;text-decoration:underline;cursor:pointer;padding:8px}
.forgot-btn:hover{color:#9b3030}

/* ===== Vérificateur d'adresse e-mail (encart visible) ===== */
.checker{background:#eef1f4;border:1px solid #d6dde4;border-radius:14px;padding:18px 20px;margin-bottom:20px}
.checker-title{margin:0 0 4px;font-family:var(--ff-display);font-size:1.15rem;font-weight:600;color:var(--c-ink)}
.checker-sub{margin:0 0 12px;font-size:.85rem;color:var(--c-muted)}
.checker-row{display:flex;gap:8px}
.checker-row input{flex:1;padding:11px 14px;border:1px solid #c9d2da;border-radius:9px;font:inherit;background:#fff}
.checker-row button{background:var(--c-accent);color:#fff;border:none;border-radius:9px;padding:11px 20px;font:inherit;font-weight:600;cursor:pointer;white-space:nowrap}
.checker-row button:hover{background:#3a4555}
.checker-result{margin-top:12px;padding:12px 14px;border-radius:9px;font-size:.88rem;line-height:1.5}
.checker-result.ok{background:#e7f3ec;border:1px solid #b8dcc6;color:#27613f}
.checker-result.info{background:#e8eef6;border:1px solid #bcccdf;color:#2b4a73}
.checker-result.warn{background:#fbeee6;border:1px solid #f0cba8;color:#9a5418}
.checker-result a{color:inherit;font-weight:600}
.checker-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.ca-btn{background:#27613f;color:#fff;border:none;border-radius:8px;padding:8px 14px;font:inherit;font-size:.83rem;font-weight:600;cursor:pointer}
.ca-btn.alt{background:#fff;color:#27613f;border:1px solid #b8dcc6}
.checker-result.warn .ca-btn{background:#9a5418}

/* ===== Coordonnées association ===== */
.contact-box{margin-top:20px;padding:14px 16px;background:#f7f5f0;border:1px solid #e4e0d7;border-radius:10px;text-align:center}
.contact-title{margin:0 0 4px;font-weight:600;color:var(--c-ink);font-size:.92rem}
.contact-box p{margin:0;font-size:.88rem;color:var(--c-muted)}
.contact-box a{color:var(--c-accent);font-weight:600}

/* ===== Encart "1ère visite" superposé sur l'image de droite ===== */
.aside{display:flex;align-items:center;justify-content:center;padding:40px}
.aside .checker{position:relative;z-index:2;max-width:440px;width:100%;margin:0;
  background:rgba(251,250,247,.94);backdrop-filter:blur(8px);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.5)}
@media(max-width:1100px){
  /* en tablette : on remontre l'aside (sinon l'encart disparaissait) */
  .auth{grid-template-columns:minmax(160px,220px) minmax(0,1fr) minmax(0,1fr)}
  .aside{display:flex}
}
@media(max-width:820px){
  .auth{grid-template-columns:1fr}
  .aside{padding:24px;min-height:auto}
  .aside .checker{max-width:none}
}

/* bloc contact intégré dans l'encart Première visite */
.checker .contact-box{margin-top:16px;background:rgba(255,255,255,.5);border:1px solid var(--c-line)}
