/* NEQ Cloud UI Mock v5 - futuristic HUD + timeline/heatmap */
:root{
  --bg:#070A12;
  --panel:rgba(17, 24, 39, .58);
  --line:rgba(255,255,255,.10);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.66);
  --muted2:rgba(255,255,255,.48);

  --cyan: rgba(30,255,214, .95);
  --violet: rgba(121,93,255, .95);
  --magenta: rgba(255, 72, 189, .95);
  --yellow: rgba(255, 209, 82, .95);
  --red: rgba(255, 99, 132, .95);

  --radius:18px;
  --shadow: 0 18px 44px rgba(0,0,0,.42);
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  position:relative;
  isolation:isolate;
  background:
    radial-gradient(1100px 650px at 10% -10%, rgba(121,93,255,.18), transparent 60%),
    radial-gradient(900px 540px at 105% 0%, rgba(30,255,214,.12), transparent 55%),
    radial-gradient(760px 520px at 60% 110%, rgba(255, 72, 189, .08), transparent 62%),
    var(--bg);
  background-attachment: fixed;
  overflow-x:hidden;
}

body::before{
  content:"";
  position:fixed; inset:0;
  z-index:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 44px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 1px, transparent 1px 44px);
  opacity:.15;
}
body::after{
  content:"";
  position:fixed; inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 30%, rgba(30,255,214,.08), transparent 35%),
    radial-gradient(circle at 80% 60%, rgba(121,93,255,.06), transparent 40%);
  opacity:.25;
}

a{color:inherit}
.muted{color:var(--muted)}
.mono{font-family:var(--mono)}

.app{
  height:100%;
  display:flex;
  position:relative;
  z-index:1;
}

.sidebar{
  width:290px;
  padding:18px 14px;
  border-right:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  backdrop-filter: blur(10px);
}

.brand{display:flex;gap:12px;align-items:center;padding:10px 10px 16px}
.brand__logo{
  width:44px;height:44px;border-radius:16px;
  display:grid;place-items:center;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.16);
  box-shadow: 0 0 0 1px rgba(30,255,214,.15) inset, 0 0 20px rgba(30,255,214,.12);
  font-weight:1000;
  letter-spacing:.7px;
}
.brand__name{font-weight:900; letter-spacing:.4px}
.brand__sub{font-size:12px;color:var(--muted)}

.nav{display:flex;flex-direction:column;gap:8px;padding:10px 6px}
.nav__item{
  width:100%;
  text-align:left;
  border:1px solid transparent;
  background:transparent;
  color:var(--muted);
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  display:flex;
  gap:10px;
  align-items:center;
  transition:.15s ease;
}
.nav__icon{width:22px;display:inline-flex;justify-content:center;opacity:.9}
.nav__item:not(.is-active):hover{color:var(--text);background:rgba(255,255,255,.05);border-color:var(--line)}
.nav__item.is-active{
  color:var(--text);
  background:rgba(255,255,255,.07);
  border-color:rgba(30,255,214,.22);
  box-shadow: 0 0 0 1px rgba(30,255,214,.14) inset;
}

.sidebar__footer{margin-top:16px;padding:10px;display:flex;flex-direction:column;gap:10px}

.chip{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
}
.chip__label{font-size:12px;color:var(--muted)}
.chip__value{font-size:12px}

.main{flex:1;display:flex;flex-direction:column;min-width:0}

.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px 22px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.04), transparent);
  backdrop-filter: blur(10px);
}
.crumbs{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.3px}
.crumbs__sep{opacity:.35}
.crumbs__current{opacity:.82}
.topbar__left{flex:1 1 auto;max-width:640px;min-width:260px}
.topbar__hint{font-size:12px;color:var(--muted);margin-top:6px;max-width:560px;line-height:1.45}
.topbar__right{display:flex;gap:10px;align-items:center;flex:0 1 auto;flex-wrap:nowrap;justify-content:flex-end;min-width:0}
.search{position:relative;min-width:180px;flex:0 1 260px;max-width:300px}
.search__input{
  width:100%;padding:10px 40px 10px 12px;border-radius:14px;border:1px solid var(--line);
  background:rgba(0,0,0,.18);color:var(--text);outline:none;backdrop-filter: blur(10px);
}
.search__input:focus{border-color: rgba(30,255,214,.25);box-shadow: 0 0 0 3px rgba(30,255,214,.10)}
.search__icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--muted2)}

