@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');
/* ═══════════════════════════════════════════════
   DARTS HUB — IRISH PUB THEME
   darts.elenium.fr
═══════════════════════════════════════════════ */

/* ── Variables ── */
:root {
  --bg-primary:#0f0a06;--bg-secondary:#1a1008;--bg-card:#1e1408;--bg-card-hover:#261a0d;--bg-input:#120d06;
  --border:#5a3e1b;--border-glow:#8b6914;
  --gold:#c9a227;--gold-light:#e8c547;--gold-dark:#8b6914;
  --green-moss:#2d4a1e;--green-light:#4a7a30;--green-bright:#6ab04c;
  --cream:#e8d5b0;--cream-dark:#c4a96a;
  --leather:#6b3a1f;--slate:#2a3540;--slate-light:#3d5060;
  --red-dart:#8b1a1a;--red-bright:#c0392b;
  --text-primary:#e8d5b0;--text-secondary:#a08050;--text-muted:#6b5030;
  --shadow-gold:0 0 20px rgba(201,162,39,0.3);--shadow-deep:0 8px 32px rgba(0,0,0,0.8);
  --font-title:'Cinzel Decorative',serif;--font-heading:'Cinzel',serif;--font-ui:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-body:'IM Fell English',serif;--font-bl:'UnifrakturMaguntia',cursive;
  --t:all 0.25s ease;
}
[data-theme="light"] {
  --bg-primary:#f5edd8;--bg-secondary:#ede0c4;--bg-card:#e8d8b8;--bg-card-hover:#ddc9a0;--bg-input:#f0e4cc;
  --border:#8b6030;--border-glow:#c9a227;
  --text-primary:#1a0f05;--text-secondary:#5a3a10;--text-muted:#8b6030;
  --shadow-deep:0 8px 32px rgba(0,0,0,0.2);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body {
  font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);
  min-height:100vh;overflow-x:hidden;
  background-image:
    radial-gradient(ellipse at 20% 20%,rgba(90,62,27,.15) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 80%,rgba(45,74,30,.1) 0%,transparent 60%);
}
body::after {
  content:'';position:fixed;top:0;left:0;right:0;height:4px;z-index:1000;
  background:linear-gradient(90deg,transparent,var(--gold-dark),var(--gold),var(--gold-light),var(--gold),var(--gold-dark),transparent);
}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg-secondary)}
::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}

/* ── NAV ── */
nav {
  position:fixed;top:0;left:0;right:0;z-index:900;
  background:linear-gradient(180deg,rgba(10,6,2,.98),rgba(15,10,6,.95));
  border-bottom:1px solid var(--border);backdrop-filter:blur(10px);
  padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 2px 20px rgba(0,0,0,.8);
}
.nav-logo{font-family:var(--font-bl);font-size:1.8rem;color:var(--gold);letter-spacing:2px;
  cursor:pointer;display:flex;align-items:center;gap:.5rem;text-shadow:0 0 20px rgba(201,162,39,.5)}
.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav-links a{font-family:var(--font-heading);font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--text-secondary);text-decoration:none;padding:.5rem .75rem;border-radius:4px;transition:var(--t);position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--gold);background:rgba(201,162,39,.1)}
.nav-links a.active::after{content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);width:20px;height:2px;background:var(--gold)}
.nav-actions{display:flex;align-items:center;gap:.75rem}
.theme-toggle{background:var(--bg-card);border:1px solid var(--border);color:var(--gold);width:38px;height:38px;
  border-radius:8px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.theme-toggle:hover{border-color:var(--gold);box-shadow:var(--shadow-gold)}
.burger{display:none;background:none;border:1px solid var(--border);color:var(--gold);width:38px;height:38px;
  border-radius:8px;cursor:pointer;font-size:1.2rem;align-items:center;justify-content:center;transition:var(--t)}
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:rgba(10,6,2,.98);
  border-bottom:1px solid var(--border);padding:1rem;z-index:899;backdrop-filter:blur(10px);flex-direction:column;gap:.5rem}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--font-heading);font-size:.8rem;letter-spacing:2px;text-transform:uppercase;
  color:var(--text-secondary);text-decoration:none;padding:.75rem 1rem;border-radius:6px;transition:var(--t);border:1px solid transparent}
