/* ═══════════════════════════════════════════
   THÈMES
═══════════════════════════════════════════ */
:root, [data-theme="dark"] {
  --bg:#0a0a0d; --surface:#111115; --card:#18181d; --card-hover:#1f1f26;
  --border:#26262e; --border-soft:#1c1c22;
  --accent:#7c6fff; --accent-dim:rgba(124,111,255,.14); --accent-glow:rgba(124,111,255,.30);
  --accent2:#a78bfa; /* violet plus doux pour les accents secondaires */
  --txt:#f2f2f6; --txt-2:#8888a0; --txt-3:#404050;
  --high:#ff5577; --high-dim:rgba(255,85,119,.14);
  --medium:#ffaa44; --medium-dim:rgba(255,170,68,.14);
  --low:#34e89e; --low-dim:rgba(52,232,158,.14);
  --danger:#ff5577; --danger-dim:rgba(255,85,119,.14);
  --input-scheme:dark;
  /* Ombres premium */
  --shadow-card: 0 2px 12px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.6);
  --shadow-nav:  0 -1px 0 rgba(255,255,255,.04), 0 -4px 24px rgba(0,0,0,.5);
  --shadow-btn:  0 4px 16px var(--accent-glow);
}
[data-theme="light"] {
  --bg:#f4f4f8; --surface:#fff; --card:#fff; --card-hover:#f8f8fc;
  --border:#e0e0ea; --border-soft:#eaeaf2;
  --accent:#6b5fff; --accent-dim:rgba(107,95,255,.10); --accent-glow:rgba(107,95,255,.22);
  --accent2:#8b7aff;
  --txt:#16162a; --txt-2:#6060780; --txt-3:#b0b0c8;
  --high:#e8374f; --high-dim:rgba(232,55,79,.10);
  --medium:#e88c30; --medium-dim:rgba(232,140,48,.10);
  --low:#1dc96e; --low-dim:rgba(29,201,110,.10);
  --danger:#e8374f; --danger-dim:rgba(232,55,79,.10);
  --input-scheme:light;
  --shadow-card: 0 2px 10px rgba(0,0,0,.07), 0 1px 3px rgba(0,0,0,.06);
  --shadow-nav:  0 -1px 0 rgba(0,0,0,.08), 0 -4px 20px rgba(0,0,0,.06);
  --shadow-btn:  0 4px 14px var(--accent-glow);
}
:root { --r:12px;--r-sm:8px;--r-lg:20px;--pill:100px;--t:.16s;--ease:cubic-bezier(.25,.46,.45,.94); }

/* ═══════════════════════════════════════════
   RESET
═══════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent; }
[hidden] { display:none !important; }

/* ─── FOND GLOBAL iOS PWA ─────────────────────────────────────────────────────
   BANDE NOIRE : causée par le fond de <html>/<body> qui transperce dans la zone
   home indicator. Trois correctifs combinés :
   1. background = var(--surface) = même couleur que la nav → zone invisible.
   2. position: fixed sur body → BLOQUE le bounce élastique iOS qui révèle le fond.
   3. height: 100% sur html + body (pas dvh) → le fond remplir vraiment le 100%.
   ────────────────────────────────────────────────────────────────────────────── */
html {
  /* var(--surface) s'adapte au thème clair/sombre — remplace le fond noir */
  background-color: var(--surface);
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'Segoe UI', system-ui, sans-serif;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  color: var(--txt);
  height: var(--real-vh, 100dvh);
  overflow: hidden;
  margin: 0; padding: 0;
}

body {
  /* PAS de position: fixed → le scroll de la modale fonctionne */
  background-color: var(--bg);
  height: var(--real-vh, 100dvh);
  overflow: hidden;
  overflow-x: hidden;
  margin: 0; padding: 0;
  width: 100%;
  position: relative;
}

button { font-family:inherit;cursor:pointer;border:none;background:none;color:inherit; }
input,textarea,select { font-family:inherit; }
svg { display:block;flex-shrink:0; }
::-webkit-scrollbar { width:3px;height:3px; }
::-webkit-scrollbar-thumb { background:var(--border);border-radius:4px; }

