/* ============================================================
   FLAG FOOTBALL — Team Hub stylesheet
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Archivo:wght@400;500;700;900&family=JetBrains+Mono:wght@400;700&display=swap');

:root{
  --bg:#0a0a0a;
  --bg-2:#141414;
  --ink:#f4f1ea;
  --ink-dim:#8a8680;
  --accent:#ff4d1c;
  --accent-2:#ffd23f;
  --line:#2a2a2a;
  --ok:#4ade80;
  --err:#ef4444;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Archivo',sans-serif;
  background:var(--bg);
  color:var(--ink);
  overflow-x:hidden;
  background-image:
    radial-gradient(circle at 20% 10%,rgba(255,77,28,.12),transparent 40%),
    radial-gradient(circle at 80% 90%,rgba(255,210,63,.06),transparent 50%);
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);
  background-size:40px 40px;
}
a{color:inherit;text-decoration:none}

/* ===== LOGIN ===== */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-wrap{width:100%;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;z-index:1}
.login-card{
  width:100%;max-width:440px;
  background:var(--bg-2);
  border:1px solid var(--line);
  padding:48px 40px;
  position:relative;
}
.login-card::before{
  content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:4px;
  background:linear-gradient(90deg,var(--accent) 0%,var(--accent) 30%,var(--accent-2) 30%,var(--accent-2) 60%,var(--ink) 60%,var(--ink) 100%);
}
.brand{margin-bottom:36px}
.brand-tag{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--accent);text-transform:uppercase;letter-spacing:.2em;margin-bottom:8px;
}
.brand h1{
  font-family:'Bebas Neue',sans-serif;font-size:56px;line-height:.85;
}
.brand h1 span{color:var(--accent)}
.brand-sub{font-size:13px;color:var(--ink-dim);margin-top:8px;letter-spacing:.05em}

.field{margin-bottom:20px}
.field label{
  display:block;font-family:'JetBrains Mono',monospace;
  font-size:10px;text-transform:uppercase;letter-spacing:.15em;
  color:var(--ink-dim);margin-bottom:8px;
}
.field input, .field select{
  width:100%;background:transparent;border:none;
  border-bottom:1px solid var(--line);
  padding:10px 0;color:var(--ink);
  font-family:'Archivo',sans-serif;font-size:16px;
  transition:border-color .2s;
}
.field select option{background:#141414;color:var(--ink)}
.field input:focus, .field select:focus{outline:none;border-bottom-color:var(--accent)}

.btn{
  width:100%;padding:16px;border:none;cursor:pointer;
  background:var(--accent);color:#fff;
  font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.1em;
  transition:transform .15s, background .2s;
  margin-top:12px;
  display:inline-block;text-align:center;
}
.btn:hover{background:#ff5e30;transform:translateY(-1px)}

.msg{
  margin-top:16px;padding:10px 12px;font-size:13px;
  font-family:'JetBrains Mono',monospace;display:none;
}
.msg.show{display:block}
.msg.err{background:rgba(239,68,68,.1);color:var(--err);border-left:2px solid var(--err)}
.msg.ok{background:rgba(74,222,128,.1);color:var(--ok);border-left:2px solid var(--ok)}

.login-foot{
  margin-top:24px;font-size:11px;color:var(--ink-dim);
  font-family:'JetBrains Mono',monospace;text-align:center;
}

/* ===== TOPBAR ===== */
.topbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 40px;border-bottom:1px solid var(--line);
  background:var(--bg-2);position:relative;z-index:1;flex-wrap:wrap;gap:12px;
}
.topbar-brand{display:flex;align-items:baseline;gap:14px}
.topbar-brand .logo{font-family:'Bebas Neue',sans-serif;font-size:28px}
.topbar-brand .logo span{color:var(--accent)}
.topbar-brand .div{width:1px;height:20px;background:var(--line)}
.topbar-brand .ctx{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.15em}

.topbar-user{display:flex;align-items:center;gap:16px}
.user-pill{
  display:flex;align-items:center;gap:10px;
  padding:8px 14px;background:var(--bg);border:1px solid var(--line);
}
.user-dot{width:8px;height:8px;border-radius:50%;background:var(--ok)}
.user-pill .name{font-size:13px;font-weight:700}
.user-pill .role{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--accent);text-transform:uppercase;letter-spacing:.15em}
.logout{
  background:transparent;border:1px solid var(--line);color:var(--ink-dim);
  padding:8px 14px;font-family:'JetBrains Mono',monospace;font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;cursor:pointer;
}
.logout:hover{color:var(--accent);border-color:var(--accent)}

