/* Maya Print Kiosk — style.css v2.5 */
:root {
  --bg:    #15151c;
  --panel: #1d1d27;
  --ink:   #e6e6ec;
  --muted: #9d9da8;
  --line:  #2c2c40;
  --ok:    #2ed573;
  --warn:  #ffa502;
  --bad:   #ff4757;
  --accent:#7c7cf0;
}
*, *::before, *::after { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, Cantarell, "Noto Sans", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
}
a { color: var(--ink); }
.wrap { max-width: 1020px; margin: 0 auto; padding: 16px; }
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 12px;
}
.row { display: flex; gap: 12px; flex-wrap: wrap; }
.hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
h1 { font-size: 18px; margin: 0; }
h2 { font-size: 14px; margin: 0 0 10px 0; color: var(--muted); font-weight: 600; letter-spacing: .05em; text-transform: uppercase; }
label { display: block; font-size: 12px; color: var(--muted); margin: 10px 0 5px; }
input, select, textarea, button {
  font-family: inherit;
  font-size: 14px;
  border-radius: 10px;
  border: 1px solid var(--line);
  padding: 9px 11px;
  background: #0f0f17;
  color: var(--ink);
  width: 100%;
}
button {
  cursor: pointer;
  background: #171729;
  width: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
button.primary { border-color: #30304a; background: #1b1b33; }
button.danger  { border-color: #4a3030; background: #331b1b; }
button.ghost   { background: #0f0f17; }
button.ok      { border-color: rgba(46,213,115,.4); background: rgba(46,213,115,.08); color: var(--ok); }
button:disabled { opacity: .5; cursor: not-allowed; }
.small { font-size: 12px; color: var(--muted); }
.badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-size: 12px;
  color: var(--muted);
  text-decoration: none;
}
.badge.ok   { color: var(--ok);   border-color: rgba(46,213,115,.35); }
.badge.warn { color: var(--warn); border-color: rgba(255,165,2,.35); }
.badge.bad  { color: var(--bad);  border-color: rgba(255,71,87,.35); }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { border-bottom: 1px solid var(--line); padding: 9px 7px; text-align: left; vertical-align: top; }
.table th { color: var(--muted); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: .05em; }
.table tr:hover td { background: rgba(255,255,255,.02); }
.actions { display: flex; gap: 6px; flex-wrap: wrap; }
.notice {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--line);
  color: var(--muted);
  background: #0f0f17;
}
.kpi { display: flex; gap: 8px; flex-wrap: wrap; }
.kpi .pill, .pill {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 10px;
  color: var(--muted);
  font-size: 12px;
}
.toast {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: #1a1a2e;
  border: 1px solid #30304a;
  color: var(--ink);
  padding: 10px 16px;
  border-radius: 14px;
  display: none;
  z-index: 999;
  font-size: 13px;
  max-width: 90vw;
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,.4);
}
details { border: 1px solid var(--line); border-radius: 14px; padding: 12px; background: #0f0f17; margin-bottom: 12px; }
details summary { cursor: pointer; font-size: 14px; font-weight: 600; color: var(--ink); list-style: none; }
details summary::before { content: "▸ "; color: var(--muted); }
details[open] summary::before { content: "▾ "; }
/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: #242436; border-radius: 3px; }

/* ─── Q5 v2.35 — Light mode ─────────────────────────────────────────────── */
@media (prefers-color-scheme: light) {
  :root {
    --bg:    #f4f4f8;
    --panel: #ffffff;
    --ink:   #1a1a2e;
    --muted: #5a5a72;
    --line:  #d8d8e8;
    --ok:    #16a34a;
    --warn:  #b45309;
    --bad:   #dc2626;
    --accent:#4f46e5;
  }
  input, select, textarea, button { background: #f9f9fc; color: var(--ink); }
  button { background: #eeeef6; }
  button.primary { background: #e0e0f4; border-color: #c0c0e0; }
  button.danger  { background: #fce8e8; border-color: #f0c0c0; }
  button.ghost   { background: #f4f4f8; }
  .notice        { background: #f4f4f8; }
  details        { background: #f9f9fc; }
  .toast         { background: #ffffff; }
  ::-webkit-scrollbar-thumb { background: #c8c8d8; }
}

/* Manual toggle: .light class overrides prefers-color-scheme */
body.light {
  --bg:    #f4f4f8;
  --panel: #ffffff;
  --ink:   #1a1a2e;
  --muted: #5a5a72;
  --line:  #d8d8e8;
  --ok:    #16a34a;
  --warn:  #b45309;
  --bad:   #dc2626;
  --accent:#4f46e5;
}
body.light input, body.light select, body.light textarea, body.light button { background: #f9f9fc; color: var(--ink); }
body.light button         { background: #eeeef6; }
body.light button.primary { background: #e0e0f4; border-color: #c0c0e0; }
body.light button.danger  { background: #fce8e8; border-color: #f0c0c0; }
body.light button.ghost   { background: #f4f4f8; }
body.light .notice        { background: #f4f4f8; }
body.light details        { background: #f9f9fc; }
body.light .toast         { background: #ffffff; }
body.dark {
  --bg:    #15151c;
  --panel: #1d1d27;
  --ink:   #e6e6ec;
  --muted: #9d9da8;
  --line:  #2c2c40;
  --ok:    #2ed573;
  --warn:  #ffa502;
  --bad:   #ff4757;
  --accent:#7c7cf0;
}
body.dark input, body.dark select, body.dark textarea, body.dark button { background: #0f0f17; color: var(--ink); }
body.dark button         { background: #171729; }
body.dark button.primary { background: #1b1b33; border-color: #30304a; }
body.dark button.danger  { background: #331b1b; border-color: #4a3030; }
body.dark button.ghost   { background: #0f0f17; }
body.dark .notice        { background: #0f0f17; }
body.dark details        { background: #0f0f17; }
body.dark .toast         { background: #1a1a2e; }
body.dark .btn          { background: #15151f; color: var(--ink); }
body.dark .btn:hover    { background: #1d1d2e; }
body.dark .btn.primary  { background: #1b1b33; border-color: #30304a; color: #fff; }
body.dark .btn.danger   { background: #331b1b; border-color: #4a3030; color: #ff8b8b; }
body.dark .btn.warn     { background: #332a1b; border-color: #4a3e1f; color: var(--warn); }
body.dark .btn.ok       { background: rgba(46,213,115,.08); border-color: rgba(46,213,115,.4); color: var(--ok); }
body.dark .btn.ghost    { background: #0f0f17; }
body.dark .period-tab   { background: #15151f; color: var(--muted); }
/* ─────────────────────────────────────────────────────────────────────────── */

/* ─── Patch deploy 27/04 : classes .btn manquantes (utilisées dans admin.html) ── */
/* Aligne la classe utilitaire .btn sur le style des éléments <button> natifs */
.btn {
  background: #15151f;
  border: 1px solid var(--line);
  color: var(--ink);
  padding: 6px 12px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 13px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background .15s, border-color .15s;
}
.btn:hover { background: #1d1d2e; border-color: var(--accent); }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.btn.primary { background: #1b1b33; border-color: #30304a; color: #fff; }
.btn.danger  { background: #331b1b; border-color: #4a3030; color: #ff8b8b; }
.btn.warn    { background: #332a1b; border-color: #4a3e1f; color: var(--warn); }
.btn.ok      { background: rgba(46,213,115,.08); border-color: rgba(46,213,115,.4); color: var(--ok); }
.btn.ghost   { background: #0f0f17; }

/* Period tabs (Aujourd'hui / 7 jours / Ce mois / Tout) */
.period-tab {
  background: #15151f;
  border: 1px solid var(--line);
  color: var(--muted);
  padding: 5px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
}
.period-tab.on { background: var(--accent); color: #fff; border-color: var(--accent); }

/* Mode clair (auto + manuel via body.light) */
@media (prefers-color-scheme: light) {
  .btn          { background: #eeeef6; color: var(--ink); }
  .btn:hover    { background: #e5e5f0; }
  .btn.primary  { background: #e0e0f4; border-color: #c0c0e0; color: #1a1a2e; }
  .btn.danger   { background: #fce8e8; border-color: #f0c0c0; color: #b91c1c; }
  .btn.warn     { background: #fdf2dc; border-color: #f0d999; color: #92400e; }
  .btn.ok       { background: rgba(34,197,94,.12); color: var(--ok); }
  .btn.ghost    { background: #f4f4f8; }
  .period-tab   { background: #f9f9fc; color: var(--muted); }
  .period-tab.on{ color: #fff; }
}
body.light .btn          { background: #eeeef6; color: var(--ink); }
body.light .btn:hover    { background: #e5e5f0; }
body.light .btn.primary  { background: #e0e0f4; border-color: #c0c0e0; color: #1a1a2e; }
body.light .btn.danger   { background: #fce8e8; border-color: #f0c0c0; color: #b91c1c; }
body.light .btn.warn     { background: #fdf2dc; border-color: #f0d999; color: #92400e; }
body.light .btn.ok       { background: rgba(34,197,94,.12); color: var(--ok); }
body.light .btn.ghost    { background: #f4f4f8; }
body.light .period-tab   { background: #f9f9fc; color: var(--muted); }
