/* =========================================================================
   Rushes — design system « Album / Veillée »
   Tokens bi-mode + composants. Le mode est posé par base.html sur
   <html data-theme="light|dark"> AVANT le premier paint (script inline).
   ========================================================================= */

/* ---------- Tokens : Album (clair, défaut) ---------- */
:root {
  color-scheme: light;
  --bg: #faf6ef;
  --panel: #ffffff;
  --panel-2: #f1e9db;
  --border: #e7ddcd;
  --border-strong: #cdbda4;
  --fg: #2c2823;
  --muted: #8d8475;
  --accent: #b9622f;
  --accent-fg: #fff8f2;
  --danger: #a8433c;
  --ok-bg: #4a7c59;   --ok-fg: #f2f7f3;
  --warn-bg: #a8862e; --warn-fg: #fff7e0;
  --bad-bg: #a8433c;  --bad-fg: #fdeae6;
  --mark-bg: #f7e3a1; --mark-fg: #4a3a10;
  --shadow: 0 2px 6px rgba(120, 95, 60, .14);
  --shadow-lift: 0 4px 14px rgba(120, 95, 60, .2);
}

/* ---------- Tokens : Veillée (sombre) ---------- */
[data-theme="dark"] {
  color-scheme: dark;
  --bg: #161310;
  --panel: #201b16;
  --panel-2: #2b241c;
  --border: #332b22;
  --border-strong: #4d4234;
  --fg: #ece5d8;
  --muted: #a39782;
  --accent: #e3a13f;
  --accent-fg: #1d1812;
  --danger: #d97862;
  --ok-bg: #3a5c46;   --ok-fg: #dcefe2;
  --warn-bg: #6e5a22; --warn-fg: #f0e3bd;
  --bad-bg: #6e352c;  --bad-fg: #f3d9d2;
  --mark-bg: #5a4720; --mark-fg: #ffe2a0;
  --shadow: 0 2px 8px rgba(0, 0, 0, .4);
  --shadow-lift: 0 4px 16px rgba(0, 0, 0, .5);
}

/* ---------- Base ---------- */
* { box-sizing: border-box; }
body { margin: 0; font: 15px/1.55 system-ui, sans-serif; background: var(--bg); color: var(--fg); }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
h2 { font-size: 22px; font-weight: 700; margin: 4px 0 16px; }
h3 { font-size: 17px; font-weight: 700; margin: 20px 0 10px; }
h2 .muted, h3 .muted { font-weight: 400; font-size: .75em; }
code { background: var(--panel-2); padding: 1px 5px; border-radius: 5px; font-size: .9em; }
mark { background: var(--mark-bg); color: var(--mark-fg); border-radius: 3px; padding: 0 2px; }
.muted { color: var(--muted); }
.label { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--muted);
         margin: 14px 0 6px; font-weight: 600; }

/* ---------- Nav ---------- */
.topnav { display: flex; gap: 18px; align-items: center; padding: 12px 24px;
          background: var(--panel); border-bottom: 1px solid var(--border); }
.topnav .brand { font-weight: 800; font-size: 17px; color: var(--fg); }
.topnav a { color: var(--fg); opacity: .85; }
.topnav a:hover { opacity: 1; color: var(--accent); text-decoration: none; }
.topnav a.active { color: var(--accent); opacity: 1; text-decoration: underline; text-underline-offset: 6px; }
.topnav .who { color: var(--muted); }
.spacer { flex: 1; }
.navsearch input { min-width: 220px; }

/* Bouton thème : l'icône montre le mode VERS lequel on bascule */
.theme-toggle::after { content: '🌙'; }
[data-theme="dark"] .theme-toggle::after { content: '☀️'; }

main { padding: 24px; max-width: 1500px; margin: 0 auto; }

/* ---------- Layout ---------- */
.layout { display: flex; gap: 24px; }
/* Flex items : min-width:auto interdit de rétrécir sous le min-content du contenu — un
   filmstrip nowrap de 400+ vignettes flex:0 0 auto gonfle la section (et le player
   width:100%) à des dizaines de milliers de px. min-width:0 rend l'overflow-x:auto effectif. */
.layout > * { min-width: 0; }
.layout-main { flex: 2.6; }
.layout-side { flex: 1; min-width: 300px; }
.layout-side .seg { margin-bottom: 10px; }
.sidebar { flex: 0 0 210px; align-self: flex-start; }
.grow { flex: 1; }