/* ═══════════════════════════════════════════
   HEADER — premium glassmorphism
═══════════════════════════════════════════ */
.app-header {
  position: fixed; top:0; left:0; right:0; z-index:200;
  background: var(--surface);
  border-bottom: 1px solid var(--border-soft);
  padding-top: env(safe-area-inset-top, 0px);
  transform: translateZ(0);
  /* Subtle bottom shadow to lift header above content */
  box-shadow: 0 1px 0 var(--border-soft), 0 4px 20px rgba(0,0,0,.18);
}
.header-inner {
  min-height: 48px; height: auto; display:flex; align-items:center; justify-content:space-between; padding:0 10px; gap:6px;
}
.header-tabs {
  flex:1; display:flex; align-items:center; justify-content:center; gap:2px;
}
.header-brand { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.brand-icon   { width:22px; height:22px; color:var(--accent); filter: drop-shadow(0 0 6px var(--accent-glow)); }
.brand-name   {
  font-size:1.28rem; font-weight:900; letter-spacing:-.04em;
  background: linear-gradient(135deg, var(--txt) 40%, var(--accent2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.header-actions { display:flex; align-items:center; gap:4px; }
.header-ctx { display:none; }

/* ═══════════════════════════════════════════
   TAG FILTER BAR
═══════════════════════════════════════════ */
.tag-filter-bar {
  position:fixed;left:0;right:0;z-index:190;
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:6px 12px;display:flex;gap:6px;
  overflow-x:auto;overflow-y:hidden;   /* POINT 3 */
  scrollbar-width:none;-ms-overflow-style:none;
  transform:translateZ(0);
}
.tag-filter-bar::-webkit-scrollbar { display:none; }
.tag-filter-btn {
  flex-shrink:0;height:27px;padding:0 11px;border-radius:var(--pill);
  font-size:.74rem;font-weight:600;background:var(--card);color:var(--txt-2);
  border:1.5px solid transparent;transition:background var(--t),color var(--t),border-color var(--t);white-space:nowrap;
}
.tag-filter-btn.active { background:var(--accent-dim);color:var(--accent);border-color:var(--accent); }
.tag-filter-btn.mgmt-btn { color:var(--txt-3);font-size:.72rem; }

/* ═══════════════════════════════════════════
   MAIN — POINT 3: scroll vertical ici seulement
   top/bottom injectés par JS (syncLayout)
═══════════════════════════════════════════ */
.app-main {
  position:fixed;left:0;right:0;
  overflow-y:scroll;          /* forcer le scroll vertical */
  overflow-x:hidden;          /* POINT 3: aucun défilement horizontal */
  -webkit-overflow-scrolling:touch;
  touch-action:pan-y;
  overscroll-behavior:none;
  transform:translateZ(0);
}

/* ═══════════════════════════════════════════
   BOTTOM NAV — premium
═══════════════════════════════════════════ */
.bottom-nav {
  position: fixed !important;
  bottom: 0 !important;
  left: 0;
  width: 100%;
  margin-bottom: 0 !important;
  background-color: var(--surface) !important;
  z-index: 10000 !important;
  box-shadow: var(--shadow-nav);
  border-top: 1px solid var(--border-soft);
  display: flex !important;
  justify-content: space-around;
  align-items: center;
  padding-top: 8px;
  padding-bottom: 8px;
  transform: translateZ(0);
}
.nav-btn {
  flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:0 2px;color:var(--txt-3);font-size:.58rem;font-weight:600;
  letter-spacing:.01em;transition:color var(--t);position:relative;
  overflow:hidden;white-space:nowrap;
}
.nav-btn svg { width:21px;height:21px;transition:transform var(--t); }
.nav-btn.active { color:var(--accent); }
.nav-btn.active svg { transform:scale(1.1); }
.nav-btn.active::before {
  content:'';position:absolute;top:-8px;width:26px;height:2px;
  background:var(--accent);border-radius:0 0 4px 4px;
}

/* ═══════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.btn-icon { width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--txt-2);transition:background var(--t),color var(--t); }
.btn-icon:hover { background:var(--card);color:var(--txt); }
.btn-icon svg { width:18px;height:18px; }
.btn-close { color:var(--txt-3); }
.btn-add {
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-radius:12px; color:#fff;
  box-shadow: var(--shadow-btn);
  transition:transform var(--t), box-shadow var(--t), opacity var(--t);
}
.btn-add:active { transform:scale(.88); box-shadow:none; opacity:.9; }
.btn-add svg { width:16px;height:16px; }
.btn-voice-main.recording { color:var(--high);animation:micPulse .9s ease infinite; }
@keyframes micPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }
.btn-primary { flex:1;height:46px;background:var(--accent);color:#fff;border-radius:var(--r);font-size:1rem;font-weight:600;box-shadow:0 4px 14px var(--accent-glow);transition:opacity var(--t),transform var(--t); }
.btn-primary:active { opacity:.88;transform:scale(.98); }
.btn-danger { height:46px;padding:0 14px;display:flex;align-items:center;gap:6px;background:var(--danger-dim);color:var(--danger);border-radius:var(--r);font-size:.9rem;font-weight:500;transition:background var(--t); }
.btn-danger svg { width:15px;height:15px; }
.btn-ghost { height:36px;padding:0 12px;color:var(--txt-2);border-radius:var(--r-sm);font-size:.86rem;font-weight:500;transition:background var(--t),color var(--t); }
.btn-ghost:hover { background:var(--card);color:var(--txt); }
.btn-tag-edit { margin-left:auto;font-size:.7rem;color:var(--accent);padding:2px 8px;border-radius:var(--pill);background:var(--accent-dim);transition:background var(--t); }

/* ═══════════════════════════════════════════
   VIEW
═══════════════════════════════════════════ */
.view { padding:13px 13px 32px;animation:viewIn .2s var(--ease) both; }
@keyframes viewIn { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════════
   DATE NAV — tailles premium agrandies
═══════════════════════════════════════════ */
.date-nav { display:flex;align-items:center;justify-content:space-between;margin-bottom:13px; }
.date-nav-center { flex:1;text-align:center; }
.date-nav-title { font-size:1.12rem;font-weight:800;letter-spacing:-.02em; }  /* +20% */
.date-nav-sub { font-size:.78rem;color:var(--txt-2);margin-top:3px; }
.today-badge {
  display:inline-block;background:var(--accent-dim);color:var(--accent);
  font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:var(--pill);
  margin-left:6px;vertical-align:middle;letter-spacing:.02em;
}
.date-nav-btn { width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--txt-2);transition:background var(--t),color var(--t); }
.date-nav-btn svg { width:20px;height:20px; }
.date-nav-btn:active { background:var(--card); }
.day-stats { display:flex;align-items:center;gap:8px;margin-bottom:12px; }
.stats-bar { flex:1;height:4px;background:var(--border);border-radius:var(--pill);overflow:hidden; }
.stats-bar-fill { height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:var(--pill);transition:width .35s var(--ease); }
.stats-text { font-size:.74rem;color:var(--txt-2);white-space:nowrap;font-weight:600; }

/* ── Bloque le zoom Safari sur TOUS les champs de saisie ── */
input, textarea, select { font-size: 16px !important; }

/* ═══════════════════════════════════════════
   SWIPE-TO-DELETE — animation visible
═══════════════════════════════════════════ */

/* Le wrapper EST le fond rouge — toujours présent, recouvert par swipe-shell */
.swipe-wrapper {
  position: relative;
  border-radius: var(--r);
  overflow: hidden;
  background: transparent;
}

/* L'icône corbeille, positionnée à droite et toujours derrière la carte */
.swipe-bg {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 90px;
  background: var(--high);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  color: #fff;
  cursor: pointer;
  /* Animation d'échelle au seuil de suppression */
  transition: transform .12s ease;
}
.swipe-bg svg  { width: 22px; height: 22px; }
.swipe-bg span { font-size: .7rem; font-weight: 700; letter-spacing: .02em; }

/* Dépassement du seuil → icône grossit pour feedback visuel */
.swipe-wrapper.over-threshold .swipe-bg { transform: scale(1.15); }
.swipe-wrapper.over-threshold            { background: #e8374f; } /* rouge plus vif */

/* La coquille qui glisse (couvre le rouge par défaut) */
.swipe-shell {
  position: relative;
  z-index: 1;
  border-radius: var(--r);
  background: var(--card); /* OBLIGATOIRE : cache le fond rouge */
  will-change: transform;
  transform: translateX(0);
}

/* ═══════════════════════════════════════════
   TASK CARD
═══════════════════════════════════════════ */
.tasks-list { display:flex; flex-direction:column; gap:8px; }

.task-card {
  display:flex; align-items:flex-start; gap:10px;
  background: var(--card);
  border-radius: var(--r);
  padding: 12px 12px 12px 14px;
  border-left: 3px solid transparent;
  box-shadow: var(--shadow-card);
  transform: translateZ(0);
  animation: cardIn .22s var(--ease) both;
  transition: background var(--t), transform .12s ease;
}
.task-card:active { transform: scale(.99) translateZ(0); }
@keyframes cardIn { from{opacity:0;transform:translateX(-10px) translateZ(0)} to{opacity:1;transform:translateX(0) translateZ(0)} }
.task-card:active { background:var(--card-hover); }
.task-card.priority-high   { border-left-color:var(--high); }
.task-card.priority-medium { border-left-color:var(--medium); }
.task-card.priority-low    { border-left-color:var(--low); }
.task-card.completed { opacity:.42;border-left-color:var(--border)!important; }
.task-check { width:22px;height:22px;flex-shrink:0;margin-top:1px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;color:#fff;transition:border-color var(--t),background var(--t),transform var(--t); }
.task-check svg { width:11px;height:11px;opacity:0;transition:opacity var(--t); }
.task-check:active { transform:scale(.82); }
.task-card.priority-high   .task-check { border-color:var(--high); }
.task-card.priority-medium .task-check { border-color:var(--medium); }
.task-card.priority-low    .task-check { border-color:var(--low); }
.task-card.completed .task-check { background:var(--txt-3);border-color:var(--txt-3); }
.task-card.completed .task-check svg { opacity:1; }
.task-body { flex:1;min-width:0; }
.task-title { font-size:.97rem;font-weight:600;color:var(--txt);line-height:1.35;word-break:break-word; }
.task-card.completed .task-title { text-decoration:line-through;color:var(--txt-3); }
.task-desc { font-size:.77rem;color:var(--txt-2);margin-top:3px;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical; }
/* Métadonnées : wrap autorisé, chips ne se réduisent jamais */
.task-meta {
  display: flex;
  flex-wrap: wrap;             /* passe à la ligne si manque d'espace */
  align-items: center;
  gap: 5px;
  margin-top: 6px;
}

/* Chaque chip garde sa taille et ne coupe jamais son texte */
.task-badge {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: .66rem; color: var(--txt-2); background: var(--surface);
  padding: 2px 6px; border-radius: var(--pill);
  white-space: nowrap;         /* texte jamais rogné */
  flex-shrink: 0;              /* chip jamais rétréci */
  text-decoration: none;
}
.task-badge svg { width:9px;height:9px; }
.task-badge.overdue     { color:var(--high);background:var(--high-dim); }
.task-badge.notif-badge { color:var(--medium);background:var(--medium-dim); }
.task-badge.recur-badge { color:var(--accent);background:var(--accent-dim); }
.task-tag-chip { font-size:.64rem;font-weight:600;padding:2px 7px;border-radius:var(--pill);display:inline-flex;align-items:center;gap:3px;white-space:nowrap;border:1px solid transparent;flex-shrink:0; }
.task-edit { width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--txt-3);flex-shrink:0;margin-top:-1px;transition:background var(--t),color var(--t); }
.task-edit svg { width:14px;height:14px; }

/* ═══════════════════════════════════════════
   SECTION HEADERS
═══════════════════════════════════════════ */
.section-header { display:flex;align-items:center;gap:7px;margin-bottom:8px;margin-top:20px; }
.section-header:first-child { margin-top:0; }
.section-label { font-size:.72rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--txt-3); }
.section-count { background:var(--card);color:var(--txt-2);font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:var(--pill); }
.section-high   .section-label { color:var(--high); }   .section-high   .section-count { background:var(--high-dim);  color:var(--high); }
.section-medium .section-label { color:var(--medium); } .section-medium .section-count { background:var(--medium-dim);color:var(--medium); }
.section-low    .section-label { color:var(--low); }    .section-low    .section-count { background:var(--low-dim);   color:var(--low); }

/* ═══════════════════════════════════════════
   PLANNING TIMELINE
═══════════════════════════════════════════ */
.planning-list { display:flex;flex-direction:column;gap:0;position:relative; }
.planning-list::before { content:'';position:absolute;left:48px;top:26px;bottom:26px;width:1px;background:var(--border-soft);z-index:0; }
.planning-row { display:flex;align-items:flex-start;padding:4px 0;position:relative;animation:cardIn .2s var(--ease) both; }
.planning-time-col { width:52px;flex-shrink:0;text-align:right;padding-right:10px;padding-top:12px;font-size:.74rem;font-weight:700;color:var(--accent);letter-spacing:-.02em;line-height:1;position:relative;z-index:1; }
.planning-time-col::after { content:'';position:absolute;right:-3px;top:17px;width:7px;height:7px;border-radius:50%;background:var(--border);border:1.5px solid var(--surface);z-index:2; }
.planning-time-col.no-time { color:var(--txt-3);font-weight:400;font-size:.69rem; }
.planning-card-wrap { flex:1;min-width:0;padding-left:10px; }
.planning-card-wrap .task-card { border-left-color:transparent!important; }
.planning-divider { width:100%;padding:4px 0 4px 52px;font-size:.67rem;font-weight:700;color:var(--txt-3);text-transform:uppercase;letter-spacing:.06em; }
.planning-row:has(.task-card.priority-high)   .planning-time-col::after { background:var(--high); }
.planning-row:has(.task-card.priority-medium) .planning-time-col::after { background:var(--medium); }
.planning-row:has(.task-card.priority-low)    .planning-time-col::after { background:var(--low); }
.planning-row:has(.task-card.completed)       .planning-time-col::after { background:var(--txt-3); }

/* ═══════════════════════════════════════════
   EMPTY STATE
═══════════════════════════════════════════ */
.empty-state { display:flex;flex-direction:column;align-items:center;padding:48px 24px;text-align:center;gap:10px; }
.empty-icon { width:52px;height:52px;background:var(--card);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--txt-3);margin-bottom:4px; }
.empty-icon svg { width:24px;height:24px; }
.empty-title { font-size:.97rem;font-weight:600;color:var(--txt-2); }
.empty-sub   { font-size:.81rem;color:var(--txt-3);line-height:1.5;max-width:220px; }

/* ═══════════════════════════════════════════
   CALENDAR
═══════════════════════════════════════════ */
.calendar { background:var(--card);border-radius:var(--r-lg);overflow:hidden;margin-bottom:13px; }
.calendar-header { display:flex;align-items:center;justify-content:space-between;padding:11px 13px;border-bottom:1px solid var(--border-soft); }
.calendar-month-title { font-size:.91rem;font-weight:600; }
.calendar-nav-btn { width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--txt-2); }
.calendar-nav-btn svg { width:16px;height:16px; }
.calendar-grid { display:grid;grid-template-columns:repeat(7,1fr); }
.calendar-dow { padding:6px 0;text-align:center;font-size:.62rem;font-weight:700;letter-spacing:.04em;color:var(--txt-3);text-transform:uppercase; }
.calendar-day { display:flex;flex-direction:column;align-items:center;padding:5px 2px 6px;min-height:48px;cursor:pointer;transition:background var(--t);gap:3px; }
.calendar-day:active { background:var(--border); }
.calendar-day.empty { cursor:default;pointer-events:none; }
.cal-num { width:27px;height:27px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.8rem;font-weight:500;color:var(--txt-2); }
.calendar-day.today .cal-num { background:var(--accent);color:#fff;font-weight:700; }
.calendar-day.selected:not(.today) .cal-num { background:var(--accent-dim);color:var(--accent); }
.cal-dots { display:flex;gap:2px;min-height:6px;flex-wrap:wrap;justify-content:center;max-width:28px; }
.cal-dot { width:5px;height:5px;border-radius:50%;flex-shrink:0; }
.cal-dot.high{background:var(--high)}.cal-dot.medium{background:var(--medium)}.cal-dot.low{background:var(--low)}.cal-dot.done{background:var(--txt-3)}
.calendar-day-detail { border-top:1px solid var(--border-soft);padding:11px 12px; }
.calendar-day-detail-title { font-size:.75rem;font-weight:700;color:var(--txt-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px; }

/* ═══════════════════════════════════════════
   FILTER VIEW — compact premium 2 colonnes
═══════════════════════════════════════════ */

/* Conteneur grille serré */
.filter-view-compact { padding: 10px 12px 28px !important; }
.filter-grid { display:flex; flex-direction:column; gap:8px; }

.fg-cell { display:flex; flex-direction:column; gap:5px; }
.fg-label {
  font-size:.62rem; font-weight:800; text-transform:uppercase;
  letter-spacing:.07em; color:var(--txt-3);
}
/* Ligne scrollable horizontalement — chips ne wrappent pas */
.fg-row {
  display:flex; gap:5px;
  overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none;
  padding-bottom:2px;
}
.fg-row::-webkit-scrollbar { display:none; }

/* Rangée divisée en 2 moitiés */
.fg-row-h { display:flex; gap:10px; align-items:flex-start; }
.fg-half  { flex:1; min-width:0; display:flex; flex-direction:column; gap:5px; }

/* Chip générique compact */
.fc {
  flex-shrink:0;
  height:28px; padding:0 10px;
  border-radius:var(--pill);
  font-size:.73rem; font-weight:600;
  background:var(--card); color:var(--txt-2);
  border:1.5px solid transparent;
  white-space:nowrap;
  transition:background var(--t),color var(--t),border-color var(--t);
}
.fc.fc-on { background:var(--accent-dim); color:var(--accent); border-color:var(--accent); }
.fc.p-high.fc-on    { background:var(--high-dim);   color:var(--high);   border-color:var(--high); }
.fc.p-medium.fc-on  { background:var(--medium-dim); color:var(--medium); border-color:var(--medium); }
.fc.p-low.fc-on     { background:var(--low-dim);    color:var(--low);    border-color:var(--low); }
.fc.fc-clear { background:var(--danger-dim); color:var(--danger); }

/* Anciens sélecteurs conservés pour compatibilité */
.filter-section { margin-bottom:10px; }
.filter-label { font-size:.65rem;font-weight:700;color:var(--txt-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px; }
.filter-chips { display:flex;gap:5px;overflow-x:auto;scrollbar-width:none; }
.filter-chips::-webkit-scrollbar { display:none; }
.filter-chip {
  flex-shrink:0; height:28px; padding:0 10px; border-radius:var(--pill);
  font-size:.73rem; font-weight:600; background:var(--card); color:var(--txt-2);
  border:1.5px solid transparent; white-space:nowrap;
  transition:background var(--t),color var(--t),border-color var(--t);
}
.filter-chip.active { background:var(--accent-dim);color:var(--accent);border-color:var(--accent); }
.filter-chip.p-high.active   { background:var(--high-dim);  color:var(--high);  border-color:var(--high); }
.filter-chip.p-medium.active { background:var(--medium-dim);color:var(--medium);border-color:var(--medium); }
.filter-chip.p-low.active    { background:var(--low-dim);   color:var(--low);   border-color:var(--low); }

.filter-row-toggle { display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-top:1px solid var(--border-soft); }
.filter-toggle-label { font-size:.84rem;color:var(--txt); }
.toggle-btn { width:44px;height:26px;border-radius:13px;background:var(--border);cursor:pointer;position:relative;transition:background var(--t);flex-shrink:0; }
.toggle-btn.on { background:var(--accent); }
.toggle-knob { position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform var(--t);box-shadow:0 1px 4px rgba(0,0,0,.3); }
.toggle-btn.on .toggle-knob { transform:translateX(18px); }
.btn-clear-filters { display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background:var(--danger-dim);color:var(--danger);border-radius:var(--r-sm);font-size:.78rem;font-weight:600; }
.filter-results-count {
  font-size:.73rem;font-weight:700;color:var(--txt-3);
  text-transform:uppercase;letter-spacing:.06em;
  padding:10px 0 6px;border-top:1px solid var(--border-soft);margin-top:4px;
}

/* ═══════════════════════════════════════════
   STATS / DONE VIEW
═══════════════════════════════════════════ */
.stats-card {
  background: linear-gradient(145deg, var(--card), var(--card-hover));
  border-radius: var(--r-lg);
  padding: 18px;
  margin-bottom: 14px;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border-soft);
}
/* ── Header stats-card ── */
.stats-card-header { display:flex;align-items:center;gap:12px;margin-bottom:18px; }
.stats-emoji {
  font-size:2rem; line-height:1;
  width:44px; height:44px;
  display:flex; align-items:center; justify-content:center;
  background: var(--accent-dim);
  border-radius:12px; flex-shrink:0;
}
.stats-headline { font-size:1.08rem;font-weight:800;line-height:1.25;letter-spacing:-.01em; }
.stats-sub { font-size:.8rem;color:var(--txt-2);margin-top:3px; }

/* ── Grille 3 boîtes ── */
.stats-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px; }
.stat-box {
  background: linear-gradient(145deg, var(--surface), var(--card));
  border-radius: var(--r);
  padding: 16px 8px 12px;
  text-align: center;
  border: 1px solid var(--border-soft);
  box-shadow: var(--shadow-card);
  position: relative; overflow: hidden;
}
/* Halo décoratif derrière le chiffre */
.stat-box::before {
  content: '';
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  width: 60px; height: 60px; border-radius: 50%;
  background: radial-gradient(circle, var(--accent-dim), transparent 70%);
}
.stat-box strong {
  display:block; font-size:2rem; font-weight:900; line-height:1;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  position: relative;
}
.stat-box span {
  font-size:.62rem; color:var(--txt-3); margin-top:5px; display:block;
  font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  position: relative;
}

/* ── Barre de taux ── */
.stats-rate-label { font-size:.74rem;font-weight:700;color:var(--txt-2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px; }
.stats-bar-lg {
  height:10px; background:var(--border); border-radius:var(--pill);
  overflow:hidden; margin-bottom:6px;
  box-shadow: inset 0 1px 3px rgba(0,0,0,.2);
}
.stats-bar-lg-fill {
  height:100%; border-radius:var(--pill); transition:width .7s var(--ease);
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow: 0 0 8px var(--accent-glow);
}

/* ── Streak ── */
.streak-row {
  display:flex; align-items:center; gap:10px;
  margin-top:14px; padding-top:14px; border-top:1px solid var(--border-soft);
}
.streak-icon { font-size:1.4rem; }
.streak-text { font-size:.88rem; font-weight:700; }
.streak-sub  { font-size:.75rem; color:var(--txt-2); margin-top:1px; }

/* ── Backup buttons ── */
.backup-row { display:flex;gap:9px;margin-bottom:16px; }
.btn-backup {
  flex:1; height:44px; display:flex; align-items:center; justify-content:center; gap:7px;
  border-radius:var(--r); font-size:.84rem; font-weight:600;
  background:var(--card); color:var(--txt-2); border:1.5px solid var(--border);
  transition:background var(--t);
}
.btn-backup svg { width:15px;height:15px; }
.btn-backup.export { color:var(--accent);border-color:var(--accent-glow); }
.btn-backup.export:hover { background:var(--accent-dim); }

/* ═══════════════════════════════════════════
   TAG MANAGEMENT
═══════════════════════════════════════════ */
.tag-mgmt-list { display:flex;flex-direction:column;gap:7px;margin-bottom:14px; }
.tag-mgmt-item { display:flex;align-items:center;gap:10px;background:var(--card);border-radius:var(--r-sm);padding:9px 12px; }
.tag-mgmt-dot { width:10px;height:10px;border-radius:50%;flex-shrink:0; }
.tag-mgmt-label { flex:1;font-size:.88rem;font-weight:500; }
.tag-mgmt-actions { display:flex;gap:4px; }
.tag-mgmt-btn { width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);transition:background var(--t); }
.tag-mgmt-btn.edit   { color:var(--accent); }
.tag-mgmt-btn.delete { color:var(--danger); }
.tag-mgmt-btn:hover  { background:var(--surface); }
.tag-mgmt-btn svg { width:14px;height:14px; }
.add-tag-form { background:var(--card);border-radius:var(--r);padding:12px;display:flex;flex-direction:column;gap:10px; }
.add-tag-form h4 { font-size:.78rem;font-weight:700;color:var(--txt-2);text-transform:uppercase;letter-spacing:.05em; }
.add-tag-row { display:flex;gap:8px; }
.color-grid { display:flex;gap:6px;flex-wrap:wrap; }
.color-swatch { width:26px;height:26px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:border-color var(--t),transform var(--t); }
.color-swatch.selected { border-color:var(--txt);transform:scale(1.1); }

/* ═══════════════════════════════════════════
   MODAL
═══════════════════════════════════════════ */
.modal-overlay { position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.55);display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .22s var(--ease);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px); }
.modal-overlay.open { opacity:1;pointer-events:all; }
.modal-sheet {
  width: 100%;
  /*
   * SCROLL FORMULAIRE iOS PWA :
   * height fixe (pas max-height) = iOS sait que la zone est scrollable.
   * overflow-y: scroll forcé + -webkit-overflow-scrolling: touch = momentum.
   * overscroll-behavior: contain = évite de "tomber" sur le body quand
   * on atteint le bas du formulaire (sans ça iOS rebondit et le scroll s'arrête).
   */
  height: 90dvh;
  background: var(--surface);
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  padding-bottom: calc(24px + env(safe-area-inset-bottom, 0px));
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
  overscroll-behavior-y: contain;
  transform: translateY(100%);
  transition: transform .28s var(--ease);
}
.modal-overlay.open .modal-sheet { transform:translateY(0); }
.modal-handle { width:34px;height:4px;background:var(--border);border-radius:4px;margin:10px auto 0; }
.modal-header { display:flex;align-items:center;justify-content:space-between;padding:11px 13px 0; }
.modal-title { font-size:1.15rem;font-weight:800;letter-spacing:-.02em; }

/* ═══════════════════════════════════════════
   FORM — POINT 2: font-size 16px sur tous les
   inputs pour bloquer le zoom iOS/Safari
═══════════════════════════════════════════ */
/* padding-bottom généreux = le bouton "Enregistrer" remonte bien au-dessus de la nav */
.task-form { padding:12px 12px 100px;display:flex;flex-direction:column;gap:12px; }
.form-group { display:flex;flex-direction:column;gap:5px; }
.form-label { font-size:.7rem;font-weight:700;color:var(--txt-2);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:4px; }
.form-label svg { width:12px;height:12px; }
.required { color:var(--high); }

.form-input {
  width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--r-sm);
  color:var(--txt);
  font-size:16px;  /* ← POINT 2: MINIMUM 16px — empêche le zoom automatique iOS */
  padding:10px 12px;outline:none;
  transition:border-color var(--t),box-shadow var(--t);
  -webkit-appearance:none;appearance:none;
}
.form-input:focus { border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim); }
.form-input::placeholder { color:var(--txt-3); }
.form-input.invalid { border-color:var(--high); }
/* textarea: aussi 16px pour éviter le zoom */
.form-textarea { resize:none;line-height:1.5;font-size:16px; }
/* date et time inputs: color-scheme + 16px */
.form-input[type="date"],
.form-input[type="time"] { color-scheme:var(--input-scheme);font-size:16px; }