.mobile-menu a:hover,.mobile-menu a.active{color:var(--gold);background:rgba(201,162,39,.1);border-color:var(--border)}

/* ── LAYOUT ── */
main{padding-top:64px;min-height:100vh;position:relative;z-index:1}
.page{display:none;padding:2rem 1.5rem;max-width:1200px;margin:0 auto;animation:fadeIn .3s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── TYPOGRAPHY ── */
.page-title{font-family:var(--font-title);font-size:clamp(1.5rem,4vw,2.5rem);color:var(--gold);
  text-align:center;margin-bottom:.5rem;text-shadow:0 0 30px rgba(201,162,39,.4);letter-spacing:2px}
.page-subtitle{font-family:var(--font-body);font-style:italic;color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-size:.95rem}
.section-title{font-family:var(--font-heading);font-size:.75rem;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold-dark);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}
.section-title::before,.section-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border))}
.section-title::after{background:linear-gradient(90deg,var(--border),transparent)}
.celtic-divider{text-align:center;color:var(--gold-dark);font-size:1.2rem;margin:1.5rem 0;letter-spacing:8px;opacity:.6}

/* ── CARDS ── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;
  position:relative;overflow:hidden;transition:var(--t)}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold-dark),transparent);opacity:0;transition:var(--t)}
.card:hover::before{opacity:1}
.card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-gold)}
.card-title{font-family:var(--font-heading);font-size:.8rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}

/* ── GRIDS ── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}

/* ── BUTTONS ── */
.btn{font-family:var(--font-heading);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;
  padding:.75rem 1.5rem;border-radius:8px;border:1px solid;cursor:pointer;transition:var(--t);
  display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}
.btn-primary{background:linear-gradient(135deg,var(--gold-dark),var(--gold));border-color:var(--gold);color:#0f0a06;font-weight:700}
.btn-primary:hover{background:linear-gradient(135deg,var(--gold),var(--gold-light));box-shadow:0 0 20px rgba(201,162,39,.4);transform:translateY(-1px)}
.btn-secondary{background:transparent;border-color:var(--border);color:var(--text-secondary)}
.btn-secondary:hover{border-color:var(--gold-dark);color:var(--gold);background:rgba(201,162,39,.08)}
.btn-danger{background:transparent;border-color:var(--red-dart);color:var(--red-bright)}
.btn-danger:hover{background:rgba(139,26,26,.2)}
.btn-green{background:linear-gradient(135deg,var(--green-moss),var(--green-light));border-color:var(--green-light);color:var(--cream)}
.btn-green:hover{background:linear-gradient(135deg,var(--green-light),var(--green-bright));box-shadow:0 0 20px rgba(74,122,48,.4);transform:translateY(-1px)}
.btn-sm{padding:.4rem .8rem;font-size:.65rem}
.btn-lg{padding:1rem 2rem;font-size:.8rem}
.btn-full{width:100%;justify-content:center}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}

/* ── FORMS ── */
.form-group{margin-bottom:1.25rem}
label{display:block;font-family:var(--font-ui);font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.5rem}
input[type="text"],input[type="number"],select,textarea{
  width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;
  color:var(--text-primary);font-family:var(--font-body);font-size:1rem;padding:.75rem 1rem;
  transition:var(--t);outline:none;appearance:none;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--gold-dark);box-shadow:0 0 0 3px rgba(201,162,39,.1)}

/* Number +/- input */
.number-input-wrapper{display:flex;align-items:center;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:var(--t)}
.number-input-wrapper:focus-within{border-color:var(--gold-dark);box-shadow:0 0 0 3px rgba(201,162,39,.1)}
.number-input-wrapper button{background:rgba(201,162,39,.1);border:none;color:var(--gold);width:42px;height:42px;
  font-size:1.2rem;cursor:pointer;transition:var(--t);display:flex;align-items:center;justify-content:center;font-family:monospace;flex-shrink:0}
.number-input-wrapper button:hover{background:rgba(201,162,39,.25)}
.number-input-wrapper button:active{transform:scale(.9)}
.number-input-wrapper input[type="number"]{border:none;border-radius:0;text-align:center;padding:.5rem;
  background:transparent;-moz-appearance:textfield;flex:1;min-width:0}
.number-input-wrapper input::-webkit-outer-spin-button,.number-input-wrapper input::-webkit-inner-spin-button{-webkit-appearance:none}

