/* ═══════════════════════════════════════════════════════════
   GESTION.CSS — Le Quai Gestion — Styles partagés
   ═══════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════
   VARIABLES & RESET
   ═══════════════════════════════════════════════════════════ */
:root {
  --bg: #000a04;
  --surface: rgba(77,255,77,0.05);
  --surface2: rgba(77,255,77,0.08);
  --gold: #4dff4d;
  --gold-lt: #b8ffb8;
  --gold-dim: rgba(77,255,77,0.5);
  --bd: rgba(77,255,77,.12);
  --bd-str: rgba(77,255,77,.25);
  --txt: #4dff4d;
  --txt-mid: rgba(77,255,77,.55);
  --txt-dim: rgba(77,255,77,.25);
  --red: #ff6a6a;
  --green: #4dff4d;
  --warn: #ffd266;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bot: env(safe-area-inset-bottom, 0px);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: 'VT323', 'Share Tech Mono', 'Courier New', monospace;
  font-size:27px;
  color: var(--txt);
  background: #000;
  background-image:
    radial-gradient(ellipse at center, rgba(77,255,77,0.04) 0%, #000a04 70%, #000 100%);
  min-height: 100vh;
  min-height: 100dvh;
  padding-top: var(--safe-top);
  padding-bottom: var(--safe-bot);
}

/* ═══════════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════════ */
.page { display: none; flex-direction: column; min-height: 100vh; min-height: 100dvh; }
.page.active { display: flex; }
.container { width: 100%; max-width: 900px; margin: 0 auto; padding: 0 16px 24px; }

/* ═══════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════ */
.app-header {
  text-align: center;
  padding: 20px 16px 12px;
}
.anchor-row { font-size:2.1rem; letter-spacing: .5em; color: var(--gold-dim); }
.app-header h1 {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:2.7rem;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: .12em;
  margin: 4px 0 2px;
}
.app-header .sub {
  font-size: .88rem;
  color: var(--txt-mid);
  text-transform: uppercase;
  letter-spacing: .15em;
}
.rule { display: flex; align-items: center; gap: 8px; margin: 10px auto 0; max-width: 200px; }
.rule-line { flex: 1; height: 1px; background: var(--bd-str); }
.rule-dia { color: var(--gold-dim); font-size: .7rem; }

/* ═══════════════════════════════════════════════════════════
   TAB BAR
   ═══════════════════════════════════════════════════════════ */
.tab-bar {
  display: flex;
  gap: 2px;
  background: var(--surface);
  border-radius: 10px;
  padding: 3px;
  margin: 0 16px 16px;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.tab-bar a {
  flex: 1;
  text-align: center;
  padding: 10px 8px;
  font-size: .9rem;
  font-weight: 600;
  color: var(--txt-mid);
  text-decoration: none;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: .06em;
  transition: all .2s;
}
.tab-bar a.active {
  background: var(--surface2);
  color: var(--gold);
}

/* ═══════════════════════════════════════════════════════════
   HUB TILES
   ═══════════════════════════════════════════════════════════ */
.hub-tiles {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
  margin: 20px 0;
}
.hub-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 20px 12px 16px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 14px;
  text-decoration: none;
  color: var(--txt);
  transition: transform .15s, border-color .2s;
}
.hub-tile:hover { transform: translateY(-2px); border-color: var(--gold-dim); }
.hub-tile:active { transform: scale(.97); }
.hub-tile-icon { font-size:2.7rem; }
.hub-tile-name { font-family: 'VT323', 'Share Tech Mono', monospace; font-size: .95rem; font-weight: 700; color: var(--gold); text-align: center; }
.hub-tile-desc { font-size: .78rem; color: var(--txt-dim); text-align: center; }
.hub-tile-badge {
  position: absolute;
  top: 8px; right: 8px;
  min-width: 20px; height: 20px;
  display: none;
  align-items: center; justify-content: center;
  font-size: .7rem; font-weight: 700;
  background: var(--red);
  color: #fff;
  border-radius: 10px;
  padding: 0 6px;
}
.hub-tile-badge.active { display: flex; }
.hub-back {
  position: fixed;
  top: calc(var(--safe-top) + 10px);
  left: 12px;
  z-index: 100;
  font-size: .9rem;
  color: var(--gold-dim);
  text-decoration: none;
  padding: 6px 12px;
  border-radius: 8px;
  background: rgba(17,35,24,.85);
  backdrop-filter: blur(8px);
  border: 1px solid var(--bd);
}
.hub-back:hover { color: var(--gold); border-color: var(--gold-dim); }

/* ═══════════════════════════════════════════════════════════
   SOUS-PAGE TABS (couts, rh-paie)
   ═══════════════════════════════════════════════════════════ */
.sub-tabs {
  display: flex;
  gap: 2px;
  background: var(--surface);
  border-radius: 10px;
  padding: 3px;
  margin: 0 0 16px;
}
.sub-tab {
  flex: 1;
  text-align: center;
  padding: 10px 8px;
  font-size: .9rem;
  font-weight: 600;
  color: var(--txt-mid);
  background: none;
  border: none;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: .06em;
  transition: all .2s;
  cursor: pointer;
  font-family: inherit;
}
.sub-tab.active {
  background: var(--surface2);
  color: var(--gold);
}

/* ═══════════════════════════════════════════════════════════
   LOGIN
   ═══════════════════════════════════════════════════════════ */
#login-screen.active {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  min-height: 100dvh;
  padding: 24px;
}
#login-screen .app-header { margin-bottom: 32px; }

/* User selection */
.user-grid {
  display: flex;
  gap: 12px;
  margin-bottom: 8px;
}
.user-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 18px 22px;
  border-radius: 12px;
  border: 1px solid var(--bd-str);
  background: var(--surface);
  color: var(--txt);
  cursor: pointer;
  transition: all .2s;
  min-width: 90px;
}
.user-btn:active, .user-btn.selected {
  border-color: var(--gold);
  background: var(--surface2);
}
.user-avatar {
  font-size:2.7rem;
  line-height: 1;
}
.user-name {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size: .92rem;
  font-weight: 600;
  letter-spacing: .04em;
}
.user-role {
  font-size: .72rem;
  color: var(--txt-dim);
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* PIN input */
#pin-section {
  display: none;
  flex-direction: column;
  align-items: center;
  margin-top: 20px;
  gap: 10px;
  width: 100%;
  max-width: 300px;
}
#pin-section.visible { display: flex; }
#pin-section label {
  font-size: .78rem;
  color: var(--txt-mid);
  text-align: center;
}
.pin-input {
  width: 100%;
  padding: 14px 18px;
  border-radius: 10px;
  border: 1px solid var(--bd-str);
  background: var(--surface);
  color: var(--txt);
  font-size:1.95rem;
  text-align: center;
  letter-spacing: .3em;
  outline: none;
}
.pin-input:focus { border-color: var(--gold); }
.pin-input::placeholder { color: var(--txt-dim); letter-spacing: .1em; font-size: .85rem; }
.login-btn {
  margin-top: 8px;
  padding: 12px 48px;
  border: 1px solid var(--gold);
  border-radius: 10px;
  background: transparent;
  color: var(--gold);
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size: .95rem;
  font-weight: 600;
  letter-spacing: .1em;
  cursor: pointer;
  transition: all .2s;
  width: 100%;
}
.login-btn:active { background: var(--gold); color: var(--bg); }
#login-error {
  margin-top: 8px;
  font-size: .8rem;
  color: var(--red);
  min-height: 1.2em;
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════
   DASHBOARD OPS — toolbar toggles + KPIs avec delta N-1
   ═══════════════════════════════════════════════════════════ */
