/* Raycin Stats (Native) — matches the native Vehicles theme (dark gunmetal + cyan-teal accent). */
.rvs-wrap{
  --rv-bg:#0d0f18; --rv-card:#12141c; --rv-line:#252836; --rv-accent:#37b7c7; --rv-accent-dim:#2b8d99;
  --rv-text:#eef0f5; --rv-muted:#8892a4; --rv-input:#1e2130; --rv-nav:#0a0b10; --rv-radius:10px;
  max-width:1280px;margin:0 auto;color:var(--rv-text);font-size:15px;line-height:1.55;
  /* clear Impreza's absolute transparent header */
  padding:calc(var(--header-height,90px) + 20px) 18px 70px}
.rvs-wrap a{color:var(--rv-muted);text-decoration:none;transition:color .2s}
.rvs-wrap a:hover{color:var(--rv-accent)}
.rvs-crumb{font-size:13px;color:var(--rv-muted);margin-bottom:14px}
.rvs-crumb span{color:var(--rv-text)}
.rvs-title{font-size:24px;font-weight:800;margin:0;color:#fff;line-height:1.1}
.rvs-empty{color:var(--rv-muted);background:var(--rv-card);border:1px solid var(--rv-line);border-radius:10px;padding:18px}

/* layout */
.rvs-layout{display:grid;grid-template-columns:248px 1fr;gap:22px;align-items:start}
@media(max-width:900px){.rvs-layout{grid-template-columns:1fr}}
.rvs-side{display:flex;flex-direction:column;gap:14px;position:sticky;top:90px}
@media(max-width:900px){.rvs-side{position:static}}
.rvs-vnav{background:var(--rv-nav);border:1px solid var(--rv-line);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:2px}
.rvs-vnav h6,.rvs-fsec h6{margin:0 0 8px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--rv-muted)}
.rvs-vnav a{padding:7px 9px;border-radius:7px;color:var(--rv-text);font-size:14px}
.rvs-vnav a:hover{background:var(--rv-card)}
.rvs-vnav a.is-active{background:var(--rv-accent);color:#06222a;font-weight:700}
.rvs-soon{font-size:11px;color:var(--rv-muted);padding:6px 9px;line-height:1.5}
.rvs-soon em{color:var(--rv-accent-dim)}
.rvs-fsec{background:var(--rv-card);border:1px solid var(--rv-line);border-radius:10px;padding:12px}
.rvs-fsec input[type=search]{width:100%;background:var(--rv-input);border:1px solid var(--rv-line);border-radius:8px;padding:8px 11px;color:#fff;font-size:14px}
.rvs-fsec input[type=search]:focus{outline:none;border-color:var(--rv-accent)}
.rvs-cats{display:flex;flex-direction:column;gap:3px;max-height:420px;overflow:auto}
.rvs-cat{display:flex;justify-content:space-between;align-items:center;padding:6px 9px;border-radius:7px;font-size:13px;color:var(--rv-muted)}
.rvs-cat:hover{background:var(--rv-input);color:var(--rv-text)}
.rvs-cat.is-active{background:var(--rv-accent);color:#06222a;font-weight:700}
.rvs-cat span{font-size:11px;opacity:.8}

/* sort bar */
.rvs-sortbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.rvs-cnt{color:var(--rv-muted);font-size:13px}
.rvs-sorts{margin-left:auto;font-size:13px;color:var(--rv-muted);display:flex;gap:10px;flex-wrap:wrap}
.rvs-sorts a.is-active{color:var(--rv-accent);font-weight:700}

/* grid + cards */
.rvs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.rvs-card{display:flex;flex-direction:column;background:var(--rv-card);border:1px solid var(--rv-line);border-radius:12px;overflow:hidden;transition:border-color .15s,transform .15s}
.rvs-card:hover{border-color:var(--rv-accent);transform:translateY(-2px)}
.rvs-card-img{position:relative;aspect-ratio:16/9;background:#0c0e14;display:flex;align-items:center;justify-content:center}
.rvs-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.rvs-card-img span,.rvs-card-img.noimg::after{color:var(--rv-muted);font-size:12px}
.rvs-card-img.noimg::after{content:'No image'}
.rvs-card-cat{position:absolute;top:8px;left:8px;background:rgba(13,15,24,.85);border:1px solid var(--rv-line);color:#cfd5e2;font-size:11px;padding:2px 8px;border-radius:999px}
.rvs-card-body{padding:11px 12px;display:flex;flex-direction:column;gap:9px}
.rvs-card-title{font-size:14px;font-weight:700;color:#fff;line-height:1.25}
.rvs-card-stats{display:flex;justify-content:space-between;gap:6px;border-top:1px solid var(--rv-line);border-bottom:1px solid var(--rv-line);padding:8px 0}
.rvs-card-stats div{display:flex;flex-direction:column;gap:1px}
.rvs-card-stats span{font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--rv-muted)}
.rvs-card-stats b{font-size:13px;color:var(--rv-text)}
.rvs-card-best{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.rvs-best-t{font-size:15px;font-weight:800;color:var(--rv-accent);font-variant-numeric:tabular-nums}
.rvs-best-h{font-size:11px;color:var(--rv-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rvs-best-none{font-size:12px;color:var(--rv-muted)}

/* detail */
.rvs-head{margin-bottom:16px}
.rvs-make{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--rv-muted)}
.rvs-grid2{display:grid;grid-template-columns:1.1fr 1fr;gap:22px;align-items:start}
@media(max-width:820px){.rvs-grid2{grid-template-columns:1fr}}
.rvs-hero{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:14px;border:1px solid var(--rv-line);background:#0c0e14;display:block}
.rvs-hero.noimg{display:flex;align-items:center;justify-content:center}
.rvs-hero.noimg::after{content:'No image';color:var(--rv-muted)}
.rvs-statrow{display:flex;gap:10px;margin-top:12px}
.rvs-statrow div{flex:1;background:var(--rv-card);border:1px solid var(--rv-line);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:2px}
.rvs-statrow span{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--rv-muted)}
.rvs-statrow b{font-size:18px;color:#fff}
.rvs-card2{background:var(--rv-card);border:1px solid var(--rv-line);border-radius:14px;padding:16px 18px}
.rvs-card2 h2{font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--rv-muted);margin:0 0 12px}
.rvs-lb{width:100%;border-collapse:collapse;font-size:13px}
.rvs-lb th,.rvs-lb td{padding:8px 10px;border-bottom:1px solid var(--rv-line);text-align:left}
.rvs-lb thead th{color:var(--rv-muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.rvs-lb td.t{font-variant-numeric:tabular-nums;font-weight:700}
.rvs-lb tr.best td{color:var(--rv-accent)}
.rvs-back{margin-top:24px;font-weight:600}

/* ============================================================
   Tracks master-detail + GTA map (parity with standalone app)
   ============================================================ */
.rvs-loading{color:var(--rv-muted);padding:24px}
.rvs-emptyl{color:var(--rv-muted);padding:18px;text-align:center}
.rvs-panel-h{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--rv-muted);margin:16px 0 8px;font-weight:700}
.muted-text{color:var(--rv-muted)}

.rvs-wrap-tracks{padding-bottom:20px}

/* Full-width filter/admin toolbar above the master-detail layout.
   Lifts dropdowns out of the cramped 340px left column. */
.tracks-toolbar{background:var(--rv-card);border:1px solid var(--rv-line);border-radius:12px;padding:10px 12px;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}
.tracks-toolbar .track-list-admin{display:flex;flex-wrap:wrap;gap:8px;padding-bottom:6px;border-bottom:1px solid var(--rv-line)}
.tracks-toolbar .track-list-filters{display:flex;flex-wrap:wrap;gap:8px;padding:0;border:none}
.tracks-toolbar .rvs-tag-filter-row{padding:0}
.tracks-toolbar #trk-search{flex:1 1 220px;min-width:160px}
.track-count-inline{font-size:12px;color:var(--rv-muted);font-weight:400;margin-left:6px}

.tracks-layout{display:grid;grid-template-columns:340px 1fr;gap:16px;align-items:stretch;height:calc(100vh - 340px);min-height:520px}
@media(max-width:900px){.tracks-layout{grid-template-columns:1fr;height:auto}.track-map-container{height:60vh!important}}

/* left list panel */
.track-list-panel{display:flex;flex-direction:column;background:var(--rv-card);border:1px solid var(--rv-line);border-radius:12px;overflow:hidden;min-height:0}
.track-list-head{padding:12px 14px;font-size:15px;font-weight:800;color:#fff;border-bottom:1px solid var(--rv-line);background:linear-gradient(180deg,#161a24,#12141c)}
.track-list-filters{display:flex;flex-wrap:wrap;gap:7px;padding:11px;border-bottom:1px solid var(--rv-line)}
.cr-input,.cr-select{background:var(--rv-input);border:1px solid var(--rv-line);border-radius:8px;padding:7px 10px;color:#fff;font-size:13px}
.cr-input{flex:1 1 100%}
.cr-input:focus,.cr-select:focus{outline:none;border-color:var(--rv-accent)}
.cr-select{flex:1 1 46%}
.btn-grey{background:var(--rv-input);border:1px solid var(--rv-line);border-radius:8px;color:var(--rv-muted);font-size:12px;padding:4px 10px;cursor:pointer}
.btn-grey:hover{color:#fff;border-color:#3a3f50}
.btn-grey.active{background:var(--rv-accent);color:#06222a;border-color:var(--rv-accent);font-weight:700}
.track-list-scroll{flex:1;overflow-y:auto;min-height:0}
.track-item{padding:9px 12px;border-bottom:1px solid var(--rv-line);cursor:pointer;transition:background .12s}
.track-item:hover{background:var(--rv-input)}
.track-item.active{background:#0f1c22;border-left:3px solid var(--rv-accent);padding-left:9px}
.track-item-name{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#fff}
.fav-btn{background:none;border:none;color:var(--rv-muted);cursor:pointer;font-size:15px;line-height:1;padding:0}
.fav-btn.fav-active{color:#f6c90e}
.track-item-meta{font-size:11px;color:var(--rv-muted);margin-top:3px;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.badge{display:inline-block;font-size:10px;padding:1px 7px;border-radius:999px;line-height:1.5}
.badge-blue{background:#0f2a33;border:1px solid var(--rv-accent-dim);color:var(--rv-accent)}
.badge-grey{background:#1a1d27;border:1px solid var(--rv-line);color:#cfd5e2}
.track-count{padding:9px 12px;border-top:1px solid var(--rv-line);color:var(--rv-muted);font-size:12px;text-align:center}

/* right detail panel */
.track-detail-panel{display:flex;flex-direction:column;background:var(--rv-card);border:1px solid var(--rv-line);border-radius:12px;overflow:hidden;min-height:0}
.track-detail-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--rv-muted)}
.track-map-container{position:relative;width:100%;flex:1 1 auto;min-height:0;background:#0c0e14}
.track-detail-info{flex:0 0 auto;display:grid;grid-template-columns:1fr 1.15fr;gap:18px;padding:14px 18px;height:212px;border-top:1px solid var(--rv-line);background:linear-gradient(180deg,#12141c,#0f1118)}
@media(max-width:900px){.track-detail-info{grid-template-columns:1fr;height:auto}}
.tdi-left{min-width:0}
.tdi-right{min-width:0;display:flex;flex-direction:column;min-height:0}
.tdi-table-wrap{overflow-y:auto;min-height:0;border:1px solid var(--rv-line);border-radius:8px}
.track-detail-name{font-size:21px;font-weight:800;color:#fff;margin-bottom:10px;line-height:1.15}
.track-meta-grid{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px}
.track-meta-item{background:var(--rv-input);border:1px solid var(--rv-line);border-radius:8px;padding:5px 10px;font-size:12px;color:var(--rv-muted)}
.track-meta-item strong{color:var(--rv-accent)}
.track-job-link{display:inline-block;color:var(--rv-accent);font-weight:600;font-size:13px}

/* best-times table */
.cr-table{width:100%;border-collapse:collapse;font-size:13px}
.cr-table th,.cr-table td{padding:7px 9px;border-bottom:1px solid var(--rv-line);text-align:left}
.cr-table thead th{color:var(--rv-muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.cr-table .lap-time{font-variant-numeric:tabular-nums;font-weight:700;color:var(--rv-accent)}
.cr-table tr.row-gold td{background:rgba(246,201,14,.06)}
.pos-gold,.pos-silver,.pos-bronze{font-size:14px}

/* leaflet map fullscreen toggle */
.rvs-map-fs{position:absolute;top:10px;right:10px;z-index:1000;width:32px;height:32px;border:1px solid var(--rv-line);background:rgba(13,15,24,.9);color:#fff;border-radius:7px;cursor:pointer;font-size:15px}
.rvs-map-fs:hover{border-color:var(--rv-accent);color:var(--rv-accent)}
.track-detail-panel.rvs-fs{position:fixed;inset:0;z-index:9999;border-radius:0}
.track-detail-panel.rvs-fs .track-map-container{height:100%}
.track-detail-panel.rvs-fs .track-detail-info{display:none}
.leaflet-container{background:#0c0e14}
.tdi-right .rvs-panel-h{margin:0 0 8px}
.tdi-table-wrap .cr-table thead th{position:sticky;top:0;background:#12141c;z-index:1}
.tdi-table-wrap .cr-table th,.tdi-table-wrap .cr-table td{padding:6px 9px}

/* ============================================================
   Section nav + table-based sections (Home/Servers/Cars/…)
   ============================================================ */
.rvs-secnav{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--rv-line);padding-bottom:10px}
.rvs-secnav a{padding:7px 13px;border-radius:8px;font-size:13px;font-weight:600;color:var(--rv-muted);white-space:nowrap}
.rvs-secnav a:hover{background:var(--rv-card);color:var(--rv-text)}
.rvs-secnav a.is-active{background:var(--rv-accent);color:#06222a}

.page-header{margin-bottom:14px}
.page-title{font-size:22px;font-weight:800;color:#fff;margin:0}
.panel{background:var(--rv-card);border:1px solid var(--rv-line);border-radius:12px;padding:14px 16px;margin-bottom:16px}
.panel-header{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--rv-muted);font-weight:700;margin-bottom:10px}
.empty-state{color:var(--rv-muted);text-align:center;padding:20px}
.rvs-err{color:#e06}
.muted-text{color:var(--rv-muted)}
.rvs-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:820px){.rvs-cols{grid-template-columns:1fr}}

.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
@media(max-width:700px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat-box{background:var(--rv-card);border:1px solid var(--rv-line);border-radius:12px;padding:14px 16px;text-align:center}
.stat-value{font-size:26px;font-weight:800;color:var(--rv-accent);line-height:1.1}
.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--rv-muted);margin-top:4px}

.bar-chart{display:flex;flex-direction:column;gap:5px}
.bar-row{display:grid;grid-template-columns:150px 1fr 90px;align-items:center;gap:10px;padding:4px 6px;border-radius:7px;cursor:pointer}
.bar-row:hover{background:var(--rv-input)}
.bar-row.active{background:#0f1c22}
.bar-label{font-size:13px;color:var(--rv-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-fill-wrap{background:#0c0e14;border-radius:99px;height:14px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--rv-accent-dim),var(--rv-accent));border-radius:99px}
.bar-count{font-size:12px;color:var(--rv-text);text-align:right}

.filter-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}
.btn-green{background:var(--rv-accent);color:#06222a;border:none;border-radius:8px;padding:7px 16px;font-weight:700;font-size:13px;cursor:pointer}
.btn-green:hover{background:var(--rv-accent-dim)}
.player-link{color:var(--rv-accent);font-weight:600}
.player-link:hover{color:#fff}
.rvs-clearf{float:right;background:none;border:none;color:var(--rv-muted);cursor:pointer;font-size:12px}
.rvs-lbl{color:var(--rv-muted);font-size:12px;display:block;margin-bottom:4px}
.rvs-chiprow{display:flex;flex-wrap:wrap;gap:6px}
.cr-table tr.row-silver td{background:rgba(192,192,192,.05)}
.cr-table tr.row-bronze td{background:rgba(205,127,50,.05)}
.cr-table td.hl,.cr-table .hl{color:var(--rv-accent)!important}

.h2h-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.h2h-col{flex:1;min-width:180px}
.h2h-vs{color:var(--rv-muted);font-size:18px;padding-bottom:6px}
.h2h-score{display:flex;gap:2rem;align-items:center;justify-content:center;padding:1rem 0}
.h2h-score>div{text-align:center}
.h2h-num{font-size:2.4rem;font-weight:800;color:var(--rv-accent)}

/* ---- Home: server card + connect + players online ---- */
.home-server-card{background:linear-gradient(135deg,#12141c,#0f1822);border:1px solid var(--rv-line);border-radius:14px;padding:16px 18px;margin-bottom:16px}
.server-status-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.server-name-big{display:flex;align-items:center;gap:9px;font-size:20px;font-weight:800;color:#fff}
.status-dot{width:11px;height:11px;border-radius:50%;background:#27ae60;box-shadow:0 0 0 4px rgba(39,174,96,.18);flex:0 0 11px}
.player-count-text{color:var(--rv-accent);font-weight:700;font-size:14px}
.btn-green{margin-left:auto;background:var(--rv-accent);color:#06222a;border:none;border-radius:8px;padding:8px 16px;font-weight:800;font-size:13px;text-decoration:none;display:inline-block}
.btn-green:hover{background:var(--rv-accent-dim);color:#06222a}
/* Gold call-to-action (Connect button) — standout per design */
.btn-gold{margin-left:auto;background:#f6c90e;color:#1a1205;border:none;border-radius:8px;padding:8px 18px;font-weight:800;font-size:13px;text-decoration:none;display:inline-block}
.btn-gold:hover{background:#e0b400;color:#1a1205}
/* Gold "Servers & Stats Home" nav tab — standout entry point */
.rvs-secnav a.rvs-secnav-home{background:#f6c90e;color:#1a1205}
.rvs-secnav a.rvs-secnav-home:hover{background:#e0b400;color:#1a1205}
.btn-discord{background:#5865F2;color:#fff;border-radius:8px;padding:8px 14px;font-weight:700;font-size:13px;text-decoration:none}
/* keep button/link text colours from being overridden by the generic ".rvs-wrap a" rule */
.rvs-wrap a.btn-gold,.rvs-wrap a.btn-gold:hover{color:#1a1205}
.rvs-wrap a.btn-green,.rvs-wrap a.btn-green:hover{color:#06222a}
.rvs-wrap a.btn-discord,.rvs-wrap a.btn-discord:hover{color:#fff}
.rvs-wrap a.player-link{color:var(--rv-accent)}
.rvs-wrap a.player-link:hover{color:#fff}
/* cyan-background buttons keep dark, readable text on hover (dark-on-light) */
.rvs-secnav a.is-active:hover{background:var(--rv-accent-dim);color:#06222a}
.rvs-vnav a.is-active:hover{background:var(--rv-accent-dim);color:#06222a}
.rvs-cat.is-active:hover{background:var(--rv-accent-dim);color:#06222a}
.btn-grey.active:hover{background:var(--rv-accent-dim);color:#06222a}
.rvs-wrap .btn-green:hover{background:var(--rv-accent-dim);color:#06222a}
.progress-bar-wrap{height:8px;background:#0c0e14;border-radius:99px;overflow:hidden;margin-top:12px}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--rv-accent-dim),var(--rv-accent));border-radius:99px;transition:width .4s}
.player-grid{display:flex;flex-wrap:wrap;gap:7px}
.player-chip{background:var(--rv-input);border:1px solid var(--rv-line);border-radius:999px;padding:5px 13px;font-size:13px;color:var(--rv-text)}
/* ── Tag system ─────────────────────────────────────────────────────── */
/* Track-card tag chips (list view + detail panel) */
.rvs-track-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.rvs-tag-chip{display:inline-block;padding:2px 8px;background:rgba(80,130,180,0.10);border:1px solid rgba(80,130,180,0.28);border-radius:999px;color:rgba(160,200,240,0.75);font-size:11px;font-weight:500;letter-spacing:.02em;white-space:nowrap}
/* Admin inline tag editor (only visible when RVS.canEdit) */
.rvs-tag-empty{color:var(--rv-muted);font-size:11px;font-style:italic;margin-right:6px}
.rvs-tag-edit{background:transparent;border:1px solid var(--rv-line);color:var(--rv-muted);padding:1px 8px;border-radius:999px;font-size:11px;cursor:pointer;transition:all .15s}
.rvs-tag-edit:hover{border-color:var(--rv-accent);color:var(--rv-accent)}
.rvs-tag-editor{margin:6px 0 10px;background:var(--rv-nav);border:1px solid var(--rv-accent-dim);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}
.rvs-te-title{font-size:12px;font-weight:700;color:var(--rv-accent);text-transform:uppercase;letter-spacing:.06em}
.rvs-te-chips{display:flex;flex-wrap:wrap;gap:5px;min-height:22px}
.rvs-te-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 4px 2px 9px;background:rgba(80,130,180,0.14);border:1px solid rgba(80,130,180,0.35);border-radius:999px;color:#cfe1f5;font-size:12px}
.rvs-te-chip button{background:transparent;border:0;color:#c66;cursor:pointer;font-size:14px;line-height:1;padding:0 4px;border-radius:50%}
.rvs-te-chip button:hover{background:rgba(200,80,80,0.18);color:#fff}
.rvs-te-empty{color:var(--rv-muted);font-size:12px;font-style:italic}
.rvs-te-row{display:flex;gap:6px}
.rvs-te-input{flex:1;background:var(--rv-input);border:1px solid var(--rv-line);border-radius:8px;padding:6px 10px;color:#fff;font-size:13px}
.rvs-te-input:focus{outline:none;border-color:var(--rv-accent)}
.rvs-te-add{background:var(--rv-input);border:1px solid var(--rv-line);color:var(--rv-text);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:12px}
.rvs-te-add:hover{border-color:var(--rv-accent);color:var(--rv-accent)}
.rvs-te-actions{display:flex;justify-content:flex-end;gap:6px}
.rvs-te-cancel,.rvs-te-save{padding:6px 14px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600}
.rvs-te-cancel{background:transparent;border:1px solid var(--rv-line);color:var(--rv-muted)}
.rvs-te-cancel:hover{border-color:var(--rv-text);color:var(--rv-text)}
.rvs-te-save{background:var(--rv-accent);border:1px solid var(--rv-accent);color:#06222a}
.rvs-te-save:hover{background:var(--rv-accent-dim);border-color:var(--rv-accent-dim);color:#fff}
.rvs-te-status{font-size:11px;color:var(--rv-muted)}
/* Tag filter chips row (track browser) */
.rvs-tag-filter-row{display:flex;flex-direction:column;gap:6px;padding:8px 0 2px}
.rvs-tag-filter-label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--rv-muted);align-self:center;margin-right:2px}

.rvs-tag-filter-head{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--rv-muted);font-weight:600;padding-bottom:2px}
.rvs-tag-filter-hint{font-size:12px;color:var(--rv-muted);background:rgba(255,255,255,.03);border-left:2px solid rgba(80,140,200,.4);padding:6px 10px;border-radius:4px;line-height:1.45;margin:2px 0 6px}
.rvs-tag-filter-hint strong{color:var(--rv-text)}
.rvs-tag-families{display:flex;flex-wrap:wrap;gap:6px 14px;align-items:flex-start}
.rvs-tag-family{background:transparent;border:none;padding:0;min-width:0}
.rvs-tag-family > summary{cursor:pointer;font-size:12px;font-weight:600;color:var(--rv-muted);user-select:none;list-style:none;display:inline-flex;align-items:center;gap:6px;padding:2px 0;text-transform:uppercase;letter-spacing:.05em}
.rvs-tag-family > summary::-webkit-details-marker{display:none}
.rvs-tag-family > summary::before{content:'▸';font-size:9px;color:var(--rv-muted);transition:transform .15s;display:inline-block}
.rvs-tag-family[open] > summary::before{transform:rotate(90deg)}
.rvs-tag-family > summary:hover{color:var(--rv-text)}
.rvs-tag-family[open] > summary{color:var(--rv-text)}
.rvs-tag-family-count{font-size:10px;color:var(--rv-muted);font-weight:400;opacity:.8}
.rvs-tag-family-body{display:flex;flex-wrap:wrap;gap:4px;padding:4px 0 2px 14px;max-width:100%}
.rvs-tag-actions{display:flex;gap:6px;margin-top:6px;border-top:1px solid var(--rv-line);padding-top:8px}
.rvs-tag-toggle{background:var(--rv-input);border:1px solid var(--rv-line);border-radius:999px;color:var(--rv-muted);font-size:12px;font-weight:500;padding:3px 10px;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}
.rvs-tag-toggle:hover{border-color:rgba(80,130,180,0.45);color:var(--rv-text)}
.rvs-tag-toggle.active{background:rgba(80,140,200,0.14);border-color:rgba(80,140,200,0.50);color:#8ec4e8}
.rvs-tag-count{font-size:10px;opacity:.6;font-weight:400;margin-left:2px}
.rvs-tag-clear{background:transparent;border:1px solid rgba(220,80,80,0.30);border-radius:999px;color:rgba(220,140,140,0.75);font-size:12px;padding:3px 9px;cursor:pointer;transition:background .15s,color .15s}
.rvs-tag-clear:hover{background:rgba(220,80,80,0.10);color:#f08080}

/* ════════════════════════════════════════════════════════════════════
 *  Tag Manager (/race-stats/tags/) — admin-only vocabulary editor
 *  + Bulk-edit mode on /race-stats/tracks/
 *  + Tag-chip colour overrides driven by vocab
 * ════════════════════════════════════════════════════════════════════ */

/* ── Tag Manager ── */
.rvs-wrap-tags{padding-top:calc(var(--header-height,90px) + 20px)}
.rtm-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;margin:18px 0 14px}
.rtm-title h2{margin:0;color:#fff;font-size:22px}
.rtm-sub{margin:4px 0 0;color:var(--rv-muted);font-size:13px}
.rtm-actions{display:flex;gap:8px;flex-wrap:wrap}
.rtm-btn{padding:7px 14px;border-radius:8px;border:1px solid var(--rv-line);background:var(--rv-input);color:var(--rv-text);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;display:inline-flex;align-items:center;gap:5px;line-height:1.2}
.rtm-btn:hover{border-color:var(--rv-accent);color:var(--rv-accent)}
.rtm-btn-primary{background:var(--rv-accent);border-color:var(--rv-accent);color:#06222a}
.rtm-btn-primary:hover{background:var(--rv-accent-dim);border-color:var(--rv-accent-dim);color:#fff}
.rtm-btn-ghost{background:transparent}
.rtm-btn-small{padding:4px 10px;font-size:12px}
.rtm-btn-danger{color:#e88;border-color:rgba(220,80,80,0.4)}
.rtm-btn-danger:hover{background:rgba(220,80,80,0.12);border-color:#e88;color:#fff}
.rtm-btn[disabled]{opacity:.4;cursor:not-allowed}

.rtm-stats{display:flex;gap:18px;flex-wrap:wrap;background:var(--rv-card);border:1px solid var(--rv-line);border-radius:10px;padding:12px 16px;margin-bottom:14px;font-size:13px;color:var(--rv-muted)}
.rtm-stats strong{color:#fff;font-size:15px;margin-right:4px}
.rtm-stat-warn{color:#f4ba4a}
.rtm-stat-warn strong{color:#f4ba4a}

.rtm-grouped{background:var(--rv-card);border:1px solid var(--rv-line);border-radius:10px;margin-bottom:14px}
.rtm-grouped > summary{padding:11px 16px;cursor:pointer;font-weight:600;color:#fff;list-style:none;user-select:none}
.rtm-grouped > summary::before{content:'\25B6';margin-right:8px;color:var(--rv-accent);font-size:10px;display:inline-block;transition:transform .15s}
.rtm-grouped[open] > summary::before{transform:rotate(90deg)}
.rtm-groups-body, .rtm-orphans-body{padding:0 16px 14px;border-top:1px solid var(--rv-line)}
.rtm-help{color:var(--rv-muted);font-size:12px;margin:12px 0}
.rtm-groups-list{display:flex;flex-direction:column;gap:6px;margin:10px 0}
.rtm-group-row{display:flex;gap:6px;align-items:center}
.rtm-group-row .rtm-input{flex:1}
.rtm-group-add{display:flex;gap:6px;align-items:center;margin-top:12px;flex-wrap:wrap}
.rtm-input{background:var(--rv-input);border:1px solid var(--rv-line);border-radius:8px;padding:7px 11px;color:#fff;font-size:13px}
.rtm-input:focus{outline:none;border-color:var(--rv-accent)}
.rtm-input[disabled]{opacity:.6}

.rtm-orphans summary{color:#f4ba4a}
.rtm-orphan-row{display:flex;align-items:center;gap:10px;padding:6px 0;flex-wrap:wrap}
.rtm-orphan-count{color:var(--rv-muted);font-size:12px;min-width:80px}

.rtm-vocab{display:flex;flex-direction:column;gap:18px}
.rtm-group{background:var(--rv-card);border:1px solid var(--rv-line);border-radius:10px;padding:14px 16px}
.rtm-group-h{margin:0 0 12px;font-size:13px;color:var(--rv-accent);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.rtm-group-count{color:var(--rv-muted);font-size:11px;font-weight:500;text-transform:none;letter-spacing:0;margin-left:4px}
.rtm-tag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.rtm-empty-cell{color:var(--rv-muted);font-size:13px;font-style:italic;padding:6px 0}

.rtm-tag-card{background:var(--rv-nav);border:1px solid var(--rv-line);border-left:3px solid var(--rtm-tag-c, var(--rv-accent-dim));border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:6px;transition:border-color .15s}
.rtm-tag-card:hover{border-color:var(--rv-line) var(--rv-line) var(--rv-line) var(--rtm-tag-c, var(--rv-accent));}
.rtm-tag-card.is-editing{background:var(--rv-card);border-left-width:3px}
.rtm-tag-head{display:flex;align-items:center;gap:8px}
.rtm-tag-swatch{width:14px;height:14px;border-radius:3px;background:var(--rtm-tag-c, var(--rv-accent-dim));flex-shrink:0;border:1px solid rgba(255,255,255,0.08)}
.rtm-tag-name{font-weight:600;color:#fff;font-size:14px;flex:1;font-family:Consolas,Monaco,monospace}
.rtm-tag-count{background:var(--rv-input);color:var(--rv-text);font-size:11px;padding:1px 8px;border-radius:999px;font-weight:600}
.rtm-tag-desc{color:var(--rv-text);font-size:12px;line-height:1.4}
.rtm-tag-meta{color:var(--rv-muted);font-size:11px}
.rtm-tag-actions{display:flex;gap:5px;flex-wrap:wrap;margin-top:4px}

.rtm-tag-edit{display:flex;flex-direction:column;gap:8px}
.rtm-edit-row{display:flex;flex-direction:column;gap:3px}
.rtm-edit-row label{font-size:11px;color:var(--rv-muted);text-transform:uppercase;letter-spacing:.04em}
.rtm-edit-row input, .rtm-edit-row select{width:100%}
.rtm-edit-row input[type="color"]{width:60px;height:32px;padding:2px;cursor:pointer}
.rtm-edit-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:6px}

/* ── Bulk-edit mode on /race-stats/tracks/ ── */
.track-list-admin{display:flex;gap:6px;padding:8px 11px;border-bottom:1px solid var(--rv-line);align-items:center;background:rgba(55,183,199,0.04)}
.rtb-bulk-toggle{margin-left:auto}
.rtb-bulk-toggle.is-active{background:var(--rv-accent);border-color:var(--rv-accent);color:#06222a}
.track-item.is-bulk{position:relative;padding-left:34px;cursor:pointer}
.track-item.is-bulk .rtb-check{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid var(--rv-line);border-radius:3px;background:var(--rv-input);transition:all .12s}
.track-item.is-bulk.is-selected{background:rgba(55,183,199,0.05);border-color:var(--rv-accent-dim)}
.track-item.is-bulk.is-selected .rtb-check{background:var(--rv-accent);border-color:var(--rv-accent);box-shadow:inset 0 0 0 3px var(--rv-nav)}

.rtb-action-bar{position:fixed;left:0;right:0;bottom:0;background:var(--rv-card);border-top:2px solid var(--rv-accent);padding:14px 22px;box-shadow:0 -4px 18px rgba(0,0,0,0.5);z-index:9000;display:none;flex-direction:column;gap:10px}
.rtb-action-bar.is-active{display:flex}
.rtb-bar-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.rtb-count{font-weight:700;color:var(--rv-accent);font-size:15px}
.rtb-bar-select-actions{display:flex;gap:6px}
.rtb-op-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rtb-op-label{color:var(--rv-muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em}
.rtb-op-pills{display:flex;gap:4px}
.rtb-op-pill{padding:5px 11px;border-radius:999px;background:var(--rv-input);border:1px solid var(--rv-line);color:var(--rv-text);font-size:12px;cursor:pointer;transition:all .12s}
.rtb-op-pill:hover{border-color:var(--rv-accent);color:var(--rv-accent)}
.rtb-op-pill.is-active{background:var(--rv-accent);border-color:var(--rv-accent);color:#06222a;font-weight:700}
.rtb-tag-picker{display:flex;flex-wrap:wrap;gap:5px;flex:1;min-width:200px}
.rtb-tag-pickbtn{padding:4px 10px;border-radius:999px;background:var(--rv-input);border:1px solid var(--rv-line);color:var(--rv-text);font-size:12px;cursor:pointer;transition:all .12s}
.rtb-tag-pickbtn:hover{border-color:var(--rv-accent)}
.rtb-tag-pickbtn.is-picked{background:rgba(55,183,199,0.18);border-color:var(--rv-accent);color:var(--rv-accent);font-weight:700}
.rtb-apply{background:var(--rv-accent);border:1px solid var(--rv-accent);color:#06222a;padding:8px 22px;border-radius:8px;font-weight:700;cursor:pointer;font-size:13px}
.rtb-apply:hover{background:var(--rv-accent-dim);color:#fff}
.rtb-apply[disabled]{opacity:.4;cursor:not-allowed}
.rtb-cancel{background:transparent;border:1px solid var(--rv-line);color:var(--rv-muted);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:13px}
.rtb-cancel:hover{color:var(--rv-text);border-color:var(--rv-text)}
.rtb-status{font-size:12px;color:var(--rv-muted)}
.rtb-status.is-ok{color:#7bd97b}
.rtb-status.is-err{color:#e88}

/* ── Untagged filter chip on tracks sidebar ── */
.rtb-untagged-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;background:var(--rv-input);border:1px solid var(--rv-line);color:var(--rv-text);font-size:12px;cursor:pointer;transition:all .12s;margin-left:6px}
.rtb-untagged-chip:hover{border-color:var(--rv-accent)}
.rtb-untagged-chip.is-active{background:var(--rv-accent);border-color:var(--rv-accent);color:#06222a;font-weight:700}

/* ── Vocab-driven picker dropdown (single-track inline editor) ── */
.rvs-te-vocab{display:flex;flex-wrap:wrap;gap:4px;max-height:120px;overflow:auto;padding:4px;background:var(--rv-input);border:1px solid var(--rv-line);border-radius:8px;margin-top:4px}
.rvs-te-vocab-btn{padding:3px 9px;background:transparent;border:1px solid var(--rv-line);border-radius:999px;color:var(--rv-muted);font-size:11px;cursor:pointer;transition:all .12s}
.rvs-te-vocab-btn:hover{border-color:var(--rv-accent);color:var(--rv-accent)}
.rvs-te-vocab-btn.is-picked{background:var(--rv-accent);border-color:var(--rv-accent);color:#06222a;font-weight:600}
.rvs-te-vocab-btn.is-orphan{font-style:italic;opacity:.7}
.rvs-te-vocab-empty{color:var(--rv-muted);font-style:italic;font-size:11px;padding:4px 8px}
.rvs-te-vocab-link{display:block;margin-top:5px;font-size:11px;color:var(--rv-accent);text-decoration:none}
.rvs-te-vocab-link:hover{text-decoration:underline}