.form-error { font-size:.73rem;color:var(--high);min-height:14px; }
.form-row { display:grid;grid-template-columns:1fr 1fr;gap:9px; }
.priority-pills { display:flex;gap:7px; }
.priority-pill { flex:1;height:37px;display:flex;align-items:center;justify-content:center;gap:5px;border-radius:var(--r-sm);font-size:.9rem;font-weight:500;background:var(--card);color:var(--txt-2);border:1.5px solid transparent;transition:background var(--t),color var(--t),border-color var(--t); }
.priority-pill .pill-dot { width:6px;height:6px;border-radius:50%; }
.priority-pill[data-priority="low"]    .pill-dot { background:var(--low); }
.priority-pill[data-priority="medium"] .pill-dot { background:var(--medium); }
.priority-pill[data-priority="high"]   .pill-dot { background:var(--high); }
.priority-pill[data-priority="low"].selected    { background:var(--low-dim);   color:var(--low);   border-color:var(--low); }
.priority-pill[data-priority="medium"].selected { background:var(--medium-dim);color:var(--medium);border-color:var(--medium); }
.priority-pill[data-priority="high"].selected   { background:var(--high-dim);  color:var(--high);  border-color:var(--high); }
.reminder-pills,.recurrence-pills,.tag-pills { display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px; }
.reminder-pills::-webkit-scrollbar,.recurrence-pills::-webkit-scrollbar,.tag-pills::-webkit-scrollbar { display:none; }
.reminder-pill,.recurrence-pill { flex-shrink:0;height:32px;padding:0 11px;border-radius:var(--pill);font-size:.88rem;font-weight:500;background:var(--card);color:var(--txt-2);border:1.5px solid transparent;transition:background var(--t),color var(--t),border-color var(--t);white-space:nowrap; }
.reminder-pill.selected,.recurrence-pill.selected { background:var(--accent-dim);color:var(--accent);border-color:var(--accent); }
.tag-pill { flex-shrink:0;height:32px;padding:0 11px;border-radius:var(--pill);font-size:.88rem;font-weight:500;background:var(--card);color:var(--txt-2);border:1.5px solid transparent;transition:background var(--t),color var(--t),border-color var(--t);white-space:nowrap; }
.form-actions { display:flex;gap:9px;margin-top:2px; }