.ops-toolbar {
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;
  align-items:center;justify-content:space-between;
}
.ops-toolbar .ops-group {
  display:flex;background:var(--surface);
  border:1px solid var(--bd);border-radius:8px;overflow:hidden;
}
.ops-toolbar .ops-btn {
  padding:7px 11px;background:transparent;border:none;
  color:var(--txt-mid);cursor:pointer;font-family:inherit;
  font-size:.85rem;letter-spacing:.05em;border-right:1px solid var(--bd);
  transition:background .15s,color .15s;
}
.ops-toolbar .ops-btn:last-child { border-right:none; }
.ops-toolbar .ops-btn:hover { background:rgba(77,255,77,.08);color:var(--txt); }
.ops-toolbar .ops-btn.active {
  background:var(--gold);color:#1a2818;font-weight:700;
}
.ops-period-label {
  font-family:'VT323','Share Tech Mono',monospace;font-size:.95rem;color:var(--gold);
  letter-spacing:.06em;flex:1;text-align:center;
}

/* KPI ops : valeur + delta N-1 sous le label */
.kpi-card .kpi-delta {
  font-size:.8rem;margin-top:4px;font-variant-numeric:tabular-nums;
}
.kpi-card .kpi-delta.up   { color:rgba(76,175,80,.95); }
.kpi-card .kpi-delta.down { color:rgba(239,83,80,.95); }
.kpi-card .kpi-delta.flat { color:var(--txt-mid); }

/* Graphique 30j — barres empilees midi/soir */
.chart-30j {
  position:relative;height:200px;
  background:var(--surface);border:1px solid var(--bd);
  border-radius:10px;padding:14px 14px 30px 50px;overflow:hidden;
  margin-bottom:14px;
}
.chart-30j .c30-bars {
  position:absolute;left:50px;right:14px;top:14px;bottom:30px;
  display:flex;align-items:flex-end;gap:2px;
}
.chart-30j .c30-bar {
  flex:1;display:flex;flex-direction:column-reverse;
  cursor:pointer;border-radius:2px 2px 0 0;
  position:relative;min-height:1px;
  transition:filter .15s;
}
.chart-30j .c30-bar:hover { filter:brightness(1.3); }
.chart-30j .c30-bar .midi { background:rgba(77,255,77,.55);width:100%; }
.chart-30j .c30-bar .soir { background:rgba(77,200,180,.5);width:100%; }
.chart-30j .c30-bar.weekend { box-shadow:inset 0 -2px 0 rgba(77,255,77,.35); }
.chart-30j .c30-bar.ferie::before {
  content:'★';position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  font-size:.7rem;color:var(--gold);
}
.chart-30j .c30-yaxis {
  position:absolute;left:6px;top:14px;bottom:30px;width:40px;
  display:flex;flex-direction:column;justify-content:space-between;
  font-size:.68rem;color:var(--txt-mid);text-align:right;
}
.chart-30j .c30-xlabel {
  position:absolute;left:50px;right:14px;bottom:6px;
  display:flex;justify-content:space-between;
  font-size:.68rem;color:var(--txt-mid);
}
.chart-30j .c30-legend {
  position:absolute;top:6px;right:14px;
  font-size:.72rem;color:var(--txt-mid);
  display:flex;gap:10px;
}
.chart-30j .c30-legend .swatch {
  display:inline-block;width:10px;height:8px;border-radius:2px;margin-right:3px;vertical-align:middle;
}
.chart-30j .c30-legend .swatch.midi { background:rgba(77,255,77,.55); }
.chart-30j .c30-legend .swatch.soir { background:rgba(77,200,180,.5); }

/* Tuile lien externe */
.ops-link-tile {
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;margin-bottom:14px;
  background:var(--surface);border:1px solid var(--bd);
  border-radius:10px;color:var(--txt);text-decoration:none;
  font-size:.9rem;
}
.ops-link-tile:hover { border-color:var(--gold); }
.ops-link-tile .ops-link-arrow { color:var(--gold);font-size:1.65rem; }

.ops-period-info {
  font-size:.82rem;color:var(--txt-mid);text-align:center;
  margin:-4px 0 14px;
}

/* Tendance & Marche (Le Quai vs UMIH/GHR) */
.tendance-grid {
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px;
}
.tendance-card {
  background:var(--surface);border:1px solid var(--bd);
  border-radius:10px;padding:12px 10px;text-align:center;
}
.tendance-label {
  font-size:.75rem;color:var(--txt-mid);
  text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px;
}
.tendance-value {
  font-family:'VT323','Share Tech Mono',monospace;font-size:1.95rem;font-weight:700;
  color:var(--gold);line-height:1.2;
}
.tendance-value.up   { color:rgba(76,175,80,.95); }
.tendance-value.down { color:rgba(239,83,80,.95); }
.tendance-value.flat { color:var(--txt-mid); }
.tendance-sub {
  font-size:.72rem;color:var(--txt-dim);margin-top:3px;
}

/* ═══════════════════════════════════════════════════════════
   KPI CARDS
   ═══════════════════════════════════════════════════════════ */
.kpi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 20px;
}
.kpi-card {
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 12px;
  padding: 16px 14px;
  text-align: center;
}
.kpi-value {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:2.55rem;
  font-weight: 700;
  color: var(--gold);
  line-height: 1.2;
}
.kpi-value.small { font-size:1.95rem; }
.kpi-label {
  font-size: .8rem;
  color: var(--txt-mid);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 6px;
}

/* ═══════════════════════════════════════════════════════════
   SECTIONS & CHARTS
   ═══════════════════════════════════════════════════════════ */
.section-title {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:1.58rem;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: .08em;
  margin: 20px 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.section-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--bd);
}

