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

:root {
  --c1: #080808; --c2: #101010; --c3: #171717; --c4: #1f1f1f;
  --acc: #ff5a1f; --acc2: #ff7a3d; --acc3: #ffb38d;
  --grn: #3bd28a; --amb: #ffb648; --red: #ff5d5d;
  --txt: #f6efe9; --txt2: #b79f92;
  --bdr: rgba(255,90,31,0.18);
  --bdr-strong: rgba(255,122,61,0.34);
  --shadow: 0 24px 60px rgba(0, 0, 0, 0.45);
}

html, body { height: 100%; background: var(--c1); color: var(--txt); font-family: 'Avenir Next', 'Segoe UI', sans-serif; }
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(255, 90, 31, 0.18), transparent 26%),
    radial-gradient(circle at top right, rgba(255, 163, 111, 0.08), transparent 18%),
    linear-gradient(180deg, #0a0a0a 0%, #080808 100%);
}
.login-page {
  justify-content: center;
}
.login-shell {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.login-card {
  width: min(460px, 100%);
}
.login-title {
  font-size: 28px;
  color: var(--txt);
  margin: 10px 0 8px;
}
.login-copy {
  margin-bottom: 20px;
}
.login-submit {
  width: 100%;
  justify-content: center;
  display: inline-flex;
}

/* ── Topbar ── */
.topbar {
  background: linear-gradient(180deg, rgba(20,20,20,0.98) 0%, rgba(14,14,14,0.95) 100%);
  border-bottom: 1px solid var(--bdr);
  padding: 16px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 30;
  backdrop-filter: blur(14px);
}
.brand-shell { display: flex; align-items: center; gap: 18px; min-width: 0; flex: 1 1 auto; }
.logo {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  min-width: 0;
  padding: 8px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,90,31,.14);
  background: linear-gradient(180deg, rgba(18,18,18,.92) 0%, rgba(10,10,10,.92) 100%);
}
.brand-logo {
  width: auto;
  height: clamp(42px, 5.5vw, 72px);
  max-width: min(340px, 28vw);
  display: block;
  object-fit: contain;
  object-position: left center;
  filter: drop-shadow(0 10px 18px rgba(255, 90, 31, 0.12));
}
.status-row { display: flex; align-items: center; gap: 14px; }
.btn-nav-shortcut {
  height: 34px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,122,61,.18) 0%, rgba(255,90,31,.12) 100%);
  border: 1px solid rgba(255,90,31,.34);
  color: var(--acc3);
  font-size: 10px;
  letter-spacing: .08em;
  padding: 0 14px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s, transform .2s;
}
.btn-nav-shortcut:hover { background: linear-gradient(180deg, rgba(255,122,61,.28) 0%, rgba(255,90,31,.18) 100%); transform: translateY(-1px); }
.pill {
  display: flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 6px 13px;
  font-size: 11px;
  background: rgba(255,255,255,0.02);
}
.alert-pill-btn {
  font-family: inherit;
  cursor: pointer;
  transition: transform .2s, background .2s, border-color .2s;
}
.alert-pill-btn:hover,
.alert-pill-btn.active {
  transform: translateY(-1px);
  border-color: rgba(255,182,72,.34);
  background: rgba(255,182,72,0.16);
}
.pill-grn { background: rgba(0,229,160,0.08); border: 1px solid rgba(0,229,160,0.25); color: var(--grn); }
.pill-amb { background: rgba(255,182,72,0.1); border: 1px solid rgba(255,182,72,0.22); color: var(--amb); }
.dot { width: 6px; height: 6px; border-radius: 50%; animation: pulse 2s infinite; }
.dot-grn { background: var(--grn); }
.dot-amb { background: var(--amb); }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }
.alert-menu {
  position: fixed;
  top: 78px;
  right: 24px;
  width: min(420px, calc(100vw - 32px));
  max-height: min(70vh, 640px);
  overflow: auto;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,182,72,.22);
  background: linear-gradient(180deg, rgba(20,20,20,.98) 0%, rgba(12,12,12,.98) 100%);
  box-shadow: var(--shadow);
  z-index: 140;
}
.alert-menu-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}
.alert-menu-title {
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--txt);
  font-weight: 700;
}
.alert-menu-subtitle {
  font-size: 11px;
  color: var(--txt2);
  margin-top: 5px;
}
.alert-item {
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(24,24,24,.98) 0%, rgba(16,16,16,.98) 100%);
  margin-bottom: 10px;
}
.alert-item:last-child { margin-bottom: 0; }
.alert-item.critical {
  border-color: rgba(255,93,93,.26);
  background: linear-gradient(180deg, rgba(42,18,18,.88) 0%, rgba(22,12,12,.96) 100%);
}
.alert-item.warning {
  border-color: rgba(255,182,72,.24);
  background: linear-gradient(180deg, rgba(40,28,14,.88) 0%, rgba(22,16,10,.96) 100%);
}
.alert-item-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.alert-item-title {
  font-size: 13px;
  color: var(--txt);
  font-weight: 700;
}
.alert-item-meta {
  font-size: 11px;
  color: var(--txt2);
  margin-top: 3px;
}
.alert-item-text {
  font-size: 11px;
  line-height: 1.5;
  color: var(--txt2);
}
.alert-item-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

