/* Modern responsive stylesheet — Inter chargée depuis layout.html (preconnect + link) */

:root{
  --bg: #f8fafc;
  --bg-alt: #f1f5f9;
  --card: #ffffff;
  --muted: #64748b;
  --muted-light: #94a3b8;
  --text: #0f172a;
  --text-secondary: #334155;
  --primary: #3b82f6;
  --primary-hover: #2563eb;
  --primary-light: #dbeafe;
  --success: #10b981;
  --success-light: #d1fae5;
  --warning: #f59e0b;
  --warning-light: #fef3c7;
  --danger: #ef4444;
  --danger-light: #fee2e2;
  --info: #0ea5e9;
  --info-light: #e0f2fe;
  --border: #e2e8f0;
  --border-light: #f1f5f9;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --sidebar-width: 240px;
  --top-bar-height: 64px;
}

/* Dark theme variables — applied via [data-theme="dark"] or @media (prefers-color-scheme: dark) when [data-theme="auto"] */
[data-theme="dark"]{
  --bg: #0b1220;
  --bg-alt: #111a2e;
  --card: #131c33;
  --muted: #94a3b8;
  --muted-light: #64748b;
  --text: #e2e8f0;
  --text-secondary: #cbd5e1;
  --primary: #60a5fa;
  --primary-hover: #93c5fd;
  --primary-light: rgba(96, 165, 250, 0.18);
  --success: #34d399;
  --success-light: rgba(52, 211, 153, 0.18);
  --warning: #fbbf24;
  --warning-light: rgba(251, 191, 36, 0.16);
  --danger: #f87171;
  --danger-light: rgba(248, 113, 113, 0.18);
  --info: #38bdf8;
  --info-light: rgba(56, 189, 248, 0.18);
  --border: #1f2a44;
  --border-light: #17223b;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
  --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.5), 0 2px 4px -1px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 10px 15px -3px rgba(0, 0, 0, 0.55), 0 4px 6px -2px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.6), 0 10px 10px -5px rgba(0, 0, 0, 0.45);
  color-scheme: dark;
}
@media (prefers-color-scheme: dark){
  [data-theme="auto"]{
    --bg: #0b1220;
    --bg-alt: #111a2e;
    --card: #131c33;
    --muted: #94a3b8;
    --muted-light: #64748b;
    --text: #e2e8f0;
    --text-secondary: #cbd5e1;
    --primary: #60a5fa;
    --primary-hover: #93c5fd;
    --primary-light: rgba(96, 165, 250, 0.18);
    --success: #34d399;
    --success-light: rgba(52, 211, 153, 0.18);
    --warning: #fbbf24;
    --warning-light: rgba(251, 191, 36, 0.16);
    --danger: #f87171;
    --danger-light: rgba(248, 113, 113, 0.18);
    --info: #38bdf8;
    --info-light: rgba(56, 189, 248, 0.18);
    --border: #1f2a44;
    --border-light: #17223b;
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
    --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.5), 0 2px 4px -1px rgba(0, 0, 0, 0.4);
    --shadow-md: 0 10px 15px -3px rgba(0, 0, 0, 0.55), 0 4px 6px -2px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.6), 0 10px 10px -5px rgba(0, 0, 0, 0.45);
    color-scheme: dark;
  }
}
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  display:flex;
  flex-direction:column;
  min-height:100vh;
  min-height:100dvh;
  line-height:1.6;
  font-size:15px;
}

.container{width:100%;padding:0 16px}

/* Top bar */
.top-bar{
  flex-shrink:0;
  background:var(--card);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  position:sticky;
  top:0;
  z-index:100;
  backdrop-filter:blur(8px);
}
.top-bar .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:16px 16px;
}
.logo h2{
  margin:0;
  font-size:1.25rem;
  font-weight:700;
  color:var(--primary);
  letter-spacing:-0.02em;
}
.logo-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:inherit;
}
.logo-link:hover{
  color:inherit;
  opacity:0.92;
}
.logo-img{
  height:32px;
  width:auto;
  vertical-align:middle;
  display:block;
}
.logo-wordmark{
  font-size:1.2rem;
  font-weight:700;
  vertical-align:middle;
  letter-spacing:0.05em;
  color:var(--primary);
}
.search{flex:1;max-width:480px}
.search input{
  width:100%;
  padding:10px 16px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--bg);
  transition:var(--transition);
  font-size:14px;
}
.search input:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-light);
  background:var(--card);
}
.user-menu{
  display:flex;
  gap:16px;
  align-items:center;
}
.user-menu span{
  color:var(--text-secondary);
  font-weight:500;
  font-size:14px;
}
.user-menu a{
  color:var(--muted);
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  transition:var(--transition);
  padding:6px 12px;
  border-radius:var(--radius-sm);
}
.user-menu a:hover{
  color:var(--danger);
  background:var(--danger-light);
  text-decoration:none;
}

/* Layout */
.main-layout{
  display:flex;
  flex:1;
  min-height:0;
  gap:32px;
  padding:32px 0;
  align-items:stretch;
  width:100%;
  padding-left:16px;
  padding-right:16px;
}
.sidebar{
  flex:0 0 240px;
  position:sticky;
  top:88px;
}
.sidebar nav ul{
  padding:0;
  margin:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.sidebar nav a{
  display:flex;
  align-items:center;
  padding:10px 16px;
  border-radius:var(--radius-sm);
  color:var(--text-secondary);
  text-decoration:none;
  font-weight:500;
  font-size:14px;
  transition:var(--transition);
  position:relative;
}
.sidebar nav a:hover{
  background:var(--bg-alt);
  color:var(--text);
}
.sidebar nav a.active{
  background:var(--primary);
  color:#fff;
  box-shadow:var(--shadow);
}
.sidebar nav a.active:hover{
  background:var(--primary-hover);
}

/* product filters widget inside sidebar */
#product-filters {
  margin-top:8px;
}
#product-filters input[type=search] {
  width:100%;
}
#product-filters .category-btn {
  justify-content:space-between;
}
#product-filters .category-count {
  color:var(--muted);
  font-size:0.85em;
}
#product-filters button[disabled] {
  cursor:not-allowed;
}