/* ═══════════ Bar chart vertical ═══════════ */
.bar-chart {
  position: relative;
  height: 240px;
  background: var(--surface);
  border-radius: 10px;
  border: 1px solid var(--bd);
  padding: 22px 14px 40px 52px;
  overflow: hidden;
}
.chart-yaxis {
  position: absolute;
  top: 18px;
  bottom: 36px;
  left: 6px;
  width: 42px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  font-size: .72rem;
  color: var(--txt-dim);
  text-align: right;
  padding-right: 6px;
  pointer-events: none;
  font-family: 'VT323', 'Share Tech Mono', monospace;
}
.chart-grid {
  position: absolute;
  top: 22px;
  bottom: 40px;
  left: 52px;
  right: 14px;
  pointer-events: none;
}
.chart-grid-line {
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background: rgba(255,255,255,0.05);
}
.chart-grid-line.base {
  background: rgba(255,255,255,0.15);
}
.chart-bars {
  position: relative;
  height: 100%;
  display: flex;
  align-items: flex-end;
  gap: 4px;
  z-index: 2;
}
.bar-col {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: center;
  gap: 2px;
  height: 100%;
  position: relative;
  min-width: 0;
  cursor: help;
}
.bar-col:hover .bar-value { opacity: 1; }
.bar-col:hover .bar { filter: brightness(1.2); }
.bar {
  width: 14px;
  max-width: 18px;
  min-height: 0;
  background: linear-gradient(180deg, var(--gold-lt) 0%, var(--gold) 100%);
  border-radius: 3px 3px 0 0;
  transition: height .5s cubic-bezier(.2,.8,.2,1), filter .2s;
  position: relative;
  box-shadow: 0 -2px 8px rgba(77,255,77,0.15);
}
.bar.bar-prev {
  background: rgba(200,200,200,0.2);
  box-shadow: none;
  border: 1px solid rgba(255,255,255,0.15);
}
.bar.warn { background: linear-gradient(180deg, #f39c47 0%, #e67e22 100%); }
.bar.danger { background: linear-gradient(180deg, #e74c3c 0%, var(--red) 100%); }
.bar-value {
  position: absolute;
  top: -18px;
  left: 50%;
  transform: translateX(-50%);
  font-size: .7rem;
  color: var(--gold-lt);
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-weight: 600;
  white-space: nowrap;
  opacity: 0;
  transition: opacity .2s;
  pointer-events: none;
  background: rgba(0,0,0,0.7);
  padding: 1px 5px;
  border-radius: 3px;
}
.bar-label {
  position: absolute;
  bottom: -26px;
  left: 0;
  right: 0;
  text-align: center;
  font-size: .8rem;
  color: var(--txt-dim);
  transform: none;
}
.chart-legend {
  display: flex;
  gap: 14px;
  justify-content: flex-end;
  align-items: center;
  font-size: .82rem;
  color: var(--txt-dim);
  margin: -6px 2px 6px;
}
.chart-legend .dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  margin-right: 5px;
  vertical-align: middle;
}
.chart-legend .dot.cur { background: var(--gold); }
.chart-legend .dot.prev { background: rgba(200,200,200,0.3); border: 1px solid rgba(255,255,255,0.2); }

/* Horizontal bars (top fournisseurs) */
.h-bars { display: flex; flex-direction: column; gap: 6px; }
.h-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  padding: 6px 10px;
  border-radius: 8px;
  transition: background .15s;
}
.h-bar-row:active { background: var(--surface2); }
.h-bar-name {
  width: 110px;
  flex-shrink: 0;
  font-size: .9rem;
  color: var(--txt);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.h-bar-track {
  flex: 1;
  height: 18px;
  background: var(--surface);
  border-radius: 4px;
  overflow: hidden;
}
.h-bar-fill {
  height: 100%;
  background: var(--gold);
  border-radius: 4px;
  transition: width .5s ease;
}
.h-bar-val {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size: .88rem;
  color: var(--gold-lt);
  width: 70px;
  text-align: right;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   FOURNISSEURS LIST
   ═══════════════════════════════════════════════════════════ */
.search-box {
  width: 100%;
  padding: 12px 16px;
  border-radius: 10px;
  border: 1px solid var(--bd);
  background: var(--surface);
  color: var(--txt);
  font-size:1.5rem;
  outline: none;
  margin-bottom: 12px;
}
.search-box:focus { border-color: var(--gold); }
.search-box::placeholder { color: var(--txt-dim); }

.filter-bar {
  display: flex; gap: 8px; margin-bottom: 10px; flex-wrap: wrap;
}
.filter-bar select {
  flex: 1; min-width: 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--bd);
  background: var(--surface);
  color: var(--txt);
  font-size: .95rem;
  outline: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23807860'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 30px;
}
.filter-bar select:focus { border-color: var(--gold); }
.filter-count {
  font-size: .82rem; color: var(--txt-dim); text-align: right;
  margin-top: -6px; margin-bottom: 8px;
}

.f-list { display: flex; flex-direction: column; gap: 6px; }
.f-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color .15s;
}
.f-item:active { border-color: var(--gold); }
.f-name { font-size:1.5rem; font-weight: 600; }
.f-meta { font-size: .82rem; color: var(--txt-mid); margin-top: 2px; }
.f-total {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:1.72rem;
  font-weight: 700;
  color: var(--gold);
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════
   DETAIL FOURNISSEUR
   ═══════════════════════════════════════════════════════════ */
.back-btn {
  background: none;
  border: none;
  color: var(--gold);
  font-size: .85rem;
  cursor: pointer;
  padding: 8px 0;
  margin-bottom: 4px;
}
.detail-name {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:2.1rem;
  color: var(--gold);
  margin-bottom: 12px;
}
.factures-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}
.factures-table th {
  text-align: left;
  color: var(--txt-mid);
  font-weight: 400;
  text-transform: uppercase;
  font-size: .78rem;
  letter-spacing: .06em;
  padding: 8px 6px;
  border-bottom: 1px solid var(--bd);
}
.factures-table td {
  padding: 10px 6px;
  border-bottom: 1px solid var(--bd);
  color: var(--txt);
}
.factures-table .amount {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  color: var(--gold);
  text-align: right;
}
.factures-table tbody tr { cursor: pointer; transition: background .15s; }
.factures-table tbody tr:hover { background: rgba(77,255,77,.05); }

/* Lignes de facture (detail produit) */
.lignes-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}
.lignes-table th {
  text-align: left;
  color: var(--txt-mid);
  font-weight: 400;
  text-transform: uppercase;
  font-size: .72rem;
  letter-spacing: .05em;
  padding: 6px 4px;
  border-bottom: 1px solid var(--bd);
}
.lignes-table td {
  padding: 8px 4px;
  border-bottom: 1px solid var(--bd);
  color: var(--txt);
  vertical-align: top;
}
.lignes-table .num { font-family: 'VT323', 'Share Tech Mono', monospace; color: var(--gold); text-align: right; white-space: nowrap; }
.lignes-table .designation { font-weight: 500; }
.lignes-table .designation small { display: block; color: var(--txt-dim); font-size: .9em; font-weight: 400; }
.lignes-table tbody tr.clickable { cursor: pointer; transition: background .15s; }
.lignes-table tbody tr.clickable:hover { background: rgba(77,255,77,.05); }

/* Top hausses de prix */
.hausses-list { display: flex; flex-direction: column; gap: 8px; }
.hausse-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px 14px;
  align-items: center;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .15s, transform .1s;
}
.hausse-item:hover { border-color: var(--bd-str); transform: translateX(2px); }
.hausse-item .h-name { font-weight: 600; color: var(--txt); }
.hausse-item .h-meta { font-size: .82rem; color: var(--txt-mid); margin-top: 2px; }
.hausse-item .h-pct {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:1.8rem;
  font-weight: 700;
  text-align: right;
  white-space: nowrap;
}
.hausse-item .h-pct.up { color: var(--red); }
.hausse-item .h-pct.down { color: var(--green); }
.hausse-item .h-prices { font-size: .82rem; color: var(--txt-dim); text-align: right; }