/* ── Nav ── */
.nav {
  display: flex;
  gap: 8px;
  background: rgba(10,10,10,0.88);
  border-bottom: 1px solid rgba(255,255,255,0.04);
  padding: 10px 24px 0;
  overflow-x: auto;
  scrollbar-width: none;
  flex-shrink: 0;
}
.nav::-webkit-scrollbar { display: none; }
.tab {
  padding: 13px 17px;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--txt2);
  cursor: pointer;
  border: 1px solid transparent;
  border-radius: 14px 14px 0 0;
  white-space: nowrap;
  transition: all .2s;
}
.tab.active {
  color: var(--txt);
  border-color: var(--bdr);
  border-bottom-color: rgba(255,255,255,0.02);
  background: linear-gradient(180deg, rgba(255, 90, 31, 0.16) 0%, rgba(255, 90, 31, 0.04) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.tab:hover:not(.active) { color: var(--txt); }

/* ── Layout ── */
.main { flex: 1; overflow-y: auto; }
.content { display: none; padding: 22px 24px; }
.content.active { display: block; }
.app-footer {
  display: flex;
  justify-content: flex-end;
  padding: 0 24px 18px;
  flex-shrink: 0;
}
.app-version-shell {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 90, 31, 0.18);
  background: rgba(12, 12, 12, 0.86);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.28);
}
.app-version-label {
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--txt2);
}
.app-version-value {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  color: var(--acc3);
}
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 16px; }
@media(max-width:1100px) {
  .topbar { flex-direction: column; align-items: stretch; }
  .brand-shell, .status-row { justify-content: space-between; }
}
@media(max-width:900px) {
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:1fr 1fr;}
  .brand-shell { flex-direction: column; align-items: stretch; }
  .logo { width: fit-content; max-width: 100%; }
  .brand-logo { max-width: min(280px, 60vw); height: clamp(40px, 7vw, 62px); }
}
@media(max-width:600px) {
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .topbar, .nav, .content { padding-left: 16px; padding-right: 16px; }
  .status-row { flex-wrap: wrap; }
  .alert-menu { top: 132px; right: 16px; width: calc(100vw - 32px); }
  .org-btn { min-width: 100%; }
  .logo { padding: 8px 12px; }
  .brand-logo { max-width: min(240px, 62vw); height: clamp(34px, 9vw, 52px); }
  .device-detail-grid { grid-template-columns: 1fr; }
  .fleet-map { height: 240px; }
  .map-legend { left: 10px; right: 10px; top: auto; bottom: 10px; justify-content: center; flex-wrap: wrap; border-radius: 12px; }
  .app-footer { padding-left: 16px; padding-right: 16px; justify-content: center; }
}