.content{flex:1;min-width:0}
h1{
  color:var(--text);
  margin:0 0 24px 0;
  font-size:2rem;
  font-weight:700;
  letter-spacing:-0.02em;
}
h2{
  color:var(--text);
  margin:0 0 16px 0;
  font-size:1.5rem;
  font-weight:600;
  letter-spacing:-0.01em;
}
h3{
  color:var(--text);
  margin:0 0 8px 0;
  font-size:1.125rem;
  font-weight:600;
}

/* Cards & Lists */
.card{
  background:var(--card);
  border-radius:var(--radius);
  padding:24px;
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.card:hover{
  box-shadow:var(--shadow);
}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:20px;
}
.item{
  background:var(--card);
  padding:20px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  transition:var(--transition);
  box-shadow:var(--shadow-sm);
}
.item:hover{
  border-color:var(--primary);
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}

/* Badge component */
.badge{
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  border-radius:12px;
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.025em;
}
.badge-primary{background:var(--primary-light);color:var(--primary)}
.badge-success{background:var(--success-light);color:var(--success)}
.badge-warning{background:var(--warning-light);color:var(--warning)}

/* Statut produit : assigné + nom archer */
a.product-assign-badge{
  text-decoration:none;
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  max-width:min(260px,100%);
  white-space:normal;
  text-align:left;
  line-height:1.3;
  padding:6px 10px;
}
span.product-assign-badge--static{
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  max-width:min(260px,100%);
  white-space:normal;
  text-align:left;
  line-height:1.3;
  padding:6px 10px;
}
.product-assign-name{
  display:block;
  font-size:12px;
  font-weight:600;
  color:var(--text-secondary);
  max-width:100%;
  overflow-wrap:anywhere;
}
a.product-assign-badge:hover .product-assign-name{
  color:var(--primary-hover);
  text-decoration:underline;
}
.badge-danger{background:var(--danger-light);color:var(--danger)}
.badge-info{background:#e0f2fe;color:#0369a1}
.badge-secondary{background:var(--bg-alt);color:var(--text-secondary)}

/* Forms */
form{background:transparent;padding:0}
.form-card{
  background:var(--card);
  padding:24px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.form-row{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px}
.form-group{flex:1;min-width:200px;margin-bottom:20px}
label{
  display:block;
  font-size:14px;
  font-weight:600;
  color:var(--text);
  margin-bottom:8px;
}
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
input[type="datetime-local"],
input[type="time"],
input[type="month"],
select,
textarea{
  width:100%;
  padding:10px 14px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--card);
  font-family:inherit;
  font-size:14px;
  color:var(--text);
  transition:var(--transition);
}
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="month"]::-webkit-calendar-picker-indicator{
  cursor:pointer;
  opacity:0.65;
}
input[type="date"]::-webkit-calendar-picker-indicator:hover,
input[type="datetime-local"]::-webkit-calendar-picker-indicator:hover,
input[type="time"]::-webkit-calendar-picker-indicator:hover,
input[type="month"]::-webkit-calendar-picker-indicator:hover{
  opacity:1;
}
input:focus,
select:focus,
textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-light);
}
textarea{
  min-height:100px;
  resize:vertical;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 20px;
  border-radius:var(--radius-sm);
  border:none;
  cursor:pointer;
  font-weight:600;
  font-size:14px;
  font-family:inherit;
  transition:var(--transition);
  text-decoration:none;
  white-space:nowrap;
}
.btn-primary{
  background:var(--primary);
  color:#fff;
  box-shadow:var(--shadow-sm);
}
.btn-primary:hover{
  background:var(--primary-hover);
  box-shadow:var(--shadow);
  transform:translateY(-1px);
}
.btn-outline{
  background:transparent;
  border:1px solid var(--border);
  color:var(--text-secondary);
}
.btn-outline:hover{
  border-color:var(--primary);
  color:var(--primary);
  background:var(--primary-light);
}
.btn-secondary{
  background:var(--bg-alt);
  color:var(--text-secondary);
  border:1px solid var(--border);
}
.btn-secondary:hover{
  background:var(--bg);
  color:var(--text);
}
.btn-danger{
  background:var(--danger);
  color:#fff;
}
.btn-danger:hover{
  background:#dc2626;
  box-shadow:var(--shadow);
}
.btn-success{
  background:var(--success);
  color:#fff;
  box-shadow:var(--shadow-sm);
}
.btn-success:hover{
  background:#059669;
  box-shadow:var(--shadow);
  transform:translateY(-1px);
}
.btn-warning{
  background:var(--warning-light);
  color:#92400e;
  border:1px solid #fbbf24;
}
.btn-warning:hover{
  background:#fde68a;
  color:#78350f;
}
.btn-sm{
  padding:6px 10px;
  font-size:13px;
}
.btn-block{
  width:100%;
  justify-content:center;
}
.btn:active{
  transform:translateY(0);
}
.btn:disabled{
  opacity:0.5;
  cursor:not-allowed;
}

/* Table */
.table{
  width:100%;
  border-collapse:collapse;
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--border);
}
.table th,
.table td{
  padding:14px 16px;
  text-align:left;
  border-bottom:1px solid var(--border-light);
}
.table th{
  background:var(--bg-alt);
  font-weight:600;
  font-size:13px;
  color:var(--text);
  text-transform:uppercase;
  letter-spacing:0.05em;
}
.table tr:last-child td{
  border-bottom:none;
}
.table tbody tr{
  transition:var(--transition);
}
.table tbody tr:hover{
  background:var(--bg);
}

.table-responsive{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  width:100%;
}

.table-row-actions{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
  align-items:center;
}

/* Tri au clic sur les en-têtes (table-sort.js) */
.table-sortable thead th:not([data-sort="disable"]){
  cursor:pointer;
  user-select:none;
}
.table-sortable thead th:not([data-sort="disable"]):hover{
  background:var(--bg);
}
.table-sortable thead th.th-sort-asc,
.table-sortable thead th.th-sort-desc{
  background:var(--bg-alt);
}
.table-sortable thead th.th-sort-asc::after{
  content:" ▲";
  font-size:0.7em;
  opacity:0.7;
  font-weight:700;
}
.table-sortable thead th.th-sort-desc::after{
  content:" ▼";
  font-size:0.7em;
  opacity:0.7;
  font-weight:700;
}