/* ═══════════════════════════════════════════
   VOICE OVERLAY
═══════════════════════════════════════════ */
.voice-overlay { position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease; }
.voice-overlay[hidden] { display:none; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.voice-box { display:flex;flex-direction:column;align-items:center;gap:14px;padding:32px 24px;text-align:center;max-width:300px; }
.voice-wave { display:flex;align-items:flex-end;gap:4px;height:40px; }
.voice-wave span { display:block;width:5px;background:var(--accent);border-radius:3px;animation:wave 1s ease infinite; }
.voice-wave span:nth-child(1){animation-delay:0s;   height:20%}
.voice-wave span:nth-child(2){animation-delay:.1s;  height:60%}
.voice-wave span:nth-child(3){animation-delay:.2s;  height:100%}
.voice-wave span:nth-child(4){animation-delay:.3s;  height:60%}
.voice-wave span:nth-child(5){animation-delay:.4s;  height:20%}
@keyframes wave { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(1.6)} }
.voice-hint    { font-size:.95rem;font-weight:600;color:var(--txt); }
.voice-preview { font-size:.85rem;color:var(--txt-2);line-height:1.5;min-height:40px;max-width:260px;font-style:italic; }

/* ═══════════════════════════════════════════
   NOTIF BANNER
═══════════════════════════════════════════ */
/* ═══════════════════════════════════════════
   CALENDAR SUB-TABS
═══════════════════════════════════════════ */
.cal-tabs {
  display: flex;
  background: var(--surface);
  border-bottom: 1px solid var(--border-soft);
  padding: 6px 12px;
  gap: 4px;
  position: sticky; top: 0; z-index: 10;
}
.cal-tab {
  flex: 1; height: 28px;
  border-radius: var(--r-sm);
  font-size: .66rem; font-weight: 600;
  color: var(--txt-2);
  background: transparent;
  transition: background var(--t), color var(--t);
  white-space: nowrap;
}
.cal-tab.active {
  background: var(--accent-dim);
  color: var(--accent);
}
.cal-tab:active { background: var(--accent-dim); color: var(--accent); }