/* ── Cards ── */
.card {
  background: linear-gradient(180deg, rgba(28,28,28,0.96) 0%, rgba(20,20,20,0.96) 100%);
  border: 1px solid var(--bdr);
  border-radius: 18px;
  padding: 16px;
  box-shadow: var(--shadow);
}
.card-title { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt2); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.card-title::before { content: ''; display: block; width: 4px; height: 13px; background: linear-gradient(180deg, var(--acc2), var(--acc)); border-radius: 999px; }
.metric-big { font-size: 30px; font-weight: 700; color: var(--txt); }
.metric-label { font-size: 11px; color: var(--txt2); margin-top: 3px; }
.metric-delta { font-size: 11px; color: var(--grn); margin-top: 3px; }
.progress-bar { height: 4px; background: rgba(255,255,255,.07); border-radius: 2px; margin-top: 10px; }
.progress-fill { height: 100%; border-radius: 2px; }

/* ── Badges ── */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 9px; border-radius: 10px; font-size: 10px; letter-spacing: .04em; }
.badge-grn { background: rgba(0,229,160,.1); color: var(--grn); border: 1px solid rgba(0,229,160,.2); }
.badge-red { background: rgba(239,68,68,.1); color: var(--red); border: 1px solid rgba(239,68,68,.2); }
.badge-amb { background: rgba(245,158,11,.1); color: var(--amb); border: 1px solid rgba(245,158,11,.2); }
.badge-blue { background: rgba(255,90,31,.1); color: var(--acc2); border: 1px solid rgba(255,90,31,.2); }

/* ── Group cards ── */
#group-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.group-card { background: linear-gradient(180deg, #171717 0%, #111111 100%); border: 1px solid var(--bdr); border-radius: 14px; padding: 14px; text-align: left; color: inherit; cursor: pointer; transition: border-color .2s, transform .2s, background .2s; }
.group-card:hover { border-color: var(--bdr-strong); transform: translateY(-1px); }
.group-card.selected { background: rgba(255,90,31,.08); border-color: rgba(255,90,31,.34); }
.group-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.group-card-name { font-size: 14px; color: var(--txt); font-weight: 700; }
.group-card-meta { font-size: 11px; color: var(--txt2); margin-top: 4px; }
.group-card-stats { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 12px; font-size: 11px; color: var(--acc3); }
.view-toggle { display: inline-flex; padding: 3px; border-radius: 999px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); gap: 4px; }
.view-toggle-btn { border: none; background: transparent; color: var(--txt2); padding: 7px 13px; border-radius: 999px; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; cursor: pointer; font-family: inherit; }
.view-toggle-btn.active { background: rgba(255,90,31,.16); color: var(--acc3); }

