
/* ── Reset ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Variables ─────────────────────────────────────────────────── */
:root {
  /* Palette sable / plage */
  --s:  #F7F4EE;
  --s1: #E7E1D6;
  --s2: #C3A363;
  --s3: #836C3F;
  --s4: #4E442F;

  /* Palette océan profond (sidebar) */
  --n:  #373735;
  --n2: #4C4C49;
  --n3: #62625E;
  --n4: #D8D3C9;
  --shell: #FFFFFF;
  --shell-border: #E7E1D6;
  --shell-text: #373735;
  --shell-muted: rgba(55,55,53,.58);
  --badge-text: #373735;

  /* Statuts */
  --red: #e03535;
  --ora: #f07030;
  --grn: #1D9E75;
  --blu: #2176ae;
  --pnk: #d63884;
  --gry: #7a8a9a;
  --yel: #e8b830;
  --pur: #7c4dcc;
  --tel: #1D9E75;
  --free: #0e9aa0;

  /* Fond — ciel de plage doux */
  --bg: #FFFFFF;
  --wh: #FFFFFF;

  /* Sidebar */
  --sb-w: 220px;

  /* Shadows */
  --sh1: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --sh2: 0 4px 12px rgba(0,0,0,.10), 0 2px 4px rgba(0,0,0,.06);
  --sh3: 0 8px 24px rgba(0,0,0,.14), 0 4px 8px rgba(0,0,0,.08);

  /* Radius */
  --r1: 6px;
  --r2: 10px;
  --r3: 14px;
}

[data-theme="dark"] {
  --s:  #252525;
  --s1: #343434;
  --s2: #C3A363;
  --s3: #D0B77A;
  --s4: #E8D9AA;
  --n:  #F5F3ED;
  --n2: #E8E4DB;
  --n3: #D8D3C9;
  --n4: #383A3C;
  --shell: #1B1D1F;
  --shell-border: #33363A;
  --shell-text: #F5F3ED;
  --shell-muted: rgba(245,243,237,.58);
  --badge-text: #1B1D1F;
  --bg: #121416;
  --wh: #1B1D1F;
  --gry: #AEB4BA;
  --sh1: 0 1px 3px rgba(0,0,0,.35), 0 1px 2px rgba(0,0,0,.28);
  --sh2: 0 4px 12px rgba(0,0,0,.38), 0 2px 4px rgba(0,0,0,.30);
  --sh3: 0 8px 24px rgba(0,0,0,.48), 0 4px 8px rgba(0,0,0,.38);
  color-scheme: dark;
}

/* ── Base ───────────────────────────────────────────────────────── */
html, body {
  height: 100%;
  font-family: 'DM Sans', system-ui, sans-serif;
  background: var(--bg);
  color: var(--n);
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}

/* ── App shell ─────────────────────────────────────────────────── */
.app {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

/* ── Sidebar info (logo + user) — desktop ──────────────────────── */
.sb-info {
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 0;
  background: var(--shell);
  padding: 22px 16px 14px;
  border-right: 1px solid var(--shell-border);
  position: relative;
}

.sb-info::after {
  content: '';
  position: absolute;
  bottom: 0; left: 16px; right: 16px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--shell-border), transparent);
}

.sb-logo-img {
  height: 58px;
  width: 100%;
  object-fit: contain;
  display: block;
  margin-bottom: 16px;
}

.sb-user {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 7px;
  width: 100%;
}

/* Badge rôle sidebar — plus élégant */
.sb-info .role-badge {
  display: block;
  text-align: center;
  font-size: 11px !important;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: var(--r1);
  width: 100%;
}

.btn-pin {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: color-mix(in srgb, var(--shell-text) 6%, transparent);
  border: 1px solid var(--shell-border);
  border-radius: var(--r1);
  color: var(--shell-muted);
  font-size: 11px;
  font-weight: 600;
  padding: 7px 12px;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: .04em;
  transition: all .15s;
  width: 100%;
  text-align: center;
}
.btn-pin:hover { background: color-mix(in srgb, var(--s2) 14%, transparent); color: var(--shell-text); border-color: var(--s2); }

.btn-pin-mob {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--r1);
  color: rgba(255,255,255,.8);
  font-size: 10px;
  font-weight: 700;
  padding: 4px 10px;
  cursor: pointer;
  font-family: inherit;
}

/* ── Mobile header ─────────────────────────────────────────────── */
.mob-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 14px;
  height: 54px;
  background: var(--shell);
  border-bottom: 2px solid var(--s2);
  flex-shrink: 0;
  gap: 10px;
}

.mob-hdr-brand {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}

.mob-logo {
  height: 32px;
  width: auto;
  object-fit: contain;
  flex-shrink: 0;
}

.mob-app-name {
  font-size: 15px;
  font-weight: 800;
  color: var(--shell-text);
  letter-spacing: -.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mob-hdr-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.mob-pin-btn {
  background: color-mix(in srgb, var(--shell-text) 6%, transparent);
  border: 1px solid var(--shell-border);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--shell-muted);
  transition: background .15s;
}
.mob-pin-btn:hover { background: color-mix(in srgb, var(--s2) 14%, transparent); color: var(--shell-text); }

.theme-btn {
  background: color-mix(in srgb, var(--shell-text) 6%, transparent);
  border: 1px solid var(--shell-border);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--shell-muted);
  transition: background .15s, color .15s;
  padding: 0;
  flex-shrink: 0;
}
.theme-btn:hover { background: color-mix(in srgb, var(--s2) 14%, transparent); color: var(--shell-text); }
.theme-btn svg { width: 16px; height: 16px; }

/* ── App body ──────────────────────────────────────────────────── */
.app-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
}

/* ── Flash info ────────────────────────────────────────────────── */
.flash {
  background: rgba(212,168,83,.13);
  border-bottom: 1px solid rgba(212,168,83,.28);
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 500;
  color: var(--n);
  letter-spacing: .01em;
  line-height: 1.4;
}

.flash-edit-btn {
  background: rgba(212,168,83,.18);
  border: 1px solid rgba(212,168,83,.35);
  border-radius: var(--r1);
  color: var(--s2);
  font-size: 10px;
  font-weight: 700;
  padding: 3px 10px;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background .15s;
}
.flash-edit-btn:hover { background: rgba(212,168,83,.3); }

.flash-theme-btn {
  background: rgba(212,168,83,.12);
  border: 1px solid rgba(212,168,83,.4);
  border-radius: 50%;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--s2);
  flex-shrink: 0;
  transition: background .15s;
  padding: 0;
}
.flash-theme-btn:hover { background: rgba(212,168,83,.28); }
.flash-theme-btn::before {
  content: '';
  display: block;
  width: 14px;
  height: 14px;
  background-color: currentColor;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Cpath d='M12 2v2'/%3E%3Cpath d='M12 20v2'/%3E%3Cpath d='m4.93 4.93 1.41 1.41'/%3E%3Cpath d='m17.66 17.66 1.41 1.41'/%3E%3Cpath d='M2 12h2'/%3E%3Cpath d='M20 12h2'/%3E%3Cpath d='m6.34 17.66-1.41 1.41'/%3E%3Cpath d='m19.07 4.93-1.41 1.41'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Cpath d='M12 2v2'/%3E%3Cpath d='M12 20v2'/%3E%3Cpath d='m4.93 4.93 1.41 1.41'/%3E%3Cpath d='m17.66 17.66 1.41 1.41'/%3E%3Cpath d='M2 12h2'/%3E%3Cpath d='M20 12h2'/%3E%3Cpath d='m6.34 17.66-1.41 1.41'/%3E%3Cpath d='m19.07 4.93-1.41 1.41'/%3E%3C/svg%3E");
}
[data-theme="dark"] .flash-theme-btn::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9z'/%3E%3C/svg%3E");
}

/* ── Global nav (mobile: bottom bar, desktop: sidebar via grid) ── */
.gnav {
  display: flex;
  flex-direction: row;
  background: var(--shell);
  flex-shrink: 0;
  overflow-x: auto;
  scrollbar-width: none;
  gap: 0;
  padding: 0;
}
.gnav::-webkit-scrollbar { display: none; }

.gnt {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 8px 4px 6px;
  border: none;
  background: transparent;
  color: var(--shell-muted);
  cursor: pointer;
  font-family: inherit;
  transition: color .15s, background .15s;
  white-space: nowrap;
  flex: 1;
}
.gnt.on   { color: var(--s2); background: color-mix(in srgb, var(--s2) 13%, transparent); }
.gnt:hover:not(.on) { color: var(--shell-text); background: color-mix(in srgb, var(--shell-text) 5%, transparent); }

.gnt-ic { width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; }
.gnt-ic svg { width: 22px; height: 22px; }
.gnt-lb { font-size: 9px; font-weight: 600; letter-spacing: .02em; }

/* ── Sub nav ───────────────────────────────────────────────────── */
.snav {
  display: flex;
  background: var(--wh);
  flex-shrink: 0;
  overflow-x: auto;
  scrollbar-width: none;
  border-bottom: 2px solid var(--s1);
  gap: 0;
  padding: 0 12px;
  box-shadow: 0 2px 6px rgba(0,0,0,.05);
}
.snav::-webkit-scrollbar { display: none; }

.snt {
  padding: 0 14px;
  height: 44px;
  border: none;
  border-bottom: 2.5px solid transparent;
  background: transparent;
  color: var(--gry);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
  transition: color .15s, border-color .15s;
}
.snt.on  { color: var(--n); border-bottom-color: var(--s2); }
.snt:hover:not(.on) { color: var(--n); }

.snt-ic { display: flex; align-items: center; }
.snt-ic svg { width: 15px; height: 15px; }

.snb {
  background: var(--red);
  color: #fff;
  border-radius: 20px;
  padding: 1px 6px;
  font-size: 9px;
  font-weight: 700;
  line-height: 1.5;
}

/* ── Main content ──────────────────────────────────────────────── */
.main {
  flex: 1;
  overflow-y: auto;
  padding: 14px;
  scroll-behavior: smooth;
}

/* ── Étiquettes / Filtres ──────────────────────────────────────── */
.et-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  padding: 10px 12px;
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r2);
  align-items: center;
  box-shadow: var(--sh1);
}

.et {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 10.5px;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid transparent;
  white-space: nowrap;
  transition: all .15s;
  font-family: inherit;
}
.et:hover { transform: translateY(-1px); box-shadow: var(--sh1); }
.et.on { box-shadow: 0 0 0 2px rgba(0,0,0,.12); }

.et-all  { background: var(--n);   color: var(--s);   border-color: var(--n3); }
.et-all.on { border-color: var(--s2); }
.et-todo { background: #fff9e6; color: #7a5000; border-color: var(--yel); }
.et-todo.on { background: var(--yel); color: #111; }
.et-urg  { background: #fef0f0; color: #b01c1c; border-color: var(--red); }
.et-urg.on  { background: var(--red); color: #fff; }
.et-blk  { background: #f2f2f2; color: #444; border-color: #bbb; }
.et-blk.on  { background: #666; color: #fff; }
.et-done { background: #edf7f1; color: #146038; border-color: var(--grn); }
.et-done.on { background: var(--grn); color: #fff; }
.et-red  { background: #fef0f0; color: #b01c1c; border-color: var(--red); }
.et-red.on  { background: var(--red); color: #fff; }
.et-grn  { background: #edf7f1; color: #146038; border-color: var(--grn); }
.et-grn.on  { background: var(--grn); color: #fff; }
.et-gray { background: #f2f2f2; color: #444; border-color: #bbb; }
.et-gray.on { background: #666; color: #fff; }
.et-pnk  { background: #fef0f8; color: #9a0055; border-color: var(--pnk); }
.et-pnk.on  { background: var(--pnk); color: #fff; }
.et-yel  { background: #fff9e6; color: #7a5000; border-color: var(--yel); }
.et-yel.on  { background: var(--yel); color: #111; }
.et-blu  { background: #eaf3fb; color: #0e4478; border-color: var(--blu); }
.et-blu.on  { background: var(--blu); color: #fff; }
.et-free { background: #e0f7fa; color: #006070; border-color: var(--free); }
.et-free.on { background: var(--free); color: #fff; }

/* ── Cards ─────────────────────────────────────────────────────── */
.cards { display: flex; flex-direction: column; gap: 7px; }

.card {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r2);
  padding: 11px 14px;
  position: relative;
  box-shadow: var(--sh1);
  transition: box-shadow .15s, transform .12s;
}
.card:hover { box-shadow: var(--sh2); transform: translateY(-1px); }

.mh-ref {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--n);
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.mh-ref-ic {
  width: 17px;
  height: 17px;
  color: var(--s3);
  flex-shrink: 0;
}

.mh-ref-camping .mh-ref-ic {
  color: var(--blu);
}

.mh-ref-resident .mh-ref-ic {
  color: var(--pur);
}

.mh-ref-compact .mh-ref-ic {
  width: 14px;
  height: 14px;
}

.mh-ref-large .mh-ref-ic {
  width: 20px;
  height: 20px;
}

.c-todo { border-left: 4px solid var(--yel) !important; }
.c-urg  { border-left: 4px solid var(--red) !important; background: #fffcfc; }
.c-blk  { border-left: 4px solid #888 !important; background: #fafafa; }
.c-done { border-left: 4px solid var(--grn) !important; background: #f8fdf9; }
.c-red  { border-left: 4px solid var(--red) !important; }
.c-grn  { border-left: 4px solid var(--grn) !important; }
.c-yel  { border-left: 4px solid var(--yel) !important; }
.c-pnk  { border-left: 4px solid var(--pnk) !important; }
.c-gray { border-left: 4px solid #888 !important; }
.c-blu  { border-left: 4px solid var(--blu) !important; }
.c-free { border-left: 4px solid var(--free) !important; background: #f0fdff; }

.card-head { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; flex-wrap: wrap; }
.cnum { font-size: 13px; font-weight: 800; letter-spacing: -.01em; }
.cop  { font-size: 12px; margin-bottom: 5px; line-height: 1.5; color: #2a2a2a; }
.cbot { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 4px; }
.cmeta { font-size: 10px; color: var(--gry); }

/* ── Pills / Badges ────────────────────────────────────────────── */
.pill {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
}
.p-todo { background: #fff9e6; color: #7a5000; }
.p-urg  { background: #fef0f0; color: var(--red); font-weight: 800; }
.p-blk  { background: #f2f2f2; color: #555; }
.p-grn  { background: #edf7f1; color: #146038; }
.p-red  { background: #fef0f0; color: var(--red); }
.p-ora  { background: #fff4ec; color: #b04800; }
.p-gry  { background: #f5f5f5; color: #555; }
.p-blu  { background: #eaf3fb; color: var(--blu); }
.p-pnk  { background: #fef0f8; color: var(--pnk); }

/* ── Forms ─────────────────────────────────────────────────────── */
.form-box {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r2);
  padding: 14px;
  margin-bottom: 12px;
  box-shadow: var(--sh1);
}

.fl {
  font-size: 10px;
  font-weight: 700;
  color: var(--s3);
  text-transform: uppercase;
  letter-spacing: .07em;
  display: block;
  margin-bottom: 4px;
}

.fi, .fsel, .fta {
  width: 100%;
  padding: 8px 10px;
  border: 1.5px solid var(--s1);
  border-radius: var(--r1);
  font-size: 13px;
  font-family: inherit;
  background: var(--wh);
  color: var(--n);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.fi:focus, .fsel:focus, .fta:focus {
  border-color: var(--grn);
  box-shadow: 0 0 0 3px rgba(29,158,117,.12);
}

.fta { height: 60px; resize: vertical; }
.g2  { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.g3  { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 7px; }
.g4  { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 6px; }
.frow { margin-bottom: 10px; }

[data-theme="dark"] .cop { color: var(--n); }
[data-theme="dark"] .c-urg,
[data-theme="dark"] .c-blk,
[data-theme="dark"] .c-done,
[data-theme="dark"] .c-free {
  background: var(--wh);
}
[data-theme="dark"] .et-row,
[data-theme="dark"] .form-box,
[data-theme="dark"] .card,
[data-theme="dark"] .ovc,
[data-theme="dark"] .day-col,
[data-theme="dark"] .topbar,
[data-theme="dark"] .snav {
  border-color: var(--s1);
}

/* ── Buttons ───────────────────────────────────────────────────── */
.btn-p {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 8px 16px;
  border-radius: var(--r1);
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  background: var(--grn);
  color: #fff;
  font-family: inherit;
  transition: background .15s, transform .1s, box-shadow .15s;
  box-shadow: 0 2px 6px rgba(29,158,117,.3);
}
.btn-p:hover { background: #18876a; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(29,158,117,.35); }
.btn-p:active { transform: translateY(0); }

.btn-s {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 8px 14px;
  border-radius: var(--r1);
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  border: 1.5px solid var(--s1);
  background: var(--wh);
  color: var(--n);
  font-family: inherit;
  transition: background .15s, border-color .15s;
}
.btn-s:hover { background: var(--s); border-color: var(--s2); }

.btn-sm {
  background: rgba(255,255,255,.12);
  color: var(--s2);
  border: 1px solid rgba(212,184,122,.3);
  border-radius: var(--r1);
  padding: 4px 10px;
  font-size: 10.5px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s;
}
.btn-sm:hover { background: rgba(255,255,255,.2); }

.btn-cr {
  width: 100%;
  padding: 12px;
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: var(--r2);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  margin-bottom: 12px;
  font-family: inherit;
  transition: background .15s;
  box-shadow: 0 2px 8px rgba(224,53,53,.25);
}
.btn-cr:hover { background: #c52020; }

/* ── Tabs ───────────────────────────────────────────────────────── */
.tabs { display: flex; gap: 4px; margin-bottom: 10px; flex-wrap: wrap; }

.tab {
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 10.5px;
  cursor: pointer;
  border: 1.5px solid var(--s1);
  background: var(--wh);
  color: var(--s3);
  font-weight: 600;
  font-family: inherit;
  transition: all .15s;
}
.tab:hover { border-color: var(--s2); color: var(--s4); }
.tab.on { background: var(--n); color: var(--s2); border-color: var(--n); }

/* ── Overlays ──────────────────────────────────────────────────── */
.ovl {
  position: fixed;
  inset: 0;
  background: rgba(10,20,10,.55);
  backdrop-filter: blur(3px);
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 300;
  padding: 16px;
  overflow-y: auto;
}
.ovl.on { display: flex; animation: fadeIn .18s ease; }

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.ovc {
  background: var(--wh);
  border-radius: var(--r3);
  border: 1px solid var(--s1);
  width: 100%;
  max-width: 480px;
  padding: 18px;
  margin: auto;
  box-shadow: var(--sh3);
  animation: slideUp .2s ease;
}

@keyframes slideUp {
  from { transform: translateY(12px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

.ovh {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--s1);
}

.ovt {
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--n);
}

.xb {
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 50%;
  width: 30px;
  height: 30px;
  font-size: 14px;
  cursor: pointer;
  color: var(--gry);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, color .15s;
}
.xb:hover { background: var(--red); color: #fff; border-color: var(--red); }

/* ── Detail rows ───────────────────────────────────────────────── */
.dr {
  display: flex;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid var(--s1);
  font-size: 12px;
  gap: 8px;
}
.dl { color: var(--gry); flex-shrink: 0; }
.dv { font-weight: 700; text-align: right; color: var(--n); }

/* ── Labels ────────────────────────────────────────────────────── */
.slbl {
  font-size: 10px;
  font-weight: 700;
  color: var(--s3);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 12px 0 6px;
}

.ms {
  font-size: 10px;
  padding: 4px 8px;
  border-radius: 20px;
  border: 1.5px solid var(--s1);
  background: var(--wh);
  cursor: pointer;
  outline: none;
  font-family: inherit;
  transition: border-color .15s;
}
.ms:focus { border-color: var(--grn); }

/* ── Role badge ────────────────────────────────────────────────── */
.role-badge {
  font-size: 9.5px;
  padding: 3px 10px;
  border-radius: 20px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* ── Notifications ─────────────────────────────────────────────── */
.confbox {
  position: fixed;
  top: 20%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--wh);
  border: 2px solid var(--grn);
  border-radius: var(--r3);
  padding: 18px 28px;
  text-align: center;
  z-index: 610;
  min-width: 200px;
  display: none;
  box-shadow: var(--sh3);
}

.notif-bar {
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--n);
  color: var(--s2);
  padding: 9px 18px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  z-index: 500;
  display: none;
  white-space: nowrap;
  max-width: 88%;
  text-align: center;
  border: 1px solid var(--n4);
  box-shadow: var(--sh3);
}

/* ── PIN ───────────────────────────────────────────────────────── */
.pin-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 10px 0;
}

.pin-key {
  padding: 14px;
  border: 1.5px solid var(--s1);
  border-radius: var(--r2);
  background: var(--wh);
  font-size: 18px;
  font-weight: 800;
  cursor: pointer;
  text-align: center;
  font-family: 'DM Mono', monospace;
  transition: all .12s;
  color: var(--n);
}
.pin-key:hover { background: var(--s); border-color: var(--s2); transform: scale(1.04); }
.pin-key:active { transform: scale(.97); }

/* ── Plan / Carte SVG ──────────────────────────────────────────── */
.plan-wrap {
  background: var(--wh);
  border-radius: var(--r2);
  margin-bottom: 14px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,.08);
}
.plan-img-wrap {
  width: 100%;
  overflow: hidden;
  border-radius: var(--r2) var(--r2) 0 0;
  line-height: 0;
}
.plan-title {
  font-size: 9px;
  font-weight: 800;
  color: var(--s3);
  text-transform: uppercase;
  letter-spacing: .12em;
  padding: 8px 14px 4px;
}
.plan-leg {
  display: flex;
  gap: 5px;
  padding: 6px 14px 8px;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  border-top: 1px solid var(--s1);
  margin-top: 2px;
  background: var(--wh);
  scrollbar-width: thin;
}
.leg-i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-height: 21px;
  padding: 3px 7px;
  border-radius: 6px;
  border: 1px solid transparent;
  font: 700 9px/1 inherit;
  color: var(--n);
  white-space: nowrap;
  box-sizing: border-box;
  flex: 0 0 auto;
}
.plan-filter-btn {
  border-color: var(--s1);
  background: var(--wh);
  box-shadow: none;
  cursor: pointer;
  transition: border-color .12s ease, background .12s ease, color .12s ease;
}
.plan-filter-btn:hover {
  border-color: var(--s3);
  background: var(--bg);
}
.plan-filter-btn.on {
  border-color: var(--s3);
  background: #f8f2e7;
  color: var(--s4);
  box-shadow: inset 0 0 0 1px var(--s2);
}
.leg-d { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; box-shadow: inset 0 0 0 1px rgba(0,0,0,.08); }
.plan-service-dot {
  transition: opacity .15s ease, transform .15s ease;
  transform-origin: center;
}
.plan-service-dot:hover {
  opacity: .86;
  transform: scale(1.08);
}

[data-theme="dark"] .plan-wrap { background: #17191B; }

@media (max-width: 767px) {
  .plan-leg {
    gap: 4px;
    padding: 6px 10px 8px;
  }
  .leg-i {
    min-height: 22px;
    padding: 3px 6px;
    font-size: 8.5px;
  }
}

/* ── Week grid ─────────────────────────────────────────────────── */
.wgrid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0,1fr));
  gap: 4px;
}
@media (max-width: 767px) {
  .wgrid {
    grid-template-columns: repeat(7, minmax(68px, 1fr));
    min-width: 476px;
  }
}
.day-col {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r1);
  min-height: 95px;
  padding: 5px 4px;
  box-shadow: var(--sh1);
}
.day-col.today { border-color: var(--blu); background: #eaf3fb; }
.slot-t {
  border-radius: 4px;
  padding: 3px 5px;
  margin-bottom: 2px;
  cursor: pointer;
  font-size: 9px;
  border: 1px solid transparent;
  transition: opacity .12s;
}
.slot-t:hover { opacity: .8; }

/* ── Calendar ──────────────────────────────────────────────────── */
.cal-g {
  display: grid;
  grid-template-columns: repeat(7, minmax(0,1fr));
  gap: 4px;
}
.day-c {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 5px;
  padding: 4px;
  text-align: center;
  cursor: pointer;
  min-height: 44px;
  transition: background .12s, border-color .12s;
  box-shadow: var(--sh1);
}
.day-c:hover { background: var(--s); border-color: var(--s2); }
.day-c.today { border-color: var(--blu); background: #eaf3fb; }
.day-c.sel   { background: var(--n); color: var(--s); border-color: var(--n); }

/* ── Cadencier ─────────────────────────────────────────────────── */
.cadtbl { width: 100%; border-collapse: collapse; font-size: 11px; }
.cadtbl th {
  padding: 6px 7px;
  background: var(--n);
  color: rgba(255,255,255,.75);
  font-size: 9px;
  font-weight: 700;
  border: 1px solid var(--n3);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.cadtbl td {
  padding: 5px 6px;
  border: 1px solid var(--s1);
  vertical-align: top;
  cursor: pointer;
  transition: background .1s;
}
.cadtbl td:hover { background: #f0fdf4; }

/* ── Stocks ────────────────────────────────────────────────────── */
.sc {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r2);
  margin-bottom: 9px;
  overflow: hidden;
  box-shadow: var(--sh1);
}
.sc-head {
  padding: 9px 14px;
  background: var(--n);
  color: var(--s);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11.5px;
  font-weight: 700;
  cursor: pointer;
}
.sc-sub {
  padding: 6px 14px;
  background: var(--s1);
  font-size: 9px;
  font-weight: 800;
  color: var(--s4);
  letter-spacing: .06em;
  text-transform: uppercase;
}
.sc-row {
  display: flex;
  align-items: center;
  padding: 8px 14px;
  border-bottom: 1px solid var(--bg);
  gap: 8px;
  font-size: 12px;
  transition: background .1s;
}
.sc-row:hover { background: var(--bg); }

/* ── Gaz ───────────────────────────────────────────────────────── */
.gaz-row {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r1);
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 5px;
  box-shadow: var(--sh1);
  transition: box-shadow .15s;
}
.gaz-row:hover { box-shadow: var(--sh2); }

/* Gaz - interface operationnelle */
.gz-page {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 1120px;
  margin: 0 auto;
}

.gz-ic {
  flex-shrink: 0;
  vertical-align: -3px;
}

.gz-hero {
  background:
    linear-gradient(135deg, rgba(240,112,48,.14), transparent 48%),
    linear-gradient(135deg, var(--wh), var(--bg));
  border: 1px solid color-mix(in srgb, #f07030 30%, var(--s1));
  border-radius: 8px;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  box-shadow: var(--sh1);
}

.gz-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #b45309;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.gz-hero h2 {
  margin: 0;
  font-size: 25px;
  line-height: 1.05;
  font-weight: 800;
  color: var(--n);
}

.gz-hero p {
  margin-top: 5px;
  font-size: 12px;
  color: var(--gry);
}

.gz-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.gz-btn {
  border: none;
  border-radius: 7px;
  min-height: 40px;
  padding: 0 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  transition: transform .12s, border-color .12s, background .12s, color .12s;
}

.gz-btn:hover { transform: translateY(-1px); }
.gz-btn-light { background: var(--bg); color: var(--n); border: 1px solid var(--s1); }
.gz-btn-light:hover { border-color: var(--s2); background: var(--s); }
.gz-btn-dark { background: color-mix(in srgb, var(--s2) 18%, var(--wh)); color: var(--s3); border: 1px solid color-mix(in srgb, var(--s2) 55%, var(--s1)); flex: 1; }
.gz-btn-outline { background: var(--wh); color: var(--n); border: 1px solid var(--s1); flex: 1; }

.gz-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.gz-stat {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-left: 4px solid var(--gry);
  border-radius: 8px;
  padding: 9px 11px;
  box-shadow: var(--sh1);
}

.gz-stat span {
  display: block;
  color: var(--gry);
  font-size: 11px;
  font-weight: 700;
  margin-bottom: 5px;
}

.gz-stat strong {
  display: block;
  font-size: 22px;
  line-height: 1;
  color: var(--n);
}

.gz-stat small {
  display: block;
  color: var(--gry);
  font-size: 10px;
  margin-top: 5px;
}

.gz-stat.gz-ok { border-left-color: var(--grn); }
.gz-stat.gz-warning { border-left-color: #EAB308; }
.gz-stat.gz-danger { border-left-color: var(--red); }
.gz-stat.gz-neutral { border-left-color: var(--gry); }

.gz-toolbar {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 11px;
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto;
  gap: 10px;
  align-items: center;
  box-shadow: var(--sh1);
}

.gz-search {
  height: 42px;
  background: var(--n);
  color: var(--s);
  border-radius: 7px;
  padding: 0 13px;
  display: flex;
  align-items: center;
  gap: 9px;
}

.gz-search input {
  border: none;
  outline: none;
  background: transparent;
  color: inherit;
  font: inherit;
  font-size: 14px;
  width: 100%;
  min-width: 0;
}

.gz-search input::placeholder { color: color-mix(in srgb, var(--s) 62%, transparent); }

.gz-filters {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  justify-content: flex-start;
  padding-bottom: 2px;
}
.gz-filters::-webkit-scrollbar { display: none; }

.gz-track-tabs {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  margin: 10px 0 12px;
  padding-bottom: 2px;
}
.gz-track-tabs::-webkit-scrollbar { display: none; }
.gz-track-tabs .gz-filter { flex: 0 0 auto; }

.gz-filter {
  height: 38px;
  padding: 0 14px;
  border-radius: 7px;
  border: 1px solid var(--s1);
  background: var(--wh);
  color: var(--n);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
}

.gz-filter.on {
  background: color-mix(in srgb, var(--s2) 16%, var(--wh));
  border-color: color-mix(in srgb, var(--s2) 55%, var(--s1));
  color: var(--s3);
}

.gz-view-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.gz-scope {
  height: 36px;
  padding: 0 13px;
  border-radius: 7px;
  border: 1px solid var(--s1);
  background: var(--wh);
  color: var(--n);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
}

.gz-scope.on {
  background: color-mix(in srgb, var(--s2) 18%, transparent);
  border-color: var(--s2);
  color: var(--s3);
}

.gz-alert {
  display: flex;
  align-items: center;
  gap: 12px;
  background: color-mix(in srgb, var(--red) 5%, var(--wh));
  border: 1px solid color-mix(in srgb, var(--red) 22%, var(--s1));
  border-left: 3px solid color-mix(in srgb, var(--red) 72%, var(--s1));
  border-radius: 8px;
  padding: 13px 15px;
}

.gz-alert-ic {
  color: color-mix(in srgb, var(--red) 78%, var(--n));
  width: 34px;
  height: 34px;
  border-radius: 7px;
  background: rgba(224,53,53,.07);
  display: flex;
  align-items: center;
  justify-content: center;
}

.gz-alert strong {
  display: block;
  color: color-mix(in srgb, var(--red) 82%, var(--n));
  font-size: 13px;
}

.gz-alert span {
  display: block;
  color: var(--n);
  font-size: 12px;
  margin-top: 2px;
}

.gz-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.gz-grid-board {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 6px;
}

.gz-tile {
  background: color-mix(in srgb, var(--wh) 88%, transparent);
  border: 1px solid var(--s1);
  border-top: 1px solid color-mix(in srgb, var(--grn) 26%, var(--s1));
  border-radius: 8px;
  padding: 7px;
  display: grid;
  gap: 6px;
  min-width: 0;
  box-shadow: var(--sh1);
}

.gz-tile.has-alert {
  border-color: color-mix(in srgb, var(--red) 28%, var(--s1));
  border-top-color: color-mix(in srgb, var(--red) 58%, var(--s1));
  background: color-mix(in srgb, var(--red) 4%, var(--wh));
}

.gz-tile-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 5px;
  min-width: 0;
}

.gz-tile-num {
  color: var(--n);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
}

.gz-tile-type {
  color: var(--gry);
  font-size: 9px;
  font-weight: 700;
  margin-top: 3px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 88px;
}

.gz-tile-body {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 6px;
  align-items: center;
  min-height: 38px;
}

.gz-tile-body strong {
  display: block;
  color: var(--n);
  font-size: 10px;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.gz-tile-body span {
  display: block;
  color: var(--gry);
  font-size: 8.5px;
  line-height: 1.35;
  margin-top: 2px;
}

.gz-tile-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
}

.gz-tile-actions .gz-row-btn {
  grid-column: auto;
  grid-row: auto;
  min-width: 0;
  width: 100%;
  height: 29px;
  font-size: 9px;
  white-space: nowrap;
}

.gz-card {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-left: 5px solid var(--gry);
  border-radius: 8px;
  padding: 12px 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  box-shadow: var(--sh1);
  transition: transform .12s, box-shadow .12s, border-color .12s;
}

.gz-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--sh2);
}

.gz-card-ok { border-left-color: var(--grn); }
.gz-card-warning { border-left-color: #EAB308; }
.gz-card-danger { border-left-color: var(--red); }

.gz-card-main {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  min-width: 0;
}

.gz-mh strong {
  display: block;
  color: var(--n);
  font-size: 18px;
  line-height: 1.1;
}

.gz-mh span {
  display: block;
  margin-top: 5px;
  color: var(--s3);
  font-size: 11px;
  line-height: 1.3;
}

.gz-bottles {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex-wrap: wrap;
}

.gz-card-meta {
  grid-column: 2;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  min-width: 0;
}

.gz-card-meta span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--gry);
  font-size: 10px;
  font-weight: 700;
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 6px;
  padding: 3px 7px;
}

.gz-card-meta span.warn {
  color: var(--red);
  background: #fff0f0;
  border-color: #f5c6c6;
}

.gz-bottle {
  width: 34px;
  height: 47px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}

.gz-bottle-cap {
  width: 14px;
  height: 5px;
  border-radius: 4px 4px 0 0;
  background: currentColor;
}

.gz-bottle-body {
  width: 34px;
  height: 42px;
  border-radius: 7px;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1;
}

.gz-bottle-body small {
  font-size: 7px;
  color: inherit;
}

.gz-bottle-full { color: var(--grn); }
.gz-bottle-full .gz-bottle-body { background: var(--grn); }
.gz-bottle-half { color: #EAB308; }
.gz-bottle-half .gz-bottle-body { background: linear-gradient(180deg, #EAB308 0 52%, var(--grn) 52% 100%); }
.gz-bottle-empty { color: var(--red); }
.gz-bottle-empty .gz-bottle-body {
  background: transparent;
  color: var(--red);
  border: 1.5px dashed var(--red);
}

.gz-count {
  color: var(--s3);
  font-size: 12px;
  white-space: nowrap;
}

.gz-card-side {
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 4px 12px;
  justify-items: end;
}

.gz-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border-radius: 99px;
  padding: 3px 5px;
  font-size: 8.5px;
  font-weight: 900;
}

.gz-badge-ok { background: color-mix(in srgb, var(--grn) 10%, var(--wh)); color: color-mix(in srgb, var(--grn) 82%, var(--n)); }
.gz-badge-warning { background: #fefce8; color: #a16207; }
.gz-badge-danger { background: color-mix(in srgb, var(--red) 8%, var(--wh)); color: color-mix(in srgb, var(--red) 84%, var(--n)); }
.gz-badge-neutral { background: var(--bg); color: var(--gry); }

.gz-card-side small {
  grid-column: 1;
  color: var(--s3);
  font-size: 10px;
}

.gz-row-btn {
  grid-column: 2;
  grid-row: 1 / span 2;
  min-width: 68px;
  height: 50px;
  border-radius: 8px;
  border: 1px solid var(--s1);
  background: var(--wh);
  color: var(--n);
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

.gz-row-btn.primary {
  background: color-mix(in srgb, var(--s2) 16%, var(--wh));
  border-color: color-mix(in srgb, var(--s2) 55%, var(--s1));
  color: var(--s3);
}

.gz-empty {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 34px;
  text-align: center;
  color: var(--gry);
}

.gz-modal {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.gz-modal-top {
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.gz-modal-bottles {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.gz-fiche-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 8px;
}

.gz-fiche-card {
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 10px 12px;
  min-width: 0;
}

.gz-fiche-card span {
  display: block;
  color: var(--gry);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 4px;
}

.gz-fiche-card strong {
  display: block;
  color: var(--n);
  font-size: 13px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.gz-detail {
  border: 1px solid var(--s1);
  border-radius: 8px;
  overflow: hidden;
}

.gz-detail-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  margin: 0 14px;
  border-bottom: 1px solid var(--s1);
}

.gz-detail-row:last-child { border-bottom: none; }
.gz-detail-row span { color: var(--s3); font-size: 13px; font-weight: 700; }
.gz-detail-row strong { color: var(--n); font-size: 14px; text-align: right; }

.gz-note {
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 11px 13px;
}

.gz-note span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--s3);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.gz-note p {
  margin-top: 6px;
  color: var(--n);
  font-size: 12px;
  line-height: 1.45;
}

.gz-action-box {
  background: #edf7f1;
  border: 1px solid #bfe7d2;
  border-left: 4px solid var(--grn);
  border-radius: 8px;
  padding: 12px 13px;
}

.gz-action-box span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--grn);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.gz-action-box strong {
  display: block;
  margin-top: 5px;
  color: var(--n);
  font-size: 14px;
}

.gz-action-box small {
  display: block;
  margin-top: 3px;
  color: var(--gry);
  font-size: 12px;
}

.gz-timeline {
  border: 1px solid var(--s1);
  border-radius: 8px;
  overflow: hidden;
}

.gz-timeline-title {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 10px 13px;
  background: var(--bg);
  color: var(--s3);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-bottom: 1px solid var(--s1);
}

.gz-timeline-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 13px;
  border-bottom: 1px solid var(--s1);
}

.gz-timeline-row:last-child { border-bottom: none; }
.gz-timeline-row strong { color: var(--n); font-size: 12px; }
.gz-timeline-row span { color: var(--gry); font-size: 12px; font-weight: 700; }
.gz-timeline-empty { padding: 12px 13px; color: var(--gry); font-size: 12px; }

.gz-modal-actions {
  display: flex;
  gap: 8px;
}

.gz-history {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 14px;
  box-shadow: var(--sh1);
}

.gz-history-title {
  color: var(--s3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 8px;
}

.gz-history-row {
  display: grid;
  grid-template-columns: 130px 40px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--s1);
}

.gz-history-row span { color: var(--n); font-size: 12px; }
.gz-history-row strong { color: var(--blu); font-size: 14px; text-align: center; }
.gz-history-row div { display: flex; gap: 3px; flex-wrap: wrap; }
.gz-history-row i { width: 8px; height: 8px; border-radius: 50%; background: var(--grn); }

.gz-history-total {
  margin-top: 12px;
  padding: 11px 14px;
  border-radius: 8px;
  background: var(--n);
  color: var(--s);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

[data-theme="dark"] .gz-alert { background: rgba(224,53,53,.12); }
[data-theme="dark"] .gz-badge-ok { background: rgba(29,158,117,.18); }
[data-theme="dark"] .gz-badge-warning { background: rgba(240,112,48,.18); }
[data-theme="dark"] .gz-badge-danger { background: rgba(224,53,53,.18); }
[data-theme="dark"] .gz-card-meta span.warn { background: rgba(224,53,53,.14); border-color: rgba(224,53,53,.28); }
[data-theme="dark"] .gz-action-box { background: rgba(29,158,117,.12); border-color: rgba(29,158,117,.28); }

@media (max-width: 767px) {
  .gz-hero {
    padding: 15px;
    align-items: stretch;
    flex-direction: column;
  }

  .gz-actions { justify-content: stretch; }
  .gz-actions .gz-btn { flex: 1; }
  .gz-summary { grid-template-columns: repeat(2, 1fr); gap: 8px; }

  .gz-toolbar {
    grid-template-columns: 1fr;
  }


  .gz-filter { flex: 0 0 auto; }
  .gz-track-tabs { gap: 5px; margin: 8px 0 10px; }
  .gz-track-tabs .gz-filter {
    height: 34px;
    padding: 0 9px;
    font-size: 11px;
    gap: 4px;
  }

  .gz-card {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .gz-card-main {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .gz-card-meta { grid-column: 1; }

  .gz-card-side {
    grid-template-columns: 1fr auto;
    justify-items: start;
  }

  .gz-card-side small { grid-column: 1; }
  .gz-row-btn { grid-column: 2; min-width: 88px; height: 44px; }
  .gz-modal-actions { flex-direction: column; }
  .gz-fiche-grid { grid-template-columns: 1fr; }
  .gz-detail-row { align-items: flex-start; flex-direction: column; gap: 4px; }
  .gz-detail-row strong { text-align: left; }
}

/* ── Historique ────────────────────────────────────────────────── */
.hbar {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 5px 0;
  border-bottom: 1px solid var(--s1);
  font-size: 11px;
}
.hdot { width: 8px; height: 8px; border-radius: 50%; background: var(--tel); flex-shrink: 0; }

/* ── Piscine KPI ───────────────────────────────────────────────── */
.pis-kpi {
  background: linear-gradient(135deg, var(--n2), var(--n));
  border-radius: var(--r2);
  padding: 10px 12px;
  border: 1px solid var(--n4);
}
.pis-lbl { font-size: 9px; color: rgba(255,255,255,.4); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 3px; }
.pis-val { font-size: 18px; font-weight: 800; font-family: 'DM Mono', monospace; }

/* ── Goodies ───────────────────────────────────────────────────── */
.good-card {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r1);
  padding: 8px 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
  transition: all .15s;
  box-shadow: var(--sh1);
}
.good-card:hover { background: var(--s); border-color: var(--s2); transform: translateX(2px); }
.good-card.sold { background: #edf7f1; border-color: #a8dfc0; }

.good-page, .rpt-page { display: flex; flex-direction: column; gap: 12px; }
.good-hero, .rpt-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--s2) 18%, var(--wh)), color-mix(in srgb, var(--blu) 10%, var(--wh)));
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 18px;
  box-shadow: var(--sh1);
}
.good-eyebrow, .rpt-eyebrow { font-size: 10px; font-weight: 900; color: var(--s3); text-transform: uppercase; letter-spacing: .08em; }
.good-hero h2, .rpt-hero h2 { font-size: 30px; line-height: 1; color: var(--n); margin: 4px 0; }
.good-hero p, .rpt-hero p { font-size: 12px; color: var(--gry); line-height: 1.4; }
.good-hero-actions { display: flex; gap: 7px; flex-wrap: wrap; justify-content: flex-end; }
.good-kpis, .rpt-kpis { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; }
.good-kpi, .rpt-kpi { background: var(--wh); border: 1px solid var(--s1); border-left: 4px solid var(--s2); border-radius: 8px; padding: 12px; box-shadow: var(--sh1); color: var(--n); }
.good-kpi.green, .rpt-kpi.green { border-left-color: var(--grn); }
.good-kpi.blue, .rpt-kpi.blue { border-left-color: var(--blu); }
.good-kpi.orange, .rpt-kpi.orange { border-left-color: var(--ora); }
.good-kpi.gold, .rpt-kpi.gold { border-left-color: var(--s2); }
.rpt-kpi.purple { border-left-color: var(--pur); }
.good-kpi-label, .rpt-kpi span { display:block; font-size: 9px; font-weight: 900; color: var(--gry); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 5px; }
.good-kpi-value, .rpt-kpi strong { display:block; font-size: 21px; font-weight: 900; color: var(--n); white-space: nowrap; }
.good-kpi-sub, .rpt-kpi em { display:block; margin-top: 3px; font-size: 11px; color: var(--gry); font-style: normal; }
.good-layout { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(330px, .75fr); gap: 12px; align-items: start; }
.good-layout.bottom, .rpt-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.good-panel, .rpt-panel { background: var(--wh); border: 1px solid var(--s1); border-radius: 8px; padding: 14px; box-shadow: var(--sh1); }
.good-panel-head, .rpt-panel-head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom: 12px; }
.good-panel-head strong, .rpt-panel-head strong { display:block; font-size: 13px; font-weight: 900; color: var(--n); }
.good-panel-head span, .rpt-panel-head span { display:block; font-size: 11px; color: var(--gry); margin-top: 2px; }
.good-mode, .good-filters { display:flex; gap:6px; flex-wrap:wrap; }
.good-mode button, .good-filter { border: 1px solid var(--s1); background: var(--bg); color: var(--gry); border-radius: 6px; padding: 6px 10px; font: inherit; font-size: 11px; font-weight: 800; cursor: pointer; }
.good-mode button.on, .good-filter.on { background: var(--n); border-color: var(--n); color: var(--s2); }
.good-calendar { display:grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 5px; }
.good-weekday { text-align:center; font-size:9px; font-weight:900; color:var(--gry); padding:2px 0 4px; }
.good-day { min-height: 62px; position: relative; border: 1px solid var(--s1); border-radius: 7px; background: var(--wh); color: var(--n); font: inherit; cursor: pointer; overflow: hidden; padding: 6px; text-align: left; }
.good-day.today { border-color: var(--blu); }
.good-day.selected { border-color: var(--grn); box-shadow: 0 0 0 2px color-mix(in srgb, var(--grn) 18%, transparent); }
.good-day span, .good-day strong, .good-day em, .good-day small { position: relative; z-index: 1; display:block; }
.good-day span { font-size: 10px; font-weight: 900; color: var(--gry); }
.good-day strong { font-size: 13px; font-weight: 900; color: var(--grn); margin-top: 5px; }
.good-day em { font-style: normal; font-size: 9px; color: var(--gry); }
.good-day small { text-align:center; color: var(--s1); margin-top: 12px; }
.good-day i { position:absolute; left:0; right:0; bottom:0; background: color-mix(in srgb, var(--grn) 16%, transparent); z-index:0; }
.good-products { display:flex; flex-direction:column; gap:6px; max-height: 560px; overflow:auto; padding-right: 3px; }
.good-product { display:grid; grid-template-columns: 1fr 88px; gap:8px; align-items:center; border:1px solid var(--s1); border-radius:7px; background:var(--bg); padding:7px; }
.good-product.sold { border-color: color-mix(in srgb, var(--grn) 45%, var(--s1)); background: color-mix(in srgb, var(--grn) 8%, var(--wh)); }
.good-product > button { display:flex; align-items:center; justify-content:space-between; gap:8px; border:0; background:transparent; color:var(--n); font:inherit; cursor:pointer; text-align:left; min-width:0; }
.good-product strong { font-size:12px; font-weight:800; display:block; }
.good-product em { font-size:10px; color:var(--gry); font-style:normal; display:block; }
.good-product b { font-size:12px; color:var(--grn); white-space:nowrap; }
.good-stepper { display:grid; grid-template-columns: 26px 1fr 26px; align-items:center; gap:3px; }
.good-stepper button { height:26px; border:1px solid var(--s1); background:var(--wh); border-radius:5px; color:var(--n); font-weight:900; cursor:pointer; }
.good-stepper button:disabled { opacity:.35; cursor:default; }
.good-stepper span { text-align:center; font-size:13px; font-weight:900; }
.good-rank, .rpt-line { display:grid; grid-template-columns: 28px 1fr auto; align-items:center; gap:9px; padding:9px 0; border-bottom:1px solid var(--bg); }
.good-rank span, .rpt-line i { width:24px; height:24px; border-radius:50%; background: color-mix(in srgb, var(--s2) 18%, transparent); color:var(--s3); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:900; font-style:normal; }
.good-rank strong, .rpt-line strong { display:block; font-size:12px; color:var(--n); }
.good-rank em, .rpt-line span { display:block; font-size:10px; color:var(--gry); font-style:normal; }
.good-rank b, .rpt-line b { font-size:12px; color:var(--grn); white-space:nowrap; }
.good-cat-row { display:grid; grid-template-columns: 1fr auto; gap:8px; align-items:center; padding:9px 0; border-bottom:1px solid var(--bg); }
.good-cat-row strong { display:block; font-size:12px; color:var(--n); }
.good-cat-row span { display:block; font-size:10px; color:var(--gry); }
.good-cat-row em { font-style:normal; font-size:12px; color:var(--s3); font-weight:900; }
.good-cat-row i { grid-column:1 / -1; height:8px; background:var(--bg); border-radius:99px; overflow:hidden; }
.good-cat-row b { display:block; height:100%; background:linear-gradient(90deg,var(--s2),var(--grn)); border-radius:99px; }
.good-empty, .rpt-empty { padding:22px 10px; text-align:center; color:var(--gry); font-size:12px; border:1px dashed var(--s1); border-radius:7px; }
.rpt-score { min-width:112px; height:112px; border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; background:var(--wh); border:5px solid var(--s2); box-shadow:var(--sh1); font-family:inherit; cursor:pointer; }
.rpt-score.ok { border-color:var(--grn); }
.rpt-score.warn { border-color:var(--ora); }
.rpt-score.danger { border-color:var(--red); }
.rpt-score span { font-size:9px; font-weight:900; color:var(--gry); text-transform:uppercase; letter-spacing:.05em; }
.rpt-score strong { font-size:34px; font-weight:900; color:var(--n); line-height:1; }
.rpt-score-detail { background:var(--wh); border:1px solid var(--s1); border-radius:8px; padding:14px; box-shadow:var(--sh1); }
.rpt-score-row { width:100%; display:grid; grid-template-columns: minmax(130px,1fr) 46px minmax(90px,1fr) 72px; align-items:center; gap:10px; padding:10px 0; border:0; border-bottom:1px solid var(--bg); background:transparent; color:var(--n); font-family:inherit; text-align:left; cursor:pointer; }
.rpt-score-row:last-child { border-bottom:0; }
.rpt-score-row strong { display:block; font-size:12px; font-weight:900; color:var(--n); }
.rpt-score-row span { display:block; font-size:10px; color:var(--gry); margin-top:2px; }
.rpt-score-row em { font-style:normal; font-size:13px; font-weight:900; color:var(--n); text-align:right; }
.rpt-score-row i { height:8px; border-radius:999px; background:var(--bg); overflow:hidden; display:block; }
.rpt-score-row i b { display:block; height:100%; border-radius:999px; background:var(--s2); }
.rpt-score-row small { font-size:10px; font-weight:900; color:var(--gry); text-align:right; }
.rpt-kpi[onclick] { cursor:pointer; transition: transform .12s, box-shadow .12s; }
.rpt-kpi[onclick]:hover { transform:translateY(-1px); box-shadow:var(--sh2); }
.rpt-grid { display:grid; gap:12px; }
.rpt-action { width:100%; display:block; text-align:left; border:1px solid var(--s1); background:var(--bg); border-radius:7px; padding:10px 12px; margin-bottom:7px; color:var(--n); font:inherit; cursor:pointer; }
.rpt-action strong { display:block; font-size:13px; font-weight:900; }
.rpt-action span { display:block; font-size:11px; color:var(--gry); margin-top:2px; }
.rpt-action.ok { border-color: color-mix(in srgb, var(--grn) 35%, var(--s1)); }
.rpt-action.warn { border-color: color-mix(in srgb, var(--ora) 45%, var(--s1)); }
.rpt-action.danger { border-color: color-mix(in srgb, var(--red) 45%, var(--s1)); }
.rpt-action.info { border-color: color-mix(in srgb, var(--blu) 35%, var(--s1)); }
.rpt-bars { display:grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap:8px; min-height:160px; align-items:end; padding-top:8px; }
.rpt-bar { display:flex; flex-direction:column; align-items:center; gap:5px; min-width:0; }
.rpt-bar span { font-size:9px; color:var(--gry); font-weight:800; }
.rpt-bar i { width:100%; max-width:28px; height:105px; background:var(--bg); border-radius:99px; display:flex; align-items:flex-end; overflow:hidden; }
.rpt-bar b { display:block; width:100%; border-radius:99px 99px 0 0; }
.rpt-bar em { font-style:normal; font-size:10px; color:var(--n); font-weight:900; }
.rpt-line i[style] { border-radius:6px; }
.rpt-ops { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:8px; }
.rpt-ops div { background:var(--bg); border:1px solid var(--s1); border-radius:7px; padding:10px; }
.rpt-ops span { display:block; font-size:10px; color:var(--gry); font-weight:800; text-transform:uppercase; }
.rpt-ops strong { display:block; font-size:22px; color:var(--n); font-weight:900; margin-top:4px; }

@media (max-width: 900px) {
  .good-kpis, .rpt-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .good-layout, .good-layout.bottom, .rpt-grid { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .good-hero, .rpt-hero { flex-direction:column; align-items:stretch; }
  .good-hero-actions { justify-content:stretch; }
  .good-hero-actions .btn-s { flex:1; }
  .good-kpi-value, .rpt-kpi strong { font-size:18px; }
  .good-calendar { gap:4px; }
  .good-day { min-height:54px; padding:5px; }
  .good-product { grid-template-columns:1fr; }
  .rpt-score { align-self:flex-start; width:104px; height:104px; min-width:104px; }
  .rpt-score-row { grid-template-columns: 1fr 42px; }
  .rpt-score-row i, .rpt-score-row small { grid-column:1 / -1; text-align:left; }
}

/* ── Sécurité ──────────────────────────────────────────────────── */
.chk-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: var(--r1);
  margin-bottom: 4px;
  box-shadow: var(--sh1);
  transition: background .12s;
}
.chk-row:hover { background: var(--bg); }
.chk-lbl { flex: 1; font-size: 12px; line-height: 1.4; }
.chk-btn {
  padding: 4px 11px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  font-family: inherit;
  transition: all .15s;
}

/* ── Photos ────────────────────────────────────────────────────── */
.photo-slot {
  width: 76px;
  height: 76px;
  border: 2px dashed var(--s2);
  border-radius: var(--r1);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
  background: var(--s);
  transition: border-color .15s, background .15s;
}
.photo-slot:hover { border-color: var(--grn); background: #edf7f1; }
.photo-slot img { width: 100%; height: 100%; object-fit: cover; }

/* ── Ménage cal ────────────────────────────────────────────────── */
.men-cal-c {
  border: 1px solid var(--s1);
  border-radius: 5px;
  padding: 3px 4px;
  text-align: center;
  cursor: pointer;
  min-height: 38px;
  font-size: 9px;
  transition: background .12s;
}
.men-cal-c:hover { background: var(--s); }

/* ── EDL slot ──────────────────────────────────────────────────── */
.edl-slot-edit {
  background: var(--wh);
  border: 2px solid var(--blu);
  border-radius: var(--r2);
  padding: 11px;
  margin-bottom: 7px;
  box-shadow: var(--sh1);
}

/* ── Suppl MH highlight ────────────────────────────────────────── */
.plan-hl-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 9px;
  padding: 8px 12px;
  background: #eaf3fb;
  border: 1px solid var(--blu);
  border-radius: var(--r1);
}

/* ── Scrollbar custom ──────────────────────────────────────────── */
.main::-webkit-scrollbar { width: 5px; }
.main::-webkit-scrollbar-track { background: transparent; }
.main::-webkit-scrollbar-thumb { background: var(--s1); border-radius: 99px; }
.main::-webkit-scrollbar-thumb:hover { background: var(--s2); }

/* ── Mobile : barre basse ──────────────────────────────────────── */
@media (max-width: 767px) {
  .mob-hdr { display: flex; }
  .sb-info  { display: none; }

  .gnav {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: 62px;
    padding-bottom: env(safe-area-inset-bottom);
    border-top: 1.5px solid var(--n4);
    z-index: 200;
    box-shadow: 0 -4px 20px rgba(0,0,0,.28);
  }
  .gnt { height: 100%; padding: 6px 4px 5px; }
  .gnt.on { border-top: 2.5px solid var(--s2); background: rgba(255,255,255,.07); }

  .snav { height: 46px; }
  .snt  { height: 46px; font-size: 11.5px; }

  .main { padding: 12px 12px 76px; overflow-x: hidden; }
  .ovc  { padding: 14px; }
  .btn-p, .btn-s {
    justify-content: center;
    min-height: 34px;
    padding: 7px 11px;
    font-size: 12px;
    white-space: nowrap;
  }
  .btn-sm {
    justify-content: center;
    min-height: 28px;
    padding: 4px 8px;
    white-space: nowrap;
  }
  .pin-key { padding: 16px; font-size: 20px; }
  .g4 { grid-template-columns: 1fr 1fr; }
  .fi, .fsel, .fta { font-size: 16px; }
  .flash { padding: 6px 12px; font-size: 10.5px; }
}

/* ── Desktop : sidebar CSS Grid ────────────────────────────────── */
@media (min-width: 768px) {
  .mob-hdr { display: none; }

  .app {
    display: grid;
    grid-template-columns: var(--sb-w) 1fr;
    grid-template-rows: auto 1fr;
    flex-direction: unset;
    overflow: hidden;
  }

  .sb-info {
    display: flex;
    grid-column: 1;
    grid-row: 1;
  }

  /* Sidebar nav avec dégradé en bas */
  .gnav {
    grid-column: 1;
    grid-row: 2;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    height: auto;
    position: static;
    padding: 12px 10px 16px;
    gap: 3px;
    border-right: 1px solid var(--shell-border);
    box-shadow: none;
    background: var(--shell);
  }
  .gnav::-webkit-scrollbar { width: 3px; }
  .gnav::-webkit-scrollbar-thumb { background: var(--shell-border); border-radius: 99px; }

  .gnt {
    flex-direction: row;
    flex: unset;
    width: 100%;
    justify-content: flex-start;
    gap: 11px;
    padding: 10px 14px;
    border-radius: 9px;
    height: auto;
    border-left: 3px solid transparent;
  }
  .gnt.on {
    border-top: none;
    border-left-color: var(--s2);
    background: color-mix(in srgb, var(--s2) 15%, transparent);
    color: var(--s2);
  }
  .gnt:hover:not(.on) { background: color-mix(in srgb, var(--shell-text) 6%, transparent); }

  .gnt-ic { width: 20px; height: 20px; flex-shrink: 0; }
  .gnt-ic svg { width: 20px; height: 20px; }
  .gnt-lb { font-size: 13.5px; font-weight: 600; letter-spacing: .01em; }

  /* Séparateur visuel entre groupes de nav */
  .gnt-sep {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--shell-border), transparent);
    margin: 6px 4px;
  }

  .app-body {
    grid-column: 2;
    grid-row: 1 / 3;
  }

  .snav { padding: 0 20px; }
  .snt  { padding: 0 16px; height: 46px; font-size: 12.5px; }
  .main { padding: 20px; }
  .topbar { display: flex; }
}

/* ── Topbar — desktop ──────────────────────────────────────────── */
.topbar {
  display: none;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
  height: 52px;
  background: var(--wh);
  border-bottom: 1px solid var(--s1);
  flex-shrink: 0;
  box-shadow: var(--sh1);
}
.topbar-l { flex-shrink: 0; }
.topbar-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--n);
  letter-spacing: -.01em;
  white-space: nowrap;
}
.topbar-c { flex: 1; min-width: 0; display: flex; justify-content: center; }
.topbar-srch {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 20px;
  padding: 6px 14px;
  width: 100%;
  max-width: 380px;
  transition: border-color .15s, box-shadow .15s;
}
.topbar-srch:focus-within {
  border-color: var(--s2);
  box-shadow: 0 0 0 3px rgba(212,168,83,.12);
}
.topbar-inp {
  background: transparent;
  border: none;
  outline: none;
  font: inherit;
  font-size: 13px;
  color: var(--n);
  flex: 1;
  min-width: 0;
}
.topbar-inp::placeholder { color: var(--gry); }
.topbar-r { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.topbar-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--s1);
  border-radius: var(--r1);
  background: var(--wh);
  color: var(--n);
  cursor: pointer;
  transition: all .15s;
}
.topbar-btn:hover { background: var(--bg); border-color: var(--s2); color: var(--s3); }
.topbar-btn svg { width: 16px; height: 16px; }
.topbar-badge {
  position: absolute;
  top: 2px;
  right: 2px;
  background: var(--red);
  color: #fff;
  font-size: 9px;
  font-weight: 800;
  min-width: 15px;
  height: 15px;
  border-radius: 99px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
}

/* ── FAB — bouton flottant mobile ──────────────────────────────── */
.fab {
  display: none;
  position: fixed;
  bottom: 74px;
  right: 16px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--s2);
  color: var(--n);
  border: none;
  font-size: 26px;
  font-weight: 300;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  z-index: 200;
  box-shadow: 0 4px 14px rgba(212,168,83,.5);
  transition: transform .15s, box-shadow .15s;
  font-family: inherit;
  line-height: 1;
}
.fab:active { transform: scale(.93); box-shadow: 0 2px 8px rgba(212,168,83,.4); }

.fab-cat {
  padding: 5px 12px;
  border-radius: 20px;
  border: 1.5px solid var(--s1);
  background: var(--wh);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  color: var(--n);
  transition: all .12s;
}
.fab-cat.on { background: var(--n); color: var(--s2); border-color: var(--n); }

@media (max-width: 767px) {
  .fab { display: flex; }
}

/* ── Dashboard grilles responsives ─────────────────────────────── */
.dash-4col { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:7px; margin-bottom:10px; }
.dash-3col { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; margin-bottom:12px; }
.dash-2col { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.dash-2col-last { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.dash-terrain-status { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:12px; }

@media (max-width: 767px) {
  .dash-4col { grid-template-columns:repeat(2,minmax(0,1fr)); gap:6px; }
  .dash-3col { grid-template-columns:1fr; }
  .dash-2col { grid-template-columns:1fr; }
  .dash-2col-last { grid-template-columns:1fr; }
  .dash-terrain-status { grid-template-columns:1fr; gap:12px; }
}

/* ── Dashboard extras ──────────────────────────────────────────── */
.dash-prog {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 10px 14px;
  margin-bottom: 10px;
  box-shadow: var(--sh1);
  display: flex;
  align-items: center;
  gap: 12px;
}
.dash-prog-bar  { flex: 1; background: var(--bg); border-radius: 20px; height: 8px; overflow: hidden; }
.dash-prog-fill { height: 100%; background: var(--grn); border-radius: 20px; transition: width .6s ease; }

.quick-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 10px 6px;
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  transition: all .15s;
  color: var(--n);
  text-align: center;
}
.quick-btn:hover { background: var(--s); border-color: var(--s2); }
.quick-btn-ic {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.quick-btn-ic svg { width: 16px; height: 16px; stroke: #fff; stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.wx-chip { padding: 3px 10px; border-radius: 20px; font-size: 10px; font-weight: 700; }
.terrain-weather-card,
.terrain-pool-card {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 12px;
  padding: 14px 16px;
  box-shadow: var(--sh1);
  min-width: 0;
}
.terrain-weather-main {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 14px;
}
.terrain-weather-icon {
  width: 84px;
  text-align: center;
  font-size: 52px;
  line-height: 1;
  flex-shrink: 0;
}
.terrain-weather-temp {
  font-size: 42px;
  font-weight: 900;
  color: var(--n);
  line-height: .95;
}
.terrain-weather-desc {
  margin-top: 4px;
  color: var(--gry);
  font-size: 15px;
}
.terrain-weather-wind {
  margin-top: 5px;
  color: var(--s3);
  font-size: 13px;
  font-weight: 700;
}
.terrain-weather-chips {
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: right;
  flex-shrink: 0;
}
.terrain-card-line {
  height: 1px;
  background: var(--s1);
  margin-bottom: 12px;
}
.terrain-section-title {
  margin-bottom: 10px;
  color: var(--s3);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.terrain-forecast {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 5px;
  text-align: center;
}
.terrain-forecast-day {
  min-width: 0;
  padding: 9px 3px;
  border: 1.5px solid transparent;
  border-radius: 9px;
  background: var(--bg);
}
.terrain-forecast-day.today {
  border-color: #4285f4;
  background: rgba(66,133,244,.09);
}
.terrain-forecast-day div {
  margin-bottom: 4px;
  color: var(--s3);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
}
.terrain-forecast-day.today div { color: #4285f4; }
.terrain-forecast-day span {
  display: block;
  margin-bottom: 5px;
  font-size: 21px;
  line-height: 1;
}
.terrain-forecast-day strong {
  display: block;
  color: var(--n);
  font-size: 14px;
  line-height: 1.1;
}
.terrain-forecast-day small {
  display: block;
  margin-top: 2px;
  color: var(--gry);
  font-size: 11px;
}
.terrain-pool-status {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 11px;
  padding: 6px 12px;
  border: 1.5px solid;
  border-radius: 9px;
}
.terrain-pool-status span {
  font-size: 14px;
  font-weight: 900;
}
.terrain-pool-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px;
}
.terrain-pool-metric {
  min-height: 52px;
  padding: 9px 10px;
  border: 1px solid var(--s1);
  border-radius: 9px;
  background: var(--bg);
}
.terrain-pool-metric strong {
  display: block;
  margin-bottom: 4px;
  font-size: 16px;
  font-weight: 900;
  line-height: 1;
}
.terrain-pool-metric span {
  color: var(--gry);
  font-size: 8.5px;
  font-weight: 900;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.terrain-pool-last {
  margin-top: 9px;
  color: var(--gry);
  font-size: 11px;
}
@media (max-width: 767px) {
  .terrain-weather-card,
  .terrain-pool-card { padding: 14px; }
  .terrain-weather-main { align-items: flex-start; gap: 10px; }
  .terrain-weather-icon { width: 56px; font-size: 38px; }
  .terrain-weather-temp { font-size: 34px; }
  .terrain-weather-chips { width: 100%; text-align: left; }
  .terrain-forecast { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .terrain-pool-grid { grid-template-columns: 1fr; }
}
.act-row { display: flex; align-items: flex-start; gap: 9px; padding: 8px 0; border-bottom: 1px solid var(--bg); }

/* Sessions */
.session-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}
.session-title { font-size: 18px; font-weight: 900; color: var(--n); }
.session-subtitle { font-size: 12px; color: var(--gry); margin-top: 2px; line-height: 1.4; }
.session-select { width: auto; min-width: 190px; }
.session-hero {
  background: linear-gradient(135deg, color-mix(in srgb, var(--blu) 14%, var(--wh)), color-mix(in srgb, var(--s2) 16%, var(--wh)));
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
  box-shadow: var(--sh1);
}
.session-eyebrow { font-size: 10px; font-weight: 800; color: var(--s3); text-transform: uppercase; letter-spacing: .08em; }
.session-hero h2 { font-size: 34px; line-height: 1; margin: 4px 0; color: var(--n); }
.session-hero p { font-size: 12px; color: var(--gry); }
.session-hero-actions { display: flex; gap: 7px; flex-wrap: wrap; justify-content: flex-end; }
.session-status {
  display: inline-flex;
  align-items: center;
  margin-top: 8px;
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid var(--s1);
  background: var(--wh);
  color: var(--n);
  font-size: 11px;
  font-weight: 900;
}
.session-status.ok { color: var(--grn); border-color: color-mix(in srgb, var(--grn) 40%, var(--s1)); }
.session-status.gold { color: var(--s3); border-color: color-mix(in srgb, var(--s2) 45%, var(--s1)); }
.session-status.blue { color: var(--blu); border-color: color-mix(in srgb, var(--blu) 40%, var(--s1)); }
.session-current {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 13px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  box-shadow: var(--sh1);
}
.session-current strong { display: block; font-size: 14px; color: var(--n); margin-bottom: 2px; }
.session-current span { display: block; font-size: 11px; color: var(--gry); }
.session-current-actions { display: flex; gap: 7px; flex-wrap: wrap; justify-content: flex-end; }
.session-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.session-kpi {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-left: 4px solid var(--s2);
  border-radius: 8px;
  padding: 11px 12px;
  box-shadow: var(--sh1);
}
.session-kpi.ok { border-left-color: var(--grn); }
.session-kpi.warn { border-left-color: var(--ora); }
.session-kpi.blue { border-left-color: var(--blu); }
.session-kpi.gold { border-left-color: var(--s2); }
.session-kpi.purple { border-left-color: var(--pur); }
.session-kpi-label { font-size: 9px; font-weight: 800; color: var(--gry); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 4px; }
.session-kpi-value { font-size: 22px; font-weight: 900; color: var(--n); white-space: nowrap; }
.session-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}
.session-panel, .session-history {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 14px;
  box-shadow: var(--sh1);
}
.session-panel-title { font-size: 10px; font-weight: 800; color: var(--s3); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }
.session-alert {
  padding: 9px 10px;
  border-radius: 7px;
  background: var(--bg);
  border: 1px solid var(--s1);
  font-size: 12px;
  font-weight: 700;
  color: var(--n);
  margin-bottom: 6px;
}
.session-rank {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 9px 0;
  border-bottom: 1px solid var(--bg);
}
.session-rank span {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--s2) 18%, transparent);
  color: var(--s3);
  font-size: 11px;
  font-weight: 900;
}
.session-rank em { font-style: normal; font-size: 11px; color: var(--gry); font-weight: 700; }
.session-archive {
  width: 100%;
  display: grid;
  grid-template-columns: 80px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--s1);
  border-radius: 7px;
  background: var(--bg);
  color: var(--n);
  font-family: inherit;
  cursor: pointer;
  margin-bottom: 6px;
  text-align: left;
}
.session-archive.on { border-color: var(--s2); background: color-mix(in srgb, var(--s2) 12%, var(--wh)); }
.session-archive strong { font-size: 14px; }
.session-archive span, .session-archive em { font-size: 11px; color: var(--gry); font-style: normal; }
.session-empty { padding: 18px 0; text-align: center; font-size: 12px; color: var(--gry); }

@media (max-width: 767px) {
  .session-toolbar, .session-hero { flex-direction: column; align-items: stretch; }
  .session-current { flex-direction: column; align-items: stretch; }
  .session-current-actions { justify-content: stretch; }
  .session-current-actions .btn-p, .session-current-actions .btn-s { flex: 1; }
  .session-hero-actions { justify-content: stretch; }
  .session-hero-actions .btn-p, .session-hero-actions .btn-s { flex: 1; }
  .session-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .session-cols { grid-template-columns: 1fr; }
  .session-archive { grid-template-columns: 1fr; gap: 3px; }
}

/* ── Carte statut inprogress ────────────────────────────────── */
.c-inp { border-left: 3px solid var(--blu); background: #f8fcff; }

/* ── Overlay détail intervention (plein écran) ──────────────── */
#ovl-tk-det {
  background: var(--bg);
  padding: 0;
  align-items: stretch;
  flex-direction: column;
  overflow: hidden;
}
.tk-det-inner {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.tk-det-head {
  display: flex;
  align-items: center;
  padding: 12px 10px;
  background: var(--wh);
  border-bottom: 1px solid var(--s1);
  flex-shrink: 0;
}
.tk-det-back {
  background: none;
  border: none;
  padding: 6px 8px;
  cursor: pointer;
  color: var(--n);
  display: flex;
  align-items: center;
  border-radius: 6px;
}
.tk-det-back:hover { background: var(--bg); }
.tk-det-title {
  flex: 1;
  font-size: 15px;
  font-weight: 700;
  color: var(--n);
  text-align: center;
}
.tk-steps {
  display: flex;
  padding: 16px 10px 12px;
  background: var(--wh);
  border-bottom: 1px solid var(--s1);
  flex-shrink: 0;
}
.tk-step {
  flex: 1;
  text-align: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--gry);
  position: relative;
  padding-top: 24px;
}
.tk-step::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--s1);
  border: 2px solid var(--s2);
  transition: background .3s, border-color .3s;
}
.tk-step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 7px;
  left: calc(50% + 9px);
  right: calc(-50% + 9px);
  height: 2px;
  background: var(--s1);
  transition: background .3s;
}
.tk-step.done::before  { background: var(--grn); border-color: var(--grn); }
.tk-step.done::after   { background: var(--grn); }
.tk-step.active::before {
  background: var(--blu);
  border-color: var(--blu);
  box-shadow: 0 0 0 3px rgba(33,118,174,.18);
}
.tk-step.active { color: var(--blu); font-weight: 700; }
.tk-det-body {
  flex: 1;
  padding: 12px 14px 16px;
  overflow-y: auto;
}
.tk-det-foot {
  flex-shrink: 0;
  background: var(--wh);
  border-top: 1px solid var(--s1);
  padding: 12px 16px;
  padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
}
.tk-info-card {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 10px;
  box-shadow: var(--sh1);
}
.tk-det-section {
  font-size: 10px;
  font-weight: 700;
  color: var(--gry);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 14px 0 6px;
}

/* Restaurant */
.rest-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
  margin-bottom: 12px;
  border: 1px solid color-mix(in srgb, var(--s2) 55%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(201,164,93,.18), transparent 46%),
    linear-gradient(135deg, var(--wh), var(--bg));
  box-shadow: var(--sh1);
}
.rest-hero.couverts {
  background:
    linear-gradient(135deg, rgba(33,118,174,.14), transparent 48%),
    linear-gradient(135deg, var(--wh), var(--bg));
}
.rest-kicker {
  font-size: 10px;
  font-weight: 900;
  color: var(--s3);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}
.rest-hero h2 {
  margin: 0;
  color: var(--n);
  font-size: 24px;
  line-height: 1.05;
}
.rest-hero p {
  margin: 6px 0 0;
  color: var(--gry);
  font-size: 12px;
}
.rest-hero-actions,
.rest-month-nav {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-shrink: 0;
}
.rest-month-nav .fsel {
  min-width: 150px;
  font-weight: 800;
}
.rest-on {
  background: var(--s3) !important;
  color: #fff !important;
  border-color: var(--s3) !important;
}
.rest-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.rest-kpi {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-left: 4px solid var(--tone);
  border-radius: 8px;
  padding: 10px 12px;
  box-shadow: var(--sh1);
  min-width: 0;
}
.rest-kpi span {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.rest-kpi strong {
  display: block;
  color: var(--tone);
  font-size: 22px;
  line-height: 1.1;
  margin-top: 4px;
}
.rest-kpi small {
  display: block;
  color: var(--gry);
  font-size: 10px;
  margin-top: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rest-alert {
  margin-bottom: 12px;
  padding: 9px 12px;
  border: 1px solid #f0c36a;
  background: #fff8e8;
  color: #8a5b00;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 800;
}
.rest-week {
  display: grid;
  grid-template-columns: repeat(7, minmax(150px, 1fr));
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 6px;
}
.rest-day {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 8px;
  box-shadow: var(--sh1);
}
.rest-day.today {
  border-color: var(--s3);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--s3) 16%, transparent);
}
.rest-day header {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 7px;
  color: var(--n);
}
.rest-day header span {
  font-size: 11px;
  font-weight: 900;
  text-transform: capitalize;
}
.rest-day header strong {
  font-size: 10px;
  color: var(--gry);
}
.rest-meal-card {
  width: 100%;
  min-height: 104px;
  border: 1px dashed var(--s2);
  border-radius: 8px;
  background: var(--bg);
  text-align: left;
  padding: 9px;
  margin-top: 7px;
  cursor: pointer;
  font-family: inherit;
  color: var(--n);
}
.rest-meal-card.filled {
  border-style: solid;
  background: var(--wh);
}
.rest-meal-card.today {
  border-color: var(--s3);
}
.rest-meal-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 7px;
}
.rest-meal-name {
  font-size: 9px;
  color: var(--gry);
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .06em;
}
.rest-meal-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #f4a261;
}
.rest-meal-dot.night {
  background: #2176ae;
}
.rest-meal-card strong {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: var(--n);
  font-size: 12px;
  line-height: 1.25;
}
.rest-meal-card strong.empty {
  color: var(--s3);
}
.rest-meal-meta {
  display: block;
  color: var(--gry);
  font-size: 10px;
  margin-top: 6px;
}
.rest-meal-card em {
  display: inline-flex;
  max-width: 100%;
  margin-top: 6px;
  padding: 2px 7px;
  border-radius: 999px;
  background: #fff3ce;
  color: #8a5b00;
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rest-place {
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
  overflow: hidden;
  margin-bottom: 14px;
}
.rest-place-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-left: 5px solid var(--place);
  border-bottom: 1px solid var(--s1);
}
.rest-place-head span {
  display: block;
  color: var(--n);
  font-size: 14px;
  font-weight: 900;
}
.rest-place-head small {
  color: var(--gry);
  font-size: 10px;
}
.rest-place-stats {
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 2px 11px;
  text-align: right;
  align-items: end;
}
.rest-place-stats b {
  color: var(--place);
  font-size: 15px;
}
.rest-place-stats small {
  font-size: 8px;
  text-transform: uppercase;
  font-weight: 800;
}
.rest-cal {
  display: grid;
  grid-template-columns: repeat(7, minmax(42px, 1fr));
  gap: 5px;
  padding: 9px;
  background: var(--bg);
}
.rest-cal-dow {
  text-align: center;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
}
.rest-cal-day {
  min-height: 52px;
  border: 1px solid var(--s1);
  border-radius: 7px;
  background: var(--wh);
  cursor: pointer;
  font-family: inherit;
  color: var(--n);
  padding: 4px;
}
.rest-cal-day.today {
  border: 2px solid var(--s3);
}
.rest-cal-day.filled {
  border-color: color-mix(in srgb, var(--place) 45%, var(--s1));
}
.rest-cal-day span {
  display: block;
  color: var(--gry);
  font-size: 8px;
  text-align: left;
}
.rest-cal-day strong {
  display: block;
  color: var(--place);
  font-size: 14px;
  line-height: 1.05;
}
.rest-cal-day em {
  display: block;
  font-style: normal;
  font-size: 11px;
}
.rest-hero-compact {
  padding: 14px 16px;
}
.rest-kpis-compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.rest-week-stable {
  grid-template-columns: repeat(7, minmax(0, 1fr));
  overflow-x: visible;
}
.rest-week-stable .rest-day {
  min-width: 0;
}
.rest-week-stable .rest-day header {
  align-items: baseline;
}
.rest-week-stable .rest-day header span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.rest-week-stable .rest-meal-card {
  min-height: 82px;
  padding: 7px;
}
.rest-week-stable .rest-meal-card strong {
  font-size: 11px;
  -webkit-line-clamp: 2;
}
.rest-meal-count {
  flex-shrink: 0;
  padding: 1px 6px;
  border-radius: 999px;
  background: var(--s1);
  color: var(--gry);
  font-size: 8px;
  font-weight: 900;
}
.rest-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
#ovl-cad .ovc {
  max-width: 620px;
  padding: 18px;
}
.rest-form-block {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.rest-form-card {
  border: 1px solid var(--s1);
  border-radius: 12px;
  background: color-mix(in srgb, var(--wh) 92%, var(--s) 8%);
  padding: 12px;
}
.rest-form-card h3 {
  margin: 0 0 10px;
  color: var(--n);
  font-size: 13px;
  line-height: 1.2;
}
.rest-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}
.rest-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.rest-number-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.rest-number-field {
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--s1);
  border-radius: 10px;
  background: var(--wh);
}
.rest-number-field span {
  display: block;
  margin-bottom: 7px;
  color: var(--s3);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.rest-form .fi,
.rest-form .fsel,
.rest-form .fta {
  width: 100%;
  min-height: 42px;
  font-size: 14px;
}
.rest-form .fta {
  min-height: 82px;
  resize: vertical;
}
.rest-form-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding-top: 4px;
}
.rest-form-actions .btn-p {
  flex: 1;
  justify-content: center;
  min-height: 42px;
  font-size: 13px;
}
.rest-form-actions .btn-s,
.rest-form-actions .rest-danger-btn {
  justify-content: center;
  min-height: 42px;
}
.rest-danger-btn {
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid #e03535;
  background: #fff5f5;
  color: #c62828;
  font-family: inherit;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}
.rest-form-compact {
  gap: 12px;
}
.rest-form-compact .rest-line {
  display: flex;
  flex-direction: column;
  gap: 5px;
  align-items: center;
  min-width: 0;
}
.rest-form-compact .rest-line-top {
  align-items: start;
}
.rest-form-compact .fl {
  margin-bottom: 0;
  color: var(--s3);
  font-size: 10px;
  letter-spacing: .07em;
}
.rest-form-compact .fi,
.rest-form-compact .fsel,
.rest-form-compact .fta {
  min-height: 42px;
  padding: 8px 10px;
  font-size: 14px;
  border-radius: var(--r1);
}
.rest-form-compact .fta {
  min-height: 82px;
  height: 82px;
}
.rest-form-compact .rest-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.rest-form-compact .rest-two .rest-line {
  display: flex;
  flex-direction: column;
}
.rest-form-compact .rest-form-actions {
  gap: 8px;
  padding-top: 4px;
}
.rest-form-compact .rest-form-actions .btn-p,
.rest-form-compact .rest-form-actions .btn-s,
.rest-form-compact .rest-form-actions .rest-danger-btn {
  min-height: 42px;
  padding: 7px 12px;
  font-size: 13px;
}
@media (max-width: 980px) {
  .rest-hero,
  .rest-place-head {
    align-items: stretch;
    flex-direction: column;
  }
  .rest-hero-actions,
  .rest-month-nav {
    width: 100%;
  }
  .rest-hero-actions .btn-sm,
  .rest-month-nav .btn-sm,
  .rest-month-nav .fsel {
    flex: 1;
  }
  .rest-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .rest-place-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    text-align: left;
  }
  .rest-week-stable {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 560px) {
  .rest-hero h2 {
    font-size: 20px;
  }
  .rest-kpis {
    grid-template-columns: 1fr;
  }
  .rest-week {
    grid-template-columns: 1fr;
    overflow-x: visible;
  }
  .rest-week-stable {
    grid-template-columns: 1fr;
  }
  .rest-form-grid {
    grid-template-columns: 1fr;
  }
  .rest-number-grid {
    grid-template-columns: 1fr;
  }
  .rest-form-actions {
    flex-direction: column;
  }
  .rest-form-actions .btn-p,
  .rest-form-actions .btn-s,
  .rest-danger-btn {
    width: 100%;
  }
  .rest-form-compact .rest-line,
  .rest-form-compact .rest-two .rest-line {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .rest-form-compact .rest-two {
    grid-template-columns: 1fr;
  }
  .rest-cal {
    gap: 4px;
  }
  .rest-cal-day {
    min-height: 46px;
  }
}

/* Profils & accès */
.profile-shell {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}
.profile-head {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 16px 18px;
  box-shadow: var(--sh1);
  min-width: 0;
}
.profile-avatar,
.profile-mini {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--s2);
  color: var(--badge-text);
  font-weight: 900;
  flex-shrink: 0;
}
.profile-avatar {
  width: 58px;
  height: 58px;
  font-size: 24px;
}
.profile-mini {
  width: 28px;
  height: 28px;
  font-size: 11px;
}
.profile-head-main {
  flex: 1;
  min-width: 0;
}
.profile-kicker {
  font-size: 10px;
  font-weight: 900;
  color: var(--s3);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 3px;
}
.profile-head h2 {
  margin: 0;
  color: var(--n);
  font-size: 22px;
  line-height: 1.1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.profile-head p {
  margin: 5px 0 0;
  color: var(--gry);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.profile-grid {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  gap: 14px;
  align-items: start;
  min-width: 0;
}
.profile-panel {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 14px;
  box-shadow: var(--sh1);
  min-width: 0;
  overflow: visible;
}
.profile-panel-title {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
  min-width: 0;
}
.profile-panel-title > div {
  min-width: 0;
}
.profile-panel-title span {
  display: block;
  font-size: 14px;
  font-weight: 900;
  color: var(--n);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.profile-panel-title small,
.profile-access-page small {
  display: block;
  color: var(--gry);
  font-size: 10px;
  margin-top: 2px;
}
.profile-create {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(130px, .7fr) minmax(120px, .55fr);
  gap: 6px;
  padding: 9px;
  background: var(--bg);
  border: 1px solid var(--s1);
  border-radius: 8px;
  margin-bottom: 9px;
  min-width: 0;
}
.profile-create .btn-p {
  grid-column: 1 / -1;
  min-height: 34px;
  padding: 7px 10px;
  white-space: nowrap;
  width: 100%;
  justify-content: center;
  font-size: 11.5px;
  font-weight: 900;
  box-shadow: 0 3px 10px rgba(29,158,117,.25);
}
.profile-create .fi,
.profile-create .fsel,
.profile-user-row .fi,
.profile-user-row .fsel {
  min-width: 0;
  width: 100%;
  min-height: 32px;
  padding: 6px 8px;
  font-size: 11.5px;
}
.profile-user-list,
.profile-access-list {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.profile-user-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(130px, .55fr) minmax(120px, .5fr);
  grid-template-areas:
    "identity role pin"
    "actions actions actions";
  gap: 8px;
  align-items: center;
  padding: 8px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  min-width: 0;
}
.profile-user-id {
  grid-area: identity;
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}
.profile-user-row > .fsel {
  grid-area: role;
}
.profile-user-row > .fi {
  grid-area: pin;
}
.profile-user-main {
  min-width: 0;
  flex: 1;
}
.profile-name-input {
  width: 100%;
  max-width: 100%;
  min-height: 32px;
  border: 1.5px solid var(--s2);
  border-radius: 7px;
  outline: 0;
  background: var(--wh);
  color: var(--n);
  font: inherit;
  font-size: 12.5px;
  font-weight: 900;
  line-height: 1.2;
  padding: 6px 8px;
  overflow: hidden;
  text-overflow: ellipsis;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}
.profile-name-input:focus {
  border-color: var(--s3);
  background: var(--wh);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--s3) 18%, transparent);
}
.profile-name-input::placeholder {
  color: var(--gry);
}
.profile-pin-input {
  font-weight: 800;
  letter-spacing: .08em;
  text-align: center;
}
.profile-role-chip {
  display: inline-flex;
  max-width: 100%;
  margin-top: 3px;
  padding: 1px 6px;
  border-radius: 999px;
  background: var(--s1);
  color: var(--gry);
  font-size: 8.5px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.profile-actions {
  grid-area: actions;
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: flex-end;
  min-width: 0;
  padding-top: 8px;
  border-top: 1px solid var(--s1);
}
.profile-actions .btn-sm {
  min-width: 0;
  white-space: nowrap;
  height: 32px;
  padding: 5px 8px;
  font-size: 10.5px;
}
.profile-save-btn {
  flex: 0 1 150px;
}
.profile-delete-btn {
  flex: 0 1 130px;
  min-width: 104px;
  height: 32px;
  border-radius: 7px;
  border: 1px solid #e03535;
  color: #fff;
  background: #e03535;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 5px 8px;
  font-family: inherit;
  font-size: 10.5px;
  font-weight: 900;
  white-space: nowrap;
}
.profile-delete-btn:hover {
  background: #c62828;
  border-color: #c62828;
}
.btn-icon-danger {
  min-width: 34px;
  height: 32px;
  border-radius: 7px;
  border: 1px solid #e03535;
  color: #fff;
  background: #e03535;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.profile-access-row {
  display: grid;
  grid-template-columns: minmax(0, .72fr) minmax(0, 1.28fr);
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--bg);
  min-width: 0;
}
.profile-access-page {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}
.profile-page-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--s3);
  background: var(--wh);
  border: 1px solid var(--s1);
  flex-shrink: 0;
}
.profile-access-page strong {
  display: block;
  color: var(--n);
  font-size: 12px;
  font-weight: 900;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.profile-role-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(76px, 1fr));
  gap: 5px;
  min-width: 0;
}
.profile-check {
  display: flex;
  align-items: center;
  gap: 5px;
  min-height: 28px;
  padding: 4px 6px;
  border: 1px solid var(--s1);
  border-radius: 7px;
  background: var(--wh);
  color: var(--n);
  font-size: 9.5px;
  font-weight: 800;
  min-width: 0;
}
.profile-check input {
  accent-color: var(--s3);
  flex-shrink: 0;
}
.profile-check span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.profile-empty {
  padding: 22px;
  border: 1px dashed var(--s2);
  border-radius: 8px;
  color: var(--gry);
  text-align: center;
  font-size: 12px;
  background: var(--bg);
}
@media (max-width: 980px) {
  .profile-grid {
    grid-template-columns: 1fr;
  }
  .profile-create,
  .profile-user-row,
  .profile-access-row {
    grid-template-columns: 1fr;
  }
  .profile-role-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .profile-head {
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .profile-switch {
    width: 100%;
  }
}
@media (max-width: 1240px) and (min-width: 981px) {
  .profile-grid {
    grid-template-columns: 1fr;
  }
  .profile-create {
    grid-template-columns: minmax(0, 1fr) minmax(130px, .7fr) minmax(120px, .55fr);
  }
  .profile-user-row {
    grid-template-columns: minmax(0, 1fr) minmax(130px, .55fr) minmax(120px, .5fr);
  }
}
@media (max-width: 560px) {
  .profile-head {
    padding: 13px;
    gap: 10px;
  }
  .profile-avatar {
    width: 46px;
    height: 46px;
    font-size: 19px;
  }
  .profile-head h2 {
    font-size: 18px;
  }
  .profile-role-grid {
    grid-template-columns: 1fr;
  }
  .profile-create .btn-p,
  .profile-actions .btn-sm {
    width: 100%;
  }
  .profile-user-row {
    grid-template-columns: 1fr;
    grid-template-areas:
      "identity"
      "role"
      "pin"
      "actions";
  }
  .profile-actions {
    justify-content: stretch;
    flex-wrap: wrap;
  }
  .profile-actions .btn-sm,
  .profile-delete-btn {
    flex: 1;
  }
  .profile-panel-title {
    align-items: flex-start;
    flex-direction: column;
  }
  .profile-panel-title .btn-sm {
    width: 100%;
  }
}

/* Piscine - carnet sanitaire */
.pis-page {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}
.pis-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--s1);
  border-left: 5px solid #2176ae;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(33,118,174,.14), transparent 46%),
    linear-gradient(135deg, var(--wh), var(--bg));
  box-shadow: var(--sh1);
}
.pis-hero.alert {
  border-left-color: var(--red);
  background:
    linear-gradient(135deg, rgba(224,53,53,.12), transparent 44%),
    linear-gradient(135deg, var(--wh), var(--bg));
}
.pis-eyebrow {
  color: var(--s3);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.pis-hero h2 {
  margin: 3px 0;
  color: var(--n);
  font-size: 30px;
  line-height: 1;
}
.pis-hero p {
  margin: 0;
  color: var(--gry);
  font-size: 12px;
}
.pis-hero-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.pis-alert {
  padding: 10px 13px;
  border: 1px solid #f4c5c5;
  border-left: 4px solid var(--red);
  border-radius: 8px;
  background: #fff5f5;
  color: #b91c1c;
  font-size: 12px;
  font-weight: 800;
}
.pis-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.pis-stat {
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid var(--s1);
  border-left: 4px solid var(--tone);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
}
.pis-stat span {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.pis-stat strong {
  display: block;
  margin-top: 4px;
  color: var(--tone);
  font-size: 22px;
  line-height: 1.1;
}
.pis-stat small {
  display: block;
  margin-top: 3px;
  color: var(--gry);
  font-size: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pis-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(300px, .8fr);
  gap: 12px;
  align-items: start;
}
.pis-main-col,
.pis-side-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}
.pis-panel {
  min-width: 0;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
  overflow: hidden;
}
.pis-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--s1);
  background: color-mix(in srgb, var(--bg) 72%, var(--wh) 28%);
}
.pis-panel-head span {
  display: block;
  color: var(--n);
  font-size: 14px;
  font-weight: 900;
}
.pis-panel-head small {
  display: block;
  margin-top: 2px;
  color: var(--gry);
  font-size: 10px;
}
.pis-tabs {
  margin: 0;
}
.pis-sheet-scroll {
  overflow-x: auto;
}
.pis-basin-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 10px;
  align-items: start;
}
.pis-sheet {
  width: 100%;
  min-width: 0;
  border-collapse: collapse;
  font-size: 10.5px;
}
.pis-sheet caption {
  padding: 9px 10px;
  border: 1px solid var(--s1);
  border-bottom: 0;
  background: color-mix(in srgb, #eaf3fb 72%, var(--wh) 28%);
  color: #1e4d7b;
  font-size: 12px;
  font-weight: 900;
  text-align: left;
}
.pis-sheet th,
.pis-sheet td {
  border: 1px solid var(--s1);
  padding: 7px 6px;
  text-align: center;
}
.pis-sheet th {
  background: #eaf3fb;
  color: #1e4d7b;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
  cursor: pointer;
}
.pis-sheet td:first-child {
  text-align: left;
  color: var(--n);
  font-weight: 800;
  background: var(--bg);
  width: 58%;
  line-height: 1.25;
}
.pis-sheet td:not(:first-child) {
  cursor: pointer;
}
.pis-sheet td:not(:first-child):hover,
.pis-sheet th:not(:first-child):hover {
  background: color-mix(in srgb, #eaf3fb 70%, var(--wh) 30%);
}
.pis-sheet .is-alert {
  background: #fff5f5;
  color: var(--red);
  font-weight: 900;
}
.pis-sheet .pis-total-row td {
  background: #e9f3fa;
  color: #17324d;
  font-weight: 900;
}
.pis-empty {
  color: #bbb;
}
.pis-calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 5px;
  padding: 10px;
  background: var(--bg);
}
.pis-calendar > b {
  text-align: center;
  color: var(--gry);
  font-size: 9px;
}
.pis-day {
  min-height: 58px;
  padding: 5px;
  border: 1px solid var(--s1);
  border-radius: 7px;
  background: var(--wh);
  color: var(--n);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}
.pis-day.today {
  border-color: #2176ae;
  box-shadow: 0 0 0 2px rgba(33,118,174,.16);
}
.pis-day.selected {
  border-color: #c9a227;
  box-shadow: 0 0 0 2px rgba(201,162,39,.22);
  background: #fffaf0;
}
.pis-day.alert {
  border-color: var(--red);
  background: #fff8f8;
}
.pis-day span,
.pis-day em {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-style: normal;
}
.pis-day strong {
  display: block;
  margin-top: 4px;
  color: #2176ae;
  font-size: 14px;
  line-height: 1.05;
}
.pis-week {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
  padding: 10px;
  background: var(--bg);
}
.pis-week-day {
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  padding: 8px;
}
.pis-week-day.today {
  border-color: #2176ae;
}
.pis-week-day.alert {
  border-color: var(--red);
}
.pis-week-day header {
  display: flex;
  justify-content: space-between;
  gap: 6px;
  margin-bottom: 7px;
  font-size: 10px;
}
.pis-week-day button,
.pis-day-row {
  width: 100%;
  margin-top: 5px;
  padding: 7px;
  border: 1px solid var(--s1);
  border-radius: 7px;
  background: var(--bg);
  color: var(--n);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}
.pis-week-day button span,
.pis-day-row span {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
  text-transform: uppercase;
}
.pis-week-day button strong,
.pis-day-row strong {
  display: block;
  color: #2176ae;
  font-size: 12px;
  margin-top: 3px;
}
.pis-week-day button em,
.pis-day-row small {
  display: block;
  color: var(--gry);
  font-size: 10px;
  font-style: normal;
}
.pis-day-list {
  padding: 10px;
  background: var(--bg);
}
.pis-day-row.alert {
  border-color: var(--red);
  background: #fff5f5;
}
.pis-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 12px;
}
.pis-summary div {
  padding: 9px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--bg);
}
.pis-summary span {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
  text-transform: uppercase;
}
.pis-summary strong {
  display: block;
  margin-top: 4px;
  color: var(--n);
  font-size: 17px;
}
.pis-layout-stock {
  grid-template-columns: 1fr;
}
.pis-stock-hidden {
  display: none;
}
.pis-stock-page {
  padding: 12px;
  background: var(--bg);
}
.pis-stock-dashboard {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}
.pis-stock-dashboard article {
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
}
.pis-stock-dashboard article.alert {
  border-color: color-mix(in srgb, var(--red) 45%, var(--s1));
  background: #fff6f6;
}
.pis-stock-dashboard span {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.pis-stock-dashboard strong {
  display: block;
  margin-top: 4px;
  color: var(--n);
  font-size: 24px;
  line-height: 1;
}
.pis-stock-dashboard small {
  display: block;
  margin-top: 5px;
  color: var(--gry);
  font-size: 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pis-stock-alert {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  padding: 10px 12px;
  border: 1px solid #f0b8b8;
  border-radius: 8px;
  background: #fff3f3;
  color: #9f1d1d;
}
.pis-stock-alert strong {
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 900;
}
.pis-stock-alert span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
}
.pis-stock-board {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 10px;
}
.pis-stock-card {
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--s1);
  border-top: 4px solid var(--tone);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
}
.pis-stock-card.low {
  background: #fffafa;
}
.pis-stock-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.pis-stock-card-head div {
  min-width: 0;
}
.pis-stock-card-head span {
  display: block;
  color: var(--tone);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.pis-stock-card-head strong {
  display: block;
  margin-top: 3px;
  color: var(--n);
  font-size: 14px;
  line-height: 1.2;
  overflow-wrap: anywhere;
}
.pis-stock-card-head b {
  flex-shrink: 0;
  min-width: 46px;
  padding: 5px 7px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--tone) 12%, var(--wh));
  color: var(--tone);
  font-size: 12px;
  text-align: center;
}
.pis-stock-meter {
  height: 9px;
  margin: 13px 0 10px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--s1);
}
.pis-stock-meter i {
  display: block;
  height: 100%;
  min-width: 3px;
  border-radius: inherit;
  background: var(--tone);
}
.pis-stock-meta {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
  color: var(--gry);
  font-size: 11px;
}
.pis-stock-meta strong {
  color: var(--n);
  font-size: 12px;
}
.pis-stock-editor {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) 38px;
  gap: 6px;
}
.pis-stock-editor button,
.pis-stock-editor input {
  min-height: 38px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  color: var(--n);
  font-family: inherit;
  font-size: 14px;
  font-weight: 900;
  text-align: center;
}
.pis-stock-editor button {
  cursor: pointer;
}
.pis-stock-editor button:hover {
  border-color: var(--tone);
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 8%, var(--wh));
}
.pis-langelier {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding: 12px;
}
.pis-langelier-result {
  margin: 0 12px 12px;
  padding: 9px 10px;
  border-radius: 8px;
  background: var(--bg);
  color: var(--n);
  font-size: 12px;
}
.pis-modal {
  max-width: 660px;
}
.pis-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pis-form-band,
.pis-form-card {
  display: grid;
  gap: 9px;
}
.pis-form-band {
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
}
.pis-form-card {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 12px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--bg);
}
.pis-form .fi,
.pis-form .fsel {
  min-height: 40px;
}
.pis-form .fta {
  min-height: 76px;
}
.pis-check {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  color: var(--n);
  font-size: 12px;
  font-weight: 800;
}
.pis-check input {
  accent-color: #2176ae;
}
.pis-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.pis-form-actions .btn-p {
  flex: 1;
  justify-content: center;
}
.pis-delete-btn {
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid #e03535;
  background: #fff5f5;
  color: #c62828;
  font-family: inherit;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1100px) {
  .pis-layout {
    grid-template-columns: 1fr;
  }
  .pis-basin-grid {
    grid-template-columns: repeat(3, minmax(220px, 1fr));
  }
  .pis-week {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .pis-hero,
  .pis-panel-head {
    align-items: stretch;
    flex-direction: column;
  }
  .pis-hero-actions,
  .pis-hero-actions .btn-p,
  .pis-hero-actions .btn-s {
    width: 100%;
  }
  .pis-hero-actions .btn-p,
  .pis-hero-actions .btn-s {
    justify-content: center;
  }
  .pis-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .pis-calendar {
    gap: 4px;
  }
  .pis-basin-grid {
    grid-template-columns: 1fr;
  }
  .pis-day {
    min-height: 52px;
  }
  .pis-form-band,
  .pis-form-card,
  .pis-langelier,
  .pis-summary {
    grid-template-columns: 1fr;
  }
  .pis-stock-dashboard {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .pis-stock-alert {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }
  .pis-stock-alert span {
    white-space: normal;
  }
  .pis-form-actions {
    flex-direction: column;
  }
  .pis-form-actions .btn-p,
  .pis-form-actions .btn-s,
  .pis-delete-btn {
    width: 100%;
  }
}
@media (max-width: 520px) {
  .pis-stats,
  .pis-week,
  .pis-stock-dashboard {
    grid-template-columns: 1fr;
  }
  .pis-stock-page {
    padding: 8px;
  }
  .pis-stock-board {
    grid-template-columns: 1fr;
  }
}

/* Sécurité jeux */
.secu-page {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.secu-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border: 1px solid color-mix(in srgb, var(--grn) 28%, var(--s1));
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(29,158,117,.16), transparent 46%),
    linear-gradient(135deg, var(--wh), var(--bg));
  box-shadow: var(--sh1);
}
.secu-hero.alert {
  border-color: color-mix(in srgb, var(--red) 35%, var(--s1));
  background:
    linear-gradient(135deg, rgba(224,53,53,.12), transparent 48%),
    linear-gradient(135deg, var(--wh), var(--bg));
}
.secu-eyebrow {
  color: var(--s3);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.secu-hero h2 {
  margin: 3px 0 0;
  color: var(--n);
  font-size: 25px;
  line-height: 1.05;
}
.secu-hero p {
  margin: 5px 0 0;
  color: var(--gry);
  font-size: 12px;
}
.secu-hero-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.secu-v2-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.secu-v2-stats article {
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid var(--s1);
  border-left: 4px solid var(--tone);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
}
.secu-v2-stats span {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.secu-v2-stats strong {
  display: block;
  margin-top: 4px;
  color: var(--tone);
  font-size: 23px;
  line-height: 1;
}
.secu-v2-stats small {
  display: block;
  margin-top: 5px;
  color: var(--gry);
  font-size: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.secu-v2-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
  padding: 5px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
}
.secu-v2-tabs button {
  min-height: 36px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: var(--gry);
  font: 900 12px/1 var(--font, inherit);
  cursor: pointer;
}
.secu-v2-tabs button.on {
  border-color: color-mix(in srgb, #2176ae 28%, var(--s1));
  background: #eaf3fb;
  color: #1b6392;
}
.secu-v2-calendar {
  display: grid;
  gap: 9px;
}
.secu-cal-head {
  color: var(--n);
  font-size: 13px;
  font-weight: 900;
  text-transform: capitalize;
}
.secu-cal-dow {
  padding: 2px 0;
  text-align: center;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
}
.secu-cal-day {
  min-height: 52px;
  display: grid;
  place-items: center;
  gap: 2px;
  border: 1px solid var(--s1);
  border-radius: 7px;
  background: var(--wh);
  color: var(--gry);
  cursor: pointer;
  font-family: inherit;
}
.secu-cal-day strong {
  color: var(--n);
  font-size: 12px;
}
.secu-cal-day span {
  font-size: 10px;
  font-weight: 900;
}
.secu-cal-day.ok {
  border-color: color-mix(in srgb, var(--grn) 40%, var(--s1));
  background: color-mix(in srgb, var(--grn) 10%, var(--wh));
}
.secu-cal-day.warn {
  border-color: color-mix(in srgb, #e8891a 42%, var(--s1));
  background: #fff8ed;
}
.secu-cal-day.bad {
  border-color: color-mix(in srgb, var(--red) 42%, var(--s1));
  background: #fff1f1;
}
.secu-cal-day.today {
  box-shadow: 0 0 0 2px #2176ae;
}
.secu-reg-form {
  display: grid;
  gap: 12px;
}
.secu-reg-form section {
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--wh);
  padding: 11px;
}
.secu-reg-form h4 {
  margin: 0 0 9px;
  color: var(--n);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.secu-form-note {
  border: 1px solid color-mix(in srgb, #2176ae 25%, var(--s1));
  border-left: 4px solid #2176ae;
  border-radius: 8px;
  background: color-mix(in srgb, #eaf3fb 70%, var(--wh) 30%);
  padding: 10px 12px;
}
.secu-form-note strong {
  display: block;
  color: var(--n);
  font-size: 13px;
}
.secu-form-note span {
  display: block;
  margin-top: 2px;
  color: var(--gry);
  font-size: 11px;
}
.secu-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.secu-form-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.secu-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.secu-kpis article {
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid var(--s1);
  border-left: 4px solid var(--tone);
  border-radius: 8px;
  background: var(--wh);
  box-shadow: var(--sh1);
}
.secu-kpis span {
  display: block;
  color: var(--gry);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.secu-kpis strong {
  display: block;
  margin-top: 4px;
  color: var(--tone);
  font-size: 23px;
  line-height: 1;
}
.secu-kpis small {
  display: block;
  margin-top: 5px;
  color: var(--gry);
  font-size: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.secu-registry-access {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, #2176ae 20%, var(--s1));
  border-left: 4px solid #2176ae;
  border-radius: 8px;
  background:
    linear-gradient(135deg, color-mix(in srgb, #eaf3fb 70%, transparent), transparent 72%),
    var(--wh);
  box-shadow: var(--sh1);
}
.secu-registry-access.active {
  border-color: color-mix(in srgb, #2176ae 38%, var(--s1));
  background:
    linear-gradient(135deg, color-mix(in srgb, #eaf3fb 92%, transparent), transparent 72%),
    var(--wh);
}
.secu-registry-access span {
  display: block;
  color: var(--s3);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.secu-registry-access strong {
  display: block;
  margin-top: 3px;
  color: var(--n);
  font-size: 15px;
  line-height: 1.15;
}
.secu-registry-access small {
  display: block;
  margin-top: 3px;
  color: var(--gry);
  font-size: 11px;
}
.secu-registry-access button {
  min-height: 38px;
  padding: 8px 16px;
  border: 0;
  border-radius: 8px;
  background: #2176ae;
  color: #fff;
  font: 800 12px/1 var(--font, inherit);
  cursor: pointer;
  box-shadow: 0 3px 9px rgba(33,118,174,.22);
}
.secu-registry-access button:hover {
  background: #1b6392;
}
.secu-tabs {
  margin: 0;
}
.secu-panel {
  background: var(--wh);
  border: 1px solid var(--s1);
  border-radius: 8px;
  padding: 12px;
  box-shadow: var(--sh1);
}
.secu-day-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.secu-day-head span {
  display: block;
  color: var(--n);
  font-size: 16px;
  font-weight: 900;
  text-transform: capitalize;
}
.secu-day-head small {
  display: block;
  color: var(--gry);
  font-size: 11px;
  margin-top: 2px;
}
.secu-progress {
  padding: 10px 12px;
  border: 1px solid var(--s1);
  border-radius: 8px;
  background: var(--bg);
  margin-bottom: 10px;
}
.secu-progress div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 7px;
}
.secu-progress span {
  color: var(--s3);
  font-size: 11px;
  font-weight: 900;
}
.secu-progress strong {
  color: var(--tone);
  font-size: 12px;
}
.secu-progress i {
  display: block;
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--s1);
}
.secu-progress b {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--tone);
}
.secu-agent-line {
  display: grid;
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr);
  gap: 8px;
  align-items: end;
  margin-bottom: 10px;
}
.secu-zone-card {
  margin-bottom: 10px;
  padding: 11px;
  border: 1px solid var(--s1);
  border-top: 4px solid var(--tone);
  border-radius: 8px;
  background: var(--wh);
}
.secu-zone-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 9px;
}
.secu-zone-head span {
  color: var(--n);
  font-size: 14px;
  font-weight: 900;
}
.secu-zone-head strong {
  flex-shrink: 0;
  padding: 3px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--tone) 12%, var(--wh));
  color: var(--tone);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}
.secu-check-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid var(--bg);
}
.secu-check-row:first-of-type {
  border-top: 0;
}
.secu-check-row > span {
  min-width: 0;
  color: var(--n);
  font-size: 12px;
  font-weight: 800;
  overflow-wrap: anywhere;
}
.secu-check-row > div {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.secu-check-row button {
  min-height: 30px;
  padding: 5px 9px;
  border: 1px solid var(--s1);
  border-radius: 7px;
  background: var(--bg);
  color: var(--gry);
  font-family: inherit;
  font-size: 10px;
  font-weight: 900;
  cursor: pointer;
}
.secu-check-row button.on {
  background: #fff8dc;
  color: #8a6000;
  border-color: #f0d37a;
}
.secu-check-row button.ok {
  background: var(--grn);
  color: #fff;
  border-color: var(--grn);
}
.secu-check-row button.bad {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
@media (max-width: 860px) {
  .secu-hero {
    align-items: stretch;
    flex-direction: column;
  }
  .secu-hero-actions,
  .secu-hero-actions .btn-p,
  .secu-hero-actions .btn-s {
    width: 100%;
  }
  .secu-hero-actions .btn-p,
  .secu-hero-actions .btn-s {
    justify-content: center;
  }
  .secu-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .secu-v2-stats,
  .secu-v2-tabs {
    grid-template-columns: 1fr;
  }
  .secu-agent-line {
    grid-template-columns: 1fr;
  }
  .secu-form-grid,
  .secu-form-actions {
    grid-template-columns: 1fr;
  }
  .secu-registry-access {
    grid-template-columns: 1fr;
  }
  .secu-registry-access button {
    width: 100%;
  }
  .secu-check-row {
    grid-template-columns: 1fr;
  }
  .secu-check-row > div {
    justify-content: stretch;
  }
  .secu-check-row button {
    flex: 1;
  }
}
@media (max-width: 520px) {
  .secu-kpis {
    grid-template-columns: 1fr;
  }
  .secu-panel {
    padding: 9px;
  }
  .secu-hero h2 {
    font-size: 21px;
  }
}
