/*
  Bootleggers-ish minimal theme (Tracker UI)
  Goal: close to game.css feel while keeping our layout.
*/


:root{
  /* Bootleggers-ish palette (dark) */
  --bg:#000;
  --panel:#2f2f2f;
  --panel2:#3b3b3b;
  --panel3:#1a1a1a;
  --line:#6b6b6b;
  --line2:#2f2f2f;
  --text:#fff;
  --muted:#bdbdbd;
  --link:#ffff66;

  --accent:#D22020;         /* BL error red */
  --accent2:#8b0000;
  --ok:#28D220;             /* BL success green */
  --warn:#cbc118;
  --bad:#D22020;

  /* density (compact) */
  --r:4px;
  --r2:6px;
  --shadow:none;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

/* Light theme (stored per user) */
html[data-theme="light"]{
  --bg:#e9e9e9;
  --panel:#f6f6f6;
  --panel2:#ffffff;
  --panel3:#f0f0f0;
  --line:#b6b6b6;
  --line2:#cfcfcf;
  --text:#111;
  --muted:#4b4b4b;
  --link:#0044cc;
}

*{box-sizing:border-box}
html,body{height:100%}
html{font-size:10px}

body{
  margin:0;
  font-family: verdana, Arial, Helvetica, sans-serif;
  background: var(--bg);
  color:var(--text);
  font-size:12px;
}

a{color:var(--link); text-decoration:none}
a:hover{text-decoration:underline}
small, .tiny{color:var(--muted)}
.tiny{font-size:11px}
.mono{font-family:var(--mono)}
.k{font-family:var(--mono); color:#e6e6e6}

/* subtle scrollbars */
*{scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.18) transparent;}
*::-webkit-scrollbar{width:8px;height:8px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:8px}
*::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.28)}

.app{display:flex; min-height:100vh; width:100%}

/* ---------- left sidebar ---------- */
.side{
  width:214px; flex:0 0 214px;
  padding:6px;
  border-right:1px solid var(--line2);
  background: var(--panel3);
  position:sticky; top:0; height:100vh;
}

