/* Socle visuel commun aux 3 prototypes — co-brandé léger (chrome neutre + accent Sika). */
:root{
  --sika:#ffcc00; --sika-ink:#7a5c00; --ink2:#1a1a1a; /* accent Sika */
  --bg:#f5f7fa; --card:#fff; --ink:#1c2530; --muted:#6b7787; --line:#e7ebf0; --line2:#eef1f5;
  --red:#e23b3b; --red-bg:#fdeaea; --orange:#f3a712; --orange-bg:#fff4de; --green:#2faa5a; --green-bg:#e7f7ee;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45}
.wrap{max-width:1180px;margin:0 auto;padding:18px 22px 64px}
a{color:inherit}

/* En-tête + bandeau d'accent */
.top{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px}
.brand .logo{height:30px;width:auto;border-radius:6px;display:block}
.brand .logo.fallback{width:30px;background:var(--sika);color:var(--ink2);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;letter-spacing:.3px}
.brand .t{font-weight:700}.brand .t small{display:block;color:var(--muted);font-weight:500;font-size:11px}
.fresh{font-size:11px;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.fresh b{color:var(--ink);font-weight:600}
.accent{margin:14px 0 18px;background:#fffdf2;border:1px solid #f0e3a8;border-left:4px solid var(--sika);
  border-radius:10px;padding:11px 15px}
.accent .a{font-weight:700}.accent .w{color:#6b6450;font-size:12.5px;margin-top:2px}
.nav{display:flex;gap:8px;margin-left:auto;font-size:12px}
.nav a{padding:5px 10px;border:1px solid var(--line);border-radius:20px;background:#fff;text-decoration:none;color:var(--muted)}
.nav a.on{border-color:var(--sika);color:var(--sika-ink);background:#fffdf2;font-weight:600}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0 20px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.kpi .l{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px}
.kpi .v{font-size:24px;font-weight:800;margin-top:4px;font-variant-numeric:tabular-nums}
.kpi.risk .v{color:var(--red)}
.kpi .v.big{font-size:34px}

/* Tableaux */
.sec{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:22px 0 9px}
table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line2);vertical-align:middle}
th{font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);background:#fafbfc;cursor:pointer;user-select:none}
th.num,td.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--mono)}
tr:last-child td{border-bottom:none}
tbody tr{cursor:pointer}
tbody tr:hover{background:#fafcff}
.prod{font-weight:600}.asin{color:var(--muted);font-size:11px;font-family:var(--mono)}

/* Pills / badges / markers */
.pill{display:inline-block;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}
.pill.red{background:var(--red-bg);color:var(--red)}
.pill.orange{background:var(--orange-bg);color:var(--orange)}
.pill.green{background:var(--green-bg);color:var(--green)}
.tag{display:inline-block;font-size:11px;padding:2px 7px;border-radius:6px;background:#eef1f5;color:#55606e}
.tag.op{background:var(--green-bg);color:var(--green)}.tag.threat{background:var(--red-bg);color:var(--red)}
.nat{font-size:10px;border:1px solid var(--line);border-radius:5px;padding:1px 5px;color:var(--muted);cursor:help;vertical-align:middle}
.nat.estime{color:#9a6b00;border-color:#f0dca0;background:#fff7e0}
.nat.proxy{color:#5b6470;background:#eef1f5}
.borne{font-size:11px;color:var(--muted)}
.eur{font-weight:700}.eur.red{color:var(--red)}

/* Inspector / drill modal */
.ovl{position:fixed;inset:0;background:rgba(10,14,20,.55);display:none;align-items:center;justify-content:center;z-index:50}
.ovl.on{display:flex}
.modal{width:min(560px,94vw);max-height:84vh;overflow:auto;background:#fff;border-radius:14px;padding:18px;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.modal h3{margin:0 0 2px;font-size:15px}
.modal .crumbs{color:var(--muted);font-size:11px;margin-bottom:10px}
.modal pre{background:#0d1117;color:#c9d1d9;border-radius:8px;padding:12px;font-size:11.5px;line-height:1.5;overflow:auto;font-family:var(--mono)}
.modal .src{font-size:11px;color:var(--muted);margin-top:8px;border-top:1px solid var(--line2);padding-top:8px}
.modal .x{float:right;border:0;background:transparent;font-size:16px;cursor:pointer;color:var(--muted)}
.kv{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:13px;margin:8px 0}
.kv .k{color:var(--muted)}.kv .v{font-family:var(--mono);text-align:right}
.formula{font-family:var(--mono);font-size:12px;background:#fafbfc;border:1px solid var(--line);border-radius:8px;padding:8px 10px;margin:8px 0}
.formula .res{color:var(--red);font-weight:700}

/* SVG charts */
.chartwrap{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.legend{display:flex;gap:14px;font-size:11px;color:var(--muted);margin-top:6px;flex-wrap:wrap}
.legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}
.spark{display:block}
footer{margin-top:30px;color:var(--muted);font-size:11px;border-top:1px solid var(--line);padding-top:12px}
@media(max-width:720px){.kpis{grid-template-columns:repeat(2,1fr)}}

/* Visite guidée (coach-marks) */
.sk-tour-btn{border:1px solid #f0e3a8;background:#fffdf2;color:var(--sika-ink);border-radius:20px;padding:5px 12px;font-family:var(--sans);font-size:12px;font-weight:600;cursor:pointer}
.sk-tour-btn:hover{background:#fff7e0}
#sk-tour{position:fixed;inset:0;z-index:9000;pointer-events:none}
#sk-tour-hole{position:fixed;border-radius:10px;border:2px solid var(--sika);box-shadow:0 0 0 9999px rgba(12,16,22,.62);transition:top .25s,left .25s,width .25s,height .25s;pointer-events:none}
#sk-tour-tip{position:fixed;width:330px;max-width:92vw;background:#fff;color:var(--ink);border-radius:12px;padding:14px 16px;box-shadow:0 18px 55px rgba(0,0,0,.45);pointer-events:auto;transition:top .2s,left .2s}
#sk-tour-step{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
#sk-tour-title{font-weight:700;font-size:15px;margin:3px 0 6px}
#sk-tour-why{font-size:13px;color:#37424f;line-height:1.5}
#sk-tour-nav{display:flex;align-items:center;gap:8px;margin-top:13px}
#sk-tour-nav button{border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 12px;font-family:var(--sans);font-size:13px;cursor:pointer}
#sk-tour-nav #sk-tour-skip{color:var(--muted);border-color:transparent;padding-left:0}
#sk-tour-nav #sk-tour-next.primary{background:var(--ink2);color:#fff;border-color:var(--ink2);font-weight:600}
