/* Le Choc des Raquettes — CSS Modern Light / Purple WOW */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@700;800;900&family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --bg:       #f4f3ff;
  --surface:  #ffffff;
  --border:   #e8e4ff;
  --p1:       #7c3aed;
  --p2:       #a855f7;
  --p3:       #ec4899;
  --grad:     linear-gradient(135deg, #7c3aed, #a855f7, #ec4899);
  --grad2:    linear-gradient(135deg, #7c3aed, #6d28d9);
  --green:    #10b981;
  --red:      #ef4444;
  --gold:     #f59e0b;
  --text:     #111827;
  --muted:    #9ca3af;
  --radius:   18px;
  --shadow:   0 4px 24px rgba(124,58,237,0.12);
  --shadow-lg:0 8px 40px rgba(124,58,237,0.2);
  --font-num: 'Barlow Condensed', sans-serif;
  --font:     'Inter', system-ui, sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html { font-size:16px; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  min-height: 100dvh;
  overflow-x: hidden;
}

/* ── FOND ── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse at 10% 10%, rgba(124,58,237,0.12) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 90%, rgba(236,72,153,0.1) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 0%,  rgba(168,85,247,0.08) 0%, transparent 40%);
  pointer-events: none;
  z-index: 0;
}

body > * { position:relative; z-index:1; }

/* ── SCREENS ── */
.screen { display:none; min-height:100dvh; flex-direction:column; }
.screen.active { display:flex; }

/* ══════════════════ LOGIN ══════════════════ */
#screen-login {
  align-items: center;
  justify-content: center;
  padding: 32px 24px;
  gap: 28px;
}

.login-logo { text-align:center; }

.logo-svg {
  width: 88px; height: 88px;
  margin-bottom: 16px;
  filter: drop-shadow(0 8px 24px rgba(124,58,237,0.4));
  animation: logoFloat 3s ease-in-out infinite;
}

@keyframes logoFloat {
  0%,100% { transform: translateY(0) rotate(-3deg); }
  50%      { transform: translateY(-12px) rotate(3deg); }
}

.logo-title {
  font-family: var(--font-num);
  font-size: 2.8rem;
  font-weight: 900;
  letter-spacing: -1px;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}

.logo-sub { font-size:.88rem; color:var(--muted); margin-top:8px; font-weight:500; }

.login-form { width:100%; max-width:360px; display:flex; flex-direction:column; gap:20px; }

.field-label {
  font-size: .7rem;
  font-weight: 800;
  color: var(--p1);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.input-text {
  width: 100%;
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-family: var(--font);
  font-size: 1.1rem;
  font-weight: 600;
  padding: 16px 18px;
  outline: none;
  transition: all 0.25s;
  box-shadow: var(--shadow);
  -webkit-appearance: none;
}

.input-text:focus {
  border-color: var(--p1);
  box-shadow: 0 0 0 4px rgba(124,58,237,0.15), var(--shadow);
}

.input-text::placeholder { color: var(--muted); font-weight:400; }

/* PIN */
.pin-dots { display:flex; gap:14px; justify-content:center; margin-bottom:16px; }

.pin-dot {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--border);
  border: 2px solid #d1c9f7;
  transition: all 0.2s;
}

.pin-dot.filled {
  background: var(--grad);
  border-color: transparent;
  box-shadow: 0 0 12px rgba(124,58,237,0.5);
  animation: dotPop 0.2s cubic-bezier(0.34,1.56,0.64,1);
}

@keyframes dotPop {
  0% { transform:scale(0.3); }
  100% { transform:scale(1); }
}

.pin-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:10px; }