/* ═══════════════════════════════════════════
   AGENDA GRID (Jour / 3 Jours)
═══════════════════════════════════════════ */
.agenda-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-soft);
}
.agenda-nav-title { font-size: .88rem; font-weight: 600; }

.agenda-container { overflow: hidden; }

/* Header des jours */
.agenda-header {
  display: flex;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  position: sticky; top: 0; z-index: 5;
}
.agenda-time-col-hdr { width: 48px; flex-shrink: 0; }
.agenda-day-headers {
  flex: 1; display: grid;
}
.agenda-day-header {
  display: flex; flex-direction: column; align-items: center; padding: 6px 0;
  border-left: 1px solid var(--border-soft);
}
.agenda-day-header.today { color: var(--accent); }
.agenda-dh-dow { font-size: .63rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--txt-3); }
.agenda-dh-num { font-size: 1.1rem; font-weight: 700; color: var(--txt); line-height: 1.2; }
.agenda-dh-num.today {
  background: var(--accent); color: #fff;
  width: 28px; height: 28px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .92rem;
}

/* Corps de la grille */
.agenda-body { overflow-x: hidden; }
.agenda-rows-wrap { position: relative; }

.agenda-row {
  display: flex; border-bottom: 1px solid var(--border-soft);
  min-height: 60px;
}
.agenda-time-label {
  width: 48px; flex-shrink: 0;
  font-size: .65rem; color: var(--txt-3);
  padding: 4px 6px 0 0; text-align: right;
  user-select: none;
}
.agenda-slots-row {
  flex: 1; display: grid;
  position: relative;
}
.agenda-slot {
  min-height: 60px;
  border-left: 1px solid var(--border-soft);
  cursor: pointer;
  position: relative;
  transition: background var(--t);
}
.agenda-slot:hover { background: var(--accent-dim); }
/* Pointillé à la demi-heure */
.agenda-slot::after {
  content: ''; position: absolute;
  top: 50%; left: 0; right: 0;
  border-top: 1px dashed var(--border-soft);
}

