/* TopStock — styles SPA prod. Derive du mockup, charte Top Sales.
   Bleu marine #002956 + Raleway + rouge signal #E30613. */

:root {
  --bg:#FFFFFF; --surface-1:#F7F7F8; --surface-2:#EFEFF1; --surface-3:#E4E4E7;
  --text:#1A1A1A; --text-muted:#52525B; --text-faint:#A1A1AA;
  --line:rgba(26,26,26,0.10); --line-strong:rgba(26,26,26,0.22);
  --primary:#002956; --primary-700:#001b3a;
  --accent:#E30613; --ok:#1E7A47; --warn:#B45309;
  --font:'Raleway',system-ui,-apple-system,sans-serif;
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-8:32px; --s-10:40px;
  --r-sm:6px; --r-md:8px; --r-lg:14px; --r-xl:20px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(0,41,86,0.06), 0 1px 3px rgba(0,41,86,0.05);
  --shadow-md:0 6px 24px rgba(0,41,86,0.10);
  --shadow-lg:0 18px 50px rgba(0,41,86,0.16);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);font-weight:400;font-size:15px;line-height:1.55;color:var(--text);background:var(--surface-1);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img,svg{display:block}
ul{list-style:none}
input,select,textarea{font:inherit}

.caps{text-transform:uppercase;letter-spacing:0.1em;font-weight:700;font-size:11px}
.muted{color:var(--text-muted)}
.faint{color:var(--text-faint)}
.num{font-variant-numeric:tabular-nums}
.strong{font-weight:700}
.right{text-align:right}
.hidden{display:none !important}