.topbar__right .btn{min-width:62px;padding-inline:10px}

.user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.18);backdrop-filter: blur(10px);flex:0 1 auto;min-width:0;max-width:176px}
.user__avatar{width:34px;height:34px;border-radius:14px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);font-weight:900;letter-spacing:.3px}
.user__meta{min-width:0;overflow:hidden}
.user__name{font-size:12px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user__role{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.screen{display:none;padding:18px 22px 28px}
.screen.is-active{display:block}

.grid{display:grid;gap:14px}
.grid--cards{grid-template-columns:repeat(4, minmax(0,1fr))}
.grid--two{grid-template-columns:repeat(2, minmax(0,1fr))}
.grid--area{grid-template-columns:320px minmax(0,1fr)}
@media (max-width: 1100px){
  .grid--cards{grid-template-columns:repeat(2, minmax(0,1fr))}
  .grid--two{grid-template-columns:1fr}
  .grid--area{grid-template-columns:1fr}
  .sidebar{display:none}
  .topbar{flex-wrap:wrap;align-items:stretch}
  .topbar__left,.topbar__right{width:100%}
  .topbar__right{justify-content:flex-start}
  .search{min-width:180px;max-width:none;flex:1 1 240px}
}

.card{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background:var(--panel);
  box-shadow:var(--shadow);
  padding:14px 14px 12px;
  backdrop-filter: blur(12px);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;inset:-2px;
  background:linear-gradient(120deg, rgba(30,255,214,.14), transparent 35%, rgba(121,93,255,.10));
  opacity:.4;pointer-events:none;
}
.card__label{font-size:12px;color:var(--muted); position:relative}
.card__value{font-size:22px;font-weight:1000;letter-spacing:.3px;margin-top:6px; position:relative}
.card__meta{font-size:12px;color:var(--muted);margin-top:6px; position:relative}
.card--glow{
  border-color: rgba(30,255,214,.20);
  box-shadow: 0 0 0 1px rgba(30,255,214,.12) inset, 0 14px 50px rgba(0,0,0,.48);
}

.panel{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background:var(--panel);
  box-shadow:var(--shadow);
  overflow:hidden;
  backdrop-filter: blur(12px);
}
.panel__head{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  flex-wrap:wrap;
  padding:12px 14px;background:linear-gradient(180deg, rgba(255,255,255,.05), transparent);
}
.panel__title{font-weight:1000; letter-spacing:.25px; min-width:0}
.panel__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.panel__actions .btn{min-width:68px}
.panel__foot{
  padding:12px 14px;border-top:1px solid var(--line);
  color:var(--muted);font-size:12px;
}

.btn{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.10);
  color:var(--text);
  padding:8px 10px;border-radius:12px;cursor:pointer;
  font-weight:900;font-size:12px;letter-spacing:.2px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1.15;
  white-space:nowrap;
  flex:0 0 auto;
}
.btn:hover{background:rgba(255,255,255,.14)}
.btn--ghost{background:transparent;color:var(--muted)}
.btn--ghost:hover{color:var(--text);background:rgba(255,255,255,.06)}
.btn--tiny{padding:6px 8px;border-radius:10px;font-size:11px}
.btn--wide{width:100%}

.tableWrap{overflow:auto}
.tableWrap--xhint{
  position:relative;
  scrollbar-gutter: stable;
}
.tableWrap--xhint.is-scrollable-x:not(.is-scrolled-end){
  box-shadow: inset -20px 0 16px -16px rgba(2,6,23,0.70);
}
.tableWrap--xhint.is-scrollable-x:not(.is-scrolled-start){
  box-shadow:
    inset 20px 0 16px -16px rgba(2,6,23,0.58),
    inset -20px 0 16px -16px rgba(2,6,23,0.70);
}
.tableWrap--xhint.is-scrollable-x.is-scrolled-end:not(.is-scrolled-start){
  box-shadow: inset 20px 0 16px -16px rgba(2,6,23,0.58);
}
.tableScrollHint{
  display:none;
  padding:6px 10px 0;
  text-align:left;
  font-size:11px;
  font-weight:900;
  letter-spacing:.2px;
  color:rgba(30,255,214,0.82);
  user-select:none;
}
.tableScrollHint.is-show{
  display:block;
  animation:hintPulse 1.2s ease-in-out infinite;
}
@keyframes hintPulse{
  0%,100%{opacity:.65}
  50%{opacity:1}
}
.table{width:100%;border-collapse:collapse;min-width:780px}
.table th, .table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);font-size:12px}
.table th{
  text-align:left;color:var(--muted);font-weight:1000;letter-spacing:.2px;
  background:rgba(255,255,255,.02);
}
.table tbody tr:hover{background:rgba(255,255,255,.04)}