/* Liste produits suivis */
.prod-list { display: flex; flex-direction: column; gap: 6px; }
.prod-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .15s, transform .15s;
}
.prod-row:hover { border-color: var(--bd-str); transform: translateX(2px); }
.prod-row .prod-main { min-width: 0; flex: 1; }
.prod-row .prod-name {
  font-weight: 600;
  color: var(--txt);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.prod-row .prod-sub { font-size: .82rem; color: var(--txt-mid); margin-top: 2px; }
.prod-row .prod-price { text-align: right; flex-shrink: 0; }
.prod-row .prod-pu { font-weight: 600; color: var(--gold); font-size:1.65rem; }
.prod-row .prod-var {
  display: inline-block;
  font-size: .82rem;
  margin-top: 2px;
  font-weight: 600;
}
.prod-row .prod-var.up { color: var(--red); }
.prod-row .prod-var.down { color: var(--green); }

/* Line chart (evolution prix) */
.line-chart {
  position: relative;
  height: 180px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 16px 12px 30px;
  margin: 12px 0;
}
.line-chart svg { width: 100%; height: 100%; overflow: visible; }
.line-chart .axis-label {
  fill: var(--txt-dim);
  font-size:14px;
  font-family: 'VT323', 'Share Tech Mono', monospace;
}
.line-chart .price-line {
  fill: none;
  stroke: var(--gold);
  stroke-width: 2;
}
.line-chart .price-area {
  fill: rgba(77,255,77,.12);
  stroke: none;
}
.line-chart .price-dot {
  fill: var(--gold);
  stroke: var(--bg);
  stroke-width: 1.5;
}
.line-chart .grid-line {
  stroke: var(--bd);
  stroke-width: 1;
  stroke-dasharray: 2,3;
}

.prod-meta {
  font-size: .92rem;
  color: var(--txt-mid);
  text-align: center;
  margin-bottom: 12px;
}

/* ═══════════════════════════════════════════════════════════
   FOOTER / UTILS
   ═══════════════════════════════════════════════════════════ */
.cache-info {
  text-align: center;
  font-size: .82rem;
  color: var(--txt-dim);
  margin-top: 20px;
  padding: 12px;
}
.refresh-btn {
  background: none;
  border: 1px solid var(--bd-str);
  color: var(--gold-dim);
  font-size: .85rem;
  padding: 6px 16px;
  border-radius: 6px;
  cursor: pointer;
  margin-top: 6px;
}
.refresh-btn:active { color: var(--gold); border-color: var(--gold); }

.loader {
  text-align: center;
  padding: 40px;
  color: var(--txt-dim);
  font-size: .85rem;
}
.toast {
  position: fixed;
  bottom: calc(20px + var(--safe-bot));
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface2);
  border: 1px solid var(--bd-str);
  color: var(--txt);
  padding: 10px 20px;
  border-radius: 10px;
  font-size: .92rem;
  z-index: 999;
  opacity: 0;
  transition: opacity .3s;
  pointer-events: none;
}
.toast.show { opacity: 1; }

.logout-btn {
  position: absolute;
  top: calc(12px + var(--safe-top));
  right: 12px;
  background: none;
  border: none;
  color: var(--txt-dim);
  font-size: .88rem;
  cursor: pointer;
}
.hub-link {
  position: absolute;
  top: calc(12px + var(--safe-top));
  left: 12px;
  color: var(--txt-dim);
  font-size: .88rem;
  text-decoration: none;
  font-family: 'VT323', 'Share Tech Mono', monospace;
  transition: color .15s;
}
.hub-link:hover { color: var(--gold); }

/* ═══════════════════════════════════════════════════════════
   CUISINE — Fiches techniques
   ═══════════════════════════════════════════════════════════ */
.empty {
  text-align: center;
  padding: 30px 16px;
  color: var(--txt-dim);
  font-size: .85rem;
  font-style: italic;
}

/* Filtre catégories (chips) */
.cat-filter {
  display: flex;
  gap: 6px;
  margin-bottom: 12px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 2px;
}
.cat-filter::-webkit-scrollbar { display: none; }
.cat-chip {
  flex-shrink: 0;
  background: var(--surface);
  border: 1px solid var(--bd);
  color: var(--txt-mid);
  padding: 7px 14px;
  border-radius: 20px;
  font-size: .88rem;
  font-family: 'VT323', 'Share Tech Mono', monospace;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.cat-chip:active { transform: scale(.96); }
.cat-chip.active {
  background: var(--gold-dim);
  border-color: var(--gold);
  color: var(--bg);
  font-weight: 700;
}

/* Liste des recettes */
.recettes-list { display: flex; flex-direction: column; gap: 6px; }
.recette-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  transition: border-color .15s, transform .1s;
}
.recette-row:hover { border-color: var(--bd-str); transform: translateX(2px); }
.recette-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.recette-nom {
  font-weight: 600;
  color: var(--txt);
  font-size:1.58rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}
.recette-fc {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:1.72rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}
.recette-sub {
  display: flex;
  justify-content: space-between;
  font-size: .82rem;
  color: var(--txt-mid);
}
.recette-marge {
  color: var(--gold-dim);
  font-weight: 600;
}

/* Badges food cost (seuils) */
.fc-ok { color: var(--green); }
.fc-warn { color: var(--gold-lt); }
.fc-alert { color: var(--red); }

/* Page détail fiche */
.fiche-head {
  margin: 10px 0 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--bd);
}
.fiche-nom {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:2.25rem;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: .03em;
  line-height: 1.2;
}
.fiche-cat {
  display: inline-block;
  margin-top: 8px;
  padding: 3px 10px;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--txt-mid);
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 12px;
}

/* Grille KPIs de la fiche (réutilise kpi-grid) */
.fiche-kpis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 8px;
}

/* Simulation (contrôles) */
.sim-controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 8px;
}
.sim-controls label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: .8rem;
  color: var(--txt-mid);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.sim-controls input {
  width: 100%;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--bd-str);
  background: var(--surface);
  color: var(--gold);
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:1.8rem;
  font-weight: 700;
  outline: none;
  text-align: center;
}
.sim-controls input:focus { border-color: var(--gold); }

/* Liste des ingrédients */
.fiche-ingr {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ingr-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 8px;
}
.ingr-main {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  min-width: 0;
}
.ingr-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  font-size: .7rem;
  flex-shrink: 0;
}
.ingr-badge.ok    { background: rgba(39,174,96,.15);  color: var(--green); }
.ingr-badge.auto  { background: rgba(77,255,77,.15); color: var(--gold); }
.ingr-badge.manual{ background: rgba(247,237,206,.08); color: var(--txt-dim); }
.ingr-nom {
  font-size: .95rem;
  font-weight: 600;
  color: var(--txt);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  flex: 1;
}
.ingr-fourn {
  font-size: .75rem;
  color: var(--txt-dim);
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
  flex-shrink: 0;
}
.ingr-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  flex-shrink: 0;
  text-align: right;
}
.ingr-qte {
  font-size: .85rem;
  color: var(--txt);
  font-weight: 600;
}
.ingr-pu {
  font-size: .75rem;
  color: var(--txt-dim);
}
.ingr-cost {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size: .95rem;
  font-weight: 700;
  color: var(--gold);
}

/* Méthode (bloc texte) */
.fiche-methode {
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 10px;
  padding: 14px 16px;
  font-size: .95rem;
  line-height: 1.5;
  color: var(--txt);
  white-space: pre-wrap;
}

@media (min-width: 640px) {
  .fiche-kpis { grid-template-columns: repeat(4, 1fr); }
}

/* ═══════════════════════════════════════════════════════════
   HISTORIQUE — styles
   ═══════════════════════════════════════════════════════════ */
