/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   ORT â€” RACE MANAGER PRO Â· Design System v9.0
   "Pit Lane Terminal" â€” Maximum Visual Impact
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,300;0,400;0,600;0,700;0,800;0,900;1,700;1,800;1,900&family=JetBrains+Mono:wght@400;500;600;700;800&family=Barlow:wght@300;400;500;600;700&family=Racing+Sans+One&family=Black+Ops+One&display=swap');

/* â”€â”€â”€ DESIGN TOKENS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
:root {
  --bg:      #070A0C;
  --bg-2:    #0D1218;
  --bg-3:    #131C24;
  --bg-4:    #1A2330;

  --surface:   rgba(255,255,255,0.042);
  --surface-2: rgba(255,255,255,0.070);
  --surface-3: rgba(255,255,255,0.105);
  --surface-4: rgba(255,255,255,0.145);

  --border:   rgba(255,255,255,0.090);
  --border-2: rgba(255,255,255,0.155);
  --border-3: rgba(255,255,255,0.225);

  --header-h: 72px;
  --tabs-h:   44px;
  --logo-h:   calc(var(--header-h) - 20px);

  --orange:      #FF5200;
  --orange-2:    #FF7A35;
  --orange-3:    #FFAA66;
  --orange-dim:  rgba(255,82,0,0.18);
  --orange-glow: rgba(255,82,0,0.40);

  --green:      #00E676;
  --green-dim:  rgba(0,230,118,0.15);
  --green-glow: rgba(0,230,118,0.30);
  --red:        #FF1744;
  --red-dim:    rgba(255,23,68,0.16);
  --red-glow:   rgba(255,23,68,0.30);
  --blue:       #2979FF;
  --yellow:     #FFD600;
  --purple:     #AA00FF;

  --text:   #E8ECF0;
  --text-2: rgba(232,236,240,0.65);
  --text-3: rgba(232,236,240,0.38);
  --text-4: rgba(232,236,240,0.18);

  --font:   'Barlow', system-ui, sans-serif;
  --font-c: 'Barlow Condensed', sans-serif;
  --font-m: 'JetBrains Mono', 'Courier New', monospace;

  --r-xs: 6px; --r-sm: 10px; --r: 14px; --r-lg: 20px; --r-xl: 28px;

  --shadow-sm: 0 2px 12px rgba(0,0,0,0.50);
  --shadow:    0 8px 36px rgba(0,0,0,0.65);
  --shadow-lg: 0 20px 64px rgba(0,0,0,0.82);
  --glow-o:    0 0 32px rgba(255,82,0,0.30);
  --glow-o-lg: 0 0 60px rgba(255,82,0,0.42);
  --glow-g:    0 0 22px rgba(0,230,118,0.28);
  --glow-r:    0 0 22px rgba(255,23,68,0.28);

  /* legacy aliases */
  --orange2: var(--orange-2); --muted: var(--text-3); --muted2: var(--text-2);
  --ort: var(--blue); --bg-card: var(--surface); --success: var(--green);
  --danger: var(--red); --warning: #FF9800;
  --perm-user-col: 220px; --perm-col: 130px;
}

/* â”€â”€â”€ RESET â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
html, body { height: 100%; }
html.modal-open, body.modal-open { overflow: hidden; overscroll-behavior: none; }
body.modal-open { position: fixed; width: 100%; left: 0; right: 0; }

/* â”€â”€â”€ BODY â€” ATMOSPHERE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
body {
  font-family: var(--font);
  font-size: 15px;
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
  min-height: 100dvh;
  padding-bottom: 80px;
}
/* Radial halos â€” visually strong */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 1800px 900px at 12% -15%,  rgba(255,82,0,0.16)  0%, transparent 65%),
    radial-gradient(ellipse 1100px 800px at 90%   6%,  rgba(41,121,255,0.11) 0%, transparent 60%),
    radial-gradient(ellipse  900px 700px at 50%  115%, rgba(255,82,0,0.07)  0%, transparent 60%);
}
/* CRT scanlines */
body::after {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,0.12) 2px, rgba(0,0,0,0.12) 3px
  );
  opacity: 0.50;
}
body > * { position: relative; z-index: 1; }

/* â”€â”€â”€ TYPOGRAPHY â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
h1 {
  font-family: var(--font-c); font-weight: 900; font-style: italic;
  font-size: clamp(30px, 6vw, 48px); letter-spacing: -0.5px; line-height: 1.05;
  background: linear-gradient(135deg, #fff 0%, var(--orange-3) 35%, var(--orange-2) 65%, var(--orange) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
h2 { font-family: var(--font-c); font-weight: 800; font-size: 20px; color: var(--text); }
h3 { font-family: var(--font-c); font-weight: 700; font-size: 17px; color: var(--text); }
p  { margin-bottom: 8px; }
.subtitle {
  font-size: 13px; color: var(--text-3); font-family: var(--font-c);
  font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase;
}
/* Mono numbers */
.stat-val, .stat-value, .tarif-amount, .rider-num, .chrono-display,
[class*="time"], .lap-time, .best-time, .mono {
  font-family: var(--font-m); font-variant-numeric: tabular-nums; letter-spacing: -0.5px;
}