/* ── Login ─────────────────────────────────────────────────────────────── */
.login-page{min-height:100vh;display:grid;place-items:center;background:var(--primary);padding:24px}
.login-card{background:#fff;border-radius:var(--r-lg);padding:36px 32px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}
.login-card .logo{display:block;margin:0 auto 24px;max-width:140px}
.login-card h1{font-size:22px;font-weight:800;text-align:center;letter-spacing:-0.02em;margin-bottom:6px}
.login-card .sub{text-align:center;color:var(--text-muted);font-size:13px;margin-bottom:24px}
.login-card label{display:block;font-size:12px;font-weight:700;letter-spacing:0.04em;color:var(--text-muted);margin-bottom:6px;margin-top:14px}
.login-card input{width:100%;padding:11px 14px;border:1px solid var(--line-strong);border-radius:var(--r-md);background:var(--surface-1);outline:none;font-size:14px}
.login-card input:focus{border-color:var(--primary);background:#fff}
.login-card button{width:100%;margin-top:22px;padding:13px;border-radius:var(--r-md);background:var(--primary);color:#fff;border:none;font-weight:700;font-size:14px}
.login-card button:hover{background:var(--primary-700)}
.login-card .err{margin-top:14px;padding:10px 12px;background:rgba(227,6,19,0.08);border:1px solid rgba(227,6,19,0.3);border-radius:var(--r-sm);color:var(--accent);font-size:13px;text-align:center}
.login-card .foot{margin-top:22px;text-align:center;font-size:11px;color:var(--text-faint)}

/* ── Buttons ───────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:14px;padding:11px 20px;border-radius:var(--r-md);border:1px solid transparent;background:var(--surface-2);color:var(--text);transition:transform .18s cubic-bezier(.4,0,.2,1),background .18s,box-shadow .18s}
.btn:hover{background:var(--surface-3)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--primary-700)}
.btn-ghost{background:transparent;border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{background:var(--surface-2)}
.btn-block{width:100%}
.btn-lg{padding:14px 22px;font-size:15px}
.btn-xl{padding:20px 24px;font-size:18px;font-weight:700}

/* ── Chrome appli ──────────────────────────────────────────────────────── */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--primary);color:#fff;display:flex;flex-direction:column;padding:var(--s-5) var(--s-4);position:sticky;top:0;height:100vh}
.sidebar .logo-wrap{background:var(--primary-700);border-radius:var(--r-md);padding:16px 18px;margin-bottom:var(--s-6)}
.sidebar .logo-wrap img{width:128px}
.nav{display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:var(--r-md);color:rgba(255,255,255,0.78);font-weight:500;font-size:14px;transition:background .16s,color .16s}
.nav a:hover{background:rgba(255,255,255,0.08);color:#fff}
.nav a.active{background:#fff;color:var(--primary);font-weight:700}
.nav a.active svg{stroke:var(--primary)}
.nav a svg{width:19px;height:19px;flex:none;stroke:currentColor}
.nav .group-label{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.45);font-weight:700;padding:0 13px;margin:var(--s-5) 0 var(--s-2)}
.sidebar .me{margin-top:auto;padding-top:var(--s-5);border-top:1px solid rgba(255,255,255,0.12);display:flex;align-items:center;gap:11px}
.sidebar .me .avatar{width:36px;height:36px;border-radius:var(--r-pill);background:#fff;color:var(--primary);display:grid;place-items:center;font-weight:800;font-size:14px;flex:none}
.sidebar .me .info{line-height:1.25;min-width:0;flex:1}
.sidebar .me .info .n{font-weight:700;font-size:13px}
.sidebar .me .info .r{font-size:11px;color:rgba(255,255,255,0.6)}
.sidebar .me .logout{color:rgba(255,255,255,0.5);font-size:12px;cursor:pointer;padding:6px 8px;border-radius:var(--r-sm)}
.sidebar .me .logout:hover{background:rgba(255,255,255,0.08);color:#fff}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-5) var(--s-8);background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.topbar h1{font-size:22px;font-weight:800;letter-spacing:-0.02em}
.topbar .sub{font-size:13px;color:var(--text-muted);margin-top:1px}
.topbar .spacer{flex:1}
.search{display:flex;align-items:center;gap:9px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);padding:9px 14px;min-width:240px}
.search input{border:none;background:none;outline:none;font:inherit;flex:1;color:var(--text)}
.content{padding:var(--s-8);display:flex;flex-direction:column;gap:var(--s-6)}

/* ── Cartes / KPI ──────────────────────────────────────────────────────── */
.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-6);box-shadow:var(--shadow-sm)}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4)}
.kpi{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.kpi .k-label{font-size:12px;font-weight:600;color:var(--text-muted)}
.kpi .k-value{font-size:34px;font-weight:800;letter-spacing:-0.03em;margin-top:6px}
.kpi .k-value small{font-size:16px;font-weight:600;color:var(--text-faint)}
.kpi .k-sub{font-size:12px;font-weight:600;margin-top:4px;color:var(--text-muted)}
.kpi.alert{border-color:rgba(227,6,19,0.35)}
.kpi.alert .k-value{color:var(--accent)}

.section-head{display:flex;align-items:center;gap:var(--s-3);margin-bottom:var(--s-4)}
.section-head h2{font-size:17px;font-weight:700}
.section-head .count{font-size:12px;color:var(--text-faint)}
.section-head .spacer{flex:1}

.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:var(--s-6);align-items:start}

/* ── Tableaux ──────────────────────────────────────────────────────────── */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-faint);font-weight:700;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--surface-1)}
.table td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:var(--surface-1)}

.tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:0.04em}
.tag.sortie{background:rgba(0,41,86,0.08);color:var(--primary)}
.tag.retour{background:rgba(30,122,71,0.12);color:var(--ok)}
.tag.casse{background:rgba(227,6,19,0.10);color:var(--accent)}
.tag.recep{background:var(--surface-2);color:var(--text-muted)}
.tag.inventaire{background:rgba(180,83,9,0.10);color:var(--warn)}

.brand-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);background:var(--surface-2);color:var(--text-muted);border:1px solid var(--line);white-space:nowrap}
.brand-pill .dot{width:7px;height:7px;border-radius:var(--r-pill);flex:none;background:var(--text-faint)}