/* ===== MAIN ===== */
.main{padding:48px 40px;max-width:1200px;margin:0 auto;position:relative;z-index:1}
.page-head{margin-bottom:40px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}
.page-head h2{font-family:'Bebas Neue',sans-serif;font-size:72px;line-height:.85}
.page-head h2 .accent{color:var(--accent)}
.page-head .sub{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.15em;margin-top:8px}

.empty-card{
  border:1px dashed var(--line);
  padding:80px 40px;text-align:center;
  background:rgba(255,255,255,.01);
}
.empty-card .num{font-family:'Bebas Neue',sans-serif;font-size:120px;color:var(--accent);line-height:1}
.empty-card .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.2em;margin-top:8px}
.empty-card p{margin-top:20px;color:var(--ink-dim);max-width:480px;margin-left:auto;margin-right:auto;line-height:1.6}

/* ===== ADMIN ===== */
.admin-section{margin-top:60px;border-top:1px solid var(--line);padding-top:40px}
.admin-head{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.admin-head .tag{background:var(--accent);color:#fff;font-family:'JetBrains Mono',monospace;font-size:9px;padding:4px 8px;letter-spacing:.15em}
.admin-head h3{font-family:'Bebas Neue',sans-serif;font-size:32px}

.admin-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:32px}
@media(max-width:760px){.admin-grid{grid-template-columns:1fr}}

.admin-card{background:var(--bg-2);border:1px solid var(--line);padding:28px}
.admin-card h4{font-family:'Bebas Neue',sans-serif;font-size:22px;margin-bottom:20px;letter-spacing:.05em}

.users-list{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow-y:auto}
.user-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 14px;background:var(--bg);border-left:2px solid var(--accent);
}
.user-row.admin{border-left-color:var(--accent-2)}
.user-row .info .n{font-weight:700;font-size:14px}
.user-row .info .r{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.15em}
.user-row button{
  background:transparent;border:1px solid var(--line);color:var(--ink-dim);
  padding:6px 10px;font-family:'JetBrains Mono',monospace;font-size:10px;cursor:pointer;
}
.user-row button:hover{color:var(--err);border-color:var(--err)}

.empty-list{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-dim);text-align:center;padding:30px}

/* ===== Welcome card (visible par tous) ===== */
.welcome-card{
  background:linear-gradient(135deg, rgba(255,77,28,.08), rgba(255,210,63,.03));
  border:1px solid var(--line);
  border-left:3px solid var(--accent);
  padding:28px 32px;
  margin-bottom:32px;
  position:relative;
}
.welcome-card::before{
  content:"";position:absolute;top:0;right:0;width:60px;height:60px;
  background:
    linear-gradient(135deg, transparent 50%, rgba(255,77,28,.15) 50%);
  pointer-events:none;
}
.welcome-head{margin-bottom:14px}
.welcome-tag{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--accent);
  text-transform:uppercase;letter-spacing:.2em;
  padding:4px 10px;border:1px solid var(--accent);
  display:inline-block;
}
.welcome-body{
  font-size:16px;line-height:1.6;color:var(--ink);
  font-weight:500;
}

/* ===== Textarea dans admin ===== */
.field textarea{
  width:100%;background:var(--bg);
  border:1px solid var(--line);
  padding:12px 14px;color:var(--ink);
  font-family:'Archivo',sans-serif;font-size:15px;
  line-height:1.5;resize:vertical;min-height:100px;
  transition:border-color .2s;
}
.field textarea:focus{outline:none;border-color:var(--accent)}

/* Admin card qui prend toute la largeur */
.admin-card.wide{max-width:100%}

.hint{
  margin-top:12px;font-size:11px;color:var(--ink-dim);
  font-family:'JetBrains Mono',monospace;line-height:1.5;
}