.brand{
  display:flex; gap:10px; align-items:center;
  padding:6px 8px;
  border:1px solid var(--line2);
  background: var(--panel2);
  border-radius: var(--r2);
}
.mark{
  width:10px; height:10px; border-radius:2px;
  background: var(--accent);
  box-shadow:none;
}
.brandTop{font-weight:700; letter-spacing:.2px; color:#fff}
.brandSub{font-size:11px; color:var(--muted)}

.nav{margin-top:10px; display:flex; flex-direction:column; gap:4px}
.navItem{
  display:flex; align-items:center; gap:8px;
  padding:5px 7px;
  border-radius: var(--r);
  border:1px solid transparent;
  color:var(--muted);
}
.navItem .dot{
  width:6px; height:6px; border-radius:0;
  background: rgba(255,255,255,.25);
}
.navItem:hover{background:var(--panel3); color:var(--text); border-color:var(--line2); text-decoration:none}
.navItem.on{background:rgba(210,32,32,.14); border-color:rgba(210,32,32,.45); color:var(--text)}
.navItem.on .dot{background: var(--accent);}
.navSep{height:1px; background:var(--line2); margin:8px 4px}

.sideFoot{margin-top:auto; padding:10px 4px}
.userBox{padding:6px 8px; border:1px solid var(--line2); border-radius:var(--r); background:var(--panel3)}
.userName{font-weight:700}
.userRole{font-size:11px; color:var(--muted)}
.sideBtns{display:flex; gap:8px; margin-top:8px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:6px 10px;
  border-radius: var(--r);
  background: #223548;
  border:1px solid #3185d4;
  color:#fff; font-weight:700;
}
.btn:hover{filter:brightness(1.05); text-decoration:none}

.btn.ghost{
  background: transparent;
  border:1px solid var(--line);
  color:var(--text);
}
.btn.ghost:hover{border-color:#fff}

.btn.btnMini{
  padding:0 6px;
  height:18px;
  min-width:18px;
  border-radius:3px;
  font-size:11px;
  line-height:18px;
  background: #1b1b1b;
  border:1px solid var(--line2);
  box-shadow:none;
}

/* ---------- topbar ---------- */
.main{flex:1; min-width:0}
.topbar{
  height:34px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 8px;
  border-bottom:1px solid var(--line2);
  background: var(--panel3);
  position:sticky; top:0; z-index:10;
}
.crumb{font-weight:700}
.topbarRight{display:flex; gap:6px; align-items:center}
.iconBtn{
  width:30px; height:30px; border-radius: var(--r);
  background: #1b1b1b;
  border:1px solid var(--line2);
  color:var(--text);
  cursor:pointer;
}
.iconBtn:hover{border-color: var(--line)}
#btnMenu{display:none}

.content{padding:8px; max-width: 1400px; margin:0 auto; width:100%}
.contentInner{transform:none}

/* ---------- cards ---------- */
.card{
  border:1px solid var(--line2);
  background: var(--panel);
  border-radius: var(--r2);
  box-shadow:none;
  overflow:hidden;
}
.cardHead{
  padding:4px 6px;
  border-bottom:1px solid var(--line2);
  display:flex; justify-content:space-between; align-items:flex-end; gap:10px;
  background: linear-gradient(#505050, #3a3a3a);
}
.cardTitle{font-weight:700}
.cardSub{color:var(--muted); font-size:11px}
.cardBody{padding:6px}

.grid2{display:grid; grid-template-columns: 1.2fr .8fr; gap:10px}
.grid2.equal{grid-template-columns: 1fr 1fr;}
.grid3{display:grid; grid-template-columns: 1fr 1fr 1fr; gap:10px}

@media (max-width: 1100px){.grid3{grid-template-columns: 1fr 1fr}}
@media (max-width: 760px){.grid2{grid-template-columns: 1fr}.grid3{grid-template-columns: 1fr}}

/* ---------- tables ---------- */
.table{width:100%; border-collapse: collapse; font-size:12px}
.table th, .table td{padding:4px 5px; border-bottom:1px solid #2a2a2a; vertical-align:top}
.table th{color:var(--muted); text-align:left; font-size:11px; letter-spacing:.2px; text-transform:uppercase; background:#2b2b2b}
.rowLink:hover{background:#262626}

html[data-theme="light"] .table th{background:#ececec}
html[data-theme="light"] .table th, html[data-theme="light"] .table td{border-bottom:1px solid #e0e0e0}
html[data-theme="light"] .rowLink:hover{background:#f0f0f0}

/* ---------- misc helpers ---------- */
.rowFlex{display:flex; align-items:center; gap:10px; flex-wrap:wrap}

.notice{border:1px solid var(--line2); background:rgba(0,0,0,.18); padding:6px 8px; border-radius:var(--r); margin-bottom:8px}
.notice.ok{border-color:rgba(40,210,32,.55)}
.notice.bad{border-color:rgba(210,32,32,.55)}

.avatar{width:42px; height:42px; border-radius:var(--r2); overflow:hidden; border:1px solid var(--line2); background:var(--panel3); display:flex; align-items:center; justify-content:center}
.avatar img{width:100%; height:100%; object-fit:cover; display:block}
.avatarPh{font-weight:700; color:var(--muted)}

.radio{display:inline-flex; align-items:center; gap:6px; padding:3px 6px; border:1px solid var(--line2); border-radius:var(--r); background:rgba(0,0,0,.14)}
html[data-theme="light"] .radio{background:rgba(255,255,255,.65)}

.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:3px 8px; border-radius:999px;
  border:1px solid var(--line2);
  background: rgba(0,0,0,.25);
  font-size:11px;
  color:var(--muted);
}
.badge.red{border-color:rgba(210,32,32,.6); color:#ffb3b3}
.badge.green{border-color:rgba(40,210,32,.55); color:#b6efa4}
.badge.yellow{border-color:rgba(203,193,24,.55); color:#fff6a6}

/* ---------- inputs ---------- */
.input, select, textarea{
  width:100%;
  padding:6px 8px;
  border-radius: var(--r);
  border:1px solid var(--line2);
  background: #111;
  color: var(--text);
  outline:none;
}
.input:focus, select:focus, textarea:focus{border-color: rgba(255,255,255,.35)}
.filters{display:grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap:10px}
.filters .span2{grid-column: span 2}

/* ---------- right feed ---------- */
.feed{
  width:340px; flex:0 0 340px;
  border-left:1px solid var(--line2);
  background:#111;
  position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column;
}
.feedHead{display:flex; justify-content:space-between; align-items:flex-start; padding:10px; border-bottom:1px solid var(--line2); background:#111}
.feedTitle{font-weight:700}
.feedSub{color:var(--muted); font-size:11px}

.feedTabs{padding:8px 10px; display:flex; gap:6px; flex-wrap:wrap; border-bottom:1px solid var(--line2)}
.tab{
  border:1px solid var(--line2);
  background: #1b1b1b;
  color: var(--muted);
  padding:5px 8px;
  border-radius: 999px;
  font-size:11px;
  cursor:pointer;
}
.tab.on{background: rgba(210,32,32,.14); border-color: rgba(210,32,32,.55); color: var(--text)}

.chip{display:inline-flex; align-items:center; gap:8px; padding:5px 8px; border:1px solid var(--line2); border-radius:999px; background:#1b1b1b; font-size:11px; color:var(--muted); user-select:none}
.chip input{accent-color: var(--accent)}

.feedList{padding:8px 10px; overflow:auto}
.feedItem{padding:7px 8px; border:1px solid #2a2a2a; border-radius: var(--r2); background: #1b1b1b; margin-bottom:8px}
.feedItemTop{display:flex; justify-content:space-between; gap:10px; align-items:center}
.feedType{font-size:10px; letter-spacing:.2px; text-transform:uppercase; color:var(--muted)}
.feedTime{font-size:11px; color:var(--muted); font-family:var(--mono)}
.feedMsg{margin-top:5px; line-height:1.25; color:#fff}
.feedMeta{margin-top:5px; display:flex; gap:6px; flex-wrap:wrap}
.feedEmpty{color:var(--muted); padding:14px 6px}

/* Key/Value list (player profile) */
.kv{border:1px solid var(--line2); border-radius:var(--r2); overflow:hidden}
.kvRow{display:flex; gap:12px; padding:6px 8px; border-bottom:1px solid #2a2a2a; align-items:center; background:#1f1f1f}
.kvRow:nth-child(even){background:#1a1a1a}
.kvRow:last-child{border-bottom:none}
.kvKey{width:160px; max-width:45%; color:var(--muted); font-size:11px; text-transform:uppercase; letter-spacing:.2px}
.kvVal{flex:1; min-width:0}
.kv select{width:100%; padding:6px 8px; border-radius:var(--r); border:1px solid var(--line2); background:#111; color:var(--text)}
.kv textarea.input{width:100%; resize:vertical}

.hero{padding:12px; background: #111; border:1px solid var(--line2); border-radius: var(--r2)}
.heroTitle{font-size:22px; font-weight:800}
.heroSub{color:var(--muted); margin-top:6px; max-width: 60ch}
.heroBtns{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px}

/* ---------- responsive ---------- */
@media (max-width: 1040px){
  .feed{display:none; position:fixed; right:0; top:0; z-index:25}
  .feed.open{display:flex; width:min(92vw, 420px)}
  #btnFeed{display:inline-flex}
  #btnFeedClose{display:none}
}
@media (max-width: 900px){
  .side{display:none; position:fixed; left:0; top:0; z-index:25; width:min(84vw, 320px)}
  .side.open{display:block}
  #btnMenu{display:inline-flex}
  .content{padding:10px}
  .grid2{grid-template-columns: 1fr}
  .filters{grid-template-columns: 1fr 1fr}
  .filters .span2{grid-column: span 2}
}
@media (max-width: 520px){
  .filters{grid-template-columns: 1fr}
  .filters .span2{grid-column: span 1}
  .heroTitle{font-size:18px}
}

/* ---------- enemies compact watchlist ---------- */
.watchCompact{display:flex; flex-direction:column; gap:6px}
.watchItem{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:6px 8px; border:1px solid #2a2a2a; border-radius: var(--r2); background:#1b1b1b}
.watchLeft{min-width:0; display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.watchRight{display:flex; align-items:center; gap:6px; flex-wrap:wrap; justify-content:flex-end}
.watchBtns{display:flex; gap:6px}
.btnSm{display:inline-flex; align-items:center; justify-content:center; height:26px; padding:0 8px; border-radius: var(--r); border:1px solid var(--line2); background:#111; color: var(--text); text-decoration:none; font-size:11px}
.btnSm:hover{border-color: rgba(255,255,255,.35); text-decoration:none}
.ugLost{border-color: rgba(203,193,24,.85) !important}

/* ---------- pills ---------- */
.pillBar{display:flex; gap:6px; flex-wrap:wrap}
.pill{border:1px solid var(--line2); background:#1b1b1b; color: var(--muted); padding:5px 8px; border-radius:999px; cursor:pointer; font-size:11px}
.pill:hover{border-color: rgba(255,255,255,.35); color: var(--text)}
.pill.active{background: rgba(210,32,32,.14); border-color: rgba(210,32,32,.55); color: var(--text)}

/* ---------- history ---------- */
.histDay{position:sticky; top:0; z-index:2; padding:8px 8px 6px 8px; font-size:11px; color: var(--muted); background:#111; border-bottom:1px solid #2a2a2a}
.histItem{padding:8px 8px; border-bottom:1px solid #2a2a2a; border-left:3px solid rgba(255,255,255,.14)}
.histItem.life{border-left-color: rgba(40,210,32,.55)}
.histItem.ug{border-left-color: rgba(203,193,24,.55)}
.histItem.org{border-left-color: rgba(210,32,32,.55)}
.histItem.intel{border-left-color: rgba(255,255,255,.22)}
@media (max-width: 820px){#histSearch{width:100% !important; max-width:100% !important}}

/* scroll lists */
.scrollList{display:flex; flex-direction:column; gap:6px; max-height: 360px; overflow:auto; padding-right:4px}
.listRow{display:flex; justify-content:space-between; gap:8px; border-bottom:1px solid #2a2a2a; padding:3px 0}
.listLeft{min-width:0}


/* Relation colored edit button */
.btnEditMini[data-rel="enemy"]{border-color:rgba(255,60,60,.85); box-shadow:0 0 10px rgba(255,60,60,.22)}
.btnEditMini[data-rel="suspect"]{border-color:rgba(255,210,60,.85); box-shadow:0 0 10px rgba(255,210,60,.18)}
.btnEditMini[data-rel="friend"]{border-color:rgba(60,220,120,.85); box-shadow:0 0 10px rgba(60,220,120,.18)}
.btnEditMini[data-rel="crew"]{border-color:rgba(100,190,255,.85); box-shadow:0 0 10px rgba(100,190,255,.18)}
.btnEditMini[data-rel="neutral"]{border-color:rgba(170,170,170,.6)}
/* Mini edit button */
.btnEditMini{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;background:#111;border:1px solid var(--line2);color:#fff;padding:0;border-radius:3px;font-size:12px;line-height:1}
.btnEditMini:hover{border-color: rgba(255,255,255,.35)}

/* watch rows */
.watchRow{display:grid;grid-template-columns:minmax(120px, 1fr) 70px 150px 60px;align-items:center;gap:4px;padding:2px 0;border-bottom:1px solid #2a2a2a}
.watchRow > *{min-width:0}
.watchRow:last-child{border-bottom:0}
.watchRow .wRank,.watchRow .wProf{justify-self:end}
.watchRow .wUG{justify-self:end}
.ugBadge{display:inline-flex;align-items:center;justify-content:space-between;gap:6px;min-width:150px}
.ugBadge .ugTick,.ugBadge .ugLostTick{min-width:112px}
.ugBadge .ugTick,.ugBadge .ugLostTick{display:inline-block;font-variant-numeric: tabular-nums;font-feature-settings: "tnum";min-width:110px;text-align:right}
@media (max-width: 820px){
  .watchRow{grid-template-columns: 1fr;align-items:flex-start;gap:6px}
  .watchRow .wProf{opacity:.9}
}

/* iframe profile modal */
.pModal{position:fixed;inset:0;background: rgba(0,0,0,.75);display:none;align-items:center;justify-content:center;z-index: 9999;padding: 12px}
.pModal.on{display:flex}
.pModalBox{width:min(1400px, 98vw);height:min(900px, 94vh);border-radius:var(--r2);border:1px solid var(--line2);background:var(--panel);overflow:hidden;position:relative}
.pModalTop{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-bottom:1px solid var(--line2);background:#111}
.pModalTitle{font-weight:700}
.pModalClose{width:30px;height:30px;border-radius: var(--r);border:1px solid var(--line2);background:#1b1b1b;color:#fff;cursor:pointer}
.pModalClose:hover{border-color: rgba(255,255,255,.35)}
.pModalFrame{width:100%;height:100%;border:0;background:transparent}


/* ---------- crew (bootleggers-ish structure boxes) ---------- */
.card.flat{box-shadow:none}
.crewHeadRight{display:flex; align-items:center; gap:10px}

.blCrewStruct{display:flex; flex-direction:column; gap:10px}

.blCrewLayer{
  border:1px solid var(--line2);
  background: rgba(255,255,255,.03);
  border-radius: var(--r);
  overflow:hidden;
}

.blCrewLayerHead{
  position:relative;
  padding:8px 10px;
  text-align:center;
  background: rgba(0,0,0,.25);
  border-bottom:1px solid var(--line2);
}

.blCrewLayerTitle{font-weight:700; letter-spacing:.2px}
.blCrewMeta{margin-top:2px; font-size:11px; color:var(--muted)}

.blCrewStatus{margin-top:4px; font-weight:700; font-size:11px; letter-spacing:.3px}
.blCrewStatus.ok{color:var(--ok)}
.blCrewStatus.bad{color:var(--bad)}
.blCrewStatus.none{color:var(--muted)}

.blCrewCount{
  position:absolute;
  top:8px;
  right:8px;
  min-width:22px;
  height:18px;
  padding:0 6px;
  border:1px solid var(--line);
  border-radius: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  color:var(--text);
  background: rgba(0,0,0,.25);
}

.blCrewLayerBox{padding:8px}

.blCrewPills{display:flex; flex-wrap:wrap; gap:6px; justify-content:center}

.blMemberPill{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:1px;
  padding:4px 8px;
  min-width:76px;
  border:1px solid var(--line2);
  border-radius: 4px;
  background: rgba(0,0,0,.35);
  color: var(--link);
  text-decoration:none;
}
.blMemberPill:hover{filter:brightness(1.06); text-decoration:none}

.blMemberPill .nm{font-weight:700; color:#cfe5ff}
.blMemberPill .sub{font-size:10px; color:var(--muted)}
.blMemberPill.dead{border-color: rgba(210,32,32,.55)}
.blMemberPill.dead .nm{color:#ffd0d0}
.blMemberPill.dead .sub{color: var(--bad); font-weight:700}

.blHistRow{padding:8px 0; border-bottom:1px solid rgba(255,255,255,.08)}
.blHistTop{display:flex; justify-content:space-between; gap:10px}


/* Overall: better mobile layout for watch rows */
@media (max-width: 560px){
  .watchRow{
    grid-template-columns:minmax(120px,1fr) auto;
    grid-template-areas:
      "name ug"
      "rank prof";
    row-gap:2px;
  }
  .watchRow .wName{grid-area:name}
  .watchRow .wUG{grid-area:ug; justify-self:end}
  .watchRow .wRank{grid-area:rank; justify-self:start}
  .watchRow .wProf{grid-area:prof; justify-self:end}
}

/* New signups: highlight rows missing rank */
#modSignups .listRow.needsRank{box-shadow:0 0 12px rgba(255,60,60,.25); border-radius:6px}


/* Admin player payloads modal */
.modal{position:fixed; inset:0; background:rgba(0,0,0,.55); display:flex; align-items:flex-start; justify-content:center; padding:24px; z-index:9999}
.modalInner{width:100%; background:var(--surface); border:1px solid var(--border); border-radius:12px; box-shadow:0 18px 60px rgba(0,0,0,.45); overflow:hidden}
.modalHead{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 14px 10px 14px; border-bottom:1px solid var(--border)}
.pre{background:var(--surface2); border:1px solid var(--border); border-radius:10px; padding:12px; white-space:pre-wrap; word-break:break-word; font-size:12px; line-height:1.35}
.btn.small{padding:6px 10px; font-size:12px}
@media (max-width: 560px){
  .modal{padding:12px}
}


/* Admin playerdata cards */
.cardGrid{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:14px; padding:14px}
@media (max-width: 1200px){ .cardGrid{grid-template-columns:repeat(2, minmax(0,1fr));} }
@media (max-width: 720px){ .cardGrid{grid-template-columns:1fr;} }

.pCard{background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:14px; box-shadow:0 6px 18px rgba(0,0,0,.20)}
.pTop{display:flex; align-items:flex-start; justify-content:space-between; gap:10px; margin-bottom:10px}
.pUser{font-size:18px; font-weight:800; letter-spacing:.2px}
.pSeen{font-size:12px; color:var(--muted); white-space:nowrap}
.pBadges{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:10px}
.pRow{display:flex; flex-wrap:wrap; gap:8px; margin:8px 0}
.pDivider{height:1px; background:var(--border); margin:10px 0}
.pSectionTitle{font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.12em; margin-bottom:6px}

.pill{display:inline-flex; align-items:center; gap:8px; padding:8px 10px; border-radius:12px; border:1px solid var(--border); background:var(--surface2); font-size:13px}
.pill b{font-size:12px; color:var(--muted); font-weight:700; letter-spacing:.06em}
.pill.money{background:rgba(255,255,255,.03)}
.pill.stat{background:rgba(255,255,255,.04)}
.pill.wpn{background:rgba(255,255,255,.02)}


/* ---------- modal: profile iframe (light, wide, no header) ---------- */
.pModalCloseFloat{
  position:absolute; top:10px; left:10px; z-index:5;
  width:34px; height:34px; border-radius: 12px;
  border:1px solid var(--line2); background: rgba(255,255,255,.85);
  color: var(--text); cursor:pointer; backdrop-filter: blur(6px);
}
html[data-theme="dark"] .pModalCloseFloat{background: rgba(0,0,0,.5); color:#fff}
.pModalCloseFloat:hover{border-color: var(--line);}

/* ---------- Online30 widget ---------- */
.online30{display:block}
.online30 .olHead{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.online30 .olTitle{font-weight:800}
.online30 .olMeta{margin-top:6px;color:var(--muted);font-size:12px}
.online30 .olBars{display:flex;align-items:flex-end;gap:4px;margin-top:10px;padding:10px;border:1px solid var(--line2);border-radius:16px;background:var(--panel2);overflow-x:auto}
.online30 .olBar{min-width:10px;flex:0 0 10px;border-radius:8px;background: rgba(0,0,0,.12);cursor:pointer}
.online30 .olBar.on{background: rgba(0,0,0,.35)}
.online30 .olBar:hover{outline:2px solid rgba(0,0,0,.10)}
.online30 .olDetail{margin-top:10px;border-top:1px dashed var(--line2);padding-top:10px}
.online30 .olDetailTitle{font-weight:700;margin-bottom:6px}
.online30 .olDetailBody{color:var(--muted);font-size:12px}
.online30 .btn.small{padding:6px 10px;border-radius:12px}

/* ---------- Timeline tighter items ---------- */
.timeline{margin-top:10px}
.tItem{display:grid;grid-template-columns:16px 1fr;gap:10px;padding:8px 0}
.tDot{width:10px;height:10px;border-radius:50%;margin-top:3px;border:2px solid rgba(0,0,0,.18);background:var(--panel)}
.tLine{position:absolute;left:5px;top:0;bottom:0;width:2px;background:rgba(0,0,0,.06)}

.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--line2);background:var(--panel2);font-size:12px;font-weight:700;color:var(--text)}
.pill.ug.on{border-color: rgba(46, 210, 32, .35); background: rgba(46,210,32,.08)}
.pill.ug.warn{border-color: rgba(210, 32, 32, .35); background: rgba(210,32,32,.08)}


/* ---------- stamps parser ---------- */
.stampHero .cardHead{align-items:center; gap:12px; flex-wrap:wrap}
.stampHeroActions{display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.stampParserGrid{display:grid; grid-template-columns:minmax(0,1.55fr) minmax(320px,.95fr); gap:12px; align-items:start; margin-top:12px}
.stampInputCard .cardBody{padding:0}
.stampLargeTextarea{
  min-height:540px;
  resize:vertical;
  border:0;
  border-radius:0 0 var(--r2) var(--r2);
  background:var(--panel3);
  font-family:var(--mono);
  line-height:1.5;
  padding:12px;
}
.stampSummaryRail{position:sticky; top:44px}
.stampSummaryCard .cardBody{display:flex; flex-direction:column; gap:12px}
.stampStatGrid{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.stampStatBox{
  border:1px solid var(--line2);
  background:rgba(0,0,0,.18);
  border-radius:var(--r2);
  padding:12px;
  min-height:76px;
}
.stampStatBox.highlight{border-color:rgba(49,133,212,.55); background:rgba(49,133,212,.12)}
.stampStatBox.nickel{border-color:rgba(203,193,24,.45); background:rgba(203,193,24,.08)}
.stampStatLabel{font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.25px}
.stampStatValue{margin-top:6px; font-size:28px; font-weight:700; line-height:1.1}
.stampMiniGrid{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.stampMiniItem{
  display:flex; justify-content:space-between; align-items:center;
  padding:9px 10px; border-radius:var(--r); border:1px solid var(--line2); background:rgba(0,0,0,.12);
}
.stampMiniItem.warn{border-color:rgba(203,193,24,.45)}
.stampMiniLabel{color:var(--muted)}
.stampInfoNote{padding:10px 12px; border-radius:var(--r); border:1px solid var(--line2); background:rgba(0,0,0,.12); color:var(--text)}
.stampInfoNote.ok{border-color:rgba(40,210,32,.5); background:rgba(40,210,32,.1)}
.stampInfoNote.warn{border-color:rgba(203,193,24,.45); background:rgba(203,193,24,.08)}
.stampInfoNote.bad{border-color:rgba(210,32,32,.55); background:rgba(210,32,32,.08)}
.stampMissingBox{padding:10px 12px; border-radius:var(--r); border:1px solid rgba(210,32,32,.35); background:rgba(210,32,32,.06)}
.stampMissingTitle{font-weight:700; margin-bottom:8px}
.stampMissingBox ul{margin:0; padding-left:18px; display:flex; flex-direction:column; gap:6px}
.stampMissingBox li{padding-right:4px}
.stampMissingBox li span{display:block; color:var(--muted); margin-top:2px}
.stampAdminCard{margin-top:12px}
.stampSearchInput{min-width:220px}
.stampDefsWrap{max-height:560px; overflow:auto}
.stampDefsTable .input{min-width:110px}

html[data-theme="light"] .stampLargeTextarea{background:#fff}
html[data-theme="light"] .stampStatBox,
html[data-theme="light"] .stampMiniItem,
html[data-theme="light"] .stampInfoNote{background:rgba(255,255,255,.75)}

@media (max-width: 980px){
  .stampParserGrid{grid-template-columns:1fr}
  .stampSummaryRail{position:static}
  .stampLargeTextarea{min-height:360px}
}
@media (max-width: 640px){
  .stampStatGrid,.stampMiniGrid{grid-template-columns:1fr}
  .stampHero .cardHead{align-items:flex-start}
  .stampSearchInput{min-width:0; width:100%}
}
