/* ===========================================================================
   FOORIR × Traccar geo-correlation — matches the ops-console aesthetic.
   ========================================================================= */

:root {
  --bg:#0a0c0f; --bg-2:#11151b; --panel:#121821; --panel-2:#0e131a;
  --line:#1e2731; --line-2:#2a3744;
  --ink:#e7eef5; --ink-dim:#8295a6; --ink-faint:#4d5d6c;
  --amber:#ffb347; --amber-hot:#ff8c1a; --cyan:#36d6e7;
  --green:#4ade80; --red:#ff5d5d; --violet:#a78bfa;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --grot:'Space Grotesk',sans-serif; --disp:'Archivo',sans-serif;
  --radius:4px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(54,214,231,.06), transparent 60%),
    radial-gradient(900px 500px at 0% 110%, rgba(255,140,26,.05), transparent 55%),
    var(--bg);
  color:var(--ink); font-family:var(--grot); font-size:14px; line-height:1.4;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
.scanlines{position:fixed;inset:0;pointer-events:none;z-index:9999;
  background:repeating-linear-gradient(to bottom,rgba(255,255,255,.012) 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay}

/* topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg-2),transparent);
  position:sticky;top:0;z-index:1000;backdrop-filter:blur(6px)}
.brand{display:flex;align-items:baseline;gap:10px}
.logo{font-family:var(--disp);font-weight:900;letter-spacing:1px;font-size:20px;
  color:var(--amber);text-shadow:0 0 18px rgba(255,140,26,.35)}
.logo2{font-family:var(--disp);font-weight:900;letter-spacing:1px;font-size:20px;
  color:var(--cyan);text-shadow:0 0 18px rgba(54,214,231,.35)}
.x{color:var(--ink-faint);font-family:var(--mono);font-size:16px}
.brand-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:2.5px;color:var(--ink-faint);margin-left:10px}
.topbar-right{display:flex;align-items:center;gap:16px}
.back{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;color:var(--ink-dim);text-decoration:none;
  padding:6px 11px;border:1px solid var(--line-2);border-radius:var(--radius)}
.back:hover{color:var(--amber);border-color:var(--amber)}
.status-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;
  letter-spacing:1.5px;padding:5px 11px;border:1px solid var(--line-2);border-radius:100px;color:var(--ink-dim)}
.status-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--ink-faint)}
.status-pill.ok{color:var(--green);border-color:rgba(74,222,128,.3)}
.status-pill.ok .dot{background:var(--green);animation:pulse 2s infinite}
.status-pill.err{color:var(--red);border-color:rgba(255,93,93,.3)}
.status-pill.err .dot{background:var(--red)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(74,222,128,.4)}70%{box-shadow:0 0 0 7px rgba(74,222,128,0)}100%{box-shadow:0 0 0 0 rgba(74,222,128,0)}}

/* layout */
.layout{display:grid;grid-template-columns:300px 1fr;min-height:calc(100vh - 57px)}
.rail{border-right:1px solid var(--line);background:var(--panel-2);padding:16px 14px;
  display:flex;flex-direction:column;gap:16px;overflow-y:auto}
.main{padding:18px 20px 36px;display:flex;flex-direction:column;gap:16px;min-width:0}

/* panels */
.panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:15px}
.panel-label{font-family:var(--mono);font-size:10px;letter-spacing:2.5px;color:var(--ink-faint);margin-bottom:12px}
label{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:1.2px;color:var(--ink-dim);margin-bottom:11px}
input,select{width:100%;margin-top:5px;background:var(--panel-2);border:1px solid var(--line-2);
  color:var(--ink);font-family:var(--mono);font-size:12px;padding:9px 10px;border-radius:var(--radius)}
input:focus,select:focus{outline:none;border-color:var(--amber)}
.tol{display:flex;align-items:center;gap:10px;margin-top:6px}
.tol input[type=range]{flex:1;accent-color:var(--amber);padding:0}
.tol span{color:var(--cyan);font-size:12px;white-space:nowrap}

.btn-accent,.btn-ghost{width:100%;font-family:var(--mono);font-size:11px;letter-spacing:1px;font-weight:600;
  padding:10px;border-radius:var(--radius);cursor:pointer;transition:.15s;margin-top:4px}
