  :root {
    --bg: #060806;
    --surface: #0c0f0c;
    --surface2: #141a14;
    --surface3: #1c241c;
    --accent: #2ec850;
    --accent2: #e8312a;
    --accent3: #ffd700;
    --accent-rgb: 46,200,80;
    --accent2-rgb: 232,49,42;
    --accent3-rgb: 255,215,0;
    --accent-hover: var(--accent-hover);
    --accent-dark: var(--accent-dark);
    --text: #eaf2ea;
    --text-dim: #5e7d5e;
    --border: #1e2e1e;
    --player-colors: #2ec850, #e8312a, #4af0ff, #ffd700;
    --card-shadow: 0 2px 12px rgba(0,0,0,0.4), 0 1px 3px rgba(0,0,0,0.3);
    --card-shadow-lg: 0 8px 32px rgba(0,0,0,0.5), 0 2px 8px rgba(0,0,0,0.3);
  }

  * { box-sizing: border-box; margin: 0; padding: 0; }

  /* ===== THEME PICKER ===== */
  .theme-picker-wrap {
    margin-bottom: 1.5rem;
  }
  #theme-picker {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .theme-option {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    background: var(--surface2);
    border: 2px solid var(--border);
    border-radius: 10px;
    padding: 0.5rem 0.55rem;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
    min-width: 58px;
    font-family: inherit;
  }
  .theme-option:hover { border-color: var(--text-dim); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.3); }
  .theme-option.theme-active {
    border-color: var(--accent);
    box-shadow: 0 0 16px rgba(var(--accent-rgb),0.2), 0 4px 12px rgba(0,0,0,0.2);
    background: linear-gradient(135deg, rgba(var(--accent-rgb),0.08), rgba(var(--accent-rgb),0.02));
  }
  .theme-option-icon { font-size: 1.2rem; line-height: 1; }
  .theme-option-swatch {
    width: 18px; height: 18px;
    border-radius: 50%;
    border: 2px solid var(--border);
  }
  .theme-option.theme-active .theme-option-swatch { border-color: var(--accent); }
  .theme-option-name {
    font-family: 'DM Mono', monospace;
    font-size: 0.48rem;
    letter-spacing: 0.12em;
    color: var(--text-dim);
    white-space: nowrap;
  }
  .theme-option.theme-active .theme-option-name { color: var(--accent); }

  @media (max-width: 480px) {
    .theme-option { min-width: 50px; padding: 0.4rem 0.35rem; }
    .theme-option-swatch { width: 14px; height: 14px; }
    .theme-option-name { font-size: 0.4rem; }
  }

  html { height: 100%; overscroll-behavior: none; }

  body {
    background: var(--bg);
    color: var(--text);
    font-family: 'Outfit', sans-serif;
    min-height: 100%;
    min-height: 100dvh;
    overflow-x: hidden;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  }

  /* NOISE TEXTURE OVERLAY */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
    pointer-events: none;
    z-index: 1000;
    opacity: 0.4;
  }

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

  /* ===== SETUP SCREEN ===== */
  #setup-screen {
    align-items: center;
    justify-content: flex-start;
    padding: 2rem;
    overflow-y: auto;
  }

  @media (min-height: 700px) {
    #setup-screen { justify-content: center; }
  }

  .logo-wrap {
    text-align: center;
    margin-bottom: 3rem;
    animation: fadeDown 0.6s ease;
  }

  .logo-img-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 0.5rem;
  }
  .logo-text {
    font-family: 'DM Mono', monospace;
    font-size: clamp(2.8rem, 12vw, 5rem);
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--accent);
    text-shadow: 0 0 40px rgba(var(--accent-rgb),0.6), 0 0 80px rgba(var(--accent-rgb),0.2), 0 0 8px rgba(var(--accent-rgb),0.4);
    animation: fadeDown 0.6s cubic-bezier(0.16,1,0.3,1);
    line-height: 1;
  }
  .logo-text .logo-m8 {
    color: #fff;
    text-shadow: 0 0 24px rgba(255,255,255,0.3), 0 0 60px rgba(255,255,255,0.1);
  }

  .logo-sub {
    font-family: 'DM Mono', monospace;
    color: var(--text-dim);
    font-size: 0.62rem;
    letter-spacing: 0.3em;
    margin-top: 0.1rem;
    text-align: center;
  }

  #live-counter-wrap {
    display: none;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    margin-top: 0.5rem;
    font-family: 'DM Mono', monospace;
    font-size: 0.62rem;
    color: var(--text-dim);
    letter-spacing: 0.08em;
  }
  #live-counter-wrap .live-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--accent);
    flex-shrink: 0;
    animation: livePulse 2s ease-in-out infinite;
  }
  @keyframes livePulse {
    0%,100% { opacity:1; box-shadow:0 0 4px var(--accent); }
    50%      { opacity:0.5; box-shadow:0 0 10px var(--accent); }
  }
  #live-user-count { color: var(--accent); }

  .setup-card {
    background: linear-gradient(165deg, rgba(14,17,14,0.95), rgba(10,13,10,0.98));
    border: 1px solid rgba(var(--accent-rgb),0.08);
    border-radius: 20px;
    padding: 2.5rem;
    width: 100%;
    max-width: 540px;
    animation: fadeUp 0.6s cubic-bezier(0.16,1,0.3,1) 0.1s both;
    box-shadow: var(--card-shadow-lg), inset 0 1px 0 rgba(255,255,255,0.03);
    backdrop-filter: blur(20px);
  }

  .setup-section {
    margin-bottom: 2rem;
  }

  .setup-label {
    font-family: 'DM Mono', monospace;
    color: var(--text-dim);
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    opacity: 0.8;
  }

  .btn-group {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }

  .btn-opt {
    flex: 1;
    min-width: 60px;
    background: var(--surface2);
    border: 2px solid var(--border);
    color: var(--text-dim);
    padding: 0.75rem 1rem;
    border-radius: 10px;
    cursor: pointer;
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
  }

  .btn-opt:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-1px); }
  .btn-opt:active { transform: translateY(0) scale(0.97); }
  .btn-opt.selected {
    background: linear-gradient(135deg, rgba(var(--accent-rgb),0.12), rgba(var(--accent-rgb),0.04));
    border-color: var(--accent);
    color: var(--accent);
    box-shadow: 0 0 20px rgba(var(--accent-rgb),0.15), inset 0 1px 0 rgba(var(--accent-rgb),0.1);
  }

  .players-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .player-input-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    animation: fadeIn 0.2s ease;
  }

  .player-dot {
    width: 12px; height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
  }

  .player-name-input {
    flex: 1;
    background: var(--surface2);
    border: 2px solid var(--border);
    color: var(--text);
    padding: 0.7rem 1rem;
    border-radius: 10px;
    font-family: 'Outfit', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    outline: none;
    transition: all 0.2s;
  }

  .player-name-input:focus { border-color: var(--accent); box-shadow: 0 0 16px rgba(var(--accent-rgb),0.1); }
  .player-name-input::placeholder { color: var(--text-dim); opacity: 0.6; }

  .btn-remove-player {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    font-size: 1.2rem;
    width: 32px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 6px;
    transition: all 0.15s;
  }
  .btn-remove-player:hover { color: var(--accent2); background: rgba(var(--accent2-rgb),0.1); }

  .btn-add-player {
    background: none;
    border: 2px dashed var(--border);
    color: var(--text-dim);
    padding: 0.6rem;
    border-radius: 8px;
    cursor: pointer;
    font-family: 'Outfit', sans-serif;
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    transition: all 0.15s;
    width: 100%;
    margin-top: 0.25rem;
  }
  .btn-add-player:hover { border-color: var(--accent); color: var(--accent); }

  .btn-start {
    width: 100%;
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    border: none;
    color: #000;
    padding: 1.1rem;
    border-radius: 12px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
    margin-top: 0.75rem;
    box-shadow: 0 4px 16px rgba(var(--accent-rgb),0.3), inset 0 1px 0 rgba(255,255,255,0.15);
    text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  }
  .btn-start:hover {
    background: linear-gradient(135deg, var(--accent-hover), var(--accent));
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(var(--accent-rgb),0.45), inset 0 1px 0 rgba(255,255,255,0.2);
  }
  .btn-start:active { transform: translateY(0) scale(0.98); }

  /* ===== GAME SCREEN ===== */
  #game-screen {
    flex-direction: column;
  }

  .game-header {
    background: linear-gradient(180deg, var(--surface), var(--bg));
    border-bottom: 1px solid var(--border);
    padding: 0.75rem 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-shrink: 0;
    box-shadow: 0 2px 12px rgba(0,0,0,0.3);
  }

  .game-header-logo-text {
    font-family: 'DM Mono', monospace;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--accent);
    text-shadow: 0 0 16px rgba(var(--accent-rgb),0.5), 0 0 4px rgba(var(--accent-rgb),0.3);
    line-height: 1;
    flex-shrink: 0;
    white-space: nowrap;
  }
  .game-header-logo-text .gh-logo-m8 {
    color: #fff;
    text-shadow: 0 0 12px rgba(255,255,255,0.25);
  }

  .game-mode-badge {
    font-family: 'Outfit', sans-serif;
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--accent);
    letter-spacing: 0.1em;
    line-height: 1;
  }

  .checkout-badge {
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
    color: var(--text-dim);
    letter-spacing: 0.2em;
    border: 1px solid var(--border);
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
  }

  .header-actions {
    margin-left: auto;
    display: flex;
    gap: 0.5rem;
  }

  .btn-icon {
    background: linear-gradient(180deg, var(--surface3), var(--surface2));
    border: 1px solid var(--border);
    color: var(--text-dim);
    width: 36px; height: 36px;
    border-radius: 9px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem;
    transition: all 0.2s;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  }
  .btn-icon:hover { color: var(--text); border-color: var(--text-dim); box-shadow: 0 4px 8px rgba(0,0,0,0.3); }

  .game-body {
    display: flex;
    flex: 1;
    overflow: hidden;
  }

  /* ===== SCOREBOARD ===== */
  .scoreboard {
    display: flex;
    flex: 1;
    gap: 0;
    overflow-x: auto;
    overflow-y: hidden;
  }

  .player-panel {
    flex: 1;
    min-width: 160px;
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--border);
    transition: background 0.3s;
    position: relative;
  }

  .player-panel:last-child { border-right: none; }

  .player-panel.active-player {
    background: linear-gradient(180deg, rgba(var(--accent-rgb),0.06), rgba(var(--accent-rgb),0.01));
  }

  .player-panel.active-player .player-header {
    border-bottom-color: var(--active-color, var(--accent));
    box-shadow: 0 2px 12px rgba(var(--accent-rgb),0.1);
  }

  .player-header {
    padding: 1rem;
    border-bottom: 3px solid transparent;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    transition: border-color 0.3s;
  }

  .player-name-display {
    font-family: 'Outfit', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .player-stats-mini {
    display: flex;
    gap: 0.5rem;
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    color: var(--text-dim);
  }

  .player-score-main {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(4.5rem, 12vw, 8.25rem);
    font-weight: 700;
    line-height: 1;
    text-align: center;
    padding: 1rem 0.5rem 0.5rem;
    letter-spacing: -0.02em;
    transition: color 0.3s, text-shadow 0.3s;
  }

  .player-panel.active-player .player-score-main {
    color: var(--active-color, var(--accent));
    text-shadow: 0 0 40px var(--active-color, rgba(var(--accent-rgb),0.5)), 0 0 80px var(--active-color, rgba(var(--accent-rgb),0.15));
  }

  .player-score-this-turn {
    text-align: center;
    font-family: 'Outfit', sans-serif;
    font-size: 1.6rem;
    color: var(--accent3);
    min-height: 2rem;
    letter-spacing: 0.05em;
  }

  .checkout-hint {
    margin: 0.5rem;
    background: linear-gradient(135deg, rgba(var(--accent3-rgb),0.08), rgba(255,140,0,0.04));
    border: 1px solid rgba(var(--accent3-rgb),0.2);
    border-radius: 10px;
    padding: 0.6rem;
    text-align: center;
    box-shadow: inset 0 1px 0 rgba(var(--accent3-rgb),0.05);
  }

  .checkout-hint-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    color: var(--accent3);
    letter-spacing: 0.2em;
    margin-bottom: 0.25rem;
  }

  .checkout-hint-darts {
    display: flex;
    gap: 4px;
    justify-content: center;
    flex-wrap: wrap;
  }

  .checkout-dart {
    background: rgba(var(--accent3-rgb),0.15);
    border: 1px solid rgba(var(--accent3-rgb),0.4);
    color: var(--accent3);
    padding: 0.2rem 0.4rem;
    border-radius: 4px;
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
    font-weight: bold;
  }

  .throws-history {
    flex: 1;
    overflow-y: auto;
    padding: 0.5rem;
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .throw-row {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 8px;
    border-radius: 6px;
    background: var(--surface2);
    font-family: 'DM Mono', monospace;
    font-size: 0.72rem;
    color: var(--text-dim);
    transition: background 0.15s;
  }

  .throw-row.latest { background: linear-gradient(90deg, rgba(var(--accent-rgb),0.06), var(--surface3)); color: var(--text); }
  .throw-row.editable { cursor: pointer; border: 1px solid rgba(var(--accent3-rgb),0.35); background: rgba(var(--accent3-rgb),0.06); }
  .throw-row.editable::after { content: '✏'; margin-left: 4px; font-size: 0.6rem; opacity: 0.6; }
  .throw-row.editable:active { background: rgba(var(--accent3-rgb),0.18); }

  .throw-num {
    color: var(--text-dim);
    font-size: 0.6rem;
    width: 20px;
  }

  .throw-scores {
    display: flex;
    gap: 3px;
    flex: 1;
  }

  .throw-score-pill {
    background: rgba(255,255,255,0.05);
    padding: 1px 5px;
    border-radius: 3px;
  }
  .throw-total {
    margin-left: auto;
    font-weight: bold;
    color: var(--accent);
  }

  /* ===== INPUT PANEL ===== */
  .input-panel {
    width: 280px;
    flex-shrink: 0;
    background: linear-gradient(180deg, var(--surface), rgba(8,10,8,0.98));
    border-left: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    padding: 1rem;
    gap: 0.75rem;
  }

  .current-turn-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    color: var(--text-dim);
    text-align: center;
  }

  .current-turn-name {
    font-family: 'Outfit', sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-align: center;
    line-height: 1;
  }

  .dart-inputs {
    display: flex;
    gap: 0.5rem;
  }

  .dart-input-box {
    flex: 1;
    background: linear-gradient(180deg, var(--surface3), var(--surface2));
    border: 2px solid var(--border);
    border-radius: 10px;
    padding: 0.5rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 2px;
    transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
    cursor: pointer;
    user-select: none;
  }

  .dart-input-box:hover {
    background: var(--surface3);
    border-color: var(--text-dim);
  }

  .dart-input-box.active-dart {
    border-color: var(--accent);
    box-shadow: 0 0 16px rgba(var(--accent-rgb),0.15), inset 0 1px 0 rgba(var(--accent-rgb),0.08);
    background: linear-gradient(180deg, rgba(var(--accent-rgb),0.06), rgba(var(--accent-rgb),0.02));
  }

  .dart-input-box.filled-dart {
    border-color: rgba(255,255,255,0.18);
  }

  /* Per-dart entry display */
  .dart-entry-row {
    display: flex;
    flex-direction: column;
    gap: 3px;
  }

  .dart-entry-wrap {
    background: linear-gradient(180deg, var(--surface3), var(--surface2));
    border: 2px solid var(--accent);
    border-radius: 12px;
    padding: 0.6rem 1rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    cursor: text;
    position: relative;
    box-shadow: 0 0 16px rgba(var(--accent-rgb),0.08), inset 0 1px 0 rgba(255,255,255,0.03);
  }

  .dart-entry-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.58rem;
    letter-spacing: 0.25em;
    color: var(--accent);
    white-space: nowrap;
    min-width: 3.5rem;
  }

  .dart-entry-display {
    flex: 1;
    font-family: 'Outfit', sans-serif;
    font-size: 1.8rem;
    letter-spacing: 0.06em;
    color: var(--text);
    line-height: 1;
    display: flex;
    align-items: center;
  }

  .dart-entry-cursor {
    display: inline-block;
    width: 2px;
    height: 1.5rem;
    background: var(--accent);
    border-radius: 1px;
    margin-left: 2px;
    vertical-align: middle;
    animation: blink 1s step-end infinite;
  }

  /* Hidden real input captures keyboard */
  .dart-text-input-hidden {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
    top: 0; left: 0;
  }

  .dart-entry-hint {
    font-family: 'DM Mono', monospace;
    font-size: 0.58rem;
    letter-spacing: 0.1em;
    color: var(--text-dim);
    text-align: center;
    min-height: 0.8rem;
  }

  .dart-input-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.55rem;
    color: var(--text-dim);
    letter-spacing: 0.2em;
  }

  .dart-input-value {
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    color: var(--text);
    letter-spacing: 0.05em;
    min-height: 1.6rem;
    line-height: 1.2;
  }

  .dart-input-multiplier {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    color: var(--text-dim);
  }

  /* Multiplier buttons */
  .multiplier-row {
    display: flex;
    gap: 0.5rem;
  }

  .btn-mult {
    flex: 1;
    padding: 0.5rem;
    background: var(--surface2);
    border: 2px solid var(--border);
    color: var(--text-dim);
    border-radius: 8px;
    cursor: pointer;
    font-family: 'Outfit', sans-serif;
    font-size: 1rem;
    letter-spacing: 0.05em;
    transition: all 0.15s;
  }

  .btn-mult:hover { border-color: var(--accent3); color: var(--accent3); }
  .btn-mult.active-mult {
    background: rgba(var(--accent3-rgb),0.1);
    border-color: var(--accent3);
    color: var(--accent3);
  }

  /* Numpad */
  .numpad {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.4rem;
  }

  .btn-num {
    background: linear-gradient(180deg, var(--surface3), var(--surface2));
    border: 1px solid var(--border);
    color: var(--text);
    padding: 0.7rem;
    border-radius: 10px;
    cursor: pointer;
    font-family: 'Outfit', sans-serif;
    font-size: 1.3rem;
    font-weight: 600;
    transition: all 0.12s cubic-bezier(0.16,1,0.3,1);
    text-align: center;
    letter-spacing: 0.05em;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.04);
  }

  .btn-num:hover { background: linear-gradient(180deg, rgba(var(--accent-rgb),0.08), var(--surface3)); border-color: rgba(var(--accent-rgb),0.3); }
  .btn-num:active { transform: scale(0.94); box-shadow: none; }

  .btn-num.btn-bull {
    color: var(--accent2);
    border-color: rgba(var(--accent2-rgb),0.3);
  }

  .btn-num.btn-clear {
    color: var(--accent2);
    font-size: 1rem;
  }

  .btn-num.btn-back {
    color: var(--accent3);
    font-size: 1rem;
  }

  .btn-num.btn-bust {
    color: var(--accent2);
    border-color: rgba(var(--accent2-rgb),0.4);
    background: rgba(var(--accent2-rgb),0.06);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    font-weight: 700;
  }
  .btn-num.btn-bust:hover { background: rgba(var(--accent2-rgb),0.15); border-color: var(--accent2); }
  .btn-num.btn-bust:active { background: rgba(var(--accent2-rgb),0.25); }

  .btn-confirm {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    border: none;
    color: #000;
    padding: 0.9rem;
    border-radius: 10px;
    cursor: pointer;
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
    box-shadow: 0 4px 12px rgba(var(--accent-rgb),0.25), inset 0 1px 0 rgba(255,255,255,0.15);
    text-shadow: 0 1px 2px rgba(0,0,0,0.15);
  }

  .btn-confirm:hover {
    background: linear-gradient(135deg, var(--accent-hover), var(--accent));
    box-shadow: 0 6px 24px rgba(var(--accent-rgb),0.4), inset 0 1px 0 rgba(255,255,255,0.2);
    transform: translateY(-1px);
  }

  .btn-confirm:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
    background: var(--surface3);
  }

  .btn-undo {
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text-dim);
    padding: 0.6rem;
    border-radius: 10px;
    cursor: pointer;
    font-family: 'Outfit', sans-serif;
    font-size: 0.9rem;
    font-weight: 600;
    transition: all 0.2s;
    text-align: center;
  }

  .btn-undo:hover { border-color: var(--text-dim); color: var(--text); background: var(--surface3); }

  .bust-indicator {
    background: linear-gradient(135deg, rgba(var(--accent2-rgb),0.15), rgba(var(--accent2-rgb),0.08));
    border: 1px solid rgba(var(--accent2-rgb),0.4);
    color: var(--accent2);
    padding: 0.6rem;
    border-radius: 10px;
    text-align: center;
    font-family: 'Outfit', sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    animation: pulse 0.5s ease;
    display: none;
    box-shadow: 0 0 20px rgba(var(--accent2-rgb),0.15);
  }

  .bust-indicator.show { display: block; }

  /* ===== WIN SCREEN ===== */
  #win-screen {
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 2rem;
    padding: 2rem;
    text-align: center;
  }

  .win-emoji {
    font-size: 5rem;
    animation: bounce 1s ease infinite alternate;
  }

  .win-title {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(2rem, 8vw, 5rem);
    font-weight: 800;
    letter-spacing: 0.15em;
    background: linear-gradient(135deg, var(--accent3), var(--accent3-dark, #ff8c00), var(--accent3));
    background-size: 200% 100%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    filter: drop-shadow(0 0 30px rgba(var(--accent3-rgb),0.5));
    animation: shimmerGold 3s ease-in-out infinite;
  }

  @keyframes shimmerGold {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
  }

  .win-name {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(2.5rem, 10vw, 6rem);
    font-weight: 800;
    letter-spacing: 0.1em;
    line-height: 1;
    text-shadow: 0 0 40px rgba(255,255,255,0.15);
  }

  .win-stats {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
    justify-content: center;
  }

  .win-match-result {
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    color: var(--text-dim);
  }

  .win-players-stats {
    display: flex;
    gap: 1.2rem;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 800px;
  }

  .win-player-card {
    background: linear-gradient(165deg, var(--surface2), var(--surface));
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 1.25rem;
    flex: 1;
    min-width: 280px;
    max-width: 380px;
    box-shadow: var(--card-shadow);
  }

  .win-player-card.winner { border-color: rgba(var(--accent3-rgb),0.4); box-shadow: 0 0 24px rgba(var(--accent3-rgb),0.12), 0 4px 16px rgba(0,0,0,0.3), inset 0 1px 0 rgba(var(--accent3-rgb),0.1); }

  .win-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--border);
  }

  .win-card-name {
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.08em;
  }

  .win-card-result {
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    background: rgba(var(--accent3-rgb),0.1);
    color: var(--accent3);
  }

  .win-card-result.loser { background: rgba(255,255,255,0.05); color: var(--text-dim); }

  .win-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem 0.75rem;
  }

  .win-sg-item {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 0.3rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.04);
  }

  .win-sg-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.58rem;
    color: var(--text-dim);
    letter-spacing: 0.15em;
    white-space: nowrap;
  }

  .win-sg-value {
    font-family: 'Outfit', sans-serif;
    font-size: 1.15rem;
    letter-spacing: 0.04em;
    text-align: right;
  }

  .win-stat {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 120px;
  }

  .win-stat-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    color: var(--text-dim);
    letter-spacing: 0.25em;
  }

  .win-stat-value {
    font-family: 'Outfit', sans-serif;
    font-size: 2rem;
    font-weight: 700;
    color: var(--accent);
  }

  .win-all-stats {
    width: 100%;
    max-width: 600px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
  }

  .win-table {
    width: 100%;
    border-collapse: collapse;
    font-family: 'Outfit', sans-serif;
  }

  .win-table th {
    background: var(--surface2);
    padding: 0.6rem 1rem;
    text-align: left;
    font-size: 0.7rem;
    font-family: 'DM Mono', monospace;
    letter-spacing: 0.2em;
    color: var(--text-dim);
  }

  .win-table td {
    padding: 0.6rem 1rem;
    border-top: 1px solid var(--border);
    font-size: 1rem;
    font-weight: 600;
  }

  .btn-play-again {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    border: none;
    color: #000;
    padding: 1rem 3rem;
    border-radius: 12px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
    box-shadow: 0 4px 16px rgba(var(--accent-rgb),0.3), inset 0 1px 0 rgba(255,255,255,0.15);
    text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  }

  .btn-play-again:hover {
    background: linear-gradient(135deg, var(--accent-hover), var(--accent));
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(var(--accent-rgb),0.45), inset 0 1px 0 rgba(255,255,255,0.2);
  }

  /* RESPONSIVE */
  /* =============================================
     RESPONSIVE — FULL OVERHAUL
     Mobile-first: input panel stacks below scores,
     buttons are large and thumb-friendly.
     ============================================= */

  /* RESPONSIVE breakpoints are in the COMPREHENSIVE RESPONSIVE section below */


  /* ANIMATIONS */
  @keyframes fadeDown {
    from { opacity: 0; transform: translateY(-24px); }
    to { opacity: 1; transform: translateY(0); }
  }
  @keyframes fadeUp {
    from { opacity: 0; transform: translateY(24px); }
    to { opacity: 1; transform: translateY(0); }
  }
  @keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
  }
  @keyframes pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.04); }
    100% { transform: scale(1); }
  }
  @keyframes bounce {
    from { transform: translateY(0); }
    to { transform: translateY(-15px); }
  }
  @keyframes scoreFlash {
    0% { opacity: 0; transform: scale(0.85); }
    50% { opacity: 1; transform: scale(1.06); }
    100% { opacity: 1; transform: scale(1); }
  }
  @keyframes subtleFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
  }

  .score-flash { animation: scoreFlash 0.3s ease; }

  /* Confetti canvas */
  #confetti-canvas {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 999;
  }

  /* Scrollbar */
  ::-webkit-scrollbar { width: 5px; height: 5px; }
  ::-webkit-scrollbar-track { background: transparent; }
  ::-webkit-scrollbar-thumb { background: rgba(var(--accent-rgb),0.15); border-radius: 3px; }
  ::-webkit-scrollbar-thumb:hover { background: rgba(var(--accent-rgb),0.25); }

  /* ===== MODE TOGGLE ===== */
  .mode-toggle {
    display: flex;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
  }

  .mode-toggle-btn {
    flex: 1;
    background: none;
    border: none;
    color: var(--text-dim);
    padding: 0.5rem 0.5rem;
    cursor: pointer;
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.1em;
    transition: all 0.2s;
    text-align: center;
    line-height: 1.3;
  }

  .mode-toggle-btn.active-mode {
    background: linear-gradient(180deg, rgba(var(--accent-rgb),0.1), rgba(var(--accent-rgb),0.03));
    color: var(--accent);
    box-shadow: inset 0 -2px 0 var(--accent);
  }

  /* ===== QUICK SCORE MODE ===== */

  .qs-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: linear-gradient(180deg, var(--surface3), var(--surface2));
    border: 2px solid var(--border);
    border-radius: 14px;
    padding: 0.6rem 1rem 0.75rem;
    gap: 0.15rem;
    transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
  }
  .qs-wrap:focus-within { border-color: var(--accent); box-shadow: 0 0 20px rgba(var(--accent-rgb),0.12), inset 0 1px 0 rgba(var(--accent-rgb),0.05); }
  .qs-wrap.qs-valid     { border-color: var(--accent); box-shadow: 0 0 20px rgba(var(--accent-rgb),0.15), inset 0 1px 0 rgba(var(--accent-rgb),0.08); }
  .qs-wrap.qs-bust      { border-color: var(--accent2); box-shadow: 0 0 20px rgba(var(--accent2-rgb),0.2); }

  .qs-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.58rem;
    letter-spacing: 0.3em;
    color: var(--text-dim);
  }

  .qs-input {
    font-family: 'Outfit', sans-serif;
    font-size: 3.5rem;
    line-height: 1;
    letter-spacing: 0.06em;
    color: var(--text);
    background: transparent;
    border: none;
    outline: none;
    text-align: center;
    width: 100%;
    caret-color: var(--accent);
    -moz-appearance: textfield;
    transition: color 0.15s;
    min-height: 4rem;
  }
  .qs-input::-webkit-outer-spin-button,
  .qs-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
  .qs-input::placeholder { color: var(--border); }
  .qs-wrap.qs-valid .qs-input { color: var(--accent); }
  .qs-wrap.qs-bust  .qs-input { color: var(--accent2); }

  .qs-feedback {
    font-family: 'DM Mono', monospace;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    color: var(--text-dim);
    min-height: 0.9rem;
    text-align: center;
  }
  .qs-feedback.ok       { color: var(--text-dim); }
  .qs-feedback.checkout { color: var(--accent3); font-size: 0.68rem; }
  .qs-feedback.bust     { color: var(--accent2); }

  /* Preset score buttons */
  .qs-presets {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
  }

  /* Type-total input bar */
  .dart-type-total-wrap { display: flex; flex-direction: column; gap: 4px; }
  .dart-type-total-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.5rem;
    letter-spacing: 0.22em;
    color: var(--text-dim);
    text-align: center;
  }

  /* TYPE SCORE PANEL */
  .panel-type { }

  .type-score-hero {
    background: linear-gradient(180deg, var(--surface3), var(--surface2));
    border: 2px solid var(--border);
    border-radius: 14px;
    padding: 1.25rem 1rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
  }
  .type-score-hero:focus-within { border-color: var(--accent); box-shadow: 0 0 20px rgba(var(--accent-rgb),0.12), inset 0 1px 0 rgba(var(--accent-rgb),0.05); }
  .type-score-hero.dt-valid  { border-color: var(--accent); box-shadow: 0 0 20px rgba(var(--accent-rgb),0.15), inset 0 1px 0 rgba(var(--accent-rgb),0.08); }
  .type-score-hero.dt-bust   { border-color: var(--accent2); box-shadow: 0 0 20px rgba(var(--accent2-rgb),0.2); }

  .type-score-hero-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.58rem;
    letter-spacing: 0.3em;
    color: var(--text-dim);
  }
  .type-score-hero-input {
    width: 100%;
    box-sizing: border-box;
    background: transparent;
    border: none;
    box-shadow: none;
    font-size: clamp(2rem, 8vw, 4rem);
    text-align: center;
    color: var(--text);
    padding: 0;
    caret-color: var(--accent);
    transition: color 0.15s;
    outline: none;
  }
  .type-score-hero.dt-valid .type-score-hero-input { color: var(--accent); }
  .type-score-hero.dt-bust  .type-score-hero-input { color: var(--accent2); }
  .type-score-hero-input::placeholder { color: var(--border); font-size: 2.5rem; }

  .type-score-hero-feedback {
    font-family: 'DM Mono', monospace;
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    color: var(--text-dim);
    min-height: 1rem;
    text-align: center;
  }
  .type-score-hero-feedback.dt-fb-checkout { color: var(--accent3); }
  .type-score-hero-feedback.dt-fb-bust     { color: var(--accent2); }
  .type-score-hero-feedback.dt-fb-ok       { color: var(--text-dim); }

  .type-score-hint {
    font-family: 'DM Mono', monospace;
    font-size: 0.5rem;
    letter-spacing: 0.15em;
    color: var(--border);
    margin-top: 0.1rem;
  }

  .type-score-presets {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
  }
    width: 100%;
    box-sizing: border-box;
    background: var(--surface2);
    border: 2px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-family: 'Outfit', sans-serif;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    padding: 0.45rem 0.9rem;
    outline: none;
    transition: border-color 0.15s, box-shadow 0.15s, color 0.15s;
    text-align: center;
  }
  .dart-total-field::placeholder { color: var(--border); font-size: 0.85rem; letter-spacing: 0.04em; font-family: 'Outfit', sans-serif; }
  .dart-total-field:focus { border-color: var(--accent); box-shadow: 0 0 8px rgba(var(--accent-rgb),0.15); }
  .dart-total-field.dt-valid   { border-color: var(--accent); color: var(--accent); }
  .dart-total-field.dt-bust    { border-color: var(--accent2); color: var(--accent2); }
  .dart-total-feedback {
    font-family: 'DM Mono', monospace;
    font-size: 0.63rem;
    letter-spacing: 0.1em;
    color: var(--text-dim);
    text-align: center;
    min-height: 0.9rem;
    transition: color 0.15s;
  }
  .dart-total-feedback.dt-fb-checkout { color: var(--accent3); }
  .dart-total-feedback.dt-fb-bust     { color: var(--accent2); }
  .dart-total-feedback.dt-fb-ok       { color: var(--text-dim); }

  /* ENTER / OK button */
  .btn-enter {
    background: linear-gradient(135deg, rgba(var(--accent-rgb),0.15), rgba(0,200,100,0.08));
    border-color: rgba(var(--accent-rgb),0.5);
    color: var(--accent);
    font-weight: bold;
  }
  .btn-enter:hover { background: rgba(var(--accent-rgb),0.25); }

  /* Common hits in dart-by-dart */
    font-family: 'DM Mono', monospace;
    font-size: 0.52rem;
    letter-spacing: 0.22em;
    color: var(--text-dim);
    text-align: center;
    margin-top: 2px;
  }
  .qs-preset-btn {
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text-dim);
    padding: 0.45rem 0.1rem;
    border-radius: 7px;
    cursor: pointer;
    font-family: 'Outfit', sans-serif;
    font-size: 0.9rem;
    letter-spacing: 0.04em;
    transition: all 0.12s;
    min-height: 40px;
  }
  .qs-preset-btn:hover  { background: var(--surface3); color: var(--text); border-color: var(--text-dim); }
  .qs-preset-btn:active { transform: scale(0.94); }
  .qs-preset-btn--gold  { color: var(--accent3); border-color: rgba(var(--accent3-rgb),0.35); }
  .qs-preset-btn--gold:hover { color: var(--accent3); border-color: var(--accent3); }

  /* hide/show panels */
  .panel-dart { }
  .panel-quick { display: none; }

  .turn-arrow {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--active-color, var(--accent));
    display: none;
  }
  .player-panel.active-player .turn-arrow { display: block; box-shadow: 0 0 6px var(--active-color, var(--accent)); }

  .input-summary-score {
    font-family: 'Outfit', sans-serif;
    font-size: 2.5rem;
    text-align: center;
    color: var(--accent);
    letter-spacing: 0.05em;
    min-height: 2.8rem;
  }

  /* ===== DYNAMIC CHECKOUT SUGGESTION PANEL ===== */
  .checkout-panel {
    background: linear-gradient(180deg, var(--surface2), var(--surface));
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
    box-shadow: var(--card-shadow);
  }

  .checkout-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.4rem 0.75rem;
    background: var(--surface3);
    border-bottom: 1px solid var(--border);
  }

  .checkout-panel-title {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    letter-spacing: 0.3em;
    color: var(--text-dim);
  }

  .checkout-panel-score {
    font-family: 'Outfit', sans-serif;
    font-size: 1rem;
    letter-spacing: 0.05em;
    color: var(--accent3);
  }

  .checkout-panel-body {
    padding: 0.6rem 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
  }

  .checkout-visit-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }

  .checkout-visit-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    color: var(--text-dim);
    letter-spacing: 0.15em;
    width: 32px;
    flex-shrink: 0;
  }

  .checkout-visit-label.next-visit { color: var(--accent3); }

  .checkout-darts-row {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    flex: 1;
  }

  .co-dart {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 4px 8px;
    border-radius: 6px;
    border: 1.5px solid transparent;
    transition: all 0.2s;
    min-width: 42px;
  }

  .co-dart.pending {
    border-color: var(--accent3);
    background: rgba(var(--accent3-rgb),0.08);
  }

  .co-dart.thrown {
    border-color: rgba(var(--accent3-rgb),0.2);
    background: rgba(var(--accent3-rgb),0.03);
    opacity: 0.45;
  }

  .co-dart.active-co {
    border-color: var(--accent3);
    background: rgba(var(--accent3-rgb),0.12);
    box-shadow: 0 0 8px rgba(var(--accent3-rgb),0.25);
  }

  .co-dart.missed {
    border-color: rgba(var(--accent3-rgb),0.3);
    background: rgba(var(--accent3-rgb),0.05);
    opacity: 0.5;
  }

  .co-dart-label {
    font-family: 'Outfit', sans-serif;
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.03em;
    color: var(--text);
  }

  .co-dart.pending .co-dart-label { color: var(--accent3); }
  .co-dart.active-co .co-dart-label { color: var(--accent3); }
  .co-dart.thrown .co-dart-label { color: rgba(var(--accent3-rgb),0.5); }
  .co-dart.missed .co-dart-label { color: rgba(var(--accent3-rgb),0.5); }

  .co-dart-score {
    font-family: 'DM Mono', monospace;
    font-size: 0.55rem;
    color: var(--text-dim);
    letter-spacing: 0.05em;
  }

  .co-dart.pending .co-dart-score { color: rgba(var(--accent3-rgb),0.6); }
  .co-dart.active-co .co-dart-score { color: rgba(var(--accent3-rgb),0.7); }

  .checkout-impossible {
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    color: var(--text-dim);
    letter-spacing: 0.1em;
    padding: 0.35rem 0;
    font-style: italic;
  }

  .checkout-panel-divider {
    height: 1px;
    background: var(--border);
    margin: 0.2rem 0;
  }

  /* ===== LEGS TRACKER IN HEADER ===== */
  .legs-tracker {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-left: 0.5rem;
  }

  .legs-player-block {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 0.2rem 0.5rem;
  }

  .legs-player-name {
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    color: var(--text-dim);
    letter-spacing: 0.05em;
    max-width: 60px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .legs-pips {
    display: flex;
    gap: 3px;
  }

  .leg-pip {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 1.5px solid currentColor;
    opacity: 0.3;
  }

  .leg-pip.won {
    opacity: 1;
    background: currentColor;
    box-shadow: 0 0 4px currentColor;
  }

  /* ===== LEG WIN OVERLAY ===== */
  #leg-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.88);
    z-index: 500;
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 1.5rem;
    text-align: center;
    backdrop-filter: blur(12px);
  }

  #leg-overlay.show { display: flex; }

  .leg-overlay-emoji { font-size: 3.5rem; animation: bounce 0.8s ease infinite alternate; }

  .leg-overlay-title {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(1.5rem,5vw,3rem);
    font-weight: 800;
    letter-spacing: 0.15em;
    color: var(--accent3);
    filter: drop-shadow(0 0 24px rgba(var(--accent3-rgb),0.6));
    text-shadow: 0 0 40px rgba(var(--accent3-rgb),0.3);
  }

  .leg-overlay-name {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(2rem,7vw,4.5rem);
    font-weight: 800;
    letter-spacing: 0.1em;
    line-height: 1;
    text-shadow: 0 0 30px rgba(255,255,255,0.12);
  }

  .leg-overlay-score {
    font-family: 'DM Mono', monospace;
    font-size: 0.9rem;
    color: var(--text-dim);
    letter-spacing: 0.2em;
  }

  .leg-pip-display {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
  }

  .leg-pip-player {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
  }

  .leg-pip-player-name {
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.1em;
  }

  .leg-pip-row {
    display: flex;
    gap: 5px;
  }

  .leg-pip-big {
    width: 16px; height: 16px;
    border-radius: 50%;
    border: 2px solid currentColor;
    opacity: 0.25;
    transition: all 0.3s;
  }

  .leg-pip-big.won {
    opacity: 1;
    background: currentColor;
    box-shadow: 0 0 8px currentColor;
  }

  .btn-next-leg {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    border: none;
    color: #000;
    padding: 0.9rem 2.5rem;
    border-radius: 12px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
    box-shadow: 0 4px 16px rgba(var(--accent-rgb),0.3), inset 0 1px 0 rgba(255,255,255,0.15);
    text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  }

  .btn-next-leg:hover {
    background: linear-gradient(135deg, var(--accent-hover), var(--accent));
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(var(--accent-rgb),0.45), inset 0 1px 0 rgba(255,255,255,0.2);
  }

  /* Leg number badge in scoreboard */
  .leg-badge {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    letter-spacing: 0.2em;
    color: var(--text-dim);
    text-align: center;
    padding: 3px 0;
    border-bottom: 1px solid var(--border);
    background: var(--surface2);
  }
  /* ===== CHECKOUT DIALOG ===== */
  #checkout-dialog { display: none; }
  #checkout-dialog.show { display: flex !important; }

  .co-dialog-box {
    background: var(--surface);
    border: 2px solid var(--accent);
    border-radius: 18px;
    padding: 2rem;
    width: min(480px, 94vw);
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    box-shadow: 0 0 60px rgba(var(--accent-rgb),0.2);
    animation: fadeUp 0.25s ease;
  }
  .co-dialog-title {
    font-family: 'Outfit', sans-serif;
    font-size: 2.2rem;
    color: var(--accent);
    letter-spacing: 0.15em;
    text-align: center;
    line-height: 1;
  }
  .co-dialog-player {
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    text-align: center;
    line-height: 1;
  }
  .co-dialog-section { display: flex; flex-direction: column; gap: 0.5rem; }
  .co-dialog-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.62rem;
    letter-spacing: 0.25em;
    color: var(--text-dim);
  }
  .co-dialog-btnrow {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }
  .co-dlg-btn {
    flex: 1;
    min-width: 48px;
    background: var(--surface2);
    border: 2px solid var(--border);
    color: var(--text-dim);
    padding: 0.7rem 0.5rem;
    border-radius: 9px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    cursor: pointer;
    transition: all 0.12s;
  }
  .co-dlg-btn:hover { border-color: var(--accent); color: var(--accent); }
  .co-dlg-btn--selected {
    background: rgba(var(--accent-rgb),0.12);
    border-color: var(--accent);
    color: var(--accent);
    box-shadow: 0 0 10px rgba(var(--accent-rgb),0.15);
  }
  .co-dialog-hint {
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    color: var(--text-dim);
    letter-spacing: 0.1em;
    text-align: center;
    min-height: 0.8rem;
  }
  .co-dlg-confirm {
    width: 100%;
    background: var(--accent);
    border: none;
    color: #000;
    padding: 0.9rem;
    border-radius: 10px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.6rem;
    letter-spacing: 0.12em;
    cursor: pointer;
    transition: all 0.15s;
  }
  .co-dlg-confirm:hover { background: var(--accent-hover); transform: translateY(-1px); }

  /* ===== PRACTICE ENTRY BUTTON ===== */
  .btn-practice-entry {
    width: 100%;
    background: transparent;
    border: 2px solid var(--border);
    color: var(--text-dim);
    padding: 0.75rem 1rem;
    border-radius: 10px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    letter-spacing: 0.12em;
    cursor: pointer;
    transition: all 0.2s;
    margin-top: 0.5rem;
  }
  .btn-practice-entry:hover { border-color: var(--accent3); color: var(--accent3); box-shadow: 0 0 16px rgba(var(--accent3-rgb),0.15); }

  /* ===== PRACTICE SCREEN ===== */
  #practice-screen {
    flex-direction: column;
    overflow-y: auto;
    padding: 0 0 2rem 0;
    align-items: stretch;
  }
  .practice-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.5rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
  }
  .practice-header-title {
    font-family: 'Outfit', sans-serif;
    font-size: 1.6rem;
    letter-spacing: 0.15em;
    color: var(--accent3);
  }
  .practice-modes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.25rem;
    padding: 1.5rem;
    max-width: 900px;
    width: 100%;
    margin: 0 auto;
  }
  .practice-card {
    background: linear-gradient(165deg, var(--surface2), var(--surface));
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 1.75rem;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    box-shadow: var(--card-shadow);
  }
  .practice-card:hover {
    border-color: rgba(var(--accent3-rgb),0.3);
    background: linear-gradient(165deg, rgba(var(--accent3-rgb),0.04), var(--surface2));
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.4), 0 0 20px rgba(var(--accent3-rgb),0.08);
  }
  .practice-card--premium {
    position: relative;
    border-color: rgba(var(--accent3-rgb),0.2);
  }
  .practice-card--premium:hover {
    border-color: rgba(var(--accent3-rgb),0.5);
    box-shadow: 0 12px 32px rgba(0,0,0,0.4), 0 0 24px rgba(var(--accent3-rgb),0.15);
  }
  .practice-card-premium-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    letter-spacing: 0.15em;
    font-weight: 600;
    color: var(--accent3);
    background: rgba(var(--accent3-rgb),0.12);
    border: 1px solid rgba(var(--accent3-rgb),0.35);
    border-radius: 5px;
    padding: 0.2rem 0.55rem;
    align-self: flex-start;
  }
  .practice-card-icon { font-size: 2.5rem; line-height: 1; }
  .practice-card-title {
    font-family: 'Outfit', sans-serif;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--accent3);
    line-height: 1;
  }
  .practice-card-desc {
    font-family: 'Outfit', sans-serif;
    font-size: 0.95rem;
    color: var(--text-dim);
    line-height: 1.4;
    font-weight: 500;
  }
  .practice-card-tag {
    font-family: 'DM Mono', monospace;
    font-size: 0.55rem;
    letter-spacing: 0.25em;
    color: var(--text-dim);
    border: 1px solid var(--border);
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    align-self: flex-start;
    margin-top: auto;
  }

  /* ===== PLAYER MODE TABS ===== */
  .player-mode-tabs {
    display: flex;
    gap: 0;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--border);
    margin-bottom: 0.75rem;
  }

  .player-mode-tab {
    flex: 1;
    padding: 0.55rem 0.3rem;
    background: transparent;
    border: none;
    color: var(--text-dim);
    font-family: 'DM Mono', monospace;
    font-size: 0.56rem;
    letter-spacing: 0.08em;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
    border-right: 1px solid var(--border);
  }
  .player-mode-tab:last-child { border-right: none; }
  .player-mode-tab.active {
    background: var(--accent);
    color: #000;
    font-weight: bold;
  }

  /* ===== BOT CARDS ===== */
  .bot-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.6rem;
    margin-top: 0.35rem;
  }

  .bot-card {
    background: var(--surface);
    border: 2px solid var(--border);
    border-radius: 10px;
    padding: 0.75rem 0.85rem;
    cursor: pointer;
    transition: border-color 0.18s, box-shadow 0.18s;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
  }
  .bot-card:hover { border-color: var(--accent); }
  .bot-card.selected {
    border-color: var(--accent);
    box-shadow: 0 0 14px rgba(var(--accent-rgb),0.3);
    background: rgba(var(--accent-rgb),0.07);
  }

  .bot-card-avatar {
    font-size: 1.6rem;
    line-height: 1;
    margin-bottom: 0.15rem;
  }

  .bot-card-name {
    font-family: 'Outfit', sans-serif;
    font-size: 1.15rem;
    letter-spacing: 0.05em;
    color: var(--text);
    line-height: 1;
  }

  .bot-card-avg {
    font-family: 'DM Mono', monospace;
    font-size: 0.52rem;
    letter-spacing: 0.12em;
    color: var(--text-dim);
  }

  .bot-card-skill {
    display: flex;
    gap: 2px;
    margin-top: 0.2rem;
  }
  .bot-skill-pip {
    width: 10px;
    height: 4px;
    border-radius: 2px;
    background: var(--border);
  }
  .bot-skill-pip.filled { background: var(--accent); }

  /* Bot thinking indicator during game */
  .bot-thinking-bar {
    display: none;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    background-size: 200% 100%;
    animation: botThink 0.9s linear infinite;
    border-radius: 2px;
    margin: 0.3rem 0;
  }
  .bot-thinking-bar.show { display: block; }
  @keyframes botThink {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
  }

  @media (max-width: 480px) {
    .player-mode-tab { font-size: 0.52rem; padding: 0.5rem 0.3rem; }
    .bot-cards-grid { grid-template-columns: repeat(3, 1fr); gap: 0.45rem; }
    .bot-card { padding: 0.6rem 0.65rem; }
    .bot-card-name { font-size: 1rem; }
  }

  .btn-25 {
    color: var(--accent);
    border-color: rgba(var(--accent-rgb),0.4);
    font-weight: bold;
  }
  .btn-25:hover { background: rgba(var(--accent-rgb),0.15); border-color: var(--accent); }

  .btn-bull {
    color: var(--accent2);
    border-color: rgba(var(--accent2-rgb),0.4);
    font-weight: bold;
    line-height: 1.1;
  }
  .btn-bull:hover { background: rgba(var(--accent2-rgb),0.15); border-color: var(--accent2); }

  /* ===== BULL UP OVERLAY ===== */
  #bull-up-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.92);
    z-index: 800;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    animation: fadeIn 0.25s ease;
  }
  #bull-up-overlay.show { display: flex; }

  .bull-up-box {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    width: 100%;
    max-width: 480px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    text-align: center;
    box-shadow: 0 0 60px rgba(var(--accent-rgb),0.12);
  }

  .bull-up-icon {
    font-size: clamp(2.5rem, 8vw, 4rem);
    animation: pulse 1.2s ease infinite;
  }

  .bull-up-title {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(2.2rem, 7vw, 3.5rem);
    letter-spacing: 0.15em;
    color: var(--accent);
    line-height: 1;
  }

  .bull-up-sub {
    font-family: 'DM Mono', monospace;
    font-size: clamp(0.65rem, 2vw, 0.85rem);
    color: var(--text-dim);
    letter-spacing: 0.2em;
    text-transform: uppercase;
  }

  .bull-up-players {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
    width: 100%;
    margin-top: 0.25rem;
  }

  .bull-up-player-btn {
    flex: 1;
    min-width: clamp(100px, 28vw, 140px);
    max-width: 180px;
    background: var(--surface2);
    border: 2px solid var(--border);
    border-radius: 14px;
    padding: clamp(0.75rem, 2vw, 1.25rem) 1rem;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    transition: all 0.15s;
    font-family: inherit;
  }

  .bull-up-player-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.3);
  }

  .bull-up-player-dot {
    width: clamp(14px, 3vw, 18px);
    height: clamp(14px, 3vw, 18px);
    border-radius: 50%;
  }

  .bull-up-player-name {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(1.2rem, 4vw, 1.8rem);
    letter-spacing: 0.1em;
    line-height: 1;
  }

  .bull-up-player-label {
    font-family: 'DM Mono', monospace;
    font-size: clamp(0.5rem, 1.3vw, 0.62rem);
    letter-spacing: 0.2em;
    color: var(--text-dim);
  }

  .bull-up-skip {
    background: none;
    border: none;
    color: var(--text-dim);
    font-family: 'DM Mono', monospace;
    font-size: clamp(0.55rem, 1.5vw, 0.7rem);
    letter-spacing: 0.15em;
    cursor: pointer;
    padding: 0.5rem;
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.15s;
    margin-top: 0.25rem;
  }
  .bull-up-skip:hover { color: var(--text); }


  .coming-soon-section {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1rem 2rem 2rem;
    max-width: 900px;
    margin: 0 auto;
    width: 100%;
  }

  .btn-coming-soon {
    display: flex;
    align-items: center;
    gap: 1rem;
    width: 100%;
    margin-top: 0.5rem;
    padding: 0.9rem 1.25rem;
    background: transparent;
    border: 1px dashed var(--border);
    border-radius: 10px;
    color: var(--text-dim);
    cursor: not-allowed;
    opacity: 0.55;
    font-family: inherit;
    text-align: left;
  }

  .btn-coming-soon-icon {
    font-size: 1.6rem;
    line-height: 1;
    flex-shrink: 0;
    filter: grayscale(0.4);
  }

  .btn-coming-soon-text {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
  }

  .btn-coming-soon-title {
    font-family: 'Outfit', sans-serif;
    font-size: 1.3rem;
    letter-spacing: 0.08em;
    color: var(--text-dim);
    line-height: 1;
  }

  .btn-coming-soon-badge {
    font-family: 'DM Mono', monospace;
    font-size: 0.55rem;
    letter-spacing: 0.25em;
    color: var(--accent);
    opacity: 0.8;
  }

  @media (max-width: 768px) {
    .coming-soon-section { padding: 0.75rem 1rem 1.5rem; gap: 0.55rem; }
    .btn-coming-soon { padding: 0.85rem 1rem; }
    .btn-coming-soon-title { font-size: 1.1rem; }
  }

  /* ===== PRACTICE GAME SCREEN ===== */
  #practice-game-screen { flex-direction: column; }
  .pg-body {
    flex: 1;
    display: flex;
    overflow: hidden;
  }
  .pg-main {
    flex: 1;
    overflow-y: auto;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .pg-turn-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    letter-spacing: 0.3em;
    color: var(--text-dim);
    text-align: center;
    margin-bottom: -4px;
  }

  /* Mode: 121 & Checkout — target display */
  .pg-target-card {
    background: var(--surface2);
    border: 2px solid var(--border);
    border-radius: 14px;
    padding: 1.5rem;
    text-align: center;
  }
  .pg-target-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.3em;
    color: var(--text-dim);
    margin-bottom: 0.4rem;
  }
  .pg-target-score {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(3.5rem, 10vw, 6rem);
    line-height: 1;
    color: var(--accent);
    letter-spacing: 0.05em;
    transition: color 0.2s;
  }
  .pg-target-score.pg-danger { color: var(--accent2); }
  .pg-checkout-hint {
    font-family: 'DM Mono', monospace;
    font-size: 0.75rem;
    color: var(--accent3);
    letter-spacing: 0.1em;
    margin-top: 0.5rem;
    min-height: 1.2rem;
  }
  .pg-darts-used {
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    color: var(--text-dim);
    letter-spacing: 0.15em;
    margin-top: 0.3rem;
  }

  /* Attempt history */
  .pg-history {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1rem;
    flex: 1;
  }
  .pg-history-title {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    letter-spacing: 0.25em;
    color: var(--text-dim);
    margin-bottom: 0.75rem;
  }
  .pg-history-list { display: flex; flex-direction: column; gap: 0.4rem; max-height: 200px; overflow-y: auto; }
  .pg-attempt-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.35rem 0.6rem;
    border-radius: 6px;
    background: var(--surface3);
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
  }
  .pg-attempt-row.pg-success { border-left: 3px solid var(--accent); }
  .pg-attempt-row.pg-bust    { border-left: 3px solid var(--accent2); color: var(--text-dim); }
  .pg-attempt-row.pg-skip    { border-left: 3px solid var(--border); color: var(--text-dim); }
  .pg-attempt-darts { color: var(--accent3); }

  /* Stats row */
  .pg-stats-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
  }
  .pg-stat-box {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0.75rem 0.5rem;
    text-align: center;
  }
  .pg-stat-val {
    font-family: 'Outfit', sans-serif;
    font-size: 2rem;
    color: var(--accent);
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .pg-stat-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.52rem;
    color: var(--text-dim);
    letter-spacing: 0.15em;
    margin-top: 0.2rem;
  }

  /* Power Scoring specific */
  .pg-power-header {
    background: var(--surface2);
    border: 2px solid var(--border);
    border-radius: 14px;
    padding: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }
  .pg-power-round {
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.25em;
    color: var(--text-dim);
  }
  .pg-power-score-big {
    font-family: 'Outfit', sans-serif;
    font-size: 3.5rem;
    color: var(--accent3);
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .pg-power-max {
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    color: var(--text-dim);
    text-align: right;
  }
  .pg-power-table {
    width: 100%;
    border-collapse: collapse;
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
  }
  .pg-power-table th {
    color: var(--text-dim);
    letter-spacing: 0.15em;
    padding: 0.4rem 0.5rem;
    border-bottom: 1px solid var(--border);
    text-align: left;
    font-size: 0.6rem;
  }
  .pg-power-table td {
    padding: 0.35rem 0.5rem;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    vertical-align: middle;
  }
  .pg-power-table tr.pg-current-row td { background: rgba(var(--accent-rgb),0.06); color: var(--text); }
  .pg-power-pts-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 5px;
    font-size: 0.75rem;
    font-weight: bold;
  }
  .pg-power-pts-0 { background: rgba(255,255,255,0.06); color: var(--text-dim); }
  .pg-power-pts-1 { background: rgba(100,200,255,0.15); color: #4af0ff; }
  .pg-power-pts-2 { background: rgba(var(--accent-rgb),0.15); color: var(--accent); }
  .pg-power-pts-3 { background: rgba(var(--accent-rgb),0.2); color: var(--accent); }
  .pg-power-pts-4 { background: rgba(var(--accent3-rgb),0.15); color: var(--accent3); }
  .pg-power-pts-5 { background: rgba(var(--accent3-rgb),0.2); color: var(--accent3); }
  .pg-power-pts-6 { background: rgba(255,180,0,0.25); color: #ffb000; }
  .pg-power-pts-7 { background: rgba(255,100,0,0.25); color: #ff7020; }
  .pg-power-pts-8 { background: rgba(var(--accent2-rgb),0.25); color: var(--accent2); }
  .pg-power-pts-9 { background: rgba(var(--accent2-rgb),0.35); color: var(--accent2); }

  .pg-power-zone-legend {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0.75rem;
  }
  .pg-zone-item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-family: 'DM Mono', monospace;
    font-size: 0.62rem;
    color: var(--text-dim);
  }
  .pg-zone-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
  }

  .pg-finish-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.85);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    z-index: 300;
    animation: fadeIn 0.3s ease;
  }
  .pg-finish-title {
    font-family: 'Outfit', sans-serif;
    font-size: 3rem;
    color: var(--accent3);
    letter-spacing: 0.2em;
  }
  .pg-finish-score {
    font-family: 'Outfit', sans-serif;
    font-size: 6rem;
    color: var(--accent);
    line-height: 1;
    letter-spacing: 0.05em;
  }
  .pg-finish-sub {
    font-family: 'DM Mono', monospace;
    font-size: 0.85rem;
    color: var(--text-dim);
    letter-spacing: 0.2em;
    text-align: center;
  }
  .pg-finish-btns { display: flex; gap: 1rem; }
  .pg-finish-btn {
    background: var(--surface2);
    border: 2px solid var(--border);
    color: var(--text);
    padding: 0.8rem 2rem;
    border-radius: 10px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.4rem;
    letter-spacing: 0.12em;
    cursor: pointer;
    transition: all 0.15s;
  }
  .pg-finish-btn:hover { border-color: var(--accent); color: var(--accent); }
  .pg-finish-btn.pg-finish-primary { background: var(--accent); color: #000; border-color: var(--accent); }
  .pg-finish-btn.pg-finish-primary:hover { background: var(--accent-hover); }

  /* Skip button for checkout */
  .btn-pg-skip {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-dim);
    padding: 0.5rem 1rem;
    border-radius: 8px;
    font-family: 'DM Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    cursor: pointer;
    transition: all 0.15s;
    align-self: center;
  }
  .btn-pg-skip:hover { border-color: var(--text-dim); color: var(--text); }

  /* ===== AROUND THE CLOCK ===== */
  .atc-timer {
    font-family: 'DM Mono', monospace;
    font-size: 2.2rem;
    color: var(--accent3);
    text-align: center;
    letter-spacing: 0.1em;
    text-shadow: 0 0 12px rgba(var(--accent3-rgb),0.3);
  }
  .atc-target-num {
    font-family: 'Outfit', sans-serif;
    font-size: 6rem;
    line-height: 1;
    text-align: center;
    color: var(--accent);
    text-shadow: 0 0 30px rgba(var(--accent-rgb),0.4);
  }
  .atc-target-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.3em;
    color: var(--text-dim);
    text-align: center;
  }
  .atc-darts-count {
    font-family: 'DM Mono', monospace;
    font-size: 0.75rem;
    color: var(--text-dim);
    text-align: center;
    letter-spacing: 0.15em;
  }
  .atc-progress {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    justify-content: center;
    padding: 0.5rem 0;
  }
  .atc-pip {
    width: 28px; height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'DM Mono', monospace;
    font-size: 0.6rem;
    font-weight: bold;
    border: 1.5px solid var(--border);
    color: var(--text-dim);
    background: var(--surface);
    transition: all 0.2s;
  }
  .atc-pip.done {
    border-color: var(--accent);
    background: rgba(var(--accent-rgb),0.15);
    color: var(--accent);
  }
  .atc-pip.current {
    border-color: var(--accent3);
    background: rgba(var(--accent3-rgb),0.12);
    color: var(--accent3);
    box-shadow: 0 0 8px rgba(var(--accent3-rgb),0.25);
  }
  .atc-hit-miss-btns {
    display: flex;
    gap: 0.8rem;
    justify-content: center;
    padding: 0.5rem 0;
  }
  .atc-btn {
    flex: 1;
    max-width: 160px;
    padding: 1.2rem 1rem;
    border-radius: 12px;
    font-family: 'Outfit', sans-serif;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    cursor: pointer;
    transition: all 0.15s;
    border: 2px solid;
  }
  .atc-btn-hit {
    background: rgba(var(--accent-rgb),0.12);
    border-color: var(--accent);
    color: var(--accent);
  }
  .atc-btn-hit:hover { background: rgba(var(--accent-rgb),0.25); }
  .atc-btn-miss {
    background: rgba(var(--accent2-rgb),0.08);
    border-color: var(--accent2);
    color: var(--accent2);
  }
  .atc-btn-miss:hover { background: rgba(var(--accent2-rgb),0.18); }

  @media (max-width: 768px) {
    .pg-body { flex-direction: column; }
    .pg-main { flex: 0 0 auto; max-height: 45dvh; padding: 0.75rem; }
    /* When input panel is hidden (JDC, Shanghai, Bob's 27, ATC) — take full height */
    .pg-body.pg-full .pg-main {
      flex: 1;
      max-height: none;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      padding: 0.5rem 0.6rem;
      gap: 0.5rem;
    }
    #pg-input-panel { flex: 1; border-top: 1px solid var(--border); border-left: none; }
    .pg-stats-row { grid-template-columns: repeat(3,1fr); gap: 0.5rem; }
    .pg-target-score { font-size: clamp(2.5rem, 12vw, 4rem); }
    .pg-power-score-big { font-size: 2.5rem; }
    .practice-modes-grid { grid-template-columns: 1fr; padding: 1rem; gap: 0.75rem; }
    .practice-card { padding: 1.2rem; }
    .pg-power-zone-legend { grid-template-columns: repeat(2,1fr); }

    /* Compact practice game elements on mobile */
    .pg-body.pg-full .pg-target-card { padding: 0.5rem 0.6rem; gap: 0.15rem; }
    .pg-body.pg-full .pg-target-score { font-size: clamp(2rem, 10vw, 3rem); margin: 0; }
    .pg-body.pg-full .pg-target-label { font-size: 0.6rem; margin: 0; }
    .pg-body.pg-full .pg-darts-used { font-size: 0.6rem; }
    .pg-body.pg-full .pg-checkout-hint { font-size: 0.65rem; }
    .pg-body.pg-full .pg-stats-row { gap: 0.35rem; }
    .pg-body.pg-full .pg-stat-box { padding: 0.3rem; }
    .pg-body.pg-full .pg-stat-val { font-size: clamp(1rem, 4vw, 1.3rem); }
    .pg-body.pg-full .pg-stat-label { font-size: 0.5rem; }

    /* Compact progress pips */
    .pg-body.pg-full .atc-progress { gap: 3px; padding: 0.2rem 0; }
    .pg-body.pg-full .atc-pip { width: 22px; height: 22px; font-size: 0.5rem; border-radius: 4px; }

    /* Compact JDC part bar */
    .pg-body.pg-full .jdc-part-bar { padding: 0.2rem 0.4rem; margin-bottom: 0.2rem; gap: 0.2rem; }
    .pg-body.pg-full .jdc-part-seg { height: 4px; }

    /* Compact dart pips */
    .pg-body.pg-full .jdc-dart-pips { margin: 0.15rem 0; gap: 0.3rem; }
    .pg-body.pg-full .jdc-pip { width: 1.7rem; height: 1.7rem; font-size: 0.65rem; }
    .pg-body.pg-full .jdc-shanghai-bonus { font-size: 0.6rem; min-height: 1em; margin: 0; }

    /* Compact buttons */
    .pg-body.pg-full .jdc-dart-btns { padding: 0.2rem 0.3rem; gap: 0.35rem; }
    .pg-body.pg-full .jdc-btn { padding: 0.55rem 0.3rem; font-size: 0.85rem; min-width: 58px; border-radius: 8px; }
    .pg-body.pg-full .jdc-dart-row-label { font-size: 0.62rem; margin: 0.1rem 0; }
    .pg-body.pg-full .atc-hit-miss-btns { padding: 0.25rem 0; gap: 0.6rem; }
    .pg-body.pg-full .atc-btn { padding: 0.8rem 0.8rem; font-size: 1.3rem; border-radius: 10px; }
    .pg-body.pg-full .atc-darts-count { font-size: 0.62rem; }

    /* Compact / hide history on mobile */
    .pg-body.pg-full .pg-history { margin-top: 0.2rem !important; padding: 0.4rem 0.5rem; }
    .pg-body.pg-full .pg-history-title { font-size: 0.55rem; margin-bottom: 0.3rem; }
    .pg-body.pg-full .pg-history-list { max-height: 70px; gap: 0.2rem; }
    .pg-body.pg-full .pg-attempt-row { padding: 0.2rem 0.5rem; font-size: 0.62rem; }
  }

  /* Very short portrait screens (iPhone SE etc) — hide history entirely */
  @media (max-width: 768px) and (max-height: 600px) and (orientation: portrait) {
    .pg-body.pg-full .pg-history { display: none; }
    .pg-body.pg-full .pg-target-score { font-size: clamp(1.8rem, 9vw, 2.5rem); }
    .pg-body.pg-full .pg-target-card { padding: 0.35rem 0.5rem; }
    .pg-body.pg-full .jdc-btn { padding: 0.45rem 0.25rem; font-size: 0.8rem; }
    .pg-body.pg-full .atc-btn { padding: 0.6rem 0.6rem; font-size: 1.1rem; }
  }

  /* =====================================================
     COMPREHENSIVE RESPONSIVE — all devices 280px → 4K
     ===================================================== */

  /* --- Base: prevent all horizontal overflow --- */
  *, *::before, *::after { box-sizing: border-box; }
  html { overflow-x: hidden; }
  body { overflow-x: hidden; max-width: 100vw; }

  /* ---- FLUID GLOBALS (apply at all sizes) ---- */
  /* Setup screen */
  #setup-screen { padding: clamp(0.5rem, 3vw, 2rem); }
  .setup-card {
    max-width: min(540px, calc(100vw - 1rem));
    width: 100%;
    padding: clamp(1rem, 4vw, 2.5rem);
  }
  .setup-section { margin-bottom: clamp(1rem, 3vw, 2rem); }
  .logo-wrap { margin-bottom: clamp(0.75rem, 3vw, 3rem); }
  .logo-sub {
    font-size: clamp(0.42rem, 1.5vw, 0.62rem);
    letter-spacing: clamp(0.05em, 0.5vw, 0.3em);
    padding: 0 0.5rem;
    word-break: break-word;
  }
  .logo-img { width: clamp(80px, 25vw, 160px); }
  .btn-opt { font-size: clamp(1rem, 3vw, 1.4rem); padding: clamp(0.5rem, 2vw, 0.75rem) 0.75rem; }
  .player-name-input { max-width: 100%; min-width: 0; }

  /* Game header: fluid */
  .game-header {
    padding: clamp(0.4rem, 1.5vw, 0.75rem) clamp(0.5rem, 2vw, 1.5rem);
    gap: clamp(0.35rem, 1vw, 1rem);
    flex-wrap: nowrap;
    min-height: 0;
  }
  .game-header-logo-text { font-size: clamp(1rem, 4vw, 1.5rem); }
  .game-mode-badge { font-size: clamp(0.8rem, 2.5vw, 1.35rem); white-space: nowrap; }
  .checkout-badge { font-size: clamp(0.5rem, 1.5vw, 0.7rem); white-space: nowrap; }
  .btn-icon { width: clamp(28px, 6vw, 36px); height: clamp(28px, 6vw, 36px); font-size: clamp(0.8rem, 2vw, 1rem); }

  /* Scoreboard: fluid score */
  .player-score-main {
    font-size: clamp(2.1rem, min(10.5vw, 12vh), 8.25rem);
    padding: clamp(0.35rem, 1.5vw, 1rem) clamp(0.1rem, 0.5vw, 0.5rem) clamp(0.2rem, 0.8vw, 0.5rem);
  }
  .player-panel { min-width: clamp(70px, 15vw, 160px); }
  .player-name-display { font-size: clamp(0.7rem, 2vw, 1rem); }
  .player-stats-mini { font-size: clamp(0.5rem, 1.3vw, 0.65rem); gap: clamp(0.15rem, 0.5vw, 0.5rem); }

  /* Input panel: fluid width on desktop, full width on mobile */
  .input-panel {
    min-width: 0;
    width: clamp(230px, 28vw, 320px);
    padding: clamp(0.6rem, 1.5vw, 1rem);
    gap: clamp(0.4rem, 1vw, 0.75rem);
  }
  .current-turn-name { font-size: clamp(1.1rem, 3.5vw, 1.8rem); }
  .current-turn-label { font-size: clamp(0.55rem, 1.2vw, 0.7rem); }

  /* Type score input: fluid */
  .type-score-hero { padding: clamp(0.6rem, 2vw, 1.25rem) clamp(0.6rem, 2vw, 1rem); gap: clamp(0.2rem, 0.5vw, 0.4rem); }
  .type-score-hero-feedback { font-size: clamp(0.55rem, 1.4vw, 0.68rem); }

  /* Numpad: fluid */
  .numpad { gap: clamp(0.2rem, 0.7vw, 0.4rem); }
  .btn-num {
    font-size: clamp(1rem, 2.5vw, 1.4rem);
    padding: clamp(0.55rem, 1.5vw, 0.85rem) clamp(0.2rem, 0.5vw, 0.5rem);
    min-height: clamp(40px, 7vw, 52px);
    border-radius: clamp(5px, 1vw, 8px);
  }
  .btn-enter { font-size: clamp(0.85rem, 2vw, 1.1rem); }

  /* Common hits: fluid grid */

  /* Win screen: fluid */
  .win-name { font-size: clamp(1.8rem, 8vw, 5rem); }
  .win-title { font-size: clamp(1.8rem, 6vw, 4rem); }
  .win-emoji { font-size: clamp(2.5rem, 8vw, 5rem); }
  .win-stats { flex-wrap: wrap; justify-content: center; gap: clamp(0.75rem, 2vw, 2rem); }
  .win-stat { min-width: clamp(70px, 16vw, 120px); padding: clamp(0.6rem, 1.5vw, 1rem) clamp(0.75rem, 2vw, 1.5rem); }
  .win-stat-value { font-size: clamp(1.2rem, 3.5vw, 2rem); }
  .win-players-stats { gap: clamp(0.6rem, 2vw, 1.2rem); }
  .win-player-card { min-width: 240px; padding: clamp(0.6rem, 2vw, 1rem); }
  .win-sg-label { font-size: clamp(0.48rem, 1.2vw, 0.58rem); }
  .win-sg-value { font-size: clamp(0.95rem, 2vw, 1.15rem); }
  .win-all-stats { max-width: 100%; overflow-x: auto; }
  .win-table { width: 100%; min-width: 260px; }
  .win-table th, .win-table td { padding: clamp(0.35rem, 1vw, 0.6rem) clamp(0.4rem, 1.5vw, 1rem); font-size: clamp(0.7rem, 1.5vw, 1rem); }
  #win-screen { padding: clamp(0.75rem, 3vw, 2rem); overflow-y: auto; gap: clamp(0.75rem, 2vw, 2rem); }
  .btn-play-again { font-size: clamp(1.1rem, 3vw, 1.6rem); padding: clamp(0.7rem, 2vw, 1rem) clamp(1.5rem, 4vw, 3rem); }

  /* Practice screen */
  .practice-modes-grid { grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr)); }
  #practice-screen { padding: clamp(0.5rem, 2vw, 1rem); overflow-y: auto; }

  /* Overlays and dialogs: fluid */
  .leg-overlay-name { font-size: clamp(2rem, 10vw, 4rem); }
  .leg-overlay-score { font-size: clamp(0.8rem, 2.5vw, 1.2rem); }
  .co-dialog-box { max-width: min(420px, calc(100vw - 1.5rem)); width: 100%; }
  .co-dialog-btnrow { flex-wrap: wrap; gap: 0.4rem; }
  .co-dlg-btn { min-width: clamp(32px, 10vw, 48px); font-size: clamp(0.75rem, 2vw, 0.9rem); }
  .checkout-panel { overflow-x: auto; }

  /* ---- MOBILE PORTRAIT (≤ 768px) ---- */
  @media (max-width: 768px) {
    /* Lock game screen to viewport */
    #game-screen.active { height: 100dvh; overflow: hidden; flex-direction: column; }
    .game-body { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }

    /* Scoreboard: compact horizontal strip at TOP */
    .scoreboard {
      flex-direction: row;
      flex: 0 0 auto;
      max-height: 38dvh;
      min-height: 0;
      overflow-x: auto;
      overflow-y: hidden;
      -webkit-overflow-scrolling: touch;
    }
    .player-panel { min-width: clamp(60px, 22vw, 120px); max-width: none; flex: 1; border-right: 1px solid var(--border); border-bottom: none; }
    .throws-history { height: 28px; max-height: 28px; overflow: hidden; padding: 2px 0.5rem; }
    .checkout-hint { display: none; }

    /* Input panel: fills remaining space below scoreboard */
    .input-panel {
      width: 100%;
      border-left: none;
      border-top: 1px solid var(--border);
      flex: 1;
      overflow-y: auto;
      min-height: 0;
      padding: clamp(0.5rem, 2vw, 0.75rem);
      gap: clamp(0.3rem, 1vw, 0.5rem);
    }

    /* Header: compact */
    .game-header { padding: 0.4rem 0.6rem; gap: 0.35rem; }
    .legs-tracker { gap: 0.2rem; }
    .legs-player-block { padding: 0.1rem 0.3rem; }
    #header-leg-num { display: none; }

    /* Numpad: bigger tap targets */
    .numpad { gap: 0.3rem; }
    .btn-num { padding: 0.75rem 0.35rem; min-height: 46px; }
    .btn-confirm { min-height: 50px; font-size: 1.2rem; }
    .btn-undo { min-height: 40px; }

    /* Win screen */
    #win-screen { padding: 1rem; gap: 1rem; }
    .win-player-card { min-width: 100%; }
    .win-stats-grid { gap: 0.35rem 0.5rem; }
    .win-sg-label { font-size: 0.48rem; }
    .win-sg-value { font-size: 0.95rem; }

    /* Setup */
    #setup-screen { padding: 0.75rem; }
    .logo-wrap { margin-bottom: 1.25rem; }
    .checkout-badge { display: none; }
    .checkout-badge:first-of-type { display: flex; }
  }

  /* ---- MOBILE PORTRAIT SMALL (≤ 480px) ---- */
  @media (max-width: 480px) {
    .scoreboard { min-height: 80px; }
    .player-score-main { font-size: clamp(2.25rem, 16.5vw, 4.2rem); }
    .player-panel { min-width: clamp(55px, 20vw, 95px); }
    .player-header { padding: 0.4rem 0.5rem; }
    .player-stats-mini { display: flex; font-size: clamp(0.42rem, 2.5vw, 0.58rem); gap: 0.2rem; }

    .input-panel { padding: 0.4rem 0.45rem; gap: 0.3rem; max-height: 68dvh; }
    .current-turn-name { font-size: 1.1rem; }
    .type-score-hero { padding: 0.5rem 0.6rem; }
    .btn-num { font-size: 1.3rem; min-height: 44px; padding: 0.7rem 0.25rem; }
  
    .win-name { font-size: clamp(1.6rem, 10vw, 3rem); }
    .win-stat-value { font-size: 1.3rem; }
    .leg-overlay-name { font-size: clamp(1.8rem, 10vw, 3.5rem); }
    .btn-next-leg { font-size: 1.1rem; padding: 0.7rem 1.2rem; }
  }

  /* ---- ULTRA SMALL (≤ 360px, e.g. Galaxy Fold outer) ---- */
  @media (max-width: 360px) {
    .logo-img { width: min(100px, 35vw); }
    .setup-card { padding: 0.85rem; }
    .player-score-main { font-size: clamp(1.8rem, 18vw, 3.3rem); }
    .player-panel { min-width: 50px; }
    .btn-num { font-size: 1.1rem; min-height: 42px; }
    .type-score-hero-input { font-size: 1.8rem; }
    .current-turn-name { font-size: 1rem; }
    .game-mode-badge { font-size: 0.5rem; }
    .game-header-logo-text { font-size: 0.95rem; }
    .win-name { font-size: clamp(1.4rem, 11vw, 2.5rem); }
    .win-stat { min-width: 60px; }
    .co-dlg-btn { min-width: 28px; font-size: 0.8rem; }
      .legs-tracker { display: none; }
  }

  /* ---- LANDSCAPE MOBILE (≤ 768px landscape) ---- */
  @media (max-width: 900px) and (orientation: landscape) {
    #game-screen.active { height: 100dvh; overflow: hidden; }
    .game-body { flex-direction: row; overflow: hidden; flex: 1; }
    .scoreboard {
      flex: 1;
      flex-direction: row;
      max-height: none;
      overflow-x: auto;
      overflow-y: hidden;
    }
    .player-panel { min-width: clamp(55px, 12vw, 120px); }
    .player-score-main { font-size: clamp(1.95rem, 9vw, 4.5rem); }
    .throws-history { height: 26px; max-height: 26px; overflow: hidden; padding: 2px 0.5rem; }
    .input-panel {
      width: clamp(190px, 30vw, 250px);
      border-left: 1px solid var(--border);
      border-top: none;
      overflow-y: auto;
      flex: 0 0 auto;
    }
    .btn-num { padding: 0.5rem 0.25rem; font-size: 1.1rem; min-height: 38px; }
    .btn-confirm { padding: 0.6rem; font-size: 1.1rem; min-height: 42px; }
    .current-turn-name { font-size: 1.1rem; }
    .numpad { gap: 0.25rem; }
    .checkout-panel { display: none; }
        .type-score-hero { padding: 0.4rem 0.5rem; gap: 0.15rem; }

    /* Practice full-screen modes in landscape */
    .pg-body.pg-full { flex-direction: row; }
    .pg-body.pg-full .pg-main { max-height: none; flex: 1; overflow-y: auto; padding: 0.4rem 0.6rem; gap: 0.4rem; }
    .pg-body.pg-full .pg-target-card { padding: 0.4rem 0.5rem; }
    .pg-body.pg-full .pg-target-score { font-size: clamp(1.8rem, 8vw, 2.5rem); }
    .pg-body.pg-full .atc-pip { width: 20px; height: 20px; font-size: 0.45rem; }
    .pg-body.pg-full .atc-progress { gap: 2px; padding: 0.1rem 0; }
    .pg-body.pg-full .pg-history { display: none; }
    .pg-body.pg-full .jdc-btn { padding: 0.4rem 0.3rem; font-size: 0.8rem; }
    .pg-body.pg-full .atc-btn { padding: 0.5rem 0.6rem; font-size: 1.1rem; }
  }

  /* ---- SHORT LANDSCAPE (height < 450px) ---- */
  @media (max-height: 450px) and (orientation: landscape) {
    .type-score-hero-label { display: none; }
    .type-score-hint { display: none; }
    .current-turn-label { display: none; }
    .btn-undo { display: none; }
    .numpad { gap: 0.2rem; }
    .btn-num { min-height: 34px; padding: 0.4rem 0.2rem; font-size: 1rem; }
      .type-score-hero { padding: 0.3rem 0.4rem; gap: 0.1rem; }

    /* Ultra-compact practice in short landscape */
    .pg-body.pg-full .pg-stat-val { font-size: 0.9rem; }
    .pg-body.pg-full .pg-stat-box { padding: 0.2rem; }
    .pg-body.pg-full .jdc-part-bar { display: none; }
    .pg-body.pg-full .jdc-dart-pips { margin: 0.1rem 0; }
    .pg-body.pg-full .jdc-pip { width: 1.4rem; height: 1.4rem; font-size: 0.55rem; }
  }

  /* ---- TABLET (769px – 1024px) ---- */
  @media (min-width: 769px) and (max-width: 1024px) {
    .input-panel { width: clamp(230px, 26vw, 290px); }
    .player-score-main { font-size: clamp(3rem, 8.25vw, 6rem); }
    .btn-num { font-size: 1.25rem; min-height: 48px; }
    .setup-card { max-width: 480px; }
  }

  /* ---- LARGE DESKTOP (≥ 1400px) ---- */
  @media (min-width: 1400px) {
    .input-panel { width: 340px; }
    .player-score-main { font-size: clamp(5.25rem, 6.75vw, 8.25rem); }
    .setup-card { max-width: 560px; }
    .btn-num { font-size: 1.4rem; min-height: 54px; }
  }

  /* ---- ULTRA-WIDE / 4K (≥ 2000px) ---- */
  @media (min-width: 2000px) {
    html { font-size: 18px; }
    .input-panel { width: 380px; }
    .game-header { padding: 1rem 2rem; }
    .setup-card { max-width: 600px; }
  }

  /* ---- TOUCH DEVICE: larger tap targets ---- */
  @media (hover: none) and (pointer: coarse) {
    .btn-confirm { min-height: 54px; }
    .btn-undo { min-height: 44px; }
      .btn-opt { min-height: 44px; }
    .btn-icon { min-width: 40px; min-height: 40px; }
  }

/* ===== JDC CHALLENGE ===== */
.jdc-dart-btns {
  display: flex; gap: 0.5rem; justify-content: center;
  padding: 0.4rem 0.5rem; flex-wrap: wrap;
}
.jdc-btn {
  flex: 1; min-width: 68px; padding: 0.75rem 0.4rem;
  border: 2px solid var(--border); border-radius: 10px;
  background: var(--surface2); color: var(--text);
  font-family: var(--font); font-size: 0.95rem; font-weight: 700;
  cursor: pointer; text-align: center; line-height: 1.4;
  transition: background 0.12s, transform 0.1s;
}
.jdc-btn:active { transform: scale(0.94); }
.jdc-single { border-color: var(--accent); }
.jdc-single:active { background: rgba(var(--accent-rgb),0.2); }
.jdc-double { border-color: #4af0ff; }
.jdc-double:active { background: rgba(74,240,255,0.2); }
.jdc-treble { border-color: var(--accent3); }
.jdc-treble:active { background: rgba(var(--accent3-rgb),0.2); }
.jdc-hit-btn { border-color: var(--accent); flex: 2; font-size: 1.05rem; }
.jdc-hit-btn:active { background: rgba(var(--accent-rgb),0.2); }
.jdc-miss-btn { border-color: #555; color: var(--text-dim); }
.jdc-dart-row-label {
  text-align: center; font-size: 0.72rem; letter-spacing: 0.12em;
  color: var(--text-dim); margin: 0.2rem 0 0.1rem;
}
.jdc-dart-pips {
  display: flex; gap: 0.45rem; justify-content: center;
  margin: 0.3rem 0 0.2rem;
}
.jdc-pip {
  width: 2.1rem; height: 2.1rem; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; font-weight: 700;
  border: 2px solid var(--border); background: var(--surface2);
  transition: all 0.2s;
}
.jdc-pip-hit  { border-color: var(--accent); color: var(--accent); background: rgba(var(--accent-rgb),0.12); }
.jdc-pip-miss { border-color: var(--accent2); color: var(--accent2); background: rgba(var(--accent2-rgb),0.12); }
.jdc-pip-next { border-color: var(--accent3); color: var(--accent3); }
.jdc-part-bar {
  display: flex; gap: 0.3rem; padding: 0.35rem 0.5rem;
  background: var(--surface2); border-radius: 8px;
  margin-bottom: 0.4rem;
}
.jdc-part-seg {
  flex: 1; height: 6px; border-radius: 3px;
  background: var(--border); transition: background 0.3s;
}
.jdc-part-seg.done { background: var(--accent); }
.jdc-part-seg.active { background: var(--accent3); }
.jdc-shanghai-bonus {
  font-size: 0.72rem; color: var(--accent3); letter-spacing: 0.1em;
  text-align: center; min-height: 1.2em; margin: 0.1rem 0;
}

/* ===== STATS SCREEN ===== */
#stats-screen { flex-direction: column; }
.stats-scroll {
  flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding: 1.25rem; display: flex; flex-direction: column; gap: 1.25rem;
}
.stats-section {
  background: linear-gradient(165deg, var(--surface2), var(--surface));
  border: 1px solid var(--border);
  border-radius: 16px; padding: 1.25rem;
  box-shadow: var(--card-shadow);
}
.stats-section-title {
  font-family: 'Outfit', sans-serif; font-size: 1.2rem; font-weight: 700;
  letter-spacing: 0.1em; color: var(--accent); margin-bottom: 1rem;
}
.stats-grid-4, .stats-grid-3 {
  display: grid; gap: 0.6rem; margin-bottom: 0.6rem;
}
.stats-grid-4 { grid-template-columns: repeat(4, 1fr); }
.stats-grid-3 { grid-template-columns: repeat(3, 1fr); }
.stats-tile {
  background: var(--surface3); border: 1px solid var(--border);
  border-radius: 10px; padding: 0.75rem 0.5rem; text-align: center;
}
.stats-tile-val {
  font-family: 'Outfit', sans-serif; font-size: 1.5rem; font-weight: 700;
  color: var(--text); line-height: 1; letter-spacing: 0.03em;
}
.stats-tile-label {
  font-family: 'DM Mono', monospace; font-size: 0.55rem;
  color: var(--text-dim); letter-spacing: 0.12em; margin-top: 0.35rem;
}

/* Match history */
.stats-match-header {
  display: grid; grid-template-columns: 28px 1fr 52px 52px 72px; gap: 0.4rem;
  padding: 0 0.5rem 0.4rem; font-family: 'DM Mono', monospace;
  font-size: 0.58rem; color: var(--text-dim); letter-spacing: 0.08em;
}
.stats-match-list { display: flex; flex-direction: column; gap: 0.4rem; max-height: 380px; overflow-y: auto; }
.stats-match-row {
  display: grid; grid-template-columns: 28px 1fr 52px 52px 72px; gap: 0.4rem;
  padding: 0.5rem 0.6rem; border-radius: 8px; background: var(--surface3);
  font-family: 'DM Mono', monospace; font-size: 0.75rem;
  align-items: center;
}
.stats-match-result {
  font-family: 'Outfit', sans-serif; font-size: 1rem;
  font-weight: 700; text-align: center;
}
.stats-match-won .stats-match-result { color: var(--accent); }
.stats-match-lost .stats-match-result { color: var(--accent2); }
.stats-match-opp { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.stats-match-score { text-align: center; }
.stats-match-avg { text-align: center; color: var(--accent3); }
.stats-match-date { text-align: right; color: var(--text-dim); font-size: 0.65rem; }

/* Practice bests */
.stats-practice-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.6rem;
}
.stats-practice-card {
  background: var(--surface3); border: 1px solid var(--border);
  border-radius: 12px; padding: 0.85rem; text-align: center;
}
.stats-practice-icon { font-size: 1.4rem; line-height: 1; }
.stats-practice-name {
  font-family: 'DM Mono', monospace; font-size: 0.6rem;
  color: var(--text-dim); letter-spacing: 0.1em; margin: 0.3rem 0;
}
.stats-practice-best {
  font-family: 'Outfit', sans-serif; font-size: 1.75rem; font-weight: 700;
  color: var(--accent3); line-height: 1; letter-spacing: 0.03em;
}
.stats-practice-sub {
  font-family: 'DM Mono', monospace; font-size: 0.55rem;
  color: var(--text-dim); margin-top: 0.25rem;
}
.stats-clear-btn {
  background: transparent; border: 1px solid rgba(var(--accent2-rgb),0.3);
  color: var(--accent2); padding: 0.6rem 1.4rem; border-radius: 8px;
  font-family: 'DM Mono', monospace; font-size: 0.65rem;
  letter-spacing: 0.12em; cursor: pointer; transition: all 0.15s;
}
.stats-clear-btn:hover { background: rgba(var(--accent2-rgb),0.1); border-color: var(--accent2); }
.btn-stats-entry { border-color: rgba(74,240,255,0.3) !important; }
.btn-stats-entry:hover { border-color: #4af0ff !important; color: #4af0ff !important; box-shadow: 0 0 16px rgba(74,240,255,0.15) !important; }

@media (max-width: 480px) {
  .stats-scroll { padding: 0.75rem; gap: 1rem; }
  .stats-section { padding: 1rem; }
  .stats-grid-4 { grid-template-columns: repeat(2, 1fr); gap: 0.5rem; }
  .stats-grid-3 { grid-template-columns: repeat(3, 1fr); }
  .stats-tile { padding: 0.7rem 0.4rem; }
  .stats-tile-val { font-size: 1.3rem; }
  .stats-tile-label { font-size: 0.5rem; }
  .stats-match-header { grid-template-columns: 24px 1fr 44px 44px 58px; font-size: 0.5rem; }
  .stats-match-row { grid-template-columns: 24px 1fr 44px 44px 58px; font-size: 0.68rem; padding: 0.4rem 0.45rem; }
  .stats-practice-grid { gap: 0.5rem; }
  .stats-practice-best { font-size: 1.4rem; }
}

/* ===== AUTH INPUTS (used in multiplayer setup) ===== */
.auth-field { margin-bottom: 1.25rem; }
.auth-label {
  font-family: 'DM Mono', monospace;
  color: var(--text-dim);
  font-size: 0.65rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
  display: block;
}
.auth-input {
  width: 100%;
  background: var(--surface2);
  border: 2px solid var(--border);
  color: var(--text);
  padding: 0.75rem 1rem;
  border-radius: 10px;
  font-family: 'Outfit', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  outline: none;
  transition: all 0.2s;
  box-sizing: border-box;
}
.auth-input:focus { border-color: var(--accent); box-shadow: 0 0 16px rgba(var(--accent-rgb),0.1); }
.auth-input::placeholder { color: var(--text-dim); opacity: 0.6; }
.mp-code-input {
  font-family: 'DM Mono', monospace;
}

/* ===== MULTIPLAYER STYLES ===== */
.mp-setup-body {
  padding: 1.5rem;
  max-width: 420px;
  margin: 0 auto;
}
.mp-section {
  background: linear-gradient(165deg, rgba(14,17,14,0.95), rgba(10,13,10,0.98));
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: var(--card-shadow);
}
.mp-section-title {
  font-family: 'Outfit', sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  color: var(--accent);
  margin-bottom: 0.25rem;
}
.mp-section-desc {
  font-family: 'DM Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  margin-bottom: 1rem;
}
.mp-divider {
  text-align: center;
  margin: 1.25rem 0;
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  color: var(--text-dim);
  letter-spacing: 0.2em;
  position: relative;
}
.mp-divider::before,
.mp-divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 35%;
  height: 1px;
  background: var(--border);
}
.mp-divider::before { left: 0; }
.mp-divider::after { right: 0; }
.mp-error {
  background: rgba(var(--accent2-rgb),0.12);
  border: 1px solid rgba(var(--accent2-rgb),0.4);
  color: var(--accent2);
  padding: 0.6rem 1rem;
  border-radius: 8px;
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: 1rem;
}

/* Lobby */
.mp-lobby-body {
  padding: 1.5rem;
  max-width: 420px;
  margin: 0 auto;
}
.mp-lobby-code-wrap {
  text-align: center;
  background: linear-gradient(165deg, var(--surface2), var(--surface));
  border: 1px solid rgba(var(--accent-rgb),0.12);
  border-radius: 16px;
  padding: 1.75rem;
  margin-bottom: 1.25rem;
  box-shadow: var(--card-shadow), inset 0 1px 0 rgba(var(--accent-rgb),0.05);
}
.mp-lobby-code-label {
  font-family: 'DM Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.3em;
  color: var(--text-dim);
  margin-bottom: 0.5rem;
}
.mp-lobby-code-display {
  font-family: 'Outfit', sans-serif;
  font-size: 3.5rem;
  font-weight: 800;
  letter-spacing: 0.35em;
  color: var(--accent);
  line-height: 1;
  text-shadow: 0 0 30px rgba(var(--accent-rgb),0.4);
}
.mp-lobby-code-hint {
  font-family: 'DM Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  margin-top: 0.5rem;
}
.mp-lobby-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1.25rem;
  margin-bottom: 1.25rem;
}
.mp-lobby-player {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 0.5rem;
}
.mp-lobby-player-name {
  font-family: 'Outfit', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
}
.mp-host-badge {
  font-family: 'DM Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  color: var(--accent3);
  border: 1px solid rgba(var(--accent3-rgb),0.3);
  background: rgba(var(--accent3-rgb),0.08);
  padding: 0.1rem 0.5rem;
  border-radius: 4px;
  margin-left: auto;
}
.mp-lobby-wait {
  font-family: 'DM Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  text-align: center;
  padding: 0.75rem;
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}
.mp-setting {
  display: flex;
  justify-content: space-between;
  padding: 0.4rem 0;
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  color: var(--text-dim);
  letter-spacing: 0.1em;
}
.mp-setting span:last-child { color: var(--text); }

/* Wait overlay for non-active player */
.mp-wait-overlay {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 50%;
  background: rgba(0,0,0,0.85);
  z-index: 200;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.mp-wait-text {
  font-family: 'Outfit', sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  animation: pulse 2s ease-in-out infinite;
}

/* ===== DARTBOARD OVERLAY STYLES ===== */
.db-open-btn {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 0.6rem;
  border-radius: 8px;
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  cursor: pointer;
  transition: all 0.2s;
  margin-top: 0.5rem;
}
.db-open-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.db-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.95);
  z-index: 600;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.db-container {
  width: 100%;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1rem;
  position: relative;
}
.db-camera {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 420px;
  border-radius: 12px;
  opacity: 0.2;
  z-index: 0;
}
.db-board-wrap {
  position: relative;
  z-index: 1;
  width: 85vw;
  max-width: 340px;
  aspect-ratio: 1;
}
.db-svg {
  width: 100%;
  height: 100%;
}
.db-segment {
  cursor: pointer;
  transition: opacity 0.12s;
  stroke: #333;
  stroke-width: 0.3;
}
.db-segment:hover { opacity: 0.8; }
.db-segment.db-tapped {
  opacity: 0.5;
  filter: brightness(1.5);
}
.db-segment-double { opacity: 0.95; }
.db-segment-treble { opacity: 0.95; }
.db-segment-single { opacity: 0.85; }
.db-segment-bull { cursor: pointer; }
.db-segment-bullseye { cursor: pointer; }

.db-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 340px;
  margin-top: 0.75rem;
  gap: 0.75rem;
}
.db-dart-labels-wrap {
  display: flex;
  gap: 0.4rem;
}
.db-dart-label {
  display: inline-block;
  min-width: 2.5rem;
  text-align: center;
  padding: 0.3rem 0.5rem;
  border-radius: 6px;
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
}
.db-dart-label.empty {
  background: var(--surface2);
  color: var(--text-dim);
  border: 1px solid var(--border);
}
.db-dart-label.filled {
  background: rgba(var(--accent-rgb),0.15);
  color: var(--accent);
  border: 1px solid rgba(var(--accent-rgb),0.4);
}
.db-total-wrap {
  text-align: center;
}
.db-total-label {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: 0.5rem;
  letter-spacing: 0.2em;
  color: var(--text-dim);
}
.db-total-value {
  font-family: 'Outfit', sans-serif;
  font-size: 2rem;
  color: var(--accent);
  line-height: 1;
}
.db-dart-count {
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  color: var(--text-dim);
  letter-spacing: 0.1em;
}
.db-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
  width: 100%;
  max-width: 340px;
}
.db-btn {
  flex: 1;
  padding: 0.7rem 0.5rem;
  border-radius: 8px;
  font-family: 'Outfit', sans-serif;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  cursor: pointer;
  transition: all 0.15s;
  border: none;
}
.db-btn-miss {
  background: var(--surface2);
  color: var(--text-dim);
  border: 1px solid var(--border);
}
.db-btn-miss:hover { border-color: var(--text-dim); }
.db-btn-undo {
  background: var(--surface2);
  color: var(--accent2);
  border: 1px solid rgba(var(--accent2-rgb),0.3);
}
.db-btn-undo:hover { border-color: var(--accent2); }
.db-btn-confirm {
  background: var(--accent);
  color: #000;
  flex: 1.5;
}
.db-btn-confirm:hover:not(:disabled) {
  background: var(--accent-hover);
  transform: translateY(-1px);
}
.db-btn-close {
  background: transparent;
  color: var(--text-dim);
  border: 1px solid var(--border);
  flex: 0.5;
  font-size: 1.2rem;
}
.db-btn-close:hover { border-color: var(--text-dim); color: var(--text); }

/* ===== BOTTOM NAVIGATION ===== */
.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: flex-end;
  justify-content: space-around;
  background: rgba(var(--surface-rgb, 12,15,12), 0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid rgba(var(--border-rgb, 255,255,255), 0.06);
  padding: 0.4rem 0 max(0.4rem, env(safe-area-inset-bottom));
  z-index: 100;
}

.nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
  cursor: pointer;
  color: var(--text-dim);
  transition: color 0.15s;
  min-width: 48px;
  padding: 0.3rem 0.5rem;
  -webkit-tap-highlight-color: transparent;
}
.nav-item span {
  font-family: 'DM Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.nav-item.active { color: var(--accent); }
.nav-item:not(.nav-play):active { transform: scale(0.92); }

.nav-play {
  position: relative;
  top: -0.5rem;
}
.nav-play-btn {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(var(--accent-rgb), 0.35);
  transition: transform 0.15s, box-shadow 0.15s;
}
.nav-play-btn svg { color: #000; }
.nav-play:active .nav-play-btn {
  transform: scale(0.92);
  box-shadow: 0 2px 8px rgba(var(--accent-rgb), 0.25);
}
.nav-play span { color: var(--text-dim); margin-top: 0.2rem; }

/* Body padding for bottom nav */
body { padding-bottom: 5rem; }

/* ===== SCREEN HEADER (back arrow) ===== */
.screen-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}
.screen-header-title {
  font-family: 'Outfit', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text);
}