/* Toggle */
.toggle-wrapper{display:flex;align-items:center;gap:.75rem;cursor:pointer}
.toggle{width:48px;height:26px;background:var(--bg-input);border:1px solid var(--border);border-radius:13px;
  position:relative;transition:var(--t);cursor:pointer;flex-shrink:0}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;
  background:var(--text-muted);border-radius:50%;transition:var(--t)}
.toggle.on{background:rgba(201,162,39,.2);border-color:var(--gold-dark)}
.toggle.on::after{background:var(--gold);transform:translateX(22px)}
.toggle-label{font-family:var(--font-body);font-size:.9rem;color:var(--text-secondary)}

/* Option buttons */
.option-group{display:flex;gap:.5rem;flex-wrap:wrap}
.option-btn{font-family:var(--font-ui);font-size:.65rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:.5rem 1rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-input);
  color:var(--text-secondary);cursor:pointer;transition:var(--t)}
.option-btn:hover{border-color:var(--gold-dark);color:var(--gold)}
.option-btn.selected{background:rgba(201,162,39,.15);border-color:var(--gold);color:var(--gold)}

/* ── Emoji picker ── */
#avatar-picker{
  display:flex;flex-wrap:wrap;gap:.35rem;
  max-height:200px;overflow-y:auto;padding:.4rem;
  background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px}
#avatar-picker .option-btn{
  font-family:serif;font-size:1.5rem;text-transform:none;letter-spacing:0;
  padding:0;width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  border-radius:8px;flex-shrink:0;line-height:1;
  background:var(--bg-card)}
#avatar-picker .option-btn:hover{
  border-color:var(--gold-dark);background:rgba(201,162,39,.12);transform:scale(1.1)}
#avatar-picker .option-btn.selected{
  border-color:var(--gold);background:rgba(201,162,39,.25);
  box-shadow:0 0 10px rgba(201,162,39,.4);transform:scale(1.05)}

/* ── Color picker ── */
#color-picker{display:flex;flex-wrap:wrap;gap:.4rem;padding:.1rem}
#color-picker .option-btn{
  font-family:var(--font-heading);font-size:.6rem;letter-spacing:.5px;text-transform:none;
  padding:.35rem .7rem;display:flex;align-items:center;gap:.25rem;border-radius:6px}
#color-picker .option-btn.selected{background:rgba(201,162,39,.12);border-color:var(--gold)}

/* ── STAT CARDS ── */
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.25rem;text-align:center;position:relative;overflow:hidden}
.stat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold-dark),transparent)}
.stat-value{font-family:var(--font-ui);font-size:2rem;font-weight:700;color:var(--gold);line-height:1;margin-bottom:.25rem}
.stat-label{font-family:var(--font-ui);font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted)}
.stat-sub{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem;font-style:italic}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-heading);font-size:.6rem;
  letter-spacing:1.5px;text-transform:uppercase;padding:.2rem .6rem;border-radius:4px;border:1px solid}
.badge-gold{background:rgba(201,162,39,.15);border-color:var(--gold-dark);color:var(--gold)}
.badge-green{background:rgba(45,74,30,.3);border-color:var(--green-light);color:var(--green-bright)}
.badge-red{background:rgba(139,26,26,.2);border-color:var(--red-dart);color:var(--red-bright)}
.badge-slate{background:rgba(42,53,64,.5);border-color:var(--slate-light);color:var(--cream-dark)}

/* ── TOAST ── */
.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}
.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1rem 1.25rem;
  font-family:var(--font-body);font-size:.9rem;color:var(--text-primary);box-shadow:var(--shadow-deep);
  animation:slideIn .3s ease;max-width:300px;display:flex;align-items:center;gap:.75rem}
.toast.success{border-color:var(--green-light)}.toast.error{border-color:var(--red-dart)}.toast.info{border-color:var(--gold-dark)}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:950;
  align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:2rem;
  max-width:560px;width:100%;max-height:90vh;overflow-y:auto;position:relative;
  box-shadow:var(--shadow-deep),0 0 60px rgba(201,162,39,.1);animation:modalIn .3s ease}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--gold-dark),var(--gold),var(--gold-dark),transparent);border-radius:16px 16px 0 0}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-title{font-family:var(--font-title);font-size:1.3rem;color:var(--gold);margin-bottom:1.5rem;text-align:center}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:1px solid var(--border);color:var(--text-muted);
  width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.modal-close:hover{border-color:var(--red-dart);color:var(--red-bright)}