/* ── Scan (mobile-first) ───────────────────────────────────────────────── */
.scan-wrap{max-width:520px;margin:0 auto;width:100%}
.scan-camera{background:#000;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:1/1;position:relative;margin-bottom:var(--s-4)}
.scan-camera #qr{width:100%;height:100%}
.scan-camera .hint{position:absolute;left:0;right:0;bottom:0;padding:14px;background:linear-gradient(transparent, rgba(0,0,0,0.6));color:#fff;font-size:13px;text-align:center}
.scan-result{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;margin-bottom:var(--s-4)}
.scan-result .nom{font-size:20px;font-weight:800;letter-spacing:-0.01em}
.scan-result .sku{font-size:12px;color:var(--text-faint);font-variant-numeric:tabular-nums;margin-top:4px}
.scan-result .row{display:flex;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-size:14px}
.qty-control{display:flex;align-items:center;background:var(--surface-1);border-radius:var(--r-lg);padding:8px;margin:16px 0;gap:10px}
.qty-control button{width:48px;height:48px;border-radius:var(--r-pill);border:1px solid var(--line);background:#fff;font-size:24px;font-weight:700}
.qty-control input{flex:1;text-align:center;font-size:34px;font-weight:800;border:none;background:transparent;outline:none;color:var(--text)}

/* ── Toast ─────────────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--text);color:#fff;padding:12px 20px;border-radius:var(--r-pill);box-shadow:var(--shadow-md);font-weight:600;font-size:14px;z-index:100;opacity:0;transition:opacity .2s, transform .2s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}
.toast.ok{background:var(--ok)}
.toast.err{background:var(--accent)}

/* ── Filtres chips ─────────────────────────────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.chip{padding:6px 12px;border-radius:var(--r-pill);background:var(--bg);border:1px solid var(--line);font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}
.chip:hover{border-color:var(--line-strong);color:var(--text)}
.chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── Loader skeleton ───────────────────────────────────────────────────── */
.skeleton{background:linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);background-size:200% 100%;animation:sk 1.4s infinite;border-radius:var(--r-sm)}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Empty state ───────────────────────────────────────────────────────── */
.empty{padding:48px;text-align:center;color:var(--text-muted);background:var(--bg);border:1px dashed var(--line-strong);border-radius:var(--r-lg)}
.empty .ico{font-size:36px;margin-bottom:8px;opacity:0.4}

/* ── Footer credit ─────────────────────────────────────────────────────── */
.credit{text-align:center;font-size:12px;color:var(--text-faint);padding:var(--s-6);border-top:1px solid var(--line)}

/* ── Modaux ─────────────────────────────────────────────────────────────── */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;overflow:auto;opacity:0;animation:bd-in .15s forwards}
@keyframes bd-in{to{opacity:1}}
.modal-card{background:var(--bg);border-radius:var(--r-lg);padding:24px 26px;width:100%;max-width:480px;box-shadow:var(--shadow-lg);transform:scale(.96);animation:m-in .18s cubic-bezier(.2,.7,.3,1.2) forwards}
@keyframes m-in{to{transform:scale(1)}}
.modal-card.large{max-width:720px}
.modal-card h3{font-size:18px;font-weight:800;letter-spacing:-0.01em;margin-bottom:6px}
.modal-card .sub{color:var(--text-muted);font-size:13px;margin-bottom:18px}
.modal-card label{display:block;font-size:12px;font-weight:700;letter-spacing:0.04em;color:var(--text-muted);margin-bottom:6px;margin-top:14px;text-transform:uppercase}
.modal-card input[type=text],.modal-card input[type=email],.modal-card input[type=password],.modal-card input[type=number],.modal-card select,.modal-card textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg);outline:none;font:inherit;font-size:14px}
.modal-card input:focus,.modal-card select:focus,.modal-card textarea:focus{border-color:var(--primary)}
.modal-card .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}
.modal-card .actions .btn{padding:9px 18px;font-size:14px}

