:root{
  --bg:#0f1216;
  --bg-2:#151a21;
  --panel:#1b212a;
  --panel-2:#232b36;
  --border:#2a3340;
  --text:#e6ebf2;
  --muted:#8a95a5;
  --accent:#d4a24c;
  --accent-2:#e9c27a;
  --ok:#5fb878;
  --warn:#e0b040;
  --err:#e5615f;
  --shadow:0 8px 30px rgba(0,0,0,.35);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5}
a{color:var(--accent-2);text-decoration:none}
h1,h2,h3{margin:0 0 .5em;font-weight:600;letter-spacing:.2px}
h2{font-size:1.6rem;margin-bottom:.2em}
.subtitle{color:var(--muted);margin:0 0 1.5em}

/* HEADER */
.app-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;background:linear-gradient(180deg,#161b23,#121821);
  border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;
  backdrop-filter:blur(8px)
}
.brand{display:flex;align-items:center;gap:12px}
.brand i{color:var(--accent);font-size:1.6rem}
.brand h1{font-size:1.3rem;margin:0}
.brand h1 span{color:var(--accent)}
nav{display:flex;gap:6px;flex-wrap:wrap}
.nav-btn{
  background:transparent;border:1px solid transparent;color:var(--muted);
  padding:8px 14px;border-radius:10px;cursor:pointer;font-size:.9rem;
  transition:.2s;display:inline-flex;align-items:center;gap:6px
}
.nav-btn:hover{color:var(--text);background:var(--panel)}
.nav-btn.active{color:var(--accent);background:var(--panel);border-color:var(--border)}
.nav-btn.icon-only{padding:8px 10px}