/* ── LOADING ── */
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--gold);
  border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9998;
  align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.loading-overlay.active{display:flex}

/* ── HOME ── */
.hero{text-align:center;padding:2rem 0 1rem}
.hero-icon{font-size:4rem;margin-bottom:1rem;filter:drop-shadow(0 0 20px rgba(201,162,39,.5))}
.quick-actions{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:2rem}
.quick-action{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem 1rem;
  text-align:center;cursor:pointer;transition:var(--t);text-decoration:none;
  display:flex;flex-direction:column;align-items:center;gap:.5rem}
.quick-action:hover{border-color:var(--gold-dark);transform:translateY(-3px);box-shadow:var(--shadow-gold)}
.quick-action-icon{font-size:2rem}
.quick-action-label{font-family:var(--font-heading);font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-secondary)}
.game-item{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid rgba(90,62,27,.3)}
.game-item:last-child{border-bottom:none}
.game-item-icon{font-size:1.5rem;flex-shrink:0}
.game-item-info{flex:1;min-width:0}
.game-item-title{font-family:var(--font-heading);font-size:.8rem;letter-spacing:1px;color:var(--text-primary);
  margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.game-item-meta{font-size:.75rem;color:var(--text-muted);font-style:italic}
.game-item-score{font-family:var(--font-ui);font-size:.75rem;color:var(--gold);text-align:right;flex-shrink:0}

/* ── PLAYERS ── */
.player-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.25rem;
  display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;transition:var(--t);text-align:center}
.player-card:hover{border-color:var(--gold-dark);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.player-avatar{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;border:2px solid var(--border);background:var(--bg-secondary)}
.player-name{font-family:var(--font-heading);font-size:.9rem;letter-spacing:1.5px;color:var(--text-primary)}
.player-stats{display:flex;gap:1.25rem;padding:1rem .5rem .5rem}
.player-stat{text-align:center}
.player-stat-val{font-family:var(--font-ui);font-size:1.1rem;color:var(--gold);font-weight:700;margin-bottom:.15rem}
.player-stat-lbl{font-family:var(--font-ui);font-size:.65rem;color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase}
.add-player-card{background:var(--bg-card);border:2px dashed var(--border);border-radius:12px;padding:1.25rem;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:var(--t);min-height:160px}
.add-player-card:hover{border-color:var(--gold-dark);background:rgba(201,162,39,.05)}
.add-player-card span:first-child{font-size:2rem;color:var(--text-muted)}
.add-player-card span:last-child{font-family:var(--font-heading);font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted)}

/* ── WIZARD ── */
.wizard-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:2rem}
.wizard-step{display:flex;flex-direction:column;align-items:center;gap:.3rem}
.wizard-step-num{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:.8rem;
  color:var(--text-muted);background:var(--bg-card);transition:var(--t)}
.wizard-step.active .wizard-step-num{border-color:var(--gold);color:var(--gold);box-shadow:0 0 12px rgba(201,162,39,.3)}
.wizard-step.done .wizard-step-num{border-color:var(--green-light);background:var(--green-moss);color:var(--green-bright)}
.wizard-step-label{font-family:var(--font-heading);font-size:.55rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted)}
.wizard-step.active .wizard-step-label{color:var(--gold)}
.wizard-connector{width:50px;height:2px;background:var(--border);margin:0 .25rem;margin-bottom:18px}
.wizard-connector.done{background:var(--green-light)}
.wizard-panel{display:none}.wizard-panel.active{display:block;animation:fadeIn .3s ease}
.mode-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}
.mode-card{background:var(--bg-input);border:2px solid var(--border);border-radius:10px;padding:1.25rem .75rem;text-align:center;cursor:pointer;transition:var(--t)}
.mode-card:hover{border-color:var(--gold-dark)}.mode-card.selected{border-color:var(--gold);background:rgba(201,162,39,.1)}
.mode-card-icon{font-size:2rem;margin-bottom:.5rem}
.mode-card-name{font-family:var(--font-heading);font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-secondary)}
.mode-card.selected .mode-card-name{color:var(--gold)}.mode-card.coming-soon{opacity:.4;cursor:not-allowed}
.player-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}
.player-select-item{background:var(--bg-input);border:2px solid var(--border);border-radius:10px;padding:1rem .75rem;
  text-align:center;cursor:pointer;transition:var(--t);position:relative}
.player-select-item:hover{border-color:var(--gold-dark)}.player-select-item.selected{border-color:var(--gold);background:rgba(201,162,39,.1)}
.player-select-item .player-order{position:absolute;top:-8px;right:-8px;width:22px;height:22px;background:var(--gold);
  color:#0f0a06;border-radius:50%;font-family:var(--font-heading);font-size:.65rem;font-weight:700;
  display:flex;align-items:center;justify-content:center}

/* ── IN GAME ── */
.game-header{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1rem 1.5rem;
  margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.game-info{font-family:var(--font-heading);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-secondary)}
.game-progress{display:flex;gap:1rem;align-items:center}
.leg-indicator{font-family:var(--font-heading);font-size:.7rem;letter-spacing:1px;color:var(--gold)}
.scoreboard{display:grid;gap:.75rem;margin-bottom:1rem}
.scoreboard-player{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1rem 1.25rem;
  display:flex;align-items:center;gap:1rem;transition:var(--t)}
.scoreboard-player.active{border-color:var(--gold);background:rgba(201,162,39,.08);box-shadow:0 0 20px rgba(201,162,39,.15)}
.scoreboard-active-indicator{width:8px;height:8px;border-radius:50%;background:var(--text-muted);flex-shrink:0}
.scoreboard-player.active .scoreboard-active-indicator{background:var(--gold);box-shadow:0 0 8px var(--gold);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.scoreboard-player-name{flex:1;font-family:var(--font-heading);font-size:.85rem;letter-spacing:1px;color:var(--text-primary)}
.scoreboard-player.active .scoreboard-player-name{color:var(--gold)}
.scoreboard-remaining{font-family:var(--font-heading);font-size:2.4rem;font-weight:700;color:var(--text-primary);min-width:80px;text-align:right}
.scoreboard-player.active .scoreboard-remaining{color:var(--gold)}
.scoreboard-avg{text-align:right;flex-shrink:0}
.scoreboard-avg-val{font-family:var(--font-ui);font-size:.85rem;color:var(--cream-dark)}
.scoreboard-avg-lbl{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.scoreboard-legs{display:flex;gap:.25rem;flex-shrink:0}
.leg-dot{width:14px;height:14px;border-radius:50%;border:1px solid var(--border);background:transparent}
.leg-dot.won{background:var(--gold);border-color:var(--gold)}.leg-dot.current{border-color:var(--gold);animation:pulse 1.5s infinite}
.checkout-suggestion{background:rgba(45,74,30,.25);border:1px solid var(--green-light);border-radius:12px;text-align:center;justify-content:center;padding:1rem 1.25rem;
  padding:.75rem 1rem;margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}
.checkout-suggestion-icon{font-size:1.4rem;margin-bottom:.2rem}
.checkout-suggestion-text{font-family:var(--font-ui);font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--green-bright);opacity:.8}
.checkout-darts{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-top:.35rem}
.checkout-dart{background:rgba(45,74,30,.5);border:1px solid var(--green-light);border-radius:8px;font-family:var(--font-heading);font-size:1.05rem;font-weight:700;padding:.45rem .8rem;
  padding:.2rem .5rem;font-family:var(--font-heading);font-size:.7rem;color:var(--green-bright);transition:var(--t)}
.checkout-dart.done{opacity:.35;background:transparent;border-color:var(--border);color:var(--text-muted);text-decoration:line-through}
.bust-indicator{display:none;background:rgba(139,26,26,.2);border:1px solid var(--red-dart);border-radius:10px;
  padding:.75rem 1rem;margin-bottom:1rem;text-align:center;font-family:var(--font-heading);
  font-size:.85rem;letter-spacing:2px;color:var(--red-bright);animation:fadeIn .3s ease}
.bust-indicator.show{display:block}
.dart-input-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.25rem}
.current-throw-display{text-align:center;margin-bottom:1rem}
.current-throw-darts{display:flex;justify-content:center;gap:.75rem;margin-bottom:.5rem}
.throw-dart-slot{width:80px;height:88px;background:var(--bg-input);border:2px solid var(--border);
  border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:var(--t)}
.throw-dart-slot.active{border-color:var(--gold);box-shadow:0 0 12px rgba(201,162,39,.3)}
.throw-dart-slot.filled{border-color:var(--gold-dark);background:rgba(201,162,39,.08)}
.throw-dart-slot.bust{border-color:var(--red-dart);background:rgba(139,26,26,.1)}
.throw-dart-value{font-family:var(--font-ui);font-size:1.45rem;font-weight:700;color:var(--gold);margin-bottom:.15rem}
.throw-dart-mult{font-size:.6rem;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}
.throw-total{font-family:var(--font-heading);font-size:1rem;color:var(--text-secondary);letter-spacing:2px}
.multiplier-toggle{display:flex;justify-content:center;gap:.5rem;margin-bottom:1rem}
.mult-btn{font-family:var(--font-ui);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;
  padding:.5rem 1rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-input);
  color:var(--text-secondary);cursor:pointer;transition:var(--t);min-width:70px;text-align:center}
.mult-btn:hover{border-color:var(--gold-dark)}
.mult-btn.active-single{border-color:var(--cream-dark);color:var(--cream);background:rgba(196,169,106,.15)}
.mult-btn.active-double{border-color:var(--gold);color:var(--gold);background:rgba(201,162,39,.15)}
.mult-btn.active-triple{border-color:var(--red-bright);color:var(--red-bright);background:rgba(192,57,43,.15)}
.number-pad{display:grid;grid-template-columns:repeat(8,1fr);gap:.35rem;margin-bottom:.75rem}
.pad-btn{font-family:var(--font-ui);font-size:.8rem;font-weight:600;padding:.75rem .2rem;border-radius:6px;
  border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);
  cursor:pointer;transition:var(--t);text-align:center;user-select:none}
.pad-btn:hover{border-color:var(--gold-dark);color:var(--gold);background:rgba(201,162,39,.08)}
.pad-btn:active{transform:scale(.92);background:rgba(201,162,39,.15)}
.pad-btn.bull{border-color:var(--green-light);color:var(--green-bright)}
.pad-btn.bull:hover{background:rgba(45,74,30,.3)}
.pad-btn.zero{border-color:var(--slate-light);color:var(--text-muted)}
.pad-actions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.volee-history{margin-top:1rem;border-top:1px solid var(--border);padding-top:.75rem;padding-bottom:2rem;max-height:220px;overflow-y:auto;scrollbar-width:thin}
.volee-row{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.8rem}

.volee-num{font-family:var(--font-heading);font-size:.6rem;color:var(--text-muted);min-width:20px}
.volee-player{color:var(--text-secondary);flex:1}
.volee-darts{display:flex;gap:.3rem}
.volee-dart{font-family:var(--font-heading);font-size:.7rem;padding:.1rem .3rem;border-radius:3px;background:rgba(201,162,39,.1);color:var(--gold)}
.volee-dart.bust-dart{background:rgba(139,26,26,.2);color:var(--red-bright)}
.volee-score{font-family:var(--font-ui);font-size:.8rem;color:var(--gold);min-width:35px;text-align:right}
.volee-remaining{font-size:.75rem;color:var(--text-muted);min-width:40px;text-align:right}

/* ── STATS ── */
.stats-player-selector{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem;justify-content:center}
.stats-player-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:.4rem 1rem;
  font-family:var(--font-heading);font-size:.65rem;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--text-secondary);cursor:pointer;transition:var(--t);display:flex;align-items:center;gap:.4rem}
.stats-player-btn:hover,.stats-player-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(201,162,39,.1)}
.stats-tabs{display:flex;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;padding:4px;margin-bottom:1.5rem;overflow-x:auto}
.stats-tab{font-family:var(--font-heading);font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:.5rem .75rem;border-radius:7px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:var(--t);white-space:nowrap}
.stats-tab.active{background:var(--bg-card);color:var(--gold);border:1px solid var(--border)}
.heatmap-container{background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:1.5rem;
  display:flex;flex-direction:column;align-items:center;gap:1rem}
.heatmap-legend{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:var(--text-muted)}
.heatmap-legend-bar{width:120px;height:8px;border-radius:4px;background:linear-gradient(90deg,transparent,rgba(201,162,39,.3),var(--gold))}
.histogram{display:flex;align-items:flex-end;gap:.3rem;height:140px;padding:0 .5rem}
.histogram-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;height:100%;justify-content:flex-end}
.histogram-bar{width:100%;background:linear-gradient(180deg,var(--gold),var(--gold-dark));border-radius:3px 3px 0 0;transition:height .5s ease;min-height:2px}
.histogram-bar:hover{background:linear-gradient(180deg,var(--gold-light),var(--gold))}
.histogram-label{font-family:var(--font-ui);font-size:.5rem;letter-spacing:.5px;color:var(--text-muted);text-align:center;white-space:nowrap}
.histogram-count{font-family:var(--font-ui);font-size:.55rem;color:var(--text-secondary)}
.histogram-pct{font-family:var(--font-ui);font-size:.5rem;color:var(--gold);letter-spacing:.5px}
.h2h-table{width:100%;border-collapse:collapse;font-size:.85rem}
.h2h-table th{font-family:var(--font-heading);font-size:.6rem;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold-dark);padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border)}
.h2h-table td{padding:.6rem .75rem;border-bottom:1px solid rgba(90,62,27,.2);color:var(--text-secondary)}
.h2h-table tr:last-child td{border-bottom:none}
.h2h-table tr:hover td{background:rgba(201,162,39,.04)}
.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}
.achievement{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1rem;text-align:center;transition:var(--t)}
.achievement.unlocked{border-color:var(--gold-dark);background:rgba(201,162,39,.08)}
.achievement.locked{opacity:.4;filter:grayscale(.5)}
.achievement-icon{font-size:1.8rem;margin-bottom:.4rem}
.achievement-name{font-family:var(--font-ui);font-size:.65rem;letter-spacing:1px;color:var(--text-secondary)}
.achievement.unlocked .achievement-name{color:var(--gold)}
.achievement-desc{font-size:.55rem;color:var(--text-muted);text-align:center;margin-top:.2rem;line-height:1.3;display:none}
.achievement:hover .achievement-desc,.achievement:hover .achievement-check{display:block}
.achievement-check{font-size:.6rem;color:var(--green-bright);margin-top:.3rem;text-align:center;display:none}

/* ── EMPTY STATES ── */
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}
.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}
.empty-state-text{font-family:var(--font-body);font-style:italic;font-size:.95rem;margin-bottom:1rem}

/* ── WIN OVERLAY ── */
.win-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9990;
  align-items:center;justify-content:center;backdrop-filter:blur(8px)}
.win-overlay.show{display:flex}
.win-card{background:var(--bg-card);border:2px solid var(--gold);border-radius:20px;padding:3rem 2rem;
  text-align:center;max-width:460px;width:90%;box-shadow:0 0 60px rgba(201,162,39,.3);animation:modalIn .5s ease}
.win-icon{font-size:4rem;margin-bottom:1rem}
.win-title{font-family:var(--font-title);font-size:2rem;color:var(--gold);text-shadow:0 0 30px rgba(201,162,39,.6);margin-bottom:.5rem}
.win-subtitle{font-family:var(--font-body);font-style:italic;color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}
.win-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .nav-links{display:none}.burger{display:flex}
  .number-pad{grid-template-columns:repeat(4,1fr);gap:.25rem}
  .scoreboard-avg{display:none}.scoreboard-legs{display:none}
  .win-stats{grid-template-columns:repeat(2,1fr)}
  .histogram{height:90px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .grid-2-mobile{grid-template-columns:repeat(2,1fr)!important}
}
@media(max-width:480px){
  .page{padding:1rem}.modal{padding:1.5rem}
  .current-throw-darts{gap:.4rem}
  .throw-dart-slot{width:55px;height:55px}
  .throw-dart-value{font-size:1rem}
  .wizard-steps{gap:0;overflow-x:auto;padding-bottom:.5rem}
  .wizard-connector{width:30px}
}

.volee-turn-sep{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-family:var(--font-ui);font-size:.65rem;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;opacity:.6}
.volee-turn-sep::before,.volee-turn-sep::after{content:"";flex:1;height:1px;background:rgba(90,62,27,.3)}