:root{
  --navy:#0f2740; --navy-2:#16314f; --navy-3:#1e3c5f;
  --ink:#1a2230; --muted:#6b7888; --line:#e4e8ef; --line-2:#eef1f6;
  --bg:#f4f6fa; --card:#ffffff;
  --teal:#0fa3a3; --teal-d:#0c7d7d; --gold:#c79a3a;
  --green:#1f9d6b; --amber:#e0a32e; --red:#d4584b; --blue:#2f6fb0;
  --radius:12px; --shadow:0 1px 3px rgba(16,32,55,.06),0 6px 22px rgba(16,32,55,.05);
  --font:"Segoe UI",-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
#app{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{width:236px;flex:0 0 236px;background:linear-gradient(180deg,var(--navy),#0b1d30);
  color:#cdd8e6;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:12px;padding:22px 20px 18px}
.brand-mark{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--teal),var(--teal-d));
  color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;letter-spacing:.5px;
  box-shadow:0 4px 14px rgba(15,163,163,.35)}
.brand-name{font-weight:700;color:#fff;font-size:15px;line-height:1.1}
.brand-sub{font-size:11px;color:#8fa3bb;letter-spacing:.4px;text-transform:uppercase;margin-top:3px}
.nav{display:flex;flex-direction:column;gap:2px;padding:10px}
.nav-item{display:flex;align-items:center;gap:11px;background:none;border:0;color:#bcccde;
  font:inherit;font-size:13.5px;text-align:left;padding:10px 12px;border-radius:9px;cursor:pointer;transition:.15s}
.nav-item .ico{width:18px;text-align:center;opacity:.8;font-size:14px}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:linear-gradient(90deg,rgba(15,163,163,.22),rgba(15,163,163,.05));color:#fff;
  box-shadow:inset 3px 0 0 var(--teal)}
.sidebar-foot{margin-top:auto;padding:16px 18px}
.mock-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1px;color:#0b1d30;
  background:var(--gold);padding:3px 8px;border-radius:5px}
.foot-note{font-size:10.5px;color:#7d91a8;margin-top:8px;line-height:1.4}

/* Main */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 30px;
  background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.topbar h1{margin:0;font-size:20px;font-weight:700;letter-spacing:-.2px}
.crumb{margin:3px 0 0;font-size:12.5px;color:var(--muted)}
.topbar-right{display:flex;align-items:center;gap:18px}
.asof{font-size:12.5px;color:var(--muted)}
.asof strong{color:var(--ink)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--navy-3);color:#fff;font-size:12px;
  font-weight:700;display:flex;align-items:center;justify-content:center}
.content{padding:24px 30px 50px;max-width:1320px}

/* KPI cards */
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow)}
.kpi .label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600}
.kpi .value{font-size:23px;font-weight:750;margin-top:7px;letter-spacing:-.5px}
.kpi .value.sm{font-size:19px}
.kpi .sub{font-size:11.5px;color:var(--muted);margin-top:4px}
.kpi .sub .up{color:var(--green);font-weight:600}
.kpi .sub .down{color:var(--red);font-weight:600}
.kpi.accent{background:linear-gradient(135deg,var(--navy),#13314f);border-color:transparent;color:#fff}
.kpi.accent .label{color:#9fb4cc}
.kpi.accent .sub{color:#9fb4cc}

/* Layout grid */
.row{display:grid;gap:16px;margin-bottom:16px}
.row.r-2{grid-template-columns:1.45fr 1fr}
.row.r-2b{grid-template-columns:1fr 1.45fr}
.row.r-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 0}
.card-h h3{margin:0;font-size:14.5px;font-weight:700}
.card-h .hint{font-size:11.5px;color:var(--muted)}
.card-b{padding:16px 18px}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--muted);margin-top:2px}
.legend span{display:inline-flex;align-items:center;gap:6px}
.dot{width:10px;height:10px;border-radius:3px;display:inline-block}

/* Tables */
table{width:100%;border-collapse:collapse;font-size:12.8px}
thead th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);
  font-weight:700;padding:9px 12px;border-bottom:1px solid var(--line);white-space:nowrap;cursor:pointer;user-select:none}
thead th.num,td.num{text-align:right}
thead th .arr{opacity:.4;font-size:9px;margin-left:3px}
tbody td{padding:9px 12px;border-bottom:1px solid var(--line-2);white-space:nowrap}
tbody tr:hover{background:#f8fafc}
.t-wrap{overflow-x:auto}
.addr{font-weight:600}
.sub-cell{color:var(--muted);font-size:11.5px}
.tnum{font-variant-numeric:tabular-nums}

/* Pills / badges */
.pill{display:inline-block;font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;line-height:1.5}
.pill.green{background:#e6f6ef;color:var(--green)}
.pill.amber{background:#fdf2dc;color:#a9781a}
.pill.red{background:#fae8e6;color:var(--red)}
.pill.blue{background:#e7f0f9;color:var(--blue)}
.pill.gray{background:#eef1f6;color:var(--muted)}
.pill.teal{background:#e2f5f5;color:var(--teal-d)}

/* mini bar in cell */
.cellbar{height:6px;border-radius:4px;background:var(--line);overflow:hidden;min-width:60px;margin-top:4px}
.cellbar > i{display:block;height:100%;border-radius:4px}

/* Filters */
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar input,.toolbar select{font:inherit;font-size:12.8px;padding:7px 11px;border:1px solid var(--line);
  border-radius:8px;background:#fff;color:var(--ink)}
.toolbar input{min-width:230px}
.toolbar .spacer{flex:1}
.chip{font-size:11.5px;color:var(--muted);background:#fff;border:1px solid var(--line);padding:6px 11px;border-radius:8px}

/* Property cards */
.prop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.prop{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.15s}
.prop:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(16,32,55,.10)}
.prop-top{padding:15px 16px;border-bottom:1px solid var(--line-2);display:flex;justify-content:space-between;gap:10px}
.prop-top .pa{font-weight:700;font-size:14px}
.prop-top .pc{font-size:11.5px;color:var(--muted);margin-top:2px}
.prop-body{padding:14px 16px;display:grid;grid-template-columns:1fr 1fr;gap:11px 14px}
.metric .m-l{font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:600}
.metric .m-v{font-size:14px;font-weight:700;margin-top:2px}

/* map */
.map-wrap{position:relative}
.map-pin{position:absolute;transform:translate(-50%,-50%);cursor:pointer}
.map-pin .pdot{width:13px;height:13px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.map-tip{position:absolute;background:var(--navy);color:#fff;font-size:11px;padding:6px 9px;border-radius:7px;
  transform:translate(-50%,-130%);white-space:nowrap;pointer-events:none;opacity:0;transition:.12s;z-index:9}
.map-pin:hover .map-tip{opacity:1}

/* misc */
.section-title{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:6px 0 12px}
.flag{display:inline-flex;align-items:center;gap:6px}
.bar-h{display:flex;align-items:center;gap:10px;margin:7px 0}
.bar-h .bl{width:150px;font-size:12px;color:var(--ink);flex:0 0 150px}
.bar-h .bt{flex:1;height:18px;background:var(--line-2);border-radius:5px;overflow:hidden}
.bar-h .bt > i{display:block;height:100%}
.bar-h .bv{width:74px;text-align:right;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.row.r-2,.row.r-2b,.row.r-3{grid-template-columns:1fr}}