.pin-key {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: 16px;
  color: var(--text);
  font-family: var(--font-num);
  font-size: 1.8rem;
  font-weight: 800;
  padding: 18px;
  cursor: pointer;
  transition: all 0.15s cubic-bezier(0.34,1.56,0.64,1);
  user-select: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.pin-key:active {
  background: var(--p1);
  border-color: var(--p1);
  color: white;
  transform: scale(0.88);
  box-shadow: 0 4px 20px rgba(124,58,237,0.4);
}

.pin-key.delete { font-size:1.3rem; color:var(--muted); }
.pin-key.empty  { visibility:hidden; }

.login-msg { text-align:center; font-size:.88rem; color:var(--muted); min-height:20px; font-weight:500; }
.login-msg.error   { color:var(--red); }
.login-msg.success { color:var(--green); }

/* ══════════════════ BOUTONS ══════════════════ */
.btn {
  border: none;
  border-radius: var(--radius);
  font-family: var(--font);
  font-weight: 800;
  font-size: 1rem;
  padding: 16px 24px;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.34,1.56,0.64,1);
  display: flex; align-items:center; justify-content:center; gap:8px;
  width: 100%; min-height:54px;
  -webkit-appearance: none;
  letter-spacing: 0.2px;
}

.btn:active:not(:disabled) { transform:scale(0.94); }
.btn:disabled { opacity:.35; cursor:not-allowed; }

.btn-primary {
  background: var(--grad);
  color: #fff;
  box-shadow: 0 6px 28px rgba(124,58,237,0.4);
}

.btn-primary:active { box-shadow:0 2px 10px rgba(124,58,237,0.3); }

.btn-secondary {
  background: var(--surface);
  border: 2px solid var(--border);
  color: var(--text);
  box-shadow: var(--shadow);
}

.btn-success {
  background: rgba(16,185,129,0.1);
  border: 2px solid var(--green);
  color: var(--green);
}

.btn-danger {
  background: rgba(239,68,68,0.1);
  border: 2px solid var(--red);
  color: var(--red);
}

.btn-sm { padding:10px 16px; font-size:.85rem; min-height:40px; width:auto; }

/* ══════════════════ HEADER ══════════════════ */
.app-header {
  background: rgba(255,255,255,0.85);
  border-bottom: 1px solid var(--border);
  padding: 14px 20px;
  display: flex; align-items:center; justify-content:space-between;
  position: sticky; top:0; z-index:50;
  backdrop-filter: blur(20px);
  flex-shrink: 0;
  box-shadow: 0 1px 20px rgba(124,58,237,0.08);
}

.header-logo {
  font-family: var(--font-num);
  font-size: 1.25rem;
  font-weight: 900;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: flex; align-items:center; gap:8px;
}

.header-player { font-size:.85rem; color:var(--muted); display:flex; align-items:center; gap:8px; font-weight:500; }
.btn-logout { background:none; border:none; color:var(--muted); font-size:1.2rem; cursor:pointer; padding:4px 8px; }

/* ══════════════════ CARDS ══════════════════ */
.card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.card-glow {
  border-color: rgba(124,58,237,0.25);
  box-shadow: var(--shadow-lg);
}

/* ══════════════════ HUB ══════════════════ */
#screen-hub { flex-direction:column; }

.hub-content {
  flex:1; padding:20px;
  display:flex; flex-direction:column; gap:16px;
  padding-bottom: 80px;
}

.section-title {
  font-size: .65rem;
  font-weight: 800;
  color: var(--p1);
  letter-spacing: 2.5px;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.session-card {
  padding: 20px;
  display: flex; flex-direction:column; gap:12px;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
}

.session-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--grad);
}

.session-card:active { transform:scale(0.98); }

.session-card-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.session-name { font-weight:800; font-size:1.1rem; color:var(--text); }

.badge-live {
  background: rgba(16,185,129,0.12);
  border: 1.5px solid var(--green);
  color: var(--green);
  font-size: .65rem; font-weight:800;
  padding: 4px 12px; border-radius:99px;
  letter-spacing: 1.5px; white-space:nowrap; flex-shrink:0;
  animation: livePulse 2s ease-in-out infinite;
}

@keyframes livePulse {
  0%,100% { box-shadow:0 0 4px rgba(16,185,129,0.3); }
  50%      { box-shadow:0 0 14px rgba(16,185,129,0.7); }
}

.session-meta { font-size:.82rem; color:var(--muted); font-weight:500; }
.empty-state { text-align:center; padding:36px 20px; color:var(--muted); font-size:.9rem; line-height:1.7; font-weight:500; }

/* ══════════════════ SESSION ══════════════════ */
#screen-session { flex-direction:column; }