/* ── Device rows ── */
.device-row-shell { border-bottom: 1px solid rgba(255,255,255,.04); }
.device-row-shell:last-child { border-bottom: none; }
.device-row { width: 100%; display: flex; align-items: center; gap: 12px; padding: 12px 0; border: none; background: transparent; color: inherit; text-align: left; cursor: pointer; }
.device-row:hover { background: rgba(255,90,31,.04); }
.device-row.selected { background: rgba(255,90,31,.08); border-radius: 12px; padding-left: 10px; padding-right: 10px; margin-left: -10px; width: calc(100% + 20px); }
.device-icon { width: 36px; height: 36px; background: linear-gradient(180deg, #1c1c1c 0%, #111111 100%); border: 1px solid var(--bdr); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.device-name-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.device-name { font-size: 13px; color: var(--txt); font-weight: 600; }
.device-loc  { font-size: 11px; color: var(--txt2); }
.device-row-side { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.device-row-link { font-size: 10px; color: var(--acc3); text-transform: uppercase; letter-spacing: .08em; }
.device-row-link-btn { border: 1px solid rgba(255,90,31,.22); background: rgba(255,90,31,.08); color: var(--acc3); border-radius: 999px; font-size: 10px; letter-spacing: .08em; text-transform: uppercase; padding: 5px 9px; cursor: pointer; font-family: inherit; }
.device-row-link-btn:hover { background: rgba(255,90,31,.16); }
.device-location-menu { margin: 8px 0 12px 48px; padding: 12px; border: 1px solid rgba(255,90,31,.18); border-radius: 14px; background: linear-gradient(180deg, rgba(22,22,22,.98) 0%, rgba(14,14,14,.98) 100%); }
.device-location-menu-header { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.device-location-menu-title { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--txt); font-weight: 700; }
.device-location-menu-meta { font-size: 10px; color: var(--txt2); }
.device-location-methods { display: flex; flex-wrap: wrap; gap: 8px; }
.device-location-chip { border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.03); color: var(--txt2); border-radius: 999px; padding: 6px 10px; font-size: 10px; cursor: pointer; font-family: inherit; }
.device-location-chip.active { border-color: rgba(255,90,31,.34); color: var(--acc3); background: rgba(255,90,31,.12); }
.device-location-note { margin-top: 10px; font-size: 11px; line-height: 1.45; color: var(--txt2); }
.device-location-empty { font-size: 11px; color: var(--txt2); text-align: center; padding: 6px 0; }
.device-detail-panel { margin-top: 16px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.06); }
.device-detail-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.device-detail-eyebrow { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txt2); }
.device-detail-title-row { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:4px; }
.device-detail-title { font-size: 18px; font-weight: 700; color: var(--txt); margin-top: 4px; }
.device-detail-sub { font-size: 12px; color: var(--txt2); margin-top: 4px; }
.device-detail-grid { display: grid; grid-template-columns: minmax(0,1.3fr) minmax(220px,.9fr); gap: 14px; }
.device-detail-meta { background: linear-gradient(180deg, rgba(24,24,24,0.96) 0%, rgba(18,18,18,0.96) 100%); border: 1px solid var(--bdr); border-radius: 14px; padding: 14px; }
.agent-pill { display:inline-flex; align-items:center; gap:5px; border-radius:999px; padding:2px 8px; font-size:10px; letter-spacing:.04em; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.03); }
.agent-pill.grn { color:var(--grn); border-color:rgba(59,210,138,.28); background:rgba(59,210,138,.08); }
.agent-pill.red { color:var(--red); border-color:rgba(255,93,93,.28); background:rgba(255,93,93,.08); }
.agent-pill.amb { color:var(--amb); border-color:rgba(255,182,72,.28); background:rgba(255,182,72,.08); }
.agent-pill.muted { color:var(--txt2); border-color:rgba(255,255,255,.08); background:rgba(255,255,255,.03); }

/* ── Signal bars ── */
.signal-bars { display: flex; align-items: flex-end; gap: 2px; }
.bar { width: 4px; background: rgba(255,255,255,.12); border-radius: 1px; }
.bar.on { background: var(--grn); }
.bar:nth-child(1){height:5px} .bar:nth-child(2){height:8px} .bar:nth-child(3){height:11px} .bar:nth-child(4){height:14px} .bar:nth-child(5){height:17px}

/* ── Stat rows ── */
.stat-row { display: flex; justify-content: space-between; font-size: 11px; margin-bottom: 5px; }
.stat-k { color: var(--txt2); }
.stat-v { color: var(--txt); font-weight: 600; }
.stat-v.grn{color:var(--grn)} .stat-v.amb{color:var(--amb)} .stat-v.red{color:var(--red)} .stat-v.muted{color:var(--txt2)}

/* ── SIM block ── */
.sim-block { background: linear-gradient(180deg, rgba(24,24,24,0.96) 0%, rgba(18,18,18,0.96) 100%); border: 1px solid var(--bdr); border-radius: 14px; padding: 12px; margin-bottom: 8px; }
.sim-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 9px; }
.sim-id { font-size: 12px; color: var(--acc); font-weight: 700; letter-spacing: .07em; }

