:root{--bg-color:#f5efe3;--beurre:#f5efe3;--creme:#fbf7ee;--tomate:#e63b2e;--tomate-hover:#d4342a;--tomate-light:#fbe5e2;--encre:#1a1614;--gris-fonce:#7a6f66;--gris-clair:#a89e94;--vert:#3f6b4e;--vert-light:#e7efe9;--jaune:#9a7d12;--jaune-light:#f7eccd;--line:#1a16141a;--line-soft:#1a16140f;--font-display:"Fraunces", Georgia, serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--radius-sm:10px;--radius-lg:16px;--sidebar-w:260px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{font-family:var(--font-body);background:var(--bg-color);color:var(--encre);-webkit-font-smoothing:antialiased;font-size:14px}button{cursor:pointer;font-family:inherit}a{color:inherit}.shell{background:var(--beurre);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--creme);border-right:1px solid var(--line);flex-direction:column;flex-shrink:0;height:100vh;padding:32px 20px;display:flex;position:sticky;top:0;overflow-y:auto}.brand{font-family:var(--font-display);letter-spacing:-.045em;align-items:center;gap:8px;padding:0 12px;font-size:24px;font-weight:700;display:flex}.brand-dot{background:var(--tomate);border-radius:50%;flex-shrink:0;width:9px;height:9px}.brand-sub{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--gris-fonce);padding:6px 12px 32px;font-size:11px}.nav{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{color:var(--gris-fonce);border-radius:var(--radius-sm);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 14px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{color:var(--encre);background:#1a16140d}.nav-item.active{background:var(--beurre);color:var(--encre);font-weight:600;box-shadow:0 1px 3px #1a161414}.nav-item svg{flex-shrink:0;width:18px;height:18px}.nav-foot{border-top:1px solid var(--line);color:var(--gris-fonce);margin-top:20px;padding-top:20px;font-size:13px}.nav-foot button{color:var(--encre);border-radius:var(--radius-sm);background:0 0;border:1px solid #1a16143d;width:100%;min-height:40px;margin-top:10px;padding:9px 14px;font-size:13px;font-weight:600}.nav-foot button:hover{opacity:.7}.main{flex:1;min-width:0;max-width:1240px;margin:0 auto;padding:48px}.page-head{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:32px;padding-bottom:24px;display:flex}.page-title{font-family:var(--font-display);letter-spacing:-.02em;margin:0;font-size:32px;font-weight:600}.page-sub{color:var(--gris-fonce);margin-top:4px;font-size:15px;line-height:1.5}.grid{gap:16px;display:grid}.grid-kpi{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.card{background:var(--creme);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px}.card-title{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--gris-fonce);margin:0 0 16px;font-size:11px;font-weight:500}.kpi-label{color:var(--gris-fonce);margin:0 0 8px;font-size:13px}.kpi-value{font-family:var(--font-display);letter-spacing:-.02em;font-size:30px;font-weight:600;line-height:1}.kpi-value small{font-family:var(--font-body);color:var(--gris-clair);margin-left:4px;font-size:15px;font-weight:500}.kpi-note{color:var(--gris-clair);margin-top:8px;font-size:12.5px}.table-wrap{background:var(--creme);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}table{border-collapse:collapse;width:100%;font-size:13.5px}th{text-align:left;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--gris-fonce);border-bottom:1px solid var(--line);white-space:nowrap;background:#1a161408;padding:13px 16px;font-size:10.5px;font-weight:500}td{border-bottom:1px solid var(--line-soft);vertical-align:middle;padding:13px 16px}tr:last-child td{border-bottom:none}tbody tr:hover{background:#1a161406}.num{font-family:var(--font-mono);text-align:right}.muted{color:var(--gris-clair)}.mono{font-family:var(--font-mono);font-size:12px}.badge{font-family:var(--font-mono);letter-spacing:.02em;white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:500;display:inline-block}.badge.ok{background:var(--vert-light);color:var(--vert)}.badge.warn{background:var(--jaune-light);color:var(--jaune)}.badge.err{background:var(--tomate-light);color:var(--tomate)}.badge.neutral{color:var(--gris-fonce);background:#1a16140f}.controls{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:20px;display:flex}input,select{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--creme);color:var(--encre);min-height:44px;padding:10px 14px;font-family:inherit;font-size:14px}input:focus,select:focus{border-color:var(--tomate);outline:none}.search{min-width:260px}.btn{font-family:var(--font-body);border-radius:var(--radius-sm);background:var(--encre);min-height:44px;color:var(--beurre);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;line-height:1;transition:opacity .2s;display:inline-flex}.btn:hover{opacity:.85}.btn:disabled,.btn:disabled:hover{opacity:.4;cursor:not-allowed}.btn.ghost{color:var(--encre);background:0 0;border:1px solid #1a16143d}.btn.primary{background:var(--tomate);color:var(--beurre)}.bars{align-items:flex-end;gap:3px;height:120px;display:flex}.bar{background:var(--tomate);border-radius:3px 3px 0 0;flex:1;min-width:2px}.bar.alt{background:var(--vert)}.bars-x{color:var(--gris-clair);font-size:10.5px;font-family:var(--font-mono);justify-content:space-between;margin-top:8px;display:flex}.logline{border-bottom:1px solid var(--line-soft);font-family:var(--font-mono);grid-template-columns:150px 80px 90px 1fr;align-items:baseline;gap:12px;padding:8px 16px;font-size:12px;display:grid}.logline:hover{background:#1a161406}.logline .lvl{font-weight:500}.lvl.ERROR,.lvl.CRITICAL{color:var(--tomate)}.lvl.WARNING{color:var(--jaune)}.lvl.INFO{color:var(--vert)}.lvl.DEBUG{color:var(--gris-clair)}.logmsg{white-space:pre-wrap;word-break:break-word}.content-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;display:grid}.content-card{background:var(--creme);border:1px solid var(--line);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.content-media{background:var(--encre);aspect-ratio:9/16;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.content-media>video,.content-media>img{object-fit:contain;background:var(--encre);width:100%;height:100%}.content-slides{scroll-snap-type:x mandatory;gap:3px;width:100%;height:100%;display:flex;overflow-x:auto}.content-slides img{object-fit:contain;scroll-snap-align:start;flex:none;width:auto;height:100%}.content-meta{padding:14px 16px}.content-meta .row{justify-content:space-between;align-items:center;gap:8px;display:flex}.pub-dots{flex-wrap:wrap;gap:4px;margin-top:10px;display:flex}.pub-dots a.badge{text-decoration:none}.state{text-align:center;color:var(--gris-fonce);padding:48px}.spinner{border:2.5px solid var(--line);border-top-color:var(--tomate);border-radius:50%;width:24px;height:24px;margin:0 auto 12px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-wrap{background:var(--beurre);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--creme);border:1px solid var(--line);border-radius:var(--radius-lg);width:380px;padding:40px}.login-card h1{font-family:var(--font-display);letter-spacing:-.045em;align-items:center;gap:9px;margin:0 0 4px;font-size:26px;font-weight:700;display:flex}.login-card p{color:var(--gris-fonce);margin:0 0 28px;font-size:14px}.login-card label{color:var(--gris-fonce);margin:0 0 6px;font-size:13px;display:block}.login-card .field{margin-bottom:16px}.login-card input{width:100%}.login-card .btn{width:100%;margin-top:8px}.login-err{background:var(--tomate-light);color:var(--tomate);border-radius:var(--radius-sm);margin-bottom:16px;padding:11px 14px;font-size:13px}.section-gap{margin-top:24px}.row-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=820px){.row-2{grid-template-columns:1fr}.main{padding:24px}.sidebar{width:210px}}