* Chip affichant le genre dans la liste des comptes */
.gender-chip{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:.1em;
  padding:2px 6px;
  border:1px solid currentColor;
  margin-left:2px;
}
.gender-chip.female{color:var(--accent)}
.gender-chip.male{color:#4dabff}
.gender-chip.none{color:var(--ink-dim);opacity:.7}

/* Actions à droite de chaque ligne */
.row-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.inline-edit{margin:0}
.inline-edit select{
  background:var(--bg-2);
  border:1px solid var(--line);
  color:var(--ink);
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  padding:5px 8px;
  text-transform:uppercase;
  letter-spacing:.05em;
  cursor:pointer;
  transition:border-color .15s;
}
.inline-edit select:hover,
.inline-edit select:focus{
  border-color:var(--accent);
  outline:none;
}
.inline-edit select option{
  background:var(--bg-2);
  color:var(--ink);
}

.btn-del{
  background:transparent;
  border:1px solid var(--line);
  color:var(--ink-dim);
  padding:5px 10px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.05em;
  cursor:pointer;
  transition:all .15s;
}
.btn-del:hover{
  color:var(--err);
  border-color:var(--err);
}

/* La ligne utilisateur prend un peu plus d'air pour accueillir les actions */
.user-row{
  padding:14px 16px !important;
  gap:12px;
  flex-wrap:wrap;
}
@media(max-width:520px){
  .user-row{flex-direction:column;align-items:flex-start}
  .row-actions{width:100%;justify-content:flex-start}
}

/* ===== Navigation ===== */
.topbar{flex-wrap:wrap;gap:16px}
.topbar-nav{display:flex;gap:4px;flex-wrap:wrap;flex:1;justify-content:center}
.topbar-nav a{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--ink-dim);
  padding:8px 14px;
  border:1px solid transparent;
  transition:all .15s;
}
.topbar-nav a:hover{color:var(--ink);border-color:var(--line)}
.topbar-nav a.active{color:var(--accent);border-color:var(--accent)}

@media(max-width:760px){
  .topbar-nav{width:100%;order:3;justify-content:flex-start}
}

/* ===== Message perso ===== */
.perso-card{
  background:linear-gradient(135deg, rgba(255,210,63,.08), rgba(255,77,28,.02));
  border:1px solid var(--line);
  border-left:3px solid var(--accent-2);
  padding:24px 28px;
  margin-bottom:32px;
  position:relative;
}
.perso-tag{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--accent-2);
  text-transform:uppercase;letter-spacing:.2em;
  padding:4px 10px;border:1px solid var(--accent-2);
  display:inline-block;
}
.perso-head{margin-bottom:12px}
.perso-body{
  font-size:15px;line-height:1.6;color:var(--ink);
  font-style:italic;
}

/* Éditeur de message perso (admin, dans la ligne utilisateur) */
.perso-editor{
  display:none;
  width:100%;
  margin-top:12px;
  padding:14px;
  background:var(--bg-2);
  border:1px dashed var(--line);
  flex-direction:column;
  gap:10px;
}
.perso-editor.open{display:flex}
.perso-editor label{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--ink-dim);
  text-transform:uppercase;letter-spacing:.1em;
}
.perso-editor textarea{
  width:100%;background:var(--bg);
  border:1px solid var(--line);
  padding:10px 12px;color:var(--ink);
  font-family:'Archivo',sans-serif;font-size:14px;
  line-height:1.5;resize:vertical;
}
.perso-editor textarea:focus{outline:none;border-color:var(--accent-2)}
.btn.small{
  width:auto;padding:8px 16px;font-size:13px;
  align-self:flex-start;
}

/* ===== Quick access grid (dashboard) ===== */
.quick-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:16px;
  margin-bottom:32px;
}
.quick-card{
  background:var(--bg-2);
  border:1px solid var(--line);
  padding:28px 24px;
  transition:all .2s;
  display:block;
  position:relative;
  overflow:hidden;
}
.quick-card::before{
  content:"";position:absolute;top:0;left:0;width:3px;height:100%;
  background:var(--accent);
  transform:scaleY(0);transform-origin:top;
  transition:transform .25s;
}
.quick-card:hover::before{transform:scaleY(1)}
.quick-card:hover{background:#1a1a1a;transform:translateY(-2px)}
.quick-icon{
  font-family:'Bebas Neue',sans-serif;
  font-size:40px;color:var(--accent);line-height:1;
}
.quick-label{
  font-family:'Bebas Neue',sans-serif;
  font-size:24px;margin-top:10px;letter-spacing:.05em;
}
.quick-sub{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--ink-dim);
  text-transform:uppercase;letter-spacing:.1em;margin-top:4px;
}

/* ===== Field grid (2 colonnes dans les formulaires) ===== */
.field-grid{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:20px;
}
@media(max-width:520px){.field-grid{grid-template-columns:1fr}}

.hint-inline{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;color:var(--ink-dim);
  text-transform:uppercase;letter-spacing:.1em;
}