/* Mode théâtre (page vidéo) : tout passe en colonne, player pleine largeur */
.layout.theater { flex-direction: column; }
.layout.theater .layout-side { min-width: 0; }
.layout.theater .transcript { max-height: 40vh; }

/* ---------- Cartes & surfaces ---------- */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 18px; }
.card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
        overflow: hidden; box-shadow: var(--shadow); }
a.card { color: var(--fg); display: block; transition: box-shadow .15s, transform .15s; }
a.card:hover { text-decoration: none; box-shadow: var(--shadow-lift); transform: translateY(-1px); }
.cover { display: block; width: 100%; aspect-ratio: 16/9; object-fit: cover; background: #000; }
.card.portrait .cover { aspect-ratio: 1/1; }
.card .body { padding: 12px 14px; }
.hrow { display: flex; gap: 12px; align-items: center; padding: 10px 12px; }
.hrow img { width: 120px; height: 68px; object-fit: cover; border-radius: 8px; flex: 0 0 auto; }
.hrow img.thumb-m { width: 80px; height: 80px; }
.crop { width: 96px; height: 96px; object-fit: cover; border-radius: 6px; }
.crops { display: flex; gap: 4px; padding: 6px; flex-wrap: wrap; }
.vstack { display: flex; flex-direction: column; gap: 10px; }
.panel { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px; }
.panel .label:first-child { margin-top: 0; }
.layout-main > .panel { margin-top: 12px; }
.picker { background: var(--panel-2); padding: 10px 12px; border-radius: 10px; margin-top: 8px; }
.picker label { display: block; padding: 3px 0; }
.placeholder { background: var(--panel-2); color: var(--muted); }
.portrait-ph { display: flex; align-items: center; justify-content: center; font-size: 34px; }
.thumb-wrap { position: relative; }
.card-fav { position: absolute; top: 6px; right: 8px; background: rgba(0, 0, 0, .35);
            border-radius: 999px; padding: 1px 4px; }

/* ---------- Boutons ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px;
       padding: 8px 16px; min-height: 34px; border-radius: 8px;
       border: 1.5px solid var(--border-strong); background: transparent; color: var(--fg);
       font: 600 14px system-ui, sans-serif; cursor: pointer; transition: .12s; }
.btn:hover { border-color: var(--accent); color: var(--accent); }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.btn-primary { background: var(--accent); border-color: var(--accent); color: var(--accent-fg); }
.btn-primary:hover { filter: brightness(1.07); color: var(--accent-fg); }
.btn-danger { border-color: var(--danger); color: var(--danger); }
.btn-danger:hover { background: var(--danger); color: var(--bg); }
.btn-sm { padding: 5px 10px; min-height: 28px; font-size: 12.5px; }
.btn-icon { padding: 6px 9px; min-height: 0; }
.fav { cursor: pointer; background: none; border: none; font-size: 18px; color: var(--accent); padding: 0 2px; }
.fav:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }

/* ---------- Chips (tags d'information ; a.chip = filtre cliquable) ---------- */
.chip { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px;
        border-radius: 999px; background: var(--panel-2); color: var(--fg);
        font-size: 12px; border: 1px solid transparent; }
a.chip:hover { border-color: var(--accent); text-decoration: none; }
.chip.active { background: var(--accent); color: var(--accent-fg); }
.chip.ok { background: var(--ok-bg); color: var(--ok-fg); }
.chip.ok .fav { color: var(--ok-fg); }
.chip .fav { font-size: 13px; }

/* ---------- Segmented control ---------- */
.seg { display: inline-flex; background: var(--panel-2); border-radius: 999px; padding: 3px; gap: 2px; }
.seg > * { border: none; background: transparent; padding: 5px 14px; border-radius: 999px;
           font: 600 13px system-ui, sans-serif; color: var(--muted); cursor: pointer; }
.seg > a { text-decoration: none; }
.seg > .active { background: var(--accent); color: var(--accent-fg); }
.seg > .disabled { cursor: not-allowed; opacity: .5; }

/* ---------- Formulaires ---------- */
input, select, textarea {
  background: var(--panel); border: 1px solid var(--border-strong); color: var(--fg);
  padding: 8px 12px; border-radius: 8px; font: 14px system-ui, sans-serif;
}
input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--accent); outline-offset: -1px; border-color: var(--accent);
}
::placeholder { color: var(--muted); opacity: 1; }
input[type="checkbox"] { accent-color: var(--accent); width: 16px; height: 16px; padding: 0; }
select { cursor: pointer; }
.sidebar select { width: 100%; }
.row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.inline-form { display: inline-flex; gap: 6px; align-items: center; }
.w-s { width: 110px; } .w-m { width: 170px; } .w-full { width: 100%; }
.search-input { width: 100%; max-width: 480px; }
.login-card { max-width: 340px; margin: 10vh auto; display: grid; gap: 12px; }
.login-card [role="alert"] { color: var(--danger); margin: 0; }