/* ===== HOME SCREEN ===== */
.home-hero {
  text-align: center;
  padding: 2rem 1rem 1.5rem;
}
.home-logo-wrap {
  margin-bottom: 0.5rem;
}
.home-logo-wrap .logo-text {
  font-size: 3rem;
}
.home-tagline {
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--text-dim);
}
.home-collab {
  font-family: 'DM Mono', monospace;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  margin-top: 0.15rem;
}

/* Quick action grid */
.quick-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  padding: 0 1.25rem;
  margin-bottom: 1.5rem;
}
.quick-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1.25rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: transform 0.15s, border-color 0.15s, background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.quick-card:active {
  transform: scale(0.96);
  border-color: var(--accent);
  background: rgba(var(--accent-rgb), 0.04);
}
.quick-card-icon {
  color: var(--accent);
  margin-bottom: 0.5rem;
}
.quick-card-label {
  font-family: 'Outfit', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--text);
  margin-bottom: 0.15rem;
}
.quick-card-sub {
  font-family: 'DM Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  color: var(--text-dim);
}

/* Recent matches on home */
.home-recent {
  padding: 0 1.25rem;
  margin-bottom: 1rem;
}
.home-section-title {
  font-family: 'DM Mono', monospace;
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  margin-bottom: 0.75rem;
  padding-left: 0.25rem;
}
.home-recent-list {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
.home-match-row {
  display: grid;
  grid-template-columns: 28px 1fr auto auto auto;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 0.75rem;
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border);
}
.home-match-row:last-child { border-bottom: none; }
.home-match-result {
  font-weight: 700;
  text-align: center;
  font-size: 0.75rem;
}
.home-match-won .home-match-result { color: var(--accent); }
.home-match-lost .home-match-result { color: var(--accent2); }
.home-match-opp { color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.home-match-score { color: var(--text-dim); }
.home-match-avg { color: var(--accent3); }
.home-match-date { color: var(--text-dim); font-size: 0.6rem; }

/* ===== MORE MENU ===== */
.more-menu {
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.more-menu-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: transform 0.15s, border-color 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.more-menu-item:active {
  transform: scale(0.98);
  border-color: var(--accent);
}
.more-menu-icon {
  color: var(--accent);
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--accent-rgb), 0.08);
  border-radius: 10px;
}
.more-menu-label {
  font-family: 'Outfit', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0.05em;
}
.more-menu-sub {
  font-family: 'DM Mono', monospace;
  font-size: 0.6rem;
  color: var(--text-dim);
  letter-spacing: 0.04em;
  margin-top: 0.1rem;
}

