/**
 * Outils EPS — styles partagés
 * Pour ajouter une page d’outil : liez cette feuille avec href="../style.css"
 * et réutilisez les classes .page-outil, .card, .btn, etc.
 */

:root {
  --bg-base: #e4eaf4;
  --bg-bloom-1: rgba(99, 102, 241, 0.16);
  --bg-bloom-2: rgba(14, 165, 233, 0.12);
  --bg-bloom-3: rgba(45, 212, 191, 0.1);
  --surface: #ffffff;
  --text: #0f172a;
  --text-muted: #64748b;
  --accent: #0d9488;
  --accent-2: #0891b2;
  --accent-deep: #0f7668;
  --accent-hover: #0f7668;
  --accent-soft: #ecfdf5;
  --accent-glow: rgba(13, 148, 136, 0.2);
  --border: rgba(148, 163, 184, 0.4);
  --success: #047857;
  --success-bg: #ecfdf5;
  --danger: #be123c;
  --danger-bg: #fff1f2;
  --warning: #b45309;
  --radius: 18px;
  --radius-sm: 12px;
  --radius-pill: 999px;
  --shadow: 0 2px 4px rgba(15, 23, 42, 0.04), 0 12px 32px -8px rgba(13, 148, 136, 0.12);
  --shadow-hover: 0 8px 24px -6px rgba(13, 148, 136, 0.22), 0 16px 40px -16px rgba(15, 23, 42, 0.1);
  --font: ui-sans-serif, "Segoe UI Variable", "Segoe UI", system-ui, -apple-system, sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.55;
  color: var(--text);
  background-color: var(--bg-base);
  background-image: radial-gradient(
      1000px 520px at 8% -8%,
      var(--bg-bloom-1),
      transparent 58%
    ),
    radial-gradient(820px 480px at 100% 0%, var(--bg-bloom-2), transparent 52%),
    radial-gradient(700px 420px at 42% 108%, var(--bg-bloom-3), transparent 48%);
  background-attachment: fixed;
  min-height: 100vh;
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

.app--tool {
  min-height: 100dvh;
}

.app--home {
  min-height: 100dvh;
}

.home-shell {
  min-height: 100dvh;
}

.home-shell__main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 100dvh;
  flex: 1 1 auto;
}

/* Sidebar — tiroir mobile */
.site-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 300;
  width: min(20rem, 88vw);
  max-width: 100%;
  transform: translateX(-105%);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

.site-sidebar.is-open {
  transform: translateX(0);
  pointer-events: auto;
}

.site-sidebar__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--surface);
  box-shadow: 8px 0 32px rgba(15, 23, 42, 0.18);
  overflow: hidden;
}

.site-sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: max(0.85rem, env(safe-area-inset-top)) 0.85rem 0.65rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  flex-shrink: 0;
}

.site-sidebar__title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--accent-deep);
}

.site-sidebar__close {
  width: 2.25rem;
  height: 2.25rem;
  border: none;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  color: var(--text-muted);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
}

.site-sidebar-backdrop {
  position: fixed;
  inset: 0;
  z-index: 299;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(3px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.site-sidebar-backdrop.is-visible {
  opacity: 1;
  pointer-events: auto;
}

body.site-sidebar-open {
  overflow: hidden;
}

.site-menu__nav {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 0.5rem 0.65rem max(0.85rem, env(safe-area-inset-bottom));
  -webkit-overflow-scrolling: touch;
}
.site-header {
  background: linear-gradient(125deg, #0f7668 0%, #0d9488 42%, #0891b2 100%);
  color: #fff;
  padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) 2.25rem
    max(1.25rem, env(safe-area-inset-left));
  text-align: center;
  border-bottom-left-radius: 28px;
  border-bottom-right-radius: 28px;
  box-shadow: 0 20px 50px -18px rgba(13, 148, 136, 0.45);
  position: relative;
  overflow: hidden;
}

.site-header::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(600px 200px at 50% 120%, rgba(255, 255, 255, 0.12), transparent 65%);
  pointer-events: none;
}

.site-header__inner {
  position: relative;
  z-index: 1;
  margin-top: 0.5rem;
}

.site-header__bar {
  position: absolute;
  top: max(0.85rem, env(safe-area-inset-top));
  left: max(1rem, env(safe-area-inset-left));
  z-index: 2;
  display: flex;
  justify-content: flex-start;
  width: auto;
  margin: 0;
}

.site-header__menu-btn {
  min-height: 2.55rem;
  padding: 0.45rem 0.85rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.45);
  color: #fff;
  font: inherit;
  font-size: 0.88rem;
  font-weight: 800;
  box-shadow: 0 4px 16px rgba(15, 23, 42, 0.12);
  transition: background 0.2s, transform 0.15s;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.site-header__menu-btn:hover {
  background: rgba(255, 255, 255, 0.28);
  transform: translateY(-1px);
}

.site-header__menu-btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

.site-header__menu-icon {
  width: 1.15rem;
  height: 1.15rem;
  display: block;
  flex-shrink: 0;
}

.site-menu__group + .site-menu__group {
  margin-top: 0.65rem;
  padding-top: 0.65rem;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.site-menu__group-title {
  margin: 0 0 0.35rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.site-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.site-menu__link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.65rem 0.7rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: inherit;
  background: transparent;
  border: none;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: background 0.15s ease;
}

.site-menu__link:hover,
.site-menu__link:focus-visible {
  background: rgba(13, 148, 136, 0.08);
  outline: none;
}

.site-menu__link-icon {
  width: 2.25rem;
  height: 2.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.65rem;
  background: linear-gradient(160deg, #fff, var(--accent-soft));
  border: 1px solid rgba(13, 148, 136, 0.15);
  font-size: 1.05rem;
  flex-shrink: 0;
}

.site-menu__link-text {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}

.site-menu__link-text strong {
  font-size: 0.95rem;
  line-height: 1.25;
}

.site-menu__link-text small {
  font-size: 0.78rem;
  color: var(--text-muted);
  line-height: 1.3;
}

.home-shell__main .site-header__inner {
  margin-top: 2.75rem;
}

.favoris-dialog {
  width: min(26rem, calc(100vw - 2rem));
  max-height: min(85dvh, 34rem);
  overflow: auto;
  border: none;
  padding: 0;
  margin: auto;
}

.favoris-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(4px);
}

.favoris-dialog__form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem;
}

.favoris-dialog__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.favoris-dialog__title {
  margin: 0;
  font-size: 1.15rem;
}

.favoris-dialog__close {
  width: 2.25rem;
  height: 2.25rem;
  border: none;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  color: var(--text-muted);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
}

.favoris-dialog__intro {
  margin: 0;
}

.favoris-dialog__list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  max-height: min(50dvh, 22rem);
  overflow: auto;
  padding-right: 0.15rem;
}

.favoris-dialog__section-title {
  margin: 0 0 0.35rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.favoris-dialog__tools {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.favoris-dialog__tool {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.65rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(248, 250, 252, 0.9);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}

.favoris-dialog__tool:hover {
  border-color: rgba(13, 148, 136, 0.25);
}

.favoris-dialog__tool.is-fav {
  border-color: rgba(202, 138, 4, 0.35);
  background: rgba(254, 243, 199, 0.35);
}

.favoris-dialog__tool input {
  width: 1.1rem;
  height: 1.1rem;
  accent-color: #ca8a04;
  flex-shrink: 0;
}

.favoris-dialog__tool-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
}

.favoris-dialog__tool-text {
  font-weight: 700;
  font-size: 0.92rem;
}

.favoris-dialog__done {
  width: 100%;
}

.site-header__toolbar-btn {
  min-height: 2.55rem;
  padding: 0.45rem 0.55rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.45);
  color: #fff;
  text-decoration: none;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  box-shadow: 0 4px 16px rgba(15, 23, 42, 0.12);
  transition: background 0.2s, transform 0.15s;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.site-header__toolbar-btn:hover {
  background: rgba(255, 255, 255, 0.28);
  transform: translateY(-1px);
}

.site-header__toolbar-btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

.site-header__toolbar-btn .btn-icon-emoji {
  font-size: 1.1rem;
  line-height: 1;
}

.info-icon {
  width: 1.35rem;
  height: 1.35rem;
  display: block;
  flex-shrink: 0;
  color: inherit;
}

.info-icon circle,
.info-icon path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
}

.info-icon circle[fill="currentColor"] {
  fill: currentColor;
  stroke: none;
}

.info-dialog,
.share-dialog {
  width: min(28rem, calc(100vw - 2rem));
  max-height: min(85dvh, 32rem);
  overflow: auto;
  border: none;
  padding: 0;
  margin: auto;
}

.info-dialog[open],
.share-dialog[open] {
  position: fixed;
  inset: 0;
  margin: auto;
}

.share-dialog--dual {
  max-height: min(92dvh, 44rem);
}

.info-dialog::backdrop,
.share-dialog::backdrop {
  background: rgba(15, 23, 42, 0.55);
}

.info-dialog__form,
.share-dialog__form {
  padding: 0;
  position: relative;
}

.info-dialog__header {
  position: relative;
  padding: 1.15rem 3.25rem 0.5rem 1.35rem;
}

.info-dialog__title,
.share-dialog__title {
  margin: 0;
  font-size: 1.2rem;
  color: var(--accent-deep);
  line-height: 1.25;
  padding-right: 0.25rem;
}

.share-dialog__header {
  position: relative;
  padding: 1.15rem 3.25rem 0.35rem 1.35rem;
}

.share-dialog__body {
  padding: 0 1.35rem 1.35rem;
}

.share-dialog__form {
  padding: 0;
}

.info-dialog__dismiss,
.share-dialog__dismiss {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 2.25rem;
  height: 2.25rem;
  margin: 0;
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #f8fafc;
  color: #64748b;
  font-size: 1.45rem;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.15s ease,
    color 0.15s ease,
    border-color 0.15s ease;
}

.info-dialog__dismiss:hover,
.share-dialog__dismiss:hover {
  background: #fff;
  border-color: #99f6e4;
  color: #0f766e;
}

.info-dialog__dismiss:focus-visible,
.share-dialog__dismiss:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.info-dialog__body {
  padding: 0 1.35rem;
}

.info-dialog__footer {
  padding: 0.75rem 1.35rem 1.35rem;
}

.info-dialog__section {
  margin-bottom: 1rem;
}

.info-dialog__section h3 {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  color: var(--accent-deep);
}

.info-dialog__section p {
  margin: 0 0 0.5rem;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--text);
}

.info-dialog__list {
  margin: 0.35rem 0 0;
  padding-left: 1.15rem;
  font-size: 0.9rem;
  line-height: 1.45;
}

.info-dialog__list li + li {
  margin-top: 0.35rem;
}

.info-dialog__link {
  color: var(--accent);
  font-weight: 600;
}

.info-dialog__close {
  width: 100%;
  margin-top: 0.5rem;
}

.share-dialog__intro {
  margin: 0 0 1rem;
  color: var(--text-muted);
  font-size: 0.9rem;
  line-height: 1.45;
}

.share-dialog__block {
  margin: 0;
}

.share-dialog__block + .share-dialog__sep,
.share-dialog__sep + .share-dialog__block {
  margin-top: 0;
}

.share-dialog__block-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.65rem;
  margin-bottom: 0.35rem;
}

.share-dialog__block-title {
  margin: 0;
  font-size: 1rem;
  color: var(--accent-deep);
  line-height: 1.25;
}

.share-dialog__badge {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #0f766e;
  background: rgba(13, 148, 136, 0.12);
  border: 1px solid rgba(13, 148, 136, 0.28);
}

.share-dialog__badge--eleve {
  color: #1d4ed8;
  background: rgba(37, 99, 235, 0.1);
  border-color: rgba(37, 99, 235, 0.28);
}

.share-dialog__sep {
  margin: 1.1rem 0;
  border: none;
  border-top: 2px dashed rgba(13, 148, 136, 0.22);
}

.share-dialog__hint {
  margin: 0 0 0.65rem;
  color: var(--text-muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.share-dialog__qr-wrap {
  display: grid;
  place-items: center;
  margin: 0 0 0.65rem;
  padding: 0.65rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.18);
}

.share-dialog__qr-wrap--eleves {
  background: rgba(37, 99, 235, 0.06);
  border-color: rgba(37, 99, 235, 0.22);
}

.share-dialog--dual .share-dialog__qr {
  width: min(9.5rem, 42vw);
  height: min(9.5rem, 42vw);
}

.share-dialog__qr {
  width: min(13rem, 70vw);
  height: min(13rem, 70vw);
  border-radius: 10px;
  background: #fff;
}

.share-dialog__link {
  width: 100%;
  margin-bottom: 0.45rem;
  font-size: 0.85rem;
}

.share-dialog__block .btn--sm {
  width: 100%;
  margin-bottom: 0.45rem;
}

.share-dialog__block .btn--sm:last-child {
  margin-bottom: 0.15rem;
}

.share-dialog__msg {
  margin: 0.35rem 0 0;
  text-align: center;
  font-weight: 700;
}

.share-dialog__actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.share-dialog__actions--top {
  margin-top: 0;
  margin-bottom: 1rem;
}

.share-dialog__actions--bottom {
  margin-top: 0.5rem;
}

@media (max-width: 460px) {
  .search-wrap__fav-label {
    display: none;
  }

  .search-wrap__fav-btn {
    min-width: 3rem;
    padding: 0.45rem;
  }
}

.site-header h1,
.site-header p {
  position: relative;
  z-index: 1;
}

.site-header h1 {
  margin: 0 0 0.4rem;
  font-size: clamp(1.45rem, 4.5vw, 1.9rem);
  font-weight: 800;
  letter-spacing: -0.02em;
}

.site-header p {
  margin: 0;
  opacity: 0.94;
  font-size: 1rem;
  max-width: 26rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.45;
}

.search-wrap {
  width: min(95%, 42rem);
  max-width: none;
  margin: -1.25rem auto 0;
  padding: 0 max(1rem, env(safe-area-inset-right)) 0 max(1rem, env(safe-area-inset-left));
  position: relative;
  z-index: 1;
}

.search-wrap__row {
  display: flex;
  align-items: stretch;
  gap: 0.5rem;
}

.search-wrap__fav-btn {
  flex-shrink: 0;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.05rem;
  min-width: 3.75rem;
  padding: 0.45rem 0.55rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(255, 255, 255, 0.5);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.08);
  color: var(--text-muted);
  font: inherit;
  font-size: 0.68rem;
  font-weight: 800;
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s, box-shadow 0.2s;
  -webkit-tap-highlight-color: transparent;
}

.search-wrap__fav-btn:hover,
.search-wrap__fav-btn:focus-visible {
  outline: none;
  border-color: rgba(202, 138, 4, 0.45);
  color: #ca8a04;
}

.search-wrap__fav-btn--active {
  border-color: rgba(202, 138, 4, 0.5);
  color: #ca8a04;
  box-shadow: 0 0 0 3px rgba(254, 243, 199, 0.85), 0 4px 24px rgba(15, 23, 42, 0.08);
}

.search-wrap__fav-icon {
  font-size: 1.15rem;
  line-height: 1;
  color: #ca8a04;
}

.search-wrap__fav-label {
  line-height: 1.1;
}

#search-outils {
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
  padding: 0.9rem 1rem 0.9rem 2.85rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: var(--radius-pill);
  font-size: 1rem;
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.08);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 1rem 50%;
  transition: box-shadow 0.2s, border-color 0.2s;
}

#search-outils:focus {
  outline: none;
  border-color: rgba(13, 148, 136, 0.55);
  box-shadow: 0 0 0 3px var(--accent-glow), 0 8px 28px rgba(15, 23, 42, 0.1);
}

.search-wrap label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

main.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem max(1rem, env(safe-area-inset-left)) 1.5rem max(1rem, env(safe-area-inset-right));
  flex: 1 0 auto;
}

.site-footer {
  width: min(100%, 42rem);
  margin: auto auto 0;
  padding: 0 max(1rem, env(safe-area-inset-right)) max(2.25rem, env(safe-area-inset-bottom))
    max(1rem, env(safe-area-inset-left));
  text-align: center;
  color: var(--text-muted);
}

.site-footer p {
  margin: 0;
  padding: 1rem 1.15rem;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(148, 163, 184, 0.22);
  font-size: 0.9rem;
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.55rem 0.9rem;
}

.site-footer strong {
  color: var(--accent-deep);
}

.site-footer a {
  color: var(--accent-deep);
  font-weight: 800;
  text-decoration: none;
}

.site-footer a:hover {
  text-decoration: underline;
}

.site-footer__text {
  flex-basis: 100%;
  margin-bottom: 0.15rem;
}

.site-footer--compact p {
  justify-content: center;
}

.site-footer--compact .site-footer__text {
  margin-bottom: 0;
  flex-basis: auto;
}

.site-footer--compact a:not([data-pwa-force-update]) {
  display: none;
}

.site-footer__version {
  flex-basis: 100%;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-muted);
  opacity: 0.9;
}

.site-footer__link-btn {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--accent-deep);
  font-weight: 800;
  cursor: pointer;
  text-decoration: none;
}

.site-footer__link-btn:hover {
  text-decoration: underline;
}

.site-footer__link-btn:disabled {
  opacity: 0.65;
  cursor: wait;
  text-decoration: none;
}

.page-outil--faq {
  max-width: min(56rem, 100%);
}

.faq-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.55rem;
}

.faq-filter.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.faq-section-title {
  margin: 0 0 0.65rem;
  font-size: 1.05rem;
  font-weight: 850;
  line-height: 1.35;
}

.faq-priority {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 13.5rem), 1fr));
  gap: 0.5rem;
}

.faq-priority-card {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.72rem 0.85rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(255, 255, 255, 0.82);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 650;
  line-height: 1.35;
  color: var(--text);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  -webkit-tap-highlight-color: transparent;
}

.faq-priority-card:hover {
  border-color: rgba(13, 148, 136, 0.45);
  background: #fff;
}

.faq-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 0.65rem;
}

.faq-empty-hint {
  margin: 0.35rem 0 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.faq-item {
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 0.8rem;
  background: rgba(255, 255, 255, 0.78);
  overflow: hidden;
}

.faq-item summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  gap: 0.55rem;
  align-items: center;
  padding: 0.72rem 0.85rem;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item__cat {
  flex-shrink: 0;
  font-size: 0.73rem;
  font-weight: 800;
  color: #0f766e;
  background: rgba(13, 148, 136, 0.12);
  border: 1px solid rgba(13, 148, 136, 0.28);
  border-radius: 999px;
  padding: 0.14rem 0.42rem;
}

.faq-item__q {
  font-weight: 700;
  line-height: 1.35;
}

.faq-item__a {
  padding: 0 0.85rem 0.85rem;
  color: var(--text);
}

.faq-item__a-lead {
  margin: 0 0 0.55rem;
  font-weight: 650;
  line-height: 1.45;
}

.faq-item__a-p {
  margin: 0 0 0.45rem;
  line-height: 1.45;
  white-space: pre-line;
}

.faq-item__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.65rem;
}

.faq-item__more {
  margin-top: 0.65rem;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
  padding-top: 0.55rem;
}

.faq-item__more summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--accent-deep);
  padding: 0.25rem 0;
  list-style: none;
}

.faq-item__more summary::-webkit-details-marker {
  display: none;
}

.faq-item__more-body {
  margin-top: 0.45rem;
  color: var(--text-muted);
  font-size: 0.92rem;
}

.faq-item__more-p {
  margin: 0 0 0.4rem;
  line-height: 1.45;
  white-space: pre-line;
}

.page-outil--legal {
  max-width: min(56rem, 100%);
}

.page-outil--legal .page-outil__subtitle {
  margin: 0.35rem 0 0;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--text-muted);
}

.legal-section__title {
  margin: 0 0 0.65rem;
  font-size: 1.05rem;
  font-weight: 850;
  line-height: 1.35;
  color: var(--text);
}

.legal-section__subtitle {
  margin: 0.85rem 0 0.4rem;
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.35;
  color: var(--accent-deep);
}

.legal-section__subtitle:first-of-type {
  margin-top: 0.35rem;
}

.legal-list {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.45rem;
  line-height: 1.5;
}

.legal-list li::marker {
  color: var(--accent-deep);
}

.legal-toc__list {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.35rem;
}

.legal-toc__list a {
  color: var(--accent-deep);
  font-weight: 650;
  text-decoration: none;
}

.legal-toc__list a:hover {
  text-decoration: underline;
}

.legal-block + .legal-block {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
}

.legal-table-wrap {
  overflow-x: auto;
  margin: 0.65rem 0;
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
  line-height: 1.45;
}

.legal-table th,
.legal-table td {
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(148, 163, 184, 0.3);
  text-align: left;
  vertical-align: top;
}

.legal-table th {
  background: rgba(13, 148, 136, 0.08);
  font-weight: 800;
}

.legal-updated {
  margin: 0.75rem 0 0;
}

#outils-count {
  color: var(--text-muted);
  font-size: 0.9rem;
  margin: 0 auto 1rem;
  max-width: 42rem;
  width: min(100%, 42rem);
  text-align: center;
  box-sizing: border-box;
}

/* Liste d’outils (accueil) — favoris en tête via script */
.tools-list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  max-width: 42rem;
  width: min(100%, 42rem);
  box-sizing: border-box;
}

.tools-list--icons {
  flex-flow: row wrap;
  align-items: stretch;
}

.tools-list__section {
  width: 100%;
  margin: 1.2rem 0 0.25rem;
  padding: 0 0.15rem;
}

.tools-list__section:first-child {
  margin-top: 0;
}

.tools-list__section-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.tools-list__section-actions {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
  margin-left: auto;
}

.tools-list__share-eleves-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 2rem;
  padding: 0.28rem 0.7rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 750;
  line-height: 1.2;
  white-space: nowrap;
}

.tools-list__share-eleves-icon {
  font-size: 0.95rem;
  line-height: 1;
}

@media (max-width: 520px) {
  .tools-list__share-eleves-label {
    display: none;
  }
}

.share-dialog--focus-eleves .share-dialog__block--eleves {
  scroll-margin-top: 0.5rem;
}

.tools-list__section-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 850;
  letter-spacing: -0.01em;
  color: var(--text);
}

.tools-list__section-desc {
  margin: 0.1rem 0 0;
  font-size: 0.84rem;
  color: var(--text-muted);
}

.tools-list__category {
  width: 100%;
  margin: 0.9rem 0 0.1rem;
  padding: 0 0.15rem;
}

.tools-list__category-title {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 850;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--accent);
}

.tools-list--icons .tools-list__category,
.tools-list--icons .tools-list__section,
.tools-list--icons .tools-list__more {
  flex: 0 0 100%;
  width: 100%;
}

.tools-view-toggle {
  display: inline-flex;
  flex-shrink: 0;
  gap: 0.2rem;
  padding: 0.16rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
}

.tools-view-toggle__btn {
  width: 2rem;
  height: 1.8rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--text-muted);
  font: inherit;
  font-size: 1rem;
  font-weight: 850;
  line-height: 1;
  cursor: pointer;
}

.tools-view-toggle__btn.is-active {
  background: var(--accent);
  color: #fff;
}

.tools-view-toggle__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.tools-list__more {
  width: 100%;
  display: flex;
  justify-content: center;
  margin: 0.15rem 0 0.55rem;
}

.tools-list__more-btn {
  width: min(100%, 16rem);
}

.tool-list__item {
  display: flex;
  align-items: stretch;
  background: var(--surface);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255, 255, 255, 0.85);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.tools-list--icons .tool-list__item {
  position: relative;
  width: calc(25% - 0.42rem);
  min-height: 7.4rem;
  flex-direction: column;
  align-items: stretch;
  border-radius: 1.25rem;
  overflow: visible;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.1);
}

.tool-list__item--fav {
  border-color: rgba(13, 148, 136, 0.35);
  box-shadow: 0 2px 12px rgba(13, 148, 136, 0.12);
}

.tool-list__item--fav::before {
  content: "";
  width: 4px;
  flex-shrink: 0;
  background: linear-gradient(180deg, var(--accent-deep), var(--accent-2));
}

.tools-list--icons .tool-list__item--fav::before {
  display: none;
}

.tool-list__link {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.85rem 0.5rem 0.85rem 1rem;
  text-decoration: none;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background 0.15s ease;
}

.tools-list--icons .tool-list__item .tool-list__link {
  min-height: 6.9rem;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.75rem 0.5rem 0.95rem;
  text-align: center;
}

.tool-list__link:hover {
  background: rgba(13, 148, 136, 0.06);
}

.tool-list__link:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.tool-list__icon {
  font-size: 1.65rem;
  line-height: 1.2;
  flex-shrink: 0;
}

.tools-list--icons .tool-list__item .tool-list__icon {
  width: 3.15rem;
  height: 3.15rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 1rem;
  background: linear-gradient(160deg, #ffffff, var(--accent-soft));
  box-shadow: inset 0 0 0 1px rgba(13, 148, 136, 0.14);
  font-size: 1.8rem;
}

.tool-list__main {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}

.tools-list--icons .tool-list__item .tool-list__main {
  align-items: center;
}

.tool-list__title {
  font-weight: 700;
  font-size: 1.02rem;
  line-height: 1.25;
}

.tool-list__icon-wrap {
  position: relative;
  flex-shrink: 0;
  display: inline-flex;
}

.tool-list__badge,
.tool-beta-badge {
  display: inline-block;
  padding: 0.12rem 0.42rem;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 55%, var(--accent-2) 130%);
  border-radius: 999px;
  border: 1.5px solid rgba(255, 255, 255, 0.95);
  box-shadow: 0 1px 4px rgba(13, 148, 136, 0.28);
  line-height: 1.15;
  vertical-align: middle;
}

.tool-list__badge {
  position: absolute;
  top: -0.2rem;
  right: -0.45rem;
  z-index: 1;
  pointer-events: none;
}

.tool-beta-badge {
  margin-left: 0.35rem;
  font-size: 0.55rem;
  transform: translateY(-0.15em);
}

.tools-list--icons .tool-list__item .tool-list__badge {
  top: -0.15rem;
  left: -0.2rem;
  right: auto;
  font-size: 0.5rem;
  padding: 0.08rem 0.3rem;
}

.tools-list--icons .tool-list__item .tool-list__title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: 0.82rem;
  line-height: 1.15;
}

.tool-list__meta {
  font-size: 0.86rem;
  color: var(--text-muted);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tools-list--icons .tool-list__item .tool-list__meta {
  display: none;
}

.tool-list__fav-star {
  position: absolute;
  top: -0.35rem;
  right: -0.35rem;
  z-index: 2;
  width: 1.35rem;
  height: 1.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #fff;
  border: 1.5px solid rgba(202, 138, 4, 0.45);
  color: #ca8a04;
  font-size: 0.72rem;
  line-height: 1;
  box-shadow: 0 2px 8px rgba(202, 138, 4, 0.25);
  pointer-events: none;
}

.tools-list--icons .tool-list__item .tool-list__fav-star {
  top: -0.2rem;
  right: -0.2rem;
  left: auto;
}

.tool-list__fav {
  display: none;
}

.tools-list--icons .tool-list__item .tool-list__fav {
  position: absolute;
  top: 0.35rem;
  right: auto;
  left: calc(50% + 0.55rem);
  width: 2rem;
  min-width: 2rem;
  min-height: 2rem;
  height: 2rem;
  border: 1px solid rgba(148, 163, 184, 0.3);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12);
}

.tool-list__fav:hover {
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.tool-list__fav:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  z-index: 1;
}

.tool-list__fav--on {
  color: #ca8a04;
  background: rgba(254, 243, 199, 0.5);
}

.tool-list__fav--on:hover {
  color: #a16207;
  background: rgba(254, 243, 199, 0.85);
}

.tool-list__fav-icon {
  font-size: 1.35rem;
  line-height: 1;
}

.tools-list--icons .tool-list__item .tool-list__fav-icon {
  font-size: 1rem;
}

@media (max-width: 899px) {
  .tools-list--icons .tool-list__item {
    width: calc(33.333% - 0.37rem);
  }
}

@media (max-width: 640px) {
  .tools-list--icons .tool-list__item {
    width: calc(50% - 0.28rem);
  }
}

/* Accueil guidé — page de décision (4 zones) */
.home-mode-bar {
  width: min(95%, 42rem);
  max-width: none;
  margin: -0.85rem auto 0;
  padding: 0 max(1rem, env(safe-area-inset-right)) 0 max(1rem, env(safe-area-inset-left));
  position: relative;
  z-index: 2;
}

.home-mode-toggle {
  display: flex;
  gap: 0.25rem;
  padding: 0.2rem;
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.08);
}

.home-mode-toggle__btn {
  flex: 1 1 50%;
  min-height: 2.5rem;
  padding: 0.45rem 0.65rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--text-muted);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1.2;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
  -webkit-tap-highlight-color: transparent;
}

.home-mode-toggle__btn.is-active {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 2px 10px rgba(13, 148, 136, 0.28);
}

.home-mode-toggle__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.home-trust-bar {
  width: min(95%, 42rem);
  max-width: none;
  margin: 0.55rem auto 0;
  padding: 0 max(1rem, env(safe-area-inset-right)) 0 max(1rem, env(safe-area-inset-left));
}

.home-trust-bar .home-trust {
  margin: 0;
}

.home-guided.container {
  flex: 1 1 auto;
  width: min(95%, 42rem);
  max-width: none;
  margin: 0 auto;
  padding: 0.85rem max(1rem, env(safe-area-inset-right)) 1.5rem max(1rem, env(safe-area-inset-left));
}

.home-guided__intro {
  margin: 0 0 0.85rem;
  padding: 0 0.1rem;
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--text-muted);
}

.home-guided__content {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.home-icon {
  flex-shrink: 0;
  line-height: 1;
}

.home-icon--zone {
  font-size: 1rem;
  vertical-align: middle;
}

.home-icon--entree {
  width: 2.85rem;
  height: 2.85rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.95rem;
  background: linear-gradient(160deg, #ffffff, var(--accent-soft));
  box-shadow: inset 0 0 0 1px rgba(13, 148, 136, 0.16);
  font-size: 1.55rem;
}

.home-icon--rapide {
  width: 2.35rem;
  height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.75rem;
  background: linear-gradient(160deg, #ffffff, var(--accent-soft));
  box-shadow: inset 0 0 0 1px rgba(13, 148, 136, 0.14);
  font-size: 1.25rem;
}

.home-icon--action {
  font-size: 1.05rem;
}

.home-icon--flow {
  font-size: 0.95rem;
}

.home-icon--trust {
  font-size: 0.9rem;
}

.home-zone__title {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  margin: 0 0 0.65rem;
  padding: 0 0.1rem;
  font-size: 0.78rem;
  font-weight: 850;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--accent-deep);
}

.home-zone__title--qr {
  font-size: 0.95rem;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--text);
}

.home-entrees {
  display: grid;
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 0.65rem;
}

.home-entree {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1rem 1rem 0.95rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(13, 148, 136, 0.22);
  background: var(--surface);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.home-entree::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent-deep), var(--accent-2));
  opacity: 0.85;
}

.home-entree__head {
  display: flex;
  flex: 0 0 auto;
  align-items: flex-start;
  gap: 0.7rem;
  margin-bottom: 0.75rem;
}

.home-entree__text {
  min-width: 0;
  flex: 1 1 auto;
}

.home-entree__title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.45rem;
  min-height: calc(2 * 1.3 * 1.02rem);
}

.home-entree__title {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 850;
  line-height: 1.3;
  color: var(--text);
  flex: 1 1 auto;
  min-width: 0;
}

.home-entree__head-action {
  flex: 0 0 auto;
  align-self: center;
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.15s ease;
  min-height: 2.15rem;
  padding: 0.38rem 0.72rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  white-space: nowrap;
  border: 1px solid rgba(13, 148, 136, 0.55);
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-deep) 100%);
  color: #fff;
  box-shadow:
    0 2px 8px rgba(13, 148, 136, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.home-entree__head-action:hover {
  background: linear-gradient(135deg, var(--accent-deep) 0%, #0f5f59 100%);
  border-color: var(--accent-deep);
  color: #fff;
  box-shadow:
    0 4px 14px rgba(13, 148, 136, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transform: translateY(-1px);
}

.home-entree__head-action:active {
  transform: translateY(0);
  box-shadow: 0 1px 5px rgba(13, 148, 136, 0.3);
}

.home-entree__head-action .home-icon--action {
  font-size: 0.82rem;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.15));
}

.home-entree__desc {
  margin: 0.3rem 0 0;
  font-size: 0.84rem;
  line-height: 1.45;
  color: var(--text-muted);
  min-height: calc(3 * 1.45 * 0.84rem);
}

.home-trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.4rem;
  margin: 0;
  padding: 0.5rem 0.45rem;
  border-radius: 0.65rem;
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid rgba(148, 163, 184, 0.25);
}

.home-trust__pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.28rem 0.5rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(148, 163, 184, 0.2);
  font-size: 0.68rem;
  font-weight: 650;
  line-height: 1.3;
  color: var(--text-muted);
}

.home-trust__text {
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.45;
  color: var(--text-muted);
  text-align: center;
}

.home-zone--qr {
  padding: 1rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(13, 148, 136, 0.25);
  background: linear-gradient(165deg, rgba(236, 253, 245, 0.7) 0%, rgba(255, 255, 255, 0.98) 55%);
  box-shadow: var(--shadow);
}

.home-zone__intro {
  margin: 0 0 0.75rem;
  font-size: 0.84rem;
  line-height: 1.5;
  color: var(--text-muted);
}

.home-qr-share {
  margin: 0 0 1rem;
  padding: 0.85rem 0.65rem 0.75rem;
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(13, 148, 136, 0.16);
  text-align: center;
}

.home-qr-share__title {
  margin: 0 0 0.65rem;
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.4;
  color: var(--text);
}

.home-qr-share__actions {
  margin-top: 0.7rem;
}

.home-qr-share__qr-wrap {
  display: inline-flex;
  padding: 0.45rem;
  border-radius: 0.75rem;
  background: #fff;
  border: 1px solid rgba(148, 163, 184, 0.25);
  box-shadow: 0 4px 16px rgba(15, 23, 42, 0.06);
}

.home-qr-share__qr {
  display: block;
  width: 10.5rem;
  height: 10.5rem;
  border-radius: 0.35rem;
}

.home-flow {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.2rem 0.15rem;
  margin: 0 0 0.85rem;
  padding: 0.6rem 0.7rem;
  border-radius: 0.75rem;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(13, 148, 136, 0.14);
  line-height: 1.55;
}

.home-flow__step {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.22rem 0.45rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(13, 148, 136, 0.14);
  font-size: 0.73rem;
  font-weight: 700;
  line-height: 1.35;
  color: var(--accent-deep);
}

.home-flow__label {
  line-height: 1.3;
}

.home-flow__arrow {
  flex-shrink: 0;
  font-size: 0.68rem;
  font-weight: 700;
  color: rgba(13, 148, 136, 0.35);
  line-height: 1;
}

.home-actions {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.home-actions--qr {
  gap: 0.45rem;
}

.home-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 2.45rem;
  padding: 0.5rem 0.85rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(255, 255, 255, 0.92);
  color: var(--text);
  font: inherit;
  font-size: 0.86rem;
  font-weight: 750;
  line-height: 1.25;
  text-align: center;
  text-decoration: none;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}

.home-action:hover {
  border-color: rgba(13, 148, 136, 0.35);
  background: rgba(13, 148, 136, 0.05);
}

.home-action:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.home-action--primary {
  border-color: rgba(13, 148, 136, 0.4);
  background: var(--accent);
  color: #fff;
  box-shadow: 0 2px 10px rgba(13, 148, 136, 0.22);
}

.home-action--primary:hover {
  background: var(--accent-deep);
  border-color: var(--accent-deep);
  color: #fff;
}

.home-actions--entree {
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: repeat(3, minmax(3.15rem, auto));
  gap: 0.4rem;
  width: 100%;
  align-items: stretch;
  justify-content: flex-start;
}

.home-actions--entree .home-action {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 3.15rem;
  box-sizing: border-box;
}

.home-actions--entree .home-action--primary {
  margin-top: 0;
  font-size: 0.9rem;
  font-weight: 800;
}

.home-actions--entree .home-action__text {
  text-align: center;
  line-height: 1.25;
}

.home-qr-copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  width: 100%;
}

.home-qr-reception {
  padding-top: 0.85rem;
  border-top: 1px solid rgba(13, 148, 136, 0.16);
}

.home-qr-reception__title {
  margin: 0 0 0.65rem;
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.4;
  color: var(--text);
}

.home-rapide__head {
  display: flex;
  flex: 0 0 auto;
  align-items: flex-start;
  gap: 0.6rem;
  margin-bottom: 0.65rem;
}

.home-rapide__text {
  min-width: 0;
  flex: 1 1 auto;
}

.home-rapides {
  display: grid;
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 0.6rem;
}

.home-rapide {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 0.85rem 0.95rem;
  border-radius: 1rem;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}

.home-rapide__title {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.3;
  color: var(--text);
  min-height: calc(2 * 1.3 * 0.92rem);
}

.home-rapide__desc {
  margin: 0.2rem 0 0;
  font-size: 0.8rem;
  line-height: 1.4;
  color: var(--text-muted);
  min-height: calc(2 * 1.4 * 0.8rem);
}

.home-rapide > .home-actions {
  flex: 1 1 auto;
  width: 100%;
  align-items: stretch;
  justify-content: flex-start;
}

.home-rapide .home-action {
  display: flex;
  width: 100%;
  box-sizing: border-box;
}

.home-guided__catalog-block {
  margin-top: 1.35rem;
  padding: 1rem;
  border-radius: 1rem;
  border: 1px dashed rgba(148, 163, 184, 0.45);
  background: rgba(255, 255, 255, 0.55);
  text-align: center;
}

.home-guided__catalog-text {
  margin: 0 0 0.65rem;
  font-size: 0.88rem;
  color: var(--text-muted);
}

.home-guided__catalog-btn {
  width: min(100%, 20rem);
  border-radius: var(--radius-pill);
}

.home-catalog[hidden] {
  display: none !important;
}

.home-guided[hidden] {
  display: none !important;
}

.app--home-catalog .home-catalog .search-wrap {
  margin-top: 0.55rem;
}

@media (max-width: 420px) {
  .home-flow {
    flex-direction: column;
    align-items: stretch;
    gap: 0.35rem;
  }

  .home-flow__arrow {
    display: none;
  }

  .home-flow__step {
    width: 100%;
    border-radius: 0.55rem;
  }
}

@media (min-width: 700px) {
  .home-mode-bar,
  .home-trust-bar,
  .home-guided.container {
    width: min(96%, 60rem);
  }

  .home-entrees {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
  }

  .home-rapides {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
  }
}

@media (min-width: 900px) {
  .home-mode-bar,
  .home-trust-bar,
  .home-guided.container {
    width: min(94%, 68rem);
  }
}

@media (min-width: 1200px) {
  .home-mode-bar,
  .home-trust-bar,
  .home-guided.container {
    width: min(92%, 76rem);
  }

  .home-rapides {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Accueil — plus de largeur sur grand écran */
@media (min-width: 900px) {
  .app--home main.container {
    max-width: min(1400px, 100%);
    padding-left: max(1.5rem, env(safe-area-inset-left));
    padding-right: max(1.5rem, env(safe-area-inset-right));
  }

  .app--home .search-wrap {
    width: 80%;
  }

  .app--home #outils-count,
  .app--home .empty-state {
    max-width: 100%;
    width: 100%;
  }

  .app--home .tools-list {
    max-width: 100%;
    width: 100%;
  }

  .app--home .tools-list:not(.tools-list--icons) {
    max-width: min(64rem, 100%);
  }

  .app--home .site-footer {
    width: 100%;
    max-width: 100%;
  }
}

@media (min-width: 1200px) {
  .app--home main.container {
    max-width: min(1600px, 100%);
    padding-left: max(2rem, env(safe-area-inset-left));
    padding-right: max(2rem, env(safe-area-inset-right));
  }

  .app--home .tools-list--icons .tool-list__item {
    width: calc(20% - 0.44rem);
  }
}

@media (min-width: 1500px) {
  .app--home .tools-list--icons .tool-list__item {
    width: calc(16.666% - 0.46rem);
  }
}

.empty-state {
  text-align: center;
  padding: 2rem 1.25rem;
  color: var(--text-muted);
  background: rgba(255, 255, 255, 0.75);
  border-radius: var(--radius);
  border: 1px dashed rgba(148, 163, 184, 0.55);
  max-width: 42rem;
  width: min(100%, 42rem);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

/* --- Timer HIIT / Tabata --- */
.page-outil--hiit {
  display: flex;
  flex-direction: column;
  max-width: min(40rem, 100%);
  min-height: 100dvh;
  min-height: 100vh;
  box-sizing: border-box;
}

.page-outil--hiit .page-outil__header {
  margin-bottom: 0.5rem;
  flex-shrink: 0;
}

.page-outil--hiit .hiit-actions,
.page-outil--hiit .hiit-msg,
.page-outil--hiit .card--accordion {
  flex-shrink: 0;
}

.hiit-timer-card {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-height: min(68dvh, calc(100dvh - 11rem));
  padding: clamp(0.5rem, 2vw, 1.25rem) clamp(0.35rem, 2vw, 1rem);
  transition: background 0.35s ease, border-color 0.35s ease, color 0.25s ease;
}

.hiit-timer-card--idle {
  background: linear-gradient(165deg, #f8fafc 0%, #ffffff 100%);
  border-color: var(--border);
}

.hiit-timer-card--countdown {
  background: linear-gradient(165deg, #fef9c3 0%, #fef08a 100%);
  border-color: rgba(202, 138, 4, 0.45);
}

.hiit-timer-card--work {
  background: linear-gradient(165deg, #fee2e2 0%, #fecaca 100%);
  border-color: rgba(220, 38, 38, 0.4);
}

.hiit-timer-card--rest {
  background: linear-gradient(165deg, #d1fae5 0%, #a7f3d0 100%);
  border-color: rgba(5, 150, 105, 0.4);
}

.hiit-timer-card--done {
  background: linear-gradient(165deg, var(--accent-soft) 0%, #ccfbf1 100%);
  border-color: rgba(13, 148, 136, 0.45);
}

.hiit-timer-card--paused {
  opacity: 0.88;
}

.hiit-phase {
  margin: 0 0 clamp(0.35rem, 2vh, 0.75rem);
  flex-shrink: 0;
  font-size: clamp(0.78rem, 2.8vw, 1rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-deep);
}

.hiit-display {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 0;
}

.hiit-time {
  margin: 0;
  font-size: clamp(4.5rem, 32vw, 11rem);
  font-weight: 800;
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}

.hiit-time--countdown {
  font-size: clamp(6rem, 48vw, 14rem);
  color: #a16207;
  letter-spacing: -0.02em;
}

.hiit-round {
  margin: clamp(0.35rem, 2vh, 0.75rem) 0 0;
  flex-shrink: 0;
  font-size: clamp(0.95rem, 3.5vw, 1.15rem);
  font-weight: 600;
  color: var(--text-muted);
}

.field-row--hiit-durees .field-group,
.field-row--hiit-extra .field-group {
  flex: 1 1 10rem;
  min-width: 0;
}

@media (max-width: 559px) {
  .field-row:not(.field-row--actions):not(.hiit-actions):not(.compo-export-row):not(.compo-actions-row):not(.field-row--photo-finish-zoom) {
    flex-direction: column;
    align-items: stretch;
  }

  .field-row:not(.field-row--actions):not(.hiit-actions):not(.compo-export-row):not(.compo-actions-row) .field-group,
  .field-row--hiit-durees .field-group,
  .field-row--hiit-extra .field-group,
  .field-row--vitesse-distance .field-group--grow,
  .field-row--vitesse-distance .field-group--unite,
  .field-row--vitesse-temps .field-group,
  .field-row--dispense-dates .field-group,
  .champ-add-row .champ-add-field {
    flex: 1 1 auto;
    width: 100%;
    min-width: 0;
    max-width: 100%;
  }

  .champ-add-row {
    flex-direction: column;
    align-items: stretch;
  }

  .champ-add-row .champ-add-btn {
    width: 100%;
    justify-content: center;
  }

  .field-row--eleve-opt .field-group {
    flex: 1 1 100%;
    width: 100%;
    min-width: 0;
    max-width: 100%;
  }

  .classes-actions-row .btn {
    flex: 1 1 100%;
    width: 100%;
    min-width: 0;
  }
}

.hiit-msg {
  margin: 0 0 1rem;
}

.hiit-reglages-locked {
  display: block;
  margin: 0 0 1rem;
  padding: 0.65rem 0.85rem;
  background: rgba(220, 38, 38, 0.08);
  border-radius: var(--radius-sm, 8px);
  border: 1px solid rgba(220, 38, 38, 0.25);
  font-weight: 600;
}

.hiit-reglages-locked[hidden] {
  display: none;
}

.hiit-presets-hint {
  margin-top: 0;
  padding-top: 0.85rem;
}

.hiit-presets-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.15rem;
}

.hiit-preset-item {
  display: flex;
  align-items: stretch;
  flex: 1 1 auto;
  min-width: min(100%, 9.5rem);
}

.hiit-preset-btn {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 0.88rem;
  padding: 0.55rem 0.75rem;
  text-align: left;
  white-space: normal;
  line-height: 1.25;
}

.hiit-preset-item:has(.hiit-preset-remove) .hiit-preset-btn {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.hiit-preset-remove {
  flex-shrink: 0;
  min-width: 2.75rem;
  min-height: auto;
  padding: 0 0.5rem;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  font-size: 1.25rem;
  line-height: 1;
}

.hiit-reglages-manuels-label {
  margin: 0 0 0.65rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.hiit-save-preset {
  width: 100%;
  margin: 0.75rem 0 0.5rem;
  justify-content: flex-start;
}

.hiit-time--warn {
  color: #b45309;
  animation: hiit-pulse 0.85s ease-in-out infinite;
}

@keyframes hiit-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.82;
  }
}

.hiit-options {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin: 1rem 0 0.5rem;
}

.hiit-option-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
}

.hiit-option-label input {
  width: 1.15rem;
  height: 1.15rem;
  accent-color: var(--accent);
}

.hiit-ios-audio-hint {
  margin: 0.35rem 0 0 1.65rem;
  font-size: 0.8rem;
}

.hiit-actions {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin: 0 0 0.75rem;
}

.hiit-actions__main {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.65rem;
  width: 100%;
  min-width: 0;
}

.hiit-actions__main .btn {
  flex: 1 1 0;
  min-width: 0;
}

.hiit-actions__reset {
  width: 100%;
  flex: none;
}

@media (min-width: 560px) {
  .hiit-actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    align-items: stretch;
  }

  .hiit-actions__main {
    display: contents;
  }

  .hiit-actions .btn {
    width: 100%;
    min-width: 0;
  }
}

/* --- Maxi timer --- */
.page-outil--maxi-timer {
  display: flex;
  flex-direction: column;
  max-width: min(52rem, 100%);
  min-height: 100dvh;
  min-height: 100vh;
}

.maxi-timer-header {
  flex-shrink: 0;
  margin-bottom: 0.5rem;
}

.maxi-timer-card {
  flex: 1 1 auto;
  min-height: min(72dvh, calc(100dvh - 7rem));
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  padding: clamp(0.75rem, 2.5vw, 1.25rem);
  border-top: 3px solid var(--accent);
}

.maxi-mode {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  margin-bottom: clamp(0.75rem, 3vh, 1.25rem);
}

.maxi-mode__btn {
  min-height: 2.75rem;
  border-radius: var(--radius-sm);
  border: 2px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.95);
  color: var(--text);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

.maxi-mode__btn.is-active {
  border-color: rgba(13, 148, 136, 0.5);
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.maxi-settings {
  flex-shrink: 0;
  margin-bottom: clamp(0.65rem, 2vh, 1rem);
}

.maxi-settings__row {
  justify-content: center;
}

.maxi-settings__row .field-group {
  flex: 0 1 8rem;
}

.maxi-label {
  margin: auto 0 0.25rem;
  font-size: clamp(0.85rem, 2.8vw, 1.05rem);
  font-weight: 850;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-deep);
}

.maxi-time {
  margin: 0;
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(5rem, 28vw, 14rem);
  font-weight: 850;
  line-height: 0.9;
  letter-spacing: -0.06em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.maxi-actions {
  flex-shrink: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.65rem;
  margin-top: clamp(0.75rem, 3vh, 1.25rem);
}

/* --- Radar vitesse (chrono course) --- */
.page-outil--radar {
  max-width: min(40rem, 100%);
}

.radar-chrono-card {
  text-align: center;
  border-top: 3px solid var(--accent);
}

.radar-chrono-label {
  margin: 0 0 0.25rem;
  font-size: clamp(0.85rem, 2.8vw, 1.05rem);
  font-weight: 850;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-deep);
}

.radar-chrono-time {
  margin: 0.25rem 0 0.75rem;
  font-size: clamp(3.5rem, 22vw, 7rem);
  font-weight: 850;
  line-height: 0.95;
  letter-spacing: -0.05em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.radar-chrono-actions {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 0.5rem;
  align-items: stretch;
}

.radar-btn-main {
  min-height: 3.25rem;
}

@media (max-width: 380px) {
  .radar-chrono-actions {
    grid-template-columns: 2fr 1fr;
  }
}

.radar-eleve-actif {
  margin: 0.5rem 0 0;
  font-weight: 700;
  color: var(--accent-deep);
}

.radar-resultats-bandeau {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
  margin-top: 0;
  text-align: center;
}

.radar-resultat-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  min-width: 0;
}

.radar-resultat-col strong {
  font-size: clamp(1.15rem, 5vw, 1.5rem);
  margin: 0;
}

.radar-resultat-col .vitesse-result-label {
  width: auto;
}

.radar-eleve-titre {
  margin-top: 1.1rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
}

@media (max-width: 420px) {
  .radar-resultats-bandeau {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
}

/* --- Radar : liste historique --- */
.radar-historique-filtres {
  align-items: flex-end;
  gap: 0.65rem;
}

.radar-historique-filtres .filter-bar {
  margin-bottom: 0;
}

.radar-historique-tri {
  flex: 0 1 11.5rem;
  min-width: 0;
}

.page-outil--radar #radar-liste-perfs {
  margin-top: 0.25rem;
  --radar-liste-action: 2.5rem;
}

.radar-liste {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: transparent;
}

.radar-liste__groupe {
  list-style: none;
  margin: 0;
  padding: 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.28);
}

.radar-liste__groupe:last-child {
  border-bottom: none;
}

.radar-liste__details > summary {
  list-style: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.radar-liste__details > summary::-webkit-details-marker {
  display: none;
}

.radar-liste__summary {
  padding: 0;
}

.radar-liste__entete {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto var(--radar-liste-action);
  gap: 0.35rem 0.5rem;
  align-items: center;
  padding: 0.65rem 0.75rem;
}

.radar-liste__identite {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}

.radar-liste__nom {
  font-weight: 750;
  font-size: 0.95rem;
  color: var(--text);
}

.radar-liste__sous {
  font-size: 0.8rem;
  color: var(--text-muted);
}

.radar-liste__resume {
  font-size: 0.88rem;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  text-align: right;
  white-space: nowrap;
}

.radar-liste__action {
  width: var(--radar-liste-action);
  height: var(--radar-liste-action);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.radar-liste__chev {
  width: 1.1rem;
  height: 1.1rem;
  flex-shrink: 0;
  position: relative;
}

.radar-liste__chev::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 2px solid var(--text-muted);
  border-bottom: 2px solid var(--text-muted);
  transform: rotate(45deg);
  transition: transform 0.15s ease;
}

.radar-liste__details[open] .radar-liste__chev::after {
  transform: rotate(-135deg);
  margin-top: 0.2rem;
}

.radar-liste__passages {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid rgba(148, 163, 184, 0.22);
}

.radar-liste__groupe--solo .radar-liste__passages {
  border-top: none;
}

.radar-liste__ligne {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--radar-liste-action);
  gap: 0.2rem 0.5rem;
  align-items: center;
  padding: 0.5rem 0.75rem;
  padding-left: 1rem;
  border-top: 1px solid rgba(148, 163, 184, 0.15);
  font-size: 0.86rem;
}

.radar-liste__ligne-contenu {
  min-width: 0;
}

.radar-liste__ligne:first-child {
  border-top: none;
}

.radar-liste__ligne-stats {
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

.radar-liste__ligne-detail {
  display: block;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.radar-liste__suppr {
  width: var(--radar-liste-action);
  height: var(--radar-liste-action);
  min-width: 0;
  min-height: 0;
  padding: 0;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-muted);
  font: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-tap-highlight-color: transparent;
}

.radar-liste__suppr:hover {
  background: rgba(190, 18, 60, 0.08);
  color: var(--danger);
}

.radar-liste__suppr .btn-icon-emoji {
  font-size: 1.1rem;
  line-height: 1;
}

.radar-liste__ligne--best .radar-liste__ligne-stats,
.radar-liste__ligne--best .radar-liste__ligne-detail {
  font-weight: 750;
}

@media (max-width: 480px) {
  .radar-liste__entete {
    grid-template-columns: minmax(0, 1fr) var(--radar-liste-action);
    grid-template-rows: auto auto;
  }

  .radar-liste__identite {
    grid-column: 1;
    grid-row: 1;
  }

  .radar-liste__resume {
    grid-column: 1;
    grid-row: 2;
    text-align: left;
    white-space: normal;
  }

  .radar-liste__action {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
  }
}

.page-outil--maxi-timer .msg-error {
  flex-shrink: 0;
  margin-top: 0.75rem;
}

@media (max-width: 559px) {
  .maxi-actions {
    grid-template-columns: 1fr;
  }
}

/* --- Table de marque --- */
.page-outil--table-marque {
  max-width: min(54rem, 100%);
}

.table-marque-header {
  margin-bottom: 0.75rem;
}

.table-marque-reglages {
  margin-bottom: 0.75rem;
}

.table-reglages-row .field-group {
  flex: 1 1 8rem;
  min-width: 0;
}

.table-timer-card {
  text-align: center;
  border-top: 3px solid var(--accent);
}

.table-timer-card h2 {
  margin-bottom: 0.25rem;
}

.table-timer-label {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 850;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-deep);
}

.table-timer-time {
  margin: 0.1rem 0 0.8rem;
  font-size: clamp(3.2rem, 18vw, 6rem);
  font-weight: 850;
  line-height: 1;
  letter-spacing: -0.05em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.table-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
}

.table-scoreboard {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.table-team {
  --team-color: var(--accent);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: center;
  min-height: 16rem;
  padding: 0.75rem;
}

.table-team--left {
  border-top: 4px solid var(--team-color);
}

.table-team--right {
  border-top: 4px solid var(--team-color);
}

.table-team__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.45rem;
  align-items: center;
}

.table-team__name-input {
  width: 100%;
  min-width: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.65rem;
  background: rgba(255, 255, 255, 0.92);
  color: var(--text);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 800;
}

.table-minus-btn {
  min-width: 3.2rem;
  min-height: 2.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(190, 18, 60, 0.25);
  background: var(--danger-bg);
  color: var(--danger);
  font: inherit;
  font-weight: 850;
  cursor: pointer;
}

.table-color-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin: 0.5rem 0 0;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.table-color-label input {
  width: 2.6rem;
  height: 2rem;
  padding: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.5rem;
  background: transparent;
  cursor: pointer;
}

.table-team__score {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  font-size: clamp(5rem, 25vw, 10rem);
  font-weight: 850;
  line-height: 0.9;
  letter-spacing: -0.06em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.table-score-btn {
  min-height: 4rem;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--team-color);
  color: #fff;
  font: inherit;
  font-size: 1.45rem;
  font-weight: 850;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.14);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.table-score-btn:active {
  transform: scale(0.98);
}

.table-reset-scores {
  width: 100%;
  justify-content: center;
}

.dispense-item.oubli-item {
  padding: 0.6rem 0.7rem;
  margin-bottom: 0.45rem;
  background: rgba(255, 255, 255, 0.94);
  border-color: rgba(190, 18, 60, 0.22);
}

.dispense-item.oubli-item .dispense-item__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 0.45rem;
  align-items: center;
}

.dispense-item.oubli-item .dispense-item__title {
  margin-bottom: 0.1rem;
  font-size: 0.98rem;
}

.dispense-item.oubli-item .dispense-item__days {
  align-items: center;
  min-width: 4.3rem;
  padding: 0.3rem 0.45rem;
  border-radius: 999px;
  background: var(--danger-bg);
  text-align: center;
}

.dispense-item.oubli-item .dispense-item__days-num {
  font-size: 1.1rem;
  letter-spacing: -0.02em;
}

.dispense-item.oubli-item .dispense-item__days-label {
  font-size: 0.62rem;
}

.dispense-item.oubli-item .dispense-actions {
  flex-wrap: nowrap;
  gap: 0.35rem;
  margin-top: 0;
}

.oubli-comment {
  margin: 0.4rem 0 0;
  padding-top: 0.4rem;
  border-top: 1px solid rgba(148, 163, 184, 0.22);
  font-size: 0.86rem;
  color: var(--text-muted);
}

@media (max-width: 420px) {
  .dispense-item.oubli-item .dispense-item__head {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .dispense-item.oubli-item .dispense-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
  }
}

/* --- Compteur ratio --- */
.page-outil--ratio {
  max-width: min(54rem, 100%);
}

.ratio-intro {
  margin-bottom: 0.85rem;
}

.ratio-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.ratio-card {
  --ratio-color: var(--accent);
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  border-top: 4px solid var(--ratio-color);
}

.ratio-card__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.45rem;
  align-items: center;
}

.ratio-name-input {
  width: 100%;
  min-width: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.65rem;
  background: rgba(255, 255, 255, 0.92);
  color: var(--text);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 800;
}

.ratio-color-input {
  width: 2.8rem;
  height: 2.35rem;
  padding: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.5rem;
  background: transparent;
  cursor: pointer;
}

.ratio-result {
  padding: 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.08);
  text-align: center;
}

.ratio-result__label {
  display: block;
  margin-bottom: 0.15rem;
  font-size: 0.7rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.ratio-result strong {
  display: block;
  font-size: clamp(2.6rem, 15vw, 4rem);
  line-height: 1;
  font-weight: 850;
  color: var(--ratio-color);
  font-variant-numeric: tabular-nums;
}

.ratio-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.4rem;
}

.ratio-stats p {
  margin: 0;
  padding: 0.55rem 0.35rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.04);
  text-align: center;
}

.ratio-stats span {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.ratio-stats strong {
  display: block;
  margin-top: 0.1rem;
  font-size: 1.25rem;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.ratio-buttons {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
}

.ratio-btn {
  min-height: 5rem;
  border: none;
  border-radius: var(--radius-sm);
  color: #fff;
  font: inherit;
  font-size: 2.5rem;
  font-weight: 850;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.ratio-btn--plus {
  background: var(--ratio-color);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.14);
}

.ratio-btn--minus {
  background: linear-gradient(180deg, #f43f5e, #be123c);
  box-shadow: 0 8px 22px rgba(190, 18, 60, 0.16);
}

.ratio-btn:active {
  transform: scale(0.98);
}

.ratio-reset {
  width: 100%;
  justify-content: center;
  margin: 0 0 0.75rem;
}

@media (max-width: 640px) {
  .ratio-grid {
    grid-template-columns: 1fr;
    gap: 0.45rem;
  }

  .ratio-card {
    padding: 0.55rem;
    gap: 0.5rem;
  }

  .ratio-result {
    padding: 0.65rem 0.35rem;
  }

  .ratio-btn {
    min-height: 4.2rem;
  }

  .table-scoreboard {
    gap: 0.55rem;
  }

  .table-team {
    min-height: 13rem;
  }
}

/* --- Compteur PTB --- */
.page-outil--ptb {
  max-width: min(70rem, 100%);
}

.ptb-subtitle {
  margin: -0.6rem 0 0.85rem;
  text-align: center;
  font-weight: 800;
  color: var(--accent-deep);
}

.ptb-config,
.ptb-match,
.ptb-stats-card {
  margin-bottom: 0.85rem;
}

.ptb-config-grid .field-group {
  flex: 1 1 12rem;
}

.ptb-duration {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto;
  gap: 0.35rem;
  align-items: center;
}

.ptb-duration input {
  min-width: 0;
}

.ptb-teams-config {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
  margin: 0.75rem 0;
}

.ptb-team-config {
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.04);
}

.ptb-config-actions,
.ptb-controls {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
  gap: 0.55rem;
}

.ptb-match {
  border-top: 4px solid var(--ptb-possession-color, var(--accent));
}

.ptb-match-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.7rem 0.8rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--ptb-possession-color, var(--accent)) 10%, #fff);
}

.ptb-match-top h2,
.ptb-match-top p {
  margin: 0;
}

.ptb-match-top p {
  font-weight: 850;
  color: var(--ptb-possession-color, var(--accent-deep));
}

.ptb-timer-side {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.65rem;
  align-items: center;
}

.ptb-timer {
  text-align: right;
  flex-shrink: 0;
}

.ptb-timer span {
  display: block;
  font-size: 0.7rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.ptb-timer strong {
  display: block;
  font-size: clamp(2.1rem, 8vw, 3.6rem);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.ptb-controls {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.45rem;
  margin: 0.65rem 0 0.55rem;
}

.ptb-control-group {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.35rem;
  padding: 0.32rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.018);
}

.ptb-control-group[hidden] {
  display: none !important;
}

.ptb-control-group__label {
  grid-column: 1 / -1;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  text-align: center;
}

.ptb-control-group .btn {
  min-height: 2.35rem;
  padding: 0.45rem 0.55rem;
  font-size: 0.78rem;
  box-shadow: none;
}

.ptb-control-group .btn__icon {
  font-size: 0.9rem;
}

.ptb-control-group--chrono {
  grid-template-columns: repeat(2, 2.55rem);
  padding: 0;
  background: transparent;
}

.ptb-control-group--chrono .ptb-control-group__label {
  display: none;
}

.ptb-control-group--chrono .btn {
  min-width: 2.55rem;
  width: 2.55rem;
  min-height: 2.55rem;
  padding: 0;
}

.ptb-control-group--chrono .btn__text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.ptb-finish-msg {
  text-align: center;
  font-weight: 850;
}

.ptb-stats-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.45rem;
  margin: 0.75rem 0 0.65rem;
}

.ptb-stats-actions .btn {
  min-height: 2.5rem;
  padding: 0.42rem 0.55rem;
  font-size: 0.78rem;
  box-shadow: none;
}

.ptb-observation {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.75rem;
}

.ptb-team-panel {
  --ptb-team-color: var(--accent);
  padding: clamp(0.85rem, 2.4vw, 1.25rem);
  border: 2px solid color-mix(in srgb, var(--ptb-team-color) 70%, #fff);
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ptb-team-color) 24%, #fff), #fff 78%),
    color-mix(in srgb, var(--ptb-team-color) 20%, #fff);
}

.ptb-team-panel.is-possession {
  border-color: var(--ptb-team-color);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--ptb-team-color) 14%, transparent);
}

.ptb-team-panel h3,
.ptb-team-score {
  margin: 0;
  text-align: center;
}

.ptb-team-panel h3 {
  font-size: clamp(1.2rem, 5vw, 1.7rem);
  color: color-mix(in srgb, var(--ptb-team-color) 78%, #111827);
}

.ptb-team-score {
  margin-top: 0.2rem;
  font-weight: 850;
  color: var(--ptb-team-color);
}

.ptb-team-score span {
  font-size: 2rem;
  font-variant-numeric: tabular-nums;
}

.ptb-action-grid {
  display: grid;
  gap: clamp(0.7rem, 2vw, 1rem);
  margin-top: clamp(0.85rem, 2.4vw, 1.25rem);
}

.ptb-action {
  min-height: clamp(5.8rem, 16vw, 8rem);
  border: 0;
  border-radius: var(--radius-sm);
  color: #fff;
  font: inherit;
  font-size: clamp(1.55rem, 6vw, 2.25rem);
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.12);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.ptb-action:active {
  transform: scale(0.98);
}

.ptb-action--loss {
  background: linear-gradient(180deg, #f97316, #c2410c);
}

.ptb-action--shot {
  background: linear-gradient(180deg, #0ea5e9, #0369a1);
}

.ptb-action--goal {
  background: linear-gradient(180deg, #22c55e, #15803d);
}

.ptb-stats-grid {
  display: block;
}

.ptb-stats-table {
  margin-top: 0.7rem;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.04);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.ptb-stats-head,
.ptb-stats-row {
  display: grid;
  grid-template-columns: minmax(7rem, 1fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 0.2rem;
  align-items: stretch;
}

.ptb-stats-head {
  background: rgba(15, 23, 42, 0.06);
}

.ptb-stats-head span,
.ptb-stats-head strong,
.ptb-stats-row span,
.ptb-stats-row strong {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 0.55rem;
}

.ptb-stats-head span,
.ptb-stats-row span {
  justify-content: flex-start;
  font-weight: 850;
  color: var(--text-muted);
}

.ptb-stats-head strong,
.ptb-stats-row strong {
  font-variant-numeric: tabular-nums;
}

.ptb-stats-head strong:nth-child(2) {
  color: var(--ptb-color-a);
}

.ptb-stats-head strong:nth-child(3) {
  color: var(--ptb-color-b);
}

.ptb-stats-row:nth-child(odd) {
  background: rgba(255, 255, 255, 0.55);
}

.ptb-stats-row .is-best {
  color: var(--accent-deep);
  font-weight: 950;
  background: rgba(13, 148, 136, 0.1);
}

.ptb-stat-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.08rem;
  line-height: 1.1;
}

.ptb-stat-stack b {
  font: inherit;
}

.ptb-stat-stack small {
  font-size: 0.72rem;
  color: var(--text-muted);
}

.ptb-compare:empty {
  display: none;
}

@media (max-width: 760px) {
  .ptb-teams-config,
  .ptb-stats-grid {
    grid-template-columns: 1fr;
  }

  .ptb-match-top {
    grid-template-columns: 1fr;
    display: grid;
  }

  .ptb-timer {
    text-align: left;
  }

  .ptb-timer-side {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.5rem;
  }

  .ptb-control-group--chrono {
    grid-template-columns: repeat(2, 2.5rem);
  }

  .ptb-control-group--chrono .btn {
    min-width: 2.5rem;
    width: 2.5rem;
    min-height: 2.5rem;
    padding: 0;
  }

  .ptb-controls {
    grid-template-columns: 1fr;
  }

  .ptb-action {
    min-height: 5.3rem;
  }
}

@media (max-width: 420px) {
  .ptb-controls,
  .ptb-config-actions {
    grid-template-columns: 1fr;
  }

  .ptb-stats-head,
  .ptb-stats-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ptb-stats-head {
    grid-template-columns: 1fr 1fr;
  }

  .ptb-stats-row {
    gap: 0;
  }

  .ptb-stats-head span,
  .ptb-stats-row span {
    grid-column: 1 / -1;
    background: rgba(15, 23, 42, 0.06);
    justify-content: center;
    text-align: center;
    padding: 0.5rem;
  }
}

/* --- Vitesse de course --- */
.page-outil--vitesse {
  max-width: min(40rem, 100%);
}

/* --- Distance VMA --- */
.page-outil--distance-vma {
  max-width: min(40rem, 100%);
}

.distance-vma-tabs {
  margin-bottom: 0.85rem;
}

.field-row--distance-vma .field-group {
  flex: 1 1 9rem;
  min-width: 0;
}

.distance-vma-balise-row {
  margin-bottom: 1rem;
}

.distance-vma-slider {
  position: relative;
  margin: 1.25rem 0 0.5rem;
  padding-top: 1.75rem;
}

.distance-vma-slider:first-of-type {
  margin-top: 0.75rem;
}

.distance-vma-slider__bubble {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.2rem 0.65rem;
  border-radius: var(--radius-pill);
  background: var(--accent);
  color: #fff;
  font-size: 0.82rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.distance-vma-slider__row {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}

.distance-vma-step {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  border: 2px solid rgba(15, 23, 42, 0.1);
  background: rgba(255, 255, 255, 0.95);
  color: var(--text);
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.distance-vma-step:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.distance-vma-slider input[type="range"] {
  flex: 1;
  min-width: 0;
  height: 0.5rem;
  margin: 0;
  -webkit-appearance: none;
  appearance: none;
  border-radius: var(--radius-pill);
  background: rgba(15, 23, 42, 0.12);
  outline: none;
}

.distance-vma-slider input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 50%;
  border: 2px solid #fff;
  background: var(--accent);
  box-shadow: 0 2px 8px rgba(13, 148, 136, 0.35);
  cursor: pointer;
}

.distance-vma-slider input[type="range"]::-moz-range-thumb {
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 50%;
  border: 2px solid #fff;
  background: var(--accent);
  box-shadow: 0 2px 8px rgba(13, 148, 136, 0.35);
  cursor: pointer;
}

.distance-vma-vitesse-result {
  margin: 1.1rem 0 0;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.22);
  text-align: center;
  font-weight: 700;
  color: var(--accent-deep);
}

.distance-vma-vitesse-result strong {
  font-size: 1.35rem;
  font-weight: 850;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.distance-vma-chrono {
  margin: 0.5rem 0 1rem;
  text-align: center;
}

.distance-vma-chrono__display {
  margin: 0 0 0.85rem;
  font-size: clamp(2.8rem, 16vw, 4.2rem);
  font-weight: 850;
  font-variant-numeric: tabular-nums;
  color: var(--accent-deep);
  line-height: 1.1;
}

.distance-vma-chrono__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}

.distance-vma-recap {
  margin: 0 0 0.85rem;
  text-align: center;
  font-weight: 700;
  color: var(--text-muted);
  font-size: 0.92rem;
}

.distance-vma-passages-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.18);
}

.distance-vma-passages-table {
  width: 100%;
  border-collapse: collapse;
  background: rgba(255, 255, 255, 0.95);
}

.distance-vma-passages-table th,
.distance-vma-passages-table td {
  padding: 0.65rem 0.5rem;
  text-align: center;
  border-bottom: 1px solid rgba(13, 148, 136, 0.12);
  font-variant-numeric: tabular-nums;
}

.distance-vma-passages-table th {
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 850;
}

.distance-vma-passages-table td {
  font-weight: 800;
}

.distance-vma-passages-table tr.is-next-passage td {
  background: var(--accent);
  color: #fff;
  font-weight: 850;
}

.distance-vma-passages-table__final td {
  font-weight: 850;
}

/* --- Vitesse aux plots --- */
.page-outil--vitesse-plots {
  max-width: min(44rem, 100%);
}

.field-row--vitesse-plots .field-group {
  flex: 1 1 11rem;
  min-width: 0;
}

.vitesse-plots-target {
  margin: 0.75rem 0 0;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-weight: 700;
}

.vitesse-plots-target strong {
  font-variant-numeric: tabular-nums;
}

.vitesse-plots-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin: 0 0 0.85rem;
}

.vitesse-plots-actions .btn {
  flex: 1 1 9rem;
}

.vitesse-plots-live-card {
  text-align: center;
  border-top: 3px solid var(--accent);
}

.vitesse-plots-chrono-label {
  display: block;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.vitesse-plots-chrono {
  display: block;
  margin: 0.15rem 0 0.8rem;
  font-size: clamp(3.2rem, 17vw, 5rem);
  line-height: 1;
  font-weight: 850;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

.vitesse-plots-pass-btn {
  width: 100%;
  min-height: clamp(7rem, 32vw, 10rem);
  border: none;
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 55%, var(--accent-2) 130%);
  color: #fff;
  font: inherit;
  font-size: clamp(1.45rem, 7vw, 2.4rem);
  font-weight: 900;
  box-shadow: 0 12px 30px rgba(13, 148, 136, 0.28);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.vitesse-plots-pass-btn:disabled {
  cursor: not-allowed;
  opacity: 0.48;
  box-shadow: none;
}

.vitesse-plots-pass-btn:active:not(:disabled) {
  transform: scale(0.99);
}

.vitesse-plots-undo {
  width: 100%;
  justify-content: center;
  margin-top: 0.7rem;
}

.vitesse-plots-results {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1rem;
  text-align: left;
}

.vitesse-plots-ecart {
  margin: 0.9rem 0 0;
  padding: 0.7rem 0.8rem;
  border-radius: var(--radius-sm);
  font-weight: 850;
}

.vitesse-plots-ecart.is-ok {
  background: var(--success-bg);
  color: var(--success);
}

.vitesse-plots-ecart.is-fast {
  background: #eff6ff;
  color: #1d4ed8;
}

.vitesse-plots-ecart.is-slow {
  background: #fff7ed;
  color: var(--warning);
}

/* ——— Relais (élève + prof) ——— */
.page-outil--relais-eleve,
.page-outil--relais {
  max-width: min(44rem, 100%);
}

.page-outil--relais .page-outil__subtitle {
  flex: 1 0 100%;
  margin: -0.25rem 0 0;
  font-size: 0.92rem;
  line-height: 1.4;
}

.page-outil--relais .card--accordion__panel > .liste-import-toolbar {
  margin-top: 0.85rem;
}

.page-outil--relais .relais-results-table {
  width: 100%;
  min-width: 36rem;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.page-outil--relais #rl-results-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.page-outil--relais .relais-results-table th,
.page-outil--relais .relais-results-table td {
  padding: 0.45rem 0.35rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}

.page-outil--relais .relais-results-table th {
  font-size: 0.78rem;
  color: var(--muted);
  font-weight: 700;
}

.page-outil--relais .relais-results-table td:last-child,
.page-outil--relais .relais-results-table th:last-child {
  text-align: right;
}

.page-outil--relais .relais-results-runner-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0;
  border: 0;
  background: none;
  color: var(--accent-deep);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  text-align: left;
}

.page-outil--relais .relais-results-runner-btn:hover,
.page-outil--relais .relais-results-runner-btn:focus-visible {
  text-decoration: underline;
}

.page-outil--relais .relais-results-runner-btn__chev {
  font-size: 0.75rem;
  opacity: 0.7;
}

.page-outil--relais .relais-results-detail-row td {
  padding: 0;
  border-bottom: 1px solid var(--border);
  background: var(--surface-soft, #f8fafc);
}

.page-outil--relais .relais-results-detail {
  padding: 0.65rem 0.5rem 0.75rem;
}

.page-outil--relais .relais-results-detail__title {
  margin: 0 0 0.45rem;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted);
}

.page-outil--relais .relais-results-detail__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.page-outil--relais .relais-results-detail__item {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  padding: 0.4rem 0;
  border-top: 1px solid var(--border);
  font-size: 0.86rem;
}

.page-outil--relais .relais-results-detail__item:first-child {
  border-top: 0;
}

.page-outil--relais .relais-results-detail__meta {
  color: var(--muted);
  font-size: 0.78rem;
}

.page-outil--relais .relais-results-invalid {
  color: var(--danger, #dc2626);
  font-size: 0.78rem;
  font-weight: 650;
}

.page-outil--relais .relais-results-invalid.is-none {
  color: var(--muted);
  font-weight: 500;
}

.page-outil--relais .relais-penalites--dialog {
  margin-top: 0.75rem;
}

.page-outil--relais .relais-results-perf.is-invalid {
  color: var(--muted);
  font-weight: 500;
  text-decoration: line-through;
}

.page-outil--relais .relais-results-perf {
  font-variant-numeric: tabular-nums;
  font-weight: 700;
}

.page-outil--relais .relais-results-perf.is-empty {
  color: var(--muted);
  font-weight: 500;
}

.page-outil--relais .relais-save-dialog .field-row {
  gap: 0.75rem;
}

.page-outil--relais .relais-save-dialog .field-group {
  flex: 1 1 12rem;
}

.page-outil--relais .dispense-nav.relais-nav {
  grid-template-columns: repeat(3, 1fr);
}

.page-outil--relais .dispense-nav__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  font-weight: 700;
  color: var(--accent-deep);
  background: #fff;
  border: 1.5px solid rgba(13, 148, 136, 0.32);
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.07);
}

.page-outil--relais .dispense-nav__btn--active {
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 55%, var(--accent-2) 130%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(13, 148, 136, 0.38);
}

@media (max-width: 22rem) {
  .page-outil--relais .dispense-nav__btn {
    min-height: 2.65rem;
    padding: 0.45rem 0.25rem;
    font-size: 0.78rem;
    gap: 0.2rem;
  }

  .page-outil--relais .dispense-nav__btn .btn-icon-emoji {
    font-size: 0.95em;
  }
}

.field-row--relais-distances .field-group {
  flex: 1 1 9rem;
  min-width: 0;
}

.relais-total-distance {
  margin: 0.75rem 0 0;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-weight: 700;
}

.relais-total-distance strong {
  font-variant-numeric: tabular-nums;
}

.relais-film-toggle {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin-top: 0.85rem;
  font-weight: 650;
  cursor: pointer;
}

.relais-film-toggle input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.relais-film-hint {
  margin-top: 0.35rem;
}

.relais-penalites {
  margin-top: 0.85rem;
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid #fecaca;
  background: #fff5f5;
}

.relais-penalites__title {
  margin: 0 0 0.5rem;
  font-weight: 700;
  font-size: 0.92rem;
}

.relais-penalite-toggle {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin-top: 0.45rem;
  font-weight: 650;
  cursor: pointer;
}

.relais-penalite-toggle input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.relais-penalites__hint {
  margin: 0.5rem 0 0;
}

.relais-live-card {
  text-align: center;
  border-top: 3px solid var(--accent);
}

.relais-scene {
  margin: 0 0 1rem;
}

.relais-scene__board {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow:
    0 10px 28px rgba(15, 23, 42, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.relais-scene__svg {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

.relais-scene__zones {
  position: absolute;
  inset: 21% 4% 28% 4%;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  pointer-events: none;
}

.relais-scene__zone {
  position: relative;
  border-radius: 4px;
  opacity: 0;
  transition: opacity 0.3s ease, background 0.3s ease;
}

.relais-scene__zone.is-active {
  opacity: 1;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.08));
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.55);
}

.relais-scene__zone--zt.is-active {
  background: linear-gradient(180deg, rgba(253, 224, 71, 0.5), rgba(245, 158, 11, 0.22));
  box-shadow:
    inset 0 0 0 2px rgba(251, 191, 36, 0.9),
    inset 0 -8px 16px rgba(245, 158, 11, 0.12);
}

.relais-scene__markers {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.relais-scene__marker {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: #0f172a;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.relais-scene__marker--depart {
  top: 6%;
  left: 3%;
}

.relais-scene__marker--arrivee {
  top: 6%;
  right: 3%;
}

.relais-scene__marker-icon {
  font-size: 0.85rem;
  line-height: 1;
}

.relais-scene__actors {
  position: absolute;
  inset: 21% 4% 30% 4%;
  pointer-events: none;
  z-index: 3;
}

.relais-runner {
  position: absolute;
  margin: 0;
  width: clamp(3.25rem, 15vw, 4.75rem);
  transition:
    left 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    top 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.25s ease,
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  filter: drop-shadow(0 4px 8px rgba(15, 23, 42, 0.2));
  z-index: 3;
}

.relais-runner[hidden] {
  display: none;
}

.relais-runner__img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  pointer-events: none;
  user-select: none;
}

/* Scène transmission — 3 colonnes : donneur | témoin | receveur */
.relais-transmission {
  position: absolute;
  top: 21%;
  bottom: 30%;
  left: 34.67%;
  width: 30.67%;
  z-index: 5;
  pointer-events: none;
}

.relais-transmission[hidden] {
  display: none;
}

.relais-transmission__stage {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding: 4% 2% 6%;
  animation: relais-transmission-in 0.48s cubic-bezier(0.22, 1, 0.36, 1);
}

.relais-transmission__athlete {
  margin: 0;
  flex: 0 0 36%;
  max-width: 36%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.relais-transmission__athlete img {
  display: block;
  width: 100%;
  height: auto;
  max-height: clamp(2.4rem, 10.5vw, 3.25rem);
  object-fit: contain;
  object-position: center bottom;
  filter: drop-shadow(0 5px 10px rgba(15, 23, 42, 0.28));
  user-select: none;
}

.relais-transmission__athlete--donneur {
  align-self: flex-end;
  transform: translateY(6%);
  opacity: 0.94;
}

.relais-transmission__athlete--receveur {
  align-self: flex-start;
  transform: translateY(-10%);
}

.relais-transmission__pass {
  flex: 0 0 22%;
  max-width: 22%;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  padding-bottom: 14%;
  position: relative;
  z-index: 2;
}

.relais-transmission__pass::before {
  content: "";
  position: absolute;
  width: 140%;
  height: 140%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.55) 0%, rgba(253, 224, 71, 0.2) 55%, transparent 75%);
  z-index: -1;
}

.relais-transmission__pass img {
  display: block;
  width: 100%;
  max-width: 1.85rem;
  height: auto;
  object-fit: contain;
  mix-blend-mode: screen;
  filter: drop-shadow(0 2px 5px rgba(15, 23, 42, 0.45));
  animation: relais-pass-pulse 2.4s ease-in-out infinite;
}

@keyframes relais-transmission-in {
  0% {
    opacity: 0;
    transform: scale(0.94) translateY(4px);
  }
  100% {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes relais-pass-pulse {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.9;
  }
  50% {
    transform: scale(1.08);
    opacity: 1;
  }
}

/* Coureur 1 — zone 1 uniquement */
.relais-runner--donneur[data-pos="depart"] {
  left: 0;
  top: 18%;
}

.relais-runner--donneur[data-pos="z1"] {
  left: 11%;
  top: 14%;
}

/* Coureur 2 seul — zone 2 et arrivée */
.relais-runner--receveur[data-pos="z2"] {
  left: 66%;
  top: 10%;
}

.relais-runner--receveur[data-pos="arrivee"] {
  left: 90%;
  top: 6%;
}

.relais-live-card.is-racing .relais-runner:not([hidden]) .relais-runner__img {
  animation: relais-run-bob 0.38s ease-in-out infinite;
}

.relais-live-card.is-racing .relais-transmission:not([hidden]) .relais-transmission__athlete--donneur img {
  animation: relais-run-bob 0.42s ease-in-out infinite;
}

.relais-live-card.is-racing .relais-transmission:not([hidden]) .relais-transmission__athlete--receveur img {
  animation: relais-run-bob 0.34s ease-in-out infinite;
  animation-delay: -0.12s;
}

@keyframes relais-run-bob {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-2px);
  }
}

.relais-scene__distances {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.4rem;
  margin-top: 0.65rem;
}

.relais-scene__dist {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.15rem 0.25rem;
  padding: 0.45rem 0.35rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(148, 163, 184, 0.35);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text);
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}

.relais-scene__dist strong {
  font-size: 1rem;
  font-variant-numeric: tabular-nums;
}

.relais-scene__dist-label {
  width: 100%;
  text-align: center;
  font-size: 0.58rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #b45309;
}

.relais-scene__dist--zt {
  border-color: rgba(245, 158, 11, 0.35);
  background: rgba(255, 251, 235, 0.85);
}

.relais-scene__dist.is-active {
  border-color: var(--accent);
  background: var(--accent-soft);
  box-shadow: 0 0 0 2px rgba(13, 148, 136, 0.15);
}

.relais-scene__dist--zt.is-active {
  border-color: #d97706;
  background: rgba(254, 243, 199, 0.95);
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.2);
}

.relais-scene__dist-arrow {
  font-size: 0.95rem;
  line-height: 1;
  opacity: 0.65;
}

.relais-eff-zt {
  margin: 0 0 0.85rem;
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 2px solid transparent;
  text-align: left;
  background: rgba(255, 255, 255, 0.72);
}

.relais-eff-zt--bilan {
  margin-top: 0.85rem;
  margin-bottom: 0;
}

.relais-eff-zt--live {
  margin-top: 1rem;
  margin-bottom: 0.35rem;
}

.relais-eff-zt__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}

.relais-eff-zt__title {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}

.relais-eff-zt__coef,
.relais-eff-zt__note10 {
  font-size: 1.55rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.relais-eff-zt__ref {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.4;
}

.relais-eff-zt__detail {
  margin: 0.3rem 0 0;
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.4;
}

.relais-eff-zt__note {
  margin: 0.35rem 0 0;
  padding: 0.45rem 0.55rem;
  border-radius: var(--radius-sm);
  background: rgba(148, 163, 184, 0.15);
  font-size: 0.76rem;
  color: var(--text);
  line-height: 1.4;
}

.relais-eff-zt__verdict {
  margin: 0.4rem 0 0;
  font-size: 0.88rem;
  font-weight: 800;
}

.relais-eff-zt.is-excellent {
  border-color: #16a34a;
  background: #f0fdf4;
}

.relais-eff-zt.is-excellent .relais-eff-zt__coef,
.relais-eff-zt.is-excellent .relais-eff-zt__note10,
.relais-eff-zt.is-excellent .relais-eff-zt__verdict {
  color: #15803d;
}

.relais-eff-zt.is-good {
  border-color: #22c55e;
  background: #f7fee7;
}

.relais-eff-zt.is-good .relais-eff-zt__coef,
.relais-eff-zt.is-good .relais-eff-zt__note10,
.relais-eff-zt.is-good .relais-eff-zt__verdict {
  color: #166534;
}

.relais-eff-zt.is-medium {
  border-color: #f59e0b;
  background: #fffbeb;
}

.relais-eff-zt.is-medium .relais-eff-zt__coef,
.relais-eff-zt.is-medium .relais-eff-zt__note10,
.relais-eff-zt.is-medium .relais-eff-zt__verdict {
  color: #b45309;
}

.relais-eff-zt.is-low {
  border-color: #ef4444;
  background: #fef2f2;
}

.relais-eff-zt.is-low .relais-eff-zt__coef,
.relais-eff-zt.is-low .relais-eff-zt__note10,
.relais-eff-zt.is-low .relais-eff-zt__verdict {
  color: #b91c1c;
}

.relais-eff-zt__toggle {
  margin-top: 0.55rem;
  width: 100%;
  justify-content: center;
}

.relais-eff-zt__explain {
  margin-top: 0.55rem;
  padding-top: 0.55rem;
  border-top: 1px solid rgba(148, 163, 184, 0.35);
}

.relais-eff-zt__explain-intro {
  margin: 0 0 0.55rem;
  font-size: 0.84rem;
  line-height: 1.45;
  color: var(--text);
}

.relais-eff-explain-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8rem;
  line-height: 1.35;
}

.relais-eff-explain-table caption {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.relais-eff-explain-table th,
.relais-eff-explain-table td {
  padding: 0.45rem 0.4rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  text-align: left;
  vertical-align: top;
}

.relais-eff-explain-table thead th {
  background: #f1f5f9;
  font-size: 0.74rem;
  font-weight: 700;
}

.relais-eff-explain-table tbody th {
  width: 2.2rem;
  text-align: center;
  font-weight: 800;
  background: #f8fafc;
  color: #475569;
}

.relais-eff-explain-table__result {
  font-weight: 700;
  white-space: nowrap;
}

.relais-eff-explain-table__row--alert td,
.relais-eff-explain-table__row--alert th {
  background: #fff1f2;
  color: #9f1239;
}

.relais-eff-explain-table__row--final td,
.relais-eff-explain-table__row--final th {
  background: #eff6ff;
  font-weight: 700;
}

.relais-eff-explain-table__row--final .relais-eff-explain-table__result {
  font-size: 0.95rem;
  color: #1d4ed8;
}

#relais-eff-explain-body {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.relais-camera-wrap {
  position: relative;
  margin: 0 0 0.85rem;
  border-radius: var(--radius);
  overflow: hidden;
  background: #0f172a;
}

.relais-camera-wrap video {
  display: block;
  width: 100%;
  max-height: 12rem;
  object-fit: cover;
}

.relais-camera-badge {
  position: absolute;
  top: 0.45rem;
  right: 0.5rem;
  padding: 0.15rem 0.45rem;
  border-radius: 999px;
  background: rgba(220, 38, 38, 0.9);
  color: #fff;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.relais-chrono-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  margin: 0 0 0.85rem;
}

.relais-chrono-icon {
  font-size: clamp(1.8rem, 8vw, 2.4rem);
  line-height: 1;
}

.relais-chrono {
  display: inline-block;
  min-width: 9.5rem;
  padding: 0.45rem 0.85rem;
  border-radius: var(--radius-sm);
  background: #1e293b;
  color: #fff;
  font-size: clamp(1.8rem, 9vw, 2.6rem);
  line-height: 1.1;
  font-weight: 850;
  font-variant-numeric: tabular-nums;
  box-shadow: inset 0 2px 6px rgba(0, 0, 0, 0.35);
}

.relais-table {
  width: 100%;
  margin-bottom: 0.85rem;
  border-collapse: collapse;
  background: rgba(148, 163, 184, 0.18);
  border-radius: var(--radius-sm);
  overflow: hidden;
  font-variant-numeric: tabular-nums;
}

.relais-table th,
.relais-table td {
  padding: 0.55rem 0.35rem;
  text-align: center;
  border: 1px solid rgba(100, 116, 139, 0.25);
}

.relais-table th {
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background: rgba(100, 116, 139, 0.22);
  color: var(--text);
}

.relais-table__row-times td {
  font-size: 0.92rem;
  font-weight: 800;
  background: rgba(255, 255, 255, 0.55);
}

.relais-table__row-speeds td {
  vertical-align: top;
  background: rgba(255, 255, 255, 0.35);
}

.relais-table__speed {
  display: block;
  font-size: 0.84rem;
  font-weight: 800;
  color: var(--text);
}

.relais-table__pct {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.68rem;
  font-weight: 650;
  color: var(--muted);
}

.relais-table td.is-active {
  background: var(--accent-soft);
  color: var(--accent-deep);
  box-shadow: inset 0 0 0 2px var(--accent);
}

.relais-table tr .relais-table__row-times td[data-zone="zt"].is-active,
.relais-table td[data-zone="zt"].is-active {
  background: rgba(245, 158, 11, 0.2);
  color: #b45309;
  box-shadow: inset 0 0 0 2px #d97706;
}

.relais-actions {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.relais-action-btn {
  width: 100%;
  min-height: clamp(4.5rem, 22vw, 6.5rem);
  border: none;
  border-radius: var(--radius);
  color: #fff;
  font: inherit;
  font-size: clamp(1.25rem, 6vw, 1.85rem);
  font-weight: 900;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
}

.relais-action-btn--depart {
  background: linear-gradient(135deg, #15803d 0%, #22c55e 100%);
}

.relais-action-btn--entree,
.relais-action-btn--sortie {
  background: linear-gradient(135deg, #b45309 0%, #f59e0b 100%);
}

.relais-action-btn--arrivee {
  background: linear-gradient(135deg, #1d4ed8 0%, #3b82f6 100%);
}

.relais-action-btn:active {
  transform: scale(0.99);
}

.relais-reset {
  width: 100%;
  justify-content: center;
  margin-top: 0.7rem;
}

.relais-bilan-card {
  border-top: 3px solid var(--accent);
  overflow: hidden;
}

.relais-bilan-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.3);
}

.relais-bilan-hero--compact {
  margin-bottom: 0.75rem;
  padding-bottom: 0.65rem;
}

.relais-bilan-hero__eyebrow {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--accent-deep);
}

.relais-bilan-hero__total {
  text-align: right;
}

.relais-bilan-hero__label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}

.relais-bilan-hero__value {
  display: block;
  margin-top: 0.1rem;
  font-size: clamp(1.6rem, 7vw, 2.2rem);
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  line-height: 1.05;
}

.relais-bilan-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.55rem;
  margin-bottom: 0.85rem;
}

.relais-bilan-zone {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 0.7rem 0.55rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(148, 163, 184, 0.32);
  text-align: center;
}

.relais-bilan-zone--zt {
  border-color: rgba(245, 158, 11, 0.45);
  background: linear-gradient(180deg, rgba(255, 251, 235, 0.95), rgba(255, 255, 255, 0.85));
}

.relais-bilan-zone__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
}

.relais-bilan-zone__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.1rem;
  padding: 0.12rem 0.45rem;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.relais-bilan-zone--zt .relais-bilan-zone__badge {
  background: rgba(245, 158, 11, 0.22);
  color: #b45309;
}

.relais-bilan-zone__hint {
  font-size: 0.58rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}

.relais-bilan-zone__time {
  font-size: 1.05rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}

.relais-bilan-zone__meta {
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
  margin-top: auto;
}

.relais-bilan-zone__speed {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.relais-bilan-zone__pct {
  font-size: 0.66rem;
  font-weight: 650;
  color: var(--muted);
}

@media (max-width: 26rem) {
  .relais-bilan-strip {
    grid-template-columns: 1fr;
  }
}

.relais-replay {
  margin: 0.85rem 0 0.5rem;
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius);
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  border: 1px solid rgba(148, 163, 184, 0.35);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}

.relais-replay__head {
  margin: 0 0 0.55rem;
}

.relais-replay__title {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--text);
}

.relais-replay__hint {
  margin: 0.2rem 0 0;
  font-size: 0.72rem;
  color: var(--muted);
  line-height: 1.35;
}

.relais-replay__video {
  display: block;
  width: 100%;
  border-radius: var(--radius-sm);
  background: #0f172a;
}

.vitesse-plots-table-wrap {
  overflow-x: auto;
}

.vitesse-plots-table {
  width: 100%;
  min-width: 32rem;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(13, 148, 136, 0.18);
}

.vitesse-plots-table th,
.vitesse-plots-table td {
  padding: 0.65rem 0.5rem;
  text-align: center;
  border: 1px solid rgba(13, 148, 136, 0.12);
  font-variant-numeric: tabular-nums;
}

.vitesse-plots-table th {
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-size: 0.76rem;
  font-weight: 850;
}

.vitesse-plots-table td {
  font-weight: 750;
}

.vitesse-plots-graph {
  margin-top: 1rem;
}

.vitesse-plots-graph h3 {
  margin: 0 0 0.55rem;
  font-size: 1rem;
  color: var(--accent-deep);
}

.vitesse-plots-graph canvas {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.18);
  background: #fff;
}

@media (max-width: 520px) {
  .vitesse-plots-actions .btn {
    flex-basis: 100%;
  }
}

/* --- Zones d'impact badminton --- */
.page-outil--bad-impact {
  max-width: min(46rem, 100%);
}

.bad-impact-intro {
  margin: -0.35rem 0 0.85rem;
  text-align: center;
}

.bad-impact-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.bad-impact-card__top h2,
.bad-impact-card__top p {
  margin: 0;
}

.bad-impact-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
  flex-shrink: 0;
}

.bad-impact-actions .btn {
  min-height: 2.45rem;
  padding: 0.42rem 0.65rem;
  font-size: 0.8rem;
  box-shadow: none;
}

.bad-impact-settings {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem 0.75rem;
  align-items: end;
  margin: 0 0 0.85rem;
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.035);
}

.bad-impact-settings .field-group {
  margin-bottom: 0;
  min-width: 0;
}

.bad-impact-settings .field-label {
  min-height: 2.55em;
}

.bad-impact-settings:has(#bad-impact-rows-group[hidden]):not(:has(#bad-impact-cols-group[hidden]))
  #bad-impact-cols-group {
  grid-column: 1 / -1;
}

.bad-impact-court {
  position: relative;
  --bad-cols: 3;
  --bad-rows: 3;
  width: min(100%, 23rem);
  aspect-ratio: 6.1 / 6.7;
  margin: 0 auto;
  border: 5px solid #f8fafc;
  border-radius: 18px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(13, 148, 136, 0.18), rgba(8, 145, 178, 0.2)),
    #0f7668;
  box-shadow: inset 0 0 0 2px rgba(15, 23, 42, 0.16), 0 14px 36px rgba(15, 23, 42, 0.18);
  cursor: crosshair;
  touch-action: none;
  user-select: none;
}

.bad-impact-court.is-table-tennis {
  width: min(100%, 24rem);
  aspect-ratio: 5 / 4;
  background:
    linear-gradient(180deg, rgba(37, 99, 235, 0.14), rgba(37, 99, 235, 0.24)),
    #1d4ed8;
}

.bad-impact-court.is-volleyball {
  width: min(100%, 26rem);
  aspect-ratio: 9 / 9;
  background:
    linear-gradient(180deg, rgba(249, 115, 22, 0.2), rgba(245, 158, 11, 0.18)),
    #d97706;
}

.bad-impact-court.is-boxe {
  width: min(100%, 20rem);
  aspect-ratio: 4 / 6;
  background:
    radial-gradient(circle at 50% 24%, rgba(15, 23, 42, 0.08), transparent 24%),
    linear-gradient(180deg, rgba(244, 63, 94, 0.08), rgba(14, 165, 233, 0.08)),
    #f8fafc;
  border-color: rgba(15, 23, 42, 0.16);
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.12);
}

.bad-impact-court:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 4px;
}

.bad-impact-court__zone-grid {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: repeat(var(--bad-cols, 3), 1fr);
  grid-template-rows: repeat(var(--bad-rows, 3), 1fr);
  pointer-events: none;
  z-index: 1;
}

.bad-impact-court.is-boxe .bad-impact-court__zone-grid {
  inset: 2% 18% 3%;
  border-radius: 999px 999px 28px 28px;
  overflow: hidden;
}

.bad-impact-court__zone-grid span {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.25rem;
  border: 2px dashed rgba(255, 255, 255, 0.38);
  color: rgba(255, 255, 255, 0.72);
  font-size: clamp(0.55rem, 2.6vw, 0.72rem);
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.bad-impact-court.is-boxe .bad-impact-court__zone-grid span {
  border-color: rgba(15, 23, 42, 0.22);
  color: rgba(15, 23, 42, 0.72);
}

.bad-impact-body-shape {
  display: none;
}

.bad-impact-court.is-boxe .bad-impact-body-shape {
  display: block;
  position: absolute;
  inset: 5% 19% 4%;
  z-index: 0;
  pointer-events: none;
}

.bad-impact-body-shape__head,
.bad-impact-body-shape__trunk,
.bad-impact-body-shape__legs {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(13, 148, 136, 0.18);
  border: 3px solid rgba(15, 23, 42, 0.32);
}

.bad-impact-body-shape__head {
  top: 0;
  width: 38%;
  aspect-ratio: 1;
  border-radius: 50%;
}

.bad-impact-body-shape__trunk {
  top: 30%;
  width: 66%;
  height: 34%;
  border-radius: 34px 34px 24px 24px;
}

.bad-impact-body-shape__legs {
  bottom: 0;
  width: 58%;
  height: 35%;
  background: transparent;
  border: 0;
}

.bad-impact-body-shape__legs::before,
.bad-impact-body-shape__legs::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 43%;
  background: rgba(13, 148, 136, 0.18);
  border: 3px solid rgba(15, 23, 42, 0.32);
  border-radius: 16px 16px 28px 28px;
}

.bad-impact-body-shape__legs::before {
  left: 0;
}

.bad-impact-body-shape__legs::after {
  right: 0;
}

.bad-impact-line {
  position: absolute;
  z-index: 2;
  background: rgba(255, 255, 255, 0.98);
  pointer-events: none;
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.2);
}

.bad-impact-line--net {
  left: 0;
  right: 0;
  bottom: 0;
  height: 8px;
  background: #111827;
  box-shadow: 0 -2px 0 rgba(255, 255, 255, 0.92), 0 -8px 18px rgba(15, 23, 42, 0.35);
}

.bad-impact-line--net::after {
  content: "FILET";
  position: absolute;
  left: 50%;
  bottom: 0.65rem;
  transform: translateX(-50%);
  padding: 0.12rem 0.5rem;
  border-radius: var(--radius-pill);
  background: rgba(15, 23, 42, 0.86);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.12em;
}

.bad-impact-line--service-top,
.bad-impact-line--service-bottom {
  left: 0;
  right: 0;
  height: 3px;
}

.bad-impact-line--service-top {
  top: 12%;
}

.bad-impact-line--service-bottom {
  top: 70%;
}

.bad-impact-line--center {
  top: 12%;
  bottom: 30%;
  left: 50%;
  width: 3px;
  transform: translateX(-50%);
}

.bad-impact-line--left-corridor,
.bad-impact-line--right-corridor {
  top: 0;
  bottom: 0;
  width: 3px;
}

.bad-impact-line--left-corridor {
  left: 9%;
}

.bad-impact-line--right-corridor {
  right: 9%;
}

.bad-impact-court.is-table-tennis .bad-impact-line--service-top {
  display: none;
}

.bad-impact-court.is-table-tennis .bad-impact-line--service-bottom {
  display: none;
}

.bad-impact-court.is-table-tennis .bad-impact-line--center {
  top: 0;
  bottom: 0;
}

.bad-impact-court.is-table-tennis .bad-impact-line--left-corridor,
.bad-impact-court.is-table-tennis .bad-impact-line--right-corridor {
  display: none;
}

.bad-impact-court.is-volleyball .bad-impact-line--service-top {
  top: 66.666%;
}

.bad-impact-court.is-volleyball .bad-impact-line--service-bottom {
  display: none;
}

.bad-impact-court.is-volleyball .bad-impact-line--center {
  display: none;
}

.bad-impact-court.is-volleyball .bad-impact-line--left-corridor,
.bad-impact-court.is-volleyball .bad-impact-line--right-corridor {
  display: none;
}

.bad-impact-court.is-boxe .bad-impact-line,
.bad-impact-court.is-boxe .bad-impact-line--net::after {
  display: none;
}

.bad-impact-markers {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.bad-impact-marker {
  position: absolute;
  width: 1.65rem;
  height: 1.65rem;
  border-radius: 50%;
  display: grid;
  place-items: center;
  transform: translate(-50%, -50%);
  background: #f97316;
  color: #fff;
  border: 2px solid #fff;
  font-size: 0.72rem;
  font-weight: 900;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.24);
}

.bad-impact-court.is-boxe .bad-impact-marker {
  background: #dc2626;
}

.bad-impact-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0.75rem 0;
}

.bad-impact-summary p {
  margin: 0;
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  text-align: center;
}

.bad-impact-summary span {
  display: block;
  font-size: 0.72rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent-deep);
}

.bad-impact-summary strong {
  display: block;
  margin-top: 0.2rem;
  font-size: 1.35rem;
  line-height: 1.1;
}

.bad-impact-zone-stats {
  display: grid;
  grid-template-columns: repeat(var(--bad-cols, 3), minmax(0, 1fr));
  gap: 0.45rem;
}

.bad-impact-zone-stat {
  min-height: 5rem;
  padding: 0.55rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.04);
  border: 1px solid rgba(148, 163, 184, 0.24);
  text-align: center;
}

.bad-impact-zone-stat.is-active {
  background: rgba(13, 148, 136, var(--bad-zone-alpha));
  border-color: rgba(13, 148, 136, 0.32);
}

.bad-impact-zone-stat span,
.bad-impact-zone-stat small {
  display: block;
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.bad-impact-zone-stat strong {
  display: block;
  margin: 0.1rem 0;
  font-size: 1.55rem;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

@media (max-width: 560px) {
  .bad-impact-card__top {
    display: block;
  }

  .bad-impact-actions {
    justify-content: stretch;
    margin-top: 0.7rem;
  }

  .bad-impact-actions .btn {
    flex: 1 1 8rem;
  }

  .bad-impact-settings {
    grid-template-columns: 1fr;
  }

  .bad-impact-settings:has(#bad-impact-rows-group[hidden]):not(:has(#bad-impact-cols-group[hidden]))
    #bad-impact-cols-group {
    grid-column: auto;
  }

  .bad-impact-summary {
    grid-template-columns: 1fr;
  }

  .bad-impact-zone-stats {
    grid-template-columns: repeat(var(--bad-cols, 3), minmax(0, 1fr));
  }
}

/* --- Test VMA --- */
.page-outil--vma {
  max-width: min(42rem, 100%);
}

.vma-tabs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
  gap: 0.45rem;
  margin: 0 0 0.85rem;
}

.vma-tab {
  min-height: 3rem;
  padding: 0.55rem 0.45rem;
  border-radius: var(--radius-sm);
  border: 2px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.92);
  color: var(--text);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1.15;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.vma-tab.is-active {
  border-color: rgba(13, 148, 136, 0.5);
  background: var(--accent-soft);
  color: var(--accent-deep);
  box-shadow: 0 8px 20px rgba(13, 148, 136, 0.12);
}

.vma-explication {
  margin-bottom: 0.85rem;
}

.vma-info-list {
  margin: 0.65rem 0 0;
  padding-left: 1.15rem;
  color: var(--text-muted);
}

.vma-info-list li + li {
  margin-top: 0.35rem;
}

.vma-reglages-row .field-group {
  flex: 1 1 11rem;
  min-width: 0;
}

.vma-reglages-title {
  margin: 1rem 0 0.55rem;
  font-size: 0.95rem;
  color: var(--accent-deep);
}

.vma-demi-result {
  margin-top: 0.75rem;
  padding: 0.9rem 1rem;
  border-radius: var(--radius-sm);
  border: 2px solid rgba(234, 179, 8, 0.55);
  background: linear-gradient(180deg, #fef9c3, #fff7ed);
  color: #78350f;
  text-align: center;
}

.vma-demi-result__label {
  display: block;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.vma-demi-result__value {
  display: block;
  margin: 0.2rem 0;
  font-size: clamp(2.25rem, 13vw, 3.5rem);
  line-height: 1;
  font-weight: 850;
  font-variant-numeric: tabular-nums;
}

.vma-demi-result__hint {
  display: block;
  font-size: 0.88rem;
  font-weight: 600;
}

.vma-chrono-card {
  text-align: center;
  border-top: 3px solid var(--accent);
}

.vma-phase {
  margin: 0 0 0.2rem;
  font-size: 0.85rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.vma-time {
  margin: 0;
  font-size: clamp(3.8rem, 20vw, 6rem);
  font-weight: 850;
  line-height: 1;
  letter-spacing: -0.06em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.vma-time-label {
  display: block;
  margin-bottom: 0.15rem;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.vma-plot-timer {
  margin: 0.65rem auto 0;
  padding: 0.6rem 0.75rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.vma-plot-timer strong {
  display: block;
  font-size: clamp(2rem, 11vw, 3rem);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.vma-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.6rem;
  margin-top: 1rem;
}

.vma-actions .btn {
  flex: 1 1 8rem;
}

.vma-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem;
}

.vma-stat {
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.04);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.vma-stat__label {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.vma-stat strong {
  display: block;
  font-size: clamp(1rem, 4vw, 1.2rem);
  line-height: 1.2;
  color: var(--text);
}

@media (max-width: 520px) {
  .vma-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .vma-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem;
  }

  .vma-actions .btn {
    width: 100%;
    min-width: 0;
  }

  .vma-stats {
    grid-template-columns: 1fr;
  }
}

/* --- Calcul 1RM --- */
.page-outil--1rm {
  max-width: min(40rem, 100%);
}

.rm-formules {
  border: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.rm-formule-option {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 2px solid rgba(15, 23, 42, 0.08);
  background: rgba(15, 23, 42, 0.02);
  cursor: pointer;
}

.rm-formule-option:has(input:checked) {
  border-color: rgba(13, 148, 136, 0.45);
  background: var(--accent-soft);
}

.rm-formule-option input {
  margin-top: 0.2rem;
  flex-shrink: 0;
}

.rm-formule-option__text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.rm-formule-option__hint {
  font-size: 0.85rem;
  color: var(--text-muted);
  font-weight: 500;
}

.rm-result-card {
  border-top: 3px solid var(--accent);
}

.rm-result-box {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.5rem;
  margin: 0.25rem 0 0.5rem;
}

.rm-result-label {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
  width: 100%;
}

.rm-result-box strong {
  font-size: clamp(2rem, 10vw, 2.75rem);
  font-weight: 800;
  line-height: 1;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.rm-result-unit {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-muted);
}

.rm-detail {
  margin: 0;
}

.rm-formules-aide .rm-formule-bloc {
  margin: 1rem 0 0;
  padding: 0.75rem 0 0;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.rm-formules-aide .rm-formule-bloc:first-of-type {
  border-top: none;
  padding-top: 0;
}

.rm-formule-bloc__titre {
  margin: 0 0 0.35rem;
  font-size: 1rem;
  color: var(--accent-deep);
}

.rm-formule-bloc__eq {
  margin: 0 0 0.5rem;
  font-family: ui-monospace, "Cascadia Code", "Consolas", monospace;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text);
}

.field-row--vitesse-distance {
  align-items: flex-end;
}

.field-row--vitesse-distance .field-group--grow {
  flex: 1 1 10rem;
  min-width: 0;
}

.field-row--vitesse-distance .field-group--unite {
  flex: 0 1 9rem;
  min-width: 7rem;
}

.field-row--vitesse-temps .field-group {
  flex: 1 1 8rem;
  min-width: 0;
}

.vitesse-resultats {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.vitesse-result-box {
  margin-top: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.5rem;
}

.vitesse-result-box strong {
  margin-bottom: 0;
  flex: 1 1 auto;
  min-width: 0;
}

.vitesse-result-label {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
  width: 100%;
}

.vitesse-result-unit {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-muted);
}

/* --- Pages outil communes --- */
.page-outil {
  min-height: 100vh;
  min-height: 100dvh;
  padding: max(0.75rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right))
    max(1.5rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
  max-width: min(40rem, 100%);
  margin: 0 auto;
}

@media (min-width: 768px) {
  .page-outil {
    max-width: min(44rem, 100%);
    padding-left: max(1.5rem, env(safe-area-inset-left));
    padding-right: max(1.5rem, env(safe-area-inset-right));
  }
}

.page-outil__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 1.35rem;
}

.tool-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.65rem;
  height: 2.65rem;
  padding: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--border);
  color: var(--text);
  text-decoration: none;
  font-weight: 700;
  font-size: 0;
  letter-spacing: 0.01em;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.tool-back::before {
  content: "🏠";
  font-size: 1.25rem;
  line-height: 1;
  font-weight: 850;
}

.tool-back:hover {
  background: #fff;
  border-color: rgba(13, 148, 136, 0.35);
  box-shadow: 0 6px 20px rgba(13, 148, 136, 0.15);
  transform: translateY(-1px);
}

.tool-back:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.tool-back__chev {
  display: none;
}

.page-outil__header h1 {
  margin: 0;
  flex: 1;
  min-width: 200px;
  text-align: center;
  font-size: clamp(1.2rem, 4vw, 1.5rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.page-outil__header--has-info {
  position: relative;
  padding-right: 3.25rem;
}

.tool-info-btn {
  position: absolute;
  top: 0;
  right: 0;
  width: 2.6rem;
  height: 2.6rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.35);
  color: var(--accent-deep);
  cursor: pointer;
  font: inherit;
  box-shadow: 0 2px 10px rgba(13, 148, 136, 0.12);
  transition: background 0.2s, transform 0.15s;
}

.tool-info-btn .info-icon {
  width: 1.35rem;
  height: 1.35rem;
}

.tool-info-btn:hover {
  background: #fff;
  transform: scale(1.05);
}

.tool-info-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.tool-info-dialog__intro {
  margin: 0 0 0.85rem;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.45;
  color: var(--accent-deep);
}

.card {
  background: linear-gradient(165deg, #ffffff 0%, #f8fafc 100%);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid rgba(255, 255, 255, 0.9);
  padding: 1.35rem 1.3rem;
  margin-bottom: 1rem;
  position: relative;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.card h2 {
  margin: 0 0 0.85rem;
  font-size: 0.82rem;
  color: var(--accent-deep);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

label.field-label {
  display: block;
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 0.35rem;
}

.field-label--with-meta,
.orient-field__label--with-meta {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.field-label__meta,
.orient-field__meta {
  font-weight: 500;
  font-size: 0.82rem;
  color: var(--text-muted);
}

.orient-field__label--with-meta .orient-field__main {
  font-weight: 600;
}

input[type="text"],
input[type="number"],
input[type="date"],
input[type="search"],
input[type="file"],
select,
textarea {
  width: 100%;
  max-width: 100%;
  padding: 0.7rem 0.85rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font: inherit;
  background: #fff;
  transition: border-color 0.15s, box-shadow 0.15s;
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: rgba(13, 148, 136, 0.55);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

textarea {
  min-height: 80px;
  resize: vertical;
}

.field-group {
  margin-bottom: 1rem;
}

.field-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: flex-end;
}

.field-row .field-group {
  flex: 1;
  min-width: 100px;
  margin-bottom: 0;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.65rem 1.1rem;
  min-height: 44px;
  border-radius: 10px;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.btn--primary {
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 55%, var(--accent-2) 130%);
  color: #fff;
  box-shadow: 0 4px 14px rgba(13, 148, 136, 0.35);
}

.btn--primary:hover {
  background: linear-gradient(135deg, #115e59 0%, var(--accent-deep) 100%);
  filter: none;
  box-shadow: 0 6px 20px rgba(13, 148, 136, 0.4);
}

.btn--ghost {
  background: rgba(255, 255, 255, 0.85);
  color: var(--accent-deep);
  border: 1px solid var(--border);
}

.btn--ghost:hover {
  background: #fff;
  border-color: rgba(13, 148, 136, 0.3);
}

.btn--danger {
  background: linear-gradient(135deg, #be123c 0%, #e11d48 100%);
  color: #fff;
  box-shadow: 0 4px 14px rgba(190, 18, 60, 0.25);
}

.btn--danger:hover {
  filter: brightness(1.05);
  box-shadow: 0 6px 18px rgba(190, 18, 60, 0.35);
}

.btn--small {
  padding: 0.45rem 0.85rem;
  font-size: 0.85rem;
  min-height: 40px;
}

.btn--labeled {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.55rem 1rem;
  min-height: 48px;
}

.btn--labeled .btn__icon {
  font-size: 1.15rem;
  line-height: 1;
}

.btn--labeled .btn__text {
  font-weight: 700;
  font-size: 0.875rem;
}

.btn--labeled.btn--small {
  min-height: 42px;
  padding: 0.4rem 0.75rem;
}

.result-box {
  background: linear-gradient(145deg, var(--accent-soft) 0%, #f0fdfa 100%);
  border: 1px solid rgba(13, 148, 136, 0.22);
  border-radius: var(--radius);
  padding: 1.1rem 1.2rem;
  margin-top: 0.75rem;
}

.result-box strong {
  font-size: 1.35rem;
  display: block;
  margin-bottom: 0.35rem;
}

.hint {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-top: 0.5rem;
}

.msg-error {
  color: var(--danger);
  font-size: 0.875rem;
  margin-top: 0.35rem;
}

.msg-ok {
  color: var(--success);
  font-size: 0.875rem;
  margin-top: 0.35rem;
}

/* Dispenses : bascule liste / formulaire */
.dispense-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.dispense-nav__btn {
  min-height: 48px;
  padding: 0.65rem 0.5rem;
  font: inherit;
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1.2;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background 0.18s, border-color 0.18s, color 0.18s, box-shadow 0.18s;
}

@media (hover: hover) {
  .dispense-nav__btn:hover {
    background: var(--accent-soft);
  }

  .dispense-nav__btn--active:hover {
    background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 50%, var(--accent-2) 100%);
    color: #fff;
    border-color: transparent;
  }
}

.dispense-nav__btn:not(.dispense-nav__btn--active):active {
  background: var(--accent-soft);
  color: var(--accent-deep);
  border-color: rgba(13, 148, 136, 0.35);
}

.dispense-nav__btn--active {
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 50%, var(--accent-2) 100%);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 18px rgba(13, 148, 136, 0.35);
}

.dispense-nav__btn--active:active {
  background: linear-gradient(135deg, #115e59 0%, var(--accent-deep) 100%);
  color: #fff;
  border-color: transparent;
}

.dispense-nav__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

.dispense-feedback {
  margin: 0 0 0.75rem;
  padding: 0.65rem 0.85rem;
  border-radius: 10px;
  text-align: center;
  font-size: 0.9rem;
  font-weight: 600;
}

.dispense-feedback--ok {
  background: var(--success-bg);
  color: var(--success);
  border: 1px solid rgba(13, 148, 136, 0.25);
}

.dispense-feedback--error {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid #f0b4b4;
}

.dispense-view[hidden] {
  display: none !important;
}

/* Dispenses list */
.filter-bar {
  margin-bottom: 1rem;
}

.dispense-list-options {
  margin-bottom: 1rem;
}

.dispense-hide-done-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.dispense-hide-done-label input[type="checkbox"] {
  width: 1.15rem;
  height: 1.15rem;
  margin: 0;
  flex-shrink: 0;
  accent-color: var(--accent);
}

/* Formulaire dispense : date + durée sur une même ligne, colonnes équilibrées */
.dispense-import-classe {
  margin-bottom: 0.5rem;
}

.dispense-import-hint {
  margin-top: 0;
  margin-bottom: 1rem;
}

.field-row--dispense-dates {
  align-items: flex-end;
}

.field-row--dispense-dates .field-group {
  flex: 1 1 140px;
  min-width: 0;
}

.dispense-item {
  border-radius: var(--radius);
  border: 1px solid var(--border);
  padding: 0.7rem;
  margin-bottom: 0.5rem;
  background: var(--surface);
}

.dispense-item--active {
  border-color: #e8a0a0;
  background: var(--danger-bg);
}

.dispense-item--done {
  border-color: #a3d9b8;
  background: var(--success-bg);
}

.dispense-item__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 0.5rem;
  align-items: center;
}

.dispense-item__main {
  min-width: 0;
}

.dispense-item__days {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 4.15rem;
  padding: 0.28rem 0.45rem;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.1);
  text-align: center;
  gap: 0.05rem;
}

.dispense-item__days-num {
  font-size: 1.1rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--accent-deep);
}

.dispense-item__days--active .dispense-item__days-num {
  color: var(--danger);
}

.dispense-item__days--done .dispense-item__days-num {
  color: var(--text-muted);
}

.dispense-item__days-label {
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}

.dispense-item__days--done .dispense-item__days-label {
  opacity: 0.85;
}

.dispense-item__title {
  font-weight: 700;
  margin: 0 0 0.1rem;
  font-size: 0.98rem;
}

.dispense-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.35rem;
  margin-top: 0;
}

.dispense-note {
  margin: 0.4rem 0 0;
  padding-top: 0.4rem;
  border-top: 1px solid rgba(148, 163, 184, 0.22);
  font-size: 0.86rem;
  color: var(--text-muted);
}

.dispense-photo-field input[type="file"] {
  cursor: pointer;
}

.dispense-photo-hint {
  margin: 0.4rem 0 0.65rem;
}

.dispense-photo-preview {
  display: grid;
  grid-template-columns: 6.5rem minmax(0, 1fr);
  gap: 0.75rem;
  align-items: center;
  padding: 0.65rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: var(--radius-sm);
  background: rgba(248, 250, 252, 0.9);
}

.dispense-photo-preview[hidden] {
  display: none;
}

.dispense-photo-preview__open {
  display: block;
  width: 6.5rem;
  aspect-ratio: 4 / 3;
  padding: 0;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: #fff;
  cursor: zoom-in;
}

.dispense-photo-preview__open img,
.dispense-photo-action img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.dispense-photo-preview__meta {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  align-items: center;
  justify-content: space-between;
  color: var(--text-muted);
  font-size: 0.86rem;
}

.dispense-photo-action {
  width: 58px;
  height: 48px;
  padding: 0.25rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.92);
  overflow: hidden;
  cursor: zoom-in;
  box-shadow: none;
}

.dispense-photo-dialog {
  width: min(62rem, calc(100vw - 1rem));
  height: min(92dvh, 50rem);
  max-width: none;
  max-height: none;
  padding: 0;
  border: none;
  border-radius: var(--radius);
  background: #f8fafc;
  overflow: hidden;
}

.dispense-photo-dialog::backdrop {
  background: rgba(15, 23, 42, 0.62);
}

.dispense-photo-dialog__form {
  height: 100%;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.dispense-photo-dialog__header {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.85rem 1rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.28);
  background: #fff;
}

.dispense-photo-dialog__header h2 {
  margin: 0;
  font-size: 1rem;
  color: var(--accent-deep);
}

.dispense-photo-dialog__close {
  width: 2.35rem;
  height: 2.35rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 999px;
  background: #fff;
  color: var(--text);
  font: inherit;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
}

.dispense-photo-dialog__toolbar {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.65rem 0.75rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.82);
}

.dispense-photo-dialog__zoom {
  min-width: 4.7rem;
  color: var(--text-muted);
  font-weight: 800;
  text-align: center;
}

.dispense-photo-dialog__viewport {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  display: grid;
  place-items: start center;
  padding: 1rem;
  background: #e2e8f0;
}

.dispense-photo-dialog__viewport img {
  display: block;
  height: auto;
  border-radius: var(--radius-sm);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.24);
}

@media (max-width: 420px) {
  .dispense-item__head {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .dispense-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
  }

  .dispense-photo-preview {
    grid-template-columns: 1fr;
  }

  .dispense-photo-preview__open {
    width: 100%;
    max-width: 14rem;
  }

  .dispense-photo-dialog {
    width: 100vw;
    height: 100dvh;
    border-radius: 0;
  }
}

/* Accessibilité : texte masqué visuellement mais lu par les lecteurs d’écran */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.btn-icon-emoji {
  font-size: 1.35rem;
  line-height: 1;
  display: block;
}

.btn--icon-only {
  min-width: 48px;
  min-height: 48px;
  padding: 0.5rem 0.65rem;
}

.input-readonly {
  background: var(--accent-soft);
  color: var(--text-muted);
  cursor: default;
}

.dispense-nav__btn--icon {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.1rem;
  min-height: 52px;
}

.field-row--actions {
  margin-top: 1rem;
  align-items: center;
}

/* Championnat poule — zone plus large sur tablette */
.page-outil--champ {
  max-width: min(52rem, 100%);
}

/* Accordéons (Gestion des équipes, Actions) */
.card.card--accordion {
  padding: 0;
}

.card--accordion > summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1.05rem 1.25rem;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.card--accordion > summary::-webkit-details-marker {
  display: none;
}

.card--accordion__title {
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.card--accordion__chev {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.22);
  position: relative;
  transition: background 0.18s ease, border-color 0.18s ease;
}

.card--accordion > summary:hover .card--accordion__chev {
  background: #d1fae5;
  border-color: rgba(13, 148, 136, 0.35);
}

.card--accordion__chev::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 42%;
  width: 0.5rem;
  height: 0.5rem;
  border-right: 2.5px solid var(--accent-deep);
  border-bottom: 2.5px solid var(--accent-deep);
  transform: translate(-50%, -50%) rotate(45deg);
  transition: transform 0.22s ease;
}

.card--accordion[open] > summary .card--accordion__chev::after {
  top: 55%;
  transform: translate(-50%, -50%) rotate(-135deg);
}

.card--accordion__panel {
  padding: 0 1.25rem 1.25rem;
  border-top: 1px solid rgba(148, 163, 184, 0.35);
}

.card--accordion__panel > .hint:first-child {
  margin-top: 0;
  padding-top: 0.85rem;
}

.champ-gestion-actions {
  margin-top: 1.15rem;
  padding-top: 1.1rem;
  border-top: 1px solid rgba(148, 163, 184, 0.35);
}

.champ-action-toggle {
  border-bottom: 1px solid rgba(148, 163, 184, 0.3);
}

.champ-action-toggle > summary {
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}

.champ-action-toggle > .card--accordion__panel {
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}

.champ-gestion-actions__label {
  margin: 0 0 0.65rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.card--accordion > summary:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.champ-team-list {
  list-style: none;
  margin: 0.75rem 0 0;
  padding: 0;
}

.champ-team-empty {
  list-style: none;
  color: var(--text-muted);
  font-size: 0.9rem;
  padding: 0.5rem 0;
}

.champ-team-group-title {
  list-style: none;
  margin: 0.55rem 0 0.35rem;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.champ-team-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.65rem 0.85rem;
  background: var(--accent-soft);
  border-radius: 10px;
  margin-bottom: 0.5rem;
  border: 1px solid var(--border);
}

.champ-team-row[style*="--poule-bg"] {
  background: var(--poule-bg);
  border-color: var(--poule-border);
}

.champ-team-name {
  font-weight: 600;
  word-break: break-word;
  min-width: 0;
  flex: 1 1 auto;
}

.champ-team-actions {
  display: flex;
  gap: 0.35rem;
  flex-shrink: 0;
}

.champ-team-poule-current {
  flex-shrink: 0;
  flex: 0 0 auto;
  width: clamp(6.4rem, 22vw, 9rem);
  max-width: 100%;
  min-height: 36px;
  border-radius: 999px;
  padding: 0.2rem 1.6rem 0.2rem 0.55rem;
  border: 1px solid var(--border);
  font-weight: 700;
  font-size: 0.82rem;
  background: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.champ-team-poule-current[style*="--poule-bg"] {
  background: var(--poule-bg);
  border-color: var(--poule-border);
  color: var(--poule-text);
}

.champ-team-level {
  flex-shrink: 0;
}

.champ-team-level__input {
  width: 5rem;
  min-height: 38px;
  text-align: center;
  font-weight: 600;
}

.champ-team-level__badge {
  flex-shrink: 0;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.2rem 0.55rem;
  font-size: 0.78rem;
  color: var(--text-muted);
  background: rgba(255, 255, 255, 0.8);
}

.champ-team-level__select {
  min-width: 5.6rem;
  min-height: 36px;
  border-radius: 999px;
  padding: 0.2rem 0.5rem;
  font-weight: 700;
  font-size: 0.8rem;
}

/* Championnat - responsive mobile */
@media (max-width: 700px) {
  .champ-gestion-menu {
    display: block;
    border-radius: var(--radius-sm);
  }

  .champ-gestion-menu__item {
    display: block;
    width: 100%;
    text-align: left;
    border-right: 0;
    border-bottom: 1px solid var(--border);
    border-radius: 0;
  }

  .champ-gestion-menu__item:last-child {
    border-bottom: 0;
  }

  .champ-gestion-menu__indicator {
    display: none;
  }

  .champ-add-row.field-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.55rem;
  }

  .champ-add-row.field-row .btn {
    width: 100%;
    justify-content: center;
  }

  .champ-segment-row {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
  }

  .champ-segment--inline {
    max-width: 100%;
    justify-content: flex-start;
  }

  .champ-team-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.45rem;
    align-items: stretch;
    padding: 0.7rem;
  }

  .champ-team-name {
    font-size: 0.95rem;
  }

  .champ-team-level,
  .champ-team-level__badge {
    justify-self: start;
  }

  .champ-team-poule-current {
    width: min(100%, 10rem);
    justify-self: start;
  }

  .champ-team-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .champ-team-actions .btn {
    min-width: 42px;
    min-height: 42px;
  }

  .champ-pools-board {
    grid-template-columns: 1fr;
  }

  .champ-pools-board__col {
    padding: 0.6rem;
  }

  .match-row {
    grid-template-columns: 1fr 3.2rem 1rem 3.2rem 1fr;
    gap: 0.3rem;
    padding: 0.65rem 0.55rem;
  }

  .match-row__name {
    font-size: 0.82rem;
  }

  .match-row__score {
    min-height: 44px;
    font-size: 1rem;
    padding: 0.3rem 0.2rem;
  }

  .champ-table {
    min-width: 32rem;
    font-size: 0.82rem;
  }

  .champ-table th,
  .champ-table td {
    padding: 0.42rem 0.32rem;
  }
}

@media (max-width: 420px) {
  .champ-segment__btn {
    padding: 0.3rem 0.55rem;
    font-size: 0.8rem;
  }

  .match-row {
    grid-template-columns: 1fr 2.9rem 0.8rem 2.9rem 1fr;
    padding: 0.55rem 0.45rem;
  }

  .match-row__name {
    font-size: 0.76rem;
  }

  .match-row__score {
    min-height: 40px;
    font-size: 0.95rem;
  }

  .champ-journee__title {
    font-size: 0.72rem;
  }
}

.champ-add-btn {
  flex-shrink: 0;
}

.champ-toolbar {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  align-items: stretch;
}

.champ-toolbar--labeled .btn {
  width: 100%;
  justify-content: flex-start;
}

@media (min-width: 540px) {
  .champ-toolbar--labeled {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
  }

  .champ-toolbar--labeled .btn {
    width: auto;
    justify-content: center;
  }
}

.champ-add-field {
  flex: 1;
  margin-bottom: 0;
  min-width: 0;
}

.champ-segment {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.champ-segment-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.champ-gestion-menu-card {
  margin-top: 8px;
}

.champ-gestion-menu {
  position: relative;
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 999px;
  overflow: hidden;
  background: #fff;
}

.champ-gestion-menu__item {
  position: relative;
  z-index: 1;
  flex: 1 1 0;
  border: 0;
  border-right: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  text-align: center;
  padding: 0.35rem 0.65rem;
  font-weight: 600;
  font-size: 0.85rem;
  display: flex;
  gap: 0.35rem;
  align-items: center;
}

.champ-gestion-menu__item:last-child {
  border-right: 0;
}

.champ-gestion-menu__item.is-active {
  color: var(--accent-deep);
}

.champ-gestion-panel {
  padding: 0.2rem 0;
}

.champ-gestion-menu__indicator {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  background: var(--accent-soft);
  border-right: 1px solid rgba(13, 148, 136, 0.35);
  transition: transform 180ms ease, width 180ms ease;
  pointer-events: none;
}

.champ-segment__btn {
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text);
  border-radius: 999px;
  padding: 0.35rem 0.75rem;
  font-weight: 600;
  font-size: 0.85rem;
}

.champ-segment__btn[style*="--poule-bg"] {
  border-color: var(--poule-border);
  color: var(--poule-text);
}

.champ-segment__btn.is-active {
  background: var(--poule-bg, var(--accent-soft));
  border-color: var(--poule-border, var(--accent));
  color: var(--poule-text, var(--accent-deep));
}

.champ-segment__btn--add {
  min-width: 2.2rem;
  padding: 0.35rem 0.6rem;
  font-size: 1.05rem;
  line-height: 1;
  font-weight: 700;
  border-style: dashed;
}

.champ-segment--inline {
  max-width: 56%;
  justify-content: flex-end;
}

.champ-pools-board {
  margin-top: 0.75rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.55rem;
}

.champ-pools-board__col {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: #fff;
  padding: 0.55rem 0.65rem;
}

.champ-pools-board__col[style*="--poule-bg"] {
  background: var(--poule-bg);
  border-color: var(--poule-border);
}

.champ-pools-board__title {
  margin: 0 0 0.45rem;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.champ-pools-board__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
}

.champ-pools-board__actions {
  display: flex;
  gap: 0.3rem;
}

.champ-pools-board__list {
  margin: 0;
  padding-left: 1rem;
  display: grid;
  gap: 0.15rem;
}

.champ-pools-board__empty {
  list-style: none;
  margin-left: -1rem;
  color: var(--text-muted);
}

.champ-match-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.champ-journee {
  margin-bottom: 0.25rem;
}

.champ-journee__title {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--accent-deep);
  margin: 0 0 0.55rem;
  font-weight: 800;
}

.match-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(3rem, 4.25rem) 1.25rem minmax(3rem, 4.25rem) minmax(0, 1fr);
  gap: 0.4rem 0.35rem;
  align-items: center;
  padding: 0.8rem 0.75rem;
  background: rgba(255, 255, 255, 0.88);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.12);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}

.match-row[style*="--poule-bg"] {
  background: color-mix(in srgb, var(--poule-bg) 62%, #ffffff);
  border-color: var(--poule-border);
}

.match-row__pool {
  grid-column: 2 / 5;
  justify-self: center;
  display: inline-block;
  margin-top: 0.15rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.15rem 0.5rem;
  font-size: 0.75rem;
  color: var(--poule-text, var(--text-muted));
  background: var(--poule-bg, transparent);
  border-color: var(--poule-border, var(--border));
}

.champ-standings-pool-badge {
  margin-right: 0.4rem;
  margin-top: 0;
  vertical-align: middle;
}

.champ-import-preview-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.35rem;
}

.champ-import-preview-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.4);
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.2;
  background: #f8fafc;
  color: #0f172a;
}

.champ-import-preview-chip strong {
  font-size: 0.82rem;
}

.champ-import-preview-decision {
  flex: 1 1 100%;
  display: block;
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.22);
  background: #ecfdf5;
  color: #115e59;
  font-weight: 750;
}

.champ-import-preview-chip--ok {
  background: #dcfce7;
  border-color: #22c55e;
  color: #14532d;
}

.champ-import-preview-chip--warn {
  background: #fef3c7;
  border-color: #f59e0b;
  color: #78350f;
}

.champ-import-preview-chip--neutral {
  background: #e0f2fe;
  border-color: #0ea5e9;
  color: #0c4a6e;
}

.champ-import-preview-chip--muted {
  background: #f1f5f9;
  border-color: #cbd5e1;
  color: #334155;
}

.champ-import-ambiguities {
  border: 2px solid #14b8a6;
  background: linear-gradient(180deg, #ecfeff 0%, #f8fafc 100%);
  box-shadow: 0 6px 18px rgba(20, 184, 166, 0.12);
}

.champ-import-ambiguities .field-label {
  color: #0f766e;
  font-weight: 700;
}

.match-row__name {
  font-weight: 600;
  font-size: 0.9rem;
  word-break: break-word;
  min-width: 0;
}

.match-row__name--away {
  text-align: right;
}

.match-row__sep {
  text-align: center;
  color: var(--text-muted);
  font-weight: 700;
}

.match-row__score {
  width: 100%;
  min-height: 48px;
  text-align: center;
  font-size: 1.1rem;
  font-weight: 700;
  padding: 0.45rem 0.25rem;
}

.champ-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0 -0.25rem;
  padding: 0 0.25rem;
}

.champ-table {
  width: 100%;
  min-width: 36rem;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.champ-table th,
.champ-table td {
  padding: 0.55rem 0.45rem;
  text-align: center;
  border-bottom: 1px solid var(--border);
}

.champ-table th:first-child,
.champ-table td:first-child,
.champ-table th:nth-child(2),
.champ-table td:nth-child(2) {
  text-align: left;
}

.champ-table th {
  background: var(--accent-soft);
  color: var(--text-muted);
  font-weight: 600;
  white-space: nowrap;
}

.champ-table--pool-colored th {
  background: var(--poule-bg);
  color: var(--poule-text);
  border-bottom-color: var(--poule-border);
}

.champ-table th abbr {
  text-decoration: none;
  cursor: help;
  border-bottom: 1px dotted var(--text-muted);
}

.champ-table-empty {
  text-align: center;
  color: var(--text-muted);
  padding: 1rem !important;
}

.champ-management {
  border-color: rgba(13, 148, 136, 0.18);
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.06);
}

.page-outil--champ .session-accordion {
  border-color: rgba(13, 148, 136, 0.18);
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.06);
}

.page-outil--champ .session-accordion > .card--accordion__summary {
  min-height: 4rem;
  background: linear-gradient(90deg, rgba(236, 253, 245, 0.95), rgba(240, 249, 255, 0.8));
}

.page-outil--champ .session-accordion > .card--accordion__panel {
  padding-top: 1rem;
}

.champ-management > .card--accordion__summary {
  min-height: 4rem;
  background: linear-gradient(90deg, rgba(236, 253, 245, 0.95), rgba(240, 249, 255, 0.8));
}

.champ-management > .card--accordion__panel {
  display: grid;
  gap: 0.9rem;
  padding-top: 1rem;
}

.champ-management > .card--accordion__panel > .hint:first-child {
  margin: 0;
  padding: 0.8rem 0.9rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.champ-management-section {
  border: 1px solid rgba(13, 148, 136, 0.18);
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.045);
  overflow: hidden;
}

.champ-management-section > .card--accordion__summary {
  min-height: 3.5rem;
  padding: 0.85rem 0.95rem;
  background: linear-gradient(90deg, rgba(236, 253, 245, 0.92), rgba(240, 249, 255, 0.76));
}

.champ-management-section > .card--accordion__panel {
  padding: 0 0.95rem 0.95rem;
  border-top-color: rgba(13, 148, 136, 0.14);
}

.champ-management-section .card--accordion__title {
  color: #115e59;
}

.champ-management-add-row {
  align-items: flex-end;
  gap: 0.65rem;
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.champ-management .champ-import-classe {
  width: 100%;
  justify-content: center;
  min-height: 46px;
}

.champ-management .champ-segment-row {
  align-items: flex-start;
  padding: 0.65rem;
  border-radius: var(--radius-sm);
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.champ-management .champ-segment {
  flex: 1 1 auto;
}

.champ-management .champ-gestion-menu-card {
  margin-top: 0.3rem;
}

.champ-management .champ-gestion-menu {
  padding: 0.25rem;
  border-radius: var(--radius-sm);
  background: #f8fafc;
  border-color: rgba(148, 163, 184, 0.24);
}

.champ-management .champ-gestion-menu__item {
  justify-content: center;
  border-right: 0;
  border-radius: calc(var(--radius-sm) - 3px);
  min-height: 42px;
}

.champ-management .champ-gestion-menu__indicator {
  top: 0.25rem;
  bottom: 0.25rem;
  border: 1px solid rgba(13, 148, 136, 0.24);
  border-radius: calc(var(--radius-sm) - 3px);
  background: #ffffff;
  box-shadow: 0 6px 16px rgba(13, 148, 136, 0.1);
}

.champ-management .champ-toolbar {
  gap: 0.5rem;
}

.champ-management .champ-team-list {
  display: grid;
  gap: 0.45rem;
  margin-top: 0.9rem;
}

.champ-management .champ-team-row {
  margin-bottom: 0;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.04);
}

.champ-management .champ-team-group-title {
  margin: 0.65rem 0 0.05rem;
  padding-left: 0.2rem;
}

.champ-pools-card {
  margin-top: 0.95rem;
  padding: 0.95rem;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: #ffffff;
}

.champ-pools-card h3 {
  font-size: 0.95rem;
  color: #115e59;
}

.champ-management .champ-pools-board {
  gap: 0.7rem;
}

.champ-management .champ-pools-board__col {
  padding: 0.7rem;
  border-radius: var(--radius-sm);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.champ-management .champ-action-toggle {
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: var(--radius-sm);
  background: #ffffff;
  overflow: hidden;
}

.champ-management .champ-action-toggle > summary {
  padding: 0.75rem 0.85rem;
}

.champ-management .champ-action-toggle > .card--accordion__panel {
  padding: 0 0.85rem 0.85rem;
}

.champ-management--single > .card--accordion__panel {
  gap: 0.75rem;
}

.champ-management--single .champ-management-section {
  width: 100%;
}

.champ-results-accordion,
.champ-session-list {
  margin-bottom: 0.75rem;
}

.champ-results-accordion > .card--accordion__panel,
.champ-session-list > .card--accordion__panel {
  display: block;
}

.champ-results-accordion .champ-table-wrap {
  margin-top: 0.75rem;
  border-radius: var(--radius-sm);
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.champ-results-accordion .champ-match-list {
  margin-top: 0.75rem;
}

.champ-match-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.55rem;
  margin-top: 0.85rem;
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.champ-match-filter__field {
  flex: 1 1 16rem;
  margin-bottom: 0;
}

.champ-match-filter__clear {
  min-height: 46px;
}

.champ-match-filter__empty {
  padding: 0.8rem 0.9rem;
  border-radius: var(--radius-sm);
  background: #f8fafc;
  border: 1px dashed rgba(148, 163, 184, 0.45);
}

.champ-import-scan-actions {
  margin-top: 0.75rem;
}

.champ-management-section--actions {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.champ-management-section--actions > .card--accordion__summary {
  background: linear-gradient(90deg, rgba(240, 249, 255, 0.95), rgba(236, 253, 245, 0.78));
}

.champ-management-section--actions .champ-gestion-actions {
  margin-top: 0;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(148, 163, 184, 0.22);
}

.champ-actions-main {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 0.55rem;
}

.champ-actions-main .btn {
  width: 100%;
  min-height: 48px;
  justify-content: center;
  background: #ffffff;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.04);
}

.champ-actions-main .btn--danger {
  background: linear-gradient(135deg, #be123c 0%, #e11d48 100%);
  color: #ffffff;
  border-color: transparent;
  box-shadow: 0 8px 18px rgba(190, 18, 60, 0.2);
}

.champ-actions-main .btn--danger:hover {
  background: linear-gradient(135deg, #9f1239 0%, #be123c 100%);
  box-shadow: 0 10px 22px rgba(190, 18, 60, 0.28);
}

.champ-management .champ-action-toggle {
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
}

.champ-management .champ-action-toggle > summary {
  background: #ffffff;
}

.champ-management .champ-action-toggle .card--accordion__title {
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.9rem;
}

.champ-management .champ-action-toggle[open] > summary {
  border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}

.session-bar__duplicate-promotion {
  border-color: rgba(8, 145, 178, 0.28);
  background: #f0f9ff;
  color: #075985;
}

.session-bar__duplicate-promotion .btn__text {
  white-space: normal;
}

.session-bar__duplicate-promotion:hover {
  background: #e0f2fe;
  border-color: rgba(8, 145, 178, 0.42);
}

@media (max-width: 700px) {
  .champ-management .champ-gestion-menu {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.4rem;
    padding: 0.35rem;
    border-radius: var(--radius-sm);
    background: #f8fafc;
    overflow: visible;
  }

  .champ-management .champ-gestion-menu__indicator {
    display: none;
  }

  .champ-management .champ-gestion-menu__item {
    width: 100%;
    min-height: 46px;
    justify-content: flex-start;
    text-align: left;
    padding: 0.65rem 0.8rem;
    border: 1px solid transparent;
    border-radius: calc(var(--radius-sm) - 3px);
    background: transparent;
    color: var(--text);
  }

  .champ-management .champ-gestion-menu__item.is-active {
    background: #ffffff;
    color: #115e59;
    border-color: rgba(13, 148, 136, 0.32);
    box-shadow: 0 6px 16px rgba(13, 148, 136, 0.12);
  }
}

@media (min-width: 760px) {
  .champ-management .champ-import-classe {
    width: auto;
  }

  .champ-management-section--share {
    display: inline-block;
    width: calc(50% - 0.4rem);
    vertical-align: top;
  }

  .champ-management--single .champ-management-section--share {
    display: block;
    width: 100%;
  }
}

/* --- Tournoi éliminatoire --- */
.page-outil--tournoi {
  max-width: min(70rem, 100%);
}

.tournoi-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 0.85rem;
}

.tournoi-actions .btn {
  flex: 1 1 12rem;
}

.tournoi-format-field {
  margin-bottom: 1rem;
}

.tournoi-seeding {
  margin-top: 1rem;
  padding: 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.035);
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.tournoi-seeding h3 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  color: var(--accent-deep);
}

.tournoi-seeding-count {
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.1);
  color: var(--accent-deep);
  font-size: 0.74rem;
  font-weight: 850;
}

.tournoi-seeding-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.7rem;
}

.tournoi-seeding-empty {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.9rem;
}

.tournoi-seeding-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(13, 148, 136, 0.12);
}

.tournoi-seeding-row span {
  min-width: 0;
  font-weight: 700;
  word-break: break-word;
}

.tournoi-seeding-remove {
  flex-shrink: 0;
  color: var(--danger, #b91c1c);
}

.tournoi-manuelle-actions {
  margin-top: 0.5rem;
}

.tournoi-level-buttons {
  display: grid;
  grid-template-columns: repeat(5, 2.15rem);
  gap: 0.25rem;
}

.tournoi-level-btn {
  min-height: 2.15rem;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 999px;
  background: #fff;
  color: var(--text-muted);
  font: inherit;
  font-weight: 850;
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.tournoi-level-btn:hover,
.tournoi-level-btn.is-active {
  border-color: rgba(13, 148, 136, 0.5);
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.tournoi-level-btn.is-active {
  box-shadow: inset 0 0 0 1px rgba(13, 148, 136, 0.26);
}

.tournoi-bracket-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-bottom: 0.65rem;
}

.tournoi-bracket-wrap {
  position: relative;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0.4rem 0.25rem 0.55rem;
}

.tournoi-connectors {
  position: absolute;
  inset: 0 auto auto 0;
  overflow: visible;
  pointer-events: none;
  z-index: 0;
}

.tournoi-connector-path {
  fill: none;
  stroke: rgba(13, 148, 136, 0.34);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tournoi-bracket {
  min-width: max-content;
  position: relative;
  z-index: 1;
}

.tournoi-bracket--table {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(13rem, 1fr);
  gap: 0.85rem;
  align-items: stretch;
}

.tournoi-table-block {
  margin-bottom: 1.1rem;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}

.tournoi-table-block:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}

.tournoi-perdants-section {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 2px solid rgba(13, 148, 136, 0.2);
}

.tournoi-perdants-title {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
  color: var(--accent-deep);
}

.tournoi-perdants-hint {
  margin: 0 0 0.85rem;
}

.tournoi-table-title {
  margin: 0 0 0.65rem;
  font-size: 1rem;
  color: var(--text);
}

.tournoi-round {
  display: grid;
  grid-template-rows: auto repeat(var(--tournoi-first-matches, 1), minmax(6.8rem, auto));
  gap: 0.7rem;
  min-width: 13rem;
  padding: 0.65rem;
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, rgba(13, 148, 136, 0.08), rgba(255, 255, 255, 0.45));
  border: 1px solid rgba(13, 148, 136, 0.12);
}

.tournoi-round:nth-child(2n) {
  background: linear-gradient(180deg, rgba(8, 145, 178, 0.09), rgba(255, 255, 255, 0.45));
}

.tournoi-round:nth-child(3n) {
  background: linear-gradient(180deg, rgba(99, 102, 241, 0.08), rgba(255, 255, 255, 0.45));
}

.tournoi-round h3 {
  grid-row: 1;
  align-self: start;
  margin: 0;
  padding: 0.35rem 0.45rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.tournoi-match {
  align-self: center;
  position: relative;
  padding: 0.65rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(13, 148, 136, 0.14);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
  z-index: 1;
}

.tournoi-match__label {
  display: block;
  margin-bottom: 0.4rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.tournoi-match__perdant-hint {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.62rem;
  font-weight: 650;
  line-height: 1.25;
  color: rgba(148, 163, 184, 0.95);
}

.tournoi-match--compact .tournoi-player {
  min-height: 2.15rem;
  margin-top: 0.25rem;
  padding: 0.38rem 0.5rem;
  font-size: 0.86rem;
}

.tournoi-player.is-perdant-hint {
  font-size: 0.62rem;
  font-weight: 650;
  line-height: 1.25;
  color: rgba(148, 163, 184, 0.95);
  background: rgba(248, 250, 252, 0.95);
  border-style: dashed;
  border-color: rgba(148, 163, 184, 0.35);
  cursor: default;
}

.tournoi-player {
  width: 100%;
  min-height: 2.7rem;
  margin-top: 0.35rem;
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  border: 2px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  color: var(--text);
  font: inherit;
  font-weight: 750;
  text-align: left;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.tournoi-player:hover:not(:disabled) {
  border-color: rgba(13, 148, 136, 0.35);
  background: var(--accent-soft);
}

.tournoi-player.is-winner {
  border-color: rgba(13, 148, 136, 0.55);
  background: linear-gradient(135deg, var(--accent-soft), #f0fdfa);
  color: var(--accent-deep);
}

.tournoi-player.is-empty {
  cursor: not-allowed;
  color: var(--text-muted);
  background: rgba(148, 163, 184, 0.12);
}

.tournoi-player.is-waiting {
  font-size: 0.82rem;
  font-weight: 650;
  line-height: 1.25;
}

.tournoi-matchs-list {
  list-style: none;
  margin: 0.85rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.tournoi-matchs-empty {
  color: var(--text-muted);
  font-size: 0.92rem;
  padding: 0.65rem 0;
}

.tournoi-matchs-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.65rem;
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(13, 148, 136, 0.14);
}

.tournoi-matchs-item__tour {
  font-size: 0.7rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.tournoi-matchs-item__players {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
}

.tournoi-matchs-player {
  min-height: 2.2rem;
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(13, 148, 136, 0.2);
  background: #fff;
  color: var(--text);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 800;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.tournoi-matchs-player:hover {
  border-color: rgba(13, 148, 136, 0.45);
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.tournoi-classement {
  min-width: 16rem;
  margin-top: 0.8rem;
  padding: 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(13, 148, 136, 0.14);
}

.tournoi-classement h2 {
  margin: 0 0 0.6rem;
  font-size: 1rem;
}

.tournoi-classement-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.tournoi-classement-list li {
  display: flex;
  gap: 0.45rem;
  padding: 0.35rem 0;
  font-weight: 700;
}

.tournoi-classement-place {
  min-width: 3.8rem;
  color: var(--accent-deep);
}

@media (max-width: 620px) {
  .tournoi-actions .btn {
    flex-basis: 100%;
  }

  .tournoi-seeding-row {
    grid-template-columns: 1fr;
  }
}

/* --- Composition d’équipes homogènes --- */
.page-outil--compo {
  max-width: min(44rem, 100%);
}

.compo-actions-row {
  margin-top: 0.75rem;
  flex-wrap: wrap;
}

.compo-nb-joueurs {
  margin-left: auto;
  align-self: center;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-muted);
  white-space: nowrap;
}

.compo-joueurs {
  margin-top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.compo-joueur-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 1rem;
  padding: 0.65rem 0.85rem;
  background: var(--accent-soft);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.15);
}

.compo-joueur-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  flex: 1 1 100%;
  min-width: 0;
}

.compo-joueur-name {
  font-weight: 600;
  flex: 1 1 auto;
  min-width: 0;
  word-break: break-word;
}

.compo-joueur-actions {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  gap: 0.35rem;
}

.compo-joueur-icon-btn {
  min-width: 2.75rem;
  min-height: 2.75rem;
  padding: 0 0.45rem;
  border-radius: 10px;
}

.compo-joueur-icon-btn .btn__icon {
  font-size: 1.1rem;
  line-height: 1;
}

.compo-joueur-icon-btn--danger:hover {
  border-color: rgba(190, 18, 60, 0.35);
  background: var(--danger-bg);
  color: var(--danger);
}

.compo-level-btns-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-muted);
  align-self: center;
}

.compo-level-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
}

.compo-level-btn {
  min-width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border-radius: 10px;
  border: 2px solid var(--border);
  background: #fff;
  font-weight: 800;
  font-size: 0.95rem;
  font-family: inherit;
  cursor: pointer;
  color: var(--text-muted);
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.12s ease,
    box-shadow 0.15s ease;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.compo-level-btn:hover {
  border-color: rgba(13, 148, 136, 0.45);
  color: var(--accent-deep);
}

.compo-level-btn:active {
  transform: scale(0.96);
}

.compo-level-btn--active {
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 3px 12px rgba(13, 148, 136, 0.35);
}

.compo-level-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.compo-equipes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 17rem), 1fr));
  gap: 1rem;
}

.compo-team-card {
  background: rgba(255, 255, 255, 0.95);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.18);
  padding: 1rem;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.04);
}

.compo-team-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid rgba(13, 148, 136, 0.25);
}

.compo-report-row {
  margin-bottom: 0.75rem;
}

.compo-team-title-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  min-width: 0;
}

.compo-team-color {
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  flex-shrink: 0;
}

.compo-team-name-input {
  flex: 1;
  min-width: 6rem;
  max-width: 100%;
  font-size: 1rem;
  font-weight: 800;
  color: var(--accent-deep);
  padding: 0.35rem 0.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}

.compo-team-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  color: var(--accent-deep);
}

.compo-team-total {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
  background: rgba(13, 148, 136, 0.14);
  padding: 0.3rem 0.7rem;
  border-radius: var(--radius-pill);
}

.compo-team-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.compo-team-player {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.9rem;
}

.compo-team-player:last-child {
  border-bottom: none;
}

.compo-level-badge {
  font-size: 0.7rem;
  font-weight: 800;
  background: var(--accent-soft);
  color: var(--accent-deep);
  padding: 0.2rem 0.45rem;
  border-radius: 6px;
  flex-shrink: 0;
}

.compo-team-player-name {
  font-weight: 600;
  min-width: 0;
  word-break: break-word;
  flex: 1 1 100px;
}

.compo-move-wrap {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  margin-left: auto;
  flex-shrink: 0;
}

.compo-move-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-muted);
}

.compo-move-select {
  width: auto;
  min-width: 6.5rem;
  font-size: 0.85rem;
  padding: 0.4rem 0.5rem;
}

.compo-team-empty {
  color: var(--text-muted);
  font-size: 0.9rem;
  padding: 0.25rem 0;
}

.compo-export-row {
  margin-bottom: 1rem;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0.65rem;
}

.compo-export-row .btn {
  flex: 1 1 0;
  min-width: 0;
}

.page-outil--compo .field-row:not(.compo-actions-row):not(.compo-export-row) .field-group {
  flex: 1 1 100%;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}

@media (max-width: 400px) {
  .match-row {
    grid-template-columns: minmax(0, 1fr) minmax(2.75rem, 3.5rem) 1rem minmax(2.75rem, 3.5rem) minmax(0, 1fr);
    gap: 0.3rem;
  }

  .match-row__score {
    font-size: 1rem;
    min-height: 44px;
  }

  .compo-move-wrap {
    margin-left: 0;
    width: 100%;
    justify-content: space-between;
  }
}

/* --- Synthèse --- */
.page-outil--synthese-eps {
  max-width: min(48rem, 100%);
  --syn-teal: var(--accent);
  --syn-teal-deep: var(--accent-deep);
  --syn-indigo: #6366f1;
  --syn-sky: #0ea5e9;
  --syn-amber: #f59e0b;
  --syn-border: var(--border);
  --syn-shadow-hover: 0 4px 16px rgba(15, 23, 42, 0.08);
}

.synthese-page-header__brand {
  flex: 1;
  min-width: 0;
}

.synthese-page-header__lead {
  margin: 0.25rem 0 0;
  font-size: 0.92rem;
  line-height: 1.45;
  color: var(--text-muted, #64748b);
}

.synthese-mode-wrap {
  display: flex;
  justify-content: center;
  margin: 0 0 1.5rem;
  padding: 0 0.25rem;
}

.synthese-toast {
  margin-bottom: 0.75rem;
  border-radius: var(--radius-sm);
  padding: 0.65rem 0.9rem;
  font-weight: 600;
}

.synthese-toolbar {
  margin-bottom: 1rem;
}

.synthese-toolbar__title {
  margin: 0 0 0.85rem;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.synthese-seg {
  display: flex;
  gap: 0.5rem;
  width: 100%;
  max-width: 22rem;
  padding: 0.35rem;
  border-radius: var(--radius);
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
}

.synthese-seg--mode {
  width: 100%;
  max-width: min(34rem, 100%);
}

.synthese-seg__btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  min-height: 5.25rem;
  padding: 0.85rem 0.65rem;
  border: none;
  border-radius: calc(var(--radius-sm) + 2px);
  background: transparent;
  font: inherit;
  font-weight: 700;
  color: var(--text-muted, #64748b);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}

.synthese-seg__btn--active {
  background: var(--accent-soft);
  color: var(--accent-deep);
  box-shadow: inset 0 0 0 1px rgba(13, 148, 136, 0.25);
}

.synthese-seg__icon {
  font-size: 2.15rem;
  line-height: 1;
}

.synthese-seg__label {
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}

.synthese-main {
  margin-top: 0.5rem;
}

.synthese-panel {
  padding-bottom: 1.5rem;
}

.synthese-stack {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.synthese-empty-state {
  margin: 1.5rem 0;
  padding: 2rem 1.25rem;
  text-align: center;
  color: var(--text-muted, #64748b);
  font-size: 0.95rem;
  border-radius: var(--radius);
  background: var(--surface-alt, #f8fafc);
  border: 1px dashed var(--border);
}

.synthese-hero {
  padding: 0;
  overflow: hidden;
}

.synthese-hero__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.65rem;
  padding: 1rem 1.1rem;
  border-bottom: 1px solid var(--border);
}

.synthese-hero__eyebrow {
  margin: 0 0 0.2rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-deep);
}

.synthese-hero__title {
  margin: 0;
  font-size: clamp(1.25rem, 3vw, 1.55rem);
  font-weight: 800;
  color: var(--text);
  line-height: 1.15;
}

.synthese-stat-list {
  display: grid;
  gap: 0;
}

@media (min-width: 640px) {
  .synthese-stat-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.synthese-stat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.65rem 1.1rem;
  border-bottom: 1px solid var(--border);
}

@media (min-width: 640px) {
  .synthese-stat-row:nth-child(odd) {
    border-right: 1px solid var(--border);
  }
}

.synthese-stat-row:last-child,
.synthese-stat-row:nth-last-child(2):nth-child(odd) {
  border-bottom: none;
}

.synthese-stat-row__lbl {
  font-size: 0.88rem;
  color: var(--text-muted, #64748b);
}

.synthese-stat-row__val {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--accent-deep);
  text-align: right;
}

.synthese-hero__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.synthese-hero__badge--vert {
  background: #d1fae5;
  color: #065f46;
}

.synthese-hero__badge--orange {
  background: #ffedd5;
  color: #9a3412;
}

.synthese-hero__badge--rouge {
  background: #fee2e2;
  color: #991b1b;
}

.synthese-block {
  padding: 0;
  overflow: hidden;
}

.page-outil--synthese-eps .synthese-block.card--accordion > summary {
  align-items: center;
  padding: 0.9rem 1.05rem;
  gap: 0.6rem;
}

.synthese-block__summary .synthese-block__icon {
  flex-shrink: 0;
  font-size: 1.05rem;
  line-height: 1;
}

.synthese-block__summary .card--accordion__title {
  flex: 1;
  min-width: 0;
  text-align: left;
}

.page-outil--synthese-eps .synthese-block.card--accordion > .card--accordion__panel,
.page-outil--synthese-eps .synthese-block.card--accordion > .synthese-block__body {
  padding: 0.95rem 1.05rem 1.1rem;
  border-top: 1px solid var(--border);
}

.page-outil--synthese-eps .synthese-block__body > :first-child {
  margin-top: 0;
}

.page-outil--synthese-eps .synthese-block__body > :last-child {
  margin-bottom: 0;
}

.page-outil--synthese-eps .synthese-block__body .hint:first-child {
  margin-top: 0;
  padding-top: 0;
}

.page-outil--synthese-eps .synthese-block__body .synthese-appel-intro {
  margin-top: 0;
}

.page-outil--synthese-eps .synthese-block__body .synthese-appel-intro--feuille {
  margin-bottom: 0.65rem;
}

.page-outil--synthese-eps .synthese-block__body .synthese-feuille-block {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
}

.page-outil--synthese-eps .synthese-block__body .synthese-feuille-block:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.page-outil--synthese-eps .synthese-block__body .synthese-grille:last-child {
  margin-bottom: 0;
}

.page-outil--synthese-eps .synthese-block__body .synthese-resume-grid {
  gap: 0.75rem;
}

.page-outil--synthese-eps .synthese-block__body .synthese-more:last-child {
  margin-bottom: 0;
}

.synthese-fact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.synthese-fact-list > li,
.synthese-fact-list__item {
  padding: 0.55rem 0.65rem;
  border-radius: var(--radius-sm);
  background: var(--surface-alt, #f8fafc);
  border: 1px solid var(--border);
  font-size: 0.9rem;
  line-height: 1.4;
}

.synthese-fact-list__item--import {
  display: grid;
  gap: 0.2rem;
}

.synthese-fact-list__meta {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--accent-deep);
}

.synthese-fact-list__val {
  color: var(--text);
}

.synthese-more {
  margin-top: 0.65rem;
}

.synthese-more summary {
  cursor: pointer;
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--accent-deep);
}

.synthese-resume-grid {
  display: grid;
  gap: 0.85rem;
}

@media (min-width: 640px) {
  .synthese-resume-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .synthese-resume-meta {
    grid-column: 1 / -1;
  }
}

.synthese-resume-block {
  padding: 0.85rem 0.95rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: #fff;
}

.synthese-resume-block--fort {
  border-left: 3px solid var(--accent);
}

.synthese-resume-block--vigilance {
  border-left: 3px solid #f59e0b;
}

.synthese-resume-block__title {
  margin: 0 0 0.5rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.synthese-resume-block--vigilance .synthese-resume-block__title {
  color: #b45309;
}

.synthese-resume-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1.25rem;
  padding: 0.75rem 0.95rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface-alt, #f8fafc);
}

.synthese-resume-meta__row {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.65rem;
  font-size: 0.88rem;
}

.synthese-resume-meta__row span {
  color: var(--text-muted, #64748b);
}

.synthese-filtres__grid {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 560px) {
  .synthese-filtres__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .synthese-filtres__grid--dates {
    grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  }
}

.synthese-block__icon {
  font-size: 1.05rem;
  line-height: 1;
}

.synthese-filtres-eleve {
  margin-top: 0.75rem;
}

.synthese-filtres__grid--classe {
  grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 560px) {
  .synthese-filtres__grid--eleve {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.synthese-periode {
  margin-top: 0.75rem;
}

.synthese-periode summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--accent-deep);
}

.synthese-actions-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.synthese-profile {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.synthese-profile__avatar {
  flex-shrink: 0;
  width: 3.25rem;
  height: 3.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 1.1rem;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent-2) 100%);
  box-shadow: var(--shadow);
}

.synthese-profile__body {
  flex: 1;
  min-width: 0;
}

.synthese-profile__nom {
  margin: 0 0 0.3rem;
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--syn-teal-deep);
  line-height: 1.2;
}

.synthese-profile__meta {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-muted, #64748b);
  line-height: 1.45;
}

.synthese-profile__comment {
  margin: 0.75rem 0 0;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  background: var(--surface-alt, #f8fafc);
  border: 1px solid var(--border);
  font-size: 0.88rem;
  line-height: 1.45;
}

.synthese-profile__comment-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--syn-teal);
  margin-bottom: 0.25rem;
}

.synthese-list {
  margin: 0;
  padding-left: 1.15rem;
}

.synthese-list li {
  margin-bottom: 0.35rem;
}

.synthese-empty {
  color: var(--text-muted, #64748b);
  font-style: italic;
  margin: 0;
}

.synthese-feed {
  list-style: none;
  margin: 0;
  padding: 0 0 0 0.35rem;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.synthese-feed__item {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.synthese-feed__dot {
  flex-shrink: 0;
  width: 0.55rem;
  height: 0.55rem;
  margin-top: 0.55rem;
  border-radius: 50%;
  background: var(--syn-teal);
  box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.15);
}

.synthese-feed__item--oubli .synthese-feed__dot { background: var(--syn-amber); box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.15); }
.synthese-feed__item--radar .synthese-feed__dot { background: var(--syn-sky); box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15); }
.synthese-feed__item--dispense .synthese-feed__dot { background: var(--syn-rose); box-shadow: 0 0 0 3px rgba(244, 63, 94, 0.15); }
.synthese-feed__item--import .synthese-feed__dot { background: var(--syn-indigo); box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15); }
.synthese-feed__item--activite .synthese-feed__dot { background: var(--syn-teal); }
.synthese-feed__item--session .synthese-feed__dot { background: #8b5cf6; box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.15); }
.synthese-feed__item--observation .synthese-feed__dot { background: #64748b; }

.synthese-feed__card {
  flex: 1;
  min-width: 0;
  padding: 0.65rem 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(248, 250, 252, 0.8);
  border: 1px solid var(--syn-border);
}

.synthese-feed__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin-bottom: 0.25rem;
}

.synthese-feed__card time {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--text-muted, #64748b);
}

.synthese-feed__tag {
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.12rem 0.45rem;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.12);
  color: var(--syn-teal-deep);
}

.synthese-feed__text {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.4;
}

.synthese-feed__detail {
  color: var(--text-muted, #64748b);
  font-size: 0.85rem;
}

.synthese-timeline__type {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--accent);
}

.synthese-insights {
  display: grid;
  gap: 0.65rem;
}

@media (min-width: 560px) {
  .synthese-insights {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.synthese-insight {
  padding: 0.85rem 0.95rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--syn-border);
  background: #fff;
}

.synthese-insight__head {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.45rem;
}

.synthese-insight__icon {
  font-size: 1rem;
}

.synthese-insight__title {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.synthese-insight--engagement { border-left: 3px solid var(--syn-teal); }
.synthese-insight--engagement .synthese-insight__title { color: var(--syn-teal-deep); }
.synthese-insight--regularite { border-left: 3px solid var(--syn-indigo); }
.synthese-insight--regularite .synthese-insight__title { color: var(--syn-indigo); }
.synthese-insight--progres { border-left: 3px solid var(--syn-sky); }
.synthese-insight--progres .synthese-insight__title { color: var(--syn-sky); }
.synthese-insight--vigilance { border-left: 3px solid var(--syn-amber); }
.synthese-insight--vigilance .synthese-insight__title { color: #b45309; }

.synthese-dl {
  margin: 0;
  display: grid;
  gap: 0.5rem;
}

.synthese-dl dt {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted, #64748b);
}

.synthese-dl dd {
  margin: 0.1rem 0 0;
}

.synthese-alerts-grid {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.synthese-alert-card {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.65rem 0.85rem;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  line-height: 1.4;
}

.synthese-alert-card--rouge {
  background: #fef2f2;
  border: 1px solid rgba(239, 68, 68, 0.2);
  color: #991b1b;
}

.synthese-alert-card--orange {
  background: #fff7ed;
  border: 1px solid rgba(245, 158, 11, 0.25);
  color: #9a3412;
}

.synthese-alert-card__icon {
  flex-shrink: 0;
  font-size: 0.95rem;
}

.synthese-eleves-alerts {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.synthese-eleves-alerts li {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.65rem 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(248, 250, 252, 0.9);
  border: 1px solid var(--syn-border);
}

.synthese-puce {
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  flex-shrink: 0;
}

.synthese-puce--vert {
  background: #10b981;
}

.synthese-puce--orange {
  background: #f59e0b;
}

.synthese-puce--rouge {
  background: #ef4444;
}

.synthese-tag {
  font-size: 0.75rem;
  color: var(--text-muted, #64748b);
}

.synthese-copy-bar {
  padding: 0 1rem 1rem;
}

.synthese-hint-top {
  margin: 0;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-sm);
  background: rgba(99, 102, 241, 0.08);
  border: 1px solid rgba(99, 102, 241, 0.15);
  font-size: 0.88rem;
}

.synthese-appel-source {
  margin: 0 0 0.75rem;
  font-size: 0.9rem;
}

.synthese-presence-resume {
  margin: 0 0 0.65rem;
}

.synthese-timeline-intro {
  margin: 0 0 0.5rem;
}

.synthese-timeline__detail {
  color: var(--text-muted, #64748b);
  font-size: 0.88rem;
}

.synthese-cmp-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  margin: 0 0 0.65rem;
  font-size: 0.8rem;
  font-weight: 600;
}

.synthese-cmp__badge {
  display: inline-block;
  padding: 0.15rem 0.45rem;
  border-radius: 4px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.synthese-cmp--above .synthese-cmp__badge {
  background: #d1fae5;
  color: #065f46;
}

.synthese-cmp--below .synthese-cmp__badge {
  background: #fee2e2;
  color: #991b1b;
}

.synthese-cmp--equal .synthese-cmp__badge {
  background: #f1f5f9;
  color: #475569;
}

.synthese-cmp--na .synthese-cmp__badge {
  background: transparent;
  color: var(--text-muted, #94a3b8);
  font-weight: 500;
}

.synthese-grille__note--above {
  color: #047857;
  font-weight: 700;
}

.synthese-grille__note--below {
  color: #b91c1c;
  font-weight: 700;
}

.synthese-grille__moy {
  background: var(--surface-alt, #f8fafc);
}

.synthese-grille__foot th,
.synthese-grille__foot td {
  border-top-width: 2px;
  font-weight: 700;
}

.synthese-appel-highlight {
  border-left: 3px solid var(--accent, #0d9488);
  padding-left: 0.75rem;
}

.synthese-appel-intro {
  margin: 0 0 0.85rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--surface-alt, #f8fafc);
}

.synthese-appel-intro .synthese-stat-row {
  background: #fff;
}

.synthese-appel-intro .synthese-stat-row:nth-child(odd) {
  background: rgba(248, 250, 252, 0.85);
}

.synthese-appel-intro--feuille {
  margin: 0 0 0.65rem;
}

@media (min-width: 640px) {
  .synthese-appel-intro:not(.synthese-appel-intro--feuille) .synthese-stat-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .synthese-appel-intro--feuille .synthese-stat-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.synthese-appel-sub {
  margin: 0 0 0.35rem;
  font-size: 0.88rem;
  color: var(--accent-deep);
}

.synthese-feuille-block {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--border);
}

.synthese-feuille-block:first-of-type {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

.synthese-grille {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  margin: 0.5rem 0 0.75rem;
}

.synthese-grille th,
.synthese-grille td {
  border: 1px solid var(--border);
  padding: 0.4rem 0.55rem;
  text-align: left;
}

.synthese-grille thead th {
  background: var(--surface-alt, #f1f5f9);
  font-weight: 700;
  font-size: 0.8rem;
}

.synthese-grille__val {
  text-align: center;
  font-weight: 600;
}

.synthese-grille__ok {
  color: #047857;
}

.synthese-grille__ko {
  color: #b91c1c;
}

.synthese-grille-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 0.5rem;
}

.synthese-grille--wide th[scope="row"] {
  text-align: left;
  font-weight: 600;
  white-space: nowrap;
}

.synthese-activites-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.synthese-activites-item {
  padding: 0.85rem 0.95rem;
  border-radius: var(--radius-sm);
  background: rgba(248, 250, 252, 0.85);
  border: 1px solid var(--syn-border);
  transition: transform 0.15s, box-shadow 0.15s;
}

.synthese-activites-item:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
}

.synthese-activites-item__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 0.88rem;
  margin-bottom: 0.35rem;
}

.synthese-activites-item__tool {
  display: inline-flex;
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: rgba(13, 148, 136, 0.12);
  color: var(--syn-teal-deep);
}

.synthese-activites-item__session {
  font-weight: 600;
  color: var(--text, #1e293b);
}

.synthese-activites-item__resume {
  margin: 0 0 0.35rem;
  font-weight: 700;
  color: var(--syn-teal-deep);
  font-size: 1rem;
  line-height: 1.35;
}

.synthese-activites-item__date {
  font-weight: 600;
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-left: auto;
}

.synthese-list--compact {
  font-size: 0.9rem;
  margin-top: 0.25rem;
}

/* --- Classes et groupes --- */
.page-outil--classes {
  max-width: min(48rem, 100%);
}

.classes-msg {
  margin-bottom: 0.75rem;
}

.classes-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem;
}

@media (min-width: 720px) {
  .classes-layout {
    grid-template-columns: minmax(10rem, 14rem) minmax(0, 1fr);
    align-items: start;
  }

  .classes-select-hint {
    grid-column: 1 / -1;
  }
}

.classes-sidebar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.classes-subtitle {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.classes-filter-archived {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0 0 0.65rem;
  font-size: 0.82rem;
  color: var(--text-muted);
}

.classes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.classes-list__btn {
  width: 100%;
  text-align: left;
  padding: 0.65rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: #fff;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}

.classes-list__item--archived .classes-list__btn {
  color: #64748b;
  background: #f8fafc;
}

.classes-list__item--active .classes-list__btn {
  background: var(--accent-soft);
  border-color: rgba(13, 148, 136, 0.45);
  color: var(--accent-deep);
}

.classes-reimport-hint {
  margin: 0 0 1rem;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.08);
  border: 1px solid rgba(13, 148, 136, 0.2);
}

.classes-detail-head {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

@media (min-width: 720px) {
  .classes-detail-head {
    display: grid;
    grid-template-columns: 1fr auto auto;
    grid-template-areas:
      "nom nom nom"
      ". archiver supprimer";
    align-items: center;
    column-gap: 0.5rem;
    row-gap: 0.6rem;
  }

  .classes-nom-wrap {
    grid-area: nom;
  }

  #btn-archiver-classe {
    grid-area: archiver;
  }

  #btn-supprimer-classe {
    grid-area: supprimer;
  }
}

.classes-nom-wrap {
  margin-bottom: 0;
  flex: 1;
}

.classes-actions-row {
  margin-bottom: 1rem;
}

.classes-actions-row .btn {
  flex: 1 1 auto;
  min-width: min(100%, 9rem);
}

.compo-import-classe,
.champ-import-classe {
  width: 100%;
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
  justify-content: flex-start;
}

.page-outil--pyramide .card--accordion__panel > .pyramide-import-classe {
  width: 100%;
  margin-top: 0.85rem;
  margin-bottom: 0.75rem;
  justify-content: flex-start;
}

.classes-eleves-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.classes-eleve-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  padding: 0.7rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: #fff;
}

.classes-eleve-item__main {
  min-width: 0;
  flex: 1;
}

.classes-eleve-item__nom {
  display: block;
  font-weight: 700;
}

.classes-eleve-item__meta {
  display: block;
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-top: 0.15rem;
}

.classes-eleve-item__equipe {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.classes-eleve-equipe-pin {
  display: inline-block;
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1px solid rgba(15, 23, 42, 0.18);
  vertical-align: -0.05em;
}

.classes-eleve-equipe-pin--light {
  border-color: rgba(15, 23, 42, 0.28);
}

.classes-eleve-item__actions {
  display: flex;
  gap: 0.35rem;
  flex-shrink: 0;
}

.classes-dialog {
  border: none;
  border-radius: var(--radius);
  padding: 0;
  max-width: min(28rem, calc(100vw - 2rem));
  width: 100%;
}

.classes-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}

.classes-dialog form {
  padding: 1.25rem;
}

.classes-dialog-title {
  margin: 0 0 1rem;
  font-size: 1.1rem;
}

.classes-dialog-actions {
  margin-top: 0.5rem;
}

.import-format-hint {
  margin: 0 0 1rem;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.15);
}

.import-format-hint__lead {
  margin: 0 0 0.5rem;
  font-size: 0.84rem;
}

.import-format-hint__list {
  margin: 0;
  padding: 0 0 0 1.1rem;
  list-style: disc;
}

.import-format-hint__list li {
  margin-bottom: 0.45rem;
  font-size: 0.84rem;
  line-height: 1.4;
}

.import-format-hint__list li:last-child {
  margin-bottom: 0;
}

.import-format-hint__ex {
  display: inline-block;
  margin-right: 0.25rem;
  padding: 0.1rem 0.35rem;
  font-family: ui-monospace, "Cascadia Code", "Consolas", monospace;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--accent-deep);
  background: #fff;
  border-radius: 4px;
  border: 1px solid rgba(13, 148, 136, 0.2);
}

.import-format-hint__note {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.78rem;
  color: var(--text-muted);
  font-weight: 500;
}

.classes-dialog--import {
  max-width: min(36rem, calc(100vw - 2rem));
  max-height: min(90vh, calc(100dvh - 2rem));
  overflow: auto;
}

.classes-dialog--import form {
  min-height: 0;
}

.import-source-hint,
.import-map-hint {
  margin: 0 0 1rem;
  font-size: 0.86rem;
}

.import-source-ou {
  margin: 0.35rem 0;
  text-align: center;
  font-size: 0.82rem;
  color: var(--text-muted);
}

.import-source-erreur,
.import-map-erreur {
  margin: 0.5rem 0 0;
  font-size: 0.86rem;
}

.import-entete-check {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0 0 1rem;
  font-size: 0.88rem;
  cursor: pointer;
}

.import-entete-check input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.import-preview-wrap {
  margin-bottom: 1rem;
}

.import-preview-label {
  margin-bottom: 0.35rem;
}

.import-preview-scroll {
  overflow-x: auto;
  border: 1px solid var(--border, rgba(15, 23, 42, 0.12));
  border-radius: var(--radius-sm);
  max-height: 8rem;
}

.import-preview-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}

.import-preview-table th,
.import-preview-table td {
  padding: 0.35rem 0.5rem;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  white-space: nowrap;
  max-width: 10rem;
  overflow: hidden;
  text-overflow: ellipsis;
}

.import-preview-table th {
  background: var(--accent-soft);
  font-weight: 600;
  text-align: left;
}

.import-mapping-fieldset {
  border: none;
  margin: 0 0 1rem;
  padding: 0;
}

.import-mapping-fieldset .field-label {
  margin-bottom: 0.5rem;
}

.import-mapping-rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.import-mapping-row {
  display: grid;
  grid-template-columns: minmax(8rem, 1fr) minmax(10rem, 1.4fr);
  gap: 0.5rem;
  align-items: center;
}

.import-mapping-label {
  font-size: 0.84rem;
  font-weight: 500;
}

.import-mapping-select {
  width: 100%;
  font-size: 0.84rem;
}

.import-ordre-wrap {
  margin-bottom: 0.75rem;
}

.import-map-info {
  margin: 0 0 0.75rem;
  font-size: 0.84rem;
}

.import-conflits-hint {
  margin: 0 0 1rem;
}

.import-conflits-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  margin-bottom: 1rem;
}

.import-conflit-card {
  padding: 0.75rem 0.9rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: #fff;
}

.import-conflit-card__title {
  margin: 0 0 0.35rem;
  font-size: 0.92rem;
  font-weight: 700;
}

.import-conflit-card__count {
  margin: 0 0 0.5rem;
  font-size: 0.8rem;
  color: var(--text-muted);
}

.import-conflit-card__exemples {
  margin: 0 0 0.65rem;
  padding-left: 1.1rem;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.import-conflit-card__exemples li + li {
  margin-top: 0.2rem;
}

.import-conflit-card__choix {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.import-conflit-radio {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  font-size: 0.84rem;
  cursor: pointer;
}

.import-conflit-radio input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.import-conflits-erreur {
  margin-bottom: 0.75rem;
}

.field-row--eleve-opt .field-group {
  flex: 1 1 10rem;
}

/* --- Import classe (modal) --- */
.import-associate-dialog {
  max-width: 28rem;
}

.import-associate-label {
  margin: 0 0 1rem;
  font-size: 1.05rem;
}

.import-associate-players {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.import-associate-player .field-label {
  margin-bottom: 0.35rem;
}

.imports-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.synthese-associate-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.synthese-associate-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid var(--border);
}

.synthese-associate-row:last-child {
  border-bottom: none;
}

.synthese-associate-row__text {
  flex: 1 1 12rem;
  min-width: 0;
}

.class-import-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right))
    max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
  background: rgba(15, 23, 42, 0.5);
  overflow-y: auto;
}

.class-import-overlay[hidden] {
  display: none !important;
}

body.class-import-open {
  overflow: hidden;
}

.class-import-dialog {
  width: 100%;
  max-width: min(26rem, 100%);
  max-height: min(90vh, 100%);
  overflow-y: auto;
  margin: auto;
}

.class-import-toolbar {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
  flex-wrap: wrap;
}

.class-import-toolbar[hidden] {
  display: none !important;
}

.class-import-list {
  max-height: min(40vh, 320px);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1rem;
  padding: 0.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: #fff;
}

.class-import-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.45rem 0.35rem;
  font-weight: 600;
  cursor: pointer;
}

.class-import-item--button {
  width: 100%;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text);
  font: inherit;
  text-align: left;
}

.class-import-item--button:hover,
.class-import-item--button:focus-visible {
  background: var(--accent-soft);
  outline: none;
}

.class-import-item input {
  margin-top: 0.2rem;
  flex-shrink: 0;
}

.class-import-item--deja-la {
  opacity: 0.55;
  cursor: not-allowed;
  background: rgba(148, 163, 184, 0.12);
}

.class-import-item--deja-la input:disabled {
  cursor: not-allowed;
}

.class-import-item--deja-la span {
  color: var(--text-muted);
}

.class-import-actions {
  flex-direction: column;
}

.class-import-actions .btn {
  width: 100%;
}

.class-import-actions--single #class-import-ok {
  display: none;
}

.liste-import-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin: 0 0 0.75rem;
}

.liste-import-toolbar .btn {
  flex: 0 1 auto;
}

.liste-manuelle-panel {
  margin-bottom: 0.75rem;
}

.liste-manuelle-panel[hidden] {
  display: none !important;
}

.liste-manuelle-ligne-hint[hidden] {
  display: none !important;
}

.liste-manuelle-ligne-hint {
  margin: 0 0 0.5rem;
}

.orient-import-toolbar .orient-import-toolbar__btn {
  flex: 1 1 12rem;
  justify-content: center;
}

@media (min-width: 560px) {
  .class-import-actions {
    flex-direction: row;
  }

  .class-import-actions .btn {
    flex: 1;
    width: auto;
  }
}

/* --- Tirage au sort --- */
.page-outil--tirage {
  max-width: min(40rem, 100%);
}

.tirage-msg {
  margin-bottom: 0.75rem;
}

.tirage-actions-row {
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.tirage-nb {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--accent-deep);
  margin-left: auto;
}

.tirage-participants {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.tirage-participants__item {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.35rem 0.5rem 0.35rem 0.75rem;
  border-radius: 999px;
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.25);
  font-weight: 600;
  font-size: 0.9rem;
}

.tirage-participants__remove {
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 1.1rem;
  line-height: 1;
  padding: 0 0.2rem;
  cursor: pointer;
  border-radius: 4px;
}

.tirage-participants__remove:hover {
  color: var(--danger);
}

.tirage-draw-card {
  text-align: center;
}

.tirage-resultat {
  margin: 0 0 1rem;
  padding: 1.5rem 1rem;
  border-radius: var(--radius);
  background: linear-gradient(145deg, var(--accent-soft), #fff);
  border: 2px solid rgba(13, 148, 136, 0.35);
}

.tirage-resultat--flash {
  animation: tirage-flash 0.4s ease;
}

@keyframes tirage-flash {
  0% {
    transform: scale(0.96);
    opacity: 0.7;
  }
  50% {
    transform: scale(1.02);
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.tirage-resultat__label {
  display: block;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-deep);
  margin-bottom: 0.35rem;
}

.tirage-resultat__nom {
  display: block;
  font-size: clamp(1.5rem, 6vw, 2.25rem);
  font-weight: 800;
  color: var(--accent-deep);
  line-height: 1.2;
  word-break: break-word;
}

.tirage-resultat-hint {
  margin-bottom: 1rem;
}

.tirage-option {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
  font-size: 0.9rem;
  cursor: pointer;
}

.tirage-btn-draw {
  width: 100%;
  max-width: 20rem;
  margin: 0 auto;
  font-size: 1.05rem;
  padding: 0.85rem 1.25rem;
}

@media (max-width: 559px) {
  .page-outil--tirage .field-row.tirage-actions-row .btn {
    flex: 1 1 100%;
    width: 100%;
  }

  .page-outil--tirage .tirage-nb {
    flex: 1 1 100%;
    margin-left: 0;
    text-align: center;
  }
}

/* --- Vidéo avec retard --- */
.page-outil--video-retard {
  max-width: min(48rem, 100%);
}

.page-outil--video-retard .video-retard-header {
  margin-bottom: 0.5rem;
}

.video-retard-stage {
  position: relative;
  width: 100%;
  min-height: min(52vh, 28rem);
  background: #0a0a0a;
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 0.75rem;
}

.video-retard-stage:fullscreen,
.video-retard-stage.is-fullscreen-fallback {
  width: 100vw;
  max-width: none;
  height: 100vh;
  min-height: 100vh;
  margin: 0;
  border-radius: 0;
  background: #000;
}

.video-retard-stage:fullscreen .video-retard-canvas,
.video-retard-stage.is-fullscreen-fallback .video-retard-canvas {
  min-height: 100vh;
  height: 100vh;
}

.video-retard-canvas,
.video-retard-overlay {
  display: block;
  width: 100%;
  height: 100%;
  min-height: min(52vh, 28rem);
}

.video-retard-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  touch-action: none;
  pointer-events: none;
}

.video-retard-overlay--draw {
  pointer-events: auto;
  cursor: crosshair;
}

.video-retard-pip {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  z-index: 3;
  width: 140px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 2px solid rgba(250, 204, 21, 0.85);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.45);
  background: #0a0a0a;
  pointer-events: none;
}

.video-retard-pip__label {
  display: block;
  padding: 0.2rem 0.4rem;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #0f172a;
  background: #facc15;
  text-align: center;
}

.video-retard-pip__canvas {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

.video-retard-fs-exit {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  z-index: 4;
  font-size: 0.85rem;
  background: rgba(15, 23, 42, 0.82) !important;
  color: #f8fafc !important;
  border-color: rgba(248, 250, 252, 0.35) !important;
}

.video-retard-stage:fullscreen .video-retard-fs-exit,
.video-retard-stage.is-fullscreen-fallback .video-retard-fs-exit {
  top: max(0.5rem, env(safe-area-inset-top));
  left: max(0.5rem, env(safe-area-inset-left));
}

.video-retard-draw-toolbar {
  margin-bottom: 0.65rem;
}

.video-retard-draw-toolbar .field-label {
  display: block;
  margin-bottom: 0.35rem;
}

.video-retard-draw-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.video-retard-draw-actions .btn,
.video-retard-draw-btn.is-active {
  flex: 1 1 auto;
  min-width: 6.5rem;
}

.video-retard-draw-btn.is-active,
#video-retard-fullscreen.is-active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.video-retard-draw-hint {
  margin: 0.35rem 0 0;
}

body.video-retard-body-fs {
  overflow: hidden;
}

.video-retard-status,
.video-retard-buffer {
  position: absolute;
  left: 0;
  right: 0;
  margin: 0;
  padding: 0.5rem 0.75rem;
  text-align: center;
  font-size: 0.88rem;
  color: #f8fafc;
  background: rgba(0, 0, 0, 0.55);
  pointer-events: none;
}

.video-retard-status {
  bottom: 0;
}

.video-retard-buffer {
  top: 0;
  font-weight: 700;
  font-size: 1rem;
  background: rgba(13, 148, 136, 0.85);
}

.video-retard-controls .field-group {
  margin-bottom: 0.75rem;
}

.video-retard-controls input[type="range"] {
  width: 100%;
  margin-top: 0.35rem;
}

.video-retard-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}

.video-retard-actions .btn {
  flex: 1 1 auto;
  min-width: 8rem;
}

.video-retard-opt {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.92rem;
  cursor: pointer;
}

.video-retard-opt input {
  flex-shrink: 0;
  width: 1.1rem;
  height: 1.1rem;
  cursor: pointer;
}

#video-retard-mirror.is-active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.video-retard-src {
  position: fixed;
  left: 0;
  top: 0;
  width: 1px;
  height: 1px;
  opacity: 0.03;
  pointer-events: none;
}

.page-outil--video-retard .msg-error {
  margin-top: 0.5rem;
}

.video-retard-capacity {
  margin: 0 0 0.75rem;
  font-size: 0.88rem;
  line-height: 1.45;
}

.video-retard-capacity strong {
  font-variant-numeric: tabular-nums;
}

.video-retard-capacity.stockage-alert--critical {
  background: rgba(244, 63, 94, 0.1);
  border-color: rgba(244, 63, 94, 0.3);
  color: #9f1239;
}

/* --- Photo finish --- */
.page-outil--photo-finish {
  max-width: min(52rem, 100%);
  --pf-analysis-max-h: min(72vh, 36rem);
  --pf-analysis-min-h: min(44vh, 22rem);
  --pf-image-area-h: clamp(18rem, 52vh, 30rem);
  --pf-chrono-size: clamp(1.25rem, 5vw, 2rem);
  --pf-capture-btn-h: 3.1rem;
}

@media (orientation: portrait) {
  .page-outil--photo-finish {
    --pf-image-area-h: clamp(22rem, 58vh, 34rem);
    --pf-analysis-min-h: clamp(18rem, 46vh, 30rem);
    --pf-analysis-max-h: clamp(22rem, 64vh, 40rem);
    --pf-chrono-size: clamp(1.35rem, 5.5vw, 2.1rem);
  }
}

@media (orientation: landscape) {
  .page-outil--photo-finish {
    --pf-image-area-h: clamp(12rem, calc(100dvh - 5.5rem), 100%);
    --pf-analysis-min-h: clamp(10rem, calc(100dvh - 9rem), 100%);
    --pf-analysis-max-h: 66vh;
    --pf-chrono-size: clamp(1rem, 3.8vh, 1.55rem);
    --pf-capture-btn-h: 2.65rem;
  }

  .page-outil--photo-finish:has(#pf-panel-capture:not([hidden])) #session-manager-mount {
    display: none;
  }

  .page-outil--photo-finish:has(#pf-panel-capture:not([hidden])) .page-outil__header {
    padding-block: 0.25rem;
  }

  .page-outil--photo-finish #pf-panel-capture > .card {
    display: none;
  }

  .page-outil--photo-finish .photo-finish-stage {
    margin-bottom: 0;
    min-height: calc(100dvh - 3.5rem);
  }

  .page-outil--photo-finish:has(#pf-panel-capture:not([hidden])) .photo-finish-stage {
    height: max(var(--pf-image-area-h), calc(100dvh - 3.5rem));
  }

  .page-outil--photo-finish .dispense-nav__btn {
    min-height: 2.35rem;
    padding-top: 0.35rem;
    padding-bottom: 0.35rem;
    font-size: 0.82rem;
  }
}

.page-outil--photo-finish .tool-session-gated:not([hidden]) {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.page-outil--photo-finish .tool-session-gated:not([hidden]) > .dispense-view:not([hidden])#pf-panel-capture,
.page-outil--photo-finish .tool-session-gated:not([hidden]) > .dispense-view:not([hidden])#pf-panel-analysis {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.page-outil--photo-finish #pf-panel-capture:not([hidden]),
.page-outil--photo-finish #pf-panel-analysis:not([hidden]) {
  min-height: 0;
}

.photo-finish-msg {
  margin-bottom: 0.5rem;
}

.page-outil--photo-finish .dispense-nav.photo-finish-nav {
  grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 640px) {
  .page-outil--photo-finish .dispense-nav.photo-finish-nav {
    grid-template-columns: repeat(4, 1fr);
  }
}

.page-outil--photo-finish .dispense-nav__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  font-weight: 700;
  color: var(--accent-deep);
  background: #fff;
  border: 1.5px solid rgba(13, 148, 136, 0.32);
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.07);
}

.page-outil--photo-finish .dispense-nav__btn .btn-icon-emoji {
  opacity: 0.92;
}

.page-outil--photo-finish .dispense-nav__btn--active {
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 55%, var(--accent-2) 130%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(13, 148, 136, 0.38);
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.15);
}

@media (hover: hover) {
  .page-outil--photo-finish .dispense-nav__btn:not(.dispense-nav__btn--active):hover {
    background: var(--accent-soft);
    color: var(--accent-deep);
    border-color: rgba(13, 148, 136, 0.45);
  }
}

.page-outil--photo-finish .dispense-nav__btn:not(.dispense-nav__btn--active):active {
  background: #ecfdf5;
  color: #0f7668;
  border-color: rgba(13, 148, 136, 0.5);
}

.page-outil--photo-finish .dispense-nav__btn--active:active {
  background: linear-gradient(135deg, #115e59 0%, var(--accent-deep) 100%);
  color: #fff;
}

.page-outil--photo-finish .card--accordion__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.65rem;
  height: 1.65rem;
  padding: 0 0.45rem;
  margin-left: 0.4rem;
  margin-right: auto;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent-deep), var(--accent));
  color: #fff;
  font-size: 0.78rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

.page-outil--photo-finish .photo-finish-advanced-acc {
  margin-top: 0.85rem;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: var(--radius-sm);
  box-shadow: none;
}

.page-outil--photo-finish .photo-finish-advanced-acc > summary {
  padding: 0.85rem 1rem;
}

.page-outil--photo-finish .photo-finish-advanced-acc > .card--accordion__panel {
  padding: 0 1rem 1rem;
}

.photo-finish-home-runners {
  display: grid;
  gap: 0.5rem;
  margin: 0.75rem 0;
}

.photo-finish-home-runners .field-label,
.photo-finish-home-runners .hint {
  grid-column: 1 / -1;
  margin: 0;
}

.photo-finish-runner-check {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 2.4rem;
  padding: 0.45rem 0.55rem;
  border: 1px solid var(--border, rgba(0, 0, 0, 0.12));
  border-radius: 0.45rem;
  background: var(--surface, #fff);
  font-weight: 700;
}

.photo-finish-runner-check input {
  width: 1.1rem;
  height: 1.1rem;
}

.photo-finish-session-player-list {
  display: grid;
  gap: 0.4rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.photo-finish-session-player {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  min-height: 2.8rem;
  padding: 0.45rem 0;
  border-bottom: 1px solid var(--border, rgba(0, 0, 0, 0.08));
}

.photo-finish-session-player span {
  flex: 1 1 auto;
  min-width: 0;
}

.photo-finish-session-player strong,
.photo-finish-session-player small {
  display: block;
}

.photo-finish-session-player small {
  color: var(--text-muted, #64748b);
}

.photo-finish-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 0.75rem;
}

.photo-finish-stage {
  position: relative;
  width: 100%;
  height: var(--pf-image-area-h, clamp(18rem, 52vh, 30rem));
  min-height: 12rem;
  flex: 1 1 auto;
  margin-bottom: 0.45rem;
  border-radius: var(--radius-md, 0.5rem);
  overflow: hidden;
  background: #0a0a0a;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.photo-finish-video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #000;
}

.photo-finish-preview-tap {
  position: absolute;
  inset: 0;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 1rem 1.25rem;
  border: 0;
  background: rgba(10, 10, 10, 0.82);
  color: #f8fafc;
  font: inherit;
  font-size: 1rem;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
}

.photo-finish-preview-tap[hidden] {
  display: none !important;
}

.pf-pwa-standalone .photo-finish-stage {
  overflow: visible;
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
}

.pf-pwa-standalone .photo-finish-video,
.photo-finish-video--pwa {
  object-fit: cover;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.photo-finish-slit-guide {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 3px;
  margin-left: -1px;
  background: #e11d48;
  box-shadow: 0 0 8px rgba(225, 29, 72, 0.8);
  pointer-events: none;
  z-index: 2;
}

.photo-finish-slit-guide span {
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 18px;
  transform: translateX(-50%);
  border-left: 1px solid rgba(225, 29, 72, 0.5);
  border-right: 1px solid rgba(225, 29, 72, 0.5);
  background: rgba(225, 29, 72, 0.08);
}

.photo-finish-capture-hud {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.photo-finish-capture-actions--overlay {
  position: absolute;
  left: 0.65rem;
  right: 0.65rem;
  bottom: 0.55rem;
  z-index: 5;
}

.photo-finish-main-capture {
  width: 100%;
  min-height: var(--pf-capture-btn-h, 3.1rem);
  justify-content: center;
  font-size: clamp(0.92rem, 2.4vw, 1.05rem);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.28);
}

.photo-finish-chrono-live {
  position: absolute;
  top: 0.45rem;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  padding: 0.18rem 0.55rem;
  font-size: var(--pf-chrono-size, clamp(1.25rem, 5vw, 2rem));
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1.15;
  color: #fff;
  background: rgba(0, 0, 0, 0.55);
  border-radius: 0.35rem;
  z-index: 3;
  pointer-events: none;
  max-width: calc(100% - 1.5rem);
  white-space: nowrap;
}

.photo-finish-status {
  position: absolute;
  left: 0.65rem;
  right: 0.65rem;
  bottom: calc(var(--pf-capture-btn-h, 3.1rem) + 0.7rem);
  margin: 0;
  padding: 0.22rem 0.45rem;
  font-size: clamp(0.68rem, 2vw, 0.8rem);
  text-align: center;
  color: #fff;
  background: rgba(0, 0, 0, 0.62);
  border-radius: 0.35rem;
  z-index: 3;
  pointer-events: none;
}

.photo-finish-start,
.photo-finish-stop {
  min-height: 4rem;
  font-size: 1.08rem;
}

.photo-finish-start.is-armed {
  background: #e11d48;
  border-color: #e11d48;
  color: #fff;
}

.photo-finish-stop:not(:disabled) {
  background: #111827;
  color: #fff;
}

.photo-finish-main-capture.is-stop {
  background: #e11d48;
  border-color: #e11d48;
  color: #fff;
}

.photo-finish-live-stats,
.photo-finish-camera-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.75rem 0 0;
  color: var(--text-muted, #64748b);
  font-size: 0.9rem;
}

.photo-finish-live-stats span {
  padding: 0.25rem 0.45rem;
  border-radius: 0.35rem;
  background: rgba(15, 118, 110, 0.08);
}

.photo-finish-camera-debug {
  margin-top: 0.75rem;
  padding: 0.75rem;
  border: 1px solid rgba(14, 165, 233, 0.28);
  border-radius: var(--radius-sm, 0.35rem);
  background: #f0f9ff;
  color: #0f172a;
}

.photo-finish-camera-debug[hidden] {
  display: none !important;
}

.photo-finish-camera-debug h3 {
  margin: 0 0 0.5rem;
  font-size: 0.95rem;
}

.photo-finish-camera-debug dl {
  display: grid;
  grid-template-columns: minmax(7rem, 0.75fr) minmax(0, 1.25fr);
  gap: 0.3rem 0.65rem;
  margin: 0;
  font-size: 0.82rem;
}

.photo-finish-camera-debug dt {
  color: #0369a1;
  font-weight: 700;
}

.photo-finish-camera-debug dd {
  min-width: 0;
  margin: 0;
  overflow-wrap: anywhere;
  font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
}

.photo-finish-presets {
  margin-top: 0.45rem;
}

.photo-finish-presets .btn {
  flex: 1 1 6rem;
  min-height: 2.25rem;
  padding-inline: 0.45rem;
}

.photo-finish-terrain ul,
.photo-finish-quality-report ul,
.photo-finish-diagnostic ul {
  margin: 0.5rem 0 0;
  padding-left: 1.1rem;
}

.photo-finish-terrain li,
.photo-finish-quality-report li,
.photo-finish-diagnostic li {
  margin: 0.25rem 0;
}

.photo-finish-quality-preview {
  margin-top: 0.75rem;
  overflow-x: auto;
  border: 1px solid var(--border, rgba(0, 0, 0, 0.12));
  border-radius: 0.5rem;
  background: #111;
}

.photo-finish-quality-preview canvas {
  display: block;
  max-width: 100%;
  height: auto;
  image-rendering: auto;
}

.photo-finish-quality-report {
  margin-top: 0.75rem;
  color: var(--text, #111827);
}

.page-outil--photo-finish #pf-panel-capture > .card {
  flex: 0 0 auto;
  margin-top: 0;
  padding: 0.5rem 0.7rem;
}

.page-outil--photo-finish #pf-panel-capture > .card h2 {
  margin: 0 0 0.35rem;
  font-size: 0.82rem;
}

.page-outil--photo-finish #pf-panel-capture .photo-finish-live-stats {
  margin: 0;
  font-size: 0.78rem;
}

.pf-pwa-standalone #pf-panel-capture > .photo-finish-capture-card {
  display: block;
}

@media (orientation: landscape) and (max-height: 520px) {
  .page-outil--photo-finish .photo-finish-stage {
    margin-bottom: 0;
  }
}

.photo-finish-analysis-card {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 0.55rem 0.65rem 0.45rem;
}

.photo-finish-bar-time {
  margin: 0;
  font-size: clamp(0.88rem, 2.6vw, 1rem);
}

.photo-finish-analysis-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.45rem 0.65rem;
  margin-bottom: 0.45rem;
  flex: 0 0 auto;
}

.photo-finish-analysis-head h2 {
  margin: 0;
  font-size: 0.95rem;
}

.photo-finish-analysis-head > div:first-child {
  min-width: 0;
  flex: 1 1 auto;
}

.photo-finish-zoom-actions {
  flex: 0 0 auto;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.3rem;
  margin: 0;
}

.photo-finish-zoom-actions .btn {
  flex: 0 0 auto;
  width: auto;
  min-width: 2.5rem;
  min-height: 2.35rem;
  padding: 0.3rem 0.45rem;
  font-size: 0.82rem;
}

.photo-finish-viewer {
  position: relative;
  overflow: hidden;
  border-radius: 0.5rem;
  background: #111;
  flex: 1 1 auto;
  min-height: 0;
}

.photo-finish-scroll {
  position: relative;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: #111;
  touch-action: pan-x pinch-zoom;
  height: 100%;
}

.photo-finish-image-wrap {
  position: relative;
  display: inline-block;
  line-height: 0;
  padding-left: var(--pf-viewer-pad, 50vw);
  padding-right: var(--pf-viewer-pad, 50vw);
  vertical-align: top;
}

.photo-finish-image-wrap.is-reversed {
  transform: scaleX(-1);
}

.photo-finish-image-wrap.is-reversed .photo-finish-marker {
  transform: translateX(-50%) scaleX(-1);
}

.photo-finish-result {
  display: block;
  width: auto;
  height: auto;
  image-rendering: auto;
  vertical-align: top;
}

.photo-finish-fixed-cursor {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 0;
  transform: translateX(-50%);
  border-left: 2px solid #e11d48;
  box-shadow: 0 0 8px rgba(225, 29, 72, 0.75);
  pointer-events: none;
  z-index: 4;
}

.photo-finish-fixed-time {
  position: absolute;
  top: 0.45rem;
  right: 0.45rem;
  left: auto;
  margin: 0;
  transform: none;
  padding: 0.28rem 0.55rem;
  border-radius: 0.4rem;
  background: rgba(0, 0, 0, 0.78);
  color: #fff;
  font-size: clamp(0.82rem, 2.8vw, 1.05rem);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
  pointer-events: none;
  z-index: 5;
}

.photo-finish-add {
  position: absolute;
  left: 50%;
  bottom: 0.85rem;
  width: clamp(3.4rem, 12vw, 4rem);
  height: clamp(3.4rem, 12vw, 4rem);
  transform: translateX(-50%);
  border: none;
  border-radius: 50%;
  background: #e11d48;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 5px rgba(225, 29, 72, 0.25);
  font-size: 2rem;
  font-weight: 800;
  line-height: 1;
  padding: 0 0 0.1rem;
  pointer-events: auto;
}

.photo-finish-slider {
  width: 100%;
  margin: 0.35rem 0 0.25rem;
  flex: 0 0 auto;
}

.page-outil--photo-finish .photo-finish-analysis-card .champ-gestion-actions {
  margin-top: 0.35rem;
  padding-top: 0.45rem;
  flex: 0 0 auto;
  gap: 0.35rem;
}

.page-outil--photo-finish .photo-finish-analysis-card .champ-gestion-actions .btn {
  flex: 1 1 0;
  min-width: 0;
  min-height: 2.45rem;
  padding-inline: 0.35rem;
  font-size: 0.74rem;
}

.page-outil--photo-finish .photo-finish-analysis-card .champ-gestion-actions .btn__text {
  font-size: 0.74rem;
  line-height: 1.15;
}

.photo-finish-bar-time strong {
  font-variant-numeric: tabular-nums;
  color: var(--accent, #2563eb);
}

.photo-finish-markers {
  position: absolute;
  top: 0;
  left: var(--pf-viewer-pad, 50vw);
  height: 100%;
  pointer-events: none;
}

.photo-finish-marker {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 0;
  padding: 0;
  transform: translateX(-50%);
  border: none;
  border-left: 2px solid #f59e0b;
  background: transparent;
  color: #111827;
  pointer-events: auto;
  box-shadow: 0 0 6px rgba(245, 158, 11, 0.55);
}

.photo-finish-marker span,
.photo-finish-marker strong {
  position: absolute;
  left: 0.35rem;
  padding: 0.08rem 0.22rem;
  border-radius: 0.2rem;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(245, 158, 11, 0.22);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.14);
  white-space: nowrap;
  font-size: 0.62rem;
  line-height: 1.2;
}

.photo-finish-marker span {
  top: 0.35rem;
}

.photo-finish-marker strong {
  top: 1.38rem;
  font-variant-numeric: tabular-nums;
}

.photo-finish-marker em {
  position: absolute;
  top: 2.38rem;
  left: 0.28rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 50%;
  background: rgba(17, 24, 39, 0.68);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  font-style: normal;
  line-height: 1;
  white-space: nowrap;
  pointer-events: auto;
  opacity: 0.78;
}

.photo-finish-marker:focus-visible,
.photo-finish-marker:hover {
  border-left-color: #fbbf24;
  box-shadow: 0 0 8px rgba(245, 158, 11, 0.75);
  background: transparent;
}

.photo-finish-marker:focus-visible em,
.photo-finish-marker:hover em {
  opacity: 1;
}

.photo-finish-nom-manuel {
  width: 100%;
  margin-bottom: 0.65rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid var(--border, rgba(0, 0, 0, 0.15));
  border-radius: var(--radius-sm, 0.35rem);
  font-size: 1rem;
}

.photo-finish-results,
.photo-finish-runners {
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
}

.photo-finish-result-item,
.photo-finish-runner {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0;
  border-bottom: 1px solid var(--border, rgba(0, 0, 0, 0.08));
}

.photo-finish-result-group {
  margin: 0.75rem 0;
  padding: 0.65rem 0 0;
  border-top: 1px solid var(--border, rgba(0, 0, 0, 0.1));
}

.photo-finish-result-group__head {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  justify-content: space-between;
  margin-bottom: 0.35rem;
}

.photo-finish-result-group__head strong,
.photo-finish-result-group__head small {
  display: block;
}

.photo-finish-result-group__head small {
  color: var(--text-muted, #64748b);
}

.photo-finish-result-group ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

.photo-finish-classement__rang {
  flex-shrink: 0;
  width: 1.75rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--text-muted, #64748b);
}

.photo-finish-result-series {
  flex-shrink: 0;
  width: 3.1rem;
  font-variant-numeric: tabular-nums;
}

.photo-finish-result-series small,
.photo-finish-result-series strong {
  display: block;
}

.photo-finish-result-series small {
  color: var(--text-muted, #64748b);
  font-size: 0.68rem;
}

.photo-finish-classement__nom {
  flex: 1 1 auto;
  min-width: 0;
}

.photo-finish-result-main,
.photo-finish-runner span {
  flex: 1 1 auto;
  min-width: 0;
}

.photo-finish-result-main strong,
.photo-finish-runner strong {
  display: block;
}

.photo-finish-result-main small,
.photo-finish-runner small {
  display: block;
  color: var(--text-muted, #64748b);
}

.photo-finish-classement__temps {
  flex-shrink: 0;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.photo-finish-dialog {
  width: min(34rem, calc(100vw - 1rem));
  padding: 0;
  border: none;
  border-radius: 0.5rem;
  background: transparent;
}

.photo-finish-dialog::backdrop {
  background: rgba(0, 0, 0, 0.5);
}

.photo-finish-dialog-card {
  padding: 1rem;
  background: var(--surface, #fff);
  border-radius: 0.5rem;
}

.photo-finish-dialog-card h2 {
  margin-top: 0;
}

.photo-finish-dialog-time {
  margin: 0 0 0.75rem;
  font-size: 1.6rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #0f766e;
}

.photo-finish-dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin: 1rem 0 0;
  padding: 0;
}

.photo-finish-debug dl,
.photo-finish-diagnostic dl {
  display: grid;
  grid-template-columns: minmax(8rem, 1fr) minmax(8rem, 1.4fr);
  gap: 0.35rem 0.75rem;
  margin: 0;
  font-size: 0.88rem;
}

.photo-finish-debug dt,
.photo-finish-diagnostic dt {
  color: var(--text-muted, #64748b);
}

.photo-finish-debug dd,
.photo-finish-diagnostic dd {
  margin: 0;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.photo-finish-contrast .page-outil--photo-finish {
  --surface: #fff;
  --text: #050505;
  --text-muted: #263238;
}

@media (min-width: 52rem) {
  .photo-finish-home {
    grid-template-columns: 1fr;
    align-items: start;
  }
}

@media (max-width: 38rem) {
  .page-outil--photo-finish .dispense-nav__btn {
    min-height: 2.65rem;
    padding: 0.45rem 0.35rem;
    font-size: 0.82rem;
  }
}

/* --- Inducteur danse --- */
.page-outil--inducteur-danse {
  max-width: min(40rem, 100%);
}

.inducteur-msg {
  margin-bottom: 0.75rem;
}

.inducteur-draw-card {
  text-align: center;
}

.inducteur-mode {
  border: none;
  margin: 0 0 1rem;
  padding: 0;
  text-align: left;
}

.inducteur-mode .field-label {
  margin-bottom: 0.5rem;
}

.inducteur-mode__opt {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 0.45rem;
  font-size: 0.92rem;
  cursor: pointer;
}

.inducteur-mode__opt input {
  margin-top: 0.2rem;
  flex-shrink: 0;
}

.inducteur-wrap-select {
  margin-bottom: 1rem;
  text-align: left;
}

.inducteur-select {
  width: 100%;
  padding: 0.55rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  font: inherit;
  background: var(--surface);
}

.inducteur-check-listes {
  margin-bottom: 1rem;
  text-align: left;
}

.inducteur-check-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.5rem;
}

.inducteur-check-item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.65rem;
  border-radius: 999px;
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.25);
  font-weight: 600;
  font-size: 0.88rem;
  cursor: pointer;
}

.inducteur-resultats {
  margin: 0 0 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.inducteur-resultats--flash .inducteur-resultat {
  animation: tirage-flash 0.4s ease;
}

.inducteur-resultat {
  padding: 1.1rem 1rem;
  border-radius: var(--radius);
  background: linear-gradient(145deg, var(--accent-soft), #fff);
  border: 2px solid rgba(13, 148, 136, 0.35);
}

.inducteur-resultat__liste {
  display: block;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
  margin-bottom: 0.25rem;
}

.inducteur-resultat__texte {
  display: block;
  font-size: clamp(1.35rem, 5.5vw, 2rem);
  font-weight: 800;
  color: var(--accent-deep);
  line-height: 1.2;
  word-break: break-word;
}

.inducteur-resultat-hint {
  margin-bottom: 1rem;
}

.inducteur-btn-draw {
  width: 100%;
  max-width: 20rem;
  margin: 0 auto;
  font-size: 1.05rem;
  padding: 0.85rem 1.25rem;
}

.inducteur-listes-editor {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-bottom: 1rem;
}

.inducteur-liste {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface);
  overflow: hidden;
}

.inducteur-liste__summary {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 0.75rem;
  cursor: pointer;
  list-style: none;
}

.inducteur-liste__summary::-webkit-details-marker {
  display: none;
}

.inducteur-liste__nom-input {
  flex: 1 1 8rem;
  min-width: 6rem;
  font: inherit;
  font-weight: 700;
  border: 1px solid transparent;
  border-radius: 6px;
  padding: 0.25rem 0.4rem;
  background: transparent;
}

.inducteur-liste__nom-input:focus {
  border-color: var(--accent);
  background: #fff;
  outline: none;
}

.inducteur-liste__count {
  font-size: 0.8rem;
  color: var(--text-muted);
  font-weight: 600;
}

.inducteur-liste__delete {
  margin-left: auto;
  border: none;
  background: transparent;
  color: var(--danger);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0.2rem 0.35rem;
  border-radius: 4px;
}

.inducteur-liste__delete:hover {
  background: var(--danger-bg);
}

.inducteur-liste__panel {
  padding: 0 0.75rem 0.85rem;
  border-top: 1px solid var(--border);
}

.inducteur-liste__textarea {
  width: 100%;
  font: inherit;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  padding: 0.5rem 0.65rem;
  resize: vertical;
  min-height: 5rem;
}

.inducteur-liste__actions {
  margin: 0.65rem 0;
}

.inducteur-inducteurs {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.inducteur-inducteurs__item {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  padding: 0.3rem 0.45rem 0.3rem 0.6rem;
  border-radius: 999px;
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.2);
  font-size: 0.85rem;
  font-weight: 600;
}

.inducteur-inducteurs__remove {
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 1.05rem;
  line-height: 1;
  padding: 0 0.15rem;
  cursor: pointer;
}

.inducteur-inducteurs__remove:hover {
  color: var(--danger);
}

.inducteur-listes-actions {
  flex-wrap: wrap;
  gap: 0.5rem;
}

/* --- Gestionnaire de séances --- */
.session-accordion {
  margin-bottom: 0.75rem;
}

.session-accordion__resume {
  margin-left: auto;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--accent-deep);
  max-width: 55%;
  text-align: right;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.session-accordion .card--accordion__summary {
  gap: 0.5rem;
}

.session-bar {
  margin-bottom: 0;
}

.session-bar__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
}

.session-bar__info {
  flex: 1 1 10rem;
  min-width: 0;
}

.session-bar__label {
  display: block;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}

.session-bar__nom {
  display: block;
  font-size: 1.05rem;
  color: var(--accent-deep);
  word-break: break-word;
}

.session-bar__meta {
  display: block;
  font-size: 0.82rem;
  color: var(--text-muted);
}

.session-bar__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.session-bar__error {
  margin: 0.5rem 0 0;
}

.session-dialog {
  width: min(32rem, calc(100vw - 2rem));
  max-height: min(85vh, 640px);
}

.session-dialog__list {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
  max-height: 50vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.session-dialog__item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  padding: 0.5rem 0.55rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface);
}

.session-dialog__item--active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.session-dialog__item--archived {
  opacity: 0.75;
}

.session-dialog__open {
  flex: 1 1 12rem;
  min-width: 0;
  border: none;
  background: transparent;
  text-align: left;
  cursor: pointer;
  padding: 0.15rem 0.25rem;
  font: inherit;
}

.session-dialog__titre {
  display: block;
  font-weight: 700;
}

.session-dialog__sous {
  display: block;
  font-size: 0.8rem;
  color: var(--text-muted);
}

.session-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
}

.session-dialog__mini {
  font-size: 0.78rem;
  padding: 0.25rem 0.45rem;
}

.session-dialog__mini--danger {
  color: var(--danger);
}

.session-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: flex-end;
}

.tool-session-gated[hidden] {
  display: none !important;
}

/* --- Questions débrief --- */
.page-outil--debrief {
  max-width: min(40rem, 100%);
}

.debrief-intro {
  margin: 0 0 1rem;
  text-align: center;
  font-size: 0.92rem;
}

.debrief-portee {
  border: none;
  margin: 0 0 1rem;
  padding: 0;
  text-align: left;
}

.debrief-portee .field-label {
  text-align: center;
  display: block;
  margin-bottom: 0.65rem;
}

.debrief-portee__toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}

.debrief-portee__btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding: 0.85rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 2px solid var(--border);
  background: var(--surface);
  cursor: pointer;
  font-weight: 700;
  font-size: 0.88rem;
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
}

.debrief-portee__btn:has(input:checked) {
  border-color: var(--accent);
  background: var(--accent-soft);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.debrief-portee__btn input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.debrief-portee__icon {
  font-size: 1.5rem;
  line-height: 1;
}

.debrief-portee-hint {
  margin: 0.65rem 0 0;
  text-align: center;
  font-size: 0.85rem;
}

.debrief-resultats__titre {
  margin: 0 0 0.75rem;
  font-size: 0.8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
  text-align: center;
}

.debrief-resultats .inducteur-resultat {
  text-align: left;
}

.debrief-resultat__num {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 0.2rem;
}

.debrief-resultat__question {
  margin: 0;
  font-size: clamp(1rem, 4.2vw, 1.2rem);
  font-weight: 700;
  line-height: 1.45;
}

.debrief-resultats__section {
  margin: 1rem 0 0.35rem;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--accent-deep);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.debrief-resultat--texte {
  margin-top: 0.5rem;
}

.debrief-reponse-label {
  margin: 0.65rem 0 0.35rem;
}

.debrief-reponse-input {
  width: 100%;
  min-height: 3.25rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: var(--radius-sm);
  font: inherit;
  line-height: 1.45;
  resize: vertical;
}

.debrief-reponse-input:focus {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
  border-color: var(--accent);
}

.debrief-reponse-hint {
  margin: 0.35rem 0 0;
}

.debrief-echelle {
  margin: 0;
  padding: 0;
  border: none;
}

.debrief-echelle__options {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.debrief-echelle__opt {
  flex: 1 1 2.75rem;
  min-width: 2.75rem;
  max-width: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.85rem;
  border-radius: var(--radius-sm);
  border: 2px solid rgba(148, 163, 184, 0.45);
  background: #fff;
  font-weight: 800;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.debrief-echelle__opt input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

.debrief-echelle__num {
  font-size: 1.15rem;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.debrief-echelle__opt.is-selected,
.debrief-echelle__opt:has(input:checked) {
  border-color: var(--accent);
  background: rgba(13, 148, 136, 0.12);
  color: var(--accent-deep);
}

.debrief-echelle__opt:focus-within {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.debrief-echelle-legend {
  margin: 0.4rem 0 0;
}

.page-outil--debrief .eleve-share-bar {
  margin-top: 0.15rem;
}

.import-preview--debrief .debrief-preview-title {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
  color: var(--accent-deep);
}

.debrief-preview-item {
  margin-top: 0.55rem;
  padding: 0.75rem 0.85rem;
}

.debrief-preview-theme {
  display: inline-block;
  margin-bottom: 0.35rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent-deep);
}

.debrief-preview-question {
  margin: 0 0 0.5rem;
  font-weight: 700;
  line-height: 1.4;
}

.debrief-preview-reponse__label {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 0.2rem;
}

.debrief-preview-reponse__text {
  margin: 0;
  white-space: pre-wrap;
  line-height: 1.45;
}

.debrief-home,
.debrief-session-view {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.debrief-new-btn {
  width: 100%;
  margin-top: 0.85rem;
  margin-bottom: 0.65rem;
}

.debrief-acc__badge {
  margin-left: auto;
  margin-right: 0.15rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--accent-deep);
  background: rgba(13, 148, 136, 0.1);
  border: 1px solid rgba(13, 148, 136, 0.18);
}

.debrief-seances {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.debrief-seance-row {
  display: flex;
  align-items: stretch;
  gap: 0.35rem;
}

.debrief-seance-del {
  flex-shrink: 0;
  align-self: center;
  min-width: 2.5rem;
  color: var(--danger, #b91c1c);
}

.debrief-seance-btn {
  flex: 1;
  width: auto;
  text-align: left;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: #fff;
  font: inherit;
  cursor: pointer;
}

.debrief-seance-btn__title {
  display: block;
  font-weight: 800;
  color: var(--text);
}

.debrief-seance-btn__meta {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.85rem;
  color: var(--text-muted);
}

/* --- Historique résultats (outils compteurs / table de marque) --- */
.tool-results-history__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.tool-results-history__row {
  display: flex;
  align-items: stretch;
  gap: 0.35rem;
}

.tool-results-history__del {
  flex-shrink: 0;
  align-self: center;
  min-width: 2.5rem;
  color: var(--danger, #b91c1c);
}

.tool-results-history__btn {
  flex: 1;
  width: auto;
  text-align: left;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: #fff;
  font: inherit;
  cursor: pointer;
}

.tool-results-history__btn-title {
  display: block;
  font-weight: 800;
  color: var(--text);
}

.tool-results-history__btn-meta {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.tool-results-history__badge {
  margin-left: auto;
  margin-right: 0.35rem;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.15);
  color: var(--accent, #0d9488);
}

.tool-results-history-dialog__body {
  max-height: 65vh;
  overflow: auto;
}

.tool-results-history-dialog__actions {
  flex-wrap: wrap;
  gap: 0.5rem;
}

.tool-results-history-dialog__actions .btn--labeled {
  flex: 1 1 auto;
  min-width: 10rem;
}

.tool-results-history-view-scores {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0.75rem;
  align-items: center;
  text-align: center;
  margin: 0.5rem 0 1rem;
}

.tool-results-history-view-scores strong {
  font-size: clamp(2rem, 8vw, 3rem);
  line-height: 1;
}

.tool-results-history-view-scores span {
  display: block;
  font-size: 0.9rem;
  font-weight: 700;
  margin-bottom: 0.25rem;
}

.tool-results-history-view-scores em {
  font-style: normal;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text-muted);
}

.tool-results-history-json {
  font-size: 0.75rem;
  white-space: pre-wrap;
  word-break: break-word;
}

.debrief-session-head {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.debrief-back {
  align-self: flex-start;
}

.debrief-session-info {
  margin-bottom: 0;
  padding: 1rem 1.05rem;
}

.debrief-session-info-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
  gap: 0.6rem 0.75rem;
  align-items: end;
}

.debrief-session-info-sep {
  grid-column: 1 / -1;
  margin: 0.2rem 0 0.05rem;
  border: none;
  border-top: 2px solid rgba(15, 23, 42, 0.1);
}

.debrief-session-info-grid .field-group {
  margin: 0;
}

.debrief-session-info-grid input {
  width: 100%;
  min-width: 0;
}

@media (max-width: 420px) {
  .debrief-session-info-grid {
    grid-template-columns: 1fr;
  }
}

.debrief-date-field input[type="date"] {
  min-width: 10.5rem;
}

.debrief-btn-draw-top {
  width: 100%;
  margin: 0.75rem 0 0.65rem;
}

.debrief-delete {
  margin-top: 0.25rem;
}

.debrief-tag span {
  max-width: 100%;
  text-align: left;
  line-height: 1.35;
}

/* --- Sauvegarde et restauration --- */
.page-outil--sauvegarde {
  max-width: min(40rem, 100%);
}

.sauvegarde-msg {
  margin-bottom: 0.75rem;
}

/* Zone 1 — État de la sauvegarde */
.sauvegarde-status-card {
  margin-bottom: 0.85rem;
  border-width: 1px;
  border-style: solid;
}

.sauvegarde-status-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.55rem;
}

.sauvegarde-status-card__head h2 {
  margin: 0;
  font-size: 1.12rem;
}

.sauvegarde-status-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.01em;
}

.sauvegarde-status-card__date {
  margin: 0 0 0.45rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
}

.sauvegarde-status-card__hint {
  margin: 0 0 0.55rem;
  font-size: 0.88rem;
  color: var(--text-muted);
}

.sauvegarde-status-card__lead {
  margin: 0 0 0.85rem;
  font-size: 0.94rem;
  line-height: 1.5;
  color: var(--text-muted);
}

.sauvegarde-status-card__note {
  margin: 0.65rem 0 0;
  font-size: 0.82rem;
  line-height: 1.4;
}

.sauvegarde-status-card--never {
  border-color: rgba(15, 23, 42, 0.1);
  background: var(--surface);
}

.sauvegarde-status-card--never .sauvegarde-status-card__badge {
  background: rgba(15, 23, 42, 0.06);
  color: var(--text-muted);
}

.sauvegarde-status-card--recent {
  border-color: rgba(13, 148, 136, 0.35);
  background: linear-gradient(160deg, rgba(240, 253, 250, 0.95), var(--surface));
}

.sauvegarde-status-card--recent .sauvegarde-status-card__badge {
  background: rgba(13, 148, 136, 0.16);
  color: var(--accent-deep);
}

.sauvegarde-status-card--soon {
  border-color: rgba(15, 23, 42, 0.1);
  background: var(--surface);
}

.sauvegarde-status-card--soon .sauvegarde-status-card__badge {
  background: rgba(59, 130, 246, 0.1);
  color: #2563eb;
}

.sauvegarde-status-card--old {
  border-color: rgba(15, 23, 42, 0.1);
  background: var(--surface);
}

.sauvegarde-status-card--old .sauvegarde-status-card__badge {
  background: rgba(15, 23, 42, 0.06);
  color: var(--text-muted);
}

.sauvegarde-status-card .btn {
  width: 100%;
}

/* Zone 2 — Comprendre */
.sauvegarde-compr {
  margin-bottom: 0.85rem;
  text-align: left;
}

.sauvegarde-compr__title {
  margin: 0 0 0.65rem;
  font-size: 1.05rem;
}

.sauvegarde-compr__lead {
  margin: 0 0 0.75rem;
  font-size: 0.94rem;
  line-height: 1.5;
}

.sauvegarde-compr__points {
  margin: 0 0 0.75rem;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.45rem;
  font-size: 0.92rem;
  line-height: 1.45;
}

.sauvegarde-compr__points li {
  padding: 0.45rem 0.65rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.06);
  border: 1px solid rgba(13, 148, 136, 0.12);
}

.sauvegarde-compr__details {
  margin-top: 0.35rem;
  font-size: 0.88rem;
}

.sauvegarde-compr__details summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--accent-deep);
}

.sauvegarde-compr__details .hint {
  margin-top: 0.55rem;
}

/* Zone 3 — Actions */
.sauvegarde-actions {
  display: grid;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.sauvegarde-action-card {
  padding: 1rem;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.85);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.sauvegarde-action-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.45rem;
}

.sauvegarde-action-card__icon {
  display: inline-flex;
  width: 2.25rem;
  height: 2.25rem;
  align-items: center;
  justify-content: center;
  border-radius: 0.65rem;
  background: var(--accent-soft);
  font-size: 1.1rem;
}

.sauvegarde-action-card h3 {
  margin: 0;
  font-size: 1.05rem;
  flex: 1 1 auto;
}

.sauvegarde-action-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.16rem 0.5rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  background: rgba(15, 23, 42, 0.06);
  color: var(--text-muted);
}

.sauvegarde-action-card__badge--primary {
  background: rgba(13, 148, 136, 0.14);
  color: var(--accent-deep);
}

.sauvegarde-action-card__badge--advanced {
  background: rgba(99, 102, 241, 0.12);
  color: #4338ca;
}

.sauvegarde-action-card p {
  margin: 0 0 0.85rem;
  font-size: 0.92rem;
  color: var(--text-muted);
  line-height: 1.45;
}

.sauvegarde-action-card .btn {
  width: 100%;
}

.sauvegarde-action-card--export {
  border-color: rgba(13, 148, 136, 0.35);
  background: linear-gradient(180deg, rgba(13, 148, 136, 0.08), var(--surface));
}

.sauvegarde-action-card--secondary {
  border-color: rgba(15, 23, 42, 0.08);
  background: var(--surface);
  box-shadow: none;
}

.sauvegarde-action-card--active,
.sauvegarde-action-card--export.sauvegarde-action-card--active {
  border-color: rgba(13, 148, 136, 0.42);
  box-shadow: 0 4px 18px rgba(13, 148, 136, 0.14);
}

/* Zone 4 — Gestion avancée (alignée sur stockage-accordion) */
.sauvegarde-advanced {
  margin-top: 1rem;
}

.sauvegarde-advanced__body {
  padding-top: 0;
}

.sauvegarde-advanced__intro {
  margin: 0 0 0.85rem;
  font-size: 0.88rem;
}

.sauvegarde-advanced .sauvegarde-stockage {
  margin: 0;
}

.sauvegarde-advanced .stockage-accordions {
  margin-top: 0.35rem;
}

.sauvegarde-import-choices__lead {
  margin: 0 0 0.75rem;
}

.sauvegarde-import-choice__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
  margin-bottom: 0.35rem;
}

.sauvegarde-import-choice__head h3 {
  margin: 0;
}

.sauvegarde-import-choice__badge {
  display: inline-flex;
  padding: 0.14rem 0.45rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  background: rgba(13, 148, 136, 0.14);
  color: var(--accent-deep);
}

.sauvegarde-import-choice__badge--danger {
  background: rgba(239, 68, 68, 0.12);
  color: #b91c1c;
}

.sauvegarde-panel-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.65rem;
}

.sauvegarde-hint {
  margin-bottom: 1rem;
}

.sauvegarde-hero {
  text-align: left;
  background: linear-gradient(160deg, rgba(13, 148, 136, 0.08), rgba(8, 145, 178, 0.05));
  border-color: rgba(13, 148, 136, 0.2);
}

.sauvegarde-hero__summary {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  list-style: none;
  font-weight: 800;
  color: var(--text);
}

.sauvegarde-hero__summary::-webkit-details-marker {
  display: none;
}

.sauvegarde-hero__summary::before {
  content: "▸";
  flex-shrink: 0;
  width: 1.1rem;
  color: var(--accent-deep);
  transition: transform 0.15s ease;
}

.sauvegarde-hero[open] > .sauvegarde-hero__summary::before {
  transform: rotate(90deg);
}

.sauvegarde-hero__summary-text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}

.sauvegarde-hero__summary-title {
  font-size: 1.05rem;
  line-height: 1.3;
}

.sauvegarde-hero__summary-hint {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-muted);
  line-height: 1.35;
}

.sauvegarde-hero__body {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(13, 148, 136, 0.14);
}

.sauvegarde-hero__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.65rem;
  height: 2.65rem;
  flex-shrink: 0;
  border-radius: 0.85rem;
  background: linear-gradient(160deg, #fff, var(--accent-soft));
  border: 1px solid rgba(13, 148, 136, 0.2);
  font-size: 1.35rem;
}

.sauvegarde-hero__lead {
  margin: 0 0 1rem;
  font-size: 1rem;
  line-height: 1.55;
}

.sauvegarde-hero__panel {
  padding: 0.85rem 0.95rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.78);
}

.sauvegarde-hero__panel + .sauvegarde-hero__panel {
  margin-top: 0.65rem;
}

.sauvegarde-hero__panel--warn {
  border-color: rgba(245, 158, 11, 0.28);
  background: rgba(255, 251, 235, 0.85);
}

.sauvegarde-hero__panel--help {
  border-color: rgba(13, 148, 136, 0.22);
  background: rgba(240, 253, 250, 0.9);
}

.sauvegarde-hero__panel--sync {
  border-color: rgba(59, 130, 246, 0.22);
  background: rgba(239, 246, 255, 0.92);
}

.sauvegarde-hero__sync-text {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.5;
}

.sauvegarde-hero__panel-title {
  margin: 0 0 0.5rem;
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--accent-deep);
}

.sauvegarde-hero__list {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.4rem;
  font-size: 0.92rem;
  line-height: 1.45;
}

.sauvegarde-hero__steps {
  margin: 0;
  padding-left: 1.25rem;
  display: grid;
  gap: 0.65rem;
  font-size: 0.92rem;
  line-height: 1.5;
}

.sauvegarde-hero__steps li {
  padding-left: 0.15rem;
}

.sauvegarde-hero__steps code {
  font-size: 0.86em;
  word-break: break-word;
}

.sauvegarde-hero__note {
  margin: 0.85rem 0 0;
  padding-top: 0.75rem;
  border-top: 1px dashed rgba(15, 23, 42, 0.12);
  font-size: 0.88rem;
  line-height: 1.45;
  text-align: left;
}

.sauvegarde-parcours {
  margin-bottom: 0.85rem;
  padding: 1rem 1.05rem;
  border-color: rgba(13, 148, 136, 0.28);
  background: linear-gradient(135deg, rgba(13, 148, 136, 0.09), rgba(255, 255, 255, 0.95));
}

.sauvegarde-parcours__title {
  margin: 0 0 0.75rem;
  font-size: 1.08rem;
}

.sauvegarde-parcours__steps {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.55rem;
}

.sauvegarde-parcours__step {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  font-size: 0.94rem;
  line-height: 1.45;
}

.sauvegarde-parcours__num {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.65rem;
  height: 1.65rem;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1;
}

.sauvegarde-parcours__step--first .sauvegarde-parcours__num {
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.sauvegarde-flow {
  display: grid;
  gap: 1rem;
  margin-bottom: 1rem;
}

.sauvegarde-flow__step {
  display: grid;
  gap: 0.55rem;
}

.sauvegarde-flow__label {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
}

.sauvegarde-flow__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.sauvegarde-quick {
  display: grid;
  gap: 0.75rem;
}

.sauvegarde-quick--secondary {
  grid-template-columns: 1fr;
}

.sauvegarde-quick-card {
  padding: 1rem;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.85);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.sauvegarde-quick-card__icon {
  display: inline-flex;
  width: 2.25rem;
  height: 2.25rem;
  align-items: center;
  justify-content: center;
  border-radius: 0.65rem;
  background: var(--accent-soft);
  font-size: 1.1rem;
  margin-bottom: 0.45rem;
}

.sauvegarde-quick-card h3 {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
}

.sauvegarde-quick-card p {
  margin: 0 0 0.85rem;
  font-size: 0.92rem;
  color: var(--text-muted);
  line-height: 1.45;
}

.sauvegarde-quick-card__tip {
  margin: -0.35rem 0 0.65rem;
  font-size: 0.82rem;
}

.sauvegarde-quick-card--export {
  border-color: rgba(13, 148, 136, 0.35);
  background: linear-gradient(180deg, rgba(13, 148, 136, 0.06), var(--surface));
}

.sauvegarde-quick-card .btn {
  width: 100%;
}

.sauvegarde-quick-card--active {
  border-color: rgba(13, 148, 136, 0.42);
  box-shadow: 0 4px 18px rgba(13, 148, 136, 0.14);
}

.sauvegarde-stockage__head {
  margin-bottom: 1rem;
}

.sauvegarde-stockage__intro {
  margin: 0.35rem 0 0;
}

.sauvegarde-stockage__summary {
  display: grid;
  gap: 0.65rem;
  margin-bottom: 0.75rem;
}

.stockage-accordions {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.stockage-accordion {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: var(--radius-sm);
  background: rgba(248, 250, 252, 0.85);
  overflow: hidden;
}

.stockage-accordion[open] {
  border-color: rgba(13, 148, 136, 0.22);
  box-shadow: 0 4px 16px rgba(13, 148, 136, 0.08);
}

.stockage-accordion__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  padding: 0.75rem 0.85rem;
  cursor: pointer;
  list-style: none;
}

.stockage-accordion__summary::-webkit-details-marker {
  display: none;
}

.stockage-accordion__title::before {
  content: "▸ ";
  color: var(--accent-deep);
  transition: transform 0.15s ease;
  display: inline-block;
}

.stockage-accordion[open] .stockage-accordion__title::before {
  transform: rotate(90deg);
}

.stockage-accordion__summary-main {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
  flex: 1 1 auto;
}

.stockage-accordion__title {
  font-weight: 800;
  font-size: 0.98rem;
  color: var(--text);
}

.stockage-accordion__meta {
  font-size: 0.82rem;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.stockage-accordion__delete-all {
  flex-shrink: 0;
  white-space: nowrap;
}

.stockage-accordion__body {
  padding: 0 0.85rem 0.85rem;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.stockage-accordion__hint {
  margin: 0.65rem 0 0.5rem;
  font-size: 0.82rem;
}

.sauvegarde-import-panel__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.sauvegarde-import-panel__head h2 {
  margin-bottom: 0.25rem;
}

.sauvegarde-import-panel__head .hint {
  margin: 0;
}

.sauvegarde-import-summary {
  display: grid;
  gap: 0.65rem;
  margin-bottom: 1rem;
}

.sauvegarde-import-stat {
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.18);
  background: rgba(13, 148, 136, 0.08);
}

.sauvegarde-import-stat--warn {
  border-color: rgba(245, 158, 11, 0.28);
  background: rgba(245, 158, 11, 0.1);
}

.sauvegarde-import-stat__value {
  display: block;
  font-size: 1.35rem;
  line-height: 1;
  font-weight: 800;
  color: var(--accent-deep);
  font-variant-numeric: tabular-nums;
}

.sauvegarde-import-stat__label {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.sauvegarde-import-choices {
  display: grid;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.sauvegarde-import-choice {
  padding: 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface-alt, #f8fafc);
}

.sauvegarde-import-choice h3 {
  margin: 0 0 0.35rem;
  font-size: 1rem;
}

.sauvegarde-import-choice .hint {
  margin: 0 0 0.75rem;
}

.sauvegarde-import-choice .btn {
  width: 100%;
}

.sauvegarde-import-choice--merge {
  border-color: rgba(13, 148, 136, 0.28);
}

.sauvegarde-import-choice--replace {
  border-color: rgba(190, 18, 60, 0.22);
}

.sauvegarde-import-details {
  border-top: 1px solid var(--border);
  padding-top: 0.85rem;
}

.sauvegarde-import-details summary {
  cursor: pointer;
  font-weight: 800;
  color: var(--accent-deep);
}

.sauvegarde-import-table-wrap {
  margin-top: 0.75rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.sauvegarde-import-table {
  width: 100%;
  min-width: 34rem;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.sauvegarde-import-table th,
.sauvegarde-import-table td {
  padding: 0.55rem 0.6rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}

.sauvegarde-import-table thead th {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  background: var(--surface-alt, #f8fafc);
}

.sauvegarde-import-table tbody th {
  font-weight: 700;
}

.sauvegarde-sync-panel {
  scroll-margin-top: 1rem;
}

.sauvegarde-sync-panel .sauvegarde-import-panel__head {
  position: sticky;
  top: 0;
  z-index: 5;
  margin-bottom: 1rem;
  padding-bottom: 0.65rem;
  background: var(--surface);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.sauvegarde-sync-panel #btn-sync-cancel {
  flex-shrink: 0;
  position: relative;
  z-index: 6;
}

.backup-sync-reader {
  overflow: hidden;
  margin-top: 0.75rem;
  margin-bottom: 0;
  border-radius: var(--radius-sm);
  max-height: min(55vh, 22rem);
}

.backup-sync-progress {
  display: grid;
  gap: 0.4rem;
  margin-bottom: 1rem;
}

.backup-sync-progress .hint {
  margin: 0;
}

.backup-sync-success {
  margin: 0 0 1rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.12);
  border: 1px solid rgba(13, 148, 136, 0.28);
}

.backup-sync-success__title {
  margin: 0 0 0.35rem;
  font-weight: 800;
  color: var(--accent-deep);
  font-size: 1.02rem;
}

.backup-sync-success__text {
  margin: 0;
  font-size: 0.92rem;
  color: var(--text-muted);
  line-height: 1.45;
}

.backup-sync-grid {
  display: grid;
  gap: 0.85rem;
}

.backup-sync-grid--pairing-only {
  grid-template-columns: 1fr;
}

.backup-sync-box {
  padding: 0.85rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface-alt, #f8fafc);
}

.backup-sync-box h3 {
  margin: 0 0 0.35rem;
  font-size: 1rem;
}

.backup-sync-box .hint {
  margin: 0 0 0.75rem;
}

.backup-sync-qr {
  display: grid;
  place-items: center;
  min-height: 14rem;
  margin-bottom: 0.65rem;
  border: 1px dashed rgba(26, 39, 68, 0.22);
  border-radius: var(--radius-sm);
  background: #fff;
}

.backup-sync-qr:empty::before {
  content: "QR";
  color: var(--text-muted);
  font-weight: 800;
}

.backup-sync-analysis {
  margin-bottom: 0.75rem;
}

.backup-sync-conflicts {
  display: grid;
  gap: 0.55rem;
  margin-bottom: 0.75rem;
}

.backup-sync-conflict-actions {
  display: grid;
  gap: 0.45rem;
  padding: 0.7rem;
  border: 1px solid rgba(13, 148, 136, 0.22);
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.07);
}

.backup-sync-conflict-actions .btn {
  width: 100%;
  justify-content: center;
}

.backup-sync-conflict {
  display: grid;
  gap: 0.35rem;
  padding: 0.7rem;
  border: 1px solid rgba(245, 158, 11, 0.3);
  border-radius: var(--radius-sm);
  background: rgba(245, 158, 11, 0.08);
}

.backup-sync-conflict span {
  overflow-wrap: anywhere;
  color: var(--text-muted);
  font-size: 0.82rem;
}

.backup-sync-conflict select {
  width: 100%;
}

.backup-sync-advanced {
  margin-top: 0.15rem;
}

.backup-sync-conflicts-list {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.55rem;
}

.backup-sync-rgpd {
  margin-top: 1rem;
}

@media (min-width: 560px) {
  .sauvegarde-quick--secondary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sauvegarde-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sauvegarde-action-card--export {
    grid-column: 1 / -1;
  }

  .sauvegarde-import-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .sauvegarde-import-choices {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .backup-sync-grid {
    grid-template-columns: minmax(16rem, 0.9fr) minmax(18rem, 1.1fr);
  }
}

.stockage-alert {
  margin: 0 0 1rem;
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius-sm);
  font-size: 0.92rem;
  line-height: 1.45;
  border: 1px solid transparent;
}

.stockage-alert--notice {
  background: rgba(59, 130, 246, 0.1);
  border-color: rgba(59, 130, 246, 0.25);
  color: #1e3a8a;
}

.stockage-alert--warning {
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.35);
  color: #92400e;
}

.stockage-alert--critical {
  background: rgba(244, 63, 94, 0.1);
  border-color: rgba(244, 63, 94, 0.3);
  color: #9f1239;
}

.stockage-quota-wrap {
  margin: 0 0 1rem;
}

.stockage-quota__line {
  margin: 0 0 0.45rem;
  font-size: 0.92rem;
  color: var(--text-muted);
}

.stockage-quota__line strong {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.stockage-quota__bar {
  height: 0.5rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  overflow: hidden;
}

.stockage-quota__fill {
  height: 100%;
  width: 0;
  border-radius: 999px;
  background: var(--accent);
  transition: width 0.25s ease;
}

.stockage-quota__fill--notice {
  background: #3b82f6;
}

.stockage-quota__fill--warning {
  background: #f59e0b;
}

.stockage-quota__fill--critical {
  background: #f43f5e;
}

.stockage-quota-hint {
  margin: -0.35rem 0 1rem;
  font-size: 0.85rem;
}

.stockage-total {
  margin: 0 0 1rem;
  font-size: 1.05rem;
}

.stockage-total strong {
  color: var(--accent-deep);
  font-variant-numeric: tabular-nums;
}

.stockage-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.stockage-groupe {
  list-style: none;
}

.stockage-groupe__titre {
  margin: 0 0 0.5rem;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.stockage-groupe__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.stockage-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.04);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.stockage-item--empty {
  opacity: 0.65;
}

.stockage-item__main {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
  flex: 1 1 auto;
}

.stockage-item__titre {
  font-weight: 700;
  color: var(--text);
}

.stockage-item__meta {
  font-size: 0.88rem;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.stockage-item__delete {
  flex-shrink: 0;
  white-space: nowrap;
}

.stockage-vide {
  margin: 0.5rem 0 0;
  text-align: center;
}

/* --- Bannière installation PWA --- */
.install-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9000;
  padding: 0.65rem max(0.65rem, env(safe-area-inset-left)) max(0.65rem, env(safe-area-inset-bottom))
    max(0.65rem, env(safe-area-inset-right));
  pointer-events: none;
  transform: translateY(110%);
  opacity: 0;
  transition: transform 0.35s ease, opacity 0.35s ease;
}

.install-banner--visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.install-banner__inner {
  max-width: 32rem;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 0.5rem 0.75rem;
  align-items: start;
  padding: 0.85rem 2.5rem 0.85rem 0.85rem;
  background: linear-gradient(165deg, #ffffff 0%, #f0fdfa 100%);
  border: 1px solid rgba(13, 148, 136, 0.35);
  border-radius: var(--radius);
  box-shadow: 0 -8px 32px rgba(15, 23, 42, 0.18);
  position: relative;
}

.install-banner__icon {
  grid-row: 1 / span 2;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(13, 148, 136, 0.2);
}

.install-banner__body {
  min-width: 0;
}

.install-banner__title {
  margin: 0 0 0.2rem;
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--accent-deep);
  line-height: 1.25;
}

.install-banner__text {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.4;
  color: var(--text-muted);
}

.install-banner__actions {
  grid-column: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.install-banner__close {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 6px;
}

.install-banner__close:hover {
  color: var(--text);
  background: rgba(15, 23, 42, 0.06);
}

body.install-banner-open {
  padding-bottom: calc(5.5rem + env(safe-area-inset-bottom, 0px));
}

/* --- Rappel mode navigateur / app installée --- */
.pwa-context-banner {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 8995;
  padding: max(0.45rem, env(safe-area-inset-top, 0px)) max(0.55rem, env(safe-area-inset-right, 0px)) 0.45rem
    max(0.55rem, env(safe-area-inset-left, 0px));
  pointer-events: none;
  transform: translateY(-110%);
  opacity: 0;
  transition: transform 0.32s ease, opacity 0.32s ease;
}

.pwa-context-banner--visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.pwa-context-banner__inner {
  max-width: 40rem;
  margin: 0 auto;
  position: relative;
  padding: 0.75rem 2.35rem 0.75rem 0.85rem;
  background: linear-gradient(165deg, #fffbeb 0%, #fff7ed 100%);
  border: 1px solid #fdba74;
  border-radius: var(--radius-sm);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.14);
}

.pwa-context-banner__title {
  margin: 0 0 0.2rem;
  font-size: 0.9rem;
  font-weight: 800;
  color: #9a3412;
  line-height: 1.3;
}

.pwa-context-banner__text {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.42;
  color: #7c2d12;
}

.pwa-context-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.55rem;
}

.pwa-context-banner__close {
  position: absolute;
  top: 0.3rem;
  right: 0.3rem;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: none;
  background: transparent;
  color: #9a3412;
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 6px;
}

.pwa-context-banner__close:hover {
  background: rgba(154, 52, 18, 0.08);
}

body.pwa-context-hint-open {
  padding-top: calc(5.75rem + env(safe-area-inset-top, 0px));
}

body.pwa-context-hint-open.install-banner-open {
  padding-top: calc(5.75rem + env(safe-area-inset-top, 0px));
}

@media (max-width: 520px) {
  body.pwa-context-hint-open {
    padding-top: calc(7.25rem + env(safe-area-inset-top, 0px));
  }

  .pwa-context-banner__actions .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
}

/* --- Bannière migration domaine (GitHub → outilseps.fr) --- */
.migration-banner {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 9020;
  padding: max(0.5rem, env(safe-area-inset-top, 0px)) max(0.55rem, env(safe-area-inset-right, 0px)) 0.5rem
    max(0.55rem, env(safe-area-inset-left, 0px));
  pointer-events: none;
  transform: translateY(-110%);
  opacity: 0;
  transition: transform 0.34s ease, opacity 0.34s ease;
}

.migration-banner--visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.migration-banner__inner {
  max-width: 52rem;
  margin: 0 auto;
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 0.55rem 0.85rem;
  align-items: start;
  padding: 0.85rem 2.4rem 0.85rem 0.9rem;
  background: linear-gradient(165deg, #ecfdf5 0%, #f0fdfa 55%, #ffffff 100%);
  border: 1px solid rgba(22, 163, 74, 0.45);
  border-radius: var(--radius);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.16);
}

.migration-banner__icon {
  grid-row: 1 / span 2;
  border-radius: 12px;
  box-shadow: 0 2px 10px rgba(22, 163, 74, 0.28);
}

.migration-banner__body {
  min-width: 0;
}

.migration-banner__title {
  margin: 0 0 0.2rem;
  font-size: 0.98rem;
  font-weight: 800;
  color: #14532d;
  line-height: 1.25;
}

.migration-banner__text {
  margin: 0 0 0.2rem;
  font-size: 0.82rem;
  line-height: 1.42;
  color: #166534;
}

.migration-banner__note {
  margin: 0.15rem 0 0;
  font-size: 0.78rem;
  line-height: 1.35;
  color: #15803d;
  font-style: italic;
}

.migration-banner__link {
  color: #0f766e;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.migration-banner__actions {
  grid-column: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.migration-banner__close {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: none;
  background: transparent;
  color: #166534;
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 6px;
}

.migration-banner__close:hover {
  background: rgba(22, 163, 74, 0.1);
}

body.migration-banner-open {
  padding-top: calc(8.5rem + env(safe-area-inset-top, 0px));
}

body.migration-banner-open.pwa-context-hint-open {
  padding-top: calc(13.5rem + env(safe-area-inset-top, 0px));
}

@media (max-width: 640px) {
  .migration-banner__inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    padding-top: 2.1rem;
  }

  .migration-banner__icon {
    grid-row: auto;
    width: 44px;
    height: 44px;
  }

  .migration-banner__actions {
    grid-column: 1;
  }

  .migration-banner__actions .btn {
    flex: 1 1 auto;
    justify-content: center;
  }

  body.migration-banner-open {
    padding-top: calc(11.5rem + env(safe-area-inset-top, 0px));
  }

  body.migration-banner-open.pwa-context-hint-open {
    padding-top: calc(17rem + env(safe-area-inset-top, 0px));
  }
}

/* --- Modale migration domaine --- */
.migration-dialog {
  max-width: min(42rem, calc(100vw - 1.5rem));
}

.migration-dialog__intro {
  margin: 0 0 1rem;
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--text-muted);
}

.migration-accordion {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-bottom: 0.85rem;
}

.migration-accordion__item {
  margin: 0;
}

.migration-accordion__panel .hint {
  margin-top: 0;
}

.migration-figure {
  margin: 0.75rem 0 0.5rem;
  text-align: center;
}

.migration-figure img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.35);
  box-shadow: 0 4px 16px rgba(15, 23, 42, 0.08);
}

.migration-figure--wide img {
  width: 100%;
}

.migration-figure figcaption {
  margin-top: 0.35rem;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.migration-steps {
  margin: 0.5rem 0 0;
  padding-left: 1.2rem;
}

.migration-steps li {
  margin-bottom: 0.35rem;
  line-height: 1.4;
}

.migration-dual-steps {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 0.65rem;
}

.migration-dual-steps__block {
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.35);
}

.migration-dual-steps__block h3 {
  margin: 0 0 0.35rem;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.migration-dual-steps__block--legacy {
  background: #eff6ff;
  border-color: rgba(30, 64, 175, 0.25);
}

.migration-dual-steps__block--legacy h3 {
  color: #1e3a8a;
}

.migration-dual-steps__block--new {
  background: #ecfdf5;
  border-color: rgba(22, 163, 74, 0.3);
}

.migration-dual-steps__block--new h3 {
  color: #14532d;
}

.migration-dual-steps__url {
  margin: 0 0 0.5rem;
  font-size: 0.75rem;
  word-break: break-all;
  color: var(--text-muted);
}

.migration-dialog__actions {
  margin-top: 0;
}

@media (max-width: 600px) {
  .migration-dual-steps {
    grid-template-columns: 1fr;
  }
}

/* --- Compteur bonus --- */
.page-outil--bonus {
  max-width: min(54rem, 100%);
}

.page-outil--bonus .page-outil__header--compact {
  margin-bottom: 0.35rem;
}

.page-outil--bonus .page-outil__header--compact h1 {
  font-size: 1.15rem;
}

.page-outil--bonus .card--accordion-compact {
  margin-bottom: 0.35rem;
}

.page-outil--bonus .card--accordion-compact .card--accordion__summary {
  padding: 0.55rem 0.75rem;
  font-size: 0.9rem;
}

.page-outil--bonus .card--accordion-compact .card--accordion__panel {
  padding-top: 0;
}

.bonus-intro {
  margin-bottom: 0.85rem;
}

.bonus-reglages-row {
  flex-wrap: wrap;
  gap: 0.35rem;
}

.bonus-reglages-row .field-group {
  flex: 1 1 4.5rem;
  min-width: 0;
}

.bonus-undo,
.bonus-reset {
  width: 100%;
  justify-content: center;
  margin: 0 0 0.5rem;
}

.bonus-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.45rem;
}

.bonus-card {
  --bonus-color: var(--accent);
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  border-top: 4px solid var(--bonus-color);
}

.bonus-card__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.45rem;
  align-items: center;
}

.bonus-name-input {
  width: 100%;
  min-width: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.65rem;
  background: rgba(255, 255, 255, 0.92);
  color: var(--text);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 800;
}

.bonus-color-input {
  width: 2.8rem;
  height: 2.35rem;
  padding: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.5rem;
  background: transparent;
  cursor: pointer;
}

.bonus-result {
  padding: 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.08);
  text-align: center;
}

.bonus-result__label {
  display: block;
  margin-bottom: 0.15rem;
  font-size: 0.7rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.bonus-result strong {
  display: inline;
  font-size: clamp(2.6rem, 15vw, 4rem);
  line-height: 1;
  font-weight: 850;
  color: var(--bonus-color);
  font-variant-numeric: tabular-nums;
}

.bonus-result__unit {
  display: inline-block;
  margin-left: 0.2rem;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text-muted);
  vertical-align: super;
}

.bonus-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.4rem;
}

.bonus-stats p {
  margin: 0;
  padding: 0.55rem 0.35rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.04);
  text-align: center;
}

.bonus-stats span {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.bonus-stat__line {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.2rem;
  margin-top: 0.1rem;
}

.bonus-stats strong {
  font-size: 1.25rem;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.bonus-stat__pct {
  font-size: 0.72rem;
  font-weight: 650;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.bonus-stat__pct:empty {
  display: none;
}

.bonus-buttons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
}

.bonus-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  min-height: 4.5rem;
  padding: 0.45rem 0.25rem;
  border: none;
  border-radius: var(--radius-sm);
  color: #fff;
  font: inherit;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.bonus-btn:active {
  transform: scale(0.98);
}

.bonus-btn__icon {
  font-size: 1.65rem;
  line-height: 1;
}

.bonus-btn__label {
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.bonus-btn--bonus {
  background: linear-gradient(180deg, #22c55e, #15803d);
  box-shadow: 0 6px 18px rgba(21, 128, 61, 0.2);
}

.bonus-btn--normal {
  background: var(--bonus-color);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.12);
}

.bonus-btn--malus {
  background: linear-gradient(180deg, #f43f5e, #be123c);
  box-shadow: 0 6px 18px rgba(190, 18, 60, 0.16);
}

@media (max-width: 640px) {
  .bonus-card {
    padding: 0.55rem;
    gap: 0.5rem;
  }

  .bonus-result {
    padding: 0.65rem 0.35rem;
  }

  .bonus-btn {
    min-height: 4rem;
  }
}

@media (min-width: 641px) {
  .bonus-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
  }

  .bonus-card {
    min-width: 0;
  }

  .bonus-btn {
    min-height: 4.75rem;
  }
}

@media (max-width: 559px) {
  .bonus-reglages-row .field-group {
    flex: 1 1 30%;
  }

  .page-outil--bonus .bonus-reset {
    padding: 0.45rem 0.65rem;
    font-size: 0.85rem;
  }
}

@media (min-width: 560px) {
  .install-banner__inner {
    max-width: 36rem;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto;
    align-items: center;
    padding-right: 2.75rem;
  }

  .install-banner__icon {
    grid-row: auto;
  }

  .install-banner__actions {
    grid-column: 3;
    flex-direction: column;
    align-items: stretch;
  }
}

/* --- Pyramide de victoires --- */
.page-outil--pyramide {
  max-width: min(48rem, 100%);
}

.pyramide-actions-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin-top: 0.75rem;
  margin-bottom: 1rem;
}

.pyramide-actions-row .btn {
  flex: 1 1 auto;
}

.pyramide-nb-joueurs {
  margin: 0 0 0.85rem;
  padding: 0.55rem 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.14);
  border: 1px solid rgba(13, 148, 136, 0.28);
  font-size: 1rem;
  font-weight: 850;
  color: var(--accent-deep);
  text-align: center;
}

.pyramide-joueurs-list,
.pyramide-historique {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.page-outil--pyramide #pyramide-historique-panel .card--accordion__panel {
  padding-top: 0.25rem;
}

.page-outil--pyramide #pyramide-historique-panel .pyramide-historique {
  margin-top: 0.35rem;
}

.pyramide-joueur-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 0.5rem;
  align-items: center;
  padding: 0.55rem 0.65rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(13, 148, 136, 0.12);
}

.pyramide-joueur-item__meta {
  font-size: 0.8rem;
  color: var(--text-muted);
  font-weight: 700;
  white-space: nowrap;
}

.pyramide-classement {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.pyramide-classement__item {
  display: grid;
  grid-template-columns: 2.25rem minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
  padding: 0.5rem 0.6rem;
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.03);
}

.pyramide-classement__rang {
  font-weight: 900;
  color: var(--accent-deep);
  text-align: center;
}

.pyramide-classement__nom {
  font-weight: 750;
  min-width: 0;
  word-break: break-word;
}

.pyramide-classement__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  justify-content: flex-end;
}

.pyramide-classement__stat {
  display: inline-flex;
  align-items: baseline;
  gap: 0.12rem;
  padding: 0.2rem 0.45rem;
  border-radius: 0.45rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}

.pyramide-classement__stat-n {
  font-size: 0.85rem;
}

.pyramide-classement__stat-lbl {
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.02em;
}

.pyramide-classement__stat--v {
  background: rgba(22, 163, 74, 0.12);
  color: #15803d;
  border: 1px solid rgba(22, 163, 74, 0.28);
}

.pyramide-classement__stat--d {
  background: rgba(220, 38, 38, 0.1);
  color: #b91c1c;
  border: 1px solid rgba(220, 38, 38, 0.24);
}

.pyramide-board__cols {
  display: none;
  gap: 0.65rem;
  overflow-x: auto;
  padding-bottom: 0.35rem;
}

.pyramide-board__stack {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.pyramide-col {
  flex: 0 0 min(9.5rem, 42vw);
  min-width: 7rem;
  padding: 0.55rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.06);
  border: 1px solid rgba(13, 148, 136, 0.16);
}

.pyramide-col__title {
  margin: 0 0 0.45rem;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--accent-deep);
  text-align: center;
}

.pyramide-col__list,
.pyramide-stack-bloc {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.pyramide-col__list li,
.pyramide-stack-bloc li {
  padding: 0.4rem 0.45rem;
  border-radius: 8px;
  background: #fff;
  font-weight: 700;
  font-size: 0.9rem;
  word-break: break-word;
}

.pyramide-stack-sep {
  margin: 0.5rem 0 0.15rem;
  padding: 0.35rem 0.55rem;
  border-radius: 999px;
  background: var(--accent-deep);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 900;
  text-align: center;
  letter-spacing: 0.02em;
}

.pyramide-match-form .field-group {
  margin-bottom: 0.65rem;
}

.pyramide-historique__item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.45rem;
  padding: 0.55rem 0.65rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.pyramide-empty {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.9rem;
}

@media (min-width: 720px) {
  .pyramide-board__cols {
    display: flex;
  }

  .pyramide-board__stack {
    display: none;
  }
}

/* --- Partage QR élèves / imports prof --- */

.eleve-share-bar {
  margin-top: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

.eleve-qr-share-btn {
  width: 100%;
  max-width: 22rem;
}

.eleve-qr-dialog {
  border: none;
  border-radius: var(--radius);
  padding: 0;
  max-width: min(96vw, 26rem);
  box-shadow: var(--shadow-lg);
  background: var(--surface);
}

.eleve-qr-dialog::backdrop {
  background: rgba(15, 23, 42, 0.55);
}

.eleve-qr-dialog__form {
  padding: 1rem 1.1rem 1.15rem;
}

.eleve-qr-dialog__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.eleve-qr-dialog__header h2 {
  margin: 0;
  font-size: 1.1rem;
}

.eleve-qr-dialog__qr {
  display: flex;
  justify-content: center;
  margin: 0.75rem 0;
  min-height: 280px;
  align-items: center;
}

.eleve-qr-dialog__qr img,
.eleve-qr-dialog__qr canvas {
  border-radius: var(--radius-sm);
}

.eleve-qr-url {
  width: 100%;
  font-family: ui-monospace, monospace;
  font-size: 0.72rem;
  padding: 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.35);
  resize: vertical;
}

.eleve-qr-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.65rem;
}

.eleve-qr-meta {
  margin-top: 0.5rem;
}

.page-outil--donnees-eleves {
  max-width: min(54rem, 100%);
}

.donnees-eleves-layout {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.donnees-eleves-scan.card,
.donnees-eleves-liste.card {
  margin: 0;
}

.recup-reader {
  width: 100%;
  max-width: 320px;
  margin: 0 auto;
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.recup-reader video {
  width: 100%;
  border-radius: var(--radius-sm);
}

.recup-scan-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.viz-filtres {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.viz-filtres__row {
  display: grid;
  gap: 0.65rem;
}

@media (min-width: 480px) {
  .viz-filtres__row--2 {
    grid-template-columns: 1fr 1fr;
  }
}

.viz-filtres-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.65rem;
}

.viz-count {
  font-weight: 600;
  color: var(--text-muted);
}

.imports-table-wrap {
  margin-top: 0.65rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid rgba(148, 163, 184, 0.25);
  border-radius: var(--radius-sm);
  background: #fff;
}

.imports-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}

.imports-table th,
.imports-table td {
  padding: 0.5rem 0.6rem;
  text-align: left;
  border-bottom: 1px solid rgba(148, 163, 184, 0.2);
  white-space: nowrap;
}

.imports-table th {
  position: sticky;
  top: 0;
  background: rgba(13, 148, 136, 0.1);
  color: var(--accent-deep);
  font-weight: 600;
  font-size: 0.8rem;
}

.imports-table tbody tr {
  cursor: pointer;
}

.imports-table tbody tr:hover {
  background: rgba(13, 148, 136, 0.05);
}

.imports-table tbody tr.is-selected {
  background: rgba(13, 148, 136, 0.12);
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.imports-table tbody tr:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.import-detail-row {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.35rem 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.15);
  font-size: 0.9rem;
}

.import-detail-section {
  margin: 0.75rem 0 0.35rem;
  font-size: 0.95rem;
  color: var(--accent-deep);
}

.sauvegarde-imports__sub {
  margin: 1.1rem 0 0.5rem;
  font-size: 1rem;
  color: var(--accent-deep);
}

.imports-detail-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem 1rem;
  margin-bottom: 0.75rem;
}

.imports-detail-toolbar__title {
  margin: 0;
}

.imports-detail-card {
  margin-top: 1rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
}

.imports-detail {
  margin-bottom: 0.75rem;
}

.import-preview-root {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.import-preview-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.65rem;
}

.import-preview-meta__chip {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.25rem;
  padding: 0.3rem 0.55rem;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.08);
  border: 1px solid rgba(13, 148, 136, 0.18);
  font-size: 0.82rem;
}

.import-preview-meta__label {
  color: var(--text-muted);
  font-weight: 600;
}

.import-preview {
  pointer-events: none;
  user-select: text;
}

.import-preview .btn,
.import-preview .ratio-btn,
.import-preview .table-score-btn,
.import-preview .table-minus-btn,
.import-preview .bonus-btn {
  display: none;
}

.import-preview__team-name,
.import-preview__title {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
  font-weight: 800;
  text-align: center;
}

.import-preview__score {
  margin: 0.25rem 0;
}

.import-preview__timer {
  margin-top: 0.65rem;
}

.import-preview__badge {
  text-align: center;
  font-weight: 700;
}

.import-preview--table-marque .table-color-label {
  display: none;
}

.import-preview__bonus-details {
  text-align: center;
  font-size: 0.88rem;
  color: var(--text-muted);
  margin: 0.35rem 0 0;
}

.import-preview__impact-grid {
  margin-top: 0.5rem;
}

/* --- Journal de musculation (élève + aperçu prof) --- */
.page-outil--journal-muscu {
  max-width: min(40rem, 100%);
}

.journal-muscu-home,
.journal-muscu-session-view {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.journal-muscu-intro {
  margin: 0 0 0.15rem;
}

.page-outil--journal-muscu .journal-muscu-acc.card--accordion > summary {
  gap: 0.5rem;
}

.journal-muscu-acc__badge {
  margin-left: auto;
  margin-right: 0.15rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--accent-deep);
  background: rgba(13, 148, 136, 0.1);
  border: 1px solid rgba(13, 148, 136, 0.18);
  white-space: nowrap;
}

.journal-muscu-new-btn {
  width: 100%;
  margin-top: 0.85rem;
  margin-bottom: 0.65rem;
}

.journal-muscu-session-info {
  margin-bottom: 0;
  padding: 1rem 1.05rem;
}

.journal-muscu-session-info-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
  gap: 0.6rem 0.75rem;
  align-items: end;
}

.journal-muscu-session-info-sep {
  grid-column: 1 / -1;
  margin: 0.2rem 0 0.05rem;
  border: none;
  border-top: 2px solid rgba(15, 23, 42, 0.1);
}

.journal-muscu-session-info-grid .field-group {
  margin: 0;
}

.journal-muscu-session-info-grid input {
  width: 100%;
  min-width: 0;
}

@media (max-width: 420px) {
  .journal-muscu-session-info-grid {
    grid-template-columns: 1fr;
  }
}

.journal-muscu-date-field input[type="date"] {
  min-width: 10.5rem;
}

.journal-muscu-session-footer {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.journal-muscu-session-footer .eleve-share-bar {
  margin-top: 0.15rem;
}

.journal-muscu-session-footer .journal-muscu-delete {
  margin-top: 0.15rem;
}

.journal-muscu-catalog-panel {
  padding-top: 0;
}

.journal-muscu-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}

@media (min-width: 480px) {
  .journal-muscu-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.journal-muscu-stat {
  margin: 0;
  padding: 0.55rem 0.5rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.08);
  text-align: center;
}

.journal-muscu-stat span {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.journal-muscu-stat strong {
  display: block;
  margin-top: 0.15rem;
  font-size: 1.15rem;
  font-variant-numeric: tabular-nums;
  color: var(--accent-deep);
}

.journal-muscu-sessions {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.journal-muscu-session-row {
  display: flex;
  align-items: stretch;
  gap: 0.35rem;
}

.journal-muscu-session-del {
  flex-shrink: 0;
  align-self: center;
  min-width: 2.5rem;
  color: var(--danger, #b91c1c);
}

.journal-muscu-session-btn {
  flex: 1;
  width: auto;
  text-align: left;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: #fff;
  font: inherit;
  cursor: pointer;
}

.journal-muscu-session-btn__title {
  display: block;
  font-weight: 800;
  color: var(--text);
}

.journal-muscu-session-btn__meta {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.journal-muscu-session-head {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.journal-muscu-back {
  align-self: flex-start;
}

.journal-muscu-catalog-hint {
  margin: 0 0 0.5rem;
}

.journal-muscu-catalog-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.5rem 0.65rem;
  align-items: end;
  margin-bottom: 0.65rem;
}

.journal-muscu-catalog-search {
  grid-column: 1 / -1;
  margin: 0;
}

.journal-muscu-catalog-filter {
  width: 100%;
  padding: 0.5rem 0.6rem;
  border: 1px solid rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-sm);
  font: inherit;
}

.journal-muscu-catalog-filter:focus {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
  border-color: var(--accent);
}

.journal-muscu-catalog-toolbar > .field-label {
  margin: 0;
  white-space: nowrap;
}

.journal-muscu-catalog-sort {
  flex: 1 1 10rem;
  min-width: 9rem;
  min-width: 0;
  padding: 0.45rem 0.5rem;
  border: 1px solid rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-sm);
  font: inherit;
}

.journal-muscu-catalog-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-height: min(22rem, 50vh);
  overflow-y: auto;
  margin-bottom: 0.65rem;
  padding-right: 0.15rem;
}

.journal-muscu-catalog-empty {
  margin: 0;
  padding: 0.75rem 0.25rem;
}

.journal-muscu-catalog-group h3 {
  margin: 0 0 0.35rem;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}

.journal-muscu-catalog-items {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.journal-muscu-catalog-chip {
  display: inline-flex;
  align-items: stretch;
  gap: 0;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: #fff;
  overflow: hidden;
}

.journal-muscu-catalog-del {
  border-radius: 0;
  border: none;
  border-left: 1px solid rgba(148, 163, 184, 0.25);
  color: var(--danger, #b91c1c);
  min-width: 2rem;
}

.journal-muscu-other-exo,
.journal-muscu-catalog-custom {
  margin-top: 0.65rem;
}

.journal-muscu-other-exo summary,
.journal-muscu-catalog-custom summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--accent-deep);
}

.journal-muscu-other-hint {
  margin: 0.35rem 0 0.5rem;
}

.journal-muscu-other-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.journal-muscu-other-form input {
  flex: 1 1 12rem;
  min-width: 0;
  padding: 0.45rem 0.5rem;
  border: 1px solid rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-sm);
  font: inherit;
}

.journal-muscu-exos-hint {
  margin: 0 0 0.65rem;
}

.journal-muscu-insights {
  margin-top: 0.85rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
}

.journal-muscu-insights-block + .journal-muscu-insights-block {
  margin-top: 0.75rem;
}

.journal-muscu-insights-title {
  margin: 0 0 0.45rem;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}

.journal-muscu-insights-list {
  margin: 0;
  padding-left: 1.15rem;
  font-size: 0.9rem;
}

.journal-muscu-insights-list li {
  margin-bottom: 0.25rem;
}

.journal-muscu-body-block {
  margin-top: 0.15rem;
}

.journal-muscu-body-hint {
  margin: 0 0 0.5rem;
  font-size: 0.82rem;
}

.journal-muscu-body-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.75rem 1rem;
}

.journal-muscu-body-svg-host {
  flex: 1 1 16rem;
  min-width: 0;
  max-width: 100%;
}

.journal-muscu-body-svg {
  display: block;
  width: 100%;
  max-width: 24rem;
  margin: 0 auto;
  height: auto;
  filter: drop-shadow(0 2px 6px rgba(15, 23, 42, 0.06));
}

.journal-muscu-body__panel {
  isolation: isolate;
}

.journal-muscu-body__outline {
  fill: #f4f7fb;
  stroke: #b8c5d4;
  stroke-width: 1.35;
  stroke-linejoin: round;
}

.journal-muscu-body__head {
  fill: #f8fafc;
  stroke: #b8c5d4;
  stroke-width: 1.1;
  pointer-events: none;
}

.journal-muscu-body__label {
  font-size: 9px;
  font-weight: 800;
  fill: var(--text-muted);
  text-anchor: middle;
  font-family: inherit;
}

.journal-muscu-body-svg [data-region] {
  fill: #d8e2ec;
  stroke: #7b92a8;
  stroke-width: 0.85;
  stroke-linejoin: round;
  stroke-linecap: round;
  transition: fill 0.2s ease, stroke 0.2s ease;
  cursor: help;
}

.journal-muscu-body-svg [data-region]:hover {
  stroke-width: 0.85;
  stroke: rgba(13, 120, 110, 0.75);
}

.journal-muscu-body-svg [data-region].has-heat {
  stroke: rgba(13, 120, 110, 0.55);
}

.journal-muscu-body-svg [data-region].has-heat--low {
  fill: rgba(13, 148, 136, 0.28);
}

.journal-muscu-body-svg [data-region].has-heat--mid {
  fill: rgba(13, 148, 136, 0.52);
}

.journal-muscu-body-svg [data-region].has-heat--high {
  fill: rgba(13, 120, 110, 0.82);
}

.journal-muscu-body-legend {
  flex: 1 1 9rem;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.85rem;
}

.journal-muscu-body-legend li {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.35rem;
}

.journal-muscu-body-legend__swatch {
  flex-shrink: 0;
  width: 0.85rem;
  height: 0.85rem;
  border-radius: 2px;
  background: rgba(13, 148, 136, calc(0.15 + var(--heat, 0) * 0.75));
  border: 1px solid rgba(13, 120, 110, 0.35);
}

.journal-muscu-body-legend strong {
  margin-left: auto;
  font-variant-numeric: tabular-nums;
  color: var(--accent-deep);
}

/* --- Journal musculation : 1RM --- */
.journal-muscu-rm-intro {
  margin-bottom: 0.65rem;
}

.journal-muscu-rm-formula {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  margin: 0 0 0.75rem;
  padding: 0;
  border: none;
}

.journal-muscu-rm-formula legend {
  width: 100%;
  margin-bottom: 0.15rem;
}

.journal-muscu-rm-formula-opt {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
}

.journal-muscu-rm-list {
  list-style: none;
  margin: 0 0 0.75rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.journal-muscu-rm-list li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  padding: 0.45rem 0.55rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 148, 136, 0.06);
  border: 1px solid rgba(148, 163, 184, 0.25);
}

.journal-muscu-rm-list__name {
  font-weight: 700;
  flex: 1 1 8rem;
}

.journal-muscu-rm-list__tag {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--accent-deep);
}

.journal-muscu-rm-add {
  margin-bottom: 0.75rem;
}

.journal-muscu-rm-add summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--accent-deep);
}

.journal-muscu-rm-add-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.45rem;
}

.journal-muscu-rm-add-form input {
  flex: 1 1 9rem;
  min-width: 0;
  padding: 0.45rem 0.5rem;
  border: 1px solid rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-sm);
  font: inherit;
}

.journal-muscu-rm-estim {
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-muted);
  font-size: 0.85em;
}

.journal-muscu-rm-table-wrap {
  overflow-x: auto;
  margin-top: 0.35rem;
}

.journal-muscu-rm-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.journal-muscu-rm-table th,
.journal-muscu-rm-table td {
  padding: 0.4rem 0.45rem;
  text-align: left;
  border-bottom: 1px solid rgba(148, 163, 184, 0.2);
  vertical-align: top;
}

.journal-muscu-rm-table th {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}

.journal-muscu-rm-potential-val {
  color: var(--accent-deep);
  white-space: nowrap;
}

.journal-muscu-rm-source {
  font-size: 0.8rem;
  color: var(--text-muted);
}

.journal-muscu-exo-rm {
  margin-top: 0.55rem;
  padding-top: 0.5rem;
  border-top: 1px dashed rgba(148, 163, 184, 0.35);
}

.journal-muscu-exo-rm__line {
  margin: 0 0 0.25rem;
  font-size: 0.84rem;
  line-height: 1.35;
}

.journal-muscu-exo-rm__line strong {
  color: var(--accent-deep);
}

.journal-muscu-exo-rm__badge {
  display: inline-block;
  padding: 0.1rem 0.35rem;
  border-radius: 3px;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background: rgba(13, 148, 136, 0.15);
  color: var(--accent-deep);
}

.journal-muscu-exo-rm__badge--rec {
  background: rgba(30, 64, 175, 0.12);
  color: #1e40af;
}

.journal-muscu-catalog-chip .journal-muscu-catalog-item {
  text-align: left;
  padding: 0.4rem 0.55rem;
  border: none;
  border-radius: 0;
  background: transparent;
  font: inherit;
  cursor: pointer;
}

.journal-muscu-catalog-item__name {
  display: block;
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--text);
}

.journal-muscu-catalog-item__meta {
  display: block;
  margin-top: 0.1rem;
  font-size: 0.72rem;
  color: var(--text-muted);
}

.journal-muscu-catalog-custom summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--accent-deep);
  margin-bottom: 0.45rem;
}

.journal-muscu-catalog-custom-form {
  display: grid;
  gap: 0.4rem;
}

.journal-muscu-add-exo {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 0.75rem;
}

.journal-muscu-add-exo input {
  flex: 1 1 12rem;
  min-width: 0;
}

#journal-acc-session-exos .card--accordion__panel {
  padding-top: 0.85rem;
  background: rgba(15, 23, 42, 0.04);
  border-radius: 0 0 calc(var(--radius) - 2px) calc(var(--radius) - 2px);
}

.journal-muscu-exercises {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.journal-muscu-exo-card {
  margin: 0;
  padding: 0.95rem 1rem 1.05rem;
  background: #fff;
  border: 2px solid rgba(15, 23, 42, 0.14);
  border-left: 5px solid var(--accent-deep);
  border-radius: var(--radius-sm);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.1);
}

.journal-muscu-exo-card::before {
  display: none;
}

.journal-muscu-exo-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.65rem;
  margin-bottom: 0.75rem;
  padding-bottom: 0.65rem;
  border-bottom: 2px solid rgba(15, 23, 42, 0.12);
}

.journal-muscu-exo-head h3 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.25;
  color: var(--text);
}

.journal-muscu-exo-index {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.85rem;
  height: 1.85rem;
  margin-top: 0.05rem;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #fff;
  background: var(--accent-deep);
}

.journal-muscu-exo-title-wrap {
  flex: 1;
  min-width: 0;
}

.journal-muscu-exo-meta {
  margin: 0.15rem 0 0;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.journal-muscu-mode {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 0.5rem;
}

.journal-muscu-mode-btn {
  flex: 1;
  padding: 0.4rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.4);
  background: #fff;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  color: var(--text-muted);
}

.journal-muscu-mode-btn.is-active {
  border-color: var(--accent);
  background: rgba(13, 148, 136, 0.12);
  color: var(--accent-deep);
}

.journal-muscu-uniform {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.4rem;
}

@media (max-width: 400px) {
  .journal-muscu-uniform {
    grid-template-columns: 1fr;
  }
}

.journal-muscu-uniform-row {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.journal-muscu-uniform-row input {
  width: 100%;
  min-width: 0;
  padding: 0.45rem 0.5rem;
  border: 1px solid rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-sm);
  font: inherit;
}

.journal-muscu-uniform-hint {
  grid-column: 1 / -1;
  margin: 0;
}

.journal-muscu-preview-uniform {
  margin: 0;
  font-weight: 700;
  color: var(--accent-deep);
}

.journal-muscu-preview-exo-meta {
  margin: 0 0 0.35rem;
}

.journal-muscu-sets-table {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.journal-muscu-sets-head,
.journal-muscu-sets-row {
  display: grid;
  grid-template-columns: 2rem 1fr 1fr minmax(5.4rem, 0.8fr) 2.5rem;
  gap: 0.35rem;
  align-items: center;
}

.journal-muscu-sets-head {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--text-muted);
}

.journal-muscu-sets-row input,
.journal-muscu-rpe-select {
  width: 100%;
  min-width: 0;
  padding: 0.45rem 0.5rem;
  border: 1px solid rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: 0.95rem;
}

.journal-muscu-rpe-select {
  font-weight: 800;
  color: var(--text-muted);
  background: #fff;
}

.journal-muscu-rpe-select.is-rpe-5,
.journal-muscu-rpe-option.is-rpe-5 {
  border-color: #06b970;
  background: #08c774;
  color: #052e18;
}

.journal-muscu-rpe-select.is-rpe-6,
.journal-muscu-rpe-option.is-rpe-6 {
  border-color: #9ee944;
  background: #b9fb63;
  color: #244006;
}

.journal-muscu-rpe-select.is-rpe-7,
.journal-muscu-rpe-option.is-rpe-7 {
  border-color: #f6d44e;
  background: #ffe35c;
  color: #4a3600;
}

.journal-muscu-rpe-select.is-rpe-8,
.journal-muscu-rpe-option.is-rpe-8 {
  border-color: #f3ad3c;
  background: #ffc45a;
  color: #4a2500;
}

.journal-muscu-rpe-select.is-rpe-9,
.journal-muscu-rpe-option.is-rpe-9 {
  border-color: #fb7a3c;
  background: #ff8d4d;
  color: #4a1400;
}

.journal-muscu-rpe-select.is-rpe-10,
.journal-muscu-rpe-option.is-rpe-10 {
  border-color: #ef2626;
  background: #ff3030;
  color: #fff;
}

.journal-muscu-rpe-acc {
  grid-column: 1 / -1;
  margin-top: 0.3rem;
  padding: 0.45rem 0.55rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: var(--radius-sm);
  background: rgba(248, 250, 252, 0.85);
}

.journal-muscu-rpe-acc summary {
  cursor: pointer;
  font-weight: 800;
  color: var(--accent-deep);
}

.journal-muscu-rpe-acc__badge {
  display: block;
  margin-top: 0.15rem;
  color: var(--text-muted);
  font-size: 0.78rem;
  font-weight: 600;
}

.journal-muscu-rpe-list {
  display: grid;
  gap: 0.35rem;
  margin-top: 0.5rem;
}

.journal-muscu-rpe-row {
  display: grid;
  grid-template-columns: minmax(4.5rem, 0.35fr) minmax(8rem, 0.65fr);
  gap: 0.45rem;
  align-items: center;
}

.journal-muscu-rpe-row > span {
  color: var(--text-muted);
  font-size: 0.82rem;
  font-weight: 800;
}

@media (max-width: 430px) {
  .journal-muscu-sets-head,
  .journal-muscu-sets-row {
    grid-template-columns: 1.7rem minmax(3.6rem, 1fr) minmax(3.6rem, 1fr) minmax(4.8rem, 0.9fr) 2.2rem;
    gap: 0.25rem;
  }

  .journal-muscu-sets-row input,
  .journal-muscu-rpe-select {
    padding-inline: 0.35rem;
    font-size: 0.86rem;
  }
}

.journal-muscu-add-set {
  margin-top: 0.45rem;
  width: 100%;
}

.journal-muscu-rpe {
  display: grid;
  grid-template-columns: minmax(5rem, 0.35fr) minmax(9rem, 0.65fr);
  gap: 0.3rem 0.5rem;
  align-items: center;
  margin-top: 0.65rem;
  padding-top: 0.55rem;
  border-top: 1px dashed rgba(148, 163, 184, 0.35);
}

.journal-muscu-rpe select {
  width: 100%;
  min-width: 0;
  padding: 0.45rem 0.5rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: var(--radius-sm);
  background: #fff;
  font: inherit;
  font-size: 0.92rem;
}

.journal-muscu-rpe-hint {
  grid-column: 1 / -1;
  margin: 0;
}

@media (max-width: 400px) {
  .journal-muscu-rpe {
    grid-template-columns: 1fr;
  }
}

.journal-muscu-delete {
  width: 100%;
  margin-top: 0.5rem;
}

.journal-muscu-preview-table-wrap {
  overflow-x: auto;
  margin-top: 0.15rem;
  border-radius: var(--radius-sm);
  border: 2px solid rgba(15, 23, 42, 0.14);
}

.journal-muscu-preview-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: #fff;
}

.journal-muscu-preview-table__caption {
  padding: 0.55rem 0.65rem;
  text-align: left;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  background: rgba(15, 23, 42, 0.06);
  border-bottom: 2px solid rgba(15, 23, 42, 0.12);
}

.journal-muscu-preview-table tbody th,
.journal-muscu-preview-table tbody td {
  padding: 0.55rem 0.65rem;
  vertical-align: top;
  border-bottom: 1px solid rgba(15, 23, 42, 0.1);
  text-align: left;
}

.journal-muscu-preview-table tbody tr:last-child th,
.journal-muscu-preview-table tbody tr:last-child td {
  border-bottom: none;
}

.journal-muscu-preview-table tbody tr:nth-child(even) th,
.journal-muscu-preview-table tbody tr:nth-child(even) td {
  background: rgba(15, 23, 42, 0.03);
}

.journal-muscu-preview-table__section td {
  padding: 0.5rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent-deep);
  background: rgba(13, 148, 136, 0.1);
  border-bottom: 2px solid rgba(15, 23, 42, 0.12);
}

.journal-muscu-preview-table__label {
  width: 38%;
  max-width: 11rem;
  font-weight: 700;
  color: var(--text-muted);
  white-space: nowrap;
}

.journal-muscu-preview-table__value {
  font-weight: 600;
  color: var(--text);
}

.journal-muscu-preview-table__notes {
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: pre-wrap;
  line-height: 1.45;
  font-weight: 500;
}

.journal-muscu-preview-table__sets {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--accent-deep);
}

/* --- Tableau de suivi --- */
.page-outil--tableau-suivi {
  --tab-head-main-h: 3.25rem;
  --tab-head-stats-h: 1.65rem;
  --tab-col-nom-max: min(12rem, 50vw);
  max-width: min(56rem, 100%);
}

@media (max-width: 640px) {
  .page-outil--tableau-suivi {
    padding-left: max(0.65rem, env(safe-area-inset-left));
    padding-right: max(0.65rem, env(safe-area-inset-right));
  }

  .page-outil--tableau-suivi .tab-suivi-grid-card {
    padding: 1rem 0.75rem 0.85rem;
  }

  .page-outil--tableau-suivi .tab-suivi-scroll {
    margin-top: 0.45rem;
  }
}

.page-outil--tableau-suivi .tab-suivi-acc {
  margin-bottom: 0.75rem;
}

.page-outil--tableau-suivi .tab-suivi-msg {
  margin: 0 0 0.75rem;
}

.page-outil--tableau-suivi .tab-suivi-tableaux-row {
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.page-outil--tableau-suivi .tab-suivi-tableaux-select {
  flex: 1 1 12rem;
  min-width: 0;
}

.page-outil--tableau-suivi .tab-suivi-panel-eleves {
  padding-top: 0.15rem;
}

.page-outil--tableau-suivi .tab-suivi-panel-eleves .tab-suivi-btn-import {
  margin-top: 0.85rem;
}

.page-outil--tableau-suivi .tab-suivi-eleves-actions {
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.page-outil--tableau-suivi .tab-suivi-nb {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin-left: auto;
}

.page-outil--tableau-suivi .tab-suivi-grid-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.page-outil--tableau-suivi .tab-suivi-grid-head__title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.75rem;
}

.page-outil--tableau-suivi .tab-suivi-col-filtre .tools-view-toggle__btn {
  width: auto;
  min-width: 2.35rem;
  height: 1.85rem;
  padding: 0 0.5rem;
  font-size: 0.74rem;
  font-weight: 700;
}

@media (max-width: 420px) {
  .page-outil--tableau-suivi .tab-suivi-col-filtre .tools-view-toggle__btn {
    min-width: 2.1rem;
    padding: 0 0.4rem;
    font-size: 0.7rem;
  }
}

.page-outil--tableau-suivi .tab-suivi-grid-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
}

.page-outil--tableau-suivi .tab-suivi-grid-actions-export {
  display: inline-flex;
  flex-wrap: nowrap;
  gap: 0.35rem;
  align-items: center;
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .page-outil--tableau-suivi .tab-suivi-grid-head {
    align-items: flex-start;
  }

  .page-outil--tableau-suivi .tab-suivi-grid-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .page-outil--tableau-suivi .tab-suivi-grid-actions-export {
    width: 100%;
    justify-content: flex-start;
    margin-left: 0;
  }
}

/* Modales tableau de suivi — sélecteurs directs sur <dialog> (comme .info-dialog) */
dialog.tab-suivi-dialog {
  --tab-dlg-ease: cubic-bezier(0.22, 1, 0.36, 1);
  box-sizing: border-box;
  width: min(22.5rem, calc(100vw - 1.5rem));
  max-width: calc(100vw - 1.5rem);
  max-height: min(88dvh, 680px);
  margin: auto;
  padding: 0;
  border: none;
  border-radius: 1.25rem;
  overflow: hidden;
  background: #f1f5f9;
  color: var(--text);
  font-family: inherit;
  font-size: 1rem;
  line-height: 1.45;
  box-shadow:
    0 25px 50px -12px rgba(15, 23, 42, 0.35),
    0 0 0 1px rgba(255, 255, 255, 0.08) inset;
}

dialog.tab-suivi-dialog[open] {
  display: flex;
  flex-direction: column;
}

dialog.tab-suivi-dialog::backdrop {
  background: rgba(15, 23, 42, 0.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__form {
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: min(88dvh, 680px);
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__header {
  position: relative;
  flex-shrink: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1.15rem 3.25rem 1.1rem 1.2rem;
  background: linear-gradient(135deg, #0f766e 0%, #14b8a6 48%, #2dd4bf 100%);
  color: #fff;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__header--compact {
  padding-top: 1rem;
  padding-bottom: 0.95rem;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__header-text {
  min-width: 0;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: #fff;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__intro {
  margin: 0.35rem 0 0;
  font-size: 0.84rem;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.88);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__close {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  width: 2.35rem;
  height: 2.35rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
  color: #fff;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.2s var(--tab-dlg-ease),
    transform 0.2s var(--tab-dlg-ease);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__close:hover {
  background: rgba(255, 255, 255, 0.35);
  transform: scale(1.06);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding: 1rem 1.1rem 1.15rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__body--remplir {
  gap: 0.55rem;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__block {
  margin: 0;
  padding: 1rem 1.05rem;
  border-radius: 1rem;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__block-title {
  margin: 0 0 0.75rem;
  padding-left: 0.55rem;
  border-left: 3px solid var(--accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent-deep);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__block-step {
  display: none;
}

dialog.tab-suivi-dialog .tab-suivi-dialog-type-grid {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

dialog.tab-suivi-dialog .tab-suivi-type-card {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 0.65rem;
  row-gap: 0.1rem;
  align-items: center;
  width: 100%;
  padding: 0.75rem 0.85rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.85rem;
  background: #f8fafc;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
  transition:
    border-color 0.2s var(--tab-dlg-ease),
    background 0.2s var(--tab-dlg-ease),
    box-shadow 0.2s var(--tab-dlg-ease);
}

dialog.tab-suivi-dialog .tab-suivi-type-card:hover {
  border-color: #99f6e4;
  background: #fff;
  box-shadow: 0 6px 16px rgba(13, 148, 136, 0.14);
}

dialog.tab-suivi-dialog .tab-suivi-type-card__icon {
  grid-row: 1 / span 2;
  width: 2.5rem;
  height: 2.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.7rem;
  font-size: 1.1rem;
  font-weight: 800;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__icon--check {
  background: #d1fae5;
  color: #047857;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__icon--number {
  background: #e0f2fe;
  color: #0369a1;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__icon--calc {
  background: #ede9fe;
  color: #6d28d9;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__icon--rubric {
  background: #fff7ed;
  color: #c2410c;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__icon--info {
  background: #e0f2fe;
  color: #0369a1;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__icon--resultat {
  background: #fef3c7;
  color: #b45309;
}

.tab-suivi-col-resultat-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.35rem;
}

.page-outil--tableau-suivi .tab-suivi-col-bareme--linked {
  color: #b45309;
  font-weight: 600;
}

.page-outil--tableau-suivi .tab-suivi-cell-resultat {
  display: block;
  width: 100%;
  padding: 0.28rem 0.2rem;
  font-size: 0.82rem;
  text-align: center;
  line-height: 1.25;
  color: var(--text, #1e293b);
}

.page-outil--tableau-suivi .tab-suivi-cell-resultat--linked {
  color: #92400e;
  font-weight: 600;
}

.page-outil--tableau-suivi .tab-suivi-cell-resultat--empty {
  color: #94a3b8;
  font-weight: 400;
}

dialog.tab-suivi-dialog--rubric-catalog,
dialog.tab-suivi-dialog--rubric-cell {
  width: min(64rem, calc(100vw - 1.5rem));
  max-height: min(92dvh, 820px);
}

dialog.tab-suivi-dialog--rubric-catalog .tab-suivi-dialog__form,
dialog.tab-suivi-dialog--rubric-cell .tab-suivi-dialog__form {
  max-height: min(92dvh, 820px);
}

dialog.tab-suivi-dialog .tab-suivi-rubric-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
  gap: 0.7rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-online {
  padding: 0.72rem 0.85rem;
  border: 1px solid #fed7aa;
  border-radius: 0.75rem;
  background: #fff7ed;
  color: #9a3412;
  font-size: 0.84rem;
  font-weight: 750;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-online.is-ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #166534;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-online.is-error {
  border-color: #fecdd3;
  background: #fff1f2;
  color: #be123c;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-online.is-warn {
  border-color: #fde68a;
  background: #fffbeb;
  color: #92400e;
}

dialog.tab-suivi-dialog #dlg-rubric-search {
  width: 100%;
  border-radius: 0.65rem;
  border: 1px solid #cbd5e1;
  background: #fff;
  font: inherit;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-page-link {
  justify-content: center;
  max-width: 100%;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-card {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: 0.85rem;
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 0.85rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.96)),
    radial-gradient(circle at top right, rgba(251, 146, 60, 0.2), transparent 42%);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

dialog.tab-suivi-dialog .tab-suivi-rubric-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.6rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-card__title {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.2;
  color: #0f172a;
  overflow-wrap: anywhere;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-card__badge {
  flex-shrink: 0;
  padding: 0.18rem 0.45rem;
  border-radius: 999px;
  background: #ffedd5;
  color: #9a3412;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-card__meta,
dialog.tab-suivi-dialog .tab-suivi-rubric-card__desc {
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.35;
  color: #64748b;
  overflow-wrap: anywhere;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-card__rating {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 850;
  color: #b45309;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-card__actions,
dialog.tab-suivi-dialog .tab-suivi-rubric-import-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: auto;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-import-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.65rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-import-meta input,
dialog.tab-suivi-dialog .tab-suivi-rubric-import-meta select {
  box-sizing: border-box;
  width: 100%;
  border-radius: 0.65rem;
  border: 1px solid #cbd5e1;
  background: #fff;
  font: inherit;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-editor-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
  margin-top: 0.2rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-editor-title {
  margin: 0 0 0.25rem;
  color: #0f172a;
  font-size: 0.95rem;
  font-weight: 900;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-editor-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-file-btn {
  cursor: pointer;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-editor {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid #e2e8f0;
  border-radius: 0.85rem;
  background: #fff;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table {
  width: 100%;
  min-width: 46rem;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table th,
dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table td {
  padding: 0.55rem;
  border-right: 1px solid #e2e8f0;
  border-bottom: 1px solid #e2e8f0;
  vertical-align: top;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table thead th {
  background: #fff7ed;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table tbody th {
  background: #f8fafc;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table input,
dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table textarea {
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  border: 1px solid #cbd5e1;
  border-radius: 0.55rem;
  background: #fff;
  font: inherit;
  font-size: 0.82rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table textarea {
  min-height: 4.8rem;
  padding: 0.5rem;
  resize: vertical;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table input {
  min-height: 2.25rem;
  padding: 0.35rem 0.45rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table [data-rubric-cell-points] {
  width: 4.5rem;
  min-width: 4.5rem;
  margin-top: 0.4rem;
  font-weight: 800;
  color: #9a3412;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-edit-del {
  width: 1.7rem;
  height: 1.7rem;
  margin-top: 0.35rem;
  border: none;
  border-radius: 999px;
  background: #fee2e2;
  color: #b91c1c;
  font-weight: 900;
  cursor: pointer;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-share {
  align-items: flex-start;
  padding: 0.7rem 0.8rem;
  border: 1px dashed #fdba74;
  border-radius: 0.75rem;
  background: #fff7ed;
  color: #7c2d12;
  overflow-wrap: anywhere;
}

.page-outil--tableau-suivi .tab-suivi-rubric-cell-btn {
  width: auto;
  min-width: 2rem;
  min-height: 2rem;
  padding: 0 0.38rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.5rem;
  background: #f8fafc;
  color: #475569;
  font-size: 0.78rem;
  font-weight: 800;
  cursor: pointer;
  transition:
    transform 0.15s ease,
    border-color 0.15s ease,
    background 0.15s ease;
}

.page-outil--tableau-suivi .tab-suivi-rubric-cell-btn:hover {
  transform: translateY(-1px);
  border-color: #fb923c;
}

.page-outil--tableau-suivi .tab-suivi-rubric-cell-btn--low {
  background: #ffe4e6;
  color: #be123c;
  border-color: rgba(244, 63, 94, 0.38);
}

.page-outil--tableau-suivi .tab-suivi-rubric-cell-btn--mid {
  background: #fef3c7;
  color: #92400e;
  border-color: rgba(245, 158, 11, 0.38);
}

.page-outil--tableau-suivi .tab-suivi-rubric-cell-btn--high {
  background: #dcfce7;
  color: #166534;
  border-color: rgba(34, 197, 94, 0.38);
}

.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--rubric .tab-suivi-col-title::after {
  content: " ▦";
  font-size: 0.78em;
  opacity: 0.7;
}

.page-outil--tableau-suivi .tab-suivi-col-rubric-opt {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.page-outil--tableau-suivi .tab-suivi-col-rubric-opt .btn {
  justify-content: center;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-score {
  position: sticky;
  top: -1rem;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(251, 146, 60, 0.25);
  border-radius: 0.9rem;
  background: rgba(255, 247, 237, 0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #7c2d12;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-score__note {
  font-size: 1.6rem;
  font-weight: 900;
  line-height: 1;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-score__detail {
  font-size: 0.82rem;
  font-weight: 700;
  text-align: right;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-grid-wrap {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid #e2e8f0;
  border-radius: 0.9rem;
  background: #fff;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-grid {
  width: 100%;
  min-width: 46rem;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-grid th,
dialog.tab-suivi-dialog .tab-suivi-rubric-grid td {
  border-right: 1px solid #e2e8f0;
  border-bottom: 1px solid #e2e8f0;
  vertical-align: stretch;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-grid thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 0.65rem;
  background: color-mix(in srgb, var(--rubric-level, #f8fafc) 42%, #ffffff);
  color: #1e293b;
  font-size: 0.82rem;
  font-weight: 900;
  text-align: left;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-grid tbody th {
  position: sticky;
  left: 0;
  z-index: 1;
  width: 12rem;
  padding: 0.7rem;
  background: #f8fafc;
  color: #0f172a;
  font-size: 0.86rem;
  font-weight: 900;
  text-align: left;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-option {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0.6rem;
  width: 100%;
  min-height: 7.2rem;
  padding: 0.7rem;
  border: 2px solid transparent;
  background: #fff;
  color: #0f172a;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.15s ease;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-option:hover {
  background: color-mix(in srgb, var(--rubric-level, #f8fafc) 18%, #ffffff);
}

dialog.tab-suivi-dialog .tab-suivi-rubric-option.is-selected {
  background: color-mix(in srgb, var(--rubric-level, #f8fafc) 46%, #ffffff);
  border-color: color-mix(in srgb, var(--rubric-level, #f8fafc) 72%, #334155);
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.08), 0 10px 22px rgba(15, 23, 42, 0.12);
  transform: translateY(-1px);
}

dialog.tab-suivi-dialog .tab-suivi-rubric-option__text {
  font-size: 0.84rem;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-option__points {
  align-self: flex-start;
  padding: 0.18rem 0.42rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  color: #334155;
  font-size: 0.7rem;
  font-weight: 900;
}

@media (max-width: 760px) {
  dialog.tab-suivi-dialog .tab-suivi-rubric-import-meta {
    grid-template-columns: 1fr 1fr;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-editor-head {
    flex-direction: column;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-editor-actions {
    justify-content: flex-start;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table {
    min-width: 36rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-score {
    align-items: flex-start;
    flex-direction: column;
    gap: 0.35rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-score__detail {
    text-align: left;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-grid {
    min-width: 37rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-grid tbody th {
    width: 9rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-option {
    min-height: 6.6rem;
    padding: 0.6rem;
  }
}

.page-outil--eval-catalog .tool-back--return {
  width: auto;
  min-width: 2.65rem;
  padding: 0.35rem 0.9rem 0.35rem 0.55rem;
  font-size: 0.88rem;
  font-weight: 700;
  gap: 0.15rem;
}

.page-outil--eval-catalog .tool-back--return::before {
  content: none;
}

.page-outil--eval-catalog .tool-back--return .tool-back__chev {
  display: inline;
  font-size: 1.15rem;
  line-height: 1;
  font-weight: 850;
}

.page-outil--eval-catalog .tool-back--return .tool-back__label {
  display: inline;
}

.page-outil--eval-catalog {
  max-width: min(56rem, 100%);
  padding-bottom: 2rem;
}

.eval-catalog-intro {
  margin-bottom: 0.85rem;
}

.page-outil--eval-catalog .eval-catalog-status {
  margin: 0 0 1rem;
  padding: 0.85rem 1rem;
  border: 1px solid #fde68a;
  border-radius: 0.85rem;
  background: #fffbeb;
  color: #92400e;
  font-weight: 750;
}

.page-outil--eval-catalog .eval-catalog-status--ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #166534;
}

.page-outil--eval-catalog .eval-catalog-status--error {
  border-color: #fecdd3;
  background: #fff1f2;
  color: #be123c;
}

.page-outil--eval-catalog .eval-catalog-toolbar {
  display: grid;
  grid-template-columns: minmax(16rem, 1fr) minmax(8rem, 12rem) minmax(8rem, 12rem) auto;
  gap: 0.75rem;
  align-items: end;
  margin-bottom: 0.85rem;
}

.page-outil--eval-catalog .eval-catalog-toolbar input,
.page-outil--eval-catalog .eval-catalog-toolbar select {
  width: 100%;
  min-height: 2.75rem;
  border-radius: 0.7rem;
  border: 1px solid #cbd5e1;
  background: #fff;
  font: inherit;
}

.page-outil--eval-catalog .eval-catalog-propose {
  min-height: 2.75rem;
  align-self: end;
}

.page-outil--eval-catalog .eval-catalog-count {
  margin: 0 0 0.75rem;
  color: var(--text-muted);
  font-weight: 700;
}

.page-outil--eval-catalog .eval-catalog-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr));
  gap: 0.9rem;
}

.page-outil--eval-catalog .eval-catalog-card {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  min-height: 16rem;
  padding: 1rem;
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: var(--radius);
  background: linear-gradient(165deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: var(--shadow);
}

.page-outil--eval-catalog .eval-catalog-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.65rem;
}

.page-outil--eval-catalog .eval-catalog-card h2 {
  margin: 0;
  color: #0f172a;
  font-size: 1.05rem;
  line-height: 1.2;
}

.page-outil--eval-catalog .eval-catalog-card__badge {
  flex-shrink: 0;
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  background: #ccfbf1;
  color: #0f766e;
  font-size: 0.72rem;
  font-weight: 900;
}

.page-outil--eval-catalog .eval-catalog-card__meta,
.page-outil--eval-catalog .eval-catalog-card__detail {
  margin: 0;
  color: #64748b;
  font-size: 0.84rem;
  line-height: 1.35;
}

.page-outil--eval-catalog .eval-catalog-card__stars {
  margin: 0;
  color: #b45309;
  font-size: 0.9rem;
  font-weight: 900;
}

.page-outil--eval-catalog .eval-catalog-card__items {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin: 0;
  padding-left: 1rem;
  color: #334155;
  font-size: 0.84rem;
}

.page-outil--eval-catalog .eval-catalog-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: auto;
}

.page-outil--eval-catalog .eval-catalog-card__actions--primary {
  margin-top: 0.35rem;
}

.page-outil--eval-catalog .eval-catalog-card__actions--votes {
  padding-top: 0.35rem;
  border-top: 1px solid rgba(226, 232, 240, 0.9);
}

.page-outil--eval-catalog .eval-catalog-view-grid {
  max-height: min(72vh, 36rem);
  margin: 0;
  padding: 0;
  overflow: visible;
}

.page-outil--eval-catalog .eval-catalog-view-dialog .tab-suivi-dialog__body {
  padding-top: 0.5rem;
  padding-bottom: 1rem;
}

.page-outil--eval-catalog .eval-rubric-preview-wrap {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid #e2e8f0;
  border-radius: 0.9rem;
  background: #fff;
  padding: 0.35rem;
}

.page-outil--eval-catalog .eval-rubric-preview-grid {
  width: 100%;
  min-width: 42rem;
  border-collapse: separate;
  border-spacing: 0.35rem;
  table-layout: fixed;
}

.page-outil--eval-catalog .eval-rubric-preview-grid th,
.page-outil--eval-catalog .eval-rubric-preview-grid td {
  border: none;
  vertical-align: top;
  padding: 0;
}

.page-outil--eval-catalog .eval-rubric-preview-grid thead th {
  padding: 0.75rem 0.85rem;
  border-radius: 0.65rem;
  background: color-mix(in srgb, var(--rubric-level, #f8fafc) 42%, #ffffff);
  color: #1e293b;
  font-size: 0.84rem;
  font-weight: 900;
  text-align: left;
}

.page-outil--eval-catalog .eval-rubric-preview-grid tbody th {
  padding: 0.8rem 0.85rem;
  border-radius: 0.65rem;
  background: #f8fafc;
  color: #0f172a;
  font-size: 0.88rem;
  font-weight: 900;
  text-align: left;
  width: 11rem;
}

.page-outil--eval-catalog .tab-suivi-rubric-option--readonly {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0.65rem;
  min-height: 7.5rem;
  padding: 0.85rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  background: #fff;
  color: #0f172a;
  pointer-events: none;
}

.page-outil--eval-catalog .tab-suivi-rubric-option--readonly .tab-suivi-rubric-option__text {
  font-size: 0.86rem;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.page-outil--eval-catalog .tab-suivi-rubric-option--readonly .tab-suivi-rubric-option__points {
  align-self: flex-start;
  padding: 0.22rem 0.5rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  color: #334155;
  font-size: 0.72rem;
  font-weight: 900;
}

.page-outil--eval-catalog .eval-catalog-card__votes--info {
  color: #64748b;
  font-weight: 600;
  font-size: 0.82rem;
}

.page-outil--eval-catalog .eval-catalog-card__votes {
  margin: 0;
  font-size: 0.88rem;
  font-weight: 700;
  color: #475569;
}

.page-outil--eval-catalog .eval-catalog-vote-btn.is-active {
  border-color: #1a2744;
  background: #e8eef8;
  color: #1a2744;
}

.page-outil--grilles-evaluation .ge-share-hint {
  margin: 0.35rem 0 0.75rem;
}

.ge-share-wrap {
  margin-top: 1rem;
}

.ge-share-wrap .ge-share,
label.ge-share {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  margin: 0;
  padding: 0.85rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: #f8fafc;
  font-weight: 600;
  cursor: pointer;
}

.ge-share-wrap--disabled .ge-share,
.ge-share-wrap--disabled label.ge-share {
  border-color: #e2e8f0;
  background: #f1f5f9;
  color: #94a3b8;
  cursor: not-allowed;
  opacity: 0.92;
}

.ge-share-wrap--disabled .ge-share input {
  cursor: not-allowed;
}

.ge-share-wrap .ge-share input {
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.2rem;
  accent-color: var(--accent);
  flex-shrink: 0;
}

.ge-share-reason {
  margin: 0.45rem 0 0;
  padding: 0.6rem 0.85rem;
  border-radius: var(--radius-sm);
  background: #f1f5f9;
  color: var(--text-muted);
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.45;
}

.ge-share-wrap:not(.ge-share-wrap--disabled) .ge-share-reason:empty {
  display: none;
}

.page-outil--grilles-evaluation .ge-section-head--library .ge-catalog-link {
  flex-shrink: 0;
}

@media (max-width: 760px) {
  .page-outil--eval-catalog .eval-catalog-toolbar {
    grid-template-columns: 1fr;
  }

  .page-outil--eval-catalog .eval-catalog-list {
    grid-template-columns: 1fr;
  }
}

.page-outil--grilles-evaluation {
  max-width: min(72rem, 100%);
  padding-bottom: 2rem;
}

.page-outil--grilles-evaluation .ge-status {
  margin: 0 0 0.9rem;
  padding: 0.75rem 0.9rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.32);
  background: #f8fafc;
  color: #475569;
  font-size: 0.88rem;
  font-weight: 700;
}

.page-outil--grilles-evaluation .ge-status--ok {
  border-color: rgba(34, 197, 94, 0.28);
  background: #f0fdf4;
  color: #166534;
}

.page-outil--grilles-evaluation .ge-status--warn {
  border-color: rgba(245, 158, 11, 0.32);
  background: #fffbeb;
  color: #92400e;
}

.page-outil--grilles-evaluation .ge-status--error {
  border-color: rgba(244, 63, 94, 0.28);
  background: #fff1f2;
  color: #be123c;
}

.page-outil--grilles-evaluation .ge-use-note {
  margin-bottom: 0.85rem;
}

.page-outil--grilles-evaluation .ge-toolbar {
  display: grid;
  grid-template-columns: minmax(14rem, 1fr) minmax(8rem, 0.35fr) minmax(8rem, 0.35fr) auto;
  gap: 0.75rem;
  align-items: end;
  margin-bottom: 0.9rem;
}

.page-outil--grilles-evaluation .ge-toolbar input,
.page-outil--grilles-evaluation .ge-toolbar select,
.page-outil--grilles-evaluation .ge-meta input,
.page-outil--grilles-evaluation .ge-meta select {
  width: 100%;
  box-sizing: border-box;
  border-radius: 0.65rem;
  border: 1px solid #cbd5e1;
  background: #fff;
  font: inherit;
}

.page-outil--grilles-evaluation .ge-toolbar__actions,
.page-outil--grilles-evaluation .ge-editor-actions,
.page-outil--grilles-evaluation .ge-savebar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.page-outil--grilles-evaluation .ge-toolbar__actions {
  justify-content: flex-end;
}

.page-outil--grilles-evaluation .ge-import-btn {
  cursor: pointer;
}

.page-outil--grilles-evaluation .ge-layout {
  display: grid;
  grid-template-columns: minmax(18rem, 0.9fr) minmax(24rem, 1.35fr);
  gap: 0.9rem;
  align-items: start;
}

.page-outil--grilles-evaluation .ge-library,
.page-outil--grilles-evaluation .ge-editor-card {
  min-width: 0;
  margin-bottom: 0;
}

.page-outil--grilles-evaluation #ge-apsa,
.page-outil--tableau-suivi #dlg-rubric-apsa {
  width: 100%;
  min-height: 2.75rem;
  padding: 0.45rem 0.65rem;
  font: inherit;
}

.page-outil--grilles-evaluation .ge-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.page-outil--grilles-evaluation .ge-section-head h2 {
  margin: 0;
  color: #0f172a;
  font-size: 1.05rem;
}

.page-outil--grilles-evaluation .ge-section-head p {
  margin: 0;
  color: #64748b;
  font-size: 0.82rem;
  font-weight: 700;
}

.page-outil--grilles-evaluation .ge-section-head--library {
  flex-wrap: wrap;
  align-items: flex-start;
}

.page-outil--grilles-evaluation .ge-section-head--library .btn {
  flex-shrink: 0;
}

.page-outil--grilles-evaluation .ge-list {
  display: grid;
  gap: 0.65rem;
  max-height: min(68vh, 44rem);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding-right: 0.15rem;
}

.page-outil--grilles-evaluation .ge-card {
  display: grid;
  gap: 0.45rem;
  padding: 0.78rem;
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 0.78rem;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.page-outil--grilles-evaluation .ge-card--catalog {
  border-color: rgba(251, 146, 60, 0.3);
  background: linear-gradient(180deg, #ffffff, #fff7ed);
}

.page-outil--grilles-evaluation .ge-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.6rem;
}

.page-outil--grilles-evaluation .ge-card h3 {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.22;
  color: #0f172a;
  overflow-wrap: anywhere;
}

.page-outil--grilles-evaluation .ge-card__badge {
  flex-shrink: 0;
  padding: 0.18rem 0.45rem;
  border-radius: 999px;
  background: #ecfdf5;
  color: #047857;
  font-size: 0.66rem;
  font-weight: 900;
  text-transform: uppercase;
}

.page-outil--grilles-evaluation .ge-card--catalog .ge-card__badge {
  background: #ffedd5;
  color: #9a3412;
}

.page-outil--grilles-evaluation .ge-card__badge--example {
  background: #e0e7ff;
  color: #4338ca;
}

.page-outil--grilles-evaluation .ge-card__meta,
.page-outil--grilles-evaluation .ge-card__detail {
  margin: 0;
  color: #64748b;
  font-size: 0.78rem;
  line-height: 1.35;
}

.page-outil--grilles-evaluation .ge-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
  margin-top: 0.1rem;
}

.page-outil--grilles-evaluation .ge-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.65rem;
}

.page-outil--grilles-evaluation .ge-editor-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
  margin: 0.85rem 0 0.55rem;
}

.page-outil--grilles-evaluation .ge-editor-top .hint {
  margin: 0;
}

.page-outil--grilles-evaluation .ge-editor {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid #e2e8f0;
  border-radius: 0.85rem;
  background: #fff;
}

.page-outil--grilles-evaluation .ge-edit-table {
  width: 100%;
  min-width: 46rem;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

.page-outil--grilles-evaluation .ge-edit-table th,
.page-outil--grilles-evaluation .ge-edit-table td {
  padding: 0.52rem;
  border-right: 1px solid #e2e8f0;
  border-bottom: 1px solid #e2e8f0;
  vertical-align: top;
}

.page-outil--grilles-evaluation .ge-edit-table thead th {
  background: #fff7ed;
}

.page-outil--grilles-evaluation .ge-edit-table tbody th {
  background: #f8fafc;
}

.page-outil--grilles-evaluation .ge-edit-table input,
.page-outil--grilles-evaluation .ge-edit-table textarea {
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  border: 1px solid #cbd5e1;
  border-radius: 0.55rem;
  background: #fff;
  font: inherit;
  font-size: 0.82rem;
}

.page-outil--grilles-evaluation .ge-edit-table textarea {
  min-height: 4.65rem;
  padding: 0.48rem;
  resize: vertical;
}

.page-outil--grilles-evaluation .ge-edit-table input {
  min-height: 2.15rem;
  padding: 0.34rem 0.45rem;
}

.page-outil--grilles-evaluation .ge-edit-table [data-cell-points] {
  width: 4.25rem;
  min-width: 4.25rem;
  margin-top: 0.38rem;
  font-weight: 800;
  color: #9a3412;
}

.page-outil--grilles-evaluation .ge-edit-del {
  width: 1.7rem;
  height: 1.7rem;
  margin-top: 0.34rem;
  border: none;
  border-radius: 999px;
  background: #fee2e2;
  color: #b91c1c;
  font-weight: 900;
  cursor: pointer;
}

.page-outil--grilles-evaluation .ge-share {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  margin-top: 0.75rem;
  padding: 0.7rem 0.8rem;
  border: 1px dashed #fdba74;
  border-radius: 0.75rem;
  background: #fff7ed;
  color: #7c2d12;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.page-outil--grilles-evaluation .ge-savebar {
  justify-content: flex-end;
  margin-top: 0.85rem;
}

@media (max-width: 920px) {
  .page-outil--grilles-evaluation .ge-toolbar,
  .page-outil--grilles-evaluation .ge-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .page-outil--grilles-evaluation .ge-toolbar__actions,
  .page-outil--grilles-evaluation .ge-savebar {
    justify-content: flex-start;
  }

  .page-outil--grilles-evaluation .ge-list {
    max-height: none;
  }
}

@media (max-width: 640px) {
  .page-outil--grilles-evaluation {
    max-width: min(100% - 0.8rem, 88rem);
  }

  .page-outil--grilles-evaluation .ge-library,
  .page-outil--grilles-evaluation .ge-editor-card {
    padding: 0.75rem;
    border-radius: 0.75rem;
  }

  .page-outil--grilles-evaluation .ge-meta {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.55rem;
  }

  .page-outil--grilles-evaluation .ge-editor-top {
    flex-direction: column;
  }

  .page-outil--grilles-evaluation .ge-editor-actions > *,
  .page-outil--grilles-evaluation .ge-savebar > *,
  .page-outil--grilles-evaluation .ge-toolbar__actions > * {
    flex: 1 1 auto;
    justify-content: center;
  }

  .page-outil--grilles-evaluation .ge-edit-table {
    min-width: 34rem;
  }

  .page-outil--grilles-evaluation .ge-edit-table th,
  .page-outil--grilles-evaluation .ge-edit-table td {
    padding: 0.42rem;
  }

  .page-outil--grilles-evaluation .ge-edit-table textarea {
    min-height: 4.1rem;
  }
}

dialog.tab-suivi-dialog .tab-suivi-calc-op-row {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

dialog.tab-suivi-dialog .tab-suivi-calc-op {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 0.85rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  background: #f8fafc;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
}

dialog.tab-suivi-dialog .tab-suivi-calc-op:has(input:checked) {
  border-color: #99f6e4;
  background: #ecfdf5;
  color: #0f766e;
}

dialog.tab-suivi-dialog .tab-suivi-calc-sources {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  max-height: 12rem;
  overflow-y: auto;
  padding: 0.25rem 0;
}

dialog.tab-suivi-dialog .tab-suivi-calc-source {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.65rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.6rem;
  background: #fff;
  font-size: 0.88rem;
  cursor: pointer;
}

dialog.tab-suivi-dialog .tab-suivi-calc-source:has(input:checked) {
  border-color: #99f6e4;
  background: #f0fdfa;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__type--calc {
  background: #ede9fe;
  color: #6d28d9;
}

.page-outil--tableau-suivi .tab-suivi-cell-calc {
  display: block;
  width: 100%;
  min-height: 2.25rem;
  line-height: 2.25rem;
  text-align: center;
  font-size: 0.9rem;
  font-weight: 600;
  color: #5b21b6;
  background: #f5f3ff;
  border-radius: 0.4rem;
}

.page-outil--tableau-suivi .tab-suivi-cell-info {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 2.25rem;
  padding: 0.2rem 0.35rem;
  font-size: 0.82rem;
  font-weight: 600;
  text-align: center;
  color: var(--text);
}

.page-outil--tableau-suivi .tab-suivi-cell-info--vide {
  color: var(--text-muted);
  font-weight: 500;
}

.page-outil--tableau-suivi .tab-suivi-cell-info--edit {
  padding: 0.15rem 0.2rem;
}

.page-outil--tableau-suivi .tab-suivi-cell-info-input {
  width: 100%;
  max-width: 6.5rem;
  min-height: 2rem;
  padding: 0.25rem 0.4rem;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  text-align: center;
  color: var(--text);
  caret-color: var(--accent);
  -webkit-text-fill-color: currentColor;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: #fff;
  -moz-appearance: textfield;
}

.page-outil--tableau-suivi .tab-suivi-cell-info-input:focus {
  outline: 2px solid var(--accent);
  border-color: var(--accent);
}

.page-outil--tableau-suivi .tab-suivi-cell-info-input::-webkit-outer-spin-button,
.page-outil--tableau-suivi .tab-suivi-cell-info-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.page-outil--tableau-suivi .tab-suivi-cell-info--edit-equipe {
  justify-content: stretch;
  min-width: 8rem;
}

.page-outil--tableau-suivi .tab-suivi-cell-info-input--equipe {
  max-width: min(14rem, 48vw);
  min-width: 7.5rem;
  text-align: left;
}

.page-outil--tableau-suivi .tab-suivi-td--cell:has(.tab-suivi-cell-info--edit-equipe) {
  min-width: 8.5rem;
}

.page-outil--tableau-suivi .tab-suivi-col-info-edit-check {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  margin-top: 0.65rem;
  font-size: 0.88rem;
  cursor: pointer;
}

.page-outil--tableau-suivi .tab-suivi-col-info-edit-check input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--info-eleve .tab-suivi-col-title::after {
  content: " ℹ";
  font-size: 0.7em;
  opacity: 0.65;
}

.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--calc .tab-suivi-col-title::after {
  content: " ƒ";
  font-size: 0.7em;
  opacity: 0.65;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__label {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}

dialog.tab-suivi-dialog .tab-suivi-type-card__hint {
  font-size: 0.75rem;
  color: var(--text-muted);
}

dialog.tab-suivi-dialog .tab-suivi-type-card__text {
  display: contents;
}

dialog.tab-suivi-dialog .tab-suivi-dialog-tri-row {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
}

dialog.tab-suivi-dialog .tab-suivi-dialog-tri-select {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
}

dialog.tab-suivi-dialog .tab-suivi-dialog-tri-select select,
dialog.tab-suivi-dialog #dlg-tri-select {
  width: 100%;
  min-height: 2.75rem;
  border-radius: 0.65rem;
  border: 1px solid #e2e8f0;
  font-size: 0.9rem;
}

dialog.tab-suivi-dialog #dlg-tri-par,
dialog.tab-suivi-dialog #dlg-tri-colonne {
  width: 100%;
  min-height: 2.75rem;
  border-radius: 0.65rem;
  border: 1px solid #e2e8f0;
  font-size: 0.9rem;
}

dialog.tab-suivi-dialog .tab-suivi-tri-sens-btn {
  width: 100%;
  min-height: 2.75rem;
  font-weight: 600;
  border-radius: 0.65rem;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
}

dialog.tab-suivi-dialog .tab-suivi-tri-sens-btn:hover {
  border-color: #99f6e4;
  background: #ecfdf5;
}

dialog.tab-suivi-dialog .tab-suivi-dialog-tri-row .btn--primary,
dialog.tab-suivi-dialog #btn-appliquer-tri {
  flex-shrink: 0;
  min-height: 2.75rem;
  padding: 0 1.15rem;
  border-radius: 0.65rem;
  font-weight: 700;
  box-shadow: 0 4px 12px rgba(13, 148, 136, 0.25);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__empty {
  margin: 0;
  padding: 0.85rem 1rem;
  font-size: 0.88rem;
  text-align: center;
  color: var(--text-muted);
  background: #f8fafc;
  border-radius: 0.75rem;
  border: 1px dashed #cbd5e1;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-cols {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-height: min(28dvh, 220px);
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 0.15rem;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.45rem;
  padding: 0.5rem 0.55rem;
  border-radius: 0.75rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col:focus-within {
  border-color: #5eead4;
  box-shadow: 0 0 0 3px rgba(45, 212, 191, 0.2);
  background: #fff;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__type {
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.55rem;
  font-size: 0.85rem;
  font-weight: 800;
  flex-shrink: 0;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__type--check {
  background: #d1fae5;
  color: #047857;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__type--num {
  background: #e0f2fe;
  color: #0369a1;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__name {
  width: 100%;
  min-width: 0;
  margin: 0;
  padding: 0.45rem 0.55rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  background: #fff;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 600;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__name:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(13, 148, 136, 0.2);
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__tools {
  display: flex;
  gap: 0.2rem;
  flex-shrink: 0;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__tool {
  width: 2.1rem;
  height: 2.1rem;
  margin: 0;
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  background: #fff;
  color: var(--text-muted);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__tool:hover:not(:disabled) {
  border-color: #99f6e4;
  color: var(--accent-deep);
  background: #ecfdf5;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__tool:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__tool--danger {
  color: #dc2626;
  border-color: #fecaca;
}

dialog.tab-suivi-dialog .tab-suivi-dlg-col__tool--danger:hover {
  background: #fef2f2;
  border-color: #fca5a5;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__footer {
  flex-shrink: 0;
  padding: 0.9rem 1.1rem max(0.9rem, env(safe-area-inset-bottom));
  background: #fff;
  border-top: 1px solid #e2e8f0;
}

dialog.tab-suivi-dialog .tab-suivi-dialog__submit {
  width: 100%;
  min-height: 2.85rem;
  margin: 0;
  border: none;
  border-radius: 0.85rem;
  font-size: 1rem;
  font-weight: 700;
  background: linear-gradient(135deg, #0d9488, #14b8a6);
  color: #fff;
  box-shadow: 0 6px 16px rgba(13, 148, 136, 0.3);
}

dialog.tab-suivi-dialog .tab-suivi-dialog__footer--split {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-nav {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-width: 0;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-nav[hidden] {
  display: none;
}

dialog.tab-suivi-dialog .tab-suivi-rubric-nav__count {
  flex-shrink: 0;
  min-width: 2.6rem;
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 800;
  text-align: center;
}

dialog.tab-suivi-dialog .tab-suivi-remplir-opt {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 2.85rem;
  margin: 0 0 0.45rem;
  padding: 0 1rem;
  border-radius: 0.85rem;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
}

dialog.tab-suivi-dialog .tab-suivi-remplir-opt.tab-suivi-remplir-ok {
  color: #047857;
  border: 1px solid #6ee7b7;
  background: #ecfdf5;
}

dialog.tab-suivi-dialog .tab-suivi-remplir-opt.tab-suivi-remplir-ko {
  color: #b91c1c;
  border: 1px solid #fca5a5;
  background: #fef2f2;
}

dialog.tab-suivi-dialog .tab-suivi-col-dlg-nom {
  width: 100%;
  min-height: 2.75rem;
  border-radius: 0.65rem;
  border: 1px solid #e2e8f0;
  font-size: 0.95rem;
  padding: 0.5rem 0.75rem;
}

dialog.tab-suivi-dialog .tab-suivi-col-dlg-block {
  margin-top: 0.15rem;
}

dialog.tab-suivi-dialog .tab-suivi-col-dlg-move {
  display: flex;
  gap: 0.5rem;
}

dialog.tab-suivi-dialog .tab-suivi-col-dlg-move-btn {
  flex: 1 1 0;
  min-height: 2.65rem;
  font-weight: 600;
}

dialog.tab-suivi-dialog .tab-suivi-col-dlg-remplir {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

dialog.tab-suivi-dialog .tab-suivi-col-dlg-remplir .field-group {
  margin: 0;
}

dialog.tab-suivi-dialog .tab-suivi-col-dlg-del {
  width: 100%;
  margin-top: 0.35rem;
}

dialog.tab-suivi-dialog .tab-suivi-remplir-input {
  width: 100%;
  box-sizing: border-box;
  min-height: 2.85rem;
  padding: 0 0.85rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.85rem;
  font: inherit;
  font-size: 1.05rem;
}

@media (max-width: 480px) {
  dialog.tab-suivi-dialog {
    width: calc(100vw - 1rem);
    max-width: calc(100vw - 1rem);
    max-height: 92dvh;
    margin: auto 0.5rem;
    border-radius: 1.1rem 1.1rem 0 0;
    align-self: flex-end;
  }

  dialog.tab-suivi-dialog[open] {
    margin-top: auto;
  }

  dialog.tab-suivi-dialog .tab-suivi-dialog-tri-row {
    flex-direction: column;
  }

  dialog.tab-suivi-dialog .tab-suivi-dialog-tri-row .btn--primary,
  dialog.tab-suivi-dialog #btn-appliquer-tri {
    width: 100%;
  }

  dialog.tab-suivi-dialog--rubric-catalog,
  dialog.tab-suivi-dialog--rubric-cell {
    max-height: 94dvh;
  }

  dialog.tab-suivi-dialog--rubric-catalog .tab-suivi-dialog__form,
  dialog.tab-suivi-dialog--rubric-cell .tab-suivi-dialog__form {
    max-height: 94dvh;
  }

  dialog.tab-suivi-dialog--rubric-catalog .tab-suivi-dialog__body,
  dialog.tab-suivi-dialog--rubric-cell .tab-suivi-dialog__body {
    padding: 0.75rem;
    gap: 0.7rem;
  }

  dialog.tab-suivi-dialog--rubric-catalog .tab-suivi-dialog__block,
  dialog.tab-suivi-dialog--rubric-cell .tab-suivi-dialog__block {
    padding: 0.75rem;
    border-radius: 0.85rem;
  }

  dialog.tab-suivi-dialog--rubric-cell .tab-suivi-dialog__footer--split {
    flex-wrap: wrap;
  }

  dialog.tab-suivi-dialog--rubric-cell .tab-suivi-rubric-nav {
    order: -1;
    flex-basis: 100%;
  }

  dialog.tab-suivi-dialog--rubric-cell .tab-suivi-rubric-nav .btn {
    flex: 1 1 0;
    justify-content: center;
    white-space: normal;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-cards {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.6rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-card {
    padding: 0.7rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-card__head {
    gap: 0.45rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-card__badge {
    padding-inline: 0.38rem;
    font-size: 0.62rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-import-meta {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.55rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-editor-actions > * {
    flex: 1 1 auto;
    justify-content: center;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table {
    min-width: 33.5rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table th,
  dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table td {
    padding: 0.42rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table textarea {
    min-height: 4.1rem;
    padding: 0.42rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table input {
    min-height: 2.05rem;
    padding: 0.32rem 0.4rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-edit-table [data-rubric-cell-points] {
    width: 3.9rem;
    min-width: 3.9rem;
  }

  .page-outil--tableau-suivi .tab-suivi-rubric-cell-btn {
    width: auto;
    min-width: 1.9rem;
    min-height: 1.9rem;
    padding-inline: 0.25rem;
    font-size: 0.72rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-score {
    top: -0.75rem;
    padding: 0.68rem 0.72rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-score__note {
    font-size: 1.35rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-grid {
    min-width: 34rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-grid thead th {
    padding: 0.5rem;
    font-size: 0.76rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-grid tbody th {
    width: 7.5rem;
    padding: 0.55rem;
    font-size: 0.78rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-option {
    min-height: 5.9rem;
    padding: 0.5rem;
    gap: 0.45rem;
  }

  dialog.tab-suivi-dialog .tab-suivi-rubric-option__text {
    font-size: 0.78rem;
  }
}

.page-outil--tableau-suivi .tab-suivi-scroll {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  margin-top: 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.4);
  background: #fff;
  isolation: isolate;
}

.page-outil--tableau-suivi #tab-suivi-thead {
  background: #ecfdf5;
}

.page-outil--tableau-suivi .tab-suivi-table {
  width: max-content;
  min-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.9rem;
}

.page-outil--tableau-suivi .tab-suivi-th,
.page-outil--tableau-suivi .tab-suivi-td {
  border-bottom: 1px solid rgba(148, 163, 184, 0.35);
  vertical-align: middle;
  padding: 0.2rem 0.12rem;
}

.page-outil--tableau-suivi #tab-suivi-thead .tab-suivi-th {
  font-weight: 700;
  text-align: center;
}

.page-outil--tableau-suivi #tab-suivi-thead .tab-suivi-th--col {
  position: sticky;
  z-index: 2;
  background: #ecfdf5;
}

.page-outil--tableau-suivi .tab-suivi-head-main .tab-suivi-th {
  border-bottom: none;
  height: var(--tab-head-main-h);
  box-sizing: border-box;
}

.page-outil--tableau-suivi .tab-suivi-head-main .tab-suivi-th--col {
  top: 0;
  background: #ecfdf5;
  padding: 0.15rem 0.1rem 0.1rem;
  vertical-align: bottom;
}

.page-outil--tableau-suivi .tab-suivi-head-main .tab-suivi-th--nom {
  top: 0;
  z-index: 12;
  background: #ecfdf5;
  padding: 0.35rem 0.5rem 0.2rem;
  vertical-align: bottom;
}

.page-outil--tableau-suivi .tab-suivi-col-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 0.12rem;
  min-height: 2.75rem;
}

.page-outil--tableau-suivi .tab-suivi-th--eleve-label {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--accent-deep);
  text-align: left;
  background: #ecfdf5;
}

.page-outil--tableau-suivi .tab-suivi-eleve-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem;
  min-width: 5.5rem;
}

.page-outil--tableau-suivi .tab-suivi-eleve-head__label {
  flex: 1 1 auto;
}

.page-outil--tableau-suivi .tab-suivi-eleve-params {
  flex-shrink: 0;
  width: 1.65rem;
  height: 1.65rem;
  padding: 0;
  border: 1px solid rgba(13, 148, 136, 0.35);
  border-radius: 0.35rem;
  background: #fff;
  color: var(--accent-deep);
  font-size: 0.95rem;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.page-outil--tableau-suivi .tab-suivi-eleve-params:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
}

/* Dialogues hors .page-outil — sélecteurs sur <dialog> */
dialog.tab-suivi-dialog--eleves .tab-suivi-eleves-dlg__select-wrap {
  margin-bottom: 0.85rem;
}

dialog.tab-suivi-dialog--eleves .tab-suivi-eleves-detail {
  margin-top: 0.15rem;
  padding: 0.85rem 0.95rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13, 148, 136, 0.22);
  background: linear-gradient(165deg, #ecfdf5 0%, #f8fafc 100%);
  transition: opacity 0.2s ease;
}

dialog.tab-suivi-dialog--eleves .tab-suivi-eleves-detail__title {
  margin: 0 0 0.65rem;
  font-size: 1rem;
  font-weight: 800;
  color: var(--accent-deep);
  line-height: 1.25;
}

dialog.tab-suivi-dialog--eleves .tab-suivi-eleves-detail__fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem 0.65rem;
  margin-bottom: 0.75rem;
}

@media (max-width: 420px) {
  dialog.tab-suivi-dialog--eleves .tab-suivi-eleves-detail__fields {
    grid-template-columns: 1fr;
  }
}

dialog.tab-suivi-dialog--eleves .tab-suivi-eleves-detail__del {
  width: 100%;
}

dialog.tab-suivi-dialog--oubli {
  width: min(26rem, calc(100vw - 1.25rem));
}

dialog.tab-suivi-dialog--oubli .tab-suivi-dialog__header--oubli {
  background: linear-gradient(135deg, #c2410c 0%, #ea580c 42%, #f97316 100%);
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-eleve {
  margin: 0.2rem 0 0;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1.25;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-dlg {
  gap: 0.65rem;
  scroll-behavior: smooth;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-stat {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
  margin: 0;
  padding: 0.55rem 0.75rem;
  border-radius: 0.65rem;
  background: #fff;
  border: 1px solid rgba(234, 88, 12, 0.2);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  line-height: 1.2;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-stat--zero {
  opacity: 0.85;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-stat__num {
  font-size: 1.5rem;
  font-weight: 800;
  color: #c2410c;
  font-variant-numeric: tabular-nums;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-stat__lbl {
  font-size: 0.88rem;
  font-weight: 600;
  color: #9a3412;
}

@keyframes tab-suivi-oubli-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  max-height: min(46vh, 18rem);
  overflow: auto;
  overscroll-behavior: contain;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-list > li {
  list-style: none;
  margin: 0;
  padding: 0;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card {
  display: flex;
  align-items: stretch;
  gap: 0.6rem;
  animation: tab-suivi-oubli-in 0.38s cubic-bezier(0.22, 1, 0.36, 1) both;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card__index {
  flex-shrink: 0;
  width: 2.1rem;
  align-self: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.88rem;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(160deg, #ea580c, #c2410c);
  border-radius: 0.5rem;
  box-shadow: 0 2px 6px rgba(194, 65, 12, 0.25);
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card__main {
  flex: 1 1 auto;
  min-width: 0;
  padding: 0.65rem 0.8rem;
  border-radius: 0.65rem;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card:hover .tab-suivi-oubli-card__main {
  border-color: rgba(234, 88, 12, 0.28);
  box-shadow: 0 6px 16px rgba(194, 65, 12, 0.12);
  transform: translateY(-1px);
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 0.55rem;
  margin-bottom: 0.35rem;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card__emoji {
  font-size: 1.15rem;
  line-height: 1;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card__date {
  font-size: 0.95rem;
  font-weight: 800;
  color: #1e293b;
  font-variant-numeric: tabular-nums;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card__classe {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #9a3412;
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  background: #ffedd5;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-card__type {
  margin: 0;
  font-size: 0.86rem;
  font-weight: 600;
  color: #64748b;
  padding: 0.35rem 0.5rem;
  border-radius: 0.4rem;
  background: #f8fafc;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-empty {
  margin: 0;
  padding: 1.5rem 1rem;
  text-align: center;
  font-size: 0.9rem;
  color: var(--text-muted);
  border-radius: 0.65rem;
  border: 1px dashed rgba(234, 88, 12, 0.35);
  background: #fff7ed;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-oubli-empty__icon {
  display: block;
  font-size: 2rem;
  margin-bottom: 0.4rem;
  opacity: 0.9;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-dialog__footer .btn--primary {
  background: linear-gradient(160deg, #ea580c 0%, #c2410c 100%);
  border-color: #c2410c;
}

dialog.tab-suivi-dialog--oubli .tab-suivi-dialog__footer .btn--primary:hover {
  filter: brightness(1.05);
}

.page-outil--tableau-suivi .tab-suivi-head-stats .tab-suivi-th--nom-vide {
  padding: 0.1rem 0.35rem;
  min-height: 0;
}

.page-outil--tableau-suivi .tab-suivi-row-icone {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  min-width: 2rem;
  padding: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.45rem;
  background: #fff;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.page-outil--tableau-suivi .tab-suivi-row-icone:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.page-outil--tableau-suivi .tab-suivi-row-oubli {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  min-width: 2rem;
  padding: 0;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.45rem;
  background: #fff;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.page-outil--tableau-suivi .tab-suivi-row-oubli:hover {
  border-color: #b45309;
  background: #fff7ed;
}

.page-outil--tableau-suivi .tab-suivi-row-oubli:disabled {
  opacity: 0.55;
  cursor: wait;
}

.page-outil--tableau-suivi .tab-suivi-row-oubli__icon {
  font-size: 1rem;
  line-height: 1;
}

.page-outil--tableau-suivi .tab-suivi-row-icone--vide {
  color: var(--text-muted);
  font-size: 1.1rem;
  font-weight: 700;
}

.page-outil--tableau-suivi .tab-suivi-row-icone--pai {
  background: #fef3c7;
  border-color: #f59e0b;
}

.page-outil--tableau-suivi .tab-suivi-row-icone--pap {
  background: #e0f2fe;
  border-color: #0284c7;
}

.page-outil--tableau-suivi .tab-suivi-row-icone--alert {
  background: #fee2e2;
  border-color: #dc2626;
  color: #b91c1c;
}

.page-outil--tableau-suivi .tab-suivi-row-icone--num {
  background: #f3e8ff;
  border-color: #9333ea;
  color: #6d28d9;
  font-weight: 800;
  font-size: 0.95rem;
}

dialog.tab-suivi-dialog .tab-suivi-icone-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.45rem;
}

dialog.tab-suivi-dialog .tab-suivi-icone-opt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  padding: 0.55rem 0.35rem;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
  background: #f8fafc;
  cursor: pointer;
  font: inherit;
  color: inherit;
}

dialog.tab-suivi-dialog .tab-suivi-icone-opt:hover {
  border-color: #99f6e4;
  background: #ecfdf5;
}

dialog.tab-suivi-dialog .tab-suivi-icone-opt__glyph {
  font-size: 1.35rem;
  line-height: 1;
}

dialog.tab-suivi-dialog .tab-suivi-icone-opt__label {
  font-size: 0.62rem;
  font-weight: 700;
  color: var(--text-muted);
  text-align: center;
  line-height: 1.1;
}

.page-outil--tableau-suivi .tab-suivi-col-fill {
  width: 1.65rem;
  height: 1.45rem;
  padding: 0;
  border: 1px solid rgba(13, 148, 136, 0.35);
  border-radius: 0.35rem;
  background: #fff;
  color: var(--accent-deep);
  font-size: 0.62rem;
  line-height: 1;
  cursor: pointer;
  display: block;
  margin: 0 auto;
}

.page-outil--tableau-suivi .tab-suivi-col-fill:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
}

.page-outil--tableau-suivi .tab-suivi-head-stats .tab-suivi-th--col {
  top: var(--tab-head-main-h);
  font-size: 0.68rem;
  font-weight: 800;
  color: var(--accent-deep);
  background: #d1fae5;
  padding-top: 0.15rem;
  padding-bottom: 0.2rem;
  z-index: 2;
  white-space: normal;
  line-height: 1.25;
}

.page-outil--tableau-suivi .tab-suivi-stat-group {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.14rem 0.22rem;
  max-width: 4.5rem;
}

.page-outil--tableau-suivi .tab-suivi-stat {
  display: inline-block;
  font-size: 0.64rem;
  font-weight: 800;
  line-height: 1.15;
  white-space: nowrap;
}

.page-outil--tableau-suivi .tab-suivi-stat--ok {
  color: #047857;
}

.page-outil--tableau-suivi .tab-suivi-stat--retard {
  color: #b45309;
}

.page-outil--tableau-suivi .tab-suivi-stat--attitude {
  color: #6d28d9;
}

.page-outil--tableau-suivi .tab-suivi-stat--justifie {
  color: #1d4ed8;
}

.page-outil--tableau-suivi .tab-suivi-stat--ko {
  color: #b91c1c;
}

.page-outil--tableau-suivi .tab-suivi-head-stats .tab-suivi-th--nom {
  top: var(--tab-head-main-h);
  z-index: 12;
  background: #d1fae5;
  color: var(--accent-deep);
}

.page-outil--tableau-suivi .tab-suivi-th--col,
.page-outil--tableau-suivi .tab-suivi-td--cell {
  width: 1%;
  white-space: nowrap;
  border-right: 2px solid rgba(15, 23, 42, 0.16);
}

.page-outil--tableau-suivi .tab-suivi-th--col:last-child,
.page-outil--tableau-suivi .tab-suivi-td--cell:last-child {
  border-right: none;
}

.page-outil--tableau-suivi #tab-suivi-thead .tab-suivi-th--nom {
  background: #ecfdf5;
}

.page-outil--tableau-suivi .tab-suivi-head-stats .tab-suivi-th--nom {
  background: #d1fae5;
}

.page-outil--tableau-suivi .tab-suivi-th--nom,
.page-outil--tableau-suivi .tab-suivi-td--nom {
  position: sticky;
  left: 0;
  z-index: 5;
  background: #fff;
  width: var(--tab-col-nom-max);
  min-width: 6.5rem;
  max-width: 50vw;
  box-shadow: 4px 0 8px -2px rgba(15, 23, 42, 0.12);
  border-right: 2px solid rgba(15, 23, 42, 0.22);
  box-sizing: border-box;
  overflow: hidden;
  isolation: isolate;
}

.page-outil--tableau-suivi #tab-suivi-thead .tab-suivi-th--nom {
  z-index: 12;
}

.page-outil--tableau-suivi .tab-suivi-th--nom::after,
.page-outil--tableau-suivi .tab-suivi-td--nom::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 8px;
  transform: translateX(100%);
  background: inherit;
  pointer-events: none;
}

.page-outil--tableau-suivi .tab-suivi-col-title {
  display: block;
  max-width: 2.6rem;
  font-size: 0.62rem;
  line-height: 1.15;
  margin: 0 auto;
  overflow: hidden;
  text-overflow: ellipsis;
}

.page-outil--tableau-suivi .tab-suivi-td--nom {
  padding: 0.35rem 0.5rem;
}

.page-outil--tableau-suivi .tab-suivi-nom-wrap {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.page-outil--tableau-suivi .tab-suivi-tr--equipe .tab-suivi-td--nom {
  box-shadow: inset 4px 0 0 var(--tab-suivi-equipe-couleur, transparent);
}

.page-outil--tableau-suivi .tab-suivi-equipe-badge {
  flex-shrink: 0;
  max-width: 5.5rem;
  padding: 0.15rem 0.45rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(15, 23, 42, 0.12);
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.2;
  color: #fff;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.25);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-outil--tableau-suivi .tab-suivi-equipe-badge--sans-couleur {
  background: rgba(13, 148, 136, 0.12);
  border-color: rgba(13, 148, 136, 0.35);
  color: var(--accent-deep);
  text-shadow: none;
}

.page-outil--tableau-suivi .tab-suivi-row-del {
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: rgba(248, 250, 252, 0.95);
  color: var(--text-muted);
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
}

.page-outil--tableau-suivi .tab-suivi-row-del:hover {
  background: rgba(254, 226, 226, 0.9);
  color: #b91c1c;
}

.page-outil--tableau-suivi .tab-suivi-nom-label {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  padding: 0.35rem 0.15rem;
  font: inherit;
  font-weight: 600;
  line-height: 1.25;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-outil--tableau-suivi .tab-suivi-td--cell {
  text-align: center;
  padding-left: 0.08rem;
  padding-right: 0.08rem;
}

.page-outil--tableau-suivi .tab-suivi-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  min-width: 2rem;
  border-radius: 0.45rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  background: rgba(248, 250, 252, 0.95);
  font-size: 1rem;
  font-weight: 800;
  cursor: pointer;
  line-height: 1;
  padding: 0;
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.page-outil--tableau-suivi .tab-suivi-check * {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

.page-outil--tableau-suivi .tab-suivi-check--ok {
  background: rgba(209, 250, 229, 0.95);
  border-color: rgba(5, 150, 105, 0.45);
  color: #047857;
}

.page-outil--tableau-suivi .tab-suivi-check--ko {
  background: rgba(254, 226, 226, 0.95);
  border-color: rgba(220, 38, 38, 0.4);
  color: #b91c1c;
}

.page-outil--tableau-suivi .tab-suivi-check--vide {
  color: var(--text-muted);
}

.page-outil--tableau-suivi .tab-suivi-check--retard {
  background: rgba(254, 243, 199, 0.95);
  border-color: rgba(217, 119, 6, 0.45);
  color: #b45309;
}

.page-outil--tableau-suivi .tab-suivi-check--attitude {
  background: rgba(237, 233, 254, 0.95);
  border-color: rgba(124, 58, 237, 0.45);
  color: #6d28d9;
  font-size: 1.1rem;
}

.page-outil--tableau-suivi .tab-suivi-check--justifie {
  background: rgba(219, 234, 254, 0.95);
  border-color: rgba(37, 99, 235, 0.4);
  color: #1d4ed8;
}

.page-outil--tableau-suivi .tab-suivi-check__clock {
  width: 1rem;
  height: 1rem;
  display: block;
}

.page-outil--tableau-suivi .tab-suivi-check__combo {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  line-height: 1;
}

.page-outil--tableau-suivi .tab-suivi-check__combo-main {
  font-size: 1rem;
  font-weight: 800;
  color: #1d4ed8;
}

.page-outil--tableau-suivi .tab-suivi-check__combo-sub {
  position: absolute;
  right: -0.28rem;
  bottom: -0.12rem;
  font-size: 0.48rem;
  font-weight: 900;
  line-height: 1;
  color: #1d4ed8;
  background: rgba(219, 234, 254, 0.98);
  border-radius: 0.12rem;
  padding: 0 0.06rem;
}

.tab-suivi-presence-menu {
  position: fixed;
  z-index: 12000;
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
  min-width: 11.5rem;
  padding: 0.35rem;
  border-radius: 0.55rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.14);
}

.tab-suivi-presence-menu[hidden] {
  display: none !important;
}

.tab-suivi-presence-menu__item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  border: none;
  border-radius: 0.4rem;
  background: transparent;
  padding: 0.38rem 0.45rem;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 650;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  border-left: 3px solid transparent;
}

.tab-suivi-presence-menu__item.tab-suivi-check--ok {
  background: rgba(209, 250, 229, 0.42);
  border-left-color: #059669;
}

.tab-suivi-presence-menu__item.tab-suivi-check--retard {
  background: rgba(254, 243, 199, 0.42);
  border-left-color: #d97706;
}

.tab-suivi-presence-menu__item.tab-suivi-check--attitude {
  background: rgba(237, 233, 254, 0.5);
  border-left-color: #7c3aed;
}

.tab-suivi-presence-menu__item.tab-suivi-check--justifie {
  background: rgba(219, 234, 254, 0.42);
  border-left-color: #2563eb;
}

.tab-suivi-presence-menu__item.tab-suivi-check--ko {
  background: rgba(254, 226, 226, 0.42);
  border-left-color: #dc2626;
}

.tab-suivi-presence-menu__item.tab-suivi-check--vide {
  background: rgba(248, 250, 252, 0.75);
  border-left-color: rgba(148, 163, 184, 0.55);
}

.tab-suivi-presence-menu__item:hover {
  filter: brightness(0.97);
}

.tab-suivi-presence-menu__glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.55rem;
  height: 1.55rem;
  border-radius: 0.35rem;
  border: 1px solid rgba(148, 163, 184, 0.4);
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1;
  flex-shrink: 0;
  padding: 0;
}

.tab-suivi-presence-menu__glyph.tab-suivi-check--ok {
  background: rgba(209, 250, 229, 0.95);
  border-color: rgba(5, 150, 105, 0.45);
  color: #047857;
}

.tab-suivi-presence-menu__glyph.tab-suivi-check--retard {
  background: rgba(254, 243, 199, 0.95);
  border-color: rgba(217, 119, 6, 0.45);
  color: #b45309;
}

.tab-suivi-presence-menu__glyph.tab-suivi-check--attitude {
  background: rgba(237, 233, 254, 0.95);
  border-color: rgba(124, 58, 237, 0.45);
  color: #6d28d9;
  font-size: 0.95rem;
}

.tab-suivi-presence-menu__glyph.tab-suivi-check--justifie {
  background: rgba(219, 234, 254, 0.95);
  border-color: rgba(37, 99, 235, 0.4);
  color: #1d4ed8;
}

.tab-suivi-presence-menu__glyph.tab-suivi-check--ko {
  background: rgba(254, 226, 226, 0.95);
  border-color: rgba(220, 38, 38, 0.4);
  color: #b91c1c;
}

.tab-suivi-presence-menu__glyph.tab-suivi-check--vide {
  background: rgba(248, 250, 252, 0.95);
  border-color: rgba(148, 163, 184, 0.45);
  color: var(--text-muted);
}

.tab-suivi-presence-menu__glyph .tab-suivi-check__clock {
  width: 0.82rem;
  height: 0.82rem;
}

.tab-suivi-presence-menu__glyph .tab-suivi-check__combo {
  width: 0.9rem;
  height: 0.9rem;
}

.tab-suivi-presence-menu__glyph .tab-suivi-check__combo-main {
  font-size: 0.82rem;
}

.tab-suivi-presence-menu__glyph .tab-suivi-check__combo-sub {
  font-size: 0.42rem;
  right: -0.22rem;
  bottom: -0.08rem;
}

.tab-suivi-presence-menu__label {
  line-height: 1.25;
}

.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--number,
.page-outil--tableau-suivi .tab-suivi-td--cell.tab-suivi-td--number,
.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--resultat,
.page-outil--tableau-suivi .tab-suivi-td--cell.tab-suivi-td--resultat,
.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--info-vma,
.page-outil--tableau-suivi .tab-suivi-td--cell.tab-suivi-td--info-vma,
.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--info-editable,
.page-outil--tableau-suivi .tab-suivi-td--cell.tab-suivi-td--info-editable {
  min-width: 5.25rem;
}

.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--number .tab-suivi-col-title,
.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--resultat,
.page-outil--tableau-suivi .tab-suivi-td--cell.tab-suivi-td--resultat {
  min-width: 6.5rem;
}

.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--resultat .tab-suivi-col-title {
  max-width: 6.5rem;
}

.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--info-vma .tab-suivi-col-title,
.page-outil--tableau-suivi .tab-suivi-th--col.tab-suivi-th--info-editable .tab-suivi-col-title {
  max-width: 4.85rem;
}

.page-outil--tableau-suivi .tab-suivi-td--number .tab-suivi-cell-number,
.page-outil--tableau-suivi .tab-suivi-td--resultat .tab-suivi-cell-text,
.page-outil--tableau-suivi .tab-suivi-td--info-vma .tab-suivi-cell-info--edit,
.page-outil--tableau-suivi .tab-suivi-td--info-editable .tab-suivi-cell-info--edit {
  width: 100%;
  justify-content: stretch;
}

.page-outil--tableau-suivi .tab-suivi-cell-input {
  width: 100%;
  min-width: 0;
  max-width: none;
  box-sizing: border-box;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.3rem;
  padding: 0.28rem 0.35rem;
  font: inherit;
  font-size: 0.82rem;
  text-align: center;
  -moz-appearance: textfield;
}

.page-outil--tableau-suivi .tab-suivi-cell-info-input--vma {
  min-width: 4.5rem;
  max-width: none;
  width: 100%;
}

.page-outil--tableau-suivi .tab-suivi-cell-input::-webkit-outer-spin-button,
.page-outil--tableau-suivi .tab-suivi-cell-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.page-outil--tableau-suivi .tab-suivi-cell-input:focus {
  outline: 2px solid var(--accent);
  border-color: var(--accent);
}

.page-outil--tableau-suivi .tab-suivi-cell-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.06rem;
}

.page-outil--tableau-suivi .tab-suivi-cell-suffix {
  font-size: 0.68rem;
  font-weight: 650;
  color: var(--text-muted);
  line-height: 1;
}

.page-outil--tableau-suivi .tab-suivi-col-note-check {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-weight: 650;
  cursor: pointer;
}

.page-outil--tableau-suivi .tab-suivi-col-bareme-row {
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.35rem;
}

.page-outil--tableau-suivi .tab-suivi-col-bareme-label {
  font-size: 0.85rem;
  font-weight: 650;
  color: var(--text-muted);
}

.page-outil--tableau-suivi .tab-suivi-col-dlg-max {
  width: 4rem;
  min-width: 4rem;
}

.page-outil--tableau-suivi .tab-suivi-col-bareme--hors-synth {
  font-style: italic;
  letter-spacing: 0;
}

.page-outil--tableau-suivi .tab-suivi-col-bareme {
  display: block;
  font-size: 0.65rem;
  font-weight: 650;
  color: var(--text-muted);
  letter-spacing: 0.02em;
}

.page-outil--tableau-suivi tbody tr:nth-child(even) .tab-suivi-td--nom {
  background: rgba(248, 250, 252, 0.98);
}

.page-outil--tableau-suivi tbody tr:nth-child(even) .tab-suivi-td--cell {
  background: rgba(15, 23, 42, 0.02);
}

/* —— Course d’orientation —— */
.page-outil--orientation {
  --orient-bg: #0f172a;
  --orient-surface: #ffffff;
  --orient-muted: #64748b;
  --orient-radius: 1rem;
  --orient-dock-h: calc(4.25rem + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  max-height: 100dvh;
  max-width: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background: var(--orient-bg);
}

.page-outil--orientation.orient-mode-pro {
  max-width: min(44rem, 100%);
  margin: 0 auto;
  max-height: none;
  padding: max(0.5rem, env(safe-area-inset-top)) max(0.65rem, env(safe-area-inset-right))
    max(0.5rem, env(safe-area-inset-bottom)) max(0.65rem, env(safe-area-inset-left));
}

.page-outil--orientation.orient-mode-eleve {
  background: linear-gradient(165deg, #0f172a 0%, #1e293b 45%, #0f172a 100%);
}

.page-outil--orientation.orient-mode-pro {
  background: #f1f5f9;
  overflow: auto;
}

.page-outil--orientation.orient-mode-eleve .page-outil__header--orient {
  display: none;
}

.orient-shell {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  position: relative;
}

.orient-shell--immersive .orient-main {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0.35rem 0.35rem 0;
  padding-bottom: calc(var(--orient-dock-h) + 0.25rem);
}

.orient-shell--pro .orient-main {
  flex: 1;
  min-height: 0;
  overflow: auto;
  padding: 0.65rem 0.75rem 1.25rem;
  -webkit-overflow-scrolling: touch;
}

.orient-pro-top {
  flex-shrink: 0;
  padding: 0.65rem 0.75rem 0.5rem;
  background: linear-gradient(180deg, #fff 0%, #f1f5f9 100%);
  border-bottom: 1px solid rgba(148, 163, 184, 0.28);
  box-shadow: 0 4px 20px rgba(15, 23, 42, 0.06);
}

.orient-pro-top .session-accordion {
  margin-bottom: 0.5rem;
  border-radius: var(--orient-radius);
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
}

.orient-shell--pro .orient-main {
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
}

.orient-pro-menu {
  margin-top: 0.5rem;
  padding: 0.75rem;
  border-radius: var(--orient-radius);
  background: #fff;
  box-shadow: 0 4px 20px rgba(15, 23, 42, 0.08);
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.orient-pro-menu__label {
  margin: 0 0 0.5rem;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--orient-muted);
}

.orient-pro-tabs--nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.4rem;
  width: 100%;
}

.orient-pro-tabs--nav .orient-pro-tabs__btn {
  min-height: 3.25rem;
  padding: 0.4rem 0.25rem;
}

.orient-pro-tabs--nav .orient-pro-tabs__text {
  font-size: 0.68rem;
}

.orient-pro-export {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: 0.55rem;
  padding-top: 0.55rem;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
}

.orient-pro-export__label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--orient-muted);
}

.orient-pro-export__btns {
  display: flex;
  gap: 0.35rem;
}

.orient-pro-export__btn {
  min-width: 3.5rem;
  padding: 0.4rem 0.85rem !important;
  font-size: 0.82rem !important;
}

.orient-pro-tabs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.4rem;
  flex: 1;
  min-width: min(100%, 14rem);
}

.orient-pro-tabs__btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.2rem;
  min-height: 3.5rem;
  padding: 0.45rem 0.35rem;
  border: 1px solid rgba(148, 163, 184, 0.3);
  border-radius: 0.75rem;
  background: #f8fafc;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 700;
  color: #334155;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.orient-pro-tabs__btn:active {
  transform: scale(0.97);
}

.orient-pro-tabs__icon {
  font-size: 1.25rem;
  line-height: 1;
}

.orient-pro-tabs__text {
  line-height: 1.2;
  text-align: center;
}

.orient-pro-tabs__btn--active {
  background: linear-gradient(145deg, #1a2744, #2563eb);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 14px rgba(37, 99, 235, 0.35);
}

.orient-pro-course-cta {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 2px solid rgba(37, 99, 235, 0.15);
}

.orient-pro-course-cta__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  width: 100%;
  min-height: 3.5rem;
  padding: 0.85rem 1rem;
  border: none;
  border-radius: 0.9rem;
  font: inherit;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: #fff;
  cursor: pointer;
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 45%, #15803d 100%);
  box-shadow:
    0 6px 0 #14532d,
    0 10px 28px rgba(22, 163, 74, 0.45);
  transition: transform 0.15s ease, box-shadow 0.2s ease, filter 0.2s ease;
  animation: orient-cta-course-pulse 2.2s ease-in-out infinite;
}

.orient-pro-course-cta__btn:hover {
  filter: brightness(1.06);
}

.orient-pro-course-cta__btn:active {
  transform: translateY(3px);
  box-shadow:
    0 3px 0 #14532d,
    0 6px 16px rgba(22, 163, 74, 0.35);
}

.orient-pro-course-cta__icon {
  font-size: 1.45rem;
  line-height: 1;
}

.orient-pro-course-cta__text {
  line-height: 1.2;
}

@keyframes orient-cta-course-pulse {
  0%,
  100% {
    box-shadow:
      0 6px 0 #14532d,
      0 10px 28px rgba(22, 163, 74, 0.4);
  }
  50% {
    box-shadow:
      0 6px 0 #14532d,
      0 10px 36px rgba(34, 197, 94, 0.65),
      0 0 0 4px rgba(74, 222, 128, 0.25);
  }
}

.orient-leaderboard__item--clickable {
  cursor: pointer;
  transition: transform 0.15s ease, background 0.2s ease, border-color 0.2s ease;
}

.orient-leaderboard__item--clickable:hover {
  background: #f8fafc;
  border-color: #94a3b8;
}

.orient-leaderboard__item--top1.orient-leaderboard__item--clickable:hover {
  background: #fef3c7;
}

.orient-leaderboard__item--top2.orient-leaderboard__item--clickable:hover {
  background: #f1f5f9;
}

.orient-leaderboard__item--top3.orient-leaderboard__item--clickable:hover {
  background: #ffedd5;
}

.orient-leaderboard__item--clickable:active {
  transform: scale(0.99);
}

.orient-leaderboard__item--clickable:focus-visible {
  outline: 2px solid #38bdf8;
  outline-offset: 2px;
}

.orient-dock {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
  display: flex;
  align-items: stretch;
  gap: 0.35rem;
  padding: 0.45rem 0.5rem calc(0.45rem + env(safe-area-inset-bottom, 0px));
  background: rgba(15, 23, 42, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.35);
}

.orient-dock__btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  min-height: 3.25rem;
  padding: 0.35rem 0.25rem;
  border: none;
  border-radius: 0.85rem;
  background: transparent;
  color: rgba(255, 255, 255, 0.65);
  font: inherit;
  font-size: 0.68rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;
}

.orient-dock__btn:active {
  transform: scale(0.96);
}

.orient-dock__btn--active {
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
}

.orient-dock__btn--pro {
  flex: 0 0 auto;
  min-width: 3.25rem;
  color: rgba(251, 191, 36, 0.9);
}

.orient-dock__icon {
  font-size: 1.35rem;
  line-height: 1;
}

.orient-view--eleve {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

#orient-panel-course {
  padding: 0;
  gap: 0.35rem;
}

.orient-legende {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.35rem 0.65rem;
  flex-shrink: 0;
  padding: 0.4rem 0.5rem 0.15rem;
}

.orient-legende__item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
}

.orient-legende__item::before {
  content: "";
  width: 0.85rem;
  height: 0.85rem;
  border-radius: 0.25rem;
  flex-shrink: 0;
}

.orient-legende__item--attente::before {
  background: linear-gradient(160deg, #bbf7d0, #22c55e);
}

.orient-legende__item--course::before {
  background: linear-gradient(160deg, #fef08a, #eab308);
}

.orient-legende__item--retard::before {
  background: linear-gradient(160deg, #fecaca, #dc2626);
}

.orient-legende__item--termine::before {
  background: linear-gradient(160deg, #bfdbfe, #2563eb);
}

.page-outil--orientation .orient-grille {
  --orient-grid-cols: 3;
  --orient-grid-rows: 2;
  --orient-grid-gap: 10px;
  --orient-grille-cell: 3.75rem;
  --orient-grille-cell-w: 5rem;
  --orient-grille-font-nom: 0.75rem;
  --orient-grille-font-meta: 0.65rem;
  display: grid;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  grid-template-columns: repeat(var(--orient-grid-cols), minmax(0, 1fr));
  grid-template-rows: repeat(var(--orient-grid-rows), minmax(0, 1fr));
  gap: var(--orient-grid-gap);
  flex: 1;
  min-height: 0;
  height: 100%;
  width: 100%;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 0.25rem 0.3rem 0.35rem;
  box-sizing: border-box;
}

.page-outil--orientation .orient-grille.orient-grille--scroll {
  grid-template-rows: repeat(var(--orient-grid-rows), minmax(var(--orient-grille-cell), var(--orient-grille-cell)));
  align-content: start;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
}

/* Très grands écrans : contenu centré à 75 % de la largeur */
@media (min-width: 1400px) {
  body.app--tool:has(.page-outil--orientation.orient-mode-eleve) {
    background: linear-gradient(165deg, #0f172a 0%, #1e293b 45%, #0f172a 100%);
    background-attachment: fixed;
  }

  .page-outil--orientation {
    width: 75vw;
    max-width: 75vw;
    margin-left: auto;
    margin-right: auto;
  }

  .page-outil--orientation.orient-mode-pro {
    width: 75vw;
    max-width: 75vw;
  }
}

.orient-grille__btn {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 0.1rem;
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  padding: 0.28rem 0.22rem;
  border: none;
  border-radius: 0.75rem;
  font: inherit;
  font-weight: 700;
  color: #0f172a;
  cursor: pointer;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.16);
  transition: transform 0.12s ease, box-shadow 0.15s ease;
  text-align: center;
  box-sizing: border-box;
  overflow: hidden;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

.orient-grille.orient-grille--scroll .orient-grille__btn {
  min-height: var(--orient-grille-cell);
}

.orient-grille__btn:active {
  transform: scale(0.98);
}

.orient-grille__nom {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  white-space: normal;
  overflow-wrap: break-word;
  word-break: break-word;
  hyphens: none;
  font-size: min(var(--orient-grille-font-nom, 0.75rem), calc(var(--orient-grille-cell-w, 5rem) * 0.2));
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: 0;
}

.orient-grille__btn:has(.orient-grille__meta) .orient-grille__nom {
  -webkit-line-clamp: 2;
  line-clamp: 2;
}

.orient-grille__meta {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  margin-top: 0.05rem;
  padding-top: 0.12rem;
  border-top: 1px solid rgba(15, 23, 42, 0.14);
  overflow: hidden;
  white-space: normal;
  overflow-wrap: break-word;
  word-break: break-word;
  font-size: min(var(--orient-grille-font-meta, 0.65rem), calc(var(--orient-grille-cell-w, 5rem) * 0.16));
  font-weight: 600;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
}

@media (max-width: 500px) {
  .orient-grille__btn {
    padding: 0.22rem 0.18rem;
    gap: 0.06rem;
  }

  .orient-grille__nom {
    font-size: min(var(--orient-grille-font-nom, 12px), calc(var(--orient-grille-cell-w, 5rem) * 0.19));
  }

  .orient-grille__meta {
    font-size: min(var(--orient-grille-font-meta, 10px), calc(var(--orient-grille-cell-w, 5rem) * 0.15));
    -webkit-line-clamp: 1;
    line-clamp: 1;
  }
}

.orient-grille__btn--attente {
  background: linear-gradient(160deg, #bbf7d0, #22c55e);
}

.orient-grille__btn--course {
  background: linear-gradient(160deg, #fef08a, #eab308);
}

.orient-grille__btn--course .orient-grille__meta {
  border-top-color: rgba(120, 53, 15, 0.2);
}

.orient-grille__btn--retard {
  background: linear-gradient(160deg, #fecaca, #dc2626);
  color: #fff;
}

.orient-grille__btn--retard .orient-grille__meta {
  border-top-color: rgba(255, 255, 255, 0.28);
}

.orient-grille__btn--termine {
  background: linear-gradient(160deg, #bfdbfe, #2563eb);
  color: #fff;
}

.orient-panel-head {
  flex-shrink: 0;
  padding: 0.65rem 0.5rem 0.75rem;
}

.orient-panel-head__title {
  margin: 0 0 0.65rem;
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.02em;
}

.orient-panel-head--classement {
  padding-bottom: 0.85rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  margin-bottom: 0.35rem;
}

.orient-classement-filter .orient-select {
  font-weight: 600;
}

.orient-leaderboard {
  list-style: none;
  margin: 0;
  padding: 0 0.35rem;
  flex: 1;
  min-height: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.orient-leaderboard__item {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.65rem 0.75rem;
  margin-bottom: 0.4rem;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 0.75rem;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.14);
  animation: orient-fade-in 0.35s ease backwards;
}

.orient-leaderboard__item--top1 {
  background: #fffbeb;
  border-color: #d97706;
  border-width: 2px;
  box-shadow: 0 3px 14px rgba(217, 119, 6, 0.22);
}

.orient-leaderboard__item--top2 {
  background: #f8fafc;
  border-color: #64748b;
  border-width: 2px;
}

.orient-leaderboard__item--top3 {
  background: #fff7ed;
  border-color: #ea580c;
  border-width: 2px;
}

.orient-leaderboard__rang {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  text-align: center;
  font-size: 1.05rem;
  font-weight: 800;
  color: #fff;
  border-radius: 999px;
  background: #1e293b;
  border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.25);
}

.orient-leaderboard__rang--top1 {
  background: #f59e0b;
  color: #1c1917;
  border-color: #fef3c7;
  box-shadow: 0 2px 8px rgba(245, 158, 11, 0.45);
}

.orient-leaderboard__rang--top2 {
  background: #94a3b8;
  color: #0f172a;
  border-color: #f1f5f9;
}

.orient-leaderboard__rang--top3 {
  background: #ea580c;
  color: #fff;
  border-color: #ffedd5;
}

.orient-leaderboard__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.orient-leaderboard__nom {
  font-weight: 800;
  font-size: 0.98rem;
  color: #0f172a;
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.orient-leaderboard__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-top: 0.15rem;
}

.orient-leaderboard__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  padding: 0.22rem 0.45rem;
  border-radius: 0.45rem;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  font-size: 0.72rem;
  line-height: 1.2;
}

.orient-leaderboard__stat-ico {
  font-size: 0.8rem;
  line-height: 1;
}

.orient-leaderboard__stat-label {
  font-weight: 700;
  color: #475569;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: 0.58rem;
}

.orient-leaderboard__stat-val {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #0f172a;
  font-size: 0.8rem;
}

.orient-leaderboard__stat--parcours {
  background: #dbeafe;
  border-color: #93c5fd;
}

.orient-leaderboard__stat--total,
.orient-leaderboard__stat--temps,
.orient-leaderboard__stat--moyenne {
  background: #ede9fe;
  border-color: #c4b5fd;
}

.orient-leaderboard__stat--ok {
  background: #dcfce7;
  border-color: #86efac;
}

.orient-leaderboard__stat--ok .orient-leaderboard__stat-val {
  color: #166534;
}

.orient-leaderboard__stat--err {
  background: #fee2e2;
  border-color: #fca5a5;
}

.orient-leaderboard__stat--err .orient-leaderboard__stat-val {
  color: #b91c1c;
}

.orient-leaderboard__temps {
  flex-shrink: 0;
  min-width: 3.75rem;
  padding: 0.4rem 0.5rem;
  text-align: center;
  font-size: 0.95rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #fff;
  letter-spacing: -0.02em;
  border-radius: 0.55rem;
  background: #0369a1;
  border: 2px solid #fff;
  box-shadow: 0 2px 8px rgba(3, 105, 161, 0.35);
}

@media (max-width: 559px) {
  .orient-leaderboard {
    padding: 0 0.15rem;
  }

  .orient-leaderboard__item {
    display: grid;
    grid-template-columns: 2.1rem 1fr auto;
    grid-template-areas:
      "rang nom temps"
      "rang stats stats";
    align-items: center;
    gap: 0.2rem 0.4rem;
    padding: 0.4rem 0.5rem;
    margin-bottom: 0.35rem;
  }

  .orient-leaderboard__body {
    display: contents;
  }

  .orient-leaderboard__rang {
    grid-area: rang;
    width: 2.1rem;
    height: 2.1rem;
    font-size: 0.92rem;
    align-self: center;
  }

  .orient-leaderboard__nom {
    grid-area: nom;
    font-size: 0.9rem;
    padding-right: 0.15rem;
  }

  .orient-leaderboard__stats {
    grid-area: stats;
    margin-top: 0;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 0.25rem;
    padding-bottom: 1px;
  }

  .orient-leaderboard__stats::-webkit-scrollbar {
    display: none;
  }

  .orient-leaderboard__stat {
    flex: 0 0 auto;
    padding: 0.18rem 0.38rem;
    font-size: 0.68rem;
  }

  .orient-leaderboard__stat-label {
    display: none;
  }

  .orient-leaderboard__stat-val {
    font-size: 0.75rem;
  }

  .orient-leaderboard__temps {
    grid-area: temps;
    min-width: 0;
    padding: 0.32rem 0.42rem;
    font-size: 0.82rem;
    align-self: center;
  }
}

@keyframes orient-fade-in {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.orient-card {
  background: var(--orient-surface);
  border-radius: var(--orient-radius);
  padding: 1rem 1.05rem;
  margin-bottom: 0.75rem;
  box-shadow: 0 2px 16px rgba(15, 23, 42, 0.06);
  border: 1px solid rgba(148, 163, 184, 0.2);
}

.orient-card--pro {
  border: none;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.07);
}

.page-outil--orientation .orient-acc.card--accordion {
  margin-bottom: 0.65rem;
  border: none;
  border-radius: var(--orient-radius);
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.07);
  overflow: hidden;
  background: #fff;
  transition: box-shadow 0.25s ease;
}

.page-outil--orientation .orient-acc.card--accordion[open] {
  box-shadow: 0 8px 32px rgba(15, 23, 42, 0.1);
}

.page-outil--orientation .orient-acc__summary {
  padding: 0.95rem 1rem;
  background: linear-gradient(135deg, #f8fafc 0%, #fff 100%);
}

.page-outil--orientation .orient-acc__summary {
  justify-content: flex-start;
}

.page-outil--orientation .orient-acc__summary .card--accordion__title {
  flex: 0 1 auto;
  font-size: 1.05rem;
  font-weight: 800;
  text-transform: none;
  letter-spacing: -0.02em;
  color: #0f172a;
}

.orient-acc__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.65rem;
  height: 1.65rem;
  padding: 0 0.45rem;
  margin-left: 0.4rem;
  margin-right: auto;
  border-radius: 999px;
  background: #1a2744;
  color: #fff;
  font-size: 0.78rem;
  font-weight: 800;
}

#orient-acc-parcours .orient-acc__badge {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
}

#orient-acc-coureurs .orient-acc__badge {
  background: linear-gradient(135deg, #16a34a, #15803d);
}

.page-outil--orientation .orient-acc.orient-acc--attention {
  animation: orient-acc-attention-glow 2.2s ease-in-out infinite;
}

.page-outil--orientation .orient-acc.orient-acc--attention .orient-acc__summary {
  animation: orient-acc-attention-shimmer 2.2s ease-in-out infinite;
}

.page-outil--orientation .orient-acc.orient-acc--attention .orient-acc__badge {
  animation: orient-acc-badge-pulse 2.2s ease-in-out infinite;
}

@keyframes orient-acc-attention-glow {
  0%,
  100% {
    box-shadow:
      0 4px 24px rgba(15, 23, 42, 0.07),
      0 0 0 2px rgba(245, 158, 11, 0.35);
  }
  50% {
    box-shadow:
      0 8px 32px rgba(245, 158, 11, 0.22),
      0 0 0 3px rgba(245, 158, 11, 0.85),
      0 0 18px rgba(251, 191, 36, 0.45);
  }
}

@keyframes orient-acc-attention-shimmer {
  0%,
  100% {
    background: linear-gradient(135deg, #fffbeb 0%, #fff 100%);
  }
  50% {
    background: linear-gradient(135deg, #fef3c7 0%, #fffbeb 55%, #fff 100%);
  }
}

@keyframes orient-acc-badge-pulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(245, 158, 11, 0);
  }
  50% {
    transform: scale(1.08);
    box-shadow: 0 0 0 4px rgba(251, 191, 36, 0.35);
  }
}

@media (prefers-reduced-motion: reduce) {
  .page-outil--orientation .orient-acc.orient-acc--attention,
  .page-outil--orientation .orient-acc.orient-acc--attention .orient-acc__summary,
  .page-outil--orientation .orient-acc.orient-acc--attention .orient-acc__badge {
    animation: none;
  }

  .page-outil--orientation .orient-acc.orient-acc--attention {
    box-shadow:
      0 4px 24px rgba(15, 23, 42, 0.07),
      0 0 0 2px rgba(245, 158, 11, 0.75);
  }

  .page-outil--orientation .orient-acc.orient-acc--attention .orient-acc__summary {
    background: linear-gradient(135deg, #fffbeb 0%, #fff 100%);
  }
}

.page-outil--orientation .orient-acc__panel {
  padding: 0 1rem 1rem;
  animation: orient-acc-open 0.28s ease;
}

.orient-acc__lead {
  margin-top: 0.85rem !important;
}

.orient-acc__panel > .orient-acc__lead:first-child {
  margin-top: 0.65rem !important;
}

@keyframes orient-acc-open {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.orient-actions-row {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.orient-actions-row--stack {
  flex-direction: column;
  margin-top: 0.5rem;
  margin-bottom: 0;
}

.orient-actions-row--duo {
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  margin-top: 0.5rem;
  margin-bottom: 0;
}

.orient-actions-row--duo .orient-btn {
  flex: 1 1 0;
  min-width: 0;
}

.orient-list__section {
  list-style: none;
  margin: 0.65rem 0 0.35rem;
  padding: 0 0.15rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--orient-muted);
}

.orient-list__section:first-child {
  margin-top: 0;
}

.orient-list__item--disabled {
  opacity: 0.72;
  background: #e2e8f0 !important;
  border-color: rgba(148, 163, 184, 0.35) !important;
  cursor: not-allowed;
  flex-direction: column;
  align-items: flex-start;
}

.orient-list__meta--course {
  width: 100%;
  font-size: 0.82rem;
  font-weight: 600;
  color: #64748b;
  font-variant-numeric: tabular-nums;
}

.orient-list__item--depart.orient-list__item--disabled .orient-list__label {
  color: #475569;
}

.orient-card--compact {
  margin-bottom: 0.65rem;
}

.orient-card__title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  font-weight: 800;
  color: #0f172a;
}

.orient-card__hint {
  margin: 0 0 0.75rem;
  font-size: 0.85rem;
  color: var(--orient-muted);
  line-height: 1.45;
}

.orient-list {
  list-style: none;
  margin: 0 0 0.75rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.orient-list__item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 0.85rem;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.25);
  border-radius: 0.75rem;
  transition: border-color 0.2s ease;
}

.orient-list__item--depart {
  align-items: center;
}

.orient-list__item--hist {
  flex-direction: column;
  align-items: stretch;
}

.orient-list__label {
  flex: 1;
  min-width: 6rem;
  font-weight: 600;
  color: #0f172a;
}

.orient-list__input {
  flex: 1;
  min-width: 8rem;
}

.orient-list__select {
  flex: 1;
  min-width: 7rem;
}

.orient-list__check {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  min-width: 8rem;
  cursor: pointer;
}

.orient-list__actions {
  display: flex;
  gap: 0.25rem;
  margin-left: auto;
}

.orient-list__action {
  flex-shrink: 0;
}

.orient-field {
  margin-bottom: 0.75rem;
}

.orient-field--inline {
  margin-bottom: 0.65rem;
}

.orient-field__label {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.55);
}

.orient-mode-pro .orient-field__label {
  color: var(--orient-muted);
}

.orient-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
}

.orient-temps-split {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.35rem;
  width: 100%;
}

.orient-temps-split__part {
  flex: 1 1 0;
  min-width: 0;
  width: auto;
  max-width: none;
  text-align: center;
}

.orient-temps-split__sep {
  flex: 0 0 auto;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
  color: rgba(255, 255, 255, 0.65);
  user-select: none;
}

.orient-mode-pro .orient-temps-split__sep {
  color: var(--orient-muted);
}

@media (max-width: 559px) {
  .orient-temps-split {
    flex-direction: row;
    flex-wrap: nowrap;
  }

  .orient-temps-split__part {
    flex: 1 1 0;
    min-width: 0;
  }
}

.orient-input,
.orient-select,
.orient-textarea {
  width: 100%;
  padding: 0.6rem 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.65rem;
  font: inherit;
  font-size: 0.95rem;
  background: #fff;
  color: #0f172a;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.orient-select--on-dark,
.orient-field--on-dark .orient-select {
  background: rgba(15, 23, 42, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.28);
  color: #fff;
  color-scheme: dark;
}

.orient-select--on-dark option,
.orient-field--on-dark .orient-select option {
  background: #1e293b;
  color: #fff;
}

.orient-fiche .orient-select,
.orient-view--pro .orient-select,
.orient-card .orient-select,
.orient-acc .orient-select,
.orient-list__select {
  background: #fff;
  border: 1px solid rgba(148, 163, 184, 0.5);
  color: #0f172a;
  color-scheme: light;
}

.orient-input:focus,
.orient-select:focus,
.orient-textarea:focus {
  outline: none;
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
}

.orient-temps-split .orient-input.orient-temps-split__part {
  flex: 1 1 0;
  min-width: 0;
  width: auto;
  max-width: none;
}

.orient-textarea {
  resize: vertical;
  min-height: 5rem;
}

.orient-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  padding: 0.55rem 1rem;
  border: none;
  border-radius: 0.75rem;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.15s ease, filter 0.2s ease, background 0.2s ease;
}

.orient-btn:active {
  transform: scale(0.98);
}

.orient-btn--block {
  width: 100%;
}

.orient-btn--lg {
  padding: 0.85rem 1rem;
  font-size: 1rem;
  border-radius: 0.85rem;
}

.orient-btn--xl {
  padding: 1.15rem 1rem;
  min-height: 3.85rem;
  font-size: 1.12rem;
  border-radius: 0.9rem;
}

.orient-btn--primary {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  color: #fff;
  box-shadow: 0 4px 14px rgba(37, 99, 235, 0.35);
}

.orient-btn--soft {
  background: rgba(15, 23, 42, 0.06);
  color: #0f172a;
}

.orient-btn--danger-soft {
  background: rgba(239, 68, 68, 0.1);
  color: #b91c1c;
  font-size: 0.8rem;
  padding: 0.35rem 0.65rem;
}

.orient-btn--glass {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.35);
  padding: 0.65rem 2rem;
}

.orient-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 0.65rem;
  border: none;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.07);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  color: #334155;
  cursor: pointer;
}

.orient-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.65rem;
}

.orient-toggle {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.9rem;
  cursor: pointer;
}

.orient-meta {
  margin: 0.35rem 0 0.75rem;
  font-size: 0.85rem;
  color: var(--orient-muted);
}

.orient-empty {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
  text-align: center;
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.95rem;
}

.orient-mode-pro .orient-empty {
  color: var(--orient-muted);
}

.orient-hist-item__main {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.35rem;
  width: 100%;
}

.orient-hist-item__temps {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #2563eb;
}

.orient-hist-balises {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0.45rem;
  width: 100%;
}

.orient-hist-balise {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.4rem;
  padding: 0.5rem 0.45rem;
  border-radius: 0.7rem;
}

.orient-hist-balise--ok {
  background: linear-gradient(160deg, rgba(22, 163, 74, 0.1), rgba(22, 163, 74, 0.04));
  border: 1px solid rgba(22, 163, 74, 0.22);
}

.orient-hist-balise--faux {
  background: linear-gradient(160deg, rgba(220, 38, 38, 0.09), rgba(220, 38, 38, 0.03));
  border: 1px solid rgba(220, 38, 38, 0.2);
}

.orient-hist-balise__head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
}

.orient-hist-balise__ico {
  font-size: 0.95rem;
  line-height: 1;
}

.orient-hist-balise__lbl {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #475569;
  white-space: nowrap;
}

.orient-hist-balise--ok .orient-hist-balise__lbl {
  color: #15803d;
}

.orient-hist-balise--faux .orient-hist-balise__lbl {
  color: #b91c1c;
}

.orient-hist-balise__ctrl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

.orient-hist-balise__val {
  min-width: 1.75rem;
  padding: 0.2rem 0.35rem;
  text-align: center;
  font-size: 1.15rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #0f172a;
}

.orient-hist-balise__btn {
  flex-shrink: 0;
  width: 2.15rem;
  height: 2.15rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 999px;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.12s ease, box-shadow 0.15s ease, filter 0.15s ease;
}

.orient-hist-balise__btn:active {
  transform: scale(0.94);
}

.orient-hist-balise__btn--moins {
  background: #fff;
  color: #475569;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.12);
  border: 1px solid rgba(148, 163, 184, 0.35);
}

.orient-hist-balise__btn--moins:hover {
  background: #f8fafc;
  color: #0f172a;
}

.orient-hist-balise--ok .orient-hist-balise__btn--plus {
  background: linear-gradient(145deg, #4ade80, #16a34a);
  color: #fff;
  box-shadow: 0 3px 10px rgba(22, 163, 74, 0.35);
}

.orient-hist-balise--faux .orient-hist-balise__btn--plus {
  background: linear-gradient(145deg, #f87171, #dc2626);
  color: #fff;
  box-shadow: 0 3px 10px rgba(220, 38, 38, 0.32);
}

.orient-hist-balise__btn--plus:hover {
  filter: brightness(1.06);
}

@media (max-width: 360px) {
  .orient-hist-balises {
    flex-wrap: wrap;
  }

  .orient-hist-balise {
    flex: 1 1 calc(50% - 0.25rem);
  }
}

.orient-hist-del {
  align-self: flex-start;
  margin-top: 0.35rem;
}

.orient-fiche {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  flex-direction: column;
  background: linear-gradient(165deg, #e8eef8 0%, #f1f5f9 38%, #eef2ff 100%);
  overflow: auto;
  animation: orient-slide-up 0.3s ease;
}

@keyframes orient-slide-up {
  from {
    transform: translateY(12px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.orient-fiche__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: calc(0.75rem + env(safe-area-inset-top, 0px)) 0.85rem 0.85rem;
  background: linear-gradient(125deg, #0f172a 0%, #1e3a8a 45%, #2563eb 100%);
  color: #fff;
  box-shadow: 0 8px 28px rgba(30, 58, 138, 0.35);
}

.orient-fiche__header h2 {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 800;
  flex: 1;
}

.orient-fiche__back {
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
}

.orient-fiche__body {
  padding: 0.85rem 0.75rem 1.25rem;
  flex: 1;
}

.orient-fiche-card--action {
  background: linear-gradient(160deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid rgba(148, 163, 184, 0.28);
  box-shadow: 0 10px 32px rgba(15, 23, 42, 0.1);
}

.orient-fiche-card--hist {
  background: #fff;
  border: 1px solid rgba(148, 163, 184, 0.22);
  box-shadow: 0 6px 22px rgba(15, 23, 42, 0.07);
}

.orient-fiche-card__title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.orient-fiche-card__title::before {
  content: "";
  width: 0.28rem;
  height: 1.1rem;
  border-radius: 999px;
  background: linear-gradient(180deg, #2563eb, #7c3aed);
}

.orient-fiche-field--parcours .orient-select,
.orient-fiche-field--parcours .orient-parcours-pick__btn {
  font-weight: 600;
  border-color: rgba(37, 99, 235, 0.35);
  background: #f8fafc;
}

.orient-parcours-pick {
  position: relative;
  width: 100%;
}

.orient-parcours-pick__btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  width: 100%;
  min-height: 2.75rem;
  padding: 0.55rem 0.75rem;
  text-align: left;
  cursor: pointer;
}

.orient-parcours-pick__btn[aria-expanded="true"] .orient-parcours-pick__chev {
  transform: rotate(180deg);
}

.orient-parcours-pick__value {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.orient-parcours-pick__value--placeholder {
  color: #64748b;
  font-weight: 500;
}

.orient-parcours-pick__value--termine {
  color: #1d4ed8;
  font-weight: 800;
}

.orient-parcours-pick__btn:disabled .orient-parcours-pick__chev {
  opacity: 0.45;
}

.orient-parcours-pick__chev {
  flex-shrink: 0;
  font-size: 0.85rem;
  color: #64748b;
  transition: transform 0.15s ease;
}

.orient-parcours-pick__menu {
  position: absolute;
  z-index: 40;
  top: calc(100% + 0.25rem);
  left: 0;
  right: 0;
  margin: 0;
  padding: 0.35rem;
  list-style: none;
  max-height: min(16rem, 50vh);
  overflow-y: auto;
  border-radius: 0.75rem;
  border: 1px solid rgba(37, 99, 235, 0.25);
  background: #fff;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.18);
}

.orient-parcours-pick__menu[hidden] {
  display: none;
}

.orient-parcours-pick__opt {
  display: block;
  width: 100%;
  padding: 0.65rem 0.75rem;
  border: none;
  border-radius: 0.5rem;
  background: transparent;
  font: inherit;
  font-weight: 600;
  text-align: left;
  color: #0f172a;
  cursor: pointer;
}

.orient-parcours-pick__opt:hover,
.orient-parcours-pick__opt:focus-visible {
  background: rgba(37, 99, 235, 0.1);
  outline: none;
}

.orient-parcours-pick__opt[aria-selected="true"] {
  background: rgba(37, 99, 235, 0.14);
  color: #1d4ed8;
}

.orient-fiche-record {
  border-left: 3px solid #2563eb;
}

.orient-ico {
  display: inline-block;
  margin-right: 0.2rem;
  line-height: 1;
}

.orient-chrono-panel {
  margin: 0.35rem 0 0.15rem;
  padding: 1rem 0.75rem;
  border-radius: 1rem;
  background: linear-gradient(145deg, #fef9c3 0%, #fde047 55%, #facc15 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.65),
    0 6px 20px rgba(234, 179, 8, 0.28);
}

.orient-chrono-panel__label {
  margin: 0 0 0.35rem;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #92400e;
  text-align: center;
}

.orient-fiche-card__title .orient-ico {
  margin-right: 0.35rem;
}

.orient-fiche-actions {
  margin-top: 0.25rem;
}

.orient-fiche-termine-depuis {
  margin: 0 0 0.65rem;
  padding: 0.55rem 0.75rem;
  border-radius: 0.65rem;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.12), rgba(37, 99, 235, 0.06));
  border: 1px solid rgba(37, 99, 235, 0.2);
  font-size: 0.85rem;
  font-weight: 600;
  color: #1e40af;
  text-align: center;
  line-height: 1.4;
}

.orient-fiche-actions-course__cancel {
  margin: 0.35rem 0 0.85rem;
  text-align: center;
}

.orient-fiche-hint-course {
  margin-bottom: 0.75rem;
}

.orient-depart-go {
  margin-bottom: 0.65rem;
}

.orient-depart-chips {
  margin-bottom: 0.5rem;
}

.orient-edit-hint {
  margin: 0.35rem 0 0;
  font-size: 0.78rem;
}

.orient-depart-parcours--alert,
.orient-fiche .orient-select--alert:not(.orient-parcours-pick__btn--termine) {
  border-color: #f59e0b !important;
  background-color: #fffbeb !important;
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.45);
  animation: orient-select-alert 1.15s ease-in-out infinite;
}

.orient-parcours-pick__btn--termine {
  border-color: rgba(37, 99, 235, 0.35) !important;
  background: #eff6ff !important;
  box-shadow: none !important;
  animation: none !important;
}

@keyframes orient-select-alert {
  0%,
  100% {
    box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.4);
    background-color: #fffbeb;
  }
  50% {
    box-shadow: 0 0 0 4px rgba(245, 158, 11, 0.75);
    background-color: #fef3c7;
  }
}

.orient-btn--annuler-depart {
  display: inline-block;
  width: auto;
  margin: 0;
  padding: 0.3rem 0.5rem;
  border: none;
  border-radius: 0.35rem;
  background: transparent;
  color: #64748b;
  font-size: 0.76rem;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
  box-shadow: none;
}

.orient-btn--annuler-depart:hover {
  color: #b91c1c;
  background: rgba(239, 68, 68, 0.06);
}

.orient-btn--annuler-depart:active {
  transform: none;
}

.orient-stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.4rem;
  margin-bottom: 0.65rem;
}

.orient-stats__grid--6 {
  grid-template-columns: repeat(3, 1fr);
}

.orient-stats__cell {
  padding: 0.65rem 0.35rem;
  text-align: center;
  background: #fff;
  border-radius: 0.75rem;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}

.orient-stats__cell strong {
  display: block;
  font-size: 1.2rem;
  font-weight: 800;
  color: #0f172a;
}

.orient-stats__cell span {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--orient-muted);
}

.orient-record {
  margin: 0 0 0.65rem;
  padding: 0.55rem 0.75rem;
  background: rgba(37, 99, 235, 0.1);
  border-radius: 0.65rem;
  font-size: 0.88rem;
  color: #1d4ed8;
  font-weight: 600;
}

.orient-chrono-live {
  font-size: 3.35rem;
  font-weight: 800;
  text-align: center;
  margin: 0;
  font-variant-numeric: tabular-nums;
  color: #713f12;
  letter-spacing: -0.03em;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.45);
}

.orient-stats--fiche .orient-stats__cell {
  border: 1px solid rgba(148, 163, 184, 0.2);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}

.orient-stats__ico {
  display: block;
  font-size: 1.2rem;
  line-height: 1;
  margin-bottom: 0.25rem;
}

.orient-stats--fiche .orient-stats__cell--parcours strong {
  color: #2563eb;
}

.orient-stats--fiche .orient-stats__cell--moyenne strong {
  color: #7c3aed;
}

.orient-stats--fiche .orient-stats__cell--rang strong {
  color: #0891b2;
}

.orient-stats--fiche .orient-stats__cell--ok strong {
  color: #16a34a;
}

.orient-stats--fiche .orient-stats__cell--err strong {
  color: #dc2626;
}

.orient-stats--fiche .orient-stats__cell--rec strong {
  color: #d97706;
}

.orient-fiche .orient-list__item--hist {
  border-radius: 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: linear-gradient(135deg, #fafafa 0%, #fff 100%);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.05);
}

.orient-fiche-resultat {
  text-align: center;
  padding: 1rem 0;
}

.orient-fiche-resultat__label {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--orient-muted);
}

.orient-fiche-resultat__time {
  font-size: 3.25rem;
  font-weight: 800;
  margin: 0.2rem 0;
  font-variant-numeric: tabular-nums;
  color: #0f172a;
}

.orient-fiche-resultat__ecart {
  margin: 0 0 0.65rem;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.45;
  color: #475569;
}

.orient-fiche-resultat__record {
  font-size: 1.05rem;
  color: #2563eb;
  font-weight: 700;
}

.orient-arrivee-modal {
  position: fixed;
  inset: 0;
  z-index: 550;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.orient-arrivee-modal--visible {
  pointer-events: auto;
  opacity: 1;
}

.orient-arrivee-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.52);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.orient-arrivee-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 22.5rem);
  max-height: min(92vh, 34rem);
  overflow: auto;
  padding: 1.65rem 1.4rem 1.4rem;
  border-radius: 1.35rem;
  background: linear-gradient(165deg, #ffffff 0%, #f8fafc 100%);
  box-shadow:
    0 28px 70px rgba(15, 23, 42, 0.28),
    0 0 0 1px rgba(255, 255, 255, 0.8) inset;
  text-align: center;
  transform: translateY(1.25rem) scale(0.94);
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.orient-arrivee-modal--visible .orient-arrivee-modal__dialog {
  transform: translateY(0) scale(1);
}

.orient-arrivee-modal__badge {
  display: inline-block;
  margin-bottom: 0.45rem;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #fef3c7, #fde68a);
  color: #92400e;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.orient-arrivee-modal__titre {
  margin: 0 0 0.35rem;
  font-size: 1.35rem;
  font-weight: 800;
  color: #0f172a;
  letter-spacing: -0.02em;
}

.orient-arrivee-modal__nom {
  margin: 0 0 0.15rem;
  font-size: 1.05rem;
  font-weight: 700;
  color: #334155;
}

.orient-arrivee-modal__parcours {
  margin: 0 0 0.85rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: #64748b;
}

.orient-arrivee-modal__temps {
  margin: 0 0 0.65rem;
  font-size: 3.35rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
  color: #0f172a;
  letter-spacing: -0.03em;
}

.orient-arrivee-modal__classement {
  margin: 0 0 0.5rem;
  padding: 0.55rem 0.65rem;
  border-radius: 0.65rem;
  background: rgba(37, 99, 235, 0.08);
}

.orient-arrivee-modal__rang-pos {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.4;
  color: #1d4ed8;
}

.orient-arrivee-modal__rang-nb {
  margin: 0.35rem 0 0;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.4;
  color: #475569;
}

.orient-arrivee-modal__record {
  margin: 0 0 0.5rem;
  font-size: 1rem;
  font-weight: 700;
  color: #15803d;
  line-height: 1.4;
}

.orient-arrivee-modal__ecart {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.45;
  color: #475569;
}

.orient-arrivee-modal__hint {
  margin: 0 0 1rem;
  font-size: 0.78rem;
  line-height: 1.4;
  color: #94a3b8;
}

.orient-arrivee-modal__btn {
  margin-top: 0.15rem;
}

body.orient-arrivee-modal-open {
  overflow: hidden;
}

.orient-parti {
  position: fixed;
  inset: 0;
  z-index: 300;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: radial-gradient(ellipse at 50% 30%, #3b82f6, #0f172a 70%);
  color: #fff;
  text-align: center;
  padding: 2rem;
}

.orient-parti__titre {
  font-size: clamp(2rem, 8vw, 2.75rem);
  font-weight: 800;
  margin: 0 0 0.5rem;
  letter-spacing: -0.02em;
}

.orient-parti__nom {
  font-size: 1.15rem;
  margin: 0 0 1rem;
  opacity: 0.9;
}

.orient-parti__chrono {
  font-size: 3.5rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  margin: 0 0 2rem;
}

/* —— Cahier de texte —— */
.page-outil--cahier .page-outil__subtitle {
  margin: 0.25rem 0 0;
  font-size: 0.92rem;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.35;
}

.cahier-msg {
  margin: 0 0 0.75rem;
}

.cahier-meta__row {
  align-items: flex-end;
}

.cahier-meta__classe {
  flex: 1 1 12rem;
  min-width: 0;
}

.cahier-meta__date {
  flex: 0 1 9rem;
  min-width: 0;
}

.cahier-repeat {
  width: 100%;
  margin-top: 0.65rem;
}

.cahier-quick__hint {
  margin-top: 0;
}

.cahier-chips-block {
  margin-bottom: 0.85rem;
}

.cahier-apsa-autre {
  margin-top: 0.65rem;
  margin-bottom: 0;
}

.cahier-champ-resume {
  margin: 0.5rem 0 0;
  line-height: 1.4;
}

.cahier-section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.cahier-section-title__icon {
  font-size: 1.05em;
  line-height: 1;
  flex-shrink: 0;
}

.cahier-section-title__text {
  min-width: 0;
}

.page-outil--cahier .field-label.cahier-section-title {
  display: inline-flex;
}

.page-outil--cahier .card--accordion__title.cahier-section-title {
  display: inline-flex;
}

.page-outil--cahier .cahier-acc__summary-title.cahier-section-title {
  font-size: 0.88rem;
  font-weight: 700;
  text-transform: none;
  letter-spacing: normal;
  color: var(--accent-deep, #1a2744);
}

.cahier-copie h3.cahier-section-title,
.cahier-dialog__title.cahier-section-title {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.cahier-chips-block__label {
  margin: 0 0 0.4rem;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted, #64748b);
}

.cahier-chips-block__label.cahier-section-title {
  display: flex;
}

.cahier-seq-objectif-source {
  margin: 0 0 0.45rem;
  font-size: 0.78rem;
  line-height: 1.35;
}

.cahier-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.cahier-chips--champ {
  flex-direction: column;
  align-items: stretch;
}

.cahier-chips--champ .cahier-chip {
  width: 100%;
  max-width: none;
  flex: 0 0 auto;
  justify-content: flex-start;
  text-align: left;
  line-height: 1.25;
  border-radius: 0.65rem;
  min-height: 2.6rem;
}

.cahier-chips--champ .cahier-chip__code {
  flex: 0 0 2.75rem;
  text-align: left;
  font-weight: 750;
}

.cahier-chips--champ .cahier-chip__libelle {
  flex: 1 1 auto;
  text-align: left;
}

.cahier-chips--champ .cahier-chip--active {
  background: #1a2744;
  border-color: #1a2744;
  color: #fff;
  box-shadow: 0 2px 8px rgba(26, 39, 68, 0.28);
}

.cahier-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35rem;
  padding: 0.4rem 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.55);
  border-radius: 999px;
  background: #fff;
  color: #0f172a;
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.cahier-chip:active {
  transform: scale(0.98);
}

.cahier-chip--active {
  background: #1a2744;
  border-color: #1a2744;
  color: #fff;
}

.cahier-opt {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0.35rem 0;
  font-size: 0.88rem;
  line-height: 1.35;
  color: #334155;
}

.cahier-opt input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.cahier-plus__panel {
  padding-top: 0.25rem;
}

.cahier-edit-zone {
  margin-bottom: 0.85rem;
}

.cahier-edit-zone__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}

.cahier-edit-zone__head .field-label {
  margin: 0;
}

.cahier-field-with-clear {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
}

.cahier-field-with-clear .cahier-textarea {
  width: 100%;
}

.cahier-field-with-clear .btn {
  margin: 0;
}

.cahier-textarea {
  width: 100%;
  min-height: 4rem;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.55);
  border-radius: 0.65rem;
  font: inherit;
  font-size: 0.92rem;
  line-height: 1.45;
  resize: vertical;
}

.cahier-dictate--active {
  background: rgba(37, 99, 235, 0.12);
  border-color: #3b82f6;
}

.page-outil--cahier .cahier-dictate--prominent {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.75rem;
  font-weight: 700;
  color: #1e40af;
  background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
  border: 2px solid #3b82f6;
  border-radius: 999px;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18);
  animation: cahier-mic-glow 2.4s ease-in-out infinite;
}

.page-outil--cahier .cahier-dictate--prominent:hover {
  background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
  color: #1d4ed8;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.28);
}

.page-outil--cahier .cahier-dictate--prominent.cahier-dictate--active {
  background: #2563eb;
  color: #fff;
  border-color: #1d4ed8;
  animation: none;
}

@keyframes cahier-mic-glow {
  0%,
  100% {
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
  }
  50% {
    box-shadow: 0 0 0 6px rgba(59, 130, 246, 0.28);
  }
}

.cahier-deroule-hint {
  margin: 0.35rem 0 0.65rem;
}

.cahier-deroule-text {
  margin-bottom: 0.85rem;
  padding: 0.75rem;
  background: #fff;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.65rem;
}

.cahier-deroule-text__head {
  margin-bottom: 0.45rem;
}

.cahier-deroule-text .cahier-textarea {
  background: #f8fafc;
}

.cahier-niveau-hint {
  margin: 0.35rem 0 0;
}

.cahier-type-seance-block {
  margin: 0.75rem 0 0;
}

.cahier-zone {
  margin-bottom: 1rem;
  padding: 0.85rem 0.9rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(248, 250, 252, 0.85);
}

.cahier-zone--perso {
  border-color: rgba(245, 158, 11, 0.45);
  background: #fffbeb;
}

.cahier-zone__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin-bottom: 0.5rem;
}

.cahier-zone__title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 800;
  color: #0f172a;
}

.cahier-zone__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.15rem 0.45rem;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background: #dcfce7;
  color: #166534;
}

.cahier-zone__badge--warn {
  background: #fef3c7;
  color: #92400e;
}

.cahier-zone__preview {
  margin: 0 0 0.65rem;
  padding: 0.65rem 0.7rem;
  border-radius: 0.55rem;
  background: #fff;
  border: 1px solid rgba(148, 163, 184, 0.35);
  font-family: inherit;
  font-size: 0.9rem;
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
  color: #0f172a;
}

.cahier-zone__preview--muted {
  color: #64748b;
}

.cahier-copy-all {
  margin: 0.5rem 0 0.65rem;
}

.cahier-save {
  width: 100%;
}

.cahier-mode {
  display: flex;
  gap: 0.35rem;
  margin-top: 0.35rem;
  margin-bottom: 0.85rem;
}

.cahier-mode__btn {
  flex: 1 1 0;
  min-width: 0;
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(148, 163, 184, 0.55);
  border-radius: 0.65rem;
  background: #fff;
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  color: #334155;
  cursor: pointer;
}

.cahier-mode__btn--active {
  background: #1a2744;
  border-color: #1a2744;
  color: #fff;
}

.cahier-panel-resume {
  margin-bottom: 0.75rem;
}

.cahier-actions-pair {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0.5rem;
  width: 100%;
}

.cahier-actions-pair .btn {
  flex: 1 1 calc(50% - 0.25rem);
  min-width: 0;
  margin: 0;
}

.cahier-actions-pair .btn:only-child {
  flex: 1 1 100%;
}

.cahier-seq-form > .cahier-actions-pair {
  margin-top: 1.35rem;
}

.cahier-seq-actions--resume {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0.5rem;
  margin-top: 1rem;
}

.cahier-seq-actions--resume .btn {
  flex: 1 1 10rem;
  margin: 0;
}

.cahier-seance-fields {
  margin-top: 0.5rem;
}

.cahier-seance-actions {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0.5rem;
  margin-top: 1.25rem;
}

.cahier-seance-actions .cahier-actions-pair {
  margin-top: 0;
}

.cahier-acc__summary-title {
  flex: 1 1 auto;
  min-width: 0;
  margin-left: 0.35rem;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--text, #0f172a);
  text-align: left;
  overflow: hidden;
}

.cahier-acc__summary-title.cahier-section-title {
  display: flex;
}

.cahier-acc__summary-title .cahier-section-title__text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cahier-seq-active-bar {
  margin-bottom: 0;
  padding-bottom: 0;
}

.cahier-hr {
  margin: 1rem 0;
  border: 0;
  border-top: 1px solid rgba(148, 163, 184, 0.38);
}

.cahier-hr[hidden] {
  display: none;
}

.cahier-hr--compact {
  margin: 0.75rem 0;
}

.cahier-seq-active-bar__meta {
  margin: 0 0 0.5rem;
}

.cahier-seq-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.cahier-seq-changer {
  margin-left: auto;
  font-weight: 700;
}

.cahier-seq-picker {
  margin-bottom: 0.85rem;
}

.cahier-seq-picker:last-child {
  margin-bottom: 0;
}

.cahier-seance__date-wrap {
  padding-top: 0.85rem;
}

.cahier-seance__date.field-group--inline {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 0.75rem;
}

.cahier-seance__date.field-group--inline .field-label {
  margin: 0;
  flex-shrink: 0;
}

.cahier-seance__date.field-group--inline input[type="date"] {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 11.5rem;
}

.cahier-ca5-params {
  margin: 0.75rem 0 0;
  padding: 0.75rem;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 0.65rem;
}

.cahier-ca5-params__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
  gap: 0.65rem;
}

.cahier-ca5-params .field-group {
  margin: 0;
}

.cahier-acc-seance .card--accordion__panel > .hint:first-child {
  margin-top: 0;
}

.cahier-copie {
  margin-top: 1rem;
  padding: 0.85rem;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 0.65rem;
}

.cahier-copie h3 {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  font-weight: 800;
}

.cahier-copie__hint {
  margin: 0 0 0.65rem;
  font-size: 0.82rem;
  line-height: 1.45;
}

.cahier-edit-zone .cahier-chips-block__label {
  margin-top: 0;
}

.cahier-export {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  justify-content: flex-start;
}

.cahier-acc__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  height: 1.5rem;
  padding: 0 0.4rem;
  margin-left: 0.35rem;
  border-radius: 999px;
  background: #1a2744;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
}

.cahier-acc__badge--inline {
  margin: 0;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 0.35rem;
  font-size: 0.72rem;
  flex-shrink: 0;
}

.cahier-acc__title-seances {
  text-transform: none;
  letter-spacing: -0.01em;
  font-size: 0.95rem;
  font-weight: 800;
}

.cahier-acc__title-seances .cahier-section-title__icon {
  margin-right: 0.1rem;
}

.cahier-workspace {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.cahier-new-seance {
  width: 100%;
  margin-top: 0.65rem;
  margin-bottom: 0.65rem;
}

.cahier-seances-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cahier-seances-list__item {
  display: grid;
  grid-template-columns: 2.35rem 1fr;
  gap: 0.6rem;
  align-items: stretch;
  position: relative;
  padding-bottom: 0.55rem;
}

.cahier-seances-list__item:not(:last-child)::before {
  content: "";
  position: absolute;
  left: 1.175rem;
  top: 2.35rem;
  bottom: 0;
  width: 2px;
  margin-left: -1px;
  background: rgba(148, 163, 184, 0.4);
  border-radius: 1px;
}

.cahier-seances-list__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  margin-top: 0.35rem;
  border-radius: 50%;
  background: #1a2744;
  color: #fff;
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1;
  flex-shrink: 0;
  z-index: 1;
}

.cahier-seances-list__btn {
  display: block;
  width: 100%;
  min-height: 2.75rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 0.65rem;
  background: #fff;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.cahier-seances-list__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
  min-width: 0;
}

.cahier-seances-list__title {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  width: 100%;
}

.cahier-seances-list__title strong {
  font-size: 0.92rem;
  font-weight: 800;
  color: #0f172a;
}

.cahier-seances-list__date {
  font-size: 0.8rem;
  font-weight: 600;
  color: #64748b;
  white-space: nowrap;
}

.cahier-seances-list__tag {
  display: inline-block;
  padding: 0.1rem 0.45rem;
  border-radius: 0.35rem;
  background: rgba(26, 39, 68, 0.08);
  color: #1a2744;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.cahier-seances-list__resume {
  font-size: 0.8rem;
  color: #64748b;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cahier-seances-list__item--active .cahier-seances-list__num {
  background: #2563eb;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}

.cahier-seances-list__item--active .cahier-seances-list__btn {
  border-color: #2563eb;
  background: #eff6ff;
}

.cahier-seance__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.65rem;
  margin-bottom: 0.5rem;
}

.cahier-seance__head h2 {
  margin: 0;
  font-size: 1.1rem;
}

.cahier-seance__date {
  flex: 0 1 auto;
  margin: 0;
}

.cahier-duplicate-seance {
  flex: 1 1 100%;
  width: 100%;
  margin-top: 0;
  margin-bottom: 0.15rem;
}

.cahier-dialog {
  width: min(22rem, calc(100vw - 2rem));
  max-width: none;
  padding: 1rem 1.1rem;
  border: none;
  border-radius: 0.75rem;
}

.cahier-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}

.cahier-dialog__title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  font-weight: 800;
}

.cahier-dialog__form {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.cahier-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
  margin-top: 0.25rem;
}

.cahier-seq-delete-wrap {
  margin-top: 0;
}

.cahier-seq-delete-wrap .btn {
  width: 100%;
  margin: 0;
}

.cahier-delete-seance {
  margin-top: 0;
  width: auto;
}

.cahier-pronote h3 {
  margin: 0 0 0.65rem;
  font-size: 1rem;
  font-weight: 800;
}

@media (max-width: 559px) {
  .cahier-chip {
    min-height: 2.5rem;
    font-size: 0.9rem;
  }

  .cahier-meta__row {
    flex-direction: column;
    align-items: stretch;
  }

  .cahier-meta__date {
    flex: 1 1 auto;
  }
}

/* —— Tableau tactique (schémas tactiques EPS) —— */
.tn-body {
  margin: 0;
  overflow: hidden;
  height: 100dvh;
  height: 100vh;
  background: var(--tn-bg, #0d1117);
}

.tn-body.app {
  padding: 0;
  max-width: none;
}

.tn-app {
  --tn-bg: #0d1117;
  --tn-surface: #161b22;
  --tn-border: rgba(255, 255, 255, 0.1);
  --tn-text: #e6edf3;
  --tn-muted: #8b949e;
  --tn-accent: #3fb950;
  --tn-accent-dim: rgba(63, 185, 80, 0.2);
  --tn-topbar-h: 3rem;
  --tn-sidebar-w: min(18rem, 88vw);
  display: flex;
  flex-direction: column;
  height: 100dvh;
  height: 100vh;
  background: var(--tn-bg);
  color: var(--tn-text);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

.tn-app[data-theme="light"] {
  --tn-bg: #eef1f4;
  --tn-surface: #ffffff;
  --tn-border: rgba(0, 0, 0, 0.1);
  --tn-text: #1a2332;
  --tn-muted: #5a6578;
  --tn-accent: #2e7d32;
  --tn-accent-dim: rgba(46, 125, 50, 0.15);
}

.tn-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  min-height: var(--tn-topbar-h);
  padding: env(safe-area-inset-top, 0) 0.5rem 0 0.5rem;
  padding-left: max(0.5rem, env(safe-area-inset-left));
  padding-right: max(0.5rem, env(safe-area-inset-right));
  background: var(--tn-surface);
  border-bottom: 1px solid var(--tn-border);
  flex-shrink: 0;
  z-index: 30;
}

.tn-topbar__left {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  min-width: 0;
}

.tn-topbar__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tn-topbar__actions {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-shrink: 0;
  min-width: 0;
}

.tn-topbar-overflow {
  position: relative;
  display: none;
}

.tn-topbar-overflow > summary {
  list-style: none;
}

.tn-topbar-overflow > summary::-webkit-details-marker {
  display: none;
}

.tn-top-btn--menu {
  min-width: 2.5rem;
  padding-inline: 0.55rem;
  font-size: 1.15rem;
  line-height: 1;
  letter-spacing: 0.08em;
}

.tn-topbar-overflow__panel {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  z-index: 40;
  min-width: 11rem;
  padding: 0.35rem;
  border-radius: 0.55rem;
  border: 1px solid var(--tn-border);
  background: var(--tn-surface);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
}

.tn-topbar-overflow__item {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0.55rem 0.65rem;
  border: none;
  border-radius: 0.4rem;
  background: transparent;
  color: var(--tn-text);
  font-size: 0.82rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
}

.tn-topbar-overflow__item:hover {
  background: var(--tn-accent-dim);
}

.tn-topbar-overflow__item--accent {
  color: var(--tn-accent);
}

.tn-topbar__actions-inline {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  min-width: 0;
}

.tn-topbar__group {
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--tn-border);
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--tn-bg);
  background: color-mix(in srgb, var(--tn-bg) 55%, var(--tn-surface));
}

.tn-topbar__group .tn-top-btn {
  border: none;
  border-radius: 0;
  border-right: 1px solid var(--tn-border);
  min-width: 2.35rem;
  justify-content: center;
}

.tn-topbar__group .tn-top-btn:last-child {
  border-right: none;
}

.tn-top-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  padding: 0.38rem 0.62rem;
  border: 1px solid var(--tn-border);
  border-radius: 0.5rem;
  background: var(--tn-bg);
  background: color-mix(in srgb, var(--tn-bg) 40%, var(--tn-surface));
  color: var(--tn-text);
  font-size: 0.74rem;
  font-weight: 650;
  letter-spacing: 0.02em;
  white-space: nowrap;
  cursor: pointer;
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease,
    transform 0.1s ease,
    box-shadow 0.15s ease;
}

.tn-top-btn:focus-visible {
  outline: 2px solid var(--tn-accent);
  outline-offset: 2px;
}

.tn-top-btn:active {
  transform: scale(0.97);
}

.tn-top-btn:hover {
  background: var(--tn-accent-dim);
  border-color: color-mix(in srgb, var(--tn-accent) 45%, var(--tn-border));
}

.tn-top-btn--primary {
  color: var(--tn-accent);
  border-color: color-mix(in srgb, var(--tn-accent) 55%, var(--tn-border));
  background: var(--tn-accent-dim);
}

.tn-top-btn--primary:hover {
  background: color-mix(in srgb, var(--tn-accent-dim) 70%, var(--tn-accent) 30%);
}

.tn-top-btn--share {
  color: var(--tn-accent);
  border-color: color-mix(in srgb, var(--tn-accent) 65%, var(--tn-border));
}

.tn-top-btn--share:hover {
  background: color-mix(in srgb, var(--tn-accent-dim) 80%, var(--tn-accent) 20%);
}

.tn-top-btn--accent {
  background: var(--tn-accent-dim);
  color: var(--tn-accent);
  border-color: color-mix(in srgb, var(--tn-accent) 50%, var(--tn-border));
}

.tn-top-btn__label {
  display: none;
}

@media (min-width: 720px) {
  .tn-top-btn {
    font-size: 0.8rem;
    padding: 0.42rem 0.72rem;
  }

  .tn-top-btn__label {
    display: inline;
  }
}

@media (max-width: 719px) {
  .tn-topbar-overflow {
    display: block;
  }

  .tn-topbar__actions-inline {
    display: none;
  }

}

.tn-topbar__zoom .tn-top-btn--zoom {
  min-width: 2.1rem;
  padding-inline: 0.45rem;
  font-size: 1rem;
  line-height: 1;
}

.tn-top-btn--zoom-level {
  min-width: 3rem;
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--tn-accent);
}

@media (min-width: 720px) {
  .tn-topbar-overflow {
    display: none;
  }
}

.tn-icon-btn {
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  border-radius: 0.45rem;
  background: transparent;
  color: var(--tn-text);
  font-size: 1.15rem;
  cursor: pointer;
}

.tn-icon-btn:hover {
  background: var(--tn-accent-dim);
}

.tn-icon-btn--menu {
  flex-shrink: 0;
  border: 1px solid var(--tn-border);
  background: color-mix(in srgb, var(--tn-bg) 35%, var(--tn-surface));
}

.tn-icon-btn--menu:hover {
  border-color: color-mix(in srgb, var(--tn-accent) 45%, var(--tn-border));
}

.tn-menu-icon {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.28rem;
  width: 1.15rem;
  height: 0.85rem;
}

.tn-menu-icon__bar {
  display: block;
  height: 2px;
  width: 100%;
  border-radius: 1px;
  background: currentColor;
  transition: transform 0.2s ease, opacity 0.15s ease;
}

.tn-icon-btn--menu[aria-expanded="true"] .tn-menu-icon__bar:nth-child(1) {
  transform: translateY(0.43rem) rotate(45deg);
}

.tn-icon-btn--menu[aria-expanded="true"] .tn-menu-icon__bar:nth-child(2) {
  opacity: 0;
}

.tn-icon-btn--menu[aria-expanded="true"] .tn-menu-icon__bar:nth-child(3) {
  transform: translateY(-0.43rem) rotate(-45deg);
}

.tn-msg {
  margin: 0;
  padding: 0.35rem 0.75rem;
  font-size: 0.85rem;
  flex-shrink: 0;
}

.tn-layout {
  display: flex;
  flex: 1;
  min-height: 0;
  position: relative;
}

.tn-sidebar {
  position: fixed;
  top: var(--tn-topbar-h);
  left: 0;
  bottom: 0;
  width: var(--tn-sidebar-w);
  background: var(--tn-surface);
  border-right: 1px solid var(--tn-border);
  z-index: 40;
  transform: translateX(-105%);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  padding-bottom: env(safe-area-inset-bottom);
}

.tn-sidebar.is-open {
  transform: translateX(0);
}

@media (min-width: 900px) {
  .tn-sidebar {
    position: relative;
    top: 0;
    transform: none;
    flex-shrink: 0;
  }

  #tn-menu,
  #tn-close-sidebar,
  .tn-sidebar-backdrop {
    display: none !important;
  }
}

.tn-sidebar__head {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
  padding: 0.6rem 0.75rem;
  border-bottom: 1px solid var(--tn-border);
}

.tn-sidebar .tn-sidebar-home.tool-back {
  flex-shrink: 0;
  align-self: flex-start;
  margin: 0;
}

.tn-sidebar__head-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.tn-sidebar__title {
  font-weight: 800;
  font-size: 0.95rem;
}

.tn-sidebar__scroll {
  overflow-y: auto;
  flex: 1;
  -webkit-overflow-scrolling: touch;
}

.tn-sidebar-backdrop {
  position: fixed;
  inset: var(--tn-topbar-h) 0 0 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 35;
}

@media (max-width: 899px) {
  .tn-sidebar-backdrop {
    pointer-events: none;
    background: rgba(0, 0, 0, 0.2);
  }

  .tn-tool {
    min-width: 2.75rem;
    min-height: 2.75rem;
  }

  .tn-swatch {
    width: 2.35rem;
    height: 2.35rem;
  }

  .tn-btn,
  .tn-chip {
    min-height: 2.75rem;
  }
}

.tn-acc {
  border-bottom: 1px solid var(--tn-border);
}

.tn-acc > summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.7rem 0.75rem;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.tn-acc > summary::-webkit-details-marker {
  display: none;
}

.tn-acc__title {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--tn-muted);
}

.tn-acc__chev {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  border: 1px solid var(--tn-border);
  position: relative;
  transition: background 0.15s ease;
}

.tn-acc__chev::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 42%;
  width: 0.35rem;
  height: 0.35rem;
  border-right: 2px solid var(--tn-muted);
  border-bottom: 2px solid var(--tn-muted);
  transform: translate(-50%, -50%) rotate(45deg);
  transition: transform 0.2s ease;
}

.tn-acc[open] > summary .tn-acc__chev::after {
  top: 55%;
  transform: translate(-50%, -50%) rotate(-135deg);
}

.tn-acc[open] > summary .tn-acc__title {
  color: var(--tn-accent);
}

.tn-acc__panel {
  padding: 0 0.75rem 0.75rem;
}

.tn-acc__panel > .tn-label:first-child,
.tn-acc__panel > .tn-hint:first-child,
.tn-acc__panel > .tn-anim-indicator:first-child {
  margin-top: 0;
}

.tn-anim-playback {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.tn-anim-playback .tn-btn {
  flex: 1 1 auto;
  min-width: calc(50% - 0.2rem);
  margin-top: 0;
}

.tn-anim-speed {
  font-size: 0.78rem;
}

.tn-label {
  display: block;
  font-size: 0.75rem;
  color: var(--tn-muted);
  margin-bottom: 0.2rem;
}

.tn-select {
  width: 100%;
  margin-bottom: 0.45rem;
  padding: 0.45rem 0.5rem;
  border-radius: 0.4rem;
  border: 1px solid var(--tn-border);
  background: var(--tn-bg);
  color: var(--tn-text);
  font-size: 0.85rem;
}

.tn-field-grid,
.tn-equip-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.tn-chip {
  padding: 0.35rem 0.55rem;
  border-radius: 2rem;
  border: 1px solid var(--tn-border);
  background: var(--tn-bg);
  color: var(--tn-text);
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
}

.tn-chip.is-active,
.tn-tool.is-active {
  border-color: var(--tn-accent);
  background: var(--tn-accent-dim);
  color: var(--tn-accent);
}

.tn-chip:active,
.tn-tool:active {
  transform: scale(0.96);
}

.tn-tools {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.35rem;
  margin-bottom: 0.5rem;
}

.tn-tools--place {
  margin-top: 0.1rem;
}

.tn-hint--tight {
  margin: 0 0 0.4rem;
}

.tn-tool {
  aspect-ratio: 1;
  border-radius: 0.5rem;
  border: 1px solid var(--tn-border);
  background: var(--tn-bg);
  font-size: 1.1rem;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
}

.tn-tool--svg {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem;
  color: var(--tn-text);
}

.tn-tool--svg .tn-tool__svg {
  width: 1.35rem;
  height: 1.35rem;
  display: block;
}

.tn-tool--svg.is-active {
  color: var(--tn-accent);
}

.tn-btn--labeled {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

.tn-btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  line-height: 0;
}

.tn-btn__text {
  line-height: 1.2;
}

.tn-range {
  width: 100%;
  margin-bottom: 0.5rem;
}

.tn-undo-row {
  display: flex;
  gap: 0.35rem;
}

.tn-undo-row .tn-btn {
  flex: 1;
}

.tn-colors {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.5rem;
}

.tn-lib-save {
  margin-top: 0.65rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--tn-border);
}

.tn-lib-save .tn-label {
  margin-bottom: 0.15rem;
}

.tn-lib-save-btn {
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  gap: 0.2rem;
  height: auto;
  padding: 0.55rem 0.65rem;
}

.tn-lib-save-btn__title {
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.25;
}

.tn-lib-save-btn__desc {
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--tn-muted);
  line-height: 1.35;
}

.tn-swatch {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  border: 2px solid var(--tn-border);
  background: var(--sw);
  cursor: pointer;
  transition: transform 0.12s, box-shadow 0.12s;
}

.tn-swatch.is-active {
  transform: scale(1.12);
  box-shadow: 0 0 0 2px var(--tn-accent);
}

.tn-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  width: 100%;
  margin-top: 0.35rem;
  padding: 0.5rem 0.65rem;
  border-radius: 0.45rem;
  border: 1px solid var(--tn-border);
  background: var(--tn-bg);
  color: var(--tn-text);
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
}

.tn-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.tn-btn--ghost {
  background: transparent;
}

.tn-btn--accent {
  border-color: var(--tn-accent);
  color: var(--tn-accent);
  background: var(--tn-accent-dim);
}

.tn-btn--danger {
  border-color: rgba(248, 81, 73, 0.5);
  color: #f85149;
}

.tn-btn--team-a {
  border-color: rgba(229, 57, 53, 0.5);
}

.tn-btn--team-b {
  border-color: rgba(30, 136, 229, 0.5);
}

.tn-team-btns {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.tn-hint {
  margin: 0.35rem 0 0;
  font-size: 0.72rem;
  color: var(--tn-muted);
  line-height: 1.35;
}

.tn-library {
  list-style: none;
  margin: 0 0 0.5rem;
  padding: 0;
  max-height: 8rem;
  overflow-y: auto;
}

.tn-lib-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.4rem 0.5rem;
  margin-bottom: 0.2rem;
  border: none;
  border-radius: 0.35rem;
  background: var(--tn-bg);
  color: var(--tn-text);
  font-size: 0.8rem;
  cursor: pointer;
}

.tn-lib-item:hover {
  background: var(--tn-accent-dim);
}

.tn-library__row {
  display: flex;
  align-items: stretch;
  gap: 0.25rem;
  margin-bottom: 0.25rem;
}

.tn-library__row .tn-lib-item {
  flex: 1;
  margin: 0;
}

.tn-lib-del {
  flex-shrink: 0;
  width: 2.1rem;
  border: 1px solid var(--tn-border);
  border-radius: 0.35rem;
  background: var(--tn-bg);
  color: #f85149;
  font-size: 1.1rem;
  font-weight: 700;
  cursor: pointer;
  line-height: 1;
}

.tn-lib-del:hover {
  background: rgba(248, 81, 73, 0.15);
}

.tn-library-empty {
  margin: 0 0 0.5rem;
  font-size: 0.78rem;
  color: var(--tn-muted);
  font-style: italic;
}

.tn-library-empty[hidden] {
  display: none;
}

.tn-anim-indicator {
  margin: 0 0 0.45rem;
  font-size: 0.88rem;
  font-weight: 700;
  text-align: center;
}

.tn-anim-nav {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 0.35rem;
}

.tn-anim-nav .tn-btn--icon {
  flex: 1;
  margin-top: 0;
}

.tn-btn--icon {
  padding: 0.45rem;
  font-size: 1.2rem;
  font-weight: 800;
}

.tn-stage {
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  position: relative;
  background: var(--tn-bg);
}

.tn-viewport {
  flex: 1;
  position: relative;
  overflow: hidden;
  touch-action: none;
  transform-origin: center center;
  transition: transform 0.05s linear;
}

.tn-canvas {
  display: block;
  width: 100%;
  height: 100%;
  touch-action: none;
  cursor: crosshair;
  -webkit-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.tn-viewport.tn-cursor-hand,
.tn-canvas.tn-cursor-hand {
  cursor: grab;
}

.tn-viewport.tn-cursor-grabbing,
.tn-canvas.tn-cursor-grabbing {
  cursor: grabbing;
}

.tn-viewport.tn-cursor-draw,
.tn-canvas.tn-cursor-draw {
  cursor: crosshair;
}

.tn-viewport.tn-cursor-erase,
.tn-canvas.tn-cursor-erase {
  cursor: cell;
}

.tn-toast {
  position: fixed;
  bottom: max(1rem, env(safe-area-inset-bottom));
  left: 50%;
  transform: translateX(-50%) translateY(1rem);
  padding: 0.55rem 1rem;
  border-radius: 2rem;
  background: var(--tn-surface);
  border: 1px solid var(--tn-border);
  color: var(--tn-text);
  font-size: 0.85rem;
  font-weight: 600;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  z-index: 50;
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
}

.tn-toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* --- Validation ASNS --- */
.page-outil--asns {
  max-width: min(48rem, 100%);
}

.page-outil--asns .asns-ref-card {
  padding: 0.85rem 1rem;
}

.page-outil--asns .asns-acc-classes {
  margin-bottom: 0.75rem;
}

.page-outil--asns .asns-classes-layout {
  padding: 0;
  gap: 1rem;
}

.page-outil--asns .asns-classes-layout .classes-select-hint {
  grid-column: 1 / -1;
}

.page-outil--asns .asns-ref-card h2 {
  margin: 0 0 0.25rem;
  font-size: 0.95rem;
}

.page-outil--asns .asns-ref-card .hint {
  margin-top: 0;
  margin-bottom: 0.65rem;
}

.page-outil--asns .asns-ref-link {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
  white-space: normal;
  line-height: 1.35;
}

.page-outil--asns .hint a {
  color: var(--accent-deep);
  font-weight: 600;
}

.dispense-nav--asns {
  grid-template-columns: repeat(2, 1fr);
  margin-bottom: 0.85rem;
}

@media (min-width: 520px) {
  .dispense-nav--asns {
    grid-template-columns: repeat(4, 1fr);
  }
}

.dispense-nav--asns .dispense-nav__btn {
  font-size: 0.78rem;
  padding: 0.55rem 0.35rem;
  line-height: 1.25;
  color: var(--text);
}

.dispense-nav--asns .dispense-nav__btn--active {
  color: #fff;
  font-weight: 700;
}

.dispense-nav--asns .dispense-nav__btn--active:hover {
  color: #fff;
}

.page-outil--asns .asns-liste {
  margin-top: 1rem;
}

.page-outil--asns .asns-liste .dispense-item {
  overflow: hidden;
}

.page-outil--asns .asns-liste .dispense-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.35rem;
  margin-top: 0.5rem;
  min-width: 0;
}

.page-outil--asns .asns-liste .dispense-actions .btn {
  min-width: 0;
  width: 100%;
  padding-inline: 0.35rem;
  font-size: 0.78rem;
  min-height: 38px;
}

.page-outil--asns .asns-liste .dispense-actions .btn--labeled {
  min-height: 38px;
  padding: 0.38rem 0.45rem;
  gap: 0.25rem;
}

.page-outil--asns .asns-liste .dispense-actions .btn--labeled .btn__icon {
  font-size: 1rem;
  flex-shrink: 0;
}

.page-outil--asns .asns-liste .dispense-actions .btn--labeled .btn__text {
  font-size: 0.72rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

@media (max-width: 420px) {
  .page-outil--asns .asns-liste .dispense-actions {
    grid-template-columns: 1fr 1fr;
  }

  .page-outil--asns .asns-liste .dispense-actions .btn:first-child {
    grid-column: 1 / -1;
  }
}

.page-outil--asns .asns-offline-hint {
  margin: 0 0 0.75rem;
  padding: 0.55rem 0.75rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-weight: 600;
}

.page-outil--asns .asns-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  margin-bottom: 1rem;
}

@media (min-width: 520px) {
  .page-outil--asns .asns-stat-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.page-outil--asns .asns-stat {
  text-align: center;
  padding: 0.85rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: #fff;
}

.page-outil--asns .asns-stat strong {
  display: block;
  font-size: 1.45rem;
  font-weight: 800;
  color: var(--accent-deep);
  line-height: 1.1;
}

.page-outil--asns .asns-stat span {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-top: 0.2rem;
}

.page-outil--asns .asns-dash-filters {
  margin-bottom: 0.75rem;
}

.page-outil--asns .asns-dash-filters .btn {
  flex: 1 1 auto;
}

.page-outil--asns .asns-import-liste {
  margin-top: 0.75rem;
}

.page-outil--asns .asns-import-liste textarea {
  font-family: inherit;
  width: 100%;
}

/* Popup validation ASNS (plein écran mobile, marges sur grands écrans) */
html.asns-modal-open,
body.asns-modal-open {
  overflow: hidden;
  overscroll-behavior: none;
}

.asns-dialog-validation {
  border: none;
  border-radius: 0;
  padding: 0;
  margin: 0;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  overflow: hidden;
  box-shadow: none;
}

.asns-dialog-validation[open] {
  display: flex;
  flex-direction: column;
  overscroll-behavior: contain;
}

@media (max-width: 639px) {
  .asns-dialog-validation[open] {
    height: 100dvh;
    max-height: 100dvh;
    width: 100%;
    max-width: 100%;
  }
}

.asns-dialog-validation::backdrop {
  background: rgba(15, 23, 42, 0.55);
}

.asns-dialog-validation .asns-val-dialog {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  max-height: 100dvh;
  min-height: 0;
  background: #f1f5f9;
}

.asns-dialog-validation[open] .asns-val-dialog {
  flex: 1 1 auto;
  min-height: 0;
}

@media (min-width: 640px) {
  .asns-dialog-validation {
    width: min(28rem, calc(100vw - 2.5rem));
    max-width: min(42rem, calc(100vw - 2.5rem));
    height: auto;
    max-height: min(92dvh, 52rem);
    margin: auto;
    border-radius: 1rem;
    box-shadow:
      0 24px 48px rgba(15, 23, 42, 0.2),
      0 0 0 1px rgba(148, 163, 184, 0.2);
  }

  .asns-dialog-validation .asns-val-dialog {
    height: auto;
    max-height: min(92dvh, 52rem);
  }
}

.asns-dialog-validation .asns-val-header {
  flex-shrink: 0;
  padding: 1rem 1rem 0.85rem;
  background: linear-gradient(145deg, #0d9488 0%, #0f766e 55%, #115e59 100%);
  color: #fff;
}

.asns-dialog-validation .asns-val-header__row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.65rem;
  margin-bottom: 0.65rem;
}

.asns-dialog-validation .asns-val-header__intro {
  flex: 1;
  min-width: 0;
}

.asns-dialog-validation .asns-val-header__tools {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex-shrink: 0;
}

.asns-dialog-validation .asns-val-header__close {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.22);
  color: #fff;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.15s ease,
    transform 0.1s ease;
}

.asns-dialog-validation .asns-val-header__close:hover {
  background: rgba(255, 255, 255, 0.35);
}

.asns-dialog-validation .asns-val-header__close:active {
  transform: scale(0.95);
}

.asns-dialog-validation .asns-val-header__kicker {
  margin: 0 0 0.15rem;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.85;
}

.asns-dialog-validation .asns-val-header__title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1.2;
  color: #fff;
}

.asns-dialog-validation .asns-val-header__badge {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  border: 2px solid rgba(255, 255, 255, 0.45);
}

.asns-dialog-validation .asns-val-header__pct {
  font-size: 0.85rem;
  font-weight: 800;
  color: #fff;
}

.asns-dialog-validation .asns-val-progress__text {
  margin: 0 0 0.4rem;
  font-size: 0.8rem;
  font-weight: 600;
  opacity: 0.9;
}

.asns-dialog-validation .asns-val-progress__track {
  height: 0.4rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.25);
  overflow: hidden;
}

.asns-dialog-validation .asns-val-progress__fill {
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: #fff;
  transition: width 0.25s ease;
}

.asns-dialog-validation .asns-val-toolbar {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.5rem;
  padding: 0.55rem 0.75rem;
  background: #fff;
  border-bottom: 1px solid rgba(148, 163, 184, 0.3);
}

.asns-dialog-validation .asns-val-toolbar__label {
  width: 100%;
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}

@media (min-width: 360px) {
  .asns-dialog-validation .asns-val-toolbar__label {
    width: auto;
    flex-shrink: 0;
  }
}

.asns-dialog-validation .asns-val-toolbar__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  flex: 1 1 auto;
}

.asns-dialog-validation .asns-val-chip {
  margin: 0;
  padding: 0.4rem 0.65rem;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.2;
  color: var(--accent-deep);
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.25);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition:
    background 0.15s ease,
    transform 0.1s ease,
    box-shadow 0.15s ease;
}

.asns-dialog-validation .asns-val-chip:active {
  transform: scale(0.97);
}

.asns-dialog-validation .asns-val-chip--accent {
  color: #fff;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  border-color: transparent;
}

.asns-dialog-validation .asns-val-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 0.6rem 0.65rem 0.75rem;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}

.asns-dialog-validation .asns-val-section-title {
  margin: 0.5rem 0 0.4rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent-deep);
  background: rgba(13, 148, 136, 0.1);
  border-radius: var(--radius-pill);
  display: inline-block;
}

.asns-dialog-validation .asns-val-section-title:first-child {
  margin-top: 0;
}

.asns-dialog-validation .asns-val-step {
  margin: 0 0 0.45rem;
  padding: 0.55rem 0.6rem 0.6rem;
  border-radius: 0.65rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-left-width: 4px;
  border-left-color: #cbd5e1;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.asns-dialog-validation .asns-val-step--valide {
  border-left-color: #059669;
}

.asns-dialog-validation .asns-val-step--non-valide {
  border-left-color: #dc2626;
}

.asns-dialog-validation .asns-val-step--a-revoir {
  border-left-color: #d97706;
}

.asns-dialog-validation .asns-val-step--absent {
  border-left-color: #64748b;
}

.asns-dialog-validation .asns-val-step__head {
  display: flex;
  gap: 0.45rem;
  align-items: flex-start;
  margin-bottom: 0.45rem;
}

.asns-dialog-validation .asns-val-step__num {
  flex-shrink: 0;
  width: 1.4rem;
  height: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 0.72rem;
  font-weight: 800;
  color: #fff;
  background: var(--accent);
}

.asns-dialog-validation .asns-val-step__label {
  margin: 0;
  flex: 1;
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1.32;
  color: var(--text);
}

.asns-dialog-validation .asns-stat-btns {
  display: flex;
  gap: 0.25rem;
  padding: 0.2rem;
  border-radius: 0.55rem;
  background: #f1f5f9;
}

.asns-dialog-validation .asns-stat-btn {
  flex: 1 1 0;
  min-width: 0;
  margin: 0;
  padding: 0.42rem 0.2rem;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
  border: none;
  border-radius: 0.4rem;
  cursor: pointer;
  opacity: 0.72;
  transition:
    background 0.15s ease,
    color 0.15s ease,
    opacity 0.15s ease,
    transform 0.1s ease,
    box-shadow 0.15s ease;
}

.asns-dialog-validation .asns-stat-btn--selected {
  opacity: 1;
  transform: scale(1.02);
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.12);
}

.asns-dialog-validation .asns-stat-btn--valide {
  color: #047857;
  background: transparent;
}

.asns-dialog-validation .asns-stat-btn--valide.asns-stat-btn--selected {
  color: #fff;
  background: #059669;
}

.asns-dialog-validation .asns-stat-btn--non-valide {
  color: #b91c1c;
  background: transparent;
}

.asns-dialog-validation .asns-stat-btn--non-valide.asns-stat-btn--selected {
  color: #fff;
  background: #dc2626;
}

.asns-dialog-validation .asns-stat-btn--a-revoir {
  color: #b45309;
  background: transparent;
}

.asns-dialog-validation .asns-stat-btn--a-revoir.asns-stat-btn--selected {
  color: #fff;
  background: #d97706;
}

.asns-dialog-validation .asns-stat-btn--absent {
  color: #475569;
  background: transparent;
}

.asns-dialog-validation .asns-stat-btn--absent.asns-stat-btn--selected {
  color: #fff;
  background: #64748b;
}

.asns-dialog-validation .asns-val-footer {
  flex-shrink: 0;
  padding: 0.65rem 0.75rem 0.85rem;
  border-top: 1px solid rgba(148, 163, 184, 0.35);
  background: #fff;
}

.asns-dialog-validation .asns-val-footer__remarques {
  margin-bottom: 0.55rem;
}

.asns-dialog-validation .asns-val-footer__remarques .field-label {
  font-size: 0.78rem;
  margin-bottom: 0.25rem;
}

.asns-dialog-validation .asns-val-footer__remarques textarea {
  width: 100%;
  font-family: inherit;
  font-size: 0.88rem;
  padding: 0.45rem 0.55rem;
  border-radius: 0.5rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  resize: vertical;
  min-height: 2.5rem;
}

.asns-dialog-validation .asns-val-footer__actions {
  display: flex;
}

.asns-dialog-validation .asns-val-footer__actions .btn {
  flex: 1 1 auto;
  width: 100%;
  padding: 0.6rem 0.85rem;
  font-size: 0.95rem;
  font-weight: 800;
}

.page-outil--asns #asns-signature-canvas {
  width: 100%;
  max-width: 400px;
  height: 120px;
  border: 1px dashed var(--border);
  border-radius: var(--radius-sm);
  touch-action: none;
  display: block;
  background: #fff;
}

.asns-dialog-eleve form {
  padding: 1.25rem;
}

.asns-dialog-eleve__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.asns-dialog-eleve__header .classes-dialog-title {
  margin: 0;
  flex: 1;
  padding-right: 0.25rem;
}

.asns-dialog-eleve__close {
  flex-shrink: 0;
  width: 2.1rem;
  height: 2.1rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(148, 163, 184, 0.3);
  color: var(--text);
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.15s ease,
    transform 0.1s ease;
}

.asns-dialog-eleve__close:hover {
  background: rgba(148, 163, 184, 0.45);
}

.asns-dialog-eleve__close:active {
  transform: scale(0.95);
}

.page-outil--asns .asns-historique {
  margin: 0.75rem 0;
  font-size: 0.88rem;
}

.page-outil--asns .asns-historique h3 {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
}

.page-outil--asns .asns-import-global {
  width: 100%;
  margin-top: 0.5rem;
  justify-content: flex-start;
}

.page-outil--asns #asns-parcours-steps .dispense-item {
  margin-bottom: 0.5rem;
}

.page-outil--asns #asns-attest-list .classes-eleve-item {
  margin-bottom: 0.5rem;
}

.page-outil--asns .asns-parcours-card .hint {
  margin-bottom: 0.65rem;
}

.page-outil--asns .asns-parcours-notice {
  margin: 0 0 0.85rem;
  padding: 0.55rem 0.7rem;
  font-size: 0.84rem;
  line-height: 1.4;
  color: var(--accent-deep);
  text-align: center;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  border: 1px solid rgba(13, 148, 136, 0.2);
}

.page-outil--asns .asns-parcours-ref {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.page-outil--asns .asns-parcours-ref--conn {
  margin-top: 0;
}

.page-outil--asns .asns-parcours-ref-title {
  margin: 1rem 0 0.45rem;
  padding-top: 0.75rem;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent-deep);
  border-top: 1px solid rgba(148, 163, 184, 0.35);
}

.page-outil--asns .asns-parcours-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.45rem 0.55rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: #fff;
}

.page-outil--asns .asns-parcours-item--conn {
  background: #f8fafc;
}

.page-outil--asns .asns-parcours-item__num {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--accent-deep);
  background: var(--accent-soft);
}

.page-outil--asns .asns-parcours-item--conn .asns-parcours-item__num {
  color: #475569;
  background: #e2e8f0;
}

.page-outil--asns .asns-parcours-item__text {
  margin: 0;
  flex: 1;
  font-size: 0.86rem;
  font-weight: 500;
  line-height: 1.35;
  color: var(--text);
}

.page-outil--asns .asns-attest-actions {
  margin-bottom: 1.25rem;
}

.page-outil--asns .asns-progress {
  height: 6px;
  margin-top: 0.5rem;
  margin-bottom: 0.65rem;
  border-radius: var(--radius-pill);
  background: rgba(148, 163, 184, 0.35);
  overflow: hidden;
}

.page-outil--asns .asns-progress__fill {
  display: block;
  height: 100%;
  border-radius: var(--radius-pill);
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  transition: width 0.2s ease;
}

/* --- Ressources EPS --- */
.page-outil--ressources-eps {
  max-width: min(54rem, 100%);
  padding-bottom: 5rem;
}

.page-outil--ressources-eps .page-outil__header {
  margin-bottom: 0.5rem;
}

.page-outil--ressources-eps .reps-hero {
  margin: 0 -0.25rem 1.25rem;
  border-radius: calc(var(--radius) + 4px);
  background: linear-gradient(135deg, #0f7668 0%, #0d9488 38%, #0891b2 72%, #6366f1 100%);
  color: #fff;
  box-shadow: var(--shadow-hover);
  overflow: hidden;
  position: relative;
}

.page-outil--ressources-eps .reps-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 90% 10%, rgba(255, 255, 255, 0.22), transparent 45%),
    radial-gradient(circle at 0% 100%, rgba(255, 255, 255, 0.12), transparent 40%);
  pointer-events: none;
}

.page-outil--ressources-eps .reps-hero__inner {
  position: relative;
  z-index: 1;
  padding: 1.35rem 1.25rem 1.5rem;
}

.page-outil--ressources-eps .reps-hero h1 {
  margin: 0 0 0.45rem;
  font-size: clamp(1.55rem, 5vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.15;
}

.page-outil--ressources-eps .reps-hero__lead {
  margin: 0 0 1.1rem;
  font-size: 0.95rem;
  line-height: 1.45;
  opacity: 0.92;
  max-width: 28rem;
}

.page-outil--ressources-eps .reps-search {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem 0.85rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.18);
}

.page-outil--ressources-eps .reps-search__icon {
  font-size: 1.1rem;
  line-height: 1;
  opacity: 0.55;
}

.page-outil--ressources-eps .reps-search__input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  font-size: 1rem;
  color: var(--text);
  outline: none;
}

.page-outil--ressources-eps .reps-offline {
  margin: 0 0 1rem;
  padding: 0.6rem 0.85rem;
  border-radius: var(--radius-sm);
  background: rgba(245, 158, 11, 0.14);
  border: 1px solid rgba(245, 158, 11, 0.35);
  font-size: 0.86rem;
  color: #92400e;
}

.page-outil--ressources-eps .reps-block-title {
  margin: 0 0 0.75rem;
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}

.page-outil--ressources-eps .reps-favoris {
  margin-bottom: 1.35rem;
}

.page-outil--ressources-eps .reps-group {
  margin-bottom: 1.5rem;
  padding: 1rem 1rem 1.1rem;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow);
  border-left: 4px solid var(--reps-group-accent, var(--accent));
}

.page-outil--ressources-eps .reps-group__head {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.9rem;
}

.page-outil--ressources-eps .reps-group__icon {
  font-size: 1.65rem;
  line-height: 1;
  flex-shrink: 0;
}

.page-outil--ressources-eps .reps-group__titles h2 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}

.page-outil--ressources-eps .reps-group__titles p {
  margin: 0.2rem 0 0;
  font-size: 0.84rem;
  color: var(--text-muted);
  line-height: 1.35;
}

.page-outil--ressources-eps .reps-tiles {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.page-outil--ressources-eps .reps-tiles--fav {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.55rem;
}

@media (min-width: 520px) {
  .page-outil--ressources-eps .reps-tiles--fav {
    grid-template-columns: repeat(2, 1fr);
  }
}

.page-outil--ressources-eps .reps-tile {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 0.65rem;
  padding: 0.8rem 0.85rem;
  border-radius: var(--radius-sm);
  background: #fff;
  border: 1px solid var(--border);
  cursor: pointer;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
  -webkit-tap-highlight-color: transparent;
}

.page-outil--ressources-eps .reps-tile:hover,
.page-outil--ressources-eps .reps-tile:focus-visible {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--reps-accent, var(--accent)) 45%, transparent);
  box-shadow: 0 10px 24px -8px color-mix(in srgb, var(--reps-accent, var(--accent)) 35%, transparent);
  outline: none;
}

.page-outil--ressources-eps .reps-tile--compact {
  padding: 0.65rem 0.75rem;
}

.page-outil--ressources-eps .reps-tile__avatar {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95rem;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(145deg, var(--reps-accent, var(--accent)), color-mix(in srgb, var(--reps-accent, var(--accent)) 70%, #0f172a));
  flex-shrink: 0;
}

.page-outil--ressources-eps .reps-tile__body {
  min-width: 0;
}

.page-outil--ressources-eps .reps-tile__title {
  margin: 0;
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--text);
}

.page-outil--ressources-eps .reps-tile--compact .reps-tile__title {
  font-size: 0.88rem;
}

.page-outil--ressources-eps .reps-tile__note {
  margin: 0.15rem 0 0;
  font-size: 0.78rem;
  color: var(--text-muted);
  line-height: 1.3;
}

.page-outil--ressources-eps .reps-tile__meta {
  margin: 0.2rem 0 0;
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--text-muted);
}

.page-outil--ressources-eps .reps-tile__fav {
  width: 2.1rem;
  height: 2.1rem;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(148, 163, 184, 0.15);
  font-size: 1.1rem;
  line-height: 1;
  color: #94a3b8;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.page-outil--ressources-eps .reps-tile__fav:hover {
  transform: scale(1.08);
}

.page-outil--ressources-eps .reps-tile__fav--on {
  background: rgba(251, 191, 36, 0.25);
  color: #d97706;
}

.page-outil--ressources-eps .reps-tile__arrow {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--reps-accent, var(--accent));
  opacity: 0.7;
}

.page-outil--ressources-eps .reps-tile__delete {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: var(--danger-bg);
  color: var(--danger);
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.15s ease;
}

.page-outil--ressources-eps .reps-tile {
  position: relative;
}

.page-outil--ressources-eps .reps-tile:hover .reps-tile__delete,
.page-outil--ressources-eps .reps-tile:focus-within .reps-tile__delete {
  opacity: 1;
}

.page-outil--ressources-eps .reps-empty {
  text-align: center;
  padding: 2rem 1rem;
  color: var(--text-muted);
  font-size: 0.95rem;
}

.page-outil--ressources-eps .reps-fab {
  position: fixed;
  right: max(1rem, env(safe-area-inset-right));
  bottom: max(1.25rem, env(safe-area-inset-bottom));
  width: 3.35rem;
  height: 3.35rem;
  border: none;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--accent), var(--accent-2));
  color: #fff;
  font-size: 1.65rem;
  font-weight: 300;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 28px rgba(13, 148, 136, 0.45);
  z-index: 20;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.page-outil--ressources-eps .reps-fab:hover {
  transform: scale(1.06);
  box-shadow: 0 14px 36px rgba(13, 148, 136, 0.5);
}

.page-outil--ressources-eps .reps-dialog {
  max-width: min(24rem, calc(100vw - 2rem));
  border: none;
  border-radius: var(--radius);
  padding: 0;
  box-shadow: var(--shadow-hover);
}

.page-outil--ressources-eps .reps-dialog form {
  padding: 1.25rem 1.25rem 1.1rem;
}

.page-outil--ressources-eps .reps-dialog h2 {
  margin: 0 0 0.35rem;
  font-size: 1.15rem;
}

.page-outil--ressources-eps .reps-dialog__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 1rem;
}

.page-outil--defi-atp .defi-hof-list {
  margin: 0;
  padding-left: 1.2rem;
}

.page-outil--defi-atp .defi-hof-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 0.65rem;
}

.page-outil--defi-atp .defi-hof-card {
  background: linear-gradient(145deg, #0f172a, #1e293b);
  border: 1px solid #334155;
  border-radius: 0.9rem;
  padding: 0.75rem 0.8rem;
  color: #f8fafc;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.25);
}

.page-outil--defi-atp .defi-hof-card__top {
  font-size: 0.82rem;
  color: #cbd5e1;
}

.page-outil--defi-atp .defi-hof-card__name {
  margin-top: 0.28rem;
  font-size: 1.05rem;
  font-weight: 700;
}

.page-outil--defi-atp .defi-hof-card__value {
  margin-top: 0.2rem;
  font-size: 0.95rem;
  color: #facc15;
  font-weight: 700;
}

.page-outil--defi-atp .defi-params-panel {
  background: linear-gradient(180deg, #fbfdff 0%, #f8fbff 100%);
  border-radius: 0.8rem;
  border: 1px solid #e2e8f0;
  padding: 0.75rem;
}

.page-outil--defi-atp .defi-params-panel h3 {
  margin: 1rem 0 0.4rem;
  font-size: 1rem;
  color: #0f172a;
  background: #eef2ff;
  border: 1px solid #dbe4ff;
  border-radius: 0.65rem;
  padding: 0.45rem 0.6rem;
  font-weight: 800;
}

.page-outil--defi-atp #defi-formula-main-row {
  align-items: flex-start;
  gap: 0.9rem;
}

.page-outil--defi-atp #defi-formula-main-row .field-group {
  min-width: 220px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.page-outil--defi-atp #defi-formule-help {
  margin-top: 0.35rem;
  margin-bottom: 0.7rem;
  padding: 0.45rem 0.6rem;
  border-radius: 0.55rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}

.page-outil--defi-atp #defi-formula-points-row,
.page-outil--defi-atp #defi-bonus-row,
.page-outil--defi-atp #defi-bonus-row-def {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  padding: 0.55rem;
  margin-top: 0.35rem;
}

.page-outil--defi-atp .defi-params-panel > .field-row:not(#defi-formula-main-row):not(#defi-formula-points-row):not(#defi-bonus-row):not(#defi-bonus-row-def) {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  padding: 0.55rem;
}

.page-outil--defi-atp #defi-player-history,
.page-outil--defi-atp #defi-player-badges,
.page-outil--defi-atp #defi-player-badges-earned,
.page-outil--defi-atp #defi-player-badges-locked {
  margin: 0.5rem 0;
  padding-left: 0;
  max-height: 14rem;
  overflow: auto;
  list-style: none;
}

.page-outil--defi-atp #defi-open-add {
  margin-bottom: 0.75rem;
}

.page-outil--defi-atp #defi-add-dialog .btn {
  min-height: 44px;
}

.page-outil--defi-atp .defi-badge {
  display: block;
  border-radius: 0.7rem;
  padding: 0.5rem 0.6rem;
  margin: 0.2rem 0;
  font-size: 0.9rem;
  border: 1px solid #d9e1ef;
  background: #f7f9fd;
}

.page-outil--defi-atp .defi-badge--locked {
  color: #9ca3af;
  border-color: #e5e7eb;
  background: #f8fafc;
  opacity: 1;
  filter: grayscale(0.2);
}

.page-outil--defi-atp .defi-badge--earned {
  color: #0f172a;
  border-color: #cbd5e1;
  background: #ffffff;
  font-weight: 700;
}

.page-outil--defi-atp .badge--orange { background: #fff7ed; border-color: #fed7aa; }
.page-outil--defi-atp .badge--purple { background: #faf5ff; border-color: #e9d5ff; }
.page-outil--defi-atp .badge--blue { background: #eff6ff; border-color: #bfdbfe; }
.page-outil--defi-atp .badge--yellow { background: #fefce8; border-color: #fde68a; }
.page-outil--defi-atp .badge--green { background: #f0fdf4; border-color: #bbf7d0; }
.page-outil--defi-atp .badge--teal { background: #f0fdfa; border-color: #99f6e4; }
.page-outil--defi-atp .badge--red { background: #fef2f2; border-color: #fecaca; }
.page-outil--defi-atp .badge--gray { background: #f8fafc; border-color: #e2e8f0; }

.page-outil--defi-atp .defi-history-card {
  list-style: none;
  background: linear-gradient(145deg, #0b1220, #0f172a);
  border: 1px solid #334155;
  border-left: 4px solid #22d3ee;
  border-radius: 0.8rem;
  padding: 0.55rem 0.65rem;
  margin: 0 0 0.5rem;
  line-height: 1.35;
  color: #e2e8f0;
}

.page-outil--defi-atp .defi-match-history {
  margin: 0;
  padding: 0;
}

.page-outil--defi-atp .defi-history-card__line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
}

.page-outil--defi-atp .defi-history-card__line--meta {
  opacity: 0.95;
}

.page-outil--defi-atp .defi-history-card__line--duel {
  align-items: center;
  margin-top: 0.25rem;
}

.page-outil--defi-atp .defi-history-vs {
  font-size: 0.75rem;
  font-weight: 900;
  color: #facc15;
  letter-spacing: 0.06em;
}

.page-outil--defi-atp .defi-history-chip {
  display: inline-block;
  padding: 0.2rem 0.42rem;
  border-radius: 999px;
  background: rgba(30, 41, 59, 0.85);
  border: 1px solid #475569;
  font-size: 0.78rem;
}

.page-outil--defi-atp .defi-history-chip--win {
  background: rgba(34, 197, 94, 0.22);
  border-color: rgba(134, 239, 172, 0.55);
}

.page-outil--defi-atp .defi-history-name {
  font-weight: 800;
  font-size: 0.95rem;
}

.page-outil--defi-atp .defi-history-name--winner {
  color: #86efac;
}

.page-outil--defi-atp .defi-history-name--loser {
  color: #fca5a5;
}

.page-outil--defi-atp .defi-history-score {
  padding: 0.14rem 0.46rem;
  border-radius: 999px;
  font-weight: 900;
  background: rgba(15, 23, 42, 0.82);
  border: 1px solid #475569;
  color: #f8fafc;
}

.page-outil--defi-atp .defi-history-meta {
  margin-left: auto;
  font-size: 0.74rem;
  color: #94a3b8;
}

.page-outil--defi-atp .defi-history-card--player {
  border-left-color: #a78bfa;
  background: linear-gradient(145deg, #111827, #0f172a 60%);
  box-shadow: inset 0 1px 0 rgba(148, 163, 184, 0.12);
}

.page-outil--defi-atp .defi-history-card__actions {
  margin-top: 0.45rem;
  display: flex;
  gap: 0.45rem;
  justify-content: flex-end;
}

.page-outil--defi-atp .champ-table tbody tr:nth-child(even) {
  background: rgba(15, 23, 42, 0.03);
}

.page-outil--defi-atp .champ-table tbody tr:nth-child(odd) {
  background: rgba(15, 23, 42, 0.01);
}

.page-outil--defi-atp .defi-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 0.45rem;
  margin: 0.45rem 0 0.65rem;
}

.page-outil--defi-atp .defi-kpi-card {
  border: 1px solid #334155;
  background: linear-gradient(145deg, #111827, #1f2937);
  border-radius: 0.75rem;
  padding: 0.5rem 0.55rem;
}

.page-outil--defi-atp .defi-kpi-card--sub {
  border-color: #dbe4f4;
  background: #f8fafc;
}

.page-outil--defi-atp .defi-kpi-card__label {
  font-size: 0.78rem;
  color: #cbd5e1;
}

.page-outil--defi-atp .defi-kpi-card__value {
  font-size: 1rem;
  font-weight: 800;
  color: #f8fafc;
  margin-top: 0.15rem;
}

#defi-popup .defi-victory {
  border-radius: 0.9rem;
  padding: 0.95rem;
  background:
    radial-gradient(circle at 15% 10%, rgba(56, 189, 248, 0.25), transparent 45%),
    radial-gradient(circle at 85% 0%, rgba(250, 204, 21, 0.28), transparent 40%),
    linear-gradient(145deg, #0f172a, #111827 55%, #1f2937);
  color: #f8fafc;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.45);
  border: 1px solid rgba(148, 163, 184, 0.35);
}

#defi-popup .defi-victory__duel {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 0.7rem;
}

#defi-popup .defi-victory__player {
  position: relative;
  border-radius: 0.75rem;
  padding: 0.68rem 0.7rem;
  backdrop-filter: blur(2px);
  overflow: hidden;
}

#defi-popup .defi-victory__player--winner {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.35), rgba(22, 163, 74, 0.2));
  border: 1px solid rgba(187, 247, 208, 0.75);
  box-shadow: 0 0 0 1px rgba(74, 222, 128, 0.2), 0 8px 24px rgba(22, 163, 74, 0.2);
}

#defi-popup .defi-victory__player--loser {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.28), rgba(127, 29, 29, 0.15));
  border: 1px solid rgba(252, 165, 165, 0.58);
}

#defi-popup .defi-victory__label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.9;
}

#defi-popup .defi-victory__name {
  font-size: 1.42rem;
  line-height: 1.15;
  font-weight: 900;
  margin-top: 0.15rem;
  color: #ffffff;
}

#defi-popup .defi-victory__player--winner .defi-victory__name {
  color: #dcfce7;
  text-shadow: 0 0 18px rgba(134, 239, 172, 0.45);
}

#defi-popup .defi-victory__stats {
  font-size: 0.92rem;
  margin-top: 0.2rem;
  font-weight: 700;
}

#defi-popup .defi-victory__rank {
  margin-top: 0.18rem;
  font-size: 1.02rem;
  font-weight: 900;
  color: #f8fafc;
  text-shadow: 0 0 14px rgba(148, 163, 184, 0.35);
}

#defi-popup .defi-victory__rank-chip {
  position: absolute;
  top: 0.45rem;
  right: 0.45rem;
  z-index: 2;
  font-size: 0.75rem;
  font-weight: 900;
  padding: 0.16rem 0.42rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.75);
  border: 1px solid rgba(148, 163, 184, 0.45);
}

#defi-popup .defi-victory__rank-big {
  position: absolute;
  right: 0.35rem;
  bottom: -0.25rem;
  font-size: 3.1rem;
  line-height: 1;
  font-weight: 900;
  opacity: 0.12;
  pointer-events: none;
}

#defi-popup .defi-victory__vs {
  font-weight: 900;
  color: #facc15;
  font-size: 1.2rem;
  text-shadow: 0 0 16px rgba(250, 204, 21, 0.35);
}

#defi-popup .defi-victory__summary {
  margin: 0.75rem 0 0.45rem;
  font-size: 0.95rem;
  padding: 0.5rem 0.6rem;
  border-radius: 0.6rem;
  background: rgba(30, 41, 59, 0.65);
  border: 1px solid rgba(148, 163, 184, 0.35);
}

#defi-popup .defi-victory__badges-title {
  margin: 0.25rem 0 0.35rem;
  font-size: 0.95rem;
}

#defi-popup .defi-victory__badges {
  margin: 0;
  padding-left: 0;
  list-style: none;
}

#defi-popup .defi-victory__badge {
  margin: 0.22rem 0;
  font-size: 0.9rem;
  padding: 0.45rem 0.55rem;
  border-radius: 0.55rem;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(148, 163, 184, 0.35);
}

#defi-popup .defi-victory__badge--none {
  opacity: 0.85;
  font-style: italic;
}

#defi-add-dialog,
#defi-player-dialog,
#defi-popup {
  position: fixed;
  inset: 0;
  margin: auto;
  border: 1px solid #334155;
  background: #0f172a;
  color: #e2e8f0;
  border-radius: 1rem;
  box-shadow: 0 20px 44px rgba(2, 6, 23, 0.55);
  padding: 0;
}

#defi-add-dialog .session-dialog__form,
#defi-player-dialog .session-dialog__form,
#defi-popup .session-dialog__form {
  position: relative;
  padding: 0.95rem;
  background: linear-gradient(165deg, #0f172a, #111827 65%, #1f2937);
  border-radius: 1rem;
}

.defi-dialog-close {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  z-index: 10;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid #475569;
  background: rgba(15, 23, 42, 0.65);
  color: #e2e8f0;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  margin: 0;
  line-height: 1;
}

.defi-dialog-close:hover {
  background: rgba(30, 41, 59, 0.9);
}

.defi-dialog-close:focus-visible {
  outline: 2px solid #22d3ee;
  outline-offset: 1px;
}

#defi-add-dialog .session-dialog__title,
#defi-player-dialog .session-dialog__title,
#defi-popup .session-dialog__title {
  color: #e2e8f0;
}

#defi-add-dialog .hint,
#defi-player-dialog .hint,
#defi-popup .hint,
#defi-player-dialog p,
#defi-player-dialog h3 {
  color: #cbd5e1;
}

#defi-add-dialog label.field-label,
#defi-player-dialog label.field-label {
  color: #e2e8f0;
}

#defi-add-dialog select,
#defi-add-dialog input,
#defi-player-dialog select,
#defi-player-dialog input {
  background: #0b1220;
  color: #e2e8f0;
  border-color: #334155;
}

#defi-add-dialog .session-dialog__footer,
#defi-player-dialog .session-dialog__footer {
  margin-top: 0.7rem;
}

#defi-player-dialog {
  width: min(920px, calc(100vw - 1.2rem));
  max-height: calc(100vh - 1.2rem);
  overflow: hidden;
}

@media (max-width: 720px) {
  #defi-player-dialog,
  #defi-popup,
  #defi-add-dialog {
    width: calc(100vw - 0.8rem);
    max-height: calc(100vh - 0.8rem);
  }

  #defi-popup .defi-victory__duel {
    grid-template-columns: 1fr;
    gap: 0.45rem;
  }

  #defi-popup .defi-victory__vs {
    text-align: center;
  }

  .page-outil--defi-atp .defi-history-meta {
    margin-left: 0;
    width: 100%;
  }
}

#defi-player-dialog .session-dialog__form {
  max-height: calc(100vh - 1.8rem);
  overflow: auto;
  padding-top: 1.1rem;
}

.defi-player-hero {
  border: 1px solid #334155;
  background:
    radial-gradient(circle at 10% 0%, rgba(56, 189, 248, 0.18), transparent 45%),
    linear-gradient(145deg, rgba(15, 23, 42, 0.9), rgba(17, 24, 39, 0.9));
  border-radius: 0.9rem;
  padding: 0.85rem;
  margin-bottom: 0.75rem;
}

.defi-player-hero #defi-player-title {
  margin-right: 2rem;
  margin-top: 0;
  margin-bottom: 0.3rem;
  font-size: 1.5rem;
}

.defi-player-hero #defi-player-stats {
  margin: 0 0 0.55rem;
  color: #cbd5e1;
  font-weight: 600;
}

.defi-player-hero .field-row {
  gap: 0.55rem;
}

.defi-player-hero .btn {
  border-radius: 999px;
  padding-inline: 0.95rem;
}

.defi-player-hero .btn--ghost {
  background: rgba(15, 23, 42, 0.7);
  color: #e2e8f0;
  border-color: #475569;
}

.defi-player-hero .btn--ghost:hover {
  background: rgba(30, 41, 59, 0.9);
}

.defi-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 0.55rem;
  margin: 0.35rem 0 0.75rem;
}

.defi-kpi-card {
  border: 1px solid #334155;
  background: linear-gradient(145deg, #111827, #1f2937);
  border-radius: 0.85rem;
  padding: 0.6rem 0.65rem;
  box-shadow: inset 0 1px 0 rgba(148, 163, 184, 0.12);
}

.defi-kpi-card--sub {
  background: linear-gradient(145deg, #0f172a, #1e293b);
  border-color: #475569;
}

.defi-kpi-card__label {
  font-size: 0.78rem;
  color: #cbd5e1;
}

.defi-kpi-card__value {
  font-size: 1.08rem;
  font-weight: 800;
  color: #f8fafc;
  margin-top: 0.2rem;
}

#defi-player-dialog h3 {
  margin: 0.8rem 0 0.35rem;
  font-size: 1.03rem;
}

#defi-player-dialog .card--accordion {
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid #334155;
}

#defi-player-dialog .card--accordion__summary {
  color: #e2e8f0;
}

#defi-player-dialog #defi-player-badges-earned,
#defi-player-dialog #defi-player-badges-locked,
#defi-player-dialog #defi-player-history {
  max-height: none;
}

#defi-player-dialog .defi-badge {
  margin-bottom: 0.35rem;
}
#defi-popup .defi-delta-chip {
  display: inline-block;
  margin-right: 0.22rem;
  margin-top: 0.2rem;
  padding: 0.18rem 0.45rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(15, 23, 42, 0.6);
}

#defi-popup .defi-delta-chip--up {
  color: #bbf7d0;
  border-color: rgba(134, 239, 172, 0.6);
  background: rgba(34, 197, 94, 0.2);
}

#defi-popup .defi-delta-chip--down {
  color: #fecaca;
  border-color: rgba(252, 165, 165, 0.6);
  background: rgba(239, 68, 68, 0.2);
}

#defi-popup .defi-victory__footer {
  margin-top: 0.65rem;
  justify-content: flex-end;
}

.page-outil--nouvelle-annee {
  max-width: min(54rem, 100%);
}

.page-outil--nouvelle-annee .card {
  border-radius: 1.1rem;
  border: 1px solid rgba(148, 163, 184, 0.28);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.page-outil--nouvelle-annee .card h2 {
  letter-spacing: 0.01em;
}

.annee-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
}

.annee-presets .btn {
  border-radius: 0.8rem;
  padding-inline: 0.95rem;
  min-height: 2.65rem;
  font-weight: 750;
}

.annee-rules-block {
  margin-top: 0.95rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 0.95rem;
  background: #fff;
  padding: 0.95rem 1rem;
}

.annee-rules-title {
  margin: 0 0 0.75rem;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-deep);
}

.annee-impact-block {
  margin-top: 0.9rem;
}

.annee-nested-accordion {
  margin-top: 0.9rem;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 0.95rem;
  overflow: hidden;
}

.annee-nested-accordion.card--accordion > summary {
  padding: 0.85rem 1rem;
}

.annee-nested-accordion .card--accordion__panel {
  padding: 0 1rem 1rem;
}

.annee-grid {
  display: grid;
  gap: 0.8rem;
}

.annee-rule-row {
  display: grid;
  grid-template-columns: minmax(170px, 220px) minmax(0, 1fr);
  gap: 0.95rem;
  align-items: center;
}

.annee-rule-label {
  font-weight: 750;
  color: #0f172a;
  letter-spacing: 0.005em;
}

.annee-rule-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 0.9rem;
  overflow: hidden;
  background: #f8fafc;
  justify-self: end;
  align-self: center;
  width: fit-content;
}

.annee-choice {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-right: 1px solid rgba(148, 163, 184, 0.45);
  padding: 0;
  font-size: 0.86rem;
  font-weight: 700;
  cursor: pointer;
  min-width: 88px;
  transition: background-color 0.22s ease, color 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
}

.annee-choice:last-child {
  border-right: none;
}

.annee-choice input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.annee-choice span {
  display: inline-block;
  padding: 0.44rem 0.72rem;
  line-height: 1;
}

.annee-choice:has(input:checked) {
  background: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 55%, var(--accent-2) 130%);
  color: #ffffff;
  box-shadow: inset 0 0 0 1px rgba(13, 148, 136, 0.6);
  transform: translateY(-1px);
}

@media (max-width: 760px) {
  .annee-rule-row {
    grid-template-columns: 1fr;
    gap: 0.45rem;
  }
  .annee-rule-actions {
    width: 100%;
    justify-self: stretch;
  }
  .annee-choice {
    flex: 1;
    min-width: 0;
  }
}

.annee-impact-card {
  margin: 0.6rem 0 0;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 0.9rem;
  background: #fff;
  overflow: hidden;
}

.annee-impact-card > summary {
  cursor: pointer;
  padding: 0.72rem 0.92rem;
  font-weight: 700;
}

.annee-impact-items {
  margin: 0;
  padding: 0 1.4rem 0.75rem;
}

.annee-impact-card.is-delete > summary {
  color: #991b1b;
}

.annee-impact-card.is-archive > summary {
  color: #1e3a8a;
}

.annee-impact-card.is-keep > summary {
  color: #166534;
}

.annee-archive-table-wrap {
  margin-top: 0.35rem;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 0.9rem;
  overflow: hidden;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.annee-archive-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.92rem;
}

.annee-archive-table th,
.annee-archive-table td {
  padding: 0.66rem 0.8rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.2);
}

.annee-archive-table thead th {
  text-align: left;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #0f7668;
  background: rgba(236, 253, 245, 0.9);
}

.annee-archive-table tbody tr:last-child td {
  border-bottom: none;
}

.annee-archive-row:hover td {
  background: rgba(15, 118, 104, 0.04);
}

.annee-archive-tool {
  font-weight: 700;
  color: #0f172a;
}

.annee-archive-number {
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: #0f172a;
}

@media (max-width: 760px) {
  .annee-archive-table {
    font-size: 0.86rem;
  }
  .annee-archive-table th,
  .annee-archive-table td {
    padding: 0.55rem 0.48rem;
  }
}

.annee-help-hide {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.85rem;
}

/* --- Contenu SEO accueil (index.html) --- */
.seo-content {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem max(1rem, env(safe-area-inset-left)) 1rem max(1rem, env(safe-area-inset-right));
}

.seo-nav {
  margin-bottom: 1.5rem;
}

.seo-nav__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.55rem;
  margin: 0;
  padding: 0.85rem 1rem;
  list-style: none;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(148, 163, 184, 0.28);
}

.seo-nav__list a {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-pill);
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-size: 0.84rem;
  font-weight: 700;
  text-decoration: none;
  line-height: 1.35;
}

.seo-nav__list a:hover {
  background: rgba(13, 148, 136, 0.18);
}

.seo-nav__list a:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.seo-section {
  margin-bottom: 2rem;
  padding: 1.35rem 1.25rem;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(148, 163, 184, 0.24);
  box-shadow: var(--shadow);
}

.seo-section h2 {
  margin: 0 0 0.85rem;
  font-size: clamp(1.15rem, 2.5vw, 1.45rem);
  line-height: 1.3;
  color: var(--text);
}

.seo-section p {
  margin: 0 0 0.85rem;
  color: var(--text);
  line-height: 1.65;
}

.seo-section p:last-child {
  margin-bottom: 0;
}

.seo-section a {
  color: var(--accent-deep);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.seo-section a:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.seo-list {
  margin: 0;
  padding-left: 1.25rem;
  color: var(--text);
}

.seo-list li {
  margin-bottom: 0.65rem;
  line-height: 1.6;
}

.seo-list li:last-child {
  margin-bottom: 0;
}

.seo-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
  gap: 0.85rem;
  margin-top: 0.5rem;
}

.seo-card {
  margin: 0;
  padding: 1rem 0.95rem;
  border-radius: var(--radius-sm);
  background: rgba(236, 253, 245, 0.45);
  border: 1px solid rgba(13, 148, 136, 0.18);
}

.seo-card__title {
  margin: 0 0 0.45rem;
  font-size: 0.98rem;
  line-height: 1.35;
  color: var(--accent-deep);
}

.seo-card p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--text-muted);
}

.seo-section--faq {
  margin-bottom: 1.25rem;
}

.seo-faq {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.seo-faq__item {
  margin: 0;
  padding: 0.95rem 1rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(148, 163, 184, 0.2);
}

.seo-faq__question {
  margin: 0 0 0.45rem;
  font-size: 1rem;
  line-height: 1.4;
  color: var(--text);
}

.seo-faq__answer {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.6;
  color: var(--text-muted);
}

@media (min-width: 900px) {
  .app--home .seo-content {
    max-width: min(1400px, 100%);
    padding-left: max(1.5rem, env(safe-area-inset-left));
    padding-right: max(1.5rem, env(safe-area-inset-right));
  }
}

@media (min-width: 1200px) {
  .app--home .seo-content {
    max-width: min(1600px, 100%);
    padding-left: max(2rem, env(safe-area-inset-left));
    padding-right: max(2rem, env(safe-area-inset-right));
  }
}

@media (max-width: 520px) {
  .seo-nav__list {
    padding: 0.75rem 0.85rem;
  }

  .seo-nav__list a {
    font-size: 0.8rem;
    padding: 0.32rem 0.62rem;
  }

  .seo-section {
    padding: 1.1rem 0.95rem;
  }
}