/* Flash messages */
.flash{
  padding:14px 18px;
  border-radius:var(--radius-sm);
  margin-bottom:20px;
  font-weight:500;
  font-size:14px;
  border:1px solid;
  display:flex;
  align-items:center;
  gap:10px;
}
.flash.success{
  background:var(--success-light);
  color:#065f46;
  border-color:#a7f3d0;
}
.flash.error{
  background:var(--danger-light);
  color:#991b1b;
  border-color:#fecaca;
}

/* Utilities */
.muted{color:var(--muted);font-size:14px}
.small{font-size:13px}
.text-center{text-align:center}
.mt-1{margin-top:8px}
.mt-2{margin-top:16px}
.mt-3{margin-top:24px}
.mb-1{margin-bottom:8px}
.mb-2{margin-bottom:16px}
.mb-3{margin-bottom:24px}

/* Action group */
.action-group{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}

/* Header with actions */
.header-with-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  margin-bottom:24px;
}

/* Stats cards */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
  margin-bottom:32px;
}
.stat-card{
  background:var(--card);
  padding:20px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.stat-value{
  font-size:2rem;
  font-weight:700;
  color:var(--primary);
  line-height:1;
  margin-bottom:8px;
}
.stat-label{
  font-size:14px;
  color:var(--muted);
  font-weight:500;
}

/* Responsive tweaks */
@media (max-width: 1024px){
  .main-layout{
    gap:24px;
    padding-left:14px;
    padding-right:14px;
  }
  .container{padding:0 14px}
  .top-bar .container{padding:16px 14px}
}

/* Mobile menu toggle */
.menu-toggle{
  display:none;
  background:transparent;
  border:none;
  font-size:20px;
  padding:6px 8px;
  cursor:pointer;
}

/* Flash colour map (kept compatible with the dismissible variant below) */
.flash.info{background:var(--info-light);color:var(--info);border-color:rgba(14,165,233,0.25)}
.flash.warning{background:var(--warning-light);color:#92400e;border-color:rgba(245,158,11,0.4)}
[data-theme="dark"] .flash.warning{color:var(--warning)}
.flash.error,.flash.danger{background:var(--danger-light);color:var(--danger);border-color:rgba(239,68,68,0.3)}

/* Breadcrumbs */
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--muted);margin-bottom:12px}
.breadcrumb a{color:var(--primary);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}

/* Focus styles for keyboard users */
a:focus, button:focus, input:focus-visible, .btn:focus-visible{outline:3px solid var(--primary-light);outline-offset:2px}

/* Form error states */
.input-error{border-color:var(--danger) !important;box-shadow:0 0 0 3px rgba(239,68,68,0.08)}
.form-error{color:var(--danger);font-size:13px;margin-top:6px}

/* Sidebar behaviour on small screens */
@media (max-width: 1024px){
  .menu-toggle{display:inline-flex}
  .sidebar{position:fixed;left:0;top:64px;bottom:0;width:260px;background:var(--card);z-index:200;transform:translateX(-110%);transition:var(--transition);box-shadow:var(--shadow-lg);padding:18px}
  .sidebar.open{transform:translateX(0)}
  .main-layout{padding-left:0}
  .content{padding:16px 10px}
}

