:root{--ink: #10202f;--ink-2: #1a3047;--paper: #f3f5f7;--card: #ffffff;--line: #dfe4ea;--muted: #64707d;--accent: #e8590c;--accent-soft: #fdeee4;--ok: #2b8a3e;--ok-soft: #e6f4ea;--bad: #c92a2a;--bad-soft: #fdecec;--warn: #b35c00;--warn-soft: #fff3e0;--radius: 8px;--font: "Barlow", system-ui, sans-serif;--font-display: "Barlow Semi Condensed", "Barlow", sans-serif;--font-mono: ui-monospace, "SF Mono", "Cascadia Mono", Consolas, monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--paper);color:var(--ink);font-size:14px}.app{display:flex;min-height:100vh}.sidebar{width:224px;flex-shrink:0;background:var(--ink);color:#cfd8e0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{padding:20px 18px 14px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:11px}.brand .name{font-family:var(--font-display);font-weight:700;font-size:17px;color:#fff;letter-spacing:.02em}.brand .sub{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-top:2px}.nav{padding:10px 8px;display:flex;flex-direction:column;gap:2px;flex:1}.nav button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;color:#b9c4ce;padding:9px 12px;border-radius:6px;font:inherit;font-weight:500;cursor:pointer;border-left:3px solid transparent}.nav button:hover{background:#ffffff0f;color:#fff}.nav button.active{background:#e8590c24;color:#fff;border-left-color:var(--accent)}.nav .sep{margin:10px 12px 4px;font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:#5d6b78}.userbox{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);font-size:13px}.userbox .who{color:#fff;font-weight:600}.userbox .role{color:var(--accent);font-size:11px;text-transform:uppercase;letter-spacing:.1em}.userbox button{display:block;width:100%;margin-top:8px;background:none;border:1px solid rgba(255,255,255,.2);color:#cfd8e0;padding:6px 10px;border-radius:6px;cursor:pointer;font:inherit;font-size:12px;text-align:left}.userbox button:hover{border-color:var(--accent);color:#fff}.main{flex:1;padding:24px 28px;min-width:0}.page-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}.page-head h1{font-family:var(--font-display);font-size:24px;font-weight:700;margin:0}.page-head .count{color:var(--muted);font-size:13px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius)}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:12px;border-bottom:1px solid var(--line)}.toolbar input[type=search],.toolbar input[type=text]{flex:1;min-width:200px}input,select,textarea{font:inherit;padding:8px 10px;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--ink);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e8590c26}label.field{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;color:var(--muted)}label.field>input,label.field>select{font-weight:400;color:var(--ink)}button.btn{font:inherit;font-weight:600;padding:8px 14px;border-radius:6px;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink)}button.btn:hover{border-color:var(--ink)}button.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.btn.primary:hover{background:#cf4d09}button.btn.danger{color:var(--bad);border-color:var(--bad);background:#fff}button.btn:disabled{opacity:.5;cursor:not-allowed}button.btn.sm{padding:4px 9px;font-size:12px}.table-wrap{overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:13.5px}table.data th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:9px 12px;border-bottom:2px solid var(--line);white-space:nowrap;background:#fafbfc;position:sticky;top:0}table.data th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}table.data th.sortable:hover{color:var(--ink)}table.data td{padding:8px 12px;border-bottom:1px solid var(--line);vertical-align:middle}table.data tbody tr:hover{background:#f7f4f1}table.data tbody tr.clickable{cursor:pointer}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}.ref{font-family:var(--font-mono);font-size:12.5px;letter-spacing:-.01em}.muted{color:var(--muted)}.prix{font-weight:600;font-variant-numeric:tabular-nums}.chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:11.5px;font-weight:600}.chip.up{background:var(--bad-soft);color:var(--bad)}.chip.down{background:var(--ok-soft);color:var(--ok)}.chip.nouveau{background:var(--accent-soft);color:var(--accent)}.chip.maj{background:var(--warn-soft);color:var(--warn)}.chip.inchange{background:#eef1f4;color:var(--muted)}.chip.erreur{background:var(--bad-soft);color:var(--bad)}.chip.role{background:#eef1f4;color:var(--ink-2);text-transform:capitalize}.chip.inactif{background:#eef1f4;color:var(--muted)}.chip.best{background:var(--ok-soft);color:var(--ok)}.pagination{display:flex;align-items:center;gap:10px;padding:12px;justify-content:flex-end;font-size:13px;color:var(--muted)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#10202f80;display:flex;justify-content:flex-end;z-index:50}.overlay.center{justify-content:center;align-items:center}.drawer{width:min(680px,100%);background:var(--card);height:100%;overflow-y:auto;padding:24px;box-shadow:-8px 0 30px #0003}.modal{width:min(520px,calc(100% - 32px));background:var(--card);border-radius:10px;padding:22px;max-height:90vh;overflow-y:auto}.modal h2,.drawer h2{font-family:var(--font-display);margin:0 0 4px;font-size:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0}.form-grid .full{grid-column:1 / -1}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.alert{padding:10px 14px;border-radius:6px;margin-bottom:14px;font-weight:500}.alert.error{background:var(--bad-soft);color:var(--bad)}.alert.success{background:var(--ok-soft);color:var(--ok)}.empty{padding:40px;text-align:center;color:var(--muted)}.login-page{min-height:100vh;display:grid;place-items:center;background:var(--ink)}.login-card{width:min(380px,calc(100% - 32px));background:var(--card);border-radius:12px;padding:32px}.login-card .brand-line{font-family:var(--font-display);font-size:22px;font-weight:700}.login-card .brand-sub{color:var(--accent);font-size:11px;text-transform:uppercase;letter-spacing:.14em;margin-bottom:22px}.login-card form{display:flex;flex-direction:column;gap:12px}.stat-row{display:flex;gap:12px;flex-wrap:wrap;margin:14px 0}.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:12px 18px;min-width:110px}.stat .v{font-family:var(--font-display);font-size:24px;font-weight:700}.stat .l{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.stat.nouveau .v{color:var(--accent)}.stat.maj .v{color:var(--warn)}.stat.erreur .v{color:var(--bad)}.steps{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.step{padding:6px 12px;border-radius:99px;font-size:12px;font-weight:600;background:#eef1f4;color:var(--muted)}.step.active{background:var(--accent);color:#fff}.step.done{background:var(--ok-soft);color:var(--ok)}.mapping-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;padding:14px}.sparkline{display:block}.histo-section h3{font-family:var(--font-display);font-size:15px;margin:20px 0 8px}.compare-group{margin-bottom:16px}.compare-group .ghead{display:flex;align-items:baseline;gap:10px;padding:12px 14px;border-bottom:1px solid var(--line);flex-wrap:wrap}.compare-group .ghead .ref{font-size:14px;font-weight:700}@media (max-width: 860px){.app{flex-direction:column}.sidebar{width:100%;height:auto;position:static}.nav{flex-direction:row;flex-wrap:wrap}.nav .sep{display:none}.nav button{width:auto;border-left:none;border-bottom:3px solid transparent}.nav button.active{border-left:none;border-bottom-color:var(--accent)}.main{padding:14px}.form-grid{grid-template-columns:1fr}.drawer{width:100%}}@media (prefers-reduced-motion: no-preference){.modal,.drawer{animation:pop .18s ease-out}@keyframes pop{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}}.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 1100px){.dash-cols{grid-template-columns:1fr}}.global-search-trigger{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;max-width:420px;margin-bottom:18px;padding:9px 12px;background:var(--card);border:1px solid var(--line);border-radius:8px;color:var(--muted);cursor:pointer;font:inherit;font-size:13px}.global-search-trigger:hover{border-color:var(--accent);color:var(--ink)}.global-search-trigger kbd{font-family:var(--font-mono);font-size:11px;background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:1px 6px}.search-overlay{align-items:flex-start;justify-content:center}.search-palette{width:min(640px,calc(100% - 32px));margin-top:10vh;background:var(--card);border-radius:12px;box-shadow:0 24px 60px #0000004d;overflow:hidden;animation:pop .15s ease-out}.search-palette>input{width:100%;border:none;border-bottom:1px solid var(--line);border-radius:0;padding:16px 18px;font-size:16px}.search-palette>input:focus{box-shadow:none;border-color:var(--accent)}.search-results{max-height:60vh;overflow-y:auto;padding:6px}.search-group{padding:6px 0}.search-group-title{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:4px 12px}.search-item{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:9px 12px;border-radius:6px;font:inherit;color:var(--ink)}.search-item:hover{background:var(--accent-soft)}.search-hint{padding:18px;text-align:center;color:var(--muted);font-size:13px}@media (max-width: 860px){.global-search-trigger{max-width:none}}.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;line-height:1}.nav button{display:flex;align-items:center;gap:10px}.copy-btn{margin-left:6px;background:none;border:none;cursor:pointer;color:var(--muted);font-size:13px;padding:1px 4px;border-radius:4px;opacity:0;transition:opacity .12s,color .12s;vertical-align:baseline}tr:hover .copy-btn,.ref:hover .copy-btn,.copy-btn.copied{opacity:1}.copy-btn:hover{color:var(--accent);background:var(--accent-soft)}.copy-btn.copied{color:var(--ok)}@media (hover: none){.copy-btn{opacity:.6}}.perm-list{display:flex;flex-direction:column;gap:6px;max-height:46vh;overflow-y:auto}.perm-item{display:flex;align-items:flex-start;gap:10px;padding:9px 11px;border:1px solid var(--line);border-radius:8px;cursor:pointer;font-size:13px}.perm-item:hover{border-color:var(--accent)}.perm-item.on{border-color:var(--accent);background:var(--accent-soft)}.perm-item input{margin-top:2px}.chip.role{background:#eef2f7;color:#2a3b4d;text-transform:capitalize}.assistant{display:flex;flex-direction:column;height:calc(100vh - 80px)}.chat-suggestions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.chip-btn{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:6px 13px;font-size:13px;cursor:pointer;color:var(--ink)}.chip-btn:hover{border-color:var(--accent);color:var(--accent)}.chat-thread{flex:1;overflow-y:auto;padding:6px 2px;display:flex;flex-direction:column;gap:12px}.chat-msg{display:flex}.chat-msg.user{justify-content:flex-end}.bubble{max-width:80%;padding:11px 14px;border-radius:14px;font-size:14px;line-height:1.45}.bubble.user{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.bubble.bot{background:var(--card);border:1px solid var(--line);border-bottom-left-radius:4px}.chat-results{margin-top:10px;display:flex;flex-direction:column;gap:5px}.chat-result{display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;align-items:center;width:100%;text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:7px 10px;cursor:pointer;font:inherit;font-size:13px}.chat-result:hover{border-color:var(--accent)}.chat-result .ref{font-family:var(--font-mono);font-weight:600}.chat-result .desg{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-result .four{color:var(--muted);font-size:12px}.chat-result .prix{font-weight:700;color:var(--accent);white-space:nowrap}.chat-input{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--line)}.chat-input input{flex:1}@media (max-width: 680px){.chat-result{grid-template-columns:auto 1fr}.chat-result .four{display:none}.bubble{max-width:92%}}.prix-special{color:#2f9e44;font-weight:700}.api-key-value{font-family:var(--font-mono);font-size:13px;background:#10202f;color:#7cfc9b;padding:8px 12px;border-radius:6px;flex:1;word-break:break-all}.api-example{font-family:var(--font-mono);font-size:12.5px;background:#0f1b27;color:#d6e2ee;padding:14px;border-radius:8px;overflow-x:auto;line-height:1.55;white-space:pre}.pin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080f18d1;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.pin-box{background:#0b1622;border:1px solid #25384c;border-radius:14px;box-shadow:0 20px 60px #00000080;max-width:760px;width:100%;color:#e8eef5;overflow:hidden}.pin-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#10202f;border-bottom:1px solid #25384c;font-size:16px}.pin-body{display:flex;gap:16px;padding:16px}.pin-game{display:flex;flex-direction:column;align-items:center;gap:8px}.pin-hud{display:flex;justify-content:space-between;width:360px;font-size:14px;color:#cdd8e3}.pin-hud b{color:#ffd166}.pin-canvas{border-radius:10px;border:1px solid #25384c;background:#0d1b2a}.pin-help{font-size:12px;color:#8aa0b4}.pin-help kbd{background:#1c2c3c;border:1px solid #34506a;border-radius:4px;padding:1px 6px;font-family:var(--font-mono)}.pin-side{flex:1;min-width:200px}.pin-side h3{margin:0 0 10px;font-size:15px}.pin-result{background:#13283a;border:1px solid #2b4a66;border-radius:8px;padding:10px;margin-bottom:12px;font-size:14px}.pin-result.record{background:#1f3a1f;border-color:#3c7a3c}.pin-board{list-style:none;margin:0;padding:0}.pin-board li{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:14px}.pin-board li:nth-child(odd){background:#ffffff08}.pin-board .pin-rank{color:#8aa0b4;text-align:center}.pin-board .pin-pts{color:#ffd166;font-weight:700;font-variant-numeric:tabular-nums}.pin-board li.medal.m0 .pin-rank{color:gold;font-weight:800}.pin-board li.medal.m1 .pin-rank{color:silver;font-weight:800}.pin-board li.medal.m2 .pin-rank{color:#cd7f32;font-weight:800}@media (max-width: 680px){.pin-body{flex-direction:column}.pin-canvas{width:100%;height:auto}.pin-hud{width:100%}}.pin-canvas canvas{border-radius:10px;border:1px solid #25384c;display:block}