/* ---------- Player & page vidéo ---------- */
.player-wrap { position: relative; }
.player { width: 100%; display: block; background: #000; border-radius: 12px; box-shadow: var(--shadow); }
.theater-btn { position: absolute; top: 10px; right: 10px; border: none; border-radius: 8px;
               background: rgba(0, 0, 0, .45); color: #fff; padding: 6px 10px; font-size: 14px;
               cursor: pointer; opacity: .65; transition: opacity .12s; }
.theater-btn:hover { opacity: 1; }
.filmstrip { display: flex; gap: 8px; overflow-x: auto; padding: 6px 0 10px; scroll-snap-type: x proximity; cursor: grab; }
.filmstrip img { height: 72px; border-radius: 8px; cursor: pointer; flex: 0 0 auto; scroll-snap-align: start;
                 user-select: none; -webkit-user-drag: none; }
.filmstrip:active, .filmstrip:active img { cursor: grabbing; }
/* Boutons de défilement du filmstrip (le scroll latéral natif est peu pratique).
   min-width:0 sur le strip imbriqué : même fix min-content que .layout > *. */
.filmstrip-wrap { display: flex; align-items: stretch; gap: 6px; }
.filmstrip-wrap .filmstrip { flex: 1; min-width: 0; }
.strip-nav { border: 1px solid var(--border-strong); background: var(--panel); color: var(--muted);
             border-radius: 8px; padding: 0 9px; cursor: pointer; font-size: 13px; }
.strip-nav:hover { border-color: var(--accent); color: var(--accent); }
.strip-nav:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.scene-caption { font-weight: 600; font-size: 15.5px; margin: 0 0 2px; }
#scene-contribs, #video-contribs { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin: 6px 0 12px; }
/* Panneau scène : aération interne régulière (grille + gaps, marges internes neutralisées) */
#scene-meta { display: grid; gap: 16px; padding: 22px 24px; }
#scene-meta p { margin: 0; }
#picker:empty { display: none; }
#in-scene { display: grid; gap: 10px; }
#in-scene .label { margin: 0; }
#scene-meta #scene-contribs { margin: 0; }

/* ---------- Transcription ---------- */
.transcript { max-height: 70vh; overflow: auto; }
.tline { cursor: pointer; padding: 6px 8px; border-radius: 6px; }
.tline:hover { background: var(--panel-2); }
.tline .t { color: var(--muted); font-size: 11px; font-variant-numeric: tabular-nums; margin-right: 4px; }
.tline.active, [data-scene-start].active { outline: 2px solid var(--accent); background: var(--panel-2); }

/* ---------- Commentaires ---------- */
.comment { padding: 8px 0; border-bottom: 1px solid var(--border); }

/* ---------- Bannières & matrice de couverture ---------- */
.banner { display: inline-flex; gap: 8px; align-items: center; padding: 10px 14px;
          border-radius: 10px; font-size: 13.5px; margin: 4px 0 12px; }
.banner-warn { background: var(--warn-bg); color: var(--warn-fg); }
.banner-warn code { background: rgba(0, 0, 0, .18); color: inherit; }
.cov-table { border-collapse: collapse; font-size: 12.5px; }
.cov-table th { padding: 3px 10px; font-weight: 600; text-align: left; }
.cov-table td { padding: 3px 12px; white-space: nowrap; }
td.cov { text-align: center; border: 1px solid var(--bg); }
.cov-0 { background: var(--bad-bg); color: var(--bad-fg); }
.cov-low { background: var(--warn-bg); color: var(--warn-fg); }
.cov-ok { background: var(--ok-bg); color: var(--ok-fg); }
.wrap-scroll { overflow-x: auto; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  main { padding: 16px; }
  .topnav { flex-wrap: wrap; gap: 10px; padding: 10px 16px; }
  .navsearch input { min-width: 140px; }
  .layout { flex-direction: column; }
  .layout-side { min-width: 0; }
  .sidebar { flex: auto; }
}