/* ===== Drill selector (page mes-temps / ranking) ===== */
.drill-selector{
  background:var(--bg-2);
  border:1px solid var(--line);
  padding:20px 24px;
  margin-bottom:32px;
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  align-items:flex-end;
}
.drill-selector > div{flex:1;min-width:200px}
.drill-selector label{
  display:block;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--ink-dim);
  text-transform:uppercase;letter-spacing:.15em;margin-bottom:8px;
}
.drill-selector select{
  width:100%;background:var(--bg);
  border:1px solid var(--line);
  padding:10px 12px;color:var(--ink);
  font-family:'Archivo',sans-serif;font-size:15px;
}
.drill-selector select:focus{outline:none;border-color:var(--accent)}

.filter-tabs .tabs{
  display:flex;gap:0;
  border:1px solid var(--line);
}
.filter-tabs .tabs a{
  flex:1;text-align:center;
  padding:10px 14px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--ink-dim);
  border-right:1px solid var(--line);
  transition:all .15s;
}
.filter-tabs .tabs a:last-child{border-right:none}
.filter-tabs .tabs a:hover{color:var(--ink);background:var(--bg)}
.filter-tabs .tabs a.active{
  background:var(--accent);color:#fff;
}

/* ===== Drill cards ===== */
.drill-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:16px;
}
.drill-card{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-left:3px solid var(--accent);
  padding:20px;
}
.drill-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:22px;letter-spacing:.05em;
  margin-bottom:8px;
}
.drill-desc{
  font-size:13px;color:var(--ink-dim);line-height:1.5;
}

/* ===== Stats cards (my-times) ===== */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:16px;
  margin-bottom:32px;
}
.stat-card{
  background:var(--bg-2);
  border:1px solid var(--line);
  padding:24px;
  text-align:center;
}
.stat-label{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--ink-dim);
  text-transform:uppercase;letter-spacing:.15em;
  margin-bottom:10px;
}
.stat-value{
  font-family:'Bebas Neue',sans-serif;
  font-size:40px;line-height:1;
}
.stat-value.accent{color:var(--accent)}

/* ===== Tables (temps + classement) ===== */
.times-table, .ranking-table{
  width:100%;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-collapse:collapse;
  margin-bottom:20px;
}
.times-table th, .ranking-table th{
  background:var(--bg);
  padding:14px 16px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--ink-dim);
  text-transform:uppercase;letter-spacing:.15em;
  text-align:left;
  border-bottom:1px solid var(--line);
  font-weight:400;
}
.times-table td, .ranking-table td{
  padding:14px 16px;
  font-size:14px;
  border-bottom:1px solid var(--line);
}
.times-table tr:last-child td, .ranking-table tr:last-child td{border-bottom:none}
.times-table tr:hover td, .ranking-table tr:hover td{background:rgba(255,255,255,.02)}

.t-time{
  font-family:'JetBrains Mono',monospace;
  font-weight:700;font-size:15px;
}
.t-time.accent{color:var(--accent);font-size:16px}
.t-note{color:var(--ink-dim);font-size:13px;font-style:italic}

.delta-ok{color:var(--ok);font-family:'JetBrains Mono',monospace;font-weight:700}
.delta-ko{color:var(--err);font-family:'JetBrains Mono',monospace;font-weight:700}

tr.is-best td{background:rgba(255,77,28,.05)}
.best-badge{
  display:inline-block;
  margin-left:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;color:var(--accent);
  border:1px solid var(--accent);
  padding:2px 6px;letter-spacing:.1em;
}

/* Recorder chips (auto / coach) */
.recorder-chip{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;
  text-transform:uppercase;letter-spacing:.1em;
  padding:3px 8px;
  border:1px solid currentColor;
}
.recorder-chip.auto{color:var(--ink-dim)}
.recorder-chip.coach{color:var(--accent-2)}

/* ===== Ranking ===== */
.col-rank{
  width:60px;text-align:center;
  font-family:'Bebas Neue',sans-serif;
  font-size:22px;
}
tr.rank-1 .col-rank, tr.rank-2 .col-rank, tr.rank-3 .col-rank{
  font-size:22px;
}
tr.you-row td{
  background:rgba(255,210,63,.06) !important;
}
tr.you-row td:first-child{
  border-left:3px solid var(--accent-2);
  padding-left:13px;
}

/* Scroll pour les tableaux sur mobile */
@media(max-width:720px){
  .times-table, .ranking-table{font-size:12px}
  .times-table th, .ranking-table th,
  .times-table td, .ranking-table td{padding:10px 8px}
  .t-note{display:none}
  .main{padding:32px 16px}
}