:root {
  --bg-primary: #0a0f1a;
  --bg-card: #111827;
  --bg-input: #0d1321;
  --border: #1e2a3a;
  --border-focus: #0ea5e9;
  --text-primary: #e8ecf1;
  --text-secondary: #7a8599;
  --text-muted: #4a556b;
  --accent: #0ea5e9;
  --accent-glow: rgba(14,165,233,.15);
  --green: #22c55e;
  --green-bg: rgba(34,197,94,.12);
  --yellow: #eab308;
  --yellow-bg: rgba(234,179,8,.12);
  --red: #ef4444;
  --red-bg: rgba(239,68,68,.12);
  --orange: #f97316;
  --radius: 10px;
  --radius-sm: 6px;
  --nav-h: 64px;
  --safe-b: env(safe-area-inset-bottom, 0px);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{overscroll-behavior:none;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'SF Pro Display','Segoe UI',sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100%;padding-bottom:calc(var(--nav-h) + var(--safe-b) + 8px);overscroll-behavior:none;-webkit-user-select:none;user-select:none;font-size:15px;line-height:1.5}
input,textarea,select,button{font-family:inherit;-webkit-user-select:text;user-select:text}
button{cursor:pointer;border:none;background:none;color:inherit}

/* === VIEWS === */
.view{display:none;padding:16px 16px 24px;animation:fadeIn .2s ease}
.view.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* === NAV === */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-b));padding-bottom:var(--safe-b);background:var(--bg-card);border-top:1px solid var(--border);display:flex;z-index:100}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;color:var(--text-muted);font-weight:600;letter-spacing:.03em;transition:color .15s}
.nav-btn.active{color:var(--accent)}
.nav-btn.disabled{opacity:.3;pointer-events:none}
.nav-btn svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* === CARDS === */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}
.card-header{font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.card-header svg{width:16px;height:16px}

/* === FORMS === */
.field{margin-bottom:16px}
.field-label{display:block;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.field-input{width:100%;padding:12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:15px;transition:border-color .15s}
.field-input:focus{outline:none;border-color:var(--border-focus)}
select.field-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%237a8599'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}

/* === BUTTONS === */
.btn{padding:14px 24px;border-radius:var(--radius-sm);font-size:15px;font-weight:700;text-align:center;transition:all .15s;width:100%;display:block}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:active{transform:scale(.98);opacity:.9}
.btn-outline{border:1px solid var(--border);color:var(--text-secondary)}
.btn-danger{background:var(--red);color:#fff}
.btn-sm{padding:10px 16px;font-size:13px}

/* === SEGMENT CONTROL === */
.seg-row{display:flex;gap:6px;margin-bottom:16px}
.seg-btn{flex:1;padding:10px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px;font-weight:700;text-align:center;transition:all .15s;color:var(--text-secondary)}
.seg-btn.selected{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.disc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:16px}
.disc-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:11px;font-weight:700;text-align:center;transition:all .15s;color:var(--text-secondary);background:transparent}
.disc-btn .disc-icon{font-size:20px;line-height:1}
.disc-btn .disc-label{font-size:10px;font-weight:600;line-height:1.2}
.disc-icon-img{width:32px;height:32px;object-fit:contain}
.disc-btn.selected{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.disc-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;line-height:1.3}
.disc-badge img{width:14px;height:14px;object-fit:contain;vertical-align:middle}

/* === SEMAPHORE (Crowd) === */
.sem-row{display:flex;gap:8px}
.sem-btn{flex:1;padding:12px 4px;border-radius:var(--radius-sm);border:2px solid var(--border);font-size:22px;text-align:center;transition:all .15s}
.sem-btn.selected{transform:scale(1.05)}
.sem-btn[data-v="empty"].selected{border-color:var(--green);background:var(--green-bg)}
.sem-btn[data-v="medium"].selected{border-color:var(--yellow);background:var(--yellow-bg)}
.sem-btn[data-v="crowded"].selected{border-color:var(--red);background:var(--red-bg)}

/* === STAR RATING === */
.stars{display:flex;gap:4px}
.star{font-size:28px;color:var(--text-muted);cursor:pointer;transition:color .1s;line-height:1}
.star.active{color:var(--yellow)}

/* === ATHLETE CHIPS === */
.athlete-grid{display:flex;flex-wrap:wrap;gap:8px}
.athlete-chip{padding:10px 16px;border-radius:20px;border:1.5px solid var(--border);font-size:14px;font-weight:600;transition:all .15s;display:flex;align-items:center;gap:6px}
.athlete-chip.selected{border-color:var(--green);background:var(--green-bg);color:var(--green)}
.athlete-chip .avi{width:26px;height:26px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff}

/* === TACTICAL IQ === */
.tac-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.tac-athlete-name{font-size:20px;font-weight:800;letter-spacing:-.02em}
.tac-nav-arrow{padding:8px 16px;font-size:22px;color:var(--text-secondary)}
.tac-stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.tac-stat{text-align:center;padding:16px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border)}
.tac-stat-val{font-size:36px;font-weight:800;letter-spacing:-.03em}
.tac-stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-top:2px}
.tac-catch{font-size:48px;font-weight:800;text-align:center;padding:20px;border-radius:var(--radius);margin-bottom:16px}
.tac-catch.good{color:var(--green);background:var(--green-bg);border:1px solid rgba(34,197,94,.2)}
.tac-catch.mid{color:var(--yellow);background:var(--yellow-bg);border:1px solid rgba(234,179,8,.2)}
.tac-catch.low{color:var(--red);background:var(--red-bg);border:1px solid rgba(239,68,68,.2)}
.tac-catch-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:700}

/* Big counters */
.counter-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}
.counter-btn{padding:20px 8px;border-radius:var(--radius);border:2px solid var(--border);text-align:center;font-weight:800;font-size:15px;transition:all .1s;display:flex;flex-direction:column;align-items:center;gap:4px;min-height:90px;justify-content:center}
.counter-btn:active{transform:scale(.95)}
.counter-btn .cnt-icon{font-size:28px}
.counter-btn .cnt-val{font-size:28px;font-weight:800}
.counter-btn.c-paddle{border-color:var(--accent);color:var(--accent);background:rgba(14,165,233,.06)}
.counter-btn.c-catch{border-color:var(--green);color:var(--green);background:rgba(34,197,94,.06)}
.counter-btn.c-fall{border-color:var(--red);color:var(--red);background:rgba(239,68,68,.06)}

/* Eval buttons */
.eval-section{margin-bottom:14px}
.eval-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.eval-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}
.eval-btn{padding:10px 6px;border-radius:var(--radius-sm);border:1.5px solid var(--border);font-size:12px;font-weight:700;text-align:center;transition:all .12s}
.eval-btn:active{transform:scale(.95)}
.eval-btn.sel-r{border-color:var(--red);color:var(--red);background:var(--red-bg)}
.eval-btn.sel-y{border-color:var(--yellow);color:var(--yellow);background:var(--yellow-bg)}
.eval-btn.sel-g{border-color:var(--green);color:var(--green);background:var(--green-bg)}
.eval-btn.sel-b{border-color:var(--accent);color:var(--accent);background:rgba(14,165,233,.12)}
.eval-btn.sel-a{border-color:#f97316;color:#f97316;background:rgba(249,115,22,.12)}
.eval-btn.sel-m{border-color:var(--text-secondary);color:var(--text-secondary);background:rgba(148,163,184,.12)}

/* Maneuver tags */
.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.tag-btn{padding:8px 14px;border-radius:16px;border:1.5px solid var(--border);font-size:12px;font-weight:700;transition:all .12s}
.tag-btn.selected{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}

/* Undo toast */
.undo-toast{position:fixed;bottom:calc(var(--nav-h) + var(--safe-b) + 16px);left:50%;transform:translateX(-50%);background:#333;color:#fff;padding:10px 20px;border-radius:20px;font-size:13px;font-weight:600;z-index:200;display:none;animation:slideUp .25s ease}
.undo-toast.show{display:flex;align-items:center;gap:12px}
.undo-toast button{color:var(--accent);font-weight:800;font-size:13px}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(12px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* === OVERVIEW === */
.ov-row{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border);gap:12px}
.ov-row:last-child{border:none}
.ov-name{flex:1;font-weight:700;font-size:15px}
.ov-stats{font-size:13px;color:var(--text-secondary);font-weight:600}
.ov-ratio{font-size:18px;font-weight:800;min-width:50px;text-align:right}
.ov-bar{width:100%;height:4px;background:var(--border);border-radius:2px;margin-top:6px}
.ov-bar-fill{height:100%;border-radius:2px;transition:width .3s}

/* === DEBRIEF === */
.db-condition{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.db-tag{padding:6px 12px;border-radius:14px;background:var(--bg-input);border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-secondary)}
.db-athlete-card{border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;background:var(--bg-card)}
.db-athlete-name{font-size:16px;font-weight:800;margin-bottom:8px}
.db-stat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px}
.db-stat{text-align:center}
.db-stat-v{font-size:20px;font-weight:800}
.db-stat-l{font-size:10px;color:var(--text-secondary);text-transform:uppercase;font-weight:700}
.db-xp{font-size:13px;color:var(--accent);font-weight:700;margin-top:6px}

/* === ATHLETES LIST === */
.ath-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}
.ath-item:last-child{border:none}
.ath-avi{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#fff;flex-shrink:0}
.ath-info{flex:1}
.ath-name{font-weight:700;font-size:15px}
.ath-sub{font-size:12px;color:var(--text-secondary)}

/* === MODAL === */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:300;display:none;align-items:flex-end;justify-content:center}
.modal-overlay.active{display:flex}
.modal-sheet{background:var(--bg-card);border-radius:16px 16px 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;padding:24px 20px calc(20px + var(--safe-b));animation:sheetUp .25s ease}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:36px;height:4px;background:var(--text-muted);border-radius:2px;margin:0 auto 20px}
.modal-title{font-size:18px;font-weight:800;margin-bottom:16px}

/* === TIMER === */
.session-bar{position:sticky;top:0;z-index:50;background:var(--bg-primary);padding:8px 16px;display:none;border-bottom:1px solid var(--border)}
.session-bar.active{display:flex;align-items:center;justify-content:space-between}
.sb-info{font-size:12px;color:var(--text-secondary);font-weight:600}
.sb-time{font-size:18px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--accent)}

/* === UTILITIES === */
.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}
.empty-state svg{width:48px;height:48px;margin-bottom:12px;opacity:.4}
.empty-state p{font-size:14px;margin-bottom:16px}
.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}
.text-center{text-align:center}
.text-sm{font-size:13px}
.text-muted{color:var(--text-secondary)}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.gap-2{gap:8px}
/* === JUDGE MODE === */
.jm-setup{padding:16px}
.jm-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.jm-surfer-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.jm-surfer-item{display:flex;flex-direction:column;gap:4px}
.jm-surfer-item label{font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px}
.jm-surfer-item input{padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px}
.jm-surfer-item input:focus{outline:none;border-color:var(--border-focus)}
.jm-surfer-item select{padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}
.jm-surfer-item select:focus{outline:none;border-color:var(--border-focus)}

.jm-timer-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--green);border-radius:var(--radius);margin-bottom:12px}
.jm-timer-bar.warning{background:var(--yellow)}
.jm-timer-bar.critical{background:var(--red);animation:pulse 1s infinite}
.jm-timer{font-size:36px;font-weight:800;font-variant-numeric:tabular-nums;color:#fff}
.jm-timer-btns{display:flex;gap:6px}
.jm-timer-btn{padding:8px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:700;color:#fff;border:1px solid rgba(255,255,255,.3)}

.jm-grid-wrap{overflow-x:auto;margin-bottom:12px;-webkit-overflow-scrolling:touch}
.jm-grid{border-collapse:separate;border-spacing:3px;min-width:900px}
.jm-grid th{background:#1e2a3a;color:var(--text-secondary);padding:6px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;text-align:center;white-space:nowrap}
.jm-grid td{text-align:center;position:relative}
.jm-color-cell{font-weight:700;font-size:12px;padding:10px 6px;border-radius:6px;cursor:pointer;position:relative;white-space:nowrap;transition:transform .1s}
.jm-color-cell:active{transform:scale(.95)}
.jm-color-red{background:#991b1b;color:#fecaca;border:1px solid #7f1d1d}
.jm-color-yellow{background:#854d0e;color:#fef08a;border:1px solid #713f12}
.jm-color-black{background:#0f172a;color:#e2e8f0;border:1px solid #334155}
.jm-color-white{background:#f0f0f0;color:#0f172a;border:1px solid #d1d5db}
.jm-color-blue{background:#1e3a8a;color:#bfdbfe;border:1px solid #1e40af}

.jm-int-badge{position:absolute;bottom:2px;right:2px;font-size:8px;padding:1px 4px;border-radius:3px;font-weight:800;background:#475569;color:#cbd5e1}
.jm-int-badge.l1{background:#f59e0b;color:#fff}
.jm-int-badge.l2{background:#ef4444;color:#fff}
.jm-int-badge.l3{background:#dc2626;color:#fff}
.jm-int-badge.l4{background:#991b1b;color:#fff}
.jm-int-badge.l5{background:#7f1d1d;color:#fff}
.jm-int-badge.l6{background:#000;color:#fff;border:1px solid #ef4444}

.jm-score-input{width:46px;padding:7px 3px;font-size:13px;font-weight:700;text-align:center;border:1px solid var(--border);border-radius:4px;background:var(--bg-input);color:var(--text-primary);-webkit-user-select:text;user-select:text}
.jm-score-input:focus{outline:none;border-color:var(--border-focus);background:var(--bg-card)}
.jm-score-input:disabled{opacity:.25;cursor:not-allowed;background:#060a12}
.jm-score-input.best{background:linear-gradient(135deg,#fbbf24,#f59e0b);border-color:#d97706;color:#78350f}
.jm-score-input.locked{border-color:#475569;opacity:.85}
.jm-score-input.recent{border-color:var(--accent);box-shadow:0 0 4px rgba(14,165,233,.3)}
.jm-score-input.int-marked{border:2px solid var(--red);background:rgba(239,68,68,.1)}
.jm-tri{position:absolute;top:0;right:2px;color:var(--red);font-size:14px;pointer-events:none;display:none}

.jm-rankings{margin-bottom:12px}
.jm-rank-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;margin-bottom:6px;border-radius:8px;font-weight:700;font-size:14px}
.jm-rank-item:nth-child(1){background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f}
.jm-rank-item:nth-child(2){background:linear-gradient(135deg,#94a3b8,#cbd5e1);color:#0f172a}
.jm-rank-item:nth-child(3){background:linear-gradient(135deg,#d97706,#f59e0b);color:#78350f}
.jm-rank-item:nth-child(n+4){background:#1e2a3a;color:#cbd5e1}
.jm-rank-waves{font-size:11px;opacity:.8;font-weight:500;margin-top:2px}
.jm-rank-need{font-size:11px;font-style:italic;font-weight:700;margin-top:2px}
.jm-rank-int{font-size:11px;padding:1px 5px;border-radius:3px;background:rgba(239,68,68,.2);color:#fca5a5;margin-left:4px}
.jm-priority{display:flex;gap:6px;margin-bottom:12px}
.jm-pri-item{flex:1;text-align:center;padding:10px 4px;border-radius:8px;font-weight:700;cursor:pointer;transition:all .15s}
.jm-pri-item:nth-child(1){background:linear-gradient(135deg,#10b981,#059669);color:#fff}
.jm-pri-item:nth-child(2){background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}
.jm-pri-item.tied{background:#475569;color:#cbd5e1}
.jm-pri-num{font-size:20px;font-weight:800}
.jm-pri-col{font-size:12px}
.jm-pri-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.04em;opacity:.8}

.jm-results{margin-top:16px}
.jm-meta-collapsed{font-size:12px;color:var(--text-secondary);font-weight:600;margin-bottom:10px;display:none}
.jm-meta-collapsed.active{display:block}
.jm-setup-form.hidden{display:none}
.jm-notes-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:300;display:none;align-items:center;justify-content:center}
.jm-notes-modal.active{display:flex}
.jm-notes-box{background:var(--bg-card);border-radius:12px;padding:20px;width:90%;max-width:500px;border:1px solid var(--border)}

/* ===== PHASE 2: PLAYER CARD ===== */
.pc-header{text-align:center;padding:20px 0 16px}
.pc-avi{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#6366f1);display:inline-flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:#fff;margin-bottom:8px}
.pc-name{font-size:22px;font-weight:800}
.pc-sub{font-size:13px;color:var(--text-secondary);margin-top:2px}
.pc-level-tag{display:inline-block;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px;margin-top:6px;letter-spacing:.04em}
.pc-xp-bar{height:6px;background:var(--bg-input);border-radius:3px;margin:8px auto 0;width:70%;overflow:hidden}
.pc-xp-fill{height:100%;background:linear-gradient(90deg,var(--accent),#6366f1);border-radius:3px;transition:width .4s}
.pc-xp-text{font-size:10px;color:var(--text-muted);margin-top:4px}

.pc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.pc-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px 4px;text-align:center}
.pc-stat-val{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums}
.pc-stat-lbl{font-size:10px;color:var(--text-secondary);margin-top:2px;text-transform:uppercase;letter-spacing:.03em}

.pc-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.pc-badge{display:flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:12px}
.pc-badge.earned{border-color:var(--yellow);background:rgba(245,158,11,.08)}
.pc-badge-icon{font-size:20px}
.pc-badge-info{text-align:left}
.pc-badge-name{font-weight:700;font-size:11px}
.pc-badge-desc{font-size:10px;color:var(--text-muted)}
.pc-badge.locked{opacity:.4}

.pc-chart{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px}
.pc-chart-title{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.pc-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}
.pc-bar-label{width:50px;text-align:right;color:var(--text-secondary);font-size:11px;flex-shrink:0}
.pc-bar-track{flex:1;height:14px;background:var(--bg-input);border-radius:7px;overflow:hidden}
.pc-bar-fill{height:100%;border-radius:7px;min-width:2px}
.pc-bar-val{width:35px;font-weight:700;font-variant-numeric:tabular-nums;font-size:11px}

.pc-history{margin-bottom:16px}
.pc-hist-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px}
.pc-hist-item:last-child{border-bottom:none}

/* ===== DRILL BANK ===== */
.drill-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px}
.drill-card.assigned{border-color:var(--accent);border-width:2px}
.drill-header{display:flex;justify-content:space-between;align-items:center}
.drill-name{font-weight:700;font-size:14px}
.drill-cat{font-size:10px;color:var(--text-secondary);background:var(--bg-input);padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}
.drill-desc{font-size:12px;color:var(--text-secondary);margin-top:6px;line-height:1.4}
.drill-meta{display:flex;gap:12px;margin-top:8px;font-size:11px;color:var(--text-muted)}
.drill-actions{display:flex;gap:6px;margin-top:10px}
.drill-cat-filter{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:12px;-webkit-overflow-scrolling:touch}
.drill-cat-btn{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap;cursor:pointer}
.drill-cat-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ===== PHASE 3: TECH LAB ===== */
.lab-video-wrap{position:relative;background:#000;border-radius:10px;overflow:hidden;margin-bottom:0;touch-action:none;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}
.lab-video{display:block;max-width:100%;max-height:55vh;width:auto;height:auto}
.lab-video-inner{transform-origin:center center;will-change:transform;position:relative;overflow:visible}
.lab-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;touch-action:none}
.lab-canvas.drawing{pointer-events:auto;cursor:crosshair;touch-action:none}

/* Gesture layer - transparent overlay for touch */
.lab-gesture{position:absolute;top:0;left:0;right:0;bottom:0;z-index:5;touch-action:none;-webkit-tap-highlight-color:transparent}
.lab-gesture.disabled{pointer-events:none}
.lab-gest-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;opacity:0;transition:opacity .15s;pointer-events:none;text-shadow:0 2px 12px rgba(0,0,0,.8)}
.lab-gest-indicator.show{opacity:1}
.lab-gest-skip{position:absolute;top:50%;transform:translateY(-50%);width:50%;height:80%;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .15s}
.lab-gest-skip.show{opacity:1}
.lab-gest-skip.left{left:0;border-radius:50% 0 0 50%}
.lab-gest-skip.right{right:0;border-radius:0 50% 50% 0}
.lab-gest-skip-inner{background:rgba(255,255,255,.15);border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:22px}
.lab-gest-scrub{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.8);border-radius:12px;padding:10px 20px;pointer-events:none;opacity:0;transition:opacity .12s;text-align:center}
.lab-gest-scrub.show{opacity:1}
.lab-gest-scrub-time{font-size:24px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums}
.lab-gest-scrub-delta{font-size:12px;color:var(--accent);font-weight:700;margin-top:2px}
.lab-gest-speed{position:absolute;top:12px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);border-radius:8px;padding:6px 14px;pointer-events:none;opacity:0;transition:opacity .12s;font-size:14px;font-weight:700;color:var(--accent)}
.lab-gest-speed.show{opacity:1}

/* Controls overlay - auto-hides */
.lab-controls-wrap{transition:opacity .3s;padding:6px 0 0}
.lab-controls-wrap.hidden{opacity:0;pointer-events:none}
.lab-controls{display:flex;align-items:center;gap:8px;padding:8px 0}
.lab-ctrl-btn{width:40px;height:40px;border-radius:8px;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-primary);cursor:pointer;flex-shrink:0}
.lab-ctrl-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.lab-ctrl-btn:active{transform:scale(.92)}
.lab-timeline{flex:1;height:6px;background:var(--bg-input);border-radius:3px;cursor:pointer;position:relative;-webkit-appearance:none;appearance:none}
.lab-timeline::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer}
.lab-time{font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:42px;text-align:center}
.lab-tools{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.lab-tool{padding:8px 12px;border-radius:8px;background:var(--bg-card);border:1px solid var(--border);font-size:12px;font-weight:600;cursor:pointer;color:var(--text-secondary)}
.lab-tool.active{background:var(--accent);border-color:var(--accent);color:#fff}
.lab-color-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);cursor:pointer}
.lab-color-dot.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent)}
.lab-szrow{display:flex;gap:4px;margin-bottom:10px;align-items:center;justify-content:center;flex-wrap:nowrap}
.lab-szrow .lab-ctrl-btn{font-size:11px;width:auto;padding:0 7px;height:32px}
.lab-sz-sep{width:1px;height:20px;background:var(--border);margin:0 4px;flex-shrink:0}
.lab-sz-label{font-size:10px;color:var(--text-muted);font-weight:600;flex-shrink:0}
.lab-zoom-level{font-size:11px;font-weight:700;color:var(--text-secondary);min-width:32px;text-align:center;font-variant-numeric:tabular-nums}

/* Sticker mini-bar (collapsed) */
.lab-stk-bar{display:none;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:10px}
.lab-stk-bar.active{display:flex}
.lab-stk-bar-preview{width:32px;height:32px;border-radius:6px;border:1px solid var(--border);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3)}
.lab-stk-bar-preview img{max-width:100%;max-height:100%;object-fit:contain}
.lab-stk-bar-name{font-size:11px;font-weight:700;color:var(--text-primary);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lab-stk-bar-btn{width:32px;height:32px;border-radius:6px;background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.lab-stk-bar-btn:active{transform:scale(.9)}
.lab-stk-bar-btn.accent{background:var(--accent);border-color:var(--accent);color:#fff;font-size:10px;width:auto;padding:0 10px;font-weight:700}

/* Sticker full panel - modal overlay */
.lab-stk-modal{display:none;position:fixed;bottom:0;left:0;right:0;z-index:10001;background:rgba(15,23,42,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.12);padding:16px 16px calc(var(--safe-b) + 16px);border-radius:16px 16px 0 0;max-height:40vh;animation:labStkSlide .2s ease}
.lab-stk-modal.active{display:block}
@keyframes labStkSlide{from{transform:translateY(100%)}to{transform:translateY(0)}}
.lab-stk-modal-title{font-size:13px;font-weight:800;color:#fff;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.lab-stk-modal-close{background:none;border:none;color:rgba(255,255,255,.5);font-size:22px;cursor:pointer;padding:4px}
.lab-stk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px}
.lab-stk-item{display:flex;flex-direction:column;align-items:center;cursor:pointer}
.lab-stk-item-img{width:64px;height:64px;border-radius:10px;border:2px solid rgba(255,255,255,.12);padding:4px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);transition:all .15s}
.lab-stk-item-img:active{transform:scale(.92)}
.lab-stk-item-img.selected{border-color:var(--accent);background:rgba(99,102,241,.15)}
.lab-stk-item-img img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:none}
.lab-stk-item-name{font-size:9px;color:rgba(255,255,255,.5);margin-top:3px;text-align:center}

/* Lab Fullscreen Mode - use ID to beat media query specificity */
.lab-fullscreen,#labFsContainer.lab-fullscreen{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;z-index:9999!important;background:#000!important;display:flex!important;flex-direction:column!important;border-radius:0!important;margin:0!important;padding:0!important;padding-top:var(--safe-t)!important;padding-bottom:var(--safe-b)!important;height:auto!important;width:auto!important}
.lab-fullscreen .lab-video-wrap{flex:1!important;border-radius:0!important;margin:0!important;min-height:0!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important}
.lab-fullscreen .lab-video{max-height:100%!important;max-width:100%!important;width:auto!important;height:auto!important;object-fit:contain!important}
.lab-fullscreen .lab-controls-wrap{position:relative!important;background:rgba(0,0,0,.85)!important;padding:4px 12px!important;opacity:1!important;pointer-events:auto!important}
.lab-fullscreen .lab-controls-wrap.mob-hidden{opacity:0!important;pointer-events:none!important;max-height:0!important;padding-top:0!important;padding-bottom:0!important}
.lab-fullscreen .lab-controls{padding:6px 0}
.lab-fullscreen .lab-tools{padding:0 12px;margin-bottom:6px;background:rgba(0,0,0,.85);justify-content:center}
.lab-fullscreen .lab-tool{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff;padding:8px 10px;font-size:13px}
.lab-fullscreen .lab-tool.active{background:var(--accent);border-color:var(--accent)}
.lab-fullscreen .lab-szrow{background:rgba(0,0,0,.85);padding:4px 12px;margin-bottom:0;display:flex!important}
.lab-fullscreen .lab-szrow .lab-ctrl-btn{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff}
.lab-fullscreen .lab-color-row{display:flex;gap:8px;padding:4px 12px;background:rgba(0,0,0,.85);align-items:center;justify-content:center}
.lab-fullscreen .lab-timeline{background:rgba(255,255,255,.15)}
.lab-fullscreen .lab-time{color:rgba(255,255,255,.7)}
.lab-fullscreen .lab-ctrl-btn{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff;width:40px;height:40px}
.lab-fullscreen .lab-stk-bar{position:relative!important;top:auto!important;left:auto!important;right:auto!important;background:rgba(0,0,0,.85)!important;border-color:rgba(255,255,255,.15)!important;margin:0 12px 4px!important}
.lab-fs-close{position:absolute;top:calc(var(--safe-t) + 8px);right:12px;z-index:10000;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.3);color:#fff;width:40px;height:40px;border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}
.lab-fs-close:active{transform:scale(.9)}
.lab-fs-expand{position:absolute;top:8px;right:8px;z-index:10;background:rgba(0,0,0,.6);border:none;color:#fff;width:36px;height:36px;border-radius:8px;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}
.lab-fs-expand:active{transform:scale(.9)}
.lab-ctrl-toggle{position:absolute;bottom:8px;right:8px;z-index:25;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.2);color:#fff;width:36px;height:36px;border-radius:8px;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .2s}
.lab-ctrl-toggle:active{transform:scale(.9)}
.lab-fullscreen .lab-ctrl-toggle{bottom:auto;top:calc(var(--safe-t) + 8px);left:12px;right:auto;z-index:10000}

.lab-frames{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.lab-frame{border-radius:8px;overflow:hidden;border:1px solid var(--border);cursor:pointer;position:relative}
.lab-frame img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover}
.lab-frame-time{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.7);font-size:10px;color:#fff;padding:3px 6px;text-align:center}
.lab-compare{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:12px}
.lab-compare img{width:100%;border-radius:8px;border:1px solid var(--border)}
.lab-clip{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:10px}
.lab-clip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.lab-clip-name{font-weight:700;font-size:14px}
.lab-clip-meta{font-size:11px;color:var(--text-muted)}

/* Video wrapper zoom support */
.lab-fullscreen .lab-video-inner{max-width:100%!important;max-height:100%!important;margin:auto!important}

/* ===== COACH BIG MODE (Accessibility) ===== */
body.big-mode{font-size:18px}
.big-mode .card{padding:18px!important}
.big-mode .card-header{font-size:18px!important;margin-bottom:14px!important}
.big-mode .field-label{font-size:15px!important}
.big-mode .field-input,.big-mode select,.big-mode textarea{font-size:17px!important;padding:14px!important}
.big-mode .btn{font-size:17px!important;padding:18px!important}
.big-mode .btn-sm{font-size:16px!important;padding:16px 18px!important}
.big-mode .btn-accent{font-size:19px!important;padding:20px!important}
.big-mode .nav-btn{font-size:13px!important}
.big-mode .nav-btn span:first-child{font-size:22px!important}
.big-mode .eval-btn{font-size:16px!important;padding:14px 16px!important}
.big-mode .tag-btn{font-size:15px!important;padding:12px 16px!important}
.big-mode .tac-stat-val{font-size:32px!important}
.big-mode .tac-stat-label{font-size:13px!important}
.big-mode .db-stat-v{font-size:26px!important}
.big-mode .db-stat-l{font-size:12px!important}
.big-mode .dash-kpi-val{font-size:28px!important}
.big-mode .dash-kpi-lbl{font-size:12px!important}
.big-mode .dash-hero-title{font-size:34px!important}
.big-mode .dash-hero-sub{font-size:16px!important}
.big-mode .kss-title{font-size:22px!important}
.big-mode .kss-subtitle{font-size:14px!important}
.big-mode .eval-label{font-size:15px!important}
.big-mode .avi{width:44px!important;height:44px!important;font-size:16px!important}
.big-mode .hist-badge{font-size:13px!important;padding:5px 10px!important}
.big-mode .sem-btn{font-size:16px!important;padding:14px!important}
.big-mode .db-tag{font-size:14px!important;padding:6px 12px!important}
.big-mode #tacWaveScoreDisplay{font-size:26px!important;min-width:62px!important}
.big-mode .lab-tool{font-size:17px!important;padding:10px 14px!important}
.big-mode .lab-tool .lab-tool-text{font-size:14px!important}
.big-mode .lab-ctrl-btn{width:48px!important;height:48px!important;font-size:20px!important}
.big-mode .lab-zoom-level{font-size:15px!important}
.big-mode .lab-time{font-size:14px!important}
.big-mode .wo-item{font-size:15px!important}
.big-mode .wo-check{width:32px!important;height:32px!important;font-size:18px!important}
.big-mode .wo-q-btn{width:38px!important;height:38px!important;font-size:15px!important}
.big-mode .jm-wave-score{font-size:28px!important}
.big-mode .counter-btn{width:52px!important;height:52px!important;font-size:26px!important}
.big-mode .share-btn{font-size:16px!important;padding:14px!important}
.big-mode .beg-eval-btn{font-size:15px!important;padding:14px!important}
.big-mode .tpl-card{font-size:15px!important;padding:14px!important}
.big-mode .dash-ath-chip{font-size:14px!important;padding:10px 14px!important}
.big-mode #hubTimer{font-size:36px!important}
.big-mode .bottom-nav{height:64px!important;padding-bottom:max(6px,env(safe-area-inset-bottom))!important}
body.big-mode{padding-bottom:80px!important}

/* ===== LAB MOBILE RESPONSIVE ===== */
/* Mobile portrait: compact controls BELOW video */
@media (max-width:768px) {
  .lab-video{max-height:40vh}
  .lab-tool .lab-tool-text{display:none}
  .lab-tool{padding:7px 10px;font-size:15px}
  .lab-szrow{margin-bottom:6px}
  .lab-szrow .lab-ctrl-btn{height:28px;font-size:10px}
  .lab-sz-label,.lab-sz-sep{display:none}
  .lab-controls .lab-ctrl-btn{width:36px;height:36px;font-size:16px}
  .lab-color-row{margin-bottom:8px!important;gap:6px!important}
  .lab-color-row>span{display:none!important}
  .lab-color-dot{width:20px;height:20px}
  .lab-color-row .lab-ctrl-btn{width:26px!important;height:26px!important;font-size:9px!important}
  .lab-controls-wrap{padding:4px 0 0}
}

/* Mobile landscape: overlay controls ON video */
@media (orientation:landscape) and (max-height:500px) {
  #labFsContainer:not(.lab-fullscreen) .lab-video-wrap{margin-bottom:0;border-radius:10px}
  #labFsContainer:not(.lab-fullscreen) .lab-video{max-height:calc(100dvh - 80px);max-width:100%;width:auto;height:auto;object-fit:contain}
  
  #labFsContainer:not(.lab-fullscreen) .lab-controls-wrap{position:absolute;bottom:0;left:0;right:0;z-index:20;background:linear-gradient(transparent,rgba(0,0,0,.9) 30%);padding:24px 8px 6px!important;border-radius:0 0 10px 10px;transition:opacity .3s}
  #labFsContainer:not(.lab-fullscreen) .lab-controls-wrap.mob-hidden{opacity:0;pointer-events:none}
  
  #labFsContainer:not(.lab-fullscreen) .lab-controls{padding:2px 0!important;gap:5px!important}
  #labFsContainer:not(.lab-fullscreen) .lab-controls .lab-ctrl-btn{width:30px;height:30px;font-size:13px;background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.12);color:#fff}
  #labFsContainer:not(.lab-fullscreen) .lab-timeline{height:4px!important}
  #labFsContainer:not(.lab-fullscreen) .lab-time{font-size:10px!important;color:rgba(255,255,255,.6)!important}
  
  #labFsContainer:not(.lab-fullscreen) .lab-szrow{display:none!important}
  
  #labFsContainer:not(.lab-fullscreen) .lab-tools{margin-bottom:2px!important;gap:2px!important;justify-content:center;flex-wrap:nowrap}
  #labFsContainer:not(.lab-fullscreen) .lab-tool{padding:5px 7px;font-size:13px;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);color:#fff;border-radius:6px}
  #labFsContainer:not(.lab-fullscreen) .lab-tool.active{background:var(--accent);border-color:var(--accent)}
  
  #labFsContainer:not(.lab-fullscreen) .lab-color-row{margin-bottom:0!important;gap:4px!important;justify-content:center}
  #labFsContainer:not(.lab-fullscreen) .lab-color-row>span{display:none!important}
  #labFsContainer:not(.lab-fullscreen) .lab-color-dot{width:16px;height:16px}
  #labFsContainer:not(.lab-fullscreen) .lab-color-row .lab-ctrl-btn{width:22px!important;height:22px!important;font-size:8px!important;background:rgba(255,255,255,.1)!important;border-color:rgba(255,255,255,.12)!important;color:#fff!important}
  
  #labFsContainer:not(.lab-fullscreen) .lab-stk-bar{position:absolute;top:6px;left:6px;right:6px;z-index:25;background:rgba(0,0,0,.8)!important;border-color:rgba(255,255,255,.12)!important;margin:0!important;padding:4px 8px!important}
  #labFsContainer:not(.lab-fullscreen) .lab-stk-bar-btn{width:28px;height:28px;font-size:13px}
}

/* Fullscreen - both orientations: always overlay controls */
.lab-fullscreen .lab-tool .lab-tool-text{display:none}

/* Tablet landscape (larger screens rotated) */
@media (orientation:landscape) and (min-height:500px) and (max-height:900px) {
  .lab-video{max-height:55vh}
  .lab-dual-wrap{grid-template-columns:1fr 1fr}
  .lab-dual-slot video{max-height:45vh}
}

/* ===== BEGINNER MODE ===== */

/* ===== TACTICAL QUICK MODE ===== */
.tq-row{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--bg-card);border-radius:10px;margin-bottom:6px;border:1px solid var(--border)}
.tq-name{font-size:13px;font-weight:700;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tq-stat{text-align:center;min-width:32px;font-size:15px;font-weight:800;line-height:1}
.tq-stat-label{font-size:8px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.03em;font-weight:600}
.tq-btn{width:40px;height:40px;border-radius:10px;border:none;font-size:16px;font-weight:800;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .1s;flex-shrink:0}
.tq-btn:active{transform:scale(.9)}
.tq-btn-wave{background:var(--green);color:#fff}
.tq-btn-fall{background:var(--red);color:#fff}
.tq-score{width:42px;height:32px;border-radius:6px;border:1.5px solid var(--border);background:var(--bg-input);font-size:14px;font-weight:800;text-align:center;color:var(--text-primary)}
.tq-score:focus{border-color:var(--accent);outline:none}
.tq-avi{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0}
.tq-ratio{font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px;min-width:36px;text-align:center}
.big-mode .tq-row{padding:10px 12px;margin-bottom:8px}
.big-mode .tq-name{font-size:16px}
.big-mode .tq-stat{font-size:18px;min-width:36px}
.big-mode .tq-btn{width:50px;height:50px;font-size:20px;border-radius:12px}
.big-mode .tq-score{width:50px;height:38px;font-size:16px}
.big-mode .tq-avi{width:36px;height:36px;font-size:13px}

/* ===== BEGINNER MODE ===== */
.beg-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;position:sticky;top:0;z-index:10;background:var(--bg)}
.beg-wave-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px;margin:0 16px 10px}
.beg-eval-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.beg-eval-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;width:70px;flex-shrink:0}
.beg-eval-opts{display:flex;gap:5px;flex:1;flex-wrap:wrap}
.beg-eval-btn{padding:6px 10px;border-radius:8px;background:var(--bg-input);border:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .12s}
.beg-eval-btn:active{transform:scale(.94)}
.beg-eval-btn.selected{background:var(--accent);border-color:var(--accent);color:#fff}
.beg-eval-btn.green.selected{background:var(--green);border-color:var(--green)}
.beg-eval-btn.yellow.selected{background:#f59e0b;border-color:#f59e0b}
.beg-eval-btn.red.selected{background:var(--red);border-color:var(--red)}
.beg-summary{margin:0 16px 12px;padding:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px}
.beg-sum-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px}
.beg-sum-label{color:var(--text-secondary);font-weight:600}
.beg-sum-val{font-weight:800;color:var(--text-primary)}
.beg-wave-mini{display:flex;align-items:center;gap:8px;padding:8px;background:var(--bg-input);border-radius:8px;margin-bottom:6px;font-size:12px}
.beg-wave-num{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.beg-wave-tags{display:flex;gap:4px;flex-wrap:wrap;flex:1}
.beg-wave-tag{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600}
.beg-graduate-badge{text-align:center;padding:20px;margin:0 16px 12px;background:linear-gradient(135deg,#22c55e,#059669);border-radius:12px;color:#fff}
.beg-graduate-badge .icon{font-size:40px;margin-bottom:6px}

/* ===== DUAL VIDEO ===== */
.lab-dual-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:4px}
@media (max-width:600px) and (orientation:portrait){.lab-dual-wrap{grid-template-columns:1fr;gap:4px}}
.lab-dual-slot{position:relative;background:#000;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent}
.lab-dual-slot.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.lab-dual-slot video{width:100%;display:block;max-height:35vh;object-fit:contain}
.lab-dual-label{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.7);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;z-index:2}
.lab-dual-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px;color:var(--text-muted);font-size:12px;gap:6px;background:var(--bg-input);border-radius:8px;border:2px dashed var(--border);cursor:pointer}
.lab-sync-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:8px}
.lab-sync-bar label{font-size:12px;font-weight:700;color:var(--text-secondary);display:flex;align-items:center;gap:6px;cursor:pointer}
.lab-sync-bar input[type="checkbox"]{width:18px;height:18px;accent-color:var(--accent)}
.lab-mode-toggle{display:flex;gap:4px;margin-bottom:10px}
.lab-mode-btn{flex:1;padding:10px;border-radius:8px;background:var(--bg-card);border:1px solid var(--border);font-size:12px;font-weight:700;color:var(--text-secondary);cursor:pointer;text-align:center}
.lab-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* ===== LIGHTBOX ===== */
.lab-lightbox{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:10002;background:rgba(0,0,0,.95);flex-direction:column;align-items:center;justify-content:center;padding:16px;padding-top:calc(var(--safe-t) + 16px);padding-bottom:calc(var(--safe-b) + 16px)}
.lab-lightbox.active{display:flex}
.lab-lightbox img{max-width:100%;max-height:calc(100vh - 120px);object-fit:contain;border-radius:8px;touch-action:pinch-zoom}
.lab-lb-actions{display:flex;gap:10px;margin-top:14px}
.lab-lb-btn{padding:10px 20px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;border:none}
.lab-lb-btn.dl{background:var(--accent);color:#fff}
.lab-lb-btn.del{background:var(--red);color:#fff}
.lab-lb-btn.close{background:rgba(255,255,255,.15);color:#fff}
.lab-lb-close{display:none}
.lab-lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:#fff;width:44px;height:44px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}
.lab-lb-nav.prev{left:8px}
.lab-lb-nav.next{right:8px}
.lab-lb-info{color:rgba(255,255,255,.6);font-size:11px;margin-top:6px;text-align:center}

/* ===== FRAME GRID OVERLAY ===== */
.lab-frame{position:relative}
.lab-frame-actions{position:absolute;top:4px;right:4px;display:flex;gap:3px;opacity:0;transition:opacity .15s}
.lab-frame:hover .lab-frame-actions,.lab-frame:active .lab-frame-actions{opacity:1}
.lab-frame-act{width:26px;height:26px;border-radius:6px;background:rgba(0,0,0,.7);border:none;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lab-frame-act:active{transform:scale(.9)}

/* ===== A→B LOOP ===== */
.lab-ab-bar{display:none;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-card);border:1px solid var(--accent);border-radius:8px;margin-bottom:8px}

/* ===== TEXT ANNOTATION INPUT ===== */
.lab-text-input{position:absolute;z-index:30;display:flex;gap:4px;align-items:center;background:rgba(0,0,0,.85);border:2px solid var(--accent);border-radius:10px;padding:6px 8px;box-shadow:0 4px 20px rgba(0,0,0,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transform:translate(-50%,-120%)}
.lab-text-input input{background:transparent;border:none;color:#fff;font-size:14px;font-weight:700;width:180px;outline:none;font-family:inherit}
.lab-text-input input::placeholder{color:rgba(255,255,255,.4)}
.lab-text-input button{width:30px;height:30px;border-radius:6px;border:none;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.lab-text-input button{background:var(--accent);color:#fff}
.lab-text-input button.cancel{background:rgba(255,255,255,.15);color:#fff}
.lab-ab-bar.active{display:flex}
.lab-ab-label{font-size:11px;font-weight:700;color:var(--accent);flex-shrink:0}
.lab-ab-time{font-size:12px;font-weight:800;color:var(--text-primary);font-variant-numeric:tabular-nums}
.lab-ab-sep{color:var(--text-muted);font-size:12px}
.lab-ab-clear{background:none;border:none;color:var(--red);font-size:14px;cursor:pointer;margin-left:auto}

/* ===== KSS BRANDING ===== */
.kss-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.kss-logo{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.kss-logo-sm{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}
.kss-logo-lg{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0}
.kss-title{font-size:20px;font-weight:800;color:var(--text-primary)}
.kss-subtitle{font-size:11px;color:var(--text-secondary);font-weight:600}
.kss-watermark{position:absolute;bottom:8px;left:8px;z-index:5;opacity:.35;pointer-events:none;width:40px;height:40px;border-radius:50%}
.lab-fullscreen .kss-watermark{width:52px;height:52px;bottom:12px;left:12px;opacity:.3}
.kss-global-wm{position:fixed;bottom:calc(var(--nav-h) + var(--safe-b) + 10px);right:12px;width:32px;height:32px;border-radius:50%;opacity:.08;pointer-events:none;z-index:90}
.share-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;color:var(--accent);border:1px solid var(--accent);background:transparent;cursor:pointer;transition:all .15s}
.share-btn:active{background:var(--accent-glow);transform:scale(.97)}
.pwa-banner{position:fixed;bottom:calc(var(--nav-h) + var(--safe-b) + 6px);left:12px;right:12px;background:linear-gradient(135deg,#0c4a6e,#0369a1);border:1px solid var(--accent);border-radius:var(--radius);padding:12px 14px;display:flex;align-items:center;gap:10px;z-index:200;box-shadow:0 8px 30px rgba(0,0,0,.5);animation:slideUp .3s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.pwa-banner-logo{width:36px;height:36px;border-radius:50%;flex-shrink:0}
.pwa-banner-text{flex:1;font-size:13px;font-weight:600;color:#fff;line-height:1.3}
.pwa-banner-text small{font-size:11px;color:rgba(255,255,255,.7);display:block;margin-top:2px}
.pwa-banner-install{padding:8px 16px;border-radius:6px;background:#fff;color:#0369a1;font-size:12px;font-weight:800;border:none;cursor:pointer;flex-shrink:0}
.pwa-banner-close{padding:4px 8px;color:rgba(255,255,255,.6);font-size:18px;cursor:pointer;border:none;background:none;flex-shrink:0}
.kss-db-header{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:16px}
.kss-db-logo{width:56px;height:56px;border-radius:50%;object-fit:cover}

/* ===== BIOMETRICS ===== */
.bio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}
.bio-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}
.bio-val{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}
.bio-lbl{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.bio-trend{display:flex;align-items:flex-end;gap:3px;height:40px;justify-content:center;margin-top:6px}
.bio-bar{width:6px;border-radius:3px;min-height:3px}

/* ===== PHASE 4: DASHBOARD ===== */
.dash-hero{text-align:center;padding:12px 0 16px}
.dash-hero-title{font-size:28px;font-weight:800;letter-spacing:-.03em}
.dash-hero-sub{font-size:13px;color:var(--text-secondary);margin-top:2px}
.dash-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.dash-kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:10px 6px;text-align:center}
.dash-kpi-val{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums}
.dash-kpi-lbl{font-size:9px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.dash-section{margin-bottom:14px}
.dash-section-title{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.dash-feed-item{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border)}
.dash-feed-item:last-child{border-bottom:none}
.dash-feed-icon{font-size:18px;margin-top:1px}
.dash-feed-text{font-size:13px;line-height:1.4}
.dash-feed-time{font-size:11px;color:var(--text-muted)}
.dash-ath-mini{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}
.dash-ath-chip{flex-shrink:0;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:10px 12px;text-align:center;min-width:80px;cursor:pointer}
.dash-ath-chip:active{transform:scale(.96)}
.dash-ath-avi{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#6366f1);display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;margin-bottom:4px}
.dash-ath-name{font-size:11px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70px}
.dash-ath-stat{font-size:10px;color:var(--text-muted)}

.tpl-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer}
.tpl-card:active{transform:scale(.98)}
.tpl-card-name{font-weight:700;font-size:14px}
.tpl-card-meta{font-size:11px;color:var(--text-secondary);margin-top:3px}

.db-chart{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px}
.db-chart canvas{width:100%;height:120px}

/* ===== WORKOUT MODULE ===== */
.wo-ath-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:10px}
.wo-ath-name{font-weight:700;font-size:14px;margin-bottom:8px}
.wo-drill-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.wo-drill-row:last-child{border-bottom:none}
.wo-drill-name{flex:1;font-weight:600}
.wo-check{width:36px;height:36px;border-radius:8px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.wo-check:active{transform:scale(.9)}
.wo-check.done{background:var(--green);border-color:var(--green);color:#fff}
.wo-check.fail{background:var(--red);border-color:var(--red);color:#fff}
.wo-quality{display:flex;gap:6px}
.wo-q-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--bg-input);-webkit-tap-highlight-color:transparent}
.wo-q-btn:active{transform:scale(.9)}
.wo-q-btn.active{font-weight:800;border-width:2px}

/* ===== HISTORY & PROGRESSION ===== */
.hist-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.hist-card:active{background:var(--bg-input)}
.hist-spot{font-weight:800;font-size:15px}
.hist-date{font-size:12px;color:var(--text-muted)}
.hist-stats{display:flex;gap:12px;margin-top:6px;font-size:12px;color:var(--text-secondary)}
.hist-badge{display:inline-flex;align-items:center;gap:3px;background:var(--bg-input);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600}
.spark-line{position:relative;width:100%;height:100%}
.spark-line svg{width:100%;height:100%}
.sd-ath-card{border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:10px;background:var(--bg-card)}
/* Analytics Engine CSS */
.anl-card-title{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.anl-time-btn{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid var(--border);background:transparent;color:var(--text-muted);transition:all .15s}
.anl-time-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(56,189,248,.08)}
.anl-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.anl-bar-label{width:70px;font-size:11px;font-weight:600;color:var(--text-secondary);text-align:right;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.anl-bar-track{flex:1;height:18px;background:var(--bg-input);border-radius:4px;overflow:hidden;position:relative}
.anl-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:2px}
.anl-bar-val{width:36px;font-size:11px;font-weight:700;text-align:right;flex-shrink:0}
.anl-donut{border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center}
.anl-donut-center{position:absolute;width:50px;height:50px;background:var(--bg-card);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800}
.anl-legend-item{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.anl-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.anl-cmp-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.anl-cmp-label{width:70px;font-size:11px;font-weight:600;color:var(--text-secondary);text-align:center;flex-shrink:0}
.anl-cmp-bar{flex:1;height:20px;background:var(--bg-input);border-radius:4px;overflow:hidden;position:relative}
.anl-cmp-fill-a{position:absolute;left:0;top:0;height:100%;background:var(--accent);border-radius:4px 0 0 4px;transition:width .4s}
.anl-cmp-fill-b{position:absolute;right:0;top:0;height:100%;background:var(--green);border-radius:0 4px 4px 0;transition:width .4s}
.anl-spot-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}
.anl-spot-row:last-child{border-bottom:none}
/* Skill checklist */
.anl-skill{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.anl-skill:last-child{border-bottom:none}
.anl-skill-badge{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;border:2px solid}
.anl-skill-badge.locked{background:var(--bg-input);border-color:var(--border);opacity:.5}
.anl-skill-badge.unlocked{border-color:var(--green);background:rgba(34,197,94,.1)}
.anl-skill-badge.mastered{border-color:#f59e0b;background:rgba(245,158,11,.1)}
.anl-skill-info{flex:1;min-width:0}
.anl-skill-name{font-size:13px;font-weight:700}
.anl-skill-req{font-size:10px;color:var(--text-muted)}
.anl-skill-progress{height:4px;background:var(--bg-input);border-radius:2px;margin-top:3px;overflow:hidden}
.anl-skill-fill{height:100%;border-radius:2px;transition:width .3s}
.anl-bio-tab{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1.5px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer}
.anl-bio-tab.active{border-color:var(--accent);background:rgba(56,189,248,.08);color:var(--accent)}
/* === Frame Selector Modal === */
.fs-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s}

/* === Lab Recording Indicator === */
.lab-rec-indicator{position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:30;display:flex;align-items:center;gap:6px;background:rgba(220,38,38,.9);padding:5px 12px;border-radius:20px;font-size:12px;font-weight:800;color:#fff;animation:labRecPulse 1s infinite;pointer-events:none}
.lab-rec-dot{width:10px;height:10px;background:#fff;border-radius:50%;animation:labRecPulse 1s infinite}
@keyframes labRecPulse{0%,100%{opacity:1}50%{opacity:.4}}
.lab-tele-indicator{position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:30;display:flex;align-items:center;gap:6px;background:rgba(168,85,247,.9);padding:5px 12px;border-radius:20px;font-size:12px;font-weight:800;color:#fff;pointer-events:none;animation:labRecPulse 2s infinite}
.lab-mic-indicator{position:absolute;top:8px;right:50px;z-index:30;display:flex;align-items:center;gap:4px;background:rgba(245,158,11,.9);padding:4px 10px;border-radius:16px;font-size:11px;font-weight:700;color:#fff;pointer-events:none}
.lab-mic-indicator .mic-bar{width:3px;background:#fff;border-radius:2px;animation:micBounce .4s infinite alternate}
.lab-mic-indicator .mic-bar:nth-child(2){animation-delay:.1s}
.lab-mic-indicator .mic-bar:nth-child(3){animation-delay:.2s}
.lab-mic-indicator .mic-bar:nth-child(4){animation-delay:.3s}
@keyframes micBounce{0%{height:4px}100%{height:14px}}
.lab-tool.rec-active{background:var(--red)!important;border-color:var(--red)!important;color:#fff!important;animation:labRecPulse 1s infinite}
.lab-tool.mic-active{background:#f59e0b!important;border-color:#f59e0b!important;color:#fff!important}
.fs-modal{background:var(--bg-card);border-radius:16px;max-width:520px;width:100%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border)}
.fs-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.fs-header h3{font-size:16px;font-weight:800;color:var(--text-primary);margin:0}
.fs-close{background:none;border:none;color:var(--text-secondary);font-size:22px;cursor:pointer;padding:4px 8px}
.fs-body{padding:16px 20px;overflow-y:auto;flex:1}
.fs-section-title{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;margin-bottom:10px;letter-spacing:.05em}
.fs-frames-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.fs-frame{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s;aspect-ratio:16/9}
.fs-frame.selected{border-color:#8b5cf6;box-shadow:0 0 12px rgba(139,92,246,.4)}
.fs-frame img{width:100%;height:100%;object-fit:cover}
.fs-frame .fs-check{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s}
.fs-frame.selected .fs-check{background:#8b5cf6;border-color:#8b5cf6}
.fs-frame .fs-label{position:absolute;bottom:0;left:0;right:0;padding:3px 6px;background:linear-gradient(transparent,rgba(0,0,0,.7));font-size:10px;color:#fff;font-weight:600}
.fs-options{display:flex;gap:8px;margin-bottom:16px}
.fs-opt{flex:1;padding:12px;border-radius:10px;border:2px solid var(--border);background:var(--bg-input);cursor:pointer;text-align:center;transition:all .2s}
.fs-opt.active{border-color:#8b5cf6;background:rgba(139,92,246,.1)}
.fs-opt-icon{font-size:22px;margin-bottom:4px}
.fs-opt-label{font-size:12px;font-weight:700;color:var(--text-primary)}
.fs-opt-desc{font-size:10px;color:var(--text-secondary);margin-top:2px}
.fs-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px}
.fs-footer .btn{flex:1}
.fs-select-actions{display:flex;gap:8px;margin-bottom:10px}
.fs-select-actions button{padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);font-size:11px;font-weight:600;cursor:pointer}

/* Onboarding hint toast animation */
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.hint-toast{animation:slideDown .3s ease}
