@font-face{ font-family:'Inter'; src:url('assets/fonts/inter-latin.woff2') format('woff2'); font-weight:100 900; font-style:normal; font-display:swap; }
@font-face{ font-family:'Commissioner'; src:url('assets/fonts/commissioner-latin.woff2') format('woff2'); font-weight:100 900; font-style:normal; font-display:swap; }
:root{
  --rouge:#e62128; --nuit:#2c3e50; --bg:#eef1f5; --line:#e1e7ef;
  --font:'Inter',-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-head:'Commissioner',-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*{ box-sizing:border-box; }
body{ margin:0; font-family:var(--font); background:var(--bg); color:#1a1a1a; }
.app{ display:flex; gap:24px; align-items:flex-start; padding:24px; max-width:1500px; margin:0 auto; }
.panel-form{ flex:0 0 420px; background:#fff; border:1px solid var(--line); border-radius:10px; padding:20px; position:sticky; top:24px; }
.panel-preview{ flex:1; display:flex; flex-direction:column; align-items:center; gap:24px; }
.form-title{ font-size:20px; margin:0 0 16px; }
#form-header{ margin-bottom:3rem; }
.form-block{ margin:18px 0; }
.form-block h2{ font-size:13px; text-transform:uppercase; letter-spacing:.5px; color:#555; margin:0 0 8px; }
label{ display:block; font-size:12px; color:#555; margin:6px 0 2px; }
input[type=text], input[type=number], input[type=date], textarea{
  width:100%; padding:8px 10px; border:1px solid var(--line); border-radius:6px; font:inherit; }
.dropzone{ border:2px dashed #cdd6e2; border-radius:8px; padding:18px; text-align:center; color:#8a97a8; cursor:pointer; }
.dropzone.over{ border-color:var(--nuit); color:var(--nuit); background:#f3f5f8; }
.thumbs{ display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.btn-primary{ background:var(--nuit); color:#fff; border:0; border-radius:6px; padding:10px 14px; cursor:pointer; font:inherit; }
.btn-ghost{ background:none; border:1px solid var(--line); border-radius:6px; padding:8px 12px; cursor:pointer; font:inherit; }
.form-actions{ display:flex; gap:8px; margin-top:20px; }
/* Feuille A4 */
.sheet{ width:210mm; min-height:297mm; background:#fff; box-shadow:0 6px 30px rgba(0,0,0,.15); padding:14mm; }
/* Page de garde */
.cover{ display:flex; flex-direction:column; text-align:center; }
.cover-inner{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; }
.cover-logo{ width:75%; max-width:460px; height:auto; }
.cover-tagline{ font-family:var(--font-head); font-size:28px; letter-spacing:1px; color:var(--nuit);
  margin:18px 0 0; padding-top:16px; border-top:3px solid var(--rouge); }
.cover-meta{ padding-top:10mm; }
.cover-camp{ font-family:var(--font-head); font-size:18px; margin:0 0 2px; color:var(--nuit); }
.cover-period{ font-size:12px; color:#888; margin:0; }
.sheet-head{ display:flex; align-items:flex-end; justify-content:space-between; border-bottom:3px solid var(--rouge); padding-bottom:8px; }
.sheet-head .brand{ display:flex; align-items:center; gap:10px; }
.sheet-head .logo-vv{ height:30px; }
.sheet-head .logo-lq{ height:36px; }
.sheet-head .cobrand{ color:var(--rouge); font-weight:700; }
.sheet-head .doc-label{ font-size:11px; text-transform:uppercase; letter-spacing:1px; color:#888; }
.camp-title{ font-family:var(--font-head); font-size:26px; font-weight:700; color:var(--nuit); margin:18px 0 2px; }
.camp-period{ color:#777; margin:0 0 14px; }
.sheet-foot{ display:flex; justify-content:space-between; font-size:10px; color:#999; border-top:1px solid #eee; margin-top:24px; padding-top:8px; }
.format-row{ border:1px solid var(--line); border-radius:8px; padding:10px; margin-bottom:8px; }
.num3{ display:flex; gap:6px; }
.num3 > div{ flex:1; }
.row-actions{ display:flex; gap:12px; margin-top:6px; }
.btn-link{ background:none; border:0; color:#555; cursor:pointer; font-size:12px; text-decoration:underline; padding:0; }
.btn-link.danger{ color:#b00020; }
/* KPI dans la feuille */
.kpi-row{ display:grid; grid-template-columns:1fr repeat(3, minmax(80px, auto)); gap:18px; align-items:center;
  border-left:3px solid var(--rouge); padding:8px 12px; margin:8px 0; background:#fafafa; }
.kpi-lib{ font-weight:600; }
.kpi-val{ font-size:18px; font-weight:700; text-align:right; display:flex; flex-direction:column; }
.kpi-val small{ font-size:9px; font-weight:400; text-transform:uppercase; letter-spacing:.5px; color:#999; }
.kpi-total{ background:var(--nuit); border-left-color:var(--rouge); color:#fff; margin-top:12px; }
.kpi-total .kpi-val small{ color:#cdd6e2; }
.thumb{ position:relative; width:72px; height:72px; border:1px solid var(--line); border-radius:6px; overflow:hidden; cursor:grab; }
.thumb img{ width:100%; height:100%; object-fit:cover; }
.thumb-del{ position:absolute; top:2px; right:2px; width:18px; height:18px; border:0; border-radius:50%;
  background:rgba(0,0,0,.6); color:#fff; cursor:pointer; line-height:1; }
.shots{ margin-top:16px; }
.shots--grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.shot{ margin:0; text-align:center; }
.shot img{ max-width:90%; height:auto; display:inline-block; border:1px solid var(--line); border-radius:6px; }
.comment{ margin-top:18px; }
.comment h3{ font-family:var(--font-head); font-size:14px; margin:0 0 4px; color:var(--nuit); }
.comment p{ margin:0; font-size:13px; line-height:1.5; color:#333; }
/* Captures par format (formulaire) */
.fmt-cap{ margin-top:8px; }
.fmt-dropzone{ padding:10px; font-size:12px; }
.fmt-thumbs{ display:flex; flex-direction:column; gap:6px; margin-top:8px; }
.thumb-row{ display:flex; align-items:center; gap:8px; border:1px solid var(--line); border-radius:6px; padding:6px; background:#fff; cursor:grab; }
.thumb-img{ width:46px; height:46px; object-fit:cover; border-radius:4px; flex:0 0 auto; }
.thumb-note{ flex:1; }
.thumb-row .thumb-del{ position:static; width:22px; height:22px; flex:0 0 auto; }
/* Sections format dans la feuille (aperçu/PDF) */
.bilan-intro{ margin:6px 0 22px; font-size:13px; line-height:1.55; color:#333; }
.bilan-intro p{ margin:0 0 6px; }
.intro-formats-label{ font-weight:600; }
.intro-formats{ margin:0 0 3rem; padding-left:20px; }
.intro-formats li{ margin:2px 0; }
.fmt-section{ margin:3rem 0 14px; }
.shots-title{ font-family:var(--font-head); font-size:13px; color:var(--nuit); margin:14px 0 6px; text-align:center; }
.shot figcaption{ font-size:11px; color:#555; padding:6px 8px 2px; font-style:italic; }
.io-actions{ display:flex; gap:8px; margin-bottom:14px; }
.io-actions .btn-ghost{ flex:1; text-align:center; }
.io-actions label.btn-ghost{ display:inline-block; cursor:pointer; }
@page { size: A4; margin: 14mm; }

@media print {
  body{ background:#fff; }
  .app{ display:block; padding:0; max-width:none; }
  .panel-form{ display:none !important; }
  .panel-preview{ display:block; }
  .sheet{ width:auto; min-height:auto; box-shadow:none; padding:0; }
  .cover{ min-height:240mm; break-after:page; }
  .fmt-section{ break-inside:avoid; }   /* garde KPI + titre + captures du format ensemble */
  .shots-title{ break-after:avoid; }    /* le titre ne reste jamais seul en bas de page */
  .kpi-row, .shot, .comment{ break-inside:avoid; }
  .shots--grid{ gap:6mm; }
  *{ -webkit-print-color-adjust:exact; print-color-adjust:exact; }
}