.pill{
  display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);font-size:11px;font-weight:1000;letter-spacing:.1px;
  background:rgba(0,0,0,.18);
}
.pill--strong{color:var(--red); box-shadow: 0 0 16px rgba(255,99,132,.12)}
.pill--weak{color:var(--yellow); box-shadow: 0 0 16px rgba(255,209,82,.10)}
.pill--ok{color:var(--cyan); box-shadow: 0 0 16px rgba(30,255,214,.10)}
.pill--ng{color:var(--red)}
.pill--neutral{color:var(--muted)}

.link{color:rgba(255,255,255,.92);text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.35)}
.link:hover{border-bottom-color:rgba(30,255,214,.65)}

/* Map HUD */
.mapHUD{padding:14px}
.mapHUD__top{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.hudTag{
  font-size:11px;font-weight:1000;letter-spacing:.45px;
  padding:4px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.18);
}
.hudTag--live{color:var(--cyan);box-shadow: 0 0 18px rgba(30,255,214,.10)}
.hudMeta{display:flex;gap:6px;align-items:baseline;padding:4px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.14)}
.hudMeta__k{font-size:11px;color:var(--muted)}
.hudMeta__v{font-size:11px}

.mapHUD__stage{
  position:relative;
  height:380px;
  border-radius:16px;border:1px solid rgba(255,255,255,.14);
  overflow:hidden;background:rgba(0,0,0,.24);
  box-shadow: 0 0 0 1px rgba(30,255,214,.08) inset;
}
.mapHUD__stage::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), transparent 25%, transparent 75%, rgba(255,255,255,.04)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 6px);
  opacity:.08;
}
.mapHUD__stage::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background: radial-gradient(circle at 50% 60%, rgba(30,255,214,.10), transparent 55%);
  opacity:.35;
}
.mapCanvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index:2;
  pointer-events:none;
  mix-blend-mode: screen;
  opacity:0.88;
}
#particleCanvas{opacity:0.65; mix-blend-mode: lighten;}
#demoMap{width:100%;height:100%;display:block;position:relative;z-index:1}
.maplibreMap{
  position:absolute;
  inset:0;
  z-index:0;
}
.maplibreMap .maplibregl-canvas{
  outline:none;
}
body.map-engine-live #demoMap,
body.map-engine-live #heatmapCanvas,
body.map-engine-live #particleCanvas{
  display:none;
}
body.map-engine-live .mapViewport{
  transform:none !important;
}
body.map-engine-live .mapHUD__stage::before,
body.map-engine-live .mapHUD__stage::after{
  opacity:.14;
}
body.map-engine-live .maplibregl-ctrl-attrib{
  background:rgba(2,6,23,0.62);
  color:rgba(226,232,240,0.88);
  border-radius:8px;
  border:1px solid rgba(148,163,184,0.24);
}
body.map-engine-live .maplibregl-ctrl-attrib a{
  color:rgba(226,232,240,0.88);
}
.mapHUD__tooltip{
  position:absolute;z-index:6;left:14px;top:14px;
  padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.58);backdrop-filter: blur(12px);
  box-shadow: var(--shadow);font-size:12px;max-width:340px;display:none;
}
.mapHUD__tooltip.is-show{display:block}

.timelineCtrl{
  position:absolute;
  left:14px; right:14px; bottom:14px;
  z-index:7;
  display:flex;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.46);
  backdrop-filter: blur(12px);
}
.timelineCtrl input[type="range"]{
  flex:1;
}
.timeLabel{
  width:140px;
  text-align:right;
  color:rgba(255,255,255,.82);
  font-size:12px;
}
.input--mini{
  min-width:92px;
  padding:8px 10px;
  border-radius:12px;
  font-size:12px;
}

.mapHUD__bottom{margin-top:10px;display:flex;gap:12px;justify-content:space-between;align-items:center;flex-wrap:wrap}

.legend{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.legend__item{display:flex;align-items:center;gap:8px}
.legend__sw{width:14px;height:14px;border-radius:6px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06)}
.legend__sw--strong{background:rgba(255,99,132,.18); box-shadow: 0 0 16px rgba(255,99,132,.20)}
.legend__sw--weak{background:rgba(255,209,82,.18); box-shadow: 0 0 16px rgba(255,209,82,.14)}
.legend__sw--normal{background:rgba(255,255,255,.08)}
.legend__sw--eq{background:rgba(30,255,214,.18); box-shadow: 0 0 16px rgba(30,255,214,.18)}
.legend__sw--heat{background:rgba(255, 72, 189, .18); box-shadow: 0 0 16px rgba(255,72,189,.16)}
.legend__sw--fx{background:rgba(121,93,255, .18); box-shadow: 0 0 16px rgba(121,93,255,.16)}
.legend--big .legend__item{font-size:13px}

/* SVG styles */
.areaPolygon{cursor:pointer;stroke-width:2}
.areaPolygon.level-strong{ fill: rgba(255,99,132,.12); stroke: rgba(255,99,132,.80); }
.areaPolygon.level-weak{ fill: rgba(255,209,82,.10); stroke: rgba(255,209,82,.78); }
.areaPolygon.level-normal{ fill: rgba(255,255,255,.05); stroke: rgba(255,255,255,.22); }
.areaPolygon:hover{stroke: rgba(30,255,214,.95);fill: rgba(30,255,214,.10);}

.eqPoint{fill: rgba(30,255,214,.92);stroke: rgba(255,255,255,.20);stroke-width:1.2;filter: url(#glow);}
.eqPulse{fill: none;stroke: rgba(30,255,214,.55);stroke-width: 2;opacity:.8;animation: pulse 1.8s infinite;}
@keyframes pulse{0%{transform: scale(.65); opacity:.95}100%{transform: scale(1.55); opacity:0}}
.radar{fill:none;stroke: rgba(30,255,214,.25);stroke-width: 1.6;stroke-dasharray: 6 10;animation: spin 10s linear infinite;transform-origin: 450px 260px;}
.radar--d2{animation-duration: 14s; opacity:.45}
.radar--d3{animation-duration: 18s; opacity:.35}
@keyframes spin{from{transform: rotate(0deg)}to{transform: rotate(360deg)}}

/* Log */
.log{padding:8px 14px 14px}
.log__row{display:grid;grid-template-columns:56px 60px 1fr;gap:10px;padding:8px 0;border-bottom:1px dashed rgba(255,255,255,.10);font-size:12px}
.log__row:last-child{border-bottom:none}
.log__time{color:var(--muted);font-family:var(--mono);font-size:11px}
.log__lvl{font-weight:1000}
.log__lvl--ok{color:var(--cyan)}
.log__lvl--warn{color:var(--yellow)}
.log__msg{color:rgba(255,255,255,.86)}

/* KV */
.kv{display:grid;gap:8px}
.kv__item{
  display:flex;justify-content:space-between;gap:12px;padding:8px 12px;
  border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.16);
}
.kv__k{color:var(--muted);font-size:12px}
.kv__v{font-size:12px}
.kv--big .kv__item{padding:10px 12px}

/* Filters / diff */
.filters{display:flex;justify-content:space-between;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);align-items:center}
.filters__left{display:flex;gap:8px;flex-wrap:wrap}
.filters__right{font-size:12px}
.diff{padding:10px 14px 14px}
.diff__row{
  display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.14);margin-bottom:10px;font-size:12px
}
.diff__row:last-child{margin-bottom:0}
.diff__k{color:var(--muted);font-weight:1000}
.diff__v{color:rgba(255,255,255,.86)}