/* ── Recherche globale ──────────────────────────────────────────────────── */
.search.global{position:relative}
.search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-md);max-height:380px;overflow:auto;z-index:50}
.search-results .item{padding:10px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);cursor:pointer}
.search-results .item:last-child{border-bottom:none}
.search-results .item:hover,.search-results .item.kbd{background:var(--surface-1)}
.search-results .kind{font-size:10px;font-weight:700;color:var(--text-faint);letter-spacing:0.08em;text-transform:uppercase;flex:none;min-width:60px}
.search-results .empty{padding:20px;text-align:center;color:var(--text-faint);font-size:13px}

/* ── Mobile hamburger + drawer ─────────────────────────────────────────── */
.hamburger{display:none;width:36px;height:36px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--bg);align-items:center;justify-content:center;flex:none}
.hamburger svg{width:20px;height:20px}

/* ── Badge sidebar (compteurs) ─────────────────────────────────────────── */
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:var(--r-pill);background:var(--accent);color:#fff;font-size:10px;font-weight:800;margin-left:auto;font-variant-numeric:tabular-nums}
.nav a.active .nav-badge{background:var(--accent);color:#fff}

/* ── Stats / graphs SVG ────────────────────────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4);margin-bottom:var(--s-6)}
.stat-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-sm)}
.stat-card .l{font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-faint)}
.stat-card .v{font-size:28px;font-weight:800;letter-spacing:-0.02em;margin-top:4px}
.stat-card .s{font-size:12px;color:var(--text-muted);margin-top:2px}
.spark{width:100%;height:34px;margin-top:8px}
.spark path{fill:none;stroke:var(--primary);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.spark .area{fill:rgba(0,41,86,0.08);stroke:none}

.bar-chart{display:flex;align-items:flex-end;gap:6px;height:160px;padding:12px 14px;background:var(--surface-1);border-radius:var(--r-md);border:1px solid var(--line)}
.bar-chart .bar{flex:1;background:var(--primary);border-radius:3px 3px 0 0;min-height:2px;position:relative;transition:opacity .12s}
.bar-chart .bar:hover{opacity:0.78}
.bar-chart .bar.warn{background:var(--warn)}
.bar-chart .bar.crit{background:var(--accent)}
.bar-chart-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--text-faint);padding:6px 14px 0}

/* ── Print stylesheet (refacturation imprimable) ───────────────────────── */
@media print {
  body{background:#fff !important}
  .sidebar,.topbar,.credit,.toast,.demo-banner,.search.global,.hamburger,.btn,.actions,.chips,.section-head .spacer + *{display:none !important}
  .app{display:block !important;grid-template-columns:none !important}
  .main{display:block !important}
  .content{padding:0 !important;display:block !important}
  .card{box-shadow:none !important;border:1px solid #ddd !important;break-inside:avoid;page-break-inside:avoid}
  .modal-card,.backdrop{display:none !important}
  a{color:#000 !important;text-decoration:none !important}
  .table{font-size:11px}
  .table th{background:#f0f0f0 !important;color:#000 !important}
  .tag{border:1px solid #ccc;color:#000 !important;background:transparent !important}
}

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 900px){
  .app{grid-template-columns:1fr}
  .sidebar{display:flex;position:fixed;top:0;left:0;width:268px;z-index:100;transform:translateX(-100%);transition:transform .2s cubic-bezier(.2,.7,.3,1)}
  .sidebar.open{transform:translateX(0);box-shadow:8px 0 30px rgba(0,0,0,0.25)}
  .hamburger{display:inline-flex}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
  .content{padding:var(--s-4)}
  .topbar{padding:var(--s-4);gap:var(--s-3)}
  .topbar .search{min-width:0;flex:1}
  .topbar .search input{font-size:14px}
  .modal-card{padding:18px 20px}
}