/* Blocs d'événements */
.agenda-events-layer {
  position: absolute; top: 0; left: 48px; right: 0;
  pointer-events: none;
  display: grid;
}
/* Événement agenda — thème adaptatif, priorité = bordure gauche */
.agenda-event {
  position: absolute;
  border-radius: 7px;
  padding: 5px 8px 5px 10px;
  font-size: .7rem; font-weight: 500;
  color: var(--txt);
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
  cursor: pointer;
  pointer-events: all;
  min-height: 26px;
  height: 56px;
  z-index: 1;
  background: var(--card);
  border: 1px solid var(--border-soft);
  border-left: 4px solid transparent;
  box-shadow: var(--shadow-card);
  transition: transform .12s ease, box-shadow .12s ease;
}
.agenda-event:active { transform: scale(.98); }

/* Priorité = couleur de bordure gauche + heure colorée */
.agenda-event.priority-high   { border-left-color: var(--high); }
.agenda-event.priority-medium { border-left-color: var(--medium); }
.agenda-event.priority-low    { border-left-color: var(--low); }
.agenda-event.completed { opacity: .4; }

/* Heure en couleur de priorité, titre en texte clair */
.aev-time {
  font-weight: 800;
  font-size: .72rem;
  margin-right: 3px;
}
.agenda-event.priority-high   .aev-time { color: var(--high); }
.agenda-event.priority-medium .aev-time { color: var(--medium); }
.agenda-event.priority-low    .aev-time { color: var(--low); }
.aev-title { color: var(--txt); font-size: .7rem; }