/* list */
.list{padding:10px 10px 14px;display:flex;flex-direction:column;gap:8px}
.list__item{
  text-align:left;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.14);color:var(--text);
  border-radius:16px;padding:10px 12px;cursor:pointer;position:relative;overflow:hidden;
}
.list__item::before{content:"";position:absolute;inset:-2px;background:linear-gradient(120deg, rgba(30,255,214,.10), transparent 40%, rgba(121,93,255,.08));opacity:.25}
.list__item:not(.is-active):hover{background:rgba(255,255,255,.05)}
.list__item.is-active{background:rgba(255,255,255,.06);border-color:rgba(30,255,214,.24);box-shadow: 0 0 0 1px rgba(30,255,214,.10) inset}
.list__title{font-weight:1000; position:relative}
.list__meta{margin-top:6px;font-size:12px;color:var(--muted);display:flex;gap:8px;align-items:center; position:relative}

/* chart */
.chart{padding:14px}
.chart__placeholder{border-radius:16px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.18);padding:14px;position:relative;overflow:hidden}
.chart__placeholder::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 30% 20%, rgba(30,255,214,.10), transparent 40%),radial-gradient(circle at 70% 60%, rgba(121,93,255,.08), transparent 45%);opacity:.55}
.chart__title{font-weight:1000;margin-bottom:10px; position:relative}
.chart svg{color:rgba(255,255,255,.86); position:relative}
.chart__legend{display:flex;gap:12px;align-items:center;color:var(--muted);font-size:12px;margin-top:8px; position:relative}
.legend2{display:flex;gap:8px;align-items:center}
.legend2__sw{width:18px;height:2px;background:rgba(30,255,214,.75);border-radius:99px}
.legend2__sw--dash{background:transparent;border-top:2px dashed rgba(255,255,255,.55);height:0}

/* timeline list */
.timeline{padding:10px 14px 14px}
.timeline__item{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px dashed rgba(255,255,255,.10)}
.timeline__item:last-child{border-bottom:none}
.timeline__dot{width:10px;height:10px;border-radius:99px;background:rgba(30,255,214,.28);margin-top:5px;box-shadow:0 0 0 4px rgba(30,255,214,.10)}
.timeline__title{font-weight:1000;font-size:12px}
.timeline__text{color:var(--muted);font-size:12px;margin-top:6px;line-height:1.55}

/* files */
.files{padding:10px 14px 14px;display:flex;flex-direction:column;gap:8px}
.modal__body .files{max-height:34vh;overflow:auto;min-height:0}
.file{display:grid;grid-template-columns:1fr minmax(96px, auto) auto auto;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.14);font-size:12px}
.file__name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file__meta{color:var(--muted);text-align:right}
.artifactPreview{min-height:220px;max-height:min(42vh, 460px);overflow:auto;margin:0 14px 14px;padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.20)}
.artifactPreview__frame{width:100%;height:min(38vh, 420px);min-height:260px;border:0;border-radius:12px;background:#fff}
.artifactPreview__image{display:block;max-width:100%;max-height:min(38vh, 420px);margin:0 auto;border-radius:12px}
.artifactPreview__pre{margin:0;white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.55;color:var(--text)}
@media (max-width: 720px){
  .file{grid-template-columns:1fr;align-items:start}
  .file__meta{text-align:left}
}

/* forms */
.form{padding:10px 14px 14px;display:flex;flex-direction:column;gap:14px}
.field__label{font-size:12px;color:var(--muted);font-weight:1000}
.field__row{display:flex;gap:10px;align-items:center;margin-top:8px;flex-wrap:wrap}
.field__hint{font-size:12px;color:var(--muted2);margin-top:8px;line-height:1.55}
.input{
  padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.18);color:var(--text);outline:none;min-width:180px;backdrop-filter: blur(10px);
}
.input--ta{min-width:min(560px, 100%)}
.input:focus{border-color: rgba(30,255,214,.25);box-shadow: 0 0 0 3px rgba(30,255,214,.10)}

/* roles */
.roles{padding:10px 14px 14px;display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:12px}
@media (max-width: 900px){.roles{grid-template-columns:1fr}}
.role{border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.14);padding:12px}
.role__title{font-weight:1000}
.role__desc{margin-top:8px;color:var(--muted);font-size:12px;line-height:1.55}

.footer{padding:14px 22px 24px;border-top:1px solid rgba(255,255,255,.10);background:transparent}

/* Modals */
.modalOverlay{position:fixed;inset:0;display:grid;place-items:center;z-index:999;background: rgba(0,0,0,.55);backdrop-filter: blur(10px);padding:12px;box-sizing:border-box}
.modalOverlay.is-hidden{display:none}
.modal{width:min(920px, calc(100vw - 24px));max-height:calc(100dvh - 24px);display:flex;flex-direction:column;border-radius:18px;border:1px solid rgba(255,255,255,.14);background: rgba(10, 14, 26, .72);box-shadow: 0 24px 70px rgba(0,0,0,.55);overflow:hidden}
.modal__head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10);background: linear-gradient(180deg, rgba(255,255,255,.06), transparent)}
.modal__title{font-weight:1000}
.iconBtn{border:1px solid rgba(255,255,255,.14);background: rgba(255,255,255,.08);color: var(--text);width:34px;height:34px;border-radius:12px;cursor:pointer;display:grid;place-items:center}
.iconBtn:hover{background: rgba(255,255,255,.12)}
.modal__body{padding:14px;overflow:auto;min-height:0;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.modal__foot{padding:12px 14px;border-top:1px solid rgba(255,255,255,.10);display:flex;justify-content:flex-end;gap:10px}
.modalGrid{display:grid;gap:14px}
.modalGrid--2col{grid-template-columns: 1fr 1fr; gap:14px}
@media (max-width: 860px){.modalGrid--2col{grid-template-columns:1fr}}

.hint{border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.16);border-radius:16px;padding:12px;color: var(--muted);font-size:12px;line-height:1.6}
.check, .radio{display:flex;align-items:center;gap:8px;font-size:12px;color: var(--text);padding:4px 6px;border-radius:10px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.10)}

.toast{position:fixed;bottom:18px;right:18px;z-index:1000;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background: rgba(0,0,0,.60);box-shadow: var(--shadow);backdrop-filter: blur(10px);color: var(--text);font-size:12px;max-width:min(420px, calc(100vw - 24px))}
.toast.is-hidden{display:none}

.steps{margin:0;padding-left:18px;color: var(--text);font-size:13px;line-height:1.6}
.steps li{margin:8px 0}
b{font-weight:1000}

/* Mini map */
.miniMap{padding:12px;height:260px}
.miniMap svg{width:100%;height:100%;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18)}

/* Evidence preview */
.previewHead{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.previewTitle{font-weight:1000}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.tab{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: var(--muted);
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  font-weight:1000;
  font-size:12px;
}
.tab:not(.is-active):hover{color:var(--text);background: rgba(255,255,255,.06)}
.tab.is-active{color:var(--text);border-color: rgba(30,255,214,.22);box-shadow: 0 0 0 1px rgba(30,255,214,.10) inset}

.previewBody{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.14);
  padding:12px;
  min-height:320px;
}
.thumb{width:100%;height:auto;border-radius:14px;border:1px solid rgba(255,255,255,.12);background: rgba(0,0,0,.18)}
.tabPane{display:none}
.tabPane.is-active{display:block}

.csvPreview__title{font-size:12px;color:var(--muted);margin-bottom:8px}
.miniTable{width:100%;border-collapse:collapse;font-size:12px}
.miniTable th, .miniTable td{border-bottom:1px solid rgba(255,255,255,.10);padding:8px 10px}
.miniTable th{color:var(--muted);text-align:left;font-weight:1000}
.jsonBox__title{font-size:12px;color:var(--muted);margin-bottom:8px}
.jsonBox__pre{
  margin:0;
  white-space:pre-wrap;
  word-break:break-word;
  font-size:11px;
  line-height:1.55;
  color: rgba(255,255,255,.86);
}

/* Admin */
.adminBody{padding:14px}
.adminTabs{margin-bottom:12px}
.adminPane{display:none}
.adminPane.is-active{display:block}
.adminBar{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:10px 14px;border:1px solid rgba(255,255,255,.10);
  border-radius:16px;background:rgba(0,0,0,.12);margin-bottom:12px;flex-wrap:wrap;
}
.adminBar__left{display:flex;gap:8px;flex-wrap:wrap}
.adminBar__right{display:flex;gap:8px;flex-wrap:wrap}

.table--compact th, .table--compact td{padding:9px 10px; font-size:11.8px}
.polyPreview{width:74px;height:44px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18)}
.polyPreviewBox{border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);padding:10px;height:280px}
.polyPreviewBox svg{width:100%;height:100%}

.dropzone{border-radius:18px;border:1px dashed rgba(255,255,255,.18);background:rgba(0,0,0,.14);padding:18px;text-align:center}
.dropzone__title{font-weight:1000}
.dropzone__sub{margin-top:8px;color:var(--muted);font-size:12px}

.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.chip2{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.16);color:var(--text);font-size:12px}
.chip2__x{opacity:.6;cursor:pointer}
.chip2__x:hover{opacity:1}


/* Map viewport (pan/zoom) */
.mapViewport{
  position:absolute;
  inset:0;
  background:
    radial-gradient(120% 100% at 20% 15%, rgba(73, 147, 214, 0.28), transparent 62%),
    linear-gradient(165deg, rgba(22, 73, 116, 0.58) 0%, rgba(15, 56, 93, 0.58) 55%, rgba(10, 42, 72, 0.58) 100%);
  transform-origin: 0 0;
  will-change: transform;
}

/* Zoom controls */
.zoomCtrl{
  position:absolute;
  right: 16px;
  top: 16px;
  display:flex;
  flex-direction: column;
  gap: 8px;
  z-index: 6;
  pointer-events:auto;
}
.zoomBtn{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,0.22);
  background: rgba(2,6,23,0.48);
  color: rgba(229,231,235,0.95);
  font-size: 18px;
  font-weight: 1000;
  cursor: pointer;
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.28);
}
.zoomBtn:hover{ background: rgba(2,6,23,0.62); }
.zoomBtn--home{ font-size: 16px; }

/* Municipal watch highlight (ward-level) */
.muni{
  fill: rgba(30,41,59,0.78);
  stroke: rgba(148,163,184,0.40);
  stroke-width: 0.7;
  vector-effect: non-scaling-stroke;
  cursor: pointer;
}
.muni:hover{ fill: rgba(37,99,235,0.35); }

.muni.muni--strong{
  fill: rgba(255,72,189,0.18);
  stroke: rgba(255,72,189,0.75);
  stroke-width: 1.4;
  filter: url(#softGlow);
}
.muni.muni--weak{
  fill: rgba(245,158,11,0.14);
  stroke: rgba(245,158,11,0.70);
  stroke-width: 1.2;
}
.muni.is-active{
  fill: rgba(34,197,94,0.18);
  stroke: rgba(34,197,94,0.90);
  stroke-width: 1.8;
}
.muni.match{
  fill: rgba(34,197,94,0.15);
}

/* Map-only modal window */
.mapWindow{
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.mapWindow__bar{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
}
.mapFrame{
  width: 100%;
  height: min(78vh, 860px);
  border: 1px solid rgba(148,163,184,0.22);
  border-radius: 16px;
  background: rgba(2,6,23,0.35);
}
.mapViewport--fill{
  width:100%;
  height:100%;
}