@media (max-width: 768px){
  .main-layout{
    flex-direction:column;
    padding-left:10px;
    padding-right:10px;
  }
  .search{max-width:100%}
  .container{padding:0 10px}
  .top-bar .container{
    flex-wrap:wrap;
    padding:12px 10px;
  }
  .grid{
    grid-template-columns:1fr;
  }
  h1{font-size:1.75rem}
  .header-with-actions{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media (max-width: 480px){
  .btn{
    padding:8px 14px;
    font-size:13px;
  }
  .card{padding:16px}
  .item{padding:16px}
  .form-card{padding:16px}
}

/* --- Page inscription événement --- */
.page-inscription-event .insc-hero{
  margin-bottom:28px;
  padding:24px 28px;
  background:linear-gradient(135deg, var(--primary-light) 0%, var(--card) 55%, var(--bg-alt) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.page-inscription-event .insc-hero h1{
  margin:0 0 10px;
  font-size:1.65rem;
  font-weight:700;
  letter-spacing:-0.02em;
  line-height:1.25;
}
.page-inscription-event .insc-hero .insc-hero__lead{
  margin:0;
  max-width:62ch;
  color:var(--text-secondary);
  font-size:15px;
  line-height:1.65;
}
.page-inscription-event .insc-hero__event-name{
  margin:0 0 8px;
  font-size:1.2rem;
  font-weight:600;
  color:var(--text);
  line-height:1.35;
  letter-spacing:-0.01em;
}
.page-inscription-event .insc-toolbar{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-bottom:16px;
  padding:16px 20px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.page-inscription-event .insc-toolbar__row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px 20px;
}
.page-inscription-event .insc-toolbar__row--primary{
  padding-bottom:14px;
  border-bottom:1px solid var(--border-light);
}
.page-inscription-event .insc-toolbar__row--secondary{
  justify-content:space-between;
  gap:12px 24px;
}
.page-inscription-event .insc-toolbar__field{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.page-inscription-event .insc-toolbar__field--danger{
  margin-right:auto;
}
.page-inscription-event .insc-toolbar__field--create{
  margin-left:auto;
}
@media (max-width: 640px){
  .page-inscription-event .insc-toolbar__row--secondary{
    flex-direction:column;
    align-items:stretch;
  }
  .page-inscription-event .insc-toolbar__field--danger,
  .page-inscription-event .insc-toolbar__field--create{
    margin:0;
  }
}
.page-inscription-event .insc-toolbar__field label{
  margin:0;
  font-size:13px;
  font-weight:600;
  color:var(--muted);
}
.page-inscription-event .insc-toolbar__select{
  min-width:240px;
  max-width:100%;
}
.page-inscription-event .insc-toolbar__new-title-input{
  min-width:200px;
  max-width:280px;
}
.page-inscription-event .insc-section-nav{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px 6px;
  margin-bottom:22px;
  padding:10px 14px;
  position:sticky;
  top:0;
  z-index:50;
  background:var(--bg);
  border:1px solid var(--border-light);
  border-radius:var(--radius-sm);
  box-shadow:0 1px 0 rgba(0,0,0,0.04);
}
.page-inscription-event .insc-section-nav a{
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  font-size:13px;
  font-weight:600;
  color:var(--text-secondary);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:999px;
  text-decoration:none;
  transition:var(--transition);
}
.page-inscription-event .insc-section-nav a:hover{
  color:var(--primary);
  border-color:var(--primary);
  background:var(--primary-light);
}
.page-inscription-event .insc-empty-state{
  padding:20px 22px;
  border:1px dashed var(--border);
  border-radius:var(--radius-sm);
  background:var(--bg-alt);
  color:var(--text-secondary);
  line-height:1.6;
}
.page-inscription-event #form-inscription{
  display:flex;
  flex-direction:column;
  gap:0;
}
.page-inscription-event .insc-panel{
  margin-bottom:28px;
  padding:22px 24px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.page-inscription-event .insc-panel:last-of-type{
  margin-bottom:0;
}
.page-inscription-event .insc-panel__head{
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border-light);
}
.page-inscription-event .insc-panel__title{
  margin:0;
  font-size:1.15rem;
  font-weight:600;
  color:var(--text);
  letter-spacing:-0.01em;
}
.page-inscription-event .insc-panel__head h2.insc-panel__title{
  font-size:1.15rem;
  margin:0;
}
.page-inscription-event .insc-panel__hint{
  margin:6px 0 0;
  max-width:72ch;
  font-size:14px;
  color:var(--muted);
  line-height:1.55;
}
.page-inscription-event .insc-subsection{
  margin-top:22px;
  padding-top:20px;
  border-top:1px solid var(--border-light);
}
.page-inscription-event #insc-section-message > .insc-panel__head + .insc-subsection{
  margin-top:0;
  padding-top:0;
  border-top:none;
}
.page-inscription-event #insc-section-message,
.page-inscription-event #insc-section-archers,
.page-inscription-event #insc-section-output{
  scroll-margin-top:118px;
}
.page-inscription-event .insc-subsection__title{
  margin:0 0 14px;
  font-size:0.95rem;
  font-weight:600;
  color:var(--text);
  letter-spacing:-0.01em;
}
.page-inscription-event .insc-subsection__hint{
  margin:0 0 10px;
  line-height:1.5;
}
.page-inscription-event .insc-subsection__hint--indented{
  margin-left:0;
  padding-left:28px;
}
.page-inscription-event .insc-dates-row{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  margin-top:16px;
  align-items:flex-end;
}
.page-inscription-event .insc-advanced-details{
  margin-top:24px;
  padding:0;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:var(--bg-alt);
  overflow:hidden;
}
.page-inscription-event .insc-advanced-details__summary{
  padding:14px 18px;
  font-size:0.95rem;
  font-weight:600;
  cursor:pointer;
  list-style:none;
  color:var(--text);
}
.page-inscription-event .insc-advanced-details__summary::-webkit-details-marker{
  display:none;
}
.page-inscription-event .insc-advanced-details__summary::after{
  content:'';
  display:inline-block;
  margin-left:8px;
  width:0;
  height:0;
  border-left:5px solid transparent;
  border-right:5px solid transparent;
  border-top:6px solid var(--muted);
  vertical-align:middle;
  transition:transform 0.15s ease;
}
.page-inscription-event .insc-advanced-details[open] .insc-advanced-details__summary::after{
  transform:rotate(180deg);
}
.page-inscription-event .insc-advanced-details__body{
  padding:0 18px 18px;
  background:var(--card);
  border-top:1px solid var(--border-light);
}
.page-inscription-event .insc-discipline-checkboxes{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.page-inscription-event .insc-discipline-check-label{
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  font-weight:500;
}
.page-inscription-event .insc-inline-check-label{
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  font-weight:600;
}
.page-inscription-event .insc-actions-row__hint{
  max-width:36ch;
  line-height:1.45;
}
.page-inscription-event .insc-actions-row--after-archers{
  margin-top:8px;
  margin-bottom:24px;
}
.page-inscription-event .insc-output-section{
  scroll-margin-top:12px;
}
.page-inscription-event .insc-output-section .insc-generate-bar{
  margin-bottom:0;
}
.page-inscription-event .insc-output-section .insc-mail-output{
  margin-top:20px;
}
.page-inscription-event .insc-table-scroll-hint{
  margin:0 0 14px;
  line-height:1.5;
}
.page-inscription-event .insc-mail-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:20px 28px;
}
@media (min-width: 880px){
  .page-inscription-event .insc-mail-grid{
    grid-template-columns:1fr 1.15fr;
  }
}
.page-inscription-event .insc-mail-grid .form-group:last-child{
  margin-bottom:0;
}
.page-inscription-event .insc-depart-phrases .depart-phrase-row{
  display:flex;
  gap:10px;
  align-items:center;
  margin-bottom:10px;
}
.page-inscription-event .insc-depart-phrases .depart-phrase-row input{
  flex:1;
  min-width:0;
}
.page-inscription-event .insc-actions-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
  margin-top:4px;
  margin-bottom:22px;
}
.page-inscription-event .insc-generate-bar{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px 16px;
  margin-bottom:24px;
  padding:16px 20px;
  background:var(--bg-alt);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  border-left:4px solid var(--primary);
}
.page-inscription-event .insc-generate-bar__label{
  width:100%;
  margin:0;
  font-size:13px;
  font-weight:600;
  color:var(--text-secondary);
  letter-spacing:0.02em;
}
.page-inscription-event .insc-mail-output{
  margin:24px 0 28px;
  padding:20px 22px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
}
.page-inscription-event .insc-mail-output__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:14px;
}
.page-inscription-event .insc-mail-output__head h3{
  margin:0;
  font-size:1.05rem;
}
.page-inscription-event #inscription-output{
  width:100%;
  min-height:240px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:13px;
  line-height:1.55;
  padding:14px 16px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:var(--bg-alt);
  color:var(--text);
}
.page-inscription-event .insc-archers-intro{
  margin:0 0 16px;
  padding:14px 16px;
  background:var(--primary-light);
  border-radius:var(--radius-sm);
  border:1px solid rgba(59,130,246,0.2);
  font-size:14px;
  color:var(--text-secondary);
  line-height:1.6;
}
.page-inscription-event .insc-archers-intro ul{
  margin:10px 0 0 1.1rem;
  padding:0;
}
.page-inscription-event .insc-archers-intro li{
  margin-bottom:6px;
}
.page-inscription-event .insc-archers-intro li:last-child{
  margin-bottom:0;
}
.page-inscription-event .insc-dep-section{
  margin-bottom:28px;
  padding:20px 22px 22px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius);
}
.page-inscription-event .insc-dep-section:last-child{
  margin-bottom:0;
}
.page-inscription-event .insc-dep-section__title{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin:0 0 14px;
  font-size:1.05rem;
  font-weight:600;
  line-height:1.35;
  color:var(--text);
}
.page-inscription-event .insc-dep-badge{
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  height:28px;
  padding:0 8px;
  font-size:12px;
  font-weight:700;
  color:var(--primary);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
}
.page-inscription-event .insc-dep-section__label{
  flex:1;
  min-width:0;
}
.page-inscription-event .insc-picker-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px;
  margin-bottom:14px;
  padding:12px 14px;
  background:var(--card);
  border:1px solid var(--border-light);
  border-radius:var(--radius-sm);
}
.page-inscription-event .insc-picker-row label{
  margin:0;
  font-size:13px;
  font-weight:600;
  color:var(--muted);
}
.page-inscription-event .insc-picker-row .insc-picker-select{
  min-width:220px;
  max-width:100%;
  flex:1;
}
.page-inscription-event .insc-table-wrap{
  overflow-x:auto;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:var(--card);
  box-shadow:var(--shadow-sm);
}
.page-inscription-event .inscription-table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
  min-width:960px;
}
.page-inscription-event .inscription-table.inscription-table--one-disc{
  min-width:820px;
}
.page-inscription-event .inscription-table.inscription-table--one-disc.inscription-table--no-detail{
  min-width:520px;
}
.page-inscription-event .inscription-table.inscription-table--no-detail:not(.inscription-table--one-disc){
  min-width:640px;
}
.page-inscription-event .inscription-table thead th:first-child{
  width:104px;
}
.page-inscription-event .inscription-table thead th:nth-child(2){
  width:56px;
}
.page-inscription-event .inscription-table thead th{
  position:sticky;
  top:0;
  z-index:1;
  padding:12px 14px;
  background:var(--bg-alt);
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.06em;
  color:var(--muted);
  text-align:left;
  border-bottom:1px solid var(--border);
  white-space:nowrap;
}
.page-inscription-event .inscription-table tbody td{
  padding:12px 14px;
  vertical-align:middle;
  border-bottom:1px solid var(--border-light);
}
.page-inscription-event .inscription-table tbody tr:last-child td{
  border-bottom:none;
}
.page-inscription-event .inscription-table tbody tr:hover{
  background:var(--bg-alt);
}
.page-inscription-event .inscription-archer-row .insc-archer-name{
  font-weight:600;
  font-size:14px;
  color:var(--text);
}
.page-inscription-event .insc-archer-fiche-line{
  font-size:12px;
  margin-top:4px;
  color:var(--muted);
}
.page-inscription-event .insc-td--license{
  font-size:13px;
  color:var(--text-secondary);
  font-variant-numeric:tabular-nums;
}
.page-inscription-event .insc-td--stack{
  vertical-align:top;
}
.page-inscription-event .insc-control{
  width:100%;
  max-width:220px;
  padding:8px 10px;
  font-size:14px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
}
.page-inscription-event .insc-control:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-light);
}
.page-inscription-event .insc-control--narrow{
  max-width:160px;
}
.page-inscription-event .insc-control--blason{
  max-width:150px;
}
.page-inscription-event .insc-control--xs{
  max-width:120px;
}
.page-inscription-event .insc-blason-pike-label{
  font-size:11px;
  margin-bottom:8px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.page-inscription-event .insc-distance-label{
  font-size:11px;
  margin-top:0;
  margin-bottom:6px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.page-inscription-event .insc-targets-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  min-width:0;
}
@media (min-width: 900px){
  .page-inscription-event .inscription-table .insc-targets-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px 16px;
    align-items:start;
  }
  .page-inscription-event .inscription-table .insc-targets-grid > .insc-blason-pike-label{
    grid-column:1 / -1;
  }
  .page-inscription-event .inscription-table .insc-targets-grid > .insc-wrap-distance{
    grid-column:1 / -1;
  }
}
.page-inscription-event .insc-targets-grid__cell{
  padding:10px 12px;
  background:var(--bg-alt);
  border:1px solid var(--border-light);
  border-radius:var(--radius-sm);
  min-width:0;
}
.page-inscription-event .insc-targets-grid > .insc-blason-pike-label{
  margin-bottom:0;
  padding-bottom:2px;
}
.page-inscription-event .insc-targets-grid__cell .insc-distance-label{
  margin-top:0;
}
.page-inscription-event .insc-btn-row-remove{
  font-size:13px;
  padding:6px 12px;
}
.page-inscription-event .insc-first-card h3{
  margin-top:0;
}
.page-inscription-event .insc-depart-phrases .depart-phrase-row .depart-remove{
  flex-shrink:0;
}
.page-inscription-event .insc-btn-delete-event{
  border-color:#fecaca;
  color:#b91c1c;
}
.page-inscription-event .insc-btn-delete-event:hover{
  border-color:var(--danger);
  color:#fff;
  background:var(--danger);
}
.page-inscription-event .insc-toolbar-back{
  flex-shrink:0;
  text-decoration:none;
}
.page-inscription-event .insc-event-index .insc-event-grid{
  list-style:none;
  margin:0 0 8px;
  padding:0;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(272px,1fr));
  gap:16px;
}
.page-inscription-event .insc-event-card{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-height:120px;
  padding:18px 20px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:var(--card);
  text-decoration:none;
  color:var(--text);
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.page-inscription-event .insc-event-card:hover{
  border-color:var(--primary);
  box-shadow:var(--shadow-md);
  transform:translateY(-1px);
  color:var(--text);
}
.page-inscription-event .insc-event-card__title{
  font-size:1.05rem;
  font-weight:600;
  color:var(--text);
  line-height:1.35;
}
.page-inscription-event .insc-event-card__recipient{
  font-size:14px;
  color:var(--muted);
  line-height:1.4;
}
.page-inscription-event .insc-event-card__meta{
  margin-top:auto;
  padding-top:12px;
  font-size:13px;
  color:var(--muted);
}
.page-inscription-event .insc-event-card__dot{
  margin:0 6px;
  opacity:0.7;
}
.page-inscription-event .insc-event-index__create{
  margin-top:12px;
  padding-top:22px;
  border-top:1px solid var(--border-light);
}
.page-inscription-event .insc-event-index__create-title{
  margin:0 0 12px;
  font-size:1rem;
  font-weight:600;
  color:var(--text);
}
.page-inscription-event .insc-event-index__create-form{
  margin:0;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:12px;
}

/* --- Shell minimal (page connexion) --- */
body.shell-minimal .menu-toggle{display:none}
body.shell-minimal .search{display:none}
body.shell-minimal .user-menu{display:none}
body.shell-minimal .sidebar{display:none}
body.shell-minimal{
  display:flex;
  flex-direction:column;
  min-height:100dvh;
}
body.shell-minimal .top-bar .container{
  justify-content:center;
}
body.shell-minimal .content--minimal{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:32px 16px 48px;
  width:100%;
}
body.shell-minimal .content--minimal .login-page-inner{
  width:100%;
  max-width:420px;
}
body.shell-minimal .content--minimal > .flash{
  width:100%;
  max-width:420px;
}
.login-card{
  width:100%;
}
.login-card h1{
  margin:0 0 8px;
  font-size:1.5rem;
  font-weight:700;
  letter-spacing:-0.02em;
  text-align:center;
}
.login-card .login-lead{
  text-align:center;
  margin:0 0 24px;
  color:var(--muted);
  font-size:14px;
}
.login-card .form-group{margin-bottom:20px}
.login-card label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text)}
.login-resend-box{
  margin-top:20px;
  padding:16px;
  border-radius:var(--radius-sm);
  background:var(--warning-light);
  border:1px solid #fcd34d;
  color:#78350f;
  font-size:14px;
  line-height:1.5;
}
.login-resend-box p{margin:0 0 12px}
.login-resend-box .btn-resend{
  width:100%;
  padding:10px 14px;
  border:none;
  border-radius:var(--radius-sm);
  background:var(--warning);
  color:#fff;
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  font-family:inherit;
  transition:var(--transition);
}
.login-resend-box .btn-resend:hover{
  filter:brightness(0.95);
}