/* ── Tower rows ── */
.tower-row { display: flex; align-items: center; gap: 10px; padding: 9px 10px; background: linear-gradient(180deg, #171717 0%, #131313 100%); border: 1px solid var(--bdr); border-radius: 12px; margin-bottom: 7px; cursor: pointer; transition: border-color .2s, transform .2s; }
.tower-row:hover { border-color: var(--bdr-strong); transform: translateY(-1px); }
.tower-row.selected { border-color: var(--acc); background: rgba(255,90,31,.07); }
.tower-id { font-size: 11px; color: var(--acc); font-weight: 700; min-width: 82px; }
.tower-carrier { font-size: 11px; color: var(--txt); min-width: 72px; }
.freq-badge { font-size: 10px; background: rgba(255,90,31,.14); color: var(--acc3); border: 1px solid rgba(255,90,31,.3); padding: 2px 7px; border-radius: 999px; }
.rsrp-bar { flex: 1; height: 4px; background: rgba(255,255,255,.08); border-radius: 2px; }
.rsrp-fill { height: 100%; border-radius: 2px; background: var(--grn); }

/* ── Port slots ── */
.port-card { background: linear-gradient(180deg, #171717 0%, #111111 100%); border: 1px solid var(--bdr); border-radius: 14px; padding: 12px; margin-bottom: 10px; }
.port-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.port-name { font-size: 12px; color: var(--txt); font-weight: 700; }
.port-type { font-size: 10px; color: var(--txt2); }
.port-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; }
.port-slot { height: 32px; background: var(--c4); border: 1px solid var(--bdr); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 10px; color: var(--txt2); cursor: pointer; transition: all .2s; }
.port-slot.active { background: rgba(0,229,160,.08); border-color: rgba(0,229,160,.3); color: var(--grn); }
.port-slot.wan    { background: rgba(255,90,31,.1); border-color: rgba(255,90,31,.3); color: var(--acc); }

/* ── Orch rules ── */
.orch-rule { background: linear-gradient(180deg, #171717 0%, #111111 100%); border: 1px solid var(--bdr); border-radius: 14px; padding: 12px 14px; margin-bottom: 8px; display: flex; align-items: center; gap: 14px; }
.orch-num { width: 24px; height: 24px; border-radius: 50%; background: rgba(255,90,31,.15); border: 1px solid rgba(255,90,31,.3); display: flex; align-items: center; justify-content: center; font-size: 11px; color: var(--acc); font-weight: 700; flex-shrink: 0; }
.orch-label { font-size: 12px; color: var(--txt); flex: 1; }
.orch-label small { display: block; color: var(--txt2); font-size: 10px; margin-top: 2px; }
.toggle { width: 38px; height: 22px; border-radius: 11px; position: relative; cursor: pointer; transition: background .25s; flex-shrink: 0; }
.toggle.on  { background: var(--grn); }
.toggle.off { background: rgba(255,255,255,.15); }
.toggle::after { content: ''; position: absolute; width: 16px; height: 16px; background: white; border-radius: 50%; top: 3px; transition: left .25s; }
.toggle.on::after  { left: calc(100% - 19px); }
.toggle.off::after { left: 3px; }

/* ── Rental cards ── */
.rental-card { background: linear-gradient(180deg, #171717 0%, #111111 100%); border: 1px solid var(--bdr); border-radius: 16px; padding: 14px; margin-bottom: 11px; }
.rental-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 10px; }
.rental-name  { font-size: 13px; color: var(--txt); font-weight: 700; }
.rental-dates { font-size: 11px; color: var(--txt2); margin-top: 2px; }
.rental-details { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-top: 10px; border-top: 1px solid rgba(255,255,255,.05); padding-top: 10px; }
.rd-label { font-size: 10px; color: var(--txt2); }
.rd-val   { font-size: 12px; color: var(--txt); font-weight: 600; margin-top: 2px; }

/* ── Template tag ── */
.template-tag { display: inline-block; background: rgba(255,90,31,.12); border: 1px solid rgba(255,90,31,.24); color: var(--acc3); font-size: 10px; padding: 2px 8px; border-radius: 999px; margin: 2px; }

/* ── Section header ── */
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.section-title { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt2); }
.btn-sm { background: linear-gradient(180deg, rgba(255,122,61,.18) 0%, rgba(255,90,31,.12) 100%); border: 1px solid rgba(255,90,31,.34); color: var(--acc3); font-size: 10px; letter-spacing: .06em; padding: 6px 13px; border-radius: 999px; cursor: pointer; text-transform: uppercase; transition: background .2s, transform .2s; }
.btn-sm:hover { background: linear-gradient(180deg, rgba(255,122,61,.28) 0%, rgba(255,90,31,.18) 100%); transform: translateY(-1px); }
.btn-danger { background: rgba(239,68,68,.1); border-color: rgba(239,68,68,.3); color: var(--red); }
.btn-danger:hover { background: rgba(239,68,68,.22); }

/* ── Info bar ── */
.infobar { background: rgba(255,90,31,.05); border: 1px solid rgba(255,90,31,.12); border-radius: 12px; padding: 9px 13px; font-size: 11px; color: var(--txt2); margin-bottom: 16px; }
.infobar span { color: var(--acc); font-weight: 700; }

/* ── Mini bar chart ── */
.mini-chart { display: flex; align-items: flex-end; gap: 3px; height: 44px; }
.mini-bar { flex: 1; border-radius: 2px 2px 0 0; min-height: 4px; }

/* ── Map ── */
.map-shell { background: var(--c2); border: 1px solid var(--bdr); border-radius: 8px; height: 230px; position: relative; overflow: hidden; }
.fleet-map { height: 300px; }
.device-detail-map { min-height: 220px; height: 220px; }
.map-surface { position: absolute; inset: 0; }
.map-empty {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 24px;
  background: linear-gradient(180deg, rgba(10,10,10,0.86) 0%, rgba(8,8,8,0.92) 100%);
  z-index: 450;
}
.map-legend {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  gap: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 10px;
  color: var(--txt2);
  background: rgba(10,10,10,0.72);
  border: 1px solid rgba(255,90,31,.18);
  backdrop-filter: blur(10px);
  pointer-events: none;
  z-index: 500;
}
.map-shell .leaflet-container { background: #0c0c0c; font: inherit; }
.map-shell .leaflet-tile-pane { filter: saturate(.78) brightness(.78) contrast(1.02); }
.map-shell .leaflet-control-attribution,
.map-shell .leaflet-control-zoom a {
  background: rgba(10,10,10,.86);
  color: var(--txt);
  border-color: rgba(255,90,31,.2);
}
.map-shell .leaflet-control-zoom a:hover { background: rgba(255,90,31,.14); color: var(--txt); }
.map-shell .leaflet-control-attribution a { color: var(--acc3); }
.map-shell .leaflet-popup-content-wrapper,
.map-shell .leaflet-popup-tip {
  background: rgba(18,18,18,.96);
  color: var(--txt);
  border: 1px solid rgba(255,90,31,.18);
}
.map-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,90,31,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,90,31,.05) 1px, transparent 1px); background-size: 32px 32px; }
.map-pin  { position: absolute; width: 11px; height: 11px; border-radius: 50%; border: 2px solid; transform: translate(-50%,-50%); }
.map-pin.active { background: var(--grn); border-color: rgba(0,229,160,.4); box-shadow: 0 0 12px rgba(0,229,160,.5); }
.map-pin.warn   { background: var(--amb); border-color: rgba(245,158,11,.4); }
.map-point { position: absolute; width: 13px; height: 13px; border-radius: 50%; border: 2px solid transparent; transform: translate(-50%,-50%); background: var(--acc); box-shadow: 0 0 0 4px rgba(255,90,31,.12); cursor: pointer; }
.map-point-active { background: var(--grn); box-shadow: 0 0 0 4px rgba(59,210,138,.12); }
.map-point-warn { background: var(--amb); box-shadow: 0 0 0 4px rgba(255,182,72,.12); }
.map-point-offline { background: var(--red); box-shadow: 0 0 0 4px rgba(255,93,93,.12); }
.map-point.selected { width: 16px; height: 16px; border-color: rgba(255,255,255,.85); z-index: 2; }
.map-label { position: absolute; font-size: 9px; color: var(--txt2); white-space: nowrap; letter-spacing: .04em; }
.map-label.selected { color: var(--txt); font-weight: 700; }
.location-method-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}
.location-method-btn {
  min-width: 168px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(22,22,22,.98) 0%, rgba(14,14,14,.98) 100%);
  cursor: pointer;
  transition: border-color .2s, transform .2s, background .2s;
}
.location-method-btn:hover { border-color: rgba(255,90,31,.28); transform: translateY(-1px); }
.location-method-btn.active {
  border-color: rgba(255,90,31,.42);
  background: linear-gradient(180deg, rgba(255,90,31,.14) 0%, rgba(255,90,31,.08) 100%);
  box-shadow: inset 0 0 0 1px rgba(255,90,31,.08);
}
.location-method-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 7px;
}
.location-method-name { font-size: 11px; color: var(--txt); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.location-method-accuracy { font-size: 11px; color: var(--txt2); }
.location-method-note { font-size: 11px; line-height: 1.45; color: var(--txt2); min-height: 32px; }
.certainty-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
}
.certainty-pill.high {
  color: var(--grn);
  background: rgba(0,229,160,.1);
  border: 1px solid rgba(0,229,160,.22);
}
.certainty-pill.medium {
  color: var(--amb);
  background: rgba(245,158,11,.1);
  border: 1px solid rgba(245,158,11,.22);
}
.certainty-pill.low {
  color: #ff8c7a;
  background: rgba(255,93,93,.08);
  border: 1px solid rgba(255,93,93,.22);
}
.location-source-list { display: flex; flex-direction: column; gap: 8px; }
.location-source-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
}
.location-source-row.active {
  border-color: rgba(255,90,31,.28);
  background: rgba(255,90,31,.06);
}
.location-source-name { font-size: 12px; color: var(--txt); font-weight: 700; }
.location-source-meta { font-size: 11px; line-height: 1.45; color: var(--txt2); margin-top: 3px; }

/* ── Loading spinner ── */
.spinner { display: inline-block; width: 14px; height: 14px; border: 2px solid rgba(255,90,31,.18); border-top-color: var(--acc); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Toast ── */
#toast { position: fixed; bottom: 24px; right: 24px; background: rgba(20,20,20,0.95); border: 1px solid var(--acc); color: var(--txt); padding: 10px 16px; border-radius: 14px; font-size: 12px; opacity: 0; transform: translateY(10px); transition: all .3s; pointer-events: none; z-index: 999; box-shadow: var(--shadow); }
#toast.show { opacity: 1; transform: translateY(0); }

/* ── Refresh button ── */
.btn-refresh { width: 34px; height: 34px; border-radius: 10px; background: rgba(255,90,31,.1); border: 1px solid rgba(255,90,31,.24); color: var(--acc); font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .25s; line-height: 1; }
.btn-refresh:hover { background: rgba(255,90,31,.18); border-color: rgba(255,90,31,.4); }
.btn-refresh.spinning { animation: spin .7s linear infinite; pointer-events: none; }

/* ── Read-only toggle ── */
.ro-toggle { display: flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; }
.ro-label { font-size: 11px; letter-spacing: .05em; text-transform: uppercase; }
.ro-label.on { color: var(--amb); }
.ro-label.off { color: var(--txt2); }
body.read-only input, body.read-only textarea { pointer-events: none; opacity: .5; }
body.read-only .btn-sm, body.read-only .toggle, body.read-only .tower-row { pointer-events: none; opacity: .5; }
body.read-only .ro-toggle, body.read-only .nav .tab, body.read-only .btn-refresh, body.read-only .btn-nav-shortcut, body.read-only .org-selector { pointer-events: auto; opacity: 1; }

/* ── Config form ── */
.config-field label { display: block; font-size: 11px; color: var(--txt2); letter-spacing: .06em; text-transform: uppercase; margin-bottom: 6px; }
.config-field input { width: 100%; background: #121212; border: 1px solid var(--bdr); border-radius: 10px; padding: 10px 12px; font-size: 13px; color: var(--txt); outline: none; font-family: inherit; }
.config-field input:focus { border-color: var(--bdr-strong); }
.config-field { margin-bottom: 16px; }
.api-key-row { display: flex; gap: 8px; }
.api-key-row input { flex: 1; }
.btn-icon { background: rgba(255,90,31,.14); border: 1px solid rgba(255,90,31,.28); color: var(--acc); font-size: 12px; padding: 8px 12px; border-radius: 10px; cursor: pointer; transition: background .2s; flex-shrink: 0; }
.btn-icon:hover { background: rgba(255,90,31,.24); }
.tab-visibility-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.tab-visibility-row:last-child { border-bottom: none; padding-bottom: 0; }
.tab-visibility-toggle { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.users-list { display: flex; flex-direction: column; gap: 10px; }
.users-row {
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  padding: 14px;
  background: linear-gradient(180deg, rgba(24,24,24,.98) 0%, rgba(16,16,16,.98) 100%);
}
.users-row-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.users-row-title { font-size: 13px; color: var(--txt); font-weight: 700; }
.users-row-subtitle { font-size: 11px; color: var(--txt2); margin-top: 4px; }
.users-row-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.users-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}
.users-assignment-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,90,31,.18);
  background: rgba(255,90,31,.08);
  color: var(--acc3);
  font-size: 10px;
}
.users-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(10px);
  z-index: 220;
  display: flex;
  justify-content: flex-end;
}
.users-drawer-backdrop[hidden] {
  display: none !important;
}
.users-drawer {
  width: min(560px, 100vw);
  height: 100vh;
  overflow-y: auto;
  padding: 22px;
  background: linear-gradient(180deg, rgba(20,20,20,.99) 0%, rgba(10,10,10,.99) 100%);
  border-left: 1px solid rgba(255,90,31,.18);
  box-shadow: var(--shadow);
}
.users-drawer-header,
.users-drawer-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}
.users-drawer-footer {
  margin-top: 22px;
  margin-bottom: 0;
  justify-content: flex-end;
}
.users-select {
  width: 100%;
  background: #121212;
  border: 1px solid var(--bdr);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 13px;
  color: var(--txt);
  outline: none;
  font-family: inherit;
}
.users-assignment-row {
  display: grid;
  grid-template-columns: 1.1fr 1.1fr .8fr auto;
  gap: 10px;
  align-items: end;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
  margin-bottom: 10px;
}
.users-form-error {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(239,68,68,.26);
  background: rgba(239,68,68,.1);
  color: var(--red);
  font-size: 11px;
}
@media(max-width:900px) {
  .users-assignment-row {
    grid-template-columns: 1fr;
  }
  .users-row-head {
    flex-direction: column;
  }
  .users-row-actions {
    justify-content: flex-start;
  }
}

/* ── Org selector ── */
.org-selector { position: relative; }
.org-btn { display: flex; align-items: center; gap: 8px; background: linear-gradient(180deg, #181818 0%, #121212 100%); border: 1px solid var(--bdr); border-radius: 999px; padding: 9px 14px; cursor: pointer; transition: border-color .2s, transform .2s; min-width: 240px; }
.org-btn:hover { border-color: var(--bdr-strong); transform: translateY(-1px); }
.org-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.org-dot.active { background: var(--grn); box-shadow: 0 0 6px rgba(0,229,160,.5); }
.org-dot.inactive { background: var(--txt2); opacity: .4; }
.org-name { font-size: 12px; color: var(--txt); font-weight: 600; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.org-arrow { font-size: 10px; color: var(--txt2); transition: transform .2s; }
.org-selector.open .org-arrow { transform: rotate(180deg); }
.org-dropdown { position: absolute; top: calc(100% + 8px); left: 0; min-width: 260px; background: rgba(17,17,17,0.98); border: 1px solid var(--bdr); border-radius: 16px; box-shadow: var(--shadow); z-index: 100; display: none; overflow: hidden; }
.org-selector.open .org-dropdown { display: block; }
.org-dropdown-header { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt2); padding: 10px 14px 6px; }
.org-option { display: flex; align-items: center; gap: 10px; padding: 10px 14px; cursor: pointer; transition: background .15s; }
.org-option:hover { background: rgba(255,90,31,.06); }
.org-option.selected { background: rgba(255,90,31,.1); }
.org-option-name { font-size: 12px; color: var(--txt); flex: 1; }
.org-option-detail { font-size: 10px; color: var(--txt2); }
.org-option.selected .org-option-name { color: var(--acc); font-weight: 700; }

/* ── Empty state ── */
.empty-state { text-align: center; padding: 60px 20px; }
.empty-state-icon { font-size: 36px; margin-bottom: 14px; opacity: .4; }
.empty-state-title { font-size: 14px; color: var(--txt); margin-bottom: 6px; }
.empty-state-msg { font-size: 12px; color: var(--txt2); max-width: 340px; margin: 0 auto; }

/* ── Event log ── */
.event-item { padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.05); display: flex; gap: 10px; align-items: flex-start; font-size: 11px; }
.event-item:last-child { border-bottom: none; }
.event-body { color: var(--txt); }
.event-meta { color: var(--txt2); margin-top: 2px; }
