/* ===============================
Base (dark-friendly)
=============================== */
:root{
  --bg:#0b1020; --surface:#12172a; --surface-2:#0f1426; --line:#1f2942;
  --text-1:#eef2ff; --text-2:#b6c0d4; --muted:#8391a8;
  --primary:#3b82f6; --primary-600:#2563eb; --primary-700:#1d4ed8;
  --success:#10b981; --warning:#f59e0b; --danger:#ef4444; --info:#0ea5e9;
  --radius-sm:10px; --radius-md:14px; --radius-lg:18px;
  --shadow-1:0 1px 2px rgba(0,0,0,.35), 0 6px 18px rgba(0,0,0,.45);
  --shadow-2:0 10px 28px rgba(0,0,0,.55);
  --ring:0 0 0 3px rgba(59,130,246,.22);
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:20px; --space-6:24px; --space-8:32px;
  --speed-1:120ms; --speed-2:200ms;
  --font-sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif;
  --fs-xs:12px; --fs-sm:clamp(12px,.85vw,14px); --fs-md:clamp(14px,1vw,16px); --fs-lg:clamp(18px,1.6vw,20px); --fs-xl:clamp(22px,2.2vw,26px);
}
html,body{font-family:var(--font-sans);font-size:var(--fs-md);color:var(--text-1);background:var(--bg);-webkit-font-smoothing:antialiased}
*,*::before,*::after{box-sizing:border-box}
a{color:var(--primary-600);text-decoration:none}
a:hover{text-decoration:underline}

/* Layout */
.container{margin:0 auto;padding:var(--space-6);max-width:1200px}
.header{position:sticky;top:0;z-index:10;backdrop-filter:saturate(140%) blur(8px);background:color-mix(in srgb,var(--surface) 85%, transparent);border-bottom:1px solid var(--line)}
.header__inner{display:flex;gap:var(--space-4);align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6)}
.app-title{font-size:var(--fs-xl);letter-spacing:-.02em;font-weight:650}
.toolbar{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-1)}
.card--pad{padding:var(--space-6)}
.section{display:grid;gap:var(--space-6);margin-block:var(--space-6)}

/* Controls */
.btn{--btn-bg:var(--surface);--btn-fg:var(--text-1);--btn-bd:var(--line);display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;border:1px solid var(--btn-bd);background:var(--btn-bg);color:var(--btn-fg);font-weight:600;line-height:1;box-shadow:var(--shadow-1);transition:transform var(--speed-1), background var(--speed-2), color var(--speed-2), border-color var(--speed-2), box-shadow var(--speed-2);cursor:pointer}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}
.btn:disabled{opacity:.6;cursor:not-allowed}
.btn--primary{--btn-bg:var(--primary);--btn-fg:#fff;--btn-bd:color-mix(in srgb,var(--primary) 90%,black 10%)}
.btn--subtle{--btn-bg:var(--surface-2);--btn-fg:var(--text-1)}
.btn--danger{--btn-bg:var(--danger);--btn-fg:#fff;--btn--bd:color-mix(in srgb,var(--danger) 90%,black 10%)}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:14px}
.input,.select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--text-1);transition:border-color var(--speed-1),box-shadow var(--speed-1)}
.input::placeholder{color:var(--muted)} .input:focus,.select:focus{box-shadow:var(--ring);border-color:var(--primary)}

/* Info badge */
.badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-weight:600;font-size:var(--fs-sm);background:var(--surface-2);color:var(--text-1);border:1px solid var(--line)}
.badge--info{background:color-mix(in srgb,var(--info) 18%,var(--surface) 82%);color:var(--text-1)}

/* Sélecteur de RV */
.r-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--text-1);font-weight:600;box-shadow:var(--shadow-1);cursor:pointer}
.r-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}