.hist-controls {
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
  margin: 8px 0 16px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 10px;
}
.hist-year-sel, .hist-compare {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .88rem;
  color: var(--txt-mid);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.hist-year-sel select {
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid var(--bd-str);
  background: var(--bg);
  color: var(--gold);
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:1.58rem;
  font-weight: 700;
  cursor: pointer;
}
.hist-compare input { accent-color: var(--gold); cursor: pointer; }
.hist-compare strong { color: var(--gold-lt); font-family: 'VT323', 'Share Tech Mono', monospace; }

/* Barres comparees (N-1 en fond plus pale) */
.bar-col { position: relative; }
.bar.bar-prev {
  position: absolute;
  bottom: 28px;
  left: 0;
  right: 0;
  margin: 0 auto;
  background: rgba(77,255,77,.25);
  border: 1px dashed rgba(77,255,77,.5);
  z-index: 0;
}
.bar-col .bar:not(.bar-prev) { z-index: 1; position: relative; }

/* KPI delta (variation vs N-1) */
.kpi-delta {
  font-size: .82rem;
  font-weight: 600;
  margin-top: 4px;
  font-family: 'VT323', 'Share Tech Mono', monospace;
}
.kpi-delta-up { color: var(--green); }
.kpi-delta-down { color: var(--red); }

/* Banniere de periode (annee partielle) */
.hist-period-banner {
  grid-column: 1 / -1;
  background: linear-gradient(135deg, rgba(192,149,62,0.15), rgba(192,149,62,0.05));
  border: 1px solid rgba(192,149,62,0.3);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .95rem;
  color: var(--gold-lt);
  font-weight: 500;
  text-align: center;
}

/* Insights */
.hist-insights {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: var(--surface);
  border: 1px solid var(--bd);
  border-radius: 10px;
  padding: 8px;
}
.insight-row {
  display: grid;
  grid-template-columns: 1fr auto auto 50px;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 6px;
  font-size: .92rem;
}
.insight-row:hover { background: var(--surface2); }
.insight-label { color: var(--txt); }
.insight-val { color: var(--gold-lt); font-family: 'VT323', 'Share Tech Mono', monospace; font-weight: 600; }
.insight-delta { font-weight: 700; font-family: 'VT323', 'Share Tech Mono', monospace; min-width: 48px; text-align: right; }
.insight-n { color: var(--txt-dim); font-size: .82rem; text-align: right; }

/* Calendrier jour par jour */
.hist-calendar {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 8px;
  margin-top: 8px;
}
.hist-day {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--bd);
  display: flex;
  flex-direction: column;
  gap: 2px;
  position: relative;
  min-height: 90px;
}
.hist-day-date {
  font-size: .82rem;
  color: var(--txt-mid);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.hist-day-ca {
  font-family: 'VT323', 'Share Tech Mono', monospace;
  font-size:1.72rem;
  font-weight: 700;
  color: var(--gold-lt);
  margin-top: 2px;
}
.hist-day-couv {
  font-size: .88rem;
  color: var(--txt);
}
.hist-day-meta {
  font-size: .8rem;
  color: var(--txt-mid);
  margin-top: auto;
  padding-top: 4px;
  line-height: 1.3;
}
.hist-day-badges {
  position: absolute;
  top: 8px;
  right: 8px;
  display: flex;
  gap: 3px;
  font-size: .85rem;
}

/* ═══════════════════════════════════════════════════════════
   DEMANDES (OFF + CP)
   ═══════════════════════════════════════════════════════════ */
.dem-filters{
  display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px;align-items:center;
}
.dem-filters select{
  background:var(--surface);color:var(--txt);
  border:1px solid var(--bd);border-radius:8px;
  padding:7px 10px;font-family:inherit;font-size:.95rem;
  cursor:pointer;
}
.dem-filters select:hover{border-color:var(--gold-dim);}
.dem-refresh{
  background:var(--surface);color:var(--gold-lt);
  border:1px solid var(--bd);border-radius:8px;
  padding:7px 12px;cursor:pointer;font-size:1.5rem;
  transition:transform .2s, background .2s;
}
.dem-refresh:hover{background:rgba(77,255,77,.12);transform:rotate(180deg);}

.dem-table-wrap{overflow-x:auto;margin-bottom:24px;}
.dem-table{
  width:100%;border-collapse:collapse;
  background:var(--surface);border:1px solid var(--bd);border-radius:10px;
  overflow:hidden;font-size:.95rem;
}
.dem-table th{
  background:rgba(77,255,77,.1);color:var(--gold-lt);
  font-family:'VT323','Share Tech Mono',monospace;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;font-size:.8rem;
  padding:10px 12px;text-align:left;
  border-bottom:1px solid var(--bd);
}
.dem-table td{
  padding:10px 12px;border-bottom:1px solid rgba(77,255,77,.1);
  color:var(--txt);vertical-align:middle;
}
.dem-table tr:last-child td{border-bottom:none;}
.dem-table tr:hover{background:rgba(77,255,77,.04);}
.dem-table .dem-empty{
  color:var(--txt-dim);text-align:center;font-style:italic;padding:24px;
}

.dem-emp{display:flex;align-items:center;gap:8px;}
.dem-emp-name{font-weight:600;}
.dem-emp-zone{
  font-size:.72rem;font-weight:700;letter-spacing:.08em;
  padding:2px 7px;border-radius:6px;text-transform:uppercase;
}
.dem-emp-zone.zA{background:rgba(129,199,132,.15);color:#81c784;}
.dem-emp-zone.zB{background:rgba(100,181,246,.15);color:#64b5f6;}
.dem-emp-zone.zpoly{background:rgba(77,255,77,.15);color:var(--gold-lt);}

.dem-status{
  display:inline-block;font-size:.72rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:3px 10px;border-radius:10px;white-space:nowrap;
}
.dem-status.pending{background:rgba(255,183,77,.18);color:#ffb74d;}
.dem-status.approved,.dem-status.accepted{background:rgba(129,199,132,.18);color:#81c784;}
.dem-status.rejected{background:rgba(229,115,115,.18);color:#e57373;}
.dem-status.cancelled{background:rgba(158,158,158,.18);color:#9e9e9e;}
.sw-shift-tag{
  display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.04em;
  padding:1px 6px;border-radius:5px;background:rgba(100,180,250,.12);color:#8fd0ff;
}

.dem-sync-tag{
  font-size:.6rem;font-weight:700;letter-spacing:.06em;
  padding:2px 8px;border-radius:6px;white-space:nowrap;
}
.dem-sync-tag.done{background:rgba(129,199,132,.15);color:#81c784;}
.dem-sync-tag.queued{background:rgba(100,181,246,.15);color:#64b5f6;}
.dem-sync-tag.missing{background:rgba(229,115,115,.15);color:#e57373;}
.dem-sync-tag.na{color:var(--txt-dim);}

.dem-actions{display:flex;gap:4px;justify-content:flex-end;flex-wrap:nowrap;}
.dem-btn{
  background:none;border:1px solid transparent;
  padding:4px 8px;border-radius:6px;cursor:pointer;
  font-family:inherit;font-size:.8rem;font-weight:600;
  transition:all .15s;line-height:1.2;white-space:nowrap;
}
.dem-btn:disabled{opacity:.4;cursor:not-allowed;}
.dem-btn-approve{color:#81c784;border-color:rgba(129,199,132,.3);}
.dem-btn-approve:hover:not(:disabled){background:rgba(129,199,132,.15);border-color:#81c784;}
.dem-btn-reject{color:#ffb74d;border-color:rgba(255,183,77,.3);}
.dem-btn-reject:hover:not(:disabled){background:rgba(255,183,77,.15);border-color:#ffb74d;}
.dem-btn-delete{color:#e57373;border-color:rgba(229,115,115,.3);}
.dem-btn-delete:hover:not(:disabled){background:rgba(229,115,115,.15);border-color:#e57373;}

.dem-days-list{
  display:flex;flex-wrap:wrap;gap:3px;
  font-family:'VT323','Share Tech Mono',monospace;font-size:.85rem;
}
.dem-day-chip{
  padding:1px 6px;border-radius:4px;
  background:rgba(77,255,77,.08);color:var(--gold-lt);
  border:1px solid rgba(77,255,77,.15);
}

@media (max-width: 640px){
  .dem-table{font-size:.88rem;}
  .dem-table th, .dem-table td{padding:7px 8px;}
  .dem-btn{padding:4px 7px;font-size:.78rem;}
}

/* ═══════════════════════════════════════════════════════════
   PAIE
   ═══════════════════════════════════════════════════════════ */
.paie-controls{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin:14px 0 22px;
}
.paie-month-sel{
  display:flex;align-items:center;gap:8px;
  font-family:'VT323','Share Tech Mono',monospace;font-size:.9rem;color:var(--gold-dim);
  letter-spacing:.06em;text-transform:uppercase;
}
.paie-month-sel select{
  background:var(--surface);color:var(--txt);
  border:1px solid var(--bd);border-radius:8px;
  padding:8px 12px;font-family:inherit;font-size:1.5rem;
  font-family:'VT323','Share Tech Mono',monospace;letter-spacing:0;text-transform:none;
  cursor:pointer;min-width:180px;
}
.paie-month-sel select:hover{border-color:var(--gold-dim);}
.paie-btn-export{
  background:linear-gradient(135deg, var(--gold), var(--gold-dim));
  color:var(--bg);border:none;border-radius:10px;
  padding:11px 18px;font-family:'VT323','Share Tech Mono',monospace;font-size:.9rem;font-weight:700;
  letter-spacing:.08em;cursor:pointer;
  box-shadow:0 4px 12px rgba(77,255,77,.25);
  transition:all .2s;
  -webkit-tap-highlight-color:transparent;
}
.paie-btn-export:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(77,255,77,.4);}
.paie-btn-export:active{transform:scale(.97);}

.paie-table{font-family:'VT323','Share Tech Mono',monospace;}
.paie-table td.num{font-family:'VT323','Share Tech Mono',monospace;color:var(--gold);text-align:right;white-space:nowrap;}
.paie-table tr.total-row td{
  font-weight:700;color:var(--gold-lt);
  border-top:2px solid var(--bd-str);background:rgba(77,255,77,.05);
}
.paie-table tr.total-row td.num{color:var(--gold-lt);}
.paie-table .emp-zone-mini{
  display:inline-block;font-size:.58rem;font-weight:700;letter-spacing:.06em;
  padding:1px 6px;border-radius:5px;margin-left:6px;text-transform:uppercase;vertical-align:middle;
}
.paie-table .emp-zone-mini.zA{background:rgba(129,199,132,.15);color:#81c784;}
.paie-table .emp-zone-mini.zB{background:rgba(100,181,246,.15);color:#64b5f6;}
.paie-table .emp-zone-mini.zpoly{background:rgba(77,255,77,.15);color:var(--gold-lt);}
.paie-table td.warn{color:#ffb74d;font-style:italic;font-size:.78rem;}
.paie-table tbody tr{cursor:pointer;}
.paie-table tbody tr:hover{background:rgba(77,255,77,.08);}
.paie-table tbody tr.total-row{cursor:default;}
.paie-table tbody tr.total-row:hover{background:rgba(77,255,77,.05);}
.paie-table td.dim{color:var(--txt-dim);font-style:italic;}
.paie-table td.pos{color:var(--green);}
.paie-table td.neg{color:var(--orange);}

.paie-edit-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.paie-edit-grid label{
  display:flex;flex-direction:column;gap:4px;
  font-size:.82rem;font-weight:600;color:var(--gold-dim);
  letter-spacing:.06em;text-transform:uppercase;
}
.paie-edit-grid input{
  background:var(--surface2);color:var(--txt);
  border:1px solid var(--bd);border-radius:8px;
  padding:9px 12px;font-family:'VT323','Share Tech Mono',monospace;font-size:1.58rem;
  outline:none;
}
.paie-edit-grid input:focus{border-color:var(--bd-str);}
@media (max-width: 640px){
  .paie-edit-grid{grid-template-columns:1fr;}
}

/* ═══════════════════════════════════════════════════════════
   RH — onglet consolidé (Demandes + Heures + Phase 4)
   ═══════════════════════════════════════════════════════════ */
.rh-section{
  background:var(--surface);border:1px solid var(--bd);
  border-radius:14px;padding:18px 20px;margin-bottom:22px;
}
.rh-section-title{
  font-family:'VT323','Share Tech Mono',monospace;font-size:.92rem;font-weight:700;
  color:var(--gold-dim);letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:14px;display:flex;align-items:center;gap:8px;
}
.rh-section-title .rh-badge{
  font-family:'VT323','Share Tech Mono',monospace;font-size:.85rem;font-weight:700;
  background:rgba(77,255,77,.18);color:var(--gold);letter-spacing:0;
  padding:1px 9px;border-radius:20px;text-transform:none;
}
.rh-heures-controls{
  display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px;
}
.rh-heures-controls label{
  display:flex;flex-direction:column;gap:4px;
  font-size:.82rem;font-weight:600;color:var(--gold-dim);
  letter-spacing:.06em;text-transform:uppercase;
}
.rh-heures-controls select{
  background:var(--surface2);color:var(--txt);
  border:1px solid var(--bd);border-radius:8px;
  padding:8px 12px;font-family:'VT323','Share Tech Mono',monospace;font-size:1.5rem;
  cursor:pointer;
}
.rh-heures-controls select:focus{border-color:var(--bd-str);outline:none;}
#rh-heures-form{display:none;}
#rh-heures-form.active{display:block;}
.rh-heures-section-label{
  font-family:'VT323','Share Tech Mono',monospace;font-size:.82rem;font-weight:600;
  color:var(--gold-dim);letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:8px;
}
.rh-heures-section-label+.rh-heures-section-label, .rh-heures-section-label ~ div + .rh-heures-section-label{
  margin-top:18px;
}
.rh-heures-actions{display:flex;gap:8px;margin-top:18px;}
.rh-heures-hint{
  color:var(--txt-dim);font-size:.95rem;font-style:italic;padding:18px 0 4px;
  text-align:center;
}
.rh-placeholder{
  background:rgba(77,255,77,.04);border:1px dashed rgba(77,255,77,.18);
  border-radius:10px;padding:20px 18px;text-align:center;
  color:var(--txt-dim);font-size:.95rem;
}
.rh-placeholder strong{display:block;color:var(--txt-mid);margin-bottom:6px;font-size:.9rem;}

/* Carnet fournisseurs */
.f-card{
  background:var(--surface);border:1px solid var(--bd);
  border-radius:12px;padding:16px 18px;margin-bottom:14px;
}
.f-card-top{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  margin-bottom:6px;
}
.f-card-name{
  font-family:'VT323','Share Tech Mono',monospace;font-size:1.65rem;color:var(--gold);font-weight:700;
}
.f-card-stats{
  color:var(--txt-mid);font-size:.9rem;margin-bottom:10px;
}
.f-card-actions{display:flex;gap:8px;flex-shrink:0;}
.f-action-btn{
  background:none;border:1px solid var(--bd);
  padding:5px 10px;border-radius:8px;cursor:pointer;
  font-size:.95rem;color:var(--txt-mid);
  transition:all .15s;
  text-decoration:none;display:inline-flex;align-items:center;gap:4px;
}
.f-action-btn:hover{border-color:var(--gold-dim);color:var(--gold);}
.f-action-btn.f-edit-btn.active{border-color:var(--gold-dim);color:var(--gold);
  background:rgba(77,255,77,.08);}
.f-carnet-panel{
  display:none;padding:14px 0 4px;border-top:1px solid var(--bd);margin-top:12px;
}
.f-carnet-panel.open{display:block;}
.f-carnet-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;
}
.f-carnet-grid label{
  display:flex;flex-direction:column;gap:4px;
  font-size:.82rem;font-weight:600;color:var(--gold-dim);
  letter-spacing:.06em;text-transform:uppercase;
}
.f-carnet-grid input,.f-carnet-grid select,.f-carnet-grid textarea{
  background:var(--surface2);color:var(--txt);
  border:1px solid var(--bd);border-radius:8px;
  padding:8px 10px;font-family:'VT323','Share Tech Mono',monospace;font-size:1.5rem;
  outline:none;
}
.f-carnet-grid input:focus,.f-carnet-grid select:focus,.f-carnet-grid textarea:focus{
  border-color:var(--bd-str);
}
.f-carnet-grid .full-width{grid-column:1/-1;}
.f-carnet-grid textarea{resize:vertical;min-height:56px;}
.f-carnet-save-btn{
  background:linear-gradient(135deg,var(--gold),var(--gold-dim));
  color:var(--bg);border:none;border-radius:8px;
  padding:9px 18px;font-family:'VT323','Share Tech Mono',monospace;font-size:.88rem;font-weight:700;
  letter-spacing:.08em;cursor:pointer;transition:all .2s;
}
.f-carnet-save-btn:hover{box-shadow:0 4px 14px rgba(77,255,77,.4);}
.f-carnet-coords{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;
}
.f-coord-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.9rem;color:var(--txt-mid);
  background:rgba(77,255,77,.06);border:1px solid var(--bd);
  padding:3px 10px;border-radius:20px;text-decoration:none;
}
.f-coord-chip:hover{color:var(--gold);border-color:var(--gold-dim);}
.f-zone-badge{
  display:inline-block;font-size:.75rem;font-weight:700;
  padding:1px 8px;border-radius:10px;letter-spacing:.05em;text-transform:uppercase;
}
.f-zone-badge.zA{background:rgba(129,199,132,.15);color:#81c784;}
.f-zone-badge.zB{background:rgba(100,181,246,.15);color:#64b5f6;}
.f-zone-badge.zAB{background:rgba(77,255,77,.15);color:var(--gold);}
@media(max-width:640px){
  .f-carnet-grid{grid-template-columns:1fr;}
}

/* ─── Bar : boutons ─────────────────────────────────────── */
.btn-gold{
  background:var(--gold);color:#0a150e;border:none;
  padding:9px 18px;border-radius:8px;font-size:.92rem;font-weight:700;
  cursor:pointer;transition:background .15s,opacity .15s;
  letter-spacing:.03em;
}
.btn-gold:hover{background:var(--gold-lt);}
.btn-gold:disabled{opacity:.45;cursor:default;}
.btn-outline{
  background:transparent;color:var(--gold);
  border:1px solid var(--bd-str);
  padding:8px 16px;border-radius:8px;font-size:.92rem;font-weight:600;
  cursor:pointer;transition:background .15s,border-color .15s;
}
.btn-outline:hover{background:rgba(77,255,77,.08);border-color:var(--gold);}

/* ─── Bar : champs formulaire ───────────────────────────── */
.field-label{
  display:block;font-size:.85rem;color:var(--txt-mid);
  letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase;
}
.field-input{
  width:100%;background:var(--surface2);color:var(--txt);
  border:1px solid var(--bd-str);border-radius:8px;
  padding:9px 12px;font-size:.95rem;
  outline:none;transition:border-color .15s;
}
.field-input:focus{border-color:var(--gold);}
.field-input option{background:var(--surface2);}

/* ─── Bar : badges marge ─────────────────────────────────── */
.marge-badge{
  display:inline-block;padding:2px 7px;border-radius:5px;
  font-size:.85rem;font-weight:700;
}
.marge-hi{background:rgba(76,175,80,.2);color:#4cca7a;}
.marge-mid{background:rgba(255,210,102,.15);color:#ffd266;}
.marge-lo{background:rgba(231,76,60,.2);color:#e74c3c;}
.marge-na{background:transparent;color:var(--txt-dim);}

/* ─── Bar : KPI cards ────────────────────────────────────── */
.bar-kpi{
  background:var(--surface);border:1px solid var(--bd);
  border-radius:10px;padding:12px 10px;text-align:center;
}
.bar-kpi-label{font-size:.75rem;color:var(--txt-mid);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px;}
.bar-kpi-val{font-family:'VT323','Share Tech Mono',monospace;font-size:1.95rem;font-weight:700;color:var(--gold);}
.bar-kpi-sub{font-size:.72rem;color:var(--txt-dim);margin-top:3px;}

/* ═══════════════════════════════════════════════════════════
   DOCK — Identical to apps.lequai56.fr dock
   ═══════════════════════════════════════════════════════════ */
.g-dock{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:2px;
  height:calc(66px + env(safe-area-inset-bottom,0px));
  padding:6px 4px env(safe-area-inset-bottom,0px);
  background:rgba(0,10,4,.95);
  border-top:1px solid rgba(77,255,77,.25);
  box-shadow:0 -4px 20px rgba(0,0,0,.6);
}
.g-dock-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;text-decoration:none;color:var(--txt);
  background:transparent;border:none;cursor:pointer;
  padding:6px 2px 4px;
  -webkit-tap-highlight-color:transparent;
  position:relative;
  font-family:inherit;font-size:15px;
  letter-spacing:.14em;text-transform:uppercase;
  transition:background .15s,color .15s;
  overflow:hidden;
}
.g-dock-btn:hover{background:rgba(77,255,77,.08);}
.g-dock-btn:active{transform:scale(.92);transition:transform .08s ease;}
.g-dock-btn.active{
  background:var(--gold);color:#001a08;
  box-shadow:0 0 8px var(--gold),inset 0 0 8px rgba(0,0,0,.35);
}
.g-dock-btn.active svg{stroke:#001a08 !important;filter:none !important;}
.g-dock-icon{line-height:1;display:flex;align-items:center;justify-content:center;}
.g-dock-label{line-height:1;}
.g-dock-badge{
  position:absolute;top:2px;right:4px;
  min-width:14px;height:12px;padding:0 3px;
  background:#ffd266;color:#001a08;
  font-size:14px;line-height:12px;text-align:center;
  font-weight:700;box-shadow:0 0 5px #ffd266;
  display:none;
}
.g-dock-badge.active{display:block;}

/* Adjust body padding for dock */
body{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))!important;}

/* ── User name in header ── */
.g-user-name{
  font-size:.72rem;color:var(--txt-mid);margin-top:6px;letter-spacing:.04em;
}

/* ═══════════════════════════════════════════════════════════
   QUICK GLANCE — KPI ribbon at top of hub
   ═══════════════════════════════════════════════════════════ */
.g-kpi-ribbon{
  display:flex;align-items:center;justify-content:center;
  gap:0;padding:14px 16px;margin-bottom:14px;
  background:var(--surface);border:1px solid var(--bd);
  border-radius:14px;text-decoration:none;color:var(--txt);
  position:relative;overflow:hidden;
  transition:border-color .25s,box-shadow .25s;
}
.g-kpi-ribbon:hover{
  border-color:rgba(77,255,77,.4);
  box-shadow:0 4px 20px rgba(77,255,77,.1);
}
.g-kpi-slot{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
}
.g-kpi-val{
  font-family:'VT323','Share Tech Mono',monospace;font-size:1.95rem;font-weight:700;
  color:var(--gold);line-height:1.2;
}
.g-kpi-val.up{color:rgba(76,175,80,.95);}
.g-kpi-val.down{color:rgba(239,83,80,.95);}
.g-kpi-val.flat{color:var(--txt-mid);}
.g-kpi-lbl{
  font-size:.72rem;color:var(--txt-dim);text-transform:uppercase;
  letter-spacing:.08em;
}
.g-kpi-divider{
  width:1px;height:32px;background:var(--bd);flex-shrink:0;
  margin:0 4px;
}
.g-kpi-arrow{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  font-size:1.8rem;color:var(--gold-dim);
  transition:transform .2s,color .2s;
}
.g-kpi-ribbon:hover .g-kpi-arrow{
  transform:translateY(-50%) translateX(3px);color:var(--gold);
}

/* ═══════════════════════════════════════════════════════════
   SECTION LABELS — subtle group headers
   ═══════════════════════════════════════════════════════════ */
.g-section-label{
  font-family:'VT323','Share Tech Mono',monospace;font-size:.75rem;font-weight:700;
  color:var(--gold-dim);letter-spacing:.2em;text-transform:uppercase;
  margin:18px 0 6px 4px;
  display:flex;align-items:center;gap:10px;
}
.g-section-label::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg,rgba(77,255,77,.2),transparent);
}

/* ═══════════════════════════════════════════════════════════
   MODULES GRID — Same app-tile style as hub
   ═══════════════════════════════════════════════════════════ */
.g-modules{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:10px;padding:4px 0 4px;
}
.g-module{
  position:relative;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  background:rgba(77,255,77,.06);
  border:1px solid rgba(77,255,77,.22);
  border-radius:14px;padding:18px 8px 14px;
  text-decoration:none;color:var(--txt);
  cursor:pointer;overflow:hidden;gap:6px;min-height:100px;
  transition:background .25s,border-color .25s,transform .18s,box-shadow .25s;
  -webkit-tap-highlight-color:transparent;
}
.g-module:hover,.g-module:focus-visible{
  background:rgba(77,255,77,.12);border-color:rgba(77,255,77,.5);
  box-shadow:0 4px 20px rgba(77,255,77,.12);transform:translateY(-2px);
}
.g-module:active{transform:translateY(0) scale(.97);}
.g-module-icon{font-size:2.7rem;line-height:1;height:40px;display:flex;align-items:center;justify-content:center;}
.g-module-name{font-size:.85rem;font-weight:700;color:var(--txt);text-align:center;line-height:1.2;}
.g-module-desc{font-size:.72rem;color:var(--txt-dim);text-align:center;line-height:1.3;}
.g-module-badge{
  position:absolute;top:4px;right:6px;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--red,#e74c3c);color:#fff;font-size:.72rem;font-weight:700;
  border-radius:9px;display:none;
  align-items:center;justify-content:center;
}
.g-module-badge.active{display:flex;}

/* ═══════════════════════════════════════════════════════════
   SECTION HEADERS — Same as hub
   ═══════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════
   PUSH CARD — ff-panel gold border style
   ═══════════════════════════════════════════════════════════ */
.g-push-card{
  position:relative;border-radius:14px;
  background:rgba(16,40,26,.85);
  padding:2px;margin-bottom:14px;overflow:visible;
}
.g-push-card::before{
  content:'';position:absolute;inset:0;border-radius:14px;padding:1.5px;
  background:linear-gradient(135deg,#4dff4d 0%,#1a8c1a 40%,#4dff4d 50%,#1a8c1a 60%,#b8ffb8 100%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.g-push-header{
  display:flex;align-items:center;gap:8px;padding:12px 16px;cursor:pointer;
  -webkit-tap-highlight-color:transparent;border-radius:12px;
}
.g-push-header:hover{background:rgba(77,255,77,.04);}
.g-push-icon{font-size:1.65rem;}
.g-push-title{
  font-family:'VT323','Share Tech Mono',monospace;font-size:.88rem;font-weight:700;
  color:var(--gold);letter-spacing:.08em;flex:1;
}
.g-push-toggle{
  background:none;border:none;color:var(--txt-dim);font-size:.9rem;
  cursor:pointer;padding:4px 8px;
}
.g-push-body{
  padding:4px 16px 14px;
  border-top:1px solid rgba(77,255,77,.12);
}

/* ── Hub link & logout → floating top bar ── */
.hub-link{
  position:fixed;top:10px;left:12px;z-index:100;
  font-size:.82rem;padding:5px 12px;border-radius:10px;text-decoration:none;
  color:var(--txt-mid);background:rgba(16,40,26,.85);
  border:1px solid rgba(77,255,77,.2);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.logout-btn{
  position:fixed;top:10px;right:12px;z-index:100;
  font-size:.82rem;padding:5px 12px;border-radius:10px;
  color:var(--txt-mid);background:rgba(16,40,26,.85);
  border:1px solid rgba(77,255,77,.2);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  font-family:'VT323','Share Tech Mono',monospace;cursor:pointer;
}
.hub-link:hover,.logout-btn:hover{border-color:rgba(77,255,77,.45);color:var(--gold);}

/* ═══════════════════════════════════════════════════════════
   OFFLINE BANNER
   ═══════════════════════════════════════════════════════════ */
.offline-bar{
  position:fixed;top:0;left:0;right:0;z-index:9999;
  background:rgba(0,10,4,.95);color:var(--warn);
  border-bottom:1px solid rgba(255,210,102,.4);
  text-align:center;font-size:.9rem;font-weight:700;letter-spacing:.1em;
  padding:8px 12px;transform:translateY(-100%);transition:transform .35s ease;
  box-shadow:0 2px 12px rgba(0,0,0,.6);
}
.offline-bar.show{transform:translateY(0);}
.offline-bar span{opacity:.6;font-weight:400;margin-left:6px;}

/* ═══════════════════════════════════════════════════════════
   JUICE — Ripple + Sparkle (same as apps hub)
   ═══════════════════════════════════════════════════════════ */
.ripple{
  position:absolute;border-radius:50%;
  background:radial-gradient(circle,rgba(77,255,77,.55) 0%,rgba(77,255,77,0) 70%);
  pointer-events:none;transform:translate(-50%,-50%) scale(0);
  animation:ripple-expand .6s ease-out forwards;mix-blend-mode:screen;
}
@keyframes ripple-expand{
  0%{transform:translate(-50%,-50%) scale(0);opacity:.9}
  100%{transform:translate(-50%,-50%) scale(3);opacity:0}
}
.spark{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle,#b8ffb8 0%,#4dff4d 40%,rgba(77,255,77,0) 80%);
  pointer-events:none;transform:translate(-50%,-50%);
  animation:spark-burst .7s cubic-bezier(.2,.8,.2,1) forwards;
  will-change:transform,opacity;
}
@keyframes spark-burst{
  0%{transform:translate(-50%,-50%) translate(0,0) scale(1);opacity:1}
  100%{transform:translate(-50%,-50%) translate(var(--sx),var(--sy)) scale(.2);opacity:0}
}

/* Responsive : 2 columns on very small screens */
@media(max-width:360px){
  .g-modules{grid-template-columns:repeat(2,1fr);}
  .g-kpi-val{font-size:1.65rem;}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;}
}