/* â”€â”€â”€ HEADER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
header {
  height: var(--header-h);
  background: linear-gradient(180deg, rgba(15,22,32,0.99) 0%, rgba(7,10,12,1.00) 100%);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 0 rgba(255,82,0,0.60), 0 4px 48px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.05);
  padding: 0 20px;
  display: flex; align-items: center; justify-content: space-between;
  position: fixed; top: 0; left: 0; right: 0; z-index: 120;
  overflow: hidden;
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
}
/* Animated top accent */
header::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg,
    transparent 0%, var(--orange) 10%, var(--orange-2) 35%,
    #fff 50%, var(--orange-2) 65%, var(--orange) 90%, transparent 100%
  );
  opacity: 0.85;
}
/* Racing diagonal stripe */
header::after {
  content: ''; position: absolute; top: 0; right: 0; bottom: 0; width: 50%;
  background: linear-gradient(108deg,
    transparent 32%, rgba(255,82,0,0.035) 32%,
    rgba(255,82,0,0.035) 55%, transparent 55%
  );
  pointer-events: none;
}
.logo {
  display: inline-flex; align-items: center; line-height: 0;
  filter: drop-shadow(0 0 20px rgba(255,82,0,0.30));
  transition: filter 0.3s; position: relative; z-index: 1; text-decoration: none;
}
.logo:hover { filter: drop-shadow(0 0 36px rgba(255,82,0,0.60)); }
.logo img { display: block; height: var(--logo-h); width: auto; max-width: 56vw; }
.header-right {
  display: flex; flex-direction: column; align-items: flex-end;
  gap: 4px; position: relative; z-index: 1;
}
.header-greeting { font-family: var(--font-c); font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 1.2px; }
.header-username  { font-family: var(--font-c); font-size: 15px; font-weight: 800; color: var(--text); letter-spacing: 0.3px; line-height: 1; }
.header-nav { display: flex; gap: 5px; align-items: center; }
.header-nav-btn {
  padding: 5px 11px; border-radius: 6px;
  border: 1px solid var(--border-2); background: var(--surface-2);
  color: var(--text-2); font-family: var(--font-c); font-size: 11px;
  font-weight: 800; text-transform: uppercase; letter-spacing: 0.8px;
  cursor: pointer; text-decoration: none; white-space: nowrap;
  transition: all 0.14s ease; min-height: 28px;
  display: inline-flex; align-items: center; gap: 4px;
}
.header-nav-btn:hover { background: var(--surface-3); border-color: var(--border-3); color: var(--text); }
.header-nav-btn.logout {
  background: linear-gradient(135deg, var(--orange), #FF6B2B);
  border-color: rgba(255,82,0,0.3); color: #fff;
  box-shadow: 0 2px 12px rgba(255,82,0,.32);
}
.header-nav-btn.logout:hover { box-shadow: 0 4px 22px rgba(255,82,0,.52); transform: translateY(-1px); }
/* legacy session-date compat */
.session-date { font-family: var(--font-c); font-size: 12px; color: var(--text-3); text-align: right; position: relative; z-index: 1; }
.session-date strong { display: block; color: var(--text); font-size: 15px; font-weight: 700; margin-bottom: 5px; }
@media (max-width: 480px) {
  :root { --header-h: 62px; --logo-h: calc(var(--header-h) - 14px); }
  header { padding: 0 12px; }
  .header-nav-btn { font-size: 10px; padding: 4px 8px; }
}

/* â”€â”€â”€ TABS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tabs {
  display: flex; height: var(--tabs-h); width: 100%;
  background: rgba(7,10,12,0.98); border-bottom: 1px solid var(--border);
  position: fixed !important; top: var(--header-h) !important; left: 0; right: 0; z-index: 130;
  overflow-x: auto; scrollbar-width: none;
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
}
.tabs::-webkit-scrollbar { display: none; }
.tabs::before, .tabs::after {
  content: ''; position: absolute; top: 0; bottom: 0; width: 24px; pointer-events: none; z-index: 1;
}
.tabs::before { left: 0;  background: linear-gradient(90deg,  rgba(7,10,12,.98), transparent); }
.tabs::after  { right: 0; background: linear-gradient(270deg, rgba(7,10,12,.98), transparent); }
.tab-btn {
  flex: 1; min-width: 68px; height: 100%; padding: 0 8px;
  background: none; border: none; color: var(--text-3);
  font-family: var(--font-c); font-size: 12px; font-weight: 800; letter-spacing: 1px;
  text-transform: uppercase; cursor: pointer; white-space: nowrap;
  display: flex; align-items: center; justify-content: center; gap: 5px;
  border-bottom: 2px solid transparent; position: relative; top: 1px; z-index: 1;
  text-decoration: none; transition: color 0.14s, border-color 0.14s;
}
.tab-btn:hover { color: var(--text-2); }
.tab-btn.active { color: var(--orange); border-bottom-color: var(--orange); text-shadow: 0 0 16px rgba(255,82,0,.55); }

/* â”€â”€â”€ PANELS / LAYOUT â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.panel { display: none; padding: 22px 16px 20px; margin-top: var(--header-h); }
.panel.active { display: block; }
.container { max-width: 1200px; margin: 0 auto; padding: 24px 20px; }
@media (min-width: 1100px) { .panel { max-width: 1100px; margin-left: auto; margin-right: auto; } }

/* â”€â”€â”€ PAGE HERO â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.page-hero {
  position: relative; overflow: hidden;
  margin-bottom: 28px; padding: 36px 28px 32px;
  border-radius: var(--r-lg);
  background:
    linear-gradient(135deg, rgba(255,82,0,0.18) 0%, rgba(255,82,0,0.06) 45%, transparent 75%),
    linear-gradient(155deg, var(--surface-3) 0%, var(--surface) 100%);
  border: 1px solid rgba(255,82,0,0.28);
  box-shadow: 0 0 80px rgba(255,82,0,0.14), var(--shadow);
}
.page-hero::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--orange) 25%, var(--orange-2) 60%, transparent);
  opacity: 0.9;
}
.page-hero__icon {
  position: absolute; right: 28px; top: 50%; transform: translateY(-50%);
  font-size: 6rem; opacity: 0.07; pointer-events: none; line-height: 1;
}
.page-hero__inner { position: relative; z-index: 1; }
.page-hero__badge {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--orange-dim); border: 1px solid rgba(255,82,0,0.38);
  color: var(--orange-2); border-radius: 999px;
  padding: 5px 14px; font-family: var(--font-c); font-size: 11px;
  font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 14px; box-shadow: 0 0 18px rgba(255,82,0,0.18);
}
.page-hero h1 { margin-bottom: 8px; }
.page-hero .subtitle { margin-bottom: 0; }

/* â”€â”€â”€ CARDS / SURFACES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.card, .form-section, .export-card, .rider-card, .user-card {
  background: linear-gradient(155deg, var(--surface-2) 0%, var(--surface) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r); position: relative; overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.18s, box-shadow 0.18s;
}
.card::before, .form-section::before, .export-card::before, .rider-card::before, .user-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.13), transparent);
  pointer-events: none;
}
.card { padding: 22px 24px; margin-bottom: 16px; }
.card:hover { border-color: var(--border-2); box-shadow: var(--shadow); }

/* â”€â”€â”€ FORM SECTIONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.form-section { padding: 22px; margin-bottom: 16px; }
.form-section:focus-within {
  border-color: rgba(255,82,0,0.38);
  box-shadow: 0 0 0 1px rgba(255,82,0,0.12), var(--shadow-sm);
}
.section-title {
  font-family: var(--font-c); font-weight: 800; font-size: 11px;
  letter-spacing: 2.5px; text-transform: uppercase; color: var(--orange-2);
  margin-bottom: 18px; display: flex; align-items: center; gap: 10px;
}
.section-title::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, rgba(255,82,0,0.32), transparent);
}
.field { margin-bottom: 16px; }
.field:last-child { margin-bottom: 0; }
label {
  display: block; font-family: var(--font-c); font-weight: 700;
  font-size: 11px; letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 7px;
}
input[type="text"], input[type="date"], input[type="password"],
input[type="email"], input[type="tel"], input[type="number"],
select, textarea {
  width: 100%; padding: 12px 15px;
  border: 1px solid var(--border); border-radius: var(--r-sm);
  background: rgba(0,0,0,0.35); color: var(--text);
  font-family: var(--font); font-size: 14px;
  transition: border-color 0.15s, box-shadow 0.15s; outline: none;
  -webkit-appearance: none; appearance: none;
}
input::placeholder, textarea::placeholder { color: var(--text-4); }
input:focus, select:focus, textarea:focus {
  border-color: var(--orange); box-shadow: 0 0 0 3px var(--orange-dim);
  background: rgba(0,0,0,0.45);
}
select option { background: var(--bg-3); color: var(--text); }
textarea { min-height: 80px; resize: vertical; line-height: 1.5; }
input:-webkit-autofill, select:-webkit-autofill, textarea:-webkit-autofill {
  -webkit-text-fill-color: var(--text);
  box-shadow: 0 0 0 1000px #0d1218 inset;
  caret-color: var(--text); transition: background-color 9999s;
}
.input-row { display: flex; gap: 8px; align-items: center; }
.input-row input { flex: 1; }
.help-text { font-size: 12px; color: var(--text-3); margin-top: 6px; }

/* â”€â”€â”€ BUTTONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn-primary, .btn-export, .nouvelle-session-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 15px 24px;
  border-radius: var(--r-sm); font-family: var(--font-c);
  font-size: 15px; font-weight: 900; letter-spacing: 1.5px; text-transform: uppercase;
  text-decoration: none; text-align: center; cursor: pointer;
  border: 1px solid rgba(255,82,0,0.38); min-height: 50px; white-space: nowrap;
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--orange) 0%, #FF6B2B 100%);
  color: #FFF;
  box-shadow: 0 4px 22px rgba(255,82,0,0.38), inset 0 1px 0 rgba(255,255,255,0.15);
  transition: all 0.16s ease; -webkit-user-select: none; user-select: none;
}
.btn-primary::after, .btn-export::after, .nouvelle-session-btn::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.10) 0%, transparent 55%);
  pointer-events: none; border-radius: inherit;
}
.btn-primary:hover, .btn-export:hover, .nouvelle-session-btn:hover {
  background: linear-gradient(135deg, #FF6B2B 0%, var(--orange) 100%);
  box-shadow: 0 6px 36px rgba(255,82,0,0.58), inset 0 1px 0 rgba(255,255,255,0.18);
  transform: translateY(-1px);
}
.btn-primary:active, .btn-export:active { transform: scale(0.98); box-shadow: 0 2px 14px rgba(255,82,0,0.38); }
.btn-primary:disabled, .btn-export:disabled, .btn-export[data-disabled="true"],
.btn-export[disabled] { opacity: 0.40; cursor: not-allowed; filter: grayscale(30%); transform: none !important; }

.btn-sm {
  display: inline-flex; align-items: center; justify-content: center; gap: 5px;
  padding: 8px 14px; border-radius: var(--r-xs);
  border: 1px solid var(--border-2); background: var(--surface-2);
  color: var(--text-2); font-family: var(--font-c); font-size: 12px;
  font-weight: 800; letter-spacing: 0.6px; text-transform: uppercase;
  cursor: pointer; white-space: nowrap; text-decoration: none;
  transition: all 0.14s ease; min-height: 34px;
}
.btn-sm:hover { background: var(--surface-3); border-color: var(--border-3); color: var(--text); }
.btn-sm:active { transform: scale(0.96); }
.btn-sm.green  { background: var(--green-dim);  border-color: rgba(0,230,118,0.32);  color: var(--green); }
.btn-sm.red    { background: var(--red-dim);    border-color: rgba(255,23,68,0.32);  color: var(--red); }
.btn-sm.orange { background: var(--orange-dim); border-color: rgba(255,82,0,0.32);   color: var(--orange-2); }
.btn-sm.green:hover  { background: rgba(0,230,118,0.26); }
.btn-sm.red:hover    { background: rgba(255,23,68,0.28); }
.btn-sm.orange:hover { background: rgba(255,82,0,0.30); box-shadow: var(--glow-o); }

.action-row { display: flex; gap: 10px; align-items: center; flex-wrap: nowrap; margin-top: 16px; }
.action-row .btn-export, .action-row .btn-primary { flex: 1 1 0; width: auto; }
.action-row .btn-export-back { flex: 1 1 0; width: auto; min-width: 0; text-decoration: none !important; }
@media (max-width: 520px) {
  .action-row { flex-wrap: wrap; }
  .action-row .btn-export, .action-row .btn-primary { order: 1; }
  .action-row .btn-export-back { flex: 1 1 100%; order: 2; }
}

.db-maintenance-layout {
  display: grid;
  gap: 14px;
  margin-top: 16px;
}

.db-maintenance-toolbar {
  display: grid;
  grid-template-columns: 1fr;
  margin-top: 12px;
}

.db-maintenance-toolbar .btn-export-back {
  width: 100%;
  min-width: 0;
  text-decoration: none !important;
}

.db-maintenance-block {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: rgba(255,255,255,0.03);
  padding: 12px;
}

.db-maintenance-block-title {
  font-family: var(--font-c);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-2);
  margin-bottom: 10px;
}

.db-maintenance-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.db-maintenance-actions .btn-export {
  white-space: normal;
  line-height: 1.2;
  min-height: 54px;
  padding: 12px 14px;
}

.init-db-actions {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.init-db-actions-top {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.init-db-actions-bottom {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.init-db-actions-top .btn-sm {
  flex: 0 0 auto;
}

.init-db-actions-bottom .btn-primary,
.init-db-actions-bottom .btn-export {
  flex: 1 1 280px;
  width: auto;
  min-width: 0;
}

@media (max-width: 700px) {
  .init-db-actions-top,
  .init-db-actions-bottom {
    display: grid;
    grid-template-columns: 1fr;
  }

  .init-db-actions-top .btn-sm,
  .init-db-actions-bottom .btn-primary,
  .init-db-actions-bottom .btn-export {
    width: 100%;
  }
}

.db-maintenance-result-card {
  margin-top: 14px;
  border: 1px solid rgba(0, 230, 118, 0.35);
  border-radius: var(--r-sm);
  background: linear-gradient(160deg, rgba(0, 230, 118, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
  overflow: hidden;
}

.db-maintenance-result-title {
  font-family: var(--font-c);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--green);
  background: rgba(0, 230, 118, 0.10);
  border-bottom: 1px solid rgba(0, 230, 118, 0.20);
  padding: 10px 12px;
}

.db-maintenance-result-body {
  margin: 0;
  padding: 12px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--text-2);
  white-space: pre-line;
  max-height: 360px;
  overflow: auto;
}

.db-maintenance-result-body:empty::before {
  content: "Aucun contr\00f4le lanc\00e9.";
  color: var(--text-3);
}

@media (max-width: 700px) {
  .db-maintenance-actions {
    grid-template-columns: 1fr;
  }
}

/* â”€â”€â”€ PAYMENT TOGGLE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.payment-toggle {
  display: flex; border-radius: var(--r-sm); overflow: hidden; border: 1px solid var(--border);
}
.payment-toggle button {
  flex: 1; padding: 12px; border: none; background: var(--surface-2);
  color: var(--text-3); font-family: var(--font-c); font-size: 13px;
  font-weight: 800; text-transform: uppercase; cursor: pointer; transition: all 0.18s; letter-spacing: 0.5px;
}
.payment-toggle button.active { background: linear-gradient(135deg, #00C853, #00E676); color: #fff; box-shadow: var(--glow-g); }
.payment-toggle button.unpaid.active { background: linear-gradient(135deg, #C62828, var(--red)); box-shadow: var(--glow-r); }

/* â”€â”€â”€ REGL BUTTONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.reglement-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.regl-btn {
  padding: 16px 6px; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text-3); font-family: var(--font-c);
  font-size: 13px; font-weight: 800; text-transform: uppercase; cursor: pointer;
  text-align: center; transition: all 0.18s; display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.regl-btn .regl-icon { font-size: 1.5rem; }
.regl-btn:hover { border-color: var(--border-2); color: var(--text-2); background: var(--surface-2); }
.regl-btn.active {
  border-color: rgba(255,82,0,0.58); color: var(--orange-2);
  background: var(--orange-dim);
  box-shadow: 0 0 0 1px rgba(255,82,0,0.22), var(--glow-o);
}

/* â”€â”€â”€ TOGGLE SWITCHES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.toggle-field {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 14px 16px; transition: border-color 0.18s;
}
.toggle-field:hover { border-color: var(--border-2); }
.toggle-label { display: flex; flex-direction: column; gap: 2px; }
.toggle-label strong { font-size: 14px; color: var(--text); }
.toggle-label small { font-size: 11px; color: var(--text-3); }
.tarif-options { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
@media (max-width: 700px) { .tarif-options { grid-template-columns: 1fr; } }
.toggle { position: relative; width: 52px; height: 28px; flex-shrink: 0; }
.toggle input { display: none; }
.slider {
  position: absolute; inset: 0; background: rgba(255,255,255,0.08);
  border: 1px solid var(--border); border-radius: 28px; cursor: pointer;
  transition: background 0.2s, border-color 0.2s, box-shadow 0.2s;
}
.slider::after {
  content: ''; position: absolute; width: 22px; height: 22px;
  background: linear-gradient(135deg, #bbb, #888); border-radius: 50%;
  top: 2px; left: 2px; transition: transform 0.2s, background 0.2s;
  box-shadow: 0 2px 8px rgba(0,0,0,0.55);
}
.toggle input:checked + .slider {
  background: linear-gradient(135deg, var(--orange), var(--orange-2));
  border-color: rgba(255,82,0,0.52); box-shadow: 0 0 14px rgba(255,82,0,0.40);
}
.toggle input:checked + .slider::after {
  transform: translateX(24px); background: linear-gradient(135deg, #fff, #ddd);
}

/* â”€â”€â”€ TARIF BADGE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tarif-badge {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  background: linear-gradient(135deg, rgba(255,82,0,0.12), rgba(255,82,0,0.04));
  border: 1px solid rgba(255,82,0,0.28); border-radius: var(--r-sm);
  padding: 18px; font-family: var(--font-c);
  box-shadow: 0 0 30px rgba(255,82,0,0.10);
}
.tarif-amount {
  font-size: 2.6rem; font-weight: 700; color: var(--orange); line-height: 1;
  text-shadow: 0 0 28px rgba(255,82,0,0.50);
}
.tarif-info .tarif-type  { font-size: 11px; color: var(--text-3); text-transform: uppercase; letter-spacing: 1px; }
.tarif-info .tarif-label { font-size: 17px; font-weight: 800; color: var(--text); }

/* â”€â”€â”€ STAT CARDS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.stats-bar { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 24px; }
.stat-card {
  background: linear-gradient(155deg, var(--surface-2) 0%, var(--surface) 100%);
  border: 1px solid var(--border); border-radius: var(--r);
  padding: 20px 12px; text-align: center;
  position: relative; overflow: hidden;
  transition: border-color 0.18s, box-shadow 0.18s;
}
.stat-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.11), transparent);
}
.stat-card::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--orange), transparent);
  opacity: 0; transition: opacity 0.28s;
}
.stat-card:hover { border-color: rgba(255,82,0,0.32); box-shadow: var(--glow-o); }
.stat-card:hover::after { opacity: 1; }
.stat-val {
  font-size: 2.1rem; font-weight: 700; color: var(--orange); line-height: 1;
  text-shadow: 0 0 24px rgba(255,82,0,0.42); display: block;
}
.stat-lbl {
  font-family: var(--font-c); font-size: 10px; color: var(--text-3);
  margin-top: 6px; text-transform: uppercase; letter-spacing: 1.4px; font-weight: 700;
}
.stat-card-lg { padding: 22px 14px; text-align: center; }
.stat-card-lg .stat-val { font-size: 2.5rem; }
.stats-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.stats-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 12px; }
#tab-annuaire .stats-bar { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.stats-section { margin-bottom: 28px; }
.stats-section-title {
  font-family: var(--font-c); font-size: 11px; font-weight: 800;
  letter-spacing: 2.5px; text-transform: uppercase; color: var(--orange-2);
  margin-bottom: 14px; display: flex; align-items: center; gap: 12px;
}
.stats-section-title::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, rgba(255,82,0,0.32), transparent);
}

/* Meteo mobile/tablette: stabilise les cartes et evite les valeurs tronquees. */
.meteo-panel .stat-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 142px;
}
.meteo-panel .stat-val {
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.05;
}
.meteo-panel .stat-lbl {
  min-height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 860px) {
  .meteo-panel .stats-bar,
  .meteo-panel .stats-grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .meteo-panel .stat-val {
    font-size: clamp(1.55rem, 7.5vw, 2rem);
  }
}

/* â”€â”€â”€ TILES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tile-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.tile-grid.compact { grid-template-columns: repeat(auto-fit, minmax(145px, 1fr)); gap: 12px; }

.tile-card {
  position: relative; overflow: hidden;
  background: linear-gradient(155deg, var(--surface-3) 0%, var(--surface) 100%);
  border: 1px solid var(--border); border-radius: var(--r);
  padding: 24px 18px; min-height: 140px;
  text-decoration: none; color: var(--text);
  display: flex; flex-direction: column; gap: 9px;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.22s, box-shadow 0.22s, transform 0.18s, background 0.22s;
}
.tile-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.13), transparent);
}
.tile-card::after {
  content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--orange), var(--orange-2));
  opacity: 0; transition: opacity 0.22s; border-radius: var(--r) 0 0 var(--r);
}
.tile-card:hover {
  background: linear-gradient(155deg, var(--surface-4) 0%, var(--surface-2) 100%);
  border-color: rgba(255,82,0,0.45); box-shadow: var(--shadow), var(--glow-o);
  transform: translateY(-3px);
}
.tile-card:hover::after { opacity: 1; }
.tile-card:active { transform: translateY(0); }
.tile-icon { font-size: 2rem; line-height: 1; filter: drop-shadow(0 0 10px rgba(255,82,0,0.20)); }
.tile-title { font-family: var(--font-c); font-size: 15px; font-weight: 900; letter-spacing: 0.8px; text-transform: uppercase; }
.tile-desc  { font-size: 12px; color: var(--text-2); line-height: 1.5; }
.tile-tag {
  position: absolute; top: 12px; right: 12px;
  background: var(--orange-dim); color: var(--orange-2);
  border: 1px solid rgba(255,82,0,0.35); padding: 3px 9px; border-radius: 999px;
  font-size: 10px; text-transform: uppercase; font-family: var(--font-c); letter-spacing: 0.1em; font-weight: 800;
}
.tile-card.disabled { opacity: 0.42; cursor: not-allowed; pointer-events: none; }
/* Primary tile */
.tile-card--primary {
  background: linear-gradient(135deg, rgba(255,82,0,0.22) 0%, rgba(255,82,0,0.08) 45%, var(--surface) 100%) !important;
  border-color: rgba(255,82,0,0.38) !important;
  box-shadow: var(--shadow), 0 0 32px rgba(255,82,0,0.20) !important;
}
.tile-card--primary .tile-title { color: var(--orange-2); }
.tile-card--primary:hover {
  border-color: rgba(255,82,0,0.68) !important;
  box-shadow: var(--shadow-lg), 0 0 52px rgba(255,82,0,0.32) !important;
}
.meteo-admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.field--span-2 {
  grid-column: 1 / -1;
}
.meteo-admin-switches {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin: 8px 0 18px;
}
.toggle-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
  font-size: 13px;
}
.meteo-admin-card {
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 12px;
}
.meteo-admin-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.meteo-admin-card__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.meteo-admin-badges {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.tile-card--meteo {
  background:
    radial-gradient(circle at top right, rgba(77, 182, 255, 0.18), transparent 36%),
    linear-gradient(160deg, rgba(11, 27, 45, 0.96) 0%, rgba(15, 28, 38, 0.98) 100%);
  border-color: rgba(77, 182, 255, 0.22);
  gap: 14px;
}
.tile-card--meteo:hover {
  background:
    radial-gradient(circle at top right, rgba(77, 182, 255, 0.24), transparent 38%),
    linear-gradient(160deg, rgba(14, 34, 53, 0.98) 0%, rgba(18, 33, 46, 1) 100%);
  border-color: rgba(77, 182, 255, 0.36);
  box-shadow: var(--shadow), 0 0 28px rgba(77, 182, 255, 0.18);
}
.tile-card--meteo::after {
  background: linear-gradient(180deg, #4db6ff, #7ce0ff);
}
.meteo-tile__head {
  display: flex;
  align-items: center;
  gap: 12px;
}
.meteo-tile__head .tile-icon {
  font-size: 1.75rem;
  color: #8fe8ff;
  filter: drop-shadow(0 0 10px rgba(77, 182, 255, 0.24));
}
.meteo-tile__eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(212, 235, 245, 0.68);
  font-family: var(--font-c);
}
.meteo-tile__hero {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.meteo-tile__selector {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.meteo-tile__selector select {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(143, 232, 255, 0.14);
  background: rgba(255, 255, 255, 0.05);
  color: #f3fbff;
  font-size: 13px;
}
.meteo-tile__temp {
  font-family: var(--font-c);
  font-size: 1.9rem;
  line-height: 1;
  color: #f3fbff;
  letter-spacing: -0.03em;
}
.meteo-tile__condition {
  font-size: 13px;
  color: rgba(228, 240, 245, 0.82);
  line-height: 1.45;
}
.meteo-tile__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.meteo-tile__stat {
  min-width: 0;
  padding: 10px 11px;
  border-radius: 14px;
  border: 1px solid rgba(143, 232, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.meteo-tile__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: rgba(198, 223, 233, 0.6);
  font-family: var(--font-c);
}
.meteo-tile__stat strong {
  font-size: 13px;
  font-weight: 700;
  color: #f3fbff;
  line-height: 1.35;
}
.meteo-tile__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: auto;
}
.tile-card--meteo .btn-sm.orange {
  border-color: rgba(77, 182, 255, 0.28);
  background: rgba(77, 182, 255, 0.12);
  color: #d7f5ff;
}
.tile-card--meteo .btn-sm.orange:hover {
  background: rgba(77, 182, 255, 0.2);
  box-shadow: 0 0 16px rgba(77, 182, 255, 0.14);
}

/* â”€â”€â”€ EXPORT CARD â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.export-card { padding: 22px 24px; margin-bottom: 18px; }
.export-title { font-family: var(--font-c); font-size: 20px; font-weight: 900; margin-bottom: 6px; color: var(--text); }
.export-version { font-family: var(--font-c); font-size: 12px; color: var(--text-3); margin-bottom: 10px; }
.export-desc { font-size: 13px; color: var(--text-2); margin-bottom: 14px; line-height: 1.6; }

/* â”€â”€â”€ FILTER BAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.filter-bar { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.filter-bar input  { flex: 1; min-width: 160px; padding: 10px 14px; font-size: 14px; }
.filter-bar select { flex: 0 0 200px; min-width: 160px; width: auto; padding: 10px 14px; font-size: 14px; }
.filter-bar .btn-sm { align-self: center; }

/* â”€â”€â”€ RIDER CARDS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.rider-card { padding: 16px 16px 16px 20px; margin-bottom: 10px; }
.rider-card:hover { border-color: var(--border-2); }
.rider-card::before {
  top: 0; left: 0; bottom: 0; right: auto; width: 3px; height: auto;
  background: var(--border); border-radius: var(--r) 0 0 var(--r);
}
.rider-card.paid::before   { background: var(--green); box-shadow: 0 0 14px rgba(0,230,118,0.42); }
.rider-card.unpaid::before { background: var(--red);   box-shadow: 0 0 14px rgba(255,23,68,0.40); }
.rider-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 10px; gap: 8px; }
.rider-header > div:first-child { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.rider-name { font-family: var(--font-c); font-size: 18px; font-weight: 700; line-height: 1.2; color: var(--text); }
.rider-num  {
  font-size: 1.8rem; font-weight: 700; color: var(--orange); line-height: 1;
  text-shadow: 0 0 18px rgba(255,82,0,0.40);
}
#tab-pilotes .rider-num, .rider-num-plate {
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #f6f2e8 0%, #f6f2e8 74%, rgba(255,82,0,.38) 74%, rgba(255,82,0,.38) 100%);
  color: #121212; border: 2px solid #121212; border-radius: 6px;
  padding: 6px 10px; min-width: 46px; text-align: center; letter-spacing: 1px;
  box-shadow: inset 0 0 0 1px rgba(255,82,0,.32), 0 4px 14px rgba(0,0,0,.52);
}
.rider-card .rider-plate, .rider-card-directory .rider-plate { flex: 0 0 auto; display: flex; align-items: center; justify-content: flex-end; margin-left: 12px; }
.rider-meta    { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.rider-licence { font-size: 11px; color: var(--text-3); font-family: var(--font-c); letter-spacing: 1px; }
.rider-tarif   { font-family: var(--font-c); font-weight: 700; font-size: 14px; }
.rider-actions { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.directory-card-head { display: flex; flex-direction: column; gap: 8px; width: 100%; }
.directory-card-badges { display: flex; flex-wrap: wrap; gap: 6px; }
.directory-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
}
.directory-card-item {
  background: linear-gradient(155deg, var(--surface-2) 0%, var(--surface) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-xs);
  padding: 8px 10px;
}
.directory-card-item span {
  display: block;
  font-size: 11px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 2px;
}
.directory-card-item strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  word-break: break-word;
}
@media (max-width: 640px) {
  .directory-card-grid { grid-template-columns: 1fr; }
}

/* â”€â”€â”€ PLATE SYSTEM â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.plate-svg { display: flex; align-items: center; justify-content: center; }
.plate-svg svg { width: 100%; height: auto; display: block; filter: drop-shadow(0 6px 18px rgba(0,0,0,.60)); }
.plate-svg--lg   { width: calc(var(--logo-h) * 1.38); }
.plate-svg--mini { width: calc(var(--plate-h, 22px) * 1.25); }
.plate-simple {
  --plate-bg: #f8fafc; --plate-text: #0f172a; --plate-h: 104px;
  --plate-shape: polygon(10% 14%,18% 4%,82% 4%,90% 14%,96% 38%,90% 86%,62% 98%,38% 98%,10% 86%,4% 38%);
  width: 150px; height: var(--plate-h); display: grid; grid-template-rows: auto 1fr;
  align-items: center; text-align: center; padding: 6px 8px; gap: 4px;
  position: relative; overflow: hidden; clip-path: var(--plate-shape);
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.60));
}
.plate-simple::before { content:''; position:absolute; inset:0; background:linear-gradient(145deg,rgba(255,255,255,.28),rgba(0,0,0,.26)),var(--plate-bg); box-shadow:inset 0 0 0 2px rgba(11,15,24,.9); z-index:0; pointer-events:none; }
.plate-simple::after  { content:''; position:absolute; inset:6px; box-shadow:inset 0 0 0 1px rgba(255,255,255,.75); background:linear-gradient(135deg,rgba(255,255,255,.24),rgba(255,255,255,0) 60%); z-index:0; pointer-events:none; }
.plate-simple > * { position:relative; z-index:1; }
.plate-xxl { --plate-xxl-h:var(--logo-h); --plate-h:var(--plate-xxl-h); width:calc(var(--plate-xxl-h)*1.38); height:var(--plate-xxl-h); padding:calc(var(--plate-xxl-h)*0.1) calc(var(--plate-xxl-h)*0.12); border-radius:calc(var(--plate-xxl-h)*0.18); }
.plate-xxl .plate-simple__num { font-size:calc(var(--plate-xxl-h)*0.58); }
.plate-xxl .plate-simple__name, .plate-xxl .plate-simple__club { font-size:calc(var(--plate-xxl-h)*0.22); padding:calc(var(--plate-xxl-h)*0.08) calc(var(--plate-xxl-h)*0.12); }
.plate-mini { width:calc(var(--plate-h,22px)*1.25); height:var(--plate-h,22px); padding:calc(var(--plate-h,22px)*0.08); gap:calc(var(--plate-h,22px)*0.04); }
.plate-mini::before { inset:0; }
.plate-mini .plate-simple__num { font-size:calc(var(--plate-h,22px)*0.5); }
.plate-mini .plate-simple__name,.plate-mini .plate-simple__club { font-size:calc(var(--plate-h,22px)*0.16); padding:calc(var(--plate-h,22px)*0.03) calc(var(--plate-h,22px)*0.05); }
.plate-simple__name,.plate-simple__club { font-family:'Racing Sans One',var(--font-c),sans-serif; font-weight:800; font-size:clamp(.55rem,calc(var(--plate-h)*.12),1.05rem); color:#fff; background:rgba(0,0,0,.55); border:1px solid rgba(255,255,255,.2); border-radius:999px; padding:4px 8px; text-transform:uppercase; letter-spacing:.06em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-shadow:0 1px 0 rgba(0,0,0,.35); }
.plate-simple__num { font-family:'Black Ops One',var(--font-c),sans-serif; font-weight:900; font-size:clamp(1.6rem,calc(var(--plate-h)*.6),4.6rem); line-height:1; color:var(--plate-text); text-shadow:0 2px 0 rgba(0,0,0,.35),0 8px 14px rgba(0,0,0,.3); letter-spacing:.02em; }
.plate-simple__club { display:none; background:rgba(255,255,255,.92); color:#0b0f18; border-color:rgba(0,0,0,.45); font-weight:900; }
@media (max-width:640px) { .plate-simple { width:132px; height:96px; } .plate-simple__num { font-size:2rem; } }
.sx23 { --name:"PILOTE"; --num:"00"; --team:"CLUB"; --blue1:#0b56c6; --blue2:#0a2e74; --blue3:#071a3b; --num-color:#fff; --num-stroke:rgba(0,0,0,.6); --yellow:#f6c300; --band-text:#0b0f18; width:clamp(180px,28vw,240px); aspect-ratio:16/9; height:auto; position:relative; filter:drop-shadow(0 10px 18px rgba(0,0,0,.45)); margin:0; }
.sx23::before { content:""; position:absolute; inset:0; border-radius:18px; border:4px solid #0b0f18; background:linear-gradient(140deg,var(--blue1) 0%,color-mix(in srgb,var(--blue1),#fff 12%) 32%,var(--blue2) 72%,var(--blue3) 100%); clip-path:polygon(6% 18%,15% 8%,85% 8%,94% 18%,98% 40%,92% 86%,55% 98%,45% 98%,8% 86%,2% 40%); }
.sx23::after { content:""; position:absolute; inset:10px; border-radius:14px; border:3px solid rgba(255,255,255,.95); clip-path:polygon(7% 20%,16% 11%,84% 11%,93% 20%,96% 40%,91% 84%,55% 96%,45% 96%,9% 84%,4% 40%); pointer-events:none; }
.sx23__inner { position:absolute; inset:0; display:grid; grid-template-rows:1fr 2.1fr 1fr; padding:16px 22px; font-family:system-ui,-apple-system,sans-serif; text-transform:uppercase; letter-spacing:.06em; color:#fff; }
.sx23__top { align-self:start; justify-self:center; width:82%; height:34px; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:.72rem; background:linear-gradient(180deg,rgba(0,0,0,.85),rgba(0,0,0,.55)); border:2px solid rgba(255,255,255,.9); border-radius:12px; transform:translateY(2px); text-shadow:0 2px 0 rgba(0,0,0,.35); padding:0 8px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sx23__top::before { content:var(--name); }
.sx23__wings { position:absolute; inset:0; clip-path:polygon(6% 18%,15% 8%,85% 8%,94% 18%,98% 40%,92% 86%,55% 98%,45% 98%,8% 86%,2% 40%); pointer-events:none; }
.sx23__wings::before { content:""; position:absolute; inset:0; background:linear-gradient(135deg,transparent 0 16%,rgba(255,255,255,.9) 16% 22%,transparent 22% 100%),linear-gradient(225deg,transparent 0 16%,rgba(255,255,255,.9) 16% 22%,transparent 22% 100%),linear-gradient(45deg,transparent 0 18%,rgba(255,255,255,.85) 18% 24%,transparent 24% 100%),linear-gradient(315deg,transparent 0 18%,rgba(255,255,255,.85) 18% 24%,transparent 24% 100%); opacity:.95; mix-blend-mode:screen; }
.sx23__wings::after { content:""; position:absolute; inset:0; background:linear-gradient(145deg,rgba(0,0,0,.55),transparent 55%),linear-gradient(215deg,rgba(0,0,0,.55),transparent 55%),radial-gradient(120% 80% at 50% 65%,rgba(0,0,0,.55),transparent 60%); opacity:.55; }
.sx23__num { align-self:center; justify-self:center; font-weight:950; font-size:clamp(52px,9vw,88px); line-height:1; letter-spacing:.02em; color:var(--num-color); text-shadow:0 10px 18px rgba(0,0,0,.30); -webkit-text-stroke:10px var(--num-stroke); paint-order:stroke fill; }
.sx23__num::before { content:var(--num); }
.sx23__bottom { align-self:end; justify-self:center; width:64%; height:32px; display:flex; align-items:center; justify-content:center; font-weight:950; color:var(--band-text); font-size:.7rem; background:linear-gradient(180deg,#ffd84a,var(--yellow)); border-radius:10px; border:2px solid rgba(0,0,0,.75); transform:translateY(-2px); box-shadow:0 8px 16px rgba(0,0,0,.18); padding:0 8px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sx23__bottom::before { content:var(--team); }
.sx23__tip { position:absolute; left:50%; bottom:0; width:38%; height:36%; transform:translateX(-50%); background:linear-gradient(180deg,rgba(0,0,0,.75),rgba(0,0,0,.92)); clip-path:polygon(10% 0,90% 0,70% 100%,30% 100%); opacity:.95; pointer-events:none; }
@media (max-width:640px) { .sx23 { width:clamp(150px,48vw,190px); } .sx23__num { font-size:clamp(44px,14vw,70px); } .sx23__top,.sx23__bottom { font-size:.62rem; } }

/* â”€â”€â”€ BADGES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge { display:inline-flex; align-items:center; padding:3px 10px; border-radius:999px; font-family:var(--font-c); font-size:11px; font-weight:800; letter-spacing:0.6px; text-transform:uppercase; }
.badge-ort    { background:rgba(41,121,255,0.14);  color:#6FA3FF; border:1px solid rgba(41,121,255,0.28); }
.badge-onia   { background:rgba(170,0,255,0.12);   color:#CC66FF; border:1px solid rgba(170,0,255,0.28); }
.badge-ext    { background:var(--surface-2);       color:var(--text-3); border:1px solid var(--border); }
.badge-paid   { background:var(--green-dim);       color:var(--green);  border:1px solid rgba(0,230,118,0.28); }
.badge-unpaid { background:var(--red-dim);         color:var(--red);    border:1px solid rgba(255,23,68,0.28); }
.badge-cash   { background:rgba(0,230,118,0.08);   color:var(--green);  border:1px solid rgba(0,230,118,0.20); }
.badge-cheque { background:rgba(41,121,255,0.08);  color:#6FA3FF;       border:1px solid rgba(41,121,255,0.20); }
.badge-wero   { background:rgba(170,0,255,0.08);   color:#CC66FF;       border:1px solid rgba(170,0,255,0.20); }
.badge-orange { background:var(--orange-dim);      color:var(--orange-2);border:1px solid rgba(255,82,0,0.25); }
.badge-green  { background:var(--green-dim);       color:var(--green);  border:1px solid rgba(0,230,118,0.28); }
.badge-red    { background:var(--red-dim);         color:var(--red);    border:1px solid rgba(255,23,68,0.28); }

/* â”€â”€â”€ USERS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.users-layout { display:grid; grid-template-columns:minmax(260px,360px) 1fr; gap:18px; align-items:start; }
@media (max-width:980px) { .users-layout { grid-template-columns:1fr; } }
.users-submenu-grid { margin-top: 14px; margin-bottom: 18px; }
.user-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:10px; margin-top:10px; }
.user-grid .field { margin-bottom:0; }
.user-card { padding:16px; margin-bottom:10px; }
.user-card:hover { border-color:var(--border-2); }
.user-header { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.user-name { font-weight:700; color:var(--text); font-family:var(--font-c); font-size:15px; }
.user-role { font-size:11px; color:var(--text-3); margin-top:2px; text-transform:uppercase; letter-spacing:.05em; font-family:var(--font-c); font-weight:700; }
.user-meta { font-size:13px; color:var(--text-3); margin-top:4px; }
.role-pill { background:var(--surface-2); border:1px solid var(--border-2); border-radius:999px; padding:4px 12px; font-size:11px; text-transform:uppercase; letter-spacing:.08em; font-weight:700; font-family:var(--font-c); color:var(--text-2); }

/* â”€â”€â”€ PERMISSIONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.perm-panel { background:linear-gradient(155deg,var(--surface-2) 0%,var(--surface) 100%); border:1px solid var(--border); border-radius:var(--r); padding:14px; overflow:hidden; }
.perm-legend { font-size:12px; color:var(--text-3); margin-bottom:8px; }
.perm-module { margin-bottom:12px; }
.perm-module-title { font-family:var(--font-c); font-weight:800; text-transform:uppercase; font-size:12px; color:var(--orange-2); margin-bottom:6px; }
.perm-row { display:grid; grid-template-columns:1fr 120px; gap:8px; padding:6px 0; border-bottom:1px dashed var(--border); }
.perm-row:last-child { border-bottom:0; }
.perm-label { font-size:13px; } .perm-select { width:100%; }
.perm-base { font-size:11px; color:var(--text-3); } .perm-allow { color:var(--green); } .perm-deny { color:var(--red); }
.matrix-toolbar { display:flex; gap:12px; align-items:flex-end; flex-wrap:wrap; margin:12px 0; }
.matrix-toolbar .field { margin-bottom:0; }
.perm-meteo-frame {
  margin-top: 10px;
  margin-bottom: 10px;
  padding: 12px 14px;
  border-radius: var(--r-sm);
  border: 1px solid rgba(41,121,255,0.38);
  background: linear-gradient(135deg, rgba(41,121,255,0.12), rgba(41,121,255,0.03));
}
.perm-meteo-title {
  font-family: var(--font-c);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #6FA3FF;
  margin-bottom: 4px;
}
.perm-meteo-desc {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.45;
}
.matrix-toggle { display:inline-flex; align-items:center; gap:8px; font-size:13px; color:var(--text); }
.matrix-actions { margin-top:10px; }
.matrix-actions .matrix-reset-btn {
  min-height: 50px;
  padding: 15px 24px;
  border-radius: var(--r-sm);
  font-size: 15px;
  letter-spacing: 1.5px;
}
.perm-group-title { font-family:var(--font-c); font-size:13px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--orange-2); margin:12px 0 7px; }
.perm-matrix-wrap { border:1px solid var(--border); border-radius:var(--r); background:var(--bg-2); overflow:auto; }
.perm-matrix { border-collapse:collapse; font-size:12px; table-layout:fixed; width:max-content; }
.perm-matrix th,.perm-matrix td { border:1px solid var(--border); padding:6px; text-align:center; }
.perm-matrix th { background:var(--surface-2); color:var(--text-3); font-family:var(--font-c); font-size:11px; letter-spacing:.06em; text-transform:uppercase; }
.perm-user { text-align:left; white-space:nowrap; background:var(--bg-2); position:sticky; left:0; z-index:2; font-weight:700; width:var(--perm-user-col); min-width:var(--perm-user-col); max-width:var(--perm-user-col); overflow:hidden; text-overflow:ellipsis; }
.perm-sticky { position:sticky; left:0; z-index:3; width:var(--perm-user-col); min-width:var(--perm-user-col); max-width:var(--perm-user-col); }
.perm-module-head { background:var(--surface-2); color:var(--orange-2); }
.perm-perm-head { white-space:normal; width:var(--perm-col); min-width:var(--perm-col); max-width:var(--perm-col); word-break:break-word; }
.perm-col-user { width:var(--perm-user-col); } .perm-col-perm { width:var(--perm-col); }
.perm-cell { width:28px; height:26px; border-radius:var(--r-xs); border:1px solid var(--border); background:var(--surface); color:var(--text-3); font-weight:800; cursor:pointer; transition:all .15s; }
.perm-cell:hover { border-color:var(--border-2); }
.perm-cell[data-state="allow"] { background:var(--green-dim); border-color:rgba(0,230,118,.35); color:var(--green); }
.perm-cell[data-state="deny"]  { background:var(--red-dim);   border-color:rgba(255,23,68,.35);  color:var(--red); }
.perm-cell.perm-base-allow { box-shadow:inset 0 0 0 1px rgba(0,230,118,.25); }
.perm-cell.perm-base-deny  { box-shadow:inset 0 0 0 1px rgba(255,23,68,.25); }
.perm-matrix-empty { color:var(--text-3); font-size:13px; padding:10px; }

/* LOGS */
.logs-filter-bar input[type="date"] { flex: 0 0 170px; min-width: 150px; }
.logs-filter-bar select { flex: 0 0 210px; min-width: 170px; }
.logs-action-row { margin-bottom: 12px; }
.logs-action-row #logs-export-btn[data-disabled="true"] {
  opacity: 0.40;
  cursor: not-allowed;
  filter: grayscale(30%);
  pointer-events: none;
}
.logs-purge-row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.logs-purge-row.hidden { display: none; }
.logs-purge-row label { font-size: 12px; color: var(--text-2); }
.logs-purge-row input[type="date"] { width: 180px; min-width: 160px; }
.logs-table-wrap { max-height: 520px; }
.logs-table { min-width: 980px; width: 100%; }
.logs-table td { text-align: left; vertical-align: top; }
.logs-table .logs-row { cursor: pointer; }
.logs-table .logs-row.active td { background: rgba(255,82,0,0.10); }
.logs-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
}
.logs-detail {
  margin: 0;
  padding: 12px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  max-height: 380px;
  overflow: auto;
  font-size: 12px;
  line-height: 1.5;
  color: var(--text);
}
.perm-user-name { font-weight:700; }
.perm-user-role { font-size:11px; color:var(--text-3); margin-top:2px; text-transform:uppercase; letter-spacing:.05em; }

/* â”€â”€â”€ PERIOD TABS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.period-tabs { display:flex; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-sm); padding:3px; margin-bottom:18px; gap:2px; }
.period-btn { flex:1; padding:10px 4px; background:none; border:none; border-radius:var(--r-xs); color:var(--text-3); font-family:var(--font-c); font-size:12px; font-weight:800; text-transform:uppercase; cursor:pointer; transition:all .18s; letter-spacing:.8px; }
.period-btn:hover { color:var(--text-2); background:var(--surface-2); }
.period-btn.active { background:linear-gradient(135deg,var(--orange),var(--orange-2)); color:#fff; box-shadow:0 2px 16px rgba(255,82,0,.40); }

/* â”€â”€â”€ BAR CHART â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.regl-stat { background:linear-gradient(155deg,var(--surface-2) 0%,var(--surface) 100%); border:1px solid var(--border); border-radius:var(--r); padding:14px 16px; margin-bottom:8px; display:flex; align-items:center; justify-content:space-between; overflow:visible; position:relative; }
.regl-stat::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.10),transparent); }
.regl-stat:hover { border-color:rgba(255,82,0,0.22); }
.regl-stat-label { font-family:var(--font-c); font-size:14px; font-weight:700; display:flex; align-items:center; gap:8px; }
.regl-stat-vals { text-align:right; font-family:var(--font-c); }
.regl-stat-amount { font-size:17px; font-weight:900; color:var(--green); }
.regl-stat-count { font-size:11px; color:var(--text-3); }
.bar-chart { margin-top:10px; }
.bar-row { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.bar-label { font-size:11px; color:var(--text-3); width:36px; text-align:right; font-family:var(--font-c); flex-shrink:0; }
.bar-wrap { flex:1; background:var(--surface-2); border-radius:5px; height:24px; overflow:hidden; border:1px solid var(--border); }
.bar-fill { height:100%; border-radius:5px; min-width:24px; background:linear-gradient(90deg,var(--orange),var(--orange-2)); display:flex; align-items:center; padding-left:8px; transition:width 0.55s cubic-bezier(.4,0,.2,1); box-shadow:0 0 10px rgba(255,82,0,0.28); }
.bar-val { font-size:11px; font-weight:700; color:#fff; font-family:var(--font-c); }

/* â”€â”€â”€ MODALS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.edit-modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.90); z-index:200; align-items:flex-end; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.edit-modal.open { display:flex; }
.edit-sheet { background:linear-gradient(180deg,var(--bg-3) 0%,var(--bg-2) 100%); border-top:2px solid var(--orange); border-radius:var(--r-xl) var(--r-xl) 0 0; padding:24px 18px; width:100%; max-height:88dvh; overflow-y:auto; box-shadow:0 -20px 70px rgba(0,0,0,.88), 0 -1px 0 rgba(255,82,0,0.42); }
.edit-sheet-title { font-family:var(--font-c); font-size:22px; font-weight:900; text-transform:uppercase; margin-bottom:20px; text-align:center; background:linear-gradient(135deg,var(--orange),var(--orange-2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; letter-spacing:1px; }
.directory-view-hero {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.directory-view-head {
  flex: 1;
  min-width: 0;
  background: linear-gradient(155deg, var(--surface-2) 0%, var(--surface) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px;
}
.directory-view-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.directory-view-plate {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: calc(var(--logo-h) * 1.5);
  padding: 8px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
}
.directory-view-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.directory-view-card {
  background: linear-gradient(155deg, var(--surface-2) 0%, var(--surface) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px;
}
.directory-view-card-title {
  font-family: var(--font-c);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--orange-2);
  margin-bottom: 8px;
}
.directory-view-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 7px;
}
.directory-view-row:last-child { margin-bottom: 0; }
.directory-view-row span { color: var(--text-3); font-size: 12px; }
.directory-view-row strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  text-align: right;
  word-break: break-word;
}
.directory-view-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.directory-view-actions .btn-sm {
  flex: 1 1 160px;
  text-align: center;
}
.mx-view-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.mx-view-card {
  background: linear-gradient(155deg, var(--surface-2) 0%, var(--surface) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px;
}
.mx-view-card-full { grid-column: 1 / -1; }
.mx-view-card-title {
  font-family: var(--font-c);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--orange-2);
  margin-bottom: 8px;
}
.mx-view-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 7px;
}
.mx-view-row:last-child { margin-bottom: 0; }
.mx-view-row span {
  color: var(--text-3);
  font-size: 12px;
}
.mx-view-row strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  text-align: right;
  word-break: break-word;
}
.mx-view-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mx-view-text {
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.45;
  margin-bottom: 6px;
  word-break: break-word;
}
.mx-view-text:last-child { margin-bottom: 0; }
.mx-view-empty {
  color: var(--text-3);
  font-size: 12px;
}
.mx-view-actions .btn-sm {
  width: 100%;
  text-align: center;
}
@media (max-width: 640px) {
  .directory-view-hero {
    flex-direction: column;
    align-items: stretch;
  }
  .directory-view-plate {
    min-width: 0;
  }
  .directory-view-row {
    flex-direction: column;
    gap: 2px;
  }
  .directory-view-row strong { text-align: left; }
  .mx-view-row {
    flex-direction: column;
    gap: 2px;
  }
  .mx-view-row strong { text-align: left; }
}
.confirm-body { font-size:14px; color:var(--text); text-align:center; margin-bottom:18px; white-space:pre-line; line-height:1.6; }
.confirm-actions { display:flex; gap:10px; }
.confirm-actions .btn-sm { flex:1; text-align:center; }
#pdf-modal { align-items:stretch; padding:0; }
.pdf-sheet { display:flex; flex-direction:column; gap:12px; width:100vw; height:100dvh; max-height:100dvh; margin:0; border-radius:0; overflow:hidden; }
.pdf-frame-wrap { flex:1 1 auto; min-height:0; border-radius:0; border:1px solid var(--border); background:#fff; overflow:hidden; }
#pdf-frame { width:100%; height:100%; border:0; display:block; background:#fff; }

/* â”€â”€â”€ EMPTY STATES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.empty-state { text-align:center; padding:52px 20px; color:var(--text-3); }
.empty-state .icon { font-size:3.2rem; margin-bottom:14px; opacity:0.45; display:block; }
.empty-state p { font-size:13px; line-height:1.7; }
.no-results { text-align:center; padding:32px; color:var(--text-3); font-size:13px; }

/* â”€â”€â”€ NOTIFY / TOAST â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.notify-container { position:fixed; top:calc(var(--header-h) + 14px); right:16px; z-index:9999; display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.notify { background:var(--bg-4); border:1px solid var(--border-2); border-left:3px solid var(--orange); color:var(--text); padding:11px 16px; border-radius:var(--r-sm); font-family:var(--font-c); font-weight:700; font-size:13px; box-shadow:var(--shadow); animation:slideIn 0.2s ease-out; max-width:320px; }
.notify.warning { border-left-color:#FF9800; } .notify.error { border-left-color:var(--red); } .notify.success { border-left-color:var(--green); }
.toast { position:fixed; bottom:90px; left:50%; transform:translateX(-50%) translateY(16px); background:var(--bg-4); border:1px solid var(--border-2); border-radius:var(--r-sm); padding:12px 24px; font-family:var(--font-c); font-size:14px; font-weight:700; z-index:500; opacity:0; transition:all 0.28s cubic-bezier(.4,0,.2,1); white-space:nowrap; max-width:90vw; text-align:center; pointer-events:none; box-shadow:var(--shadow); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.success { border-left:3px solid var(--green); color:var(--green); }
.toast.error   { border-left:3px solid var(--red);   color:var(--red); }
.toast.info    { border-left:3px solid var(--orange); color:var(--orange-2); }

/* â”€â”€â”€ FOOTER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.site-footer { margin-top:36px; text-align:center; padding:20px 12px 30px; color:var(--text-4); font-family:var(--font-c); font-size:12px; letter-spacing:0.6px; border-top:1px solid var(--border); }

/* â”€â”€â”€ LOGIN â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-page { min-height:100dvh; padding:24px 16px; display:flex; align-items:center; justify-content:center; }
.login-wrap { width:100%; max-width:420px; }
.login-card {
  background:linear-gradient(155deg,var(--surface-3) 0%,var(--surface) 100%);
  border:1px solid rgba(255,82,0,0.24); border-radius:var(--r-xl);
  padding:36px 28px 28px;
  box-shadow:0 36px 72px rgba(0,0,0,.88), 0 0 0 1px rgba(255,255,255,.03), 0 0 90px rgba(255,82,0,0.12);
  position:relative; overflow:hidden;
}
.login-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--orange) 25%,var(--orange-2) 65%,transparent);
  opacity:0.9;
}
.login-logo-shell { width:100%; margin:0 auto 24px; display:flex; justify-content:center; filter:drop-shadow(0 0 32px rgba(255,82,0,0.42)); }
.login-logo { display:block; width:min(65vw,200px); height:auto; }
.login-title { text-align:center; margin-bottom:10px; font-size:11px; letter-spacing:3px; justify-content:center; }
@media (max-width:480px) { .login-card { padding:28px 20px 22px; } .login-logo { width:min(70vw,180px); } }

/* â”€â”€â”€ COMPTE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.compte-wrap { max-width:520px; margin:0 auto; }
.compte-user-badge {
  display:flex; align-items:center; gap:16px;
  background:linear-gradient(135deg,rgba(255,82,0,0.12),rgba(255,82,0,0.04));
  border:1px solid rgba(255,82,0,0.25); border-radius:var(--r);
  padding:18px 20px; margin-bottom:20px;
}
.compte-avatar {
  width:52px; height:52px; border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--orange-2));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-c); font-size:22px; font-weight:900; color:#fff;
  flex-shrink:0; box-shadow:0 0 22px rgba(255,82,0,0.40);
}
.compte-user-info { flex:1; min-width:0; }
.compte-username { font-family:var(--font-c); font-size:20px; font-weight:800; color:var(--text); line-height:1; }
.compte-role { font-size:12px; color:var(--text-3); margin-top:4px; text-transform:uppercase; letter-spacing:1px; font-family:var(--font-c); font-weight:700; }

/* â”€â”€â”€ SCROLLBAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
* { scrollbar-width:thin; scrollbar-color:rgba(255,255,255,0.10) transparent; }
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.10); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:rgba(255,82,0,0.45); }
::selection { background:rgba(255,82,0,0.28); color:#fff; }
a { color:inherit; }

/* â”€â”€â”€ ANIMATIONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@keyframes fadeIn  { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeInFast { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
@keyframes slideIn { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }
@keyframes pulse-green { 0%,100%{box-shadow:0 0 0 0 var(--green-glow)} 50%{box-shadow:0 0 0 8px transparent} }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.4} }
@keyframes shimmer { from{transform:translateX(-100%)} to{transform:translateX(100%)} }

.panel.active > * { animation:fadeIn 0.30s ease-out both; }
.panel.active > *:nth-child(1) { animation-delay:0.00s; }
.panel.active > *:nth-child(2) { animation-delay:0.06s; }
.panel.active > *:nth-child(3) { animation-delay:0.12s; }
.panel.active > *:nth-child(4) { animation-delay:0.18s; }
.panel.active > *:nth-child(5) { animation-delay:0.24s; }
.panel.active > *:nth-child(6) { animation-delay:0.30s; }
.tile-card { animation:fadeIn 0.25s ease-out; }
.rider-card { animation:fadeInFast 0.20s ease-out; }

/* â”€â”€â”€ PRINT â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media print {
  body { background:white; color:black; }
  body::before,body::after { display:none; }
  .card,.form-section,.export-card,.rider-card { background:white!important; border:1px solid #ddd!important; box-shadow:none!important; }
  header,.tabs,.site-footer,.action-row { display:none!important; }
}

/* â”€â”€â”€ RESPONSIVE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:640px) {
  .form-section { padding:16px; }
  .export-card  { padding:16px 18px; }
  .card         { padding:16px; }
  .page-hero    { padding:24px 20px 22px; }
  .page-hero h1 { font-size:28px; }
  .stats-bar    { gap:8px; }
  .tile-grid    { grid-template-columns:repeat(auto-fit,minmax(145px,1fr)); gap:10px; }
  .meteo-tile__grid { grid-template-columns: 1fr; }
  .meteo-admin-grid { grid-template-columns: 1fr; }
  .meteo-admin-card__head { flex-direction: column; }
  .meteo-tile__actions { justify-content: stretch; }
  .meteo-tile__actions .btn-sm { width: 100%; }

  .meteo-panel .stat-card {
    padding: 16px 10px;
  }
  .meteo-panel .stat-lbl {
    font-size: 9px;
    letter-spacing: 1px;
  }
}

@media (max-width:420px) {
  .meteo-panel .stats-bar,
  .meteo-panel .stats-grid-3 {
    grid-template-columns: 1fr;
  }
}



/* Meteo page: phone-first refinements */
.meteo-panel .meteo-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.meteo-panel .meteo-badges .badge {
  margin: 0;
}
.meteo-panel .meteo-details {
  margin-top: 2px;
}
.meteo-panel .meteo-kv-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 10px;
}
.meteo-panel .meteo-kv {
  border: 1px solid var(--border);
  border-radius: var(--r-xs);
  background: rgba(255, 255, 255, 0.02);
  padding: 9px 10px;
  font-size: 12px;
  line-height: 1.45;
  color: var(--text-2);
  overflow-wrap: anywhere;
}
.meteo-panel .meteo-warning {
  margin-top: 10px;
  border: 1px solid rgba(255, 82, 0, 0.25);
  border-radius: var(--r-xs);
  background: rgba(255, 82, 0, 0.08);
  padding: 10px 12px;
  font-size: 12px;
  line-height: 1.45;
}
.meteo-panel .meteo-source {
  margin-bottom: 0;
}
.meteo-panel .meteo-forecast-grid {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}
.meteo-panel .meteo-forecast-card {
  min-height: 0;
  padding: 16px 14px;
  gap: 5px;
}
.meteo-panel .meteo-forecast-card .tile-title {
  font-size: 14px;
}
.meteo-panel .meteo-forecast-card .tile-desc {
  line-height: 1.35;
}
.meteo-panel .meteo-actions {
  margin-top: 16px;
}

@media (max-width: 700px) {
  .meteo-panel .meteo-kv-grid {
    grid-template-columns: 1fr;
  }
  .meteo-panel .meteo-forecast-grid {
    grid-template-columns: 1fr;
  }
  .meteo-panel .meteo-actions {
    flex-wrap: wrap;
  }
  .meteo-panel .meteo-actions .btn-export,
  .meteo-panel .meteo-actions .btn-export-back {
    flex: 1 1 100%;
    order: 0;
  }
}