/* --- Tableaux & dashboard --- */
.table--flush{margin:0}
.table--wide{min-width:960px}
.table--dashboard{min-width:520px}
.th-col-narrow{width:22%}
.th-id{width:1%;white-space:nowrap}
.td-tabular{font-variant-numeric:tabular-nums}
.td-actions{text-align:right}
.th-actions{text-align:right;white-space:nowrap}
.text-nowrap{white-space:nowrap}
.btn-muted{opacity:0.85}
.form-inline{display:inline;margin:0}

/* --- Filtres (liste archers) --- */
.filter-panel{
  margin-bottom:20px;
  padding:16px 18px;
  background:var(--bg-alt);
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
}
.filter-panel[open]{padding-bottom:18px}
.filter-panel__label{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:600;
  font-size:14px;
  color:var(--text);
  cursor:pointer;
  list-style:none;
  user-select:none;
  padding:2px 0;
}
.filter-panel__label::-webkit-details-marker{display:none}
.filter-panel__label::after{
  content:'▸';
  margin-left:auto;
  font-size:14px;
  color:var(--muted);
  transition:transform 0.2s ease;
}
.filter-panel[open] .filter-panel__label::after{
  transform:rotate(90deg);
}
.filter-panel__row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
}
.filter-panel__form{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  margin:0;
}
.filter-panel__form .input-age{width:90px}
.empty-state{
  text-align:center;
  padding:48px 24px;
}
.empty-state--tight{
  padding:40px 24px;
}
.empty-state .btn{margin-top:16px}

/* --- Cartes archer / événements --- */
.archer-event-grid{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}
.event-card{
  padding:18px 20px;
  height:100%;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.event-card__actions{
  margin-top:auto;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:stretch;
}
.card-section-title{
  margin:0 0 12px;
  font-size:1.1rem;
  font-weight:600;
}
.card--portal{margin-bottom:16px}
.stats-grid--below-header{margin-bottom:28px}
.list-events{margin:0;padding-left:1.2rem;line-height:1.7}
.badge--inline{margin-left:6px}
.badge--inline-sm{margin-left:6px;font-size:11px;vertical-align:middle}
.note-below{margin-top:4px}
.mon-arc-title{margin:0 0 8px;font-size:1.15rem}
.mon-arc-meta{margin:0}

/* --- Formulaires centrés --- */
.form-narrow{
  max-width:600px;
  margin:0 auto;
}
.form-actions{
  margin-top:20px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.label-required{color:var(--danger)}

/* --- Pages inscription archer (largeurs statiques) --- */
.form-card--archer-insc{max-width:720px}
.archer-insc-cancel{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.h3-tight{margin-top:0}
.h3-spaced{margin-top:24px}
.p-muted-tight{margin:0 0 8px}

/* Smooth scrolling */
html{scroll-behavior:smooth}

/* ============================================================
 * UX enhancements layer
 * ============================================================ */

/* Skip-to-content (a11y) */
.skip-link{
  position:absolute;
  left:-9999px;
  top:8px;
  z-index:1000;
  padding:10px 14px;
  background:var(--primary);
  color:#fff;
  font-weight:600;
  border-radius:var(--radius-sm);
  text-decoration:none;
  box-shadow:var(--shadow-md);
}
.skip-link:focus,
.skip-link:focus-visible{
  left:12px;
  outline:none;
  color:#fff;
}

/* Theme toggle button */
.theme-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  padding:0;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:var(--card);
  color:var(--text-secondary);
  cursor:pointer;
  font-size:16px;
  line-height:1;
  transition:var(--transition);
}
.theme-toggle:hover{
  border-color:var(--primary);
  color:var(--primary);
  background:var(--primary-light);
}
.theme-toggle .theme-icon-dark{display:none}
[data-theme="dark"] .theme-toggle .theme-icon-light{display:none}
[data-theme="dark"] .theme-toggle .theme-icon-dark{display:inline}
@media (prefers-color-scheme: dark){
  [data-theme="auto"] .theme-toggle .theme-icon-light{display:none}
  [data-theme="auto"] .theme-toggle .theme-icon-dark{display:inline}
}

/* Keyboard shortcut chip */
.search{position:relative}
.search input{padding-right:48px}
.kbd-hint{
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border:1px solid var(--border);
  border-bottom-width:2px;
  border-radius:6px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:12px;
  color:var(--muted);
  background:var(--bg-alt);
  pointer-events:none;
  user-select:none;
  transition:var(--transition);
}
.search input:focus + .kbd-hint{opacity:0}

/* Dismissible flashes — icon + close + auto-fade animation */
.flash{
  position:relative;
  padding-left:46px;
  padding-right:48px;
  display:flex;
  align-items:flex-start;
  gap:10px;
  animation:flashIn 0.25s ease-out both;
}
.flash::before{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  font-size:18px;
  line-height:1;
}
.flash.success::before{content:'✓';color:var(--success);font-weight:700}
.flash.error::before,
.flash.danger::before{content:'⚠';color:var(--danger);font-weight:700}
.flash.warning::before{content:'!';color:var(--warning);font-weight:700;font-family:ui-monospace,monospace}
.flash.info::before{content:'i';color:var(--info);font-weight:700;font-style:italic;font-family:Georgia,serif}
.flash .flash-close{
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  width:28px;
  height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:none;
  background:transparent;
  color:inherit;
  opacity:0.6;
  cursor:pointer;
  border-radius:6px;
  font-size:16px;
  line-height:1;
  transition:var(--transition);
}
.flash .flash-close:hover{opacity:1;background:rgba(0,0,0,0.06)}
[data-theme="dark"] .flash .flash-close:hover{background:rgba(255,255,255,0.08)}
.flash.is-dismissing{
  animation:flashOut 0.25s ease-in both;
}
@keyframes flashIn{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes flashOut{
  from{opacity:1;transform:translateY(0);max-height:200px}
  to{opacity:0;transform:translateY(-6px);max-height:0;margin-top:0;margin-bottom:0;padding-top:0;padding-bottom:0;border-width:0}
}

/* Button loading state */
.btn.is-loading{
  pointer-events:none;
  opacity:0.75;
  position:relative;
  color:transparent !important;
}
.btn.is-loading::after{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:16px;
  height:16px;
  margin-left:-8px;
  margin-top:-8px;
  border-radius:50%;
  border:2px solid currentColor;
  border-top-color:transparent;
  color:#fff;
  animation:btnSpin 0.6s linear infinite;
}
.btn-outline.is-loading::after,
.btn-secondary.is-loading::after,
.btn-warning.is-loading::after{color:var(--text-secondary)}
@keyframes btnSpin{
  to{transform:rotate(360deg)}
}

/* Top-bar polish */
.top-bar{
  height:var(--top-bar-height);
}
.top-bar .container{
  height:100%;
  padding-top:0;
  padding-bottom:0;
}
.top-bar-tools{
  display:flex;
  align-items:center;
  gap:10px;
}

/* Sidebar collapse on desktop */
.sidebar-collapse-btn{
  display:none;
  width:100%;
  margin-bottom:12px;
  padding:8px 10px;
  border:1px dashed var(--border);
  background:transparent;
  color:var(--muted);
  font-size:12px;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  border-radius:var(--radius-sm);
  cursor:pointer;
  transition:var(--transition);
}
.sidebar-collapse-btn:hover{
  border-color:var(--primary);
  color:var(--primary);
}
.sidebar nav a{gap:10px}
.sidebar nav .nav-icon{
  display:inline-flex;
  width:20px;
  flex-shrink:0;
  justify-content:center;
  font-size:16px;
  line-height:1;
}
.sidebar nav .nav-label{
  flex:1;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
@media (min-width: 1025px){
  .sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;gap:6px}
  body.sidebar-collapsed .sidebar{
    flex-basis:64px;
    width:64px;
  }
  body.sidebar-collapsed .sidebar nav a{
    justify-content:center;
    padding:10px 8px;
  }
  body.sidebar-collapsed .sidebar nav .nav-label{display:none}
  body.sidebar-collapsed .sidebar-collapse-btn{padding:8px}
  body.sidebar-collapsed .sidebar-collapse-btn::before{content:'»';font-size:14px;font-weight:700;line-height:1}
  body:not(.sidebar-collapsed) .sidebar-collapse-btn::before{content:'«';font-size:12px;font-weight:700;margin-right:6px}
  body.sidebar-collapsed .sidebar-collapse-btn .sidebar-collapse-label{display:none}
}
@media (max-width: 1024px){
  .sidebar-collapse-btn{display:none !important}
}

/* Quick-action grid for dashboards */
.quick-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:14px;
  margin-bottom:32px;
}
.quick-card{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:18px 20px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text);
  text-decoration:none;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.quick-card::after{
  content:'';
  position:absolute;
  inset:0;
  border-left:3px solid transparent;
  border-radius:inherit;
  transition:var(--transition);
  pointer-events:none;
}
.quick-card:hover{
  border-color:var(--primary);
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
  color:var(--text);
}
.quick-card:hover::after{border-left-color:var(--primary)}
.quick-card__icon{
  width:36px;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  font-size:18px;
  background:var(--primary-light);
  color:var(--primary);
}
.quick-card__title{
  font-size:1rem;
  font-weight:600;
  color:var(--text);
  margin:0;
}
.quick-card__desc{
  margin:0;
  font-size:13px;
  color:var(--muted);
  line-height:1.5;
}
.quick-card__cta{
  margin-top:auto;
  padding-top:6px;
  font-size:13px;
  font-weight:600;
  color:var(--primary);
  display:inline-flex;
  align-items:center;
  gap:4px;
}
.quick-card[data-tone="success"] .quick-card__icon{background:var(--success-light);color:var(--success)}
.quick-card[data-tone="warning"] .quick-card__icon{background:var(--warning-light);color:#92400e}
[data-theme="dark"] .quick-card[data-tone="warning"] .quick-card__icon{color:var(--warning)}
.quick-card[data-tone="info"] .quick-card__icon{background:var(--info-light);color:var(--info)}
.quick-card[data-tone="muted"] .quick-card__icon{background:var(--bg-alt);color:var(--muted)}

/* Stat cards with subtle accent */
.stat-card{
  position:relative;
  overflow:hidden;
}
.stat-card::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:var(--primary);
  opacity:0.85;
}
.stat-card[data-tone="success"]::before{background:var(--success)}
.stat-card[data-tone="warning"]::before{background:var(--warning)}
.stat-card[data-tone="info"]::before{background:var(--info)}

/* Active filter chips */
.filter-active-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.filter-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  background:var(--primary-light);
  color:var(--primary);
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  text-decoration:none;
}
.filter-chip:hover{
  background:var(--primary);
  color:#fff;
}
.filter-chip__close{
  font-size:14px;
  line-height:1;
  opacity:0.8;
}
.filter-chip:hover .filter-chip__close{opacity:1}

/* Sticky table header within long pages */
.table--sticky thead th{
  position:sticky;
  top:var(--top-bar-height);
  z-index:5;
  background:var(--bg-alt);
}

/* Login polish */
body.shell-minimal .top-bar{
  background:transparent;
  border-bottom:none;
  box-shadow:none;
}
body.shell-minimal .top-bar .container{justify-content:center}
body.shell-minimal .logo-img{height:40px}
body.shell-minimal .logo-wordmark{font-size:1.4rem}
.login-card .login-logo{
  display:flex;
  justify-content:center;
  margin-bottom:16px;
}
.login-card .login-logo img{
  height:56px;
  width:auto;
}

/* Logout button visual cue */
.user-menu .btn-logout{
  display:inline-flex;
  align-items:center;
  gap:6px;
}

/* Form helper text */
.form-help{
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
  line-height:1.5;
}

/* Mobile responsive table fallback: card mode */
@media (max-width: 640px){
  .table--cards-mobile{
    display:block;
    border:none;
    box-shadow:none;
    background:transparent;
  }
  .table--cards-mobile thead{
    display:none;
  }
  .table--cards-mobile tbody,
  .table--cards-mobile tr,
  .table--cards-mobile td{
    display:block;
    width:100%;
  }
  .table--cards-mobile tr{
    background:var(--card);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:14px 16px;
    margin-bottom:12px;
    box-shadow:var(--shadow-sm);
  }
  .table--cards-mobile td{
    padding:6px 0;
    border-bottom:1px dashed var(--border-light);
    text-align:left !important;
  }
  .table--cards-mobile td:last-child{border-bottom:none}
  .table--cards-mobile td[data-label]::before{
    content:attr(data-label);
    display:block;
    font-size:11px;
    font-weight:700;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:0.05em;
    margin-bottom:2px;
  }
  .table--cards-mobile .table-row-actions{justify-content:flex-start}
}

/* Inputs / selects dark mode: tame native colors */
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea{
  color-scheme:dark;
}
@media (prefers-color-scheme: dark){
  [data-theme="auto"] input,
  [data-theme="auto"] select,
  [data-theme="auto"] textarea{
    color-scheme:dark;
  }
}

/* Hover/zebra polish for sortable tables */
.table-sortable tbody tr:nth-child(even) td{
  background:var(--bg-alt);
}
.table-sortable tbody tr:hover td{background:var(--bg)}
[data-theme="dark"] .table-sortable tbody tr:hover td{background:var(--bg-alt)}

/* Subtle entrance animation for main content */
.content > *{
  animation:fadeUp 0.25s ease-out both;
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}
@media (prefers-reduced-motion: reduce){
  .content > *{animation:none}
}

/* Inline-style replacement utilities (used by templates) */
.u-flex{display:flex}
.u-flex-align-center{display:flex;align-items:center}
.u-gap-8{gap:8px}
.u-gap-12{gap:12px}
.u-gap-16{gap:16px}
.u-mt-0{margin-top:0 !important}
.u-mb-0{margin-bottom:0 !important}
.u-text-right{text-align:right}
.u-nowrap{white-space:nowrap}
.u-w-1{width:1%}
.u-min-w-560{min-width:560px}
.u-min-w-720{min-width:720px}
.u-min-w-960{min-width:960px}
.u-max-w-600{max-width:600px}
.action-bar-row{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:24px;
  flex-wrap:wrap;
}
.action-bar-row h1{margin:0}

/* Notice / callout block */
.notice{
  margin-top:24px;
  padding:18px 20px;
  background:var(--warning-light);
  border:1px solid var(--warning);
  border-left-width:4px;
  border-radius:var(--radius);
}
.notice h3{margin:0 0 8px 0;font-size:1rem}
.notice--info{
  background:var(--info-light);
  border-color:var(--info);
}
.notice--info h3{color:var(--info)}

/* Sort toolbar (composites etc.) */
.sort-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:20px;
  padding:10px 14px;
  background:var(--bg-alt);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  flex-wrap:wrap;
}
.sort-toolbar__label{
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.05em;
}
.sort-toolbar a{
  padding:6px 12px;
  font-size:13px;
}

/* Liens type référence (IDs / noms dans tableaux) */
.ref-link{
  color:var(--primary);
  font-weight:600;
  text-decoration:none;
  font-variant-numeric:tabular-nums;
}
.ref-link:hover{text-decoration:underline}
.ref-link.small{font-size:13px;font-weight:600}

/* Links */
a{
  color:var(--primary);
  text-decoration:none;
  transition:var(--transition);
}
a:hover{
  color:var(--primary-hover);
  text-decoration:none;
}

/* Selection */
::selection{
  background:var(--primary-light);
  color:var(--primary);
}

/* Focus visible */
:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}