/* ═══════════════════════════════════════════
   YEAR VIEW
═══════════════════════════════════════════ */
.year-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; border-bottom: 1px solid var(--border-soft);
}
.year-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 12px;
}
.year-month {
  background: var(--card);
  border-radius: var(--r);
  padding: 8px 6px;
  box-shadow: var(--shadow-card);
}
.year-month-title {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--accent);
  text-align: center; margin-bottom: 5px;
}
.year-month-grid {
  display: grid; grid-template-columns: repeat(7,1fr); gap: 1px;
}
.year-dow {
  font-size: .55rem; color: var(--txt-3); text-align: center;
  font-weight: 700; padding-bottom: 2px;
}
.year-day {
  font-size: .63rem; color: var(--txt-2);
  text-align: center; padding: 2px 1px;
  border-radius: 3px;
  cursor: pointer; transition: background var(--t);
  line-height: 1.4;
}
.year-day:hover       { background: var(--accent-dim); color: var(--accent); }
.year-day.today       { background: var(--accent); color: #fff; border-radius: 50%; font-weight: 700; }
.year-day.has-tasks   { font-weight: 700; color: var(--txt); position: relative; }
.year-day.has-tasks::after {
  content: ''; position: absolute;
  bottom: 0; left: 50%; transform: translateX(-50%);
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--accent);
}

/* Bouton ajouter dans détail jour */
.btn-add-slot {
  display: block; width: 100%;
  padding: 8px 12px; margin-bottom: 10px;
  background: var(--accent-dim); color: var(--accent);
  border-radius: var(--r-sm); font-size: .82rem; font-weight: 600;
  border: 1px solid var(--accent-glow); text-align: left;
  transition: background var(--t);
}
.btn-add-slot:hover { background: rgba(124,111,255,.22); }

.notif-banner { background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:var(--r);padding:9px 11px;display:flex;align-items:center;gap:7px;margin-bottom:11px; }
.notif-banner-text { flex:1;font-size:.78rem;color:var(--txt-2);line-height:1.4; }
.notif-banner-text strong { color:var(--txt); }
.notif-icon { color:var(--accent);flex-shrink:0; }
.notif-icon svg { width:17px;height:17px; }