.btn-accent{background:linear-gradient(180deg,var(--amber),var(--amber-hot));color:#1a1206;border:none}
.btn-accent:hover{filter:brightness(1.1);box-shadow:0 0 18px rgba(255,140,26,.35)}
.btn-accent:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(.3)}
.btn-ghost{background:transparent;color:var(--ink-dim);border:1px solid var(--line-2)}
.btn-ghost:hover{color:var(--ink);border-color:var(--cyan)}

.hint{font-family:var(--grot);font-size:11px;color:var(--ink-faint);line-height:1.5;margin-top:12px}
.hint b{color:var(--cyan)}
.msg{font-family:var(--mono);font-size:11px;margin-top:10px;min-height:14px;line-height:1.5}
.msg.ok{color:var(--green)} .msg.err{color:var(--red)}

.stat-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);
  font-size:12px;padding:7px 0;border-bottom:1px solid var(--line)}
.stat-row:last-child{border-bottom:none}
.stat-row span{color:var(--ink-dim);font-size:10.5px;letter-spacing:.5px}
.stat-row b{color:var(--amber);font-weight:700}

.hidden{display:none!important}

/* map */
.map-card{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--panel-2);height:440px}
#map{position:absolute;inset:0;background:#0c1116}
.map-empty{position:absolute;inset:0;display:grid;place-items:center;z-index:500;
  background:radial-gradient(circle at 50% 40%,rgba(18,24,33,.6),var(--panel-2))}
.me-inner{text-align:center}
.me-title{font-family:var(--mono);letter-spacing:3px;color:var(--ink-faint);font-size:13px;margin-bottom:10px}
.me-sub{font-family:var(--grot);color:var(--ink-faint);font-size:12.5px;line-height:1.7}

/* leaflet dark tweaks */
.leaflet-container{background:#0c1116;font-family:var(--mono)}
.leaflet-tile{filter:brightness(.7) invert(1) contrast(.85) hue-rotate(190deg) saturate(.45) brightness(.95)}
.leaflet-control-attribution{background:rgba(10,12,15,.7)!important;color:var(--ink-faint)!important}
.leaflet-control-attribution a{color:var(--ink-dim)!important}
.leaflet-bar a{background:var(--panel)!important;color:var(--ink)!important;border-color:var(--line-2)!important}
.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:var(--panel);color:var(--ink);
  border:1px solid var(--line-2);box-shadow:0 10px 30px rgba(0,0,0,.5)}
.leaflet-popup-content{font-family:var(--mono);font-size:11px;line-height:1.6;margin:11px 13px}
.popup-h{color:var(--amber);font-weight:700;letter-spacing:1px;margin-bottom:5px}
.popup-row{display:flex;justify-content:space-between;gap:16px}
.popup-row .pk{color:var(--ink-dim)}

/* cards */
.card{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-2);padding:14px 16px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.card-title{font-family:var(--mono);font-size:11px;letter-spacing:2px;color:var(--ink)}
.muted{color:var(--ink-faint);font-family:var(--mono);font-size:10px}
.legend{display:flex;gap:13px}
.lg{font-family:var(--mono);font-size:10px;letter-spacing:1px;display:flex;align-items:center;gap:5px}
.lg::before{content:'';width:10px;height:10px;border-radius:2px}
.lg-in::before{background:var(--green)} .lg-out::before{background:var(--red)}
.lg-spd::before{background:var(--cyan)}
.timeline-card canvas{width:100%;display:block}

/* table */
.table-wrap{max-height:300px;overflow:auto}
table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:11px}
thead th{position:sticky;top:0;background:var(--panel-2);text-align:left;color:var(--ink-faint);
  font-weight:600;letter-spacing:1px;font-size:9.5px;padding:8px 8px;border-bottom:1px solid var(--line-2)}
tbody td{padding:7px 8px;border-bottom:1px solid var(--line);color:var(--ink-dim)}
tbody tr:hover{background:rgba(255,180,71,.05);cursor:pointer}
tbody tr.unmatched td{opacity:.45}
td.in{color:var(--green)} td.out{color:var(--red)}
.locate{color:var(--cyan);text-decoration:none}
.locate:hover{text-decoration:underline}
.table-empty{text-align:center;color:var(--ink-faint);font-family:var(--mono);font-size:11px;padding:24px}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px}
::-webkit-scrollbar-track{background:transparent}

@media(max-width:980px){
  .layout{grid-template-columns:1fr}
  .rail{border-right:none;border-bottom:1px solid var(--line)}
  .map-card{height:360px}
}