.session-content {
  flex:1; overflow-y:auto;
  padding:20px; padding-bottom:110px;
  display:flex; flex-direction:column; gap:20px;
}

/* Classement soirée */
.rank-row {
  display:flex; align-items:center; gap:12px;
  padding:14px 16px;
  background:#faf8ff;
  border-radius:14px;
  border: 1.5px solid var(--border);
  transition: all 0.2s;
}

.rank-row:first-child {
  background: linear-gradient(135deg, rgba(245,158,11,0.08), rgba(251,191,36,0.04));
  border-color: rgba(245,158,11,0.3);
}

.rank-pos { font-family:var(--font-num); font-size:1.6rem; font-weight:900; width:36px; text-align:center; flex-shrink:0; }
.rank-pos-1 { color:var(--gold); }
.rank-pos-2 { color:#9ca3af; }
.rank-pos-3 { color:#cd7f32; }
.rank-pos-n { color:var(--muted); font-size:1rem; }
.rank-pseudo { flex:1; font-weight:700; }
.rank-score  { font-family:var(--font-num); font-size:1.4rem; font-weight:900; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* Matchs */
.match-item {
  padding:14px 16px;
  background:#faf8ff;
  border-radius:14px;
  border:1.5px solid var(--border);
  display:flex; flex-direction:column; gap:6px;
  position: relative; overflow:hidden;
}

.match-item::before {
  content:'';
  position:absolute; left:0; top:0; bottom:0;
  width:3px;
  background: var(--grad);
  border-radius:99px;
}

.match-players { display:flex; align-items:center; gap:10px; font-size:.95rem; }
.match-player { flex:1; font-weight:700; }
.match-player.winner { color:var(--green); }
.match-player.loser  { color:var(--muted); text-decoration:line-through; font-weight:500; }
.match-player.right  { text-align:right; }

.match-score {
  font-family:var(--font-num);
  font-size:1.3rem; font-weight:900;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.match-time { font-size:.72rem; color:var(--muted); font-weight:500; }

/* FAB */
.fab {
  position:fixed; bottom:80px; right:20px;
  background: var(--grad);
  color:#fff; border:none; border-radius:18px;
  padding:16px 26px;
  font-family:var(--font); font-size:1rem; font-weight:800;
  cursor:pointer;
  box-shadow:0 6px 30px rgba(124,58,237,0.4);
  display:flex; align-items:center; gap:10px;
  transition:all 0.2s cubic-bezier(0.34,1.56,0.64,1);
  z-index:40;
}

.fab:active { transform:scale(0.93); box-shadow:0 3px 15px rgba(124,58,237,0.3); }

/* ══════════════════ ADD MATCH ══════════════════ */
#screen-add-match { flex-direction:column; }

.add-match-content {
  flex:1; padding:24px 20px; padding-bottom:40px;
  display:flex; flex-direction:column; gap:24px;
  overflow-y:auto;
}

.player-select-list { display:flex; flex-direction:column; gap:8px; }

.player-select-item {
  display:flex; align-items:center; gap:14px;
  padding:16px 18px;
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:var(--radius);
  cursor:pointer; transition:all 0.15s;
  box-shadow:0 2px 8px rgba(0,0,0,0.04);
}

.player-select-item:active { transform:scale(0.97); }

.player-select-item.selected {
  border-color:var(--p1);
  background:rgba(124,58,237,0.05);
  box-shadow:0 0 0 4px rgba(124,58,237,0.1), var(--shadow);
}

.player-select-item .check {
  display:none; width:26px; height:26px;
  border-radius:50%;
  background:var(--grad);
  color:#fff;
  align-items:center; justify-content:center;
  font-size:.8rem; font-weight:800; flex-shrink:0;
  animation:checkPop 0.25s cubic-bezier(0.34,1.56,0.64,1);
}

.player-select-item.selected .check { display:flex; }

@keyframes checkPop { 0%{transform:scale(0)} 100%{transform:scale(1)} }

.player-select-item .pseudo { font-weight:700; font-size:1.05rem; flex:1; }

/* Score */
.score-section-card {
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:var(--radius);
  padding:24px 20px;
  box-shadow:var(--shadow);
}

.score-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.score-row-name {
  font-size: 1rem;
  font-weight: 800;
  color: var(--text);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.score-row-controls { display:flex; align-items:center; gap:10px; flex-shrink:0; }

.score-btn {
  width:48px; height:48px; border-radius:14px;
  background:#f4f3ff; border:2px solid var(--border);
  color:var(--p1); font-size:1.5rem; font-weight:800;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:all 0.15s cubic-bezier(0.34,1.56,0.64,1); flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,0.06);
}

.score-btn:active { background:var(--p1); color:#fff; transform:scale(0.88); box-shadow:0 4px 16px rgba(124,58,237,0.4); }

.score-num {
  font-family:var(--font-num);
  font-size:2.6rem; font-weight:900;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  min-width:60px; text-align:center; line-height:1;
}

.score-num.bump { animation:scoreBump 0.2s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes scoreBump { 0%{transform:scale(1)} 50%{transform:scale(1.4)} 100%{transform:scale(1)} }

.score-vs { font-family:var(--font-num); font-size:1.6rem; font-weight:900; color:var(--muted); }
.score-error { font-size:.82rem; color:var(--red); text-align:center; min-height:20px; margin-top:12px; font-weight:600; }

/* ══════════════════ RANKING ══════════════════ */
#screen-ranking { flex-direction:column; }

.ranking-content {
  flex:1; overflow-y:auto;
  padding:20px; padding-bottom:80px;
  display:flex; flex-direction:column; gap:20px;
}

/* Podium */
.podium-wrap {
  padding:28px 16px 20px;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  background:linear-gradient(160deg, rgba(124,58,237,0.05) 0%, rgba(236,72,153,0.05) 100%);
}

.podium-top {
  display:flex; align-items:flex-end; justify-content:center;
  gap:12px; width:100%;
}

.podium-player { display:flex; flex-direction:column; align-items:center; gap:6px; flex:1; }

.podium-crown {
  font-size:1.8rem;
  animation:crownBounce 1.2s ease-in-out infinite;
  display:none; margin-bottom:4px;
}

.podium-player.first .podium-crown { display:block; }

@keyframes crownBounce {
  0%,100% { transform:translateY(0) rotate(-8deg); }
  50%      { transform:translateY(-8px) rotate(8deg); }
}

.podium-avatar {
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-num); font-weight:900; color:white;
}

.podium-player.second .podium-avatar { width:60px; height:60px; font-size:1.4rem; background:linear-gradient(135deg,#9ca3af,#6b7280); box-shadow:0 4px 16px rgba(0,0,0,0.15); }
.podium-player.first  .podium-avatar { width:80px; height:80px; font-size:1.9rem; background:var(--grad); box-shadow:0 8px 32px rgba(124,58,237,0.45); }
.podium-player.third  .podium-avatar { width:56px; height:56px; font-size:1.2rem; background:linear-gradient(135deg,#cd7f32,#92400e); box-shadow:0 4px 16px rgba(0,0,0,0.15); }

.podium-pseudo { font-size:.8rem; font-weight:800; text-align:center; max-width:90px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text); }
.podium-wins   { font-family:var(--font-num); font-size:1rem; font-weight:900; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* Tableau complet */
.ranking-table { display:flex; flex-direction:column; gap:8px; }

.ranking-row {
  display:flex; align-items:center; gap:14px;
  padding:16px 18px;
  background:var(--surface);
  border-radius:16px;
  border:1.5px solid var(--border);
  box-shadow:0 2px 8px rgba(0,0,0,0.04);
  transition:all 0.2s;
}

.ranking-row:first-child {
  background:linear-gradient(135deg,rgba(245,158,11,0.06),rgba(251,191,36,0.03));
  border-color:rgba(245,158,11,0.3);
}

.ranking-num { font-family:var(--font-num); font-size:1.2rem; font-weight:900; color:var(--muted); width:28px; text-align:center; flex-shrink:0; }
.ranking-pseudo { flex:1; font-weight:700; font-size:1.05rem; }
.ranking-stats { text-align:right; }
.ranking-wins { font-family:var(--font-num); font-size:1.5rem; font-weight:900; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1; }
.ranking-winrate { font-size:.75rem; color:var(--muted); font-weight:500; }

/* ══════════════════ BOTTOM NAV ══════════════════ */
.bottom-nav {
  background:rgba(255,255,255,0.9);
  border-top:1.5px solid var(--border);
  display:flex;
  padding-bottom:env(safe-area-inset-bottom);
  flex-shrink:0;
  backdrop-filter:blur(20px);
  position:sticky; bottom:0;
  box-shadow:0 -4px 20px rgba(124,58,237,0.08);
}

.nav-item {
  flex:1; display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:12px 8px; cursor:pointer;
  color:var(--muted); font-size:.68rem; font-weight:700;
  transition:all 0.2s; border:none; background:none;
  -webkit-appearance:none; letter-spacing:0.5px;
}

.nav-item .nav-icon { font-size:1.4rem; transition:transform 0.2s; }
.nav-item.active { color:var(--p1); }
.nav-item.active .nav-icon { transform:scale(1.2); }

/* ══════════════════ BACK HEADER ══════════════════ */
.back-header {
  background:rgba(255,255,255,0.9);
  border-bottom:1.5px solid var(--border);
  padding:14px 20px;
  display:flex; align-items:center; gap:14px;
  flex-shrink:0; position:sticky; top:0; z-index:50;
  backdrop-filter:blur(20px);
  box-shadow:0 1px 20px rgba(124,58,237,0.08);
}

.btn-back { background:none; border:none; color:var(--p1); font-size:1.6rem; cursor:pointer; padding:4px; line-height:1; }
.back-title { font-weight:800; font-size:1.05rem; }

/* ══════════════════ TOAST ══════════════════ */
.toast {
  position:fixed; bottom:90px; left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--surface);
  border:2px solid var(--border);
  color:var(--text);
  padding:14px 24px; border-radius:16px;
  font-size:.95rem; font-weight:700;
  opacity:0;
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  z-index:999; pointer-events:none; white-space:nowrap;
  max-width:calc(100vw - 40px); text-align:center;
  box-shadow:var(--shadow-lg);
}

.toast.show  { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.success { border-color:var(--green); color:var(--green); }
.toast.error   { border-color:var(--red);   color:var(--red); }

/* ══════════════════ LOADER ══════════════════ */
.loader { display:flex; align-items:center; justify-content:center; padding:40px; color:var(--muted); font-size:.9rem; gap:10px; }
.spinner { width:20px; height:20px; border:2.5px solid var(--border); border-top-color:var(--p1); border-radius:50%; animation:spin 0.7s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ══════════════════ MODAL ══════════════════ */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.35);
  z-index:200; display:flex; align-items:flex-end;
  padding:20px; padding-bottom:max(20px, env(safe-area-inset-bottom));
  backdrop-filter:blur(8px);
}

.modal-overlay.hidden { display:none; }

.modal-box {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:24px;
  width:100%; max-width:440px; margin:0 auto;
  padding:28px 24px;
  display:flex; flex-direction:column; gap:16px;
  box-shadow:var(--shadow-lg);
  animation:modalUp 0.3s cubic-bezier(0.34,1.56,0.64,1);
}

@keyframes modalUp { from{transform:translateY(60px);opacity:0} to{transform:translateY(0);opacity:1} }

.modal-title { font-size:1.2rem; font-weight:800; }

/* ══════════════════ CONFETTI ══════════════════ */
.confetti-piece {
  position:fixed; width:10px; height:10px;
  border-radius:2px; pointer-events:none; z-index:9999;
  animation:confettiFall linear forwards;
}

@keyframes confettiFall {
  0%   { transform:translateY(0) rotate(0deg) scale(1); opacity:1; }
  100% { transform:translateY(100vh) rotate(720deg) scale(0.3); opacity:0; }
}

/* ══════════════════ UTILS ══════════════════ */
input, select, textarea { font-size:16px !important; }

@media (min-width:600px) {
  body { max-width:480px; margin:0 auto; }
  .fab { right:calc(50% - 220px); }
}