/* ═══════════════════════════════════════════
   TOAST
═══════════════════════════════════════════ */
.toast-container { position:fixed;left:13px;right:13px;z-index:400;display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none; }
.toast { display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--card-hover);color:var(--txt);border-radius:var(--r-sm);padding:10px 13px;font-size:.84rem;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,.4);border:1px solid var(--border);pointer-events:all;width:100%;animation:toastIn .22s var(--ease) both; }
.toast.hiding { animation:toastOut .18s var(--ease) both; }
@keyframes toastIn  { from{opacity:0;transform:translateY(10px) scale(.97)} to{opacity:1;transform:translateY(0) scale(1)} }
@keyframes toastOut { from{opacity:1;transform:translateY(0) scale(1)} to{opacity:0;transform:translateY(-6px) scale(.97)} }
.toast-undo { color:var(--accent);font-size:.83rem;font-weight:600;cursor:pointer;padding:0;white-space:nowrap;flex-shrink:0; }

/* ═══════════════════════════════════════════
   DRAG & DROP — événement agenda
═══════════════════════════════════════════ */
/* Carte "attrapée" pendant le drag — reste dans le flow, indique le slot */
.event-dragging {
  opacity: .25 !important;
  pointer-events: none;
}

/* Classe .is-dragging appliquée par setupAgendaDragDrop */
.is-dragging {
  transform: scale(1.05);
  box-shadow: 0 10px 20px rgba(0,0,0,.35), 0 0 0 2px var(--accent-glow) !important;
  z-index: 100;
  position: relative;
  opacity: .85;
  transition: transform .15s ease, box-shadow .15s ease !important;
}

.drag-ghost {
  position: fixed;
  z-index: 2000;
  pointer-events: none;
  border-radius: 7px;
  padding: 5px 10px;
  font-size: .72rem; font-weight: 700;
  color: #fff;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 220px;
  box-shadow: 0 10px 32px rgba(0,0,0,.55), 0 0 0 2px rgba(255,255,255,.1);
  transform: scale(1.05) rotate(-1deg);
  transition: none !important;
  /* Empêche la sélection de texte pendant le drag */
  user-select: none; -webkit-user-select: none;
}

/* ═══════════════════════════════════════════
   DONUT CHART — premium
═══════════════════════════════════════════ */
.donut-wrap {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 8px 0 4px;
}

.donut-svg {
  flex-shrink: 0;
  filter: drop-shadow(0 4px 12px var(--accent-glow));
}

.donut-legend {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dl-item {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: .82rem;
  padding: 4px 0;
  border-bottom: 1px solid var(--border-soft);
}
.dl-item:last-child { border-bottom: none; }

.dl-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 6px currentColor;
}

.dl-label {
  flex: 1;
  color: var(--txt-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}

.dl-val {
  font-weight: 900;
  font-size: .9rem;
  color: var(--txt);
  min-width: 24px;
  text-align: right;
}

/* ═══════════════════════════════════════════
   MODALE SÉRIE — remplace confirm() natif
═══════════════════════════════════════════ */
.series-modal-overlay {
  position: fixed; inset: 0; z-index: 600;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: flex-end;
  opacity: 0; transition: opacity .2s ease;
}
.series-modal-overlay.open { opacity: 1; }

.series-modal {
  width: 100%;
  background: var(--surface);
  border-radius: 24px 24px 0 0;
  padding: 12px 18px calc(20px + env(safe-area-inset-bottom, 0px));
  box-shadow: 0 -6px 40px rgba(0,0,0,.55), 0 0 0 1px var(--border-soft);
  border-top: 1px solid var(--border-soft);
  transform: translateY(100%);
  transition: transform .28s cubic-bezier(.25,.46,.45,.94);
}
.series-modal-overlay.open .series-modal { transform: translateY(0); }

.series-modal-handle {
  width: 36px; height: 4px; background: var(--border);
  border-radius: 4px; margin: 0 auto 16px;
}
.series-modal-icon { font-size: 1.8rem; text-align: center; margin-bottom: 6px; line-height: 1; }
.series-modal-title {
  font-size: 1.05rem; font-weight: 800; text-align: center; margin-bottom: 6px;
}
.series-modal-desc {
  font-size: .84rem; color: var(--txt-2); text-align: center;
  line-height: 1.5; margin-bottom: 20px;
}
.series-modal-actions { display: flex; flex-direction: column; gap: 9px; }

/* Bouton principal : Toute la série */
.smb-series {
  height: 50px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff; border-radius: var(--r);
  font-size: .97rem; font-weight: 700;
  box-shadow: 0 4px 18px var(--accent-glow);
  transition: opacity .15s, transform .15s;
}
.smb-series:active { opacity: .88; transform: scale(.98); }

/* Bouton secondaire : Cette occurrence */
.smb-single {
  height: 50px;
  background: var(--card); color: var(--txt);
  border-radius: var(--r); font-size: .95rem; font-weight: 600;
  border: 1.5px solid var(--border);
  transition: background .15s;
}
.smb-single:hover { background: var(--card-hover); }

/* Bouton neutre : Annuler */
.smb-cancel {
  height: 44px; color: var(--txt-3);
  font-size: .88rem; font-weight: 500;
  transition: color .15s;
}
.smb-cancel:hover { color: var(--txt-2); }

/* ═══════════════════════════════════════════
   RÉGLAGES
═══════════════════════════════════════════ */
.settings-card {
  background:var(--card);border-radius:var(--r-lg);padding:20px;margin-bottom:14px;
}
.settings-card-title {
  font-size:1rem;font-weight:700;color:var(--txt);margin-bottom:10px;
}
.settings-card-desc {
  font-size:.85rem;color:var(--txt-2);line-height:1.55;margin-bottom:16px;
}
.btn-setting-push {
  width:100%;height:48px;
  background:var(--accent);color:#fff;
  border-radius:var(--r);font-size:1rem;font-weight:600;
  box-shadow:0 4px 14px var(--accent-glow);
  transition:opacity var(--t),transform var(--t);
}
.btn-setting-push:active { opacity:.88;transform:scale(.98); }
.settings-push-status {
  margin-top:12px;font-size:.82rem;color:var(--txt-2);
  line-height:1.4;text-align:center;
}