/* Calendar grid */
.calendar{display:grid;gap:var(--space-4);grid-template-columns:repeat(7,1fr)}
@media (max-width:1100px){.calendar{grid-template-columns:repeat(5,1fr)}}
@media (max-width:900px){.calendar{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.calendar{grid-template-columns:repeat(2,1fr)}}

/* Day card */
.day{
  position:relative;
  background:linear-gradient(180deg, color-mix(in srgb,var(--surface) 96%, black 4%), color-mix(in srgb,var(--surface) 90%, black 10%));
  border:1px solid color-mix(in srgb,var(--line) 85%, black 15%);
  border-radius:16px;
  box-shadow:var(--shadow-1);
  display:grid; grid-template-rows:auto 1fr;
  min-height:200px;
  overflow:hidden;
}
.day:hover{box-shadow:var(--shadow-2);border-color:color-mix(in srgb,var(--primary) 30%, var(--line) 70%)}

/* Header de jour */
.day__head{
  position:sticky; top:0; z-index:1;
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px;
  border-bottom:1px solid color-mix(in srgb,var(--line) 90%, black 10%);
  background:linear-gradient(180deg, color-mix(in srgb,var(--surface-2) 70%, transparent), transparent);
  backdrop-filter:saturate(130%) blur(2px);
  border-top-left-radius:16px; border-top-right-radius:16px;
}
.day__title{font-size:clamp(15px,1.2vw,17px);font-weight:800;letter-spacing:-.01em;text-transform:none;color:var(--text-1)}
.day__meta{display:none !important}

/* Slots: overlay label + rangée de pastilles en bas */
.slots{
  display:flex; flex-direction:column; gap:10px;
  padding:12px 12px 14px;
  overflow:auto;
  max-height:48vh;
}
@media (max-height:740px){ .slots{ max-height:44vh } }

.slot{
  --mine:#22c55e;
  position:relative;
  height:46px;
  width:100%;
  border:1px solid color-mix(in srgb,var(--line) 80%, black 20%);
  border-radius:12px;
  background:color-mix(in srgb,var(--surface) 96%, var(--primary) 4%);
  transition:background var(--speed-1),border-color var(--speed-1),box-shadow var(--speed-1);
  cursor:pointer;
}
.slot:hover{border-color:color-mix(in srgb,var(--primary) 45%, var(--line) 55%); box-shadow:0 6px 14px rgba(0,0,0,.25)}

.slot__label{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-weight:800; letter-spacing:.01em;
  pointer-events:none;
  text-shadow:0 1px 1px rgba(0,0,0,.25);
}

/* badge compteur (visible > 0) */
.slot::after{
  content: attr(data-count) " dispo";
  position:absolute; right:8px; top:6px;
  padding:2px 8px; border-radius:999px;
  font-size:var(--fs-xs); font-weight:700; letter-spacing:.02em;
  background:color-mix(in srgb,var(--surface-2) 70%, var(--success) 30%);
  color:color-mix(in srgb,#fff 92%, var(--success) 8%);
  border:1px solid color-mix(in srgb,var(--success) 50%, var(--line) 50%);
  opacity:.95;
}
.slot[data-count="0"]::after{ display:none; content:""; }

/* Indicateur “moi” */
.slot.is-mine::before{
  content:""; position:absolute; left:10px; top:50%; transform:translateY(-50%);
  width:10px; height:10px; border-radius:50%; background:var(--mine);
  box-shadow:0 0 0 2px rgba(0,0,0,.45);
}

/* Pastilles en LIGNE (centrées bas) */
.slot__stack{
  position:absolute;
  left:50%; bottom:6px; transform:translateX(-50%);
  display:flex; gap:6px; flex-wrap:wrap; justify-content:center;
  max-width:calc(100% - 16px);
  pointer-events:none;
}
.stack-dot{
  width:9px;height:9px;border-radius:50%;
  border:1px solid color-mix(in srgb,var(--line) 60%,black 40%);
  background:var(--surface-2);
}

/* Nuance par densité */
.slot[data-count="0"]{background:color-mix(in srgb,var(--surface) 98%, var(--primary) 2%); opacity:.9}
.slot[data-count="1"]{background:color-mix(in srgb,var(--surface) 95%, var(--primary) 5%)}
.slot[data-count="2"]{background:color-mix(in srgb,var(--surface) 92%, var(--primary) 8%)}
.slot[data-count="3"]{background:color-mix(in srgb,var(--surface) 90%, var(--primary) 10%)}
.slot[data-count="4"]{background:color-mix(in srgb,var(--surface) 88%, var(--primary) 12%)}
.slot[data-count="5"]{background:color-mix(in srgb,var(--surface) 86%, var(--primary) 14%)}
.slot[data-count="6"]{background:color-mix(in srgb,var(--surface) 84%, var(--primary) 16%)}

/* Sélection */
.slot.is-selected{
  border-color:var(--primary-700);
  background:linear-gradient(180deg, color-mix(in srgb,var(--primary) 26%, var(--surface) 74%), color-mix(in srgb,var(--primary) 18%, var(--surface) 82%));
  box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 35%, transparent), inset 0 1px 0 rgba(255,255,255,.04);
}

/* Alt enfoncé: hint pour “Alt+clic = journée” */
body[data-alt="1"] .slot:hover{
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.12);
  border-color: color-mix(in srgb,var(--warning) 40%, var(--line) 60%);
}

/* TOP 3 */
.podium.podium--row{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(260px, 1fr);gap:var(--space-4);overflow-x:auto;padding-bottom:6px;scroll-snap-type:x proximity;scrollbar-width:thin}
.podium-card{scroll-snap-align:start;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-1);padding:14px;display:grid;gap:10px;min-width:260px}
@media (min-width:980px){.podium.podium--row{grid-auto-columns:1fr}.podium-card{min-width:auto}}
.podium-card__head{display:flex;align-items:center;gap:10px;color:var(--text-2);font-size:var(--fs-sm)}
.rank{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;font-weight:800;color:#fff;background:var(--primary)}
.rank[data-rank="1"]{background:linear-gradient(135deg,#fbbf24,#f59e0b)}
.rank[data-rank="2"]{background:linear-gradient(135deg,#d1d5db,#9ca3af);color:#111}
.rank[data-rank="3"]{background:linear-gradient(135deg,#a16207,#eab308)}
.podium-card__title{font-weight:700;letter-spacing:-.01em}
.podium-card__slot{font-variant-numeric:tabular-nums}
.score-badge{justify-self:start;font-weight:700;padding:8px 10px;border-radius:12px;background:color-mix(in srgb,var(--success) 18%,var(--surface) 82%);color:var(--success);border:1px solid color-mix(in srgb,var(--success) 40%,var(--line) 60%)}

/* Noms en colonne (Top 3) */
.names-list{display:grid;gap:6px;margin:4px 0 0 0;padding:0;list-style:none}
.name-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px dashed var(--line)}
.name-row:last-child{border-bottom:0}
.name-dot{width:10px;height:10px;border-radius:50%;background:var(--text-2);flex:0 0 10px;border:1px solid color-mix(in srgb,var(--line) 50%, black 50%)}
.name-text{font-weight:700;letter-spacing:-0.01em}

/* Utils */
.hidden{display:none !important}
.muted{color:var(--text-2)}
.small{font-size:var(--fs-sm)}
.progress-mini{min-width:220px}
.progress-mini__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.progress-mini__bar{height:8px;background:var(--surface-2);border-radius:999px;position:relative;overflow:hidden}
.progress-mini__bar>i{position:absolute;left:0;top:0;bottom:0;width:var(--value,0%);background:linear-gradient(90deg,var(--primary),var(--success))}