/* VIEWS */
main{padding:28px}
.view{display:none;animation:fade .3s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.container{max-width:1100px;margin:0 auto}
.container.wide{max-width:1500px}

/* UPLOAD */
.upload-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}
@media(max-width:820px){.upload-grid{grid-template-columns:1fr}}
.dropzone{
  background:var(--panel);border:2px dashed var(--border);border-radius:var(--radius);
  padding:48px 24px;text-align:center;cursor:pointer;transition:.2s
}
.dropzone.drag{border-color:var(--accent);background:#202834}
.dropzone i{font-size:2.5rem;color:var(--accent);margin-bottom:10px}
.dropzone h3{margin:6px 0}
.dropzone p{color:var(--muted);margin:0}
.link{color:var(--accent-2);cursor:pointer;text-decoration:underline}

.qr-panel{
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;text-align:center
}
.qr-panel #qr-code{display:flex;justify-content:center;margin:14px 0;
  background:#fff;padding:10px;border-radius:10px;width:fit-content;margin-left:auto;margin-right:auto}
.qr-panel small{color:var(--muted)}

.previews{display:flex;flex-wrap:wrap;gap:14px;margin:20px 0}
.preview-card{
  background:var(--panel);border:1px solid var(--border);border-radius:12px;
  padding:8px;position:relative;width:200px
}
.preview-card img{width:100%;height:260px;object-fit:cover;border-radius:8px;background:#000}
.preview-card .rm{
  position:absolute;top:6px;right:6px;background:rgba(0,0,0,.6);color:#fff;
  border:none;border-radius:50%;width:28px;height:28px;cursor:pointer
}
.preview-card small{display:block;color:var(--muted);margin-top:6px;font-size:.8rem;word-break:break-all}

/* BUTTONS */
.btn{
  background:var(--panel-2);color:var(--text);border:1px solid var(--border);
  padding:10px 18px;border-radius:10px;cursor:pointer;font-size:.95rem;
  display:inline-flex;align-items:center;gap:8px;transition:.2s
}
.btn:hover{background:#2a3342;border-color:#3a4558}
.btn.primary{background:linear-gradient(180deg,var(--accent),#b8862f);color:#1a130a;border-color:#a8791e;font-weight:600}
.btn.primary:hover{filter:brightness(1.08)}
.btn.sm{padding:6px 10px;font-size:.85rem}
.btn:disabled{opacity:.5;cursor:not-allowed}
.actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}

/* PANEL */
.panel{
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow)
}
.panel h3{margin-top:0;color:var(--accent-2);font-size:1rem;letter-spacing:.5px;text-transform:uppercase}

/* ANALYZE */
.analyze-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px}
@media(max-width:900px){.analyze-grid{grid-template-columns:1fr}}
.progress{height:10px;background:#11161d;border-radius:6px;overflow:hidden;margin-bottom:8px}
.progress-bar{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .3s}
.progress-label{color:var(--muted);font-size:.85rem;margin-bottom:12px}
.log{list-style:none;margin:0;padding:0;max-height:460px;overflow:auto;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.82rem}
.log li{padding:4px 8px;border-bottom:1px solid #20262e;color:#c1c9d4}
.log li.ok{color:var(--ok)}
.log li.warn{color:var(--warn)}
.log li.err{color:var(--err)}
.log li.info{color:#80a9d6}

.quality-index{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.quality-circle{position:relative;width:130px;height:130px}
.quality-circle svg{width:100%;height:100%}
.quality-value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column}
.quality-value span{font-size:1.8rem;font-weight:700}
.quality-value small{color:var(--muted)}
.quality-stats{list-style:none;margin:0;padding:0;flex:1;min-width:180px}
.quality-stats li{padding:4px 0;color:var(--muted);font-size:.9rem;display:flex;justify-content:space-between}
.quality-stats li b{color:var(--text)}
/* Live-Timer neben der Panel-Überschrift "Fortschritt" */
.timer-live{
  display:inline-flex;align-items:center;gap:6px;
  margin-left:10px;padding:2px 10px;border-radius:999px;
  background:rgba(212,162,76,.12);color:var(--accent-2);
  font-size:.78rem;font-family:ui-monospace,monospace;font-weight:600;
  vertical-align:middle;
}
.timer-live[hidden]{display:none}
.timer-live i{font-size:.8rem;opacity:.8}
.ok{color:var(--ok)!important}
.warn{color:var(--warn)!important}
.err{color:var(--err)!important}

/* REVIEW */
.review-grid{display:grid;grid-template-columns:minmax(380px,520px) 1fr 1fr;gap:20px}
@media(max-width:1200px){.review-grid{grid-template-columns:1fr 1fr;}.image-panel{grid-column:span 2}}
@media(max-width:720px){.review-grid{grid-template-columns:1fr}.image-panel{grid-column:auto}}
#board{width:100%;max-width:480px;min-width:320px;margin:0 auto}
.board-panel{min-width:360px}
.board-controls{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:14px}
.move-indicator{margin:0 10px;color:var(--muted);font-variant-numeric:tabular-nums}

.moves-table{display:grid;grid-template-columns:40px 1fr 1fr;gap:6px;font-variant-numeric:tabular-nums;
  max-height:640px;overflow:auto}
.moves-table .mv-num{color:var(--muted);padding:6px 4px;text-align:right}
.moves-table .mv{
  padding:4px 8px;background:#1f2631;border:1px solid #242c39;border-radius:8px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:6px;font-size:.95rem;
  min-height:44px
}
.moves-table .mv-text{min-width:40px;flex:1}
.moves-table .mv-edit{
  background:transparent;border:none;color:var(--muted);cursor:pointer;padding:3px 5px;
  border-radius:4px;font-size:.8rem
}
.moves-table .mv-edit:hover{color:var(--accent);background:rgba(212,162,76,.1)}
.moves-table .mv:hover .mv-edit{color:var(--accent-2)}
.moves-table .mv:hover{background:#2a3240}
.moves-table .mv.active{background:var(--accent);color:#1a1208;border-color:var(--accent)}
.moves-table .mv.illegal{border-color:var(--err);background:#3a1e1e}
.moves-table .mv.fixed{border-color:var(--warn);background:#342a15}
.moves-table .mv .tag{font-size:.7rem;opacity:.8}
.alt-popup{
  position:absolute;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;
  padding:8px;box-shadow:var(--shadow);z-index:20;min-width:180px
}
.alt-popup button{
  display:block;width:100%;text-align:left;padding:6px 10px;background:transparent;border:none;
  color:var(--text);cursor:pointer;border-radius:6px;font-size:.9rem
}
.alt-popup button:hover{background:var(--panel)}

.image-viewer{
  position:relative;overflow:auto;max-height:80vh;min-height:200px;
  background:#0b0d11;border-radius:10px;padding:0;
  cursor:grab;user-select:none;
  /* Kein overflow:hidden – auto reicht und erlaubt Scrollbars */
}
.image-viewer.iv-dragging{cursor:grabbing}
.iv-controls{
  position:sticky;top:0;left:0;z-index:5;
  display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:linear-gradient(180deg,rgba(11,13,17,.95),rgba(11,13,17,.7));
  backdrop-filter:blur(4px);border-bottom:1px solid var(--border);
}
.iv-btn{
  background:var(--panel-2);border:1px solid var(--border);color:var(--text);
  width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:.9rem;
  display:inline-flex;align-items:center;justify-content:center;padding:0
}
.iv-btn:hover{background:#2a3342}
.iv-zoom{flex:1;min-width:80px;max-width:200px;accent-color:var(--accent)}
.iv-pct{color:var(--muted);font-size:.8rem;min-width:44px;text-align:right;
  font-variant-numeric:tabular-nums}
/* Stage: Breite kommt per inline-style von _applyImageZoom als %-Wert.
   Kein min-width:max-content – das ließ den Viewer breiter werden als
   das Panel. Wraps sind 100% des Stage, Bilder 100% des Wraps. */
.iv-stage{padding:6px;display:flex;flex-direction:column;gap:8px;/* Breite per JS als %-Wert */}
.iv-wrap{position:relative;flex:none;width:100%;}
.iv-wrap img{display:block;border-radius:8px;width:100%;height:auto;
  pointer-events:none;user-select:none}
.iv-wrap.iv-active-page{outline:2px solid var(--accent);outline-offset:-2px;border-radius:8px}
.iv-marker{
  position:absolute;pointer-events:none;
  /* left/width/top/height werden aus JS gesetzt (2D-Zelle) */
  border:2px dashed rgba(212,162,76,.85);
  background:rgba(212,162,76,.08);
  box-shadow:0 0 0 1px rgba(212,162,76,.3) inset, 0 0 14px rgba(212,162,76,.25);
  border-radius:4px;
  transition:top .2s ease, height .2s ease, left .2s ease, width .2s ease;
}
/* Kalibrier-Modus */
.image-viewer.iv-calibrating{cursor:crosshair}
.image-viewer.iv-calibrating .iv-wrap img{cursor:crosshair;pointer-events:auto}
.iv-cal-hint{
  position:sticky;top:46px;z-index:4;margin:0 10px;
  padding:8px 12px;background:rgba(74,163,255,.12);
  border:1px solid rgba(74,163,255,.45);color:#bfdcff;
  border-radius:8px;font-size:.85rem
}
.iv-anchor{
  /* 1D-Anker (nur y): Horizontale Linie über die ganze Breite */
  position:absolute;left:0;right:0;height:0;pointer-events:none;
  border-top:2px solid #4aa3ff;
  box-shadow:0 0 0 1px rgba(74,163,255,.4);
}
.iv-anchor.iv-anchor-2d{
  /* 2D-Anker (x und y): kleiner Punkt am markierten Ort */
  right:auto;width:12px;height:12px;
  transform:translate(-50%, -50%);
  border:2px solid #4aa3ff;border-top:2px solid #4aa3ff;
  background:rgba(74,163,255,.35);
  border-radius:50%;
  box-shadow:0 0 0 1px rgba(11,13,17,.6), 0 0 8px rgba(74,163,255,.6);
}
.iv-anchor::after{
  content:attr(data-label);
  position:absolute;left:4px;top:-18px;
  background:#4aa3ff;color:#0b0d11;
  font-size:.7rem;padding:1px 6px;border-radius:4px;font-weight:600;
  white-space:nowrap;
}
.iv-anchor.iv-anchor-2d::after{ left:14px; top:-8px }
.iv-btn.iv-cal-active{background:#4aa3ff;color:#0b0d11;border-color:#4aa3ff}
/* Auto-Kalibrier-Wizard: unterscheidbar vom manuellen Kalibrier-Modus */
.iv-btn[data-iv="auto-cal"].iv-cal-active{
  background:#5fb878;border-color:#5fb878;color:#0b0d11;
  box-shadow:0 0 0 2px rgba(95,184,120,.35);
}

/* EXPORT */
.export-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:18px}
.export-meta label{display:flex;flex-direction:column;font-size:.8rem;color:var(--muted);gap:4px}
.export-meta input,.export-meta select,.modal input,.modal select{
  background:#11151c;border:1px solid var(--border);color:var(--text);
  padding:8px 10px;border-radius:8px;font-size:.92rem;font-family:inherit
}
.pgn-out{
  width:100%;min-height:320px;background:#0b0d11;color:#e6ebf2;border:1px solid var(--border);
  border-radius:10px;padding:14px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.88rem;resize:vertical
}
.pgn-annot-opt{
  display:inline-flex;align-items:center;gap:6px;margin-left:auto;
  font-size:.85rem;color:var(--muted);cursor:pointer;user-select:none;
}
.pgn-annot-opt input[type=checkbox]:disabled + span{opacity:.55}
.pgn-annot-opt input[type=checkbox]:disabled ~ small{opacity:.7}
.pgn-annot-opt small{font-size:.75rem;opacity:.65}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50}
.modal[hidden]{display:none}
.modal-body{
  background:var(--panel);border:1px solid var(--border);border-radius:14px;
  width:min(520px,92vw);box-shadow:var(--shadow);overflow:hidden
}
.modal-body header{
  padding:14px 20px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center
}
.modal-body header h3{margin:0;color:var(--accent-2);font-size:1rem}
.modal-body .close{background:none;border:none;color:var(--muted);font-size:1.6rem;cursor:pointer}
.modal-content{padding:20px;display:flex;flex-direction:column;gap:14px}
.modal-content label{display:flex;flex-direction:column;gap:6px;font-size:.88rem;color:var(--muted)}
.modal-content small{color:var(--muted);font-size:.78rem;line-height:1.4}
.modal-content code{background:#0b0d11;padding:1px 5px;border-radius:4px;font-size:.78rem}

/* TOAST */
#toast-container{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:100}
.toast{
  background:var(--panel-2);border:1px solid var(--border);border-left:3px solid var(--accent);
  padding:10px 16px;border-radius:8px;min-width:220px;box-shadow:var(--shadow);
  animation:slide .25s ease
}
.toast.ok{border-left-color:var(--ok)}
.toast.err{border-left-color:var(--err)}
.toast.warn{border-left-color:var(--warn)}
@keyframes slide{from{transform:translateX(100%);opacity:0}to{transform:none;opacity:1}}

/* Chessboard tweaks */
.board-panel .white-1e1d7{background:#efe3c7!important}
.board-panel .black-3c85d{background:#b58863!important}

/* Stockfish-Engine-Badges in der Zug-Tabelle */
.eng-dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  margin-right:5px;vertical-align:middle;cursor:help;
  box-shadow:0 0 0 1px rgba(0,0,0,.25) inset;
}
.eng-inaccuracy{background:#e0b040}
.eng-mistake   {background:#e08040}
.eng-blunder   {background:#e5615f;box-shadow:0 0 6px rgba(229,97,95,.55)}
/* Blunder MIT plausibler OCR-Alternative: blauer Ring, klickbar */
.eng-ocr-fix{
  width:10px;height:10px;
  box-shadow:0 0 0 2px #4aa3ff, 0 0 8px rgba(74,163,255,.6);
}
.quality-stats .muted{color:var(--muted)}

/* LIVE-DETAILS (Technik-Protokoll) — einklappbar unter dem Haupt-Log */
.analyze-trace{
  margin-top:10px;border:1px solid var(--border);border-radius:10px;
  background:#10141a;
}
.analyze-trace[hidden]{display:none}
.analyze-trace > summary{
  cursor:pointer;padding:8px 12px;color:var(--muted);font-size:.85rem;
  list-style:none;user-select:none;display:flex;align-items:center;gap:8px;
}
.analyze-trace > summary::-webkit-details-marker{display:none}
.analyze-trace > summary:hover{color:var(--text)}
.analyze-trace[open] > summary{border-bottom:1px solid var(--border)}
.trace-log{
  max-height:240px;overflow-y:auto;margin:0;padding:8px 12px;list-style:none;
  font-family:"SFMono-Regular",Menlo,Consolas,monospace;font-size:.75rem;
  color:#9fb0c5;
}
.trace-log li{padding:2px 0;white-space:pre-wrap;word-break:break-word}
.trace-log li.trace-ocr{color:#8fd0ff}
.trace-log li.trace-val{color:#cfa7ff}
.trace-log li.trace-ret{color:#ffd58a}
.trace-log li.trace-eng{color:#8fe0a8}

/* KONSISTENZ-BANNER (Review) */
.consistency-status{
  margin:0 0 14px;padding:12px 16px;border-radius:10px;font-weight:600;
  display:flex;align-items:center;gap:10px;font-size:.95rem;
  border:1px solid;
  animation:fade .35s ease;
}
.consistency-status[hidden]{display:none}
.consistency-status.ok{
  background:rgba(95,184,120,.10);border-color:rgba(95,184,120,.45);color:#8adca0;
}
.consistency-status.warn{
  background:rgba(224,176,64,.10);border-color:rgba(224,176,64,.45);color:#e0b040;
}
.consistency-status.err{
  background:rgba(229,97,95,.10);border-color:rgba(229,97,95,.5);color:#e5615f;
}
.consistency-status i{font-size:1.1rem}

/* ERÖFFNUNGS-BANNER (Review + Export) */
.opening-name{
  margin:0 0 14px;padding:10px 16px;border-radius:10px;
  background:rgba(212,162,76,.08);border:1px solid rgba(212,162,76,.35);
  display:flex;align-items:center;gap:10px;font-size:.92rem;
  color:var(--accent-2);
}
.opening-name[hidden]{display:none}
.opening-name .eco{
  display:inline-block;font-family:ui-monospace,monospace;font-weight:700;
  padding:2px 8px;background:rgba(212,162,76,.18);border-radius:6px;
  color:var(--accent);font-size:.82rem;letter-spacing:.02em;
}
.opening-name .name{color:var(--text);font-weight:600}
.opening-name .plies{color:var(--muted);font-size:.78rem;margin-left:auto}
.opening-name i{color:var(--accent);font-size:1rem}

/* BLITZ-ANALYSE (Export) */
.blitz-panel h3{margin-bottom:6px}
.blitz-controls{
  display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;margin:10px 0 14px;
}
.blitz-controls fieldset.blitz-color{
  border:1px solid var(--border);border-radius:8px;padding:4px 12px 8px;margin:0;
  display:flex;gap:12px;
}
.blitz-controls fieldset.blitz-color legend{color:var(--muted);font-size:.75rem;padding:0 4px}
.blitz-controls label{display:flex;flex-direction:column;gap:4px;color:var(--muted);font-size:.8rem}
.blitz-controls fieldset label{flex-direction:row;align-items:center;gap:4px;color:var(--text);font-size:.9rem}
.blitz-controls select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:6px 8px}
.blitz-progress{margin:6px 0 14px}
.blitz-progress .progress{height:6px;background:var(--panel-2);border-radius:6px;overflow:hidden}
.blitz-progress .progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .2s}
.blitz-progress small{color:var(--muted);display:block;margin-top:4px}
.blitz-progress .blitz-engine-info{
  color:var(--muted);font-size:.75rem;font-family:ui-monospace,monospace;
  opacity:.85;margin-top:2px;
}

.blitz-chart-wrap{
  background:#0b0e13;border:1px solid var(--border);border-radius:10px;
  padding:10px;margin-bottom:14px;
}
#blitz-chart-svg{width:100%;height:160px;display:block}
/* Hintergrund-Zonen: obere Hälfte Weiß-Vorteil, untere Hälfte Schwarz-Vorteil */
#blitz-chart-svg .bchart-bg-w{fill:#e8e2d1}
#blitz-chart-svg .bchart-bg-b{fill:#1a1f27}
/* Gefüllte Kurven-Flächen: stärker kontrastiert zur Hintergrund-Zone */
#blitz-chart-svg .bchart-fill-w{fill:#ffffff;opacity:.85}
#blitz-chart-svg .bchart-fill-b{fill:#000000;opacity:.75}
#blitz-chart-svg .bchart-zero{stroke:#c3463b;stroke-width:1;stroke-dasharray:3 4}
#blitz-chart-svg .bchart-line{fill:none;stroke:var(--accent);stroke-width:1.6}
#blitz-chart-svg .bchart-dot{fill:var(--accent-2);cursor:pointer}
#blitz-chart-svg .bchart-dot.blunder{fill:#e5615f}
#blitz-chart-svg .bchart-dot.mistake{fill:#e08040}
#blitz-chart-svg .bchart-dot.inaccuracy{fill:#e0b040}
#blitz-chart-svg .bchart-dot.best{fill:#5fb878}
#blitz-chart-svg .bchart-dot:hover{r:4}
/* Achsen-Skala */
#blitz-chart-svg .bchart-grid{
  stroke:#7a7a7a;stroke-width:1;stroke-dasharray:2 3;opacity:.30;
}
#blitz-chart-svg .bchart-tick{
  stroke:#9aa0a6;stroke-width:1;opacity:.55;
}
#blitz-chart-svg .bchart-axis-y,
#blitz-chart-svg .bchart-axis-x{
  fill:#9aa0a6;font-size:10px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  pointer-events:none;user-select:none;
}

.blitz-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.blitz-tab{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  padding:6px 12px;border-radius:8px;cursor:pointer;font-size:.85rem;
  display:inline-flex;align-items:center;gap:6px;
}
.blitz-tab:hover{color:var(--text)}
.blitz-tab.active{background:var(--panel-2);color:var(--accent);border-color:var(--accent)}
.blitz-tab span{
  background:rgba(212,162,76,.16);padding:1px 6px;border-radius:999px;font-size:.7rem;
}
.blitz-lists{position:relative;min-height:60px}
.blitz-list{list-style:none;padding:0;margin:0;display:none}
.blitz-list.active{display:block}
.blitz-list li{
  padding:8px 12px;border-bottom:1px solid var(--border);
  cursor:pointer;display:flex;align-items:center;gap:10px;
  transition:background .15s;
}
.blitz-list li:hover{background:var(--panel-2)}
.blitz-list li:last-child{border-bottom:none}
.blitz-list .bl-num{font-weight:600;color:var(--accent);min-width:56px}
.blitz-list .bl-san{font-family:"SFMono-Regular",Menlo,Consolas,monospace;color:var(--text);min-width:80px}
.blitz-list .bl-eval{color:var(--muted);font-size:.8rem;min-width:130px}
.blitz-list .bl-tag{
  margin-left:auto;padding:2px 8px;border-radius:999px;font-size:.72rem;
  background:var(--panel-2);color:var(--muted);
}
.blitz-list .bl-tag.blunder{background:rgba(229,97,95,.18);color:#e5615f}
.blitz-list .bl-tag.mistake{background:rgba(224,128,64,.18);color:#e08040}
.blitz-list .bl-tag.inaccuracy{background:rgba(224,176,64,.18);color:#e0b040}
.blitz-list .bl-tag.best{background:rgba(95,184,120,.18);color:#5fb878}
.blitz-list .bl-tag.missed{background:rgba(229,97,95,.20);color:#ff8f8f}
.blitz-list .bl-empty{color:var(--muted);font-style:italic;padding:12px}
.blitz-list .bl-wpdelta{font-variant-numeric:tabular-nums;opacity:.85}
.blitz-list .bl-cp{font-size:.72rem;opacity:.55;margin-left:4px}

.blitz-mini-board{width:320px;max-width:80vw;margin:0 auto}
.blitz-modal-info{margin-top:12px;color:var(--muted);font-size:.9rem;line-height:1.6}
.blitz-modal-info b{color:var(--text)}
