:root{
  --bg-darkest:#0a0d14;--bg-dark:#0e1119;--bg-card:#141926;--bg-elevated:#1c2334;
  --accent:#66c0f4;--accent-hover:#9edcff;--accent-dim:rgba(102,192,244,.3);--accent-glow:rgba(102,192,244,.18);
  --accent-grad-1:#66c0f4;--accent-grad-2:#4a90c2;
  --text:#c6d4df;--text-bright:#fff;--text-dim:#6b7384;--text-muted:#8f98a0;
  --green:#3fb950;--green-bg:rgba(63,185,80,.12);--red:#f85149;--red-bg:rgba(248,81,73,.12);--yellow:#d29922;
  --border:#1d2433;--border-strong:#2a3142;--radius:12px;--radius-sm:8px;
  --shadow-card:0 6px 28px rgba(0,0,0,.4);--shadow-glow:0 0 24px rgba(102,192,244,.15);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg-darkest);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.mono{font-family:'JetBrains Mono',monospace}
body::before{content:'';position:fixed;inset:0;z-index:-3;pointer-events:none;background:radial-gradient(ellipse 80% 50% at top right,rgba(102,192,244,.06) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at bottom left,rgba(88,101,242,.04) 0%,transparent 60%),var(--bg-darkest)}

/* real constellation canvas + star-hunt (from framework) */
.framework-constellation{position:fixed;inset:0;width:100vw;height:100vh;z-index:-1;pointer-events:none}
.framework-score-display{position:fixed;top:0;left:0;z-index:950;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 16px;background:linear-gradient(135deg,rgba(22,27,34,.9),rgba(12,16,21,.82));backdrop-filter:blur(14px) saturate(140%);border:1px solid rgba(102,192,244,.3);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.55),0 0 0 1px rgba(102,192,244,.08) inset;opacity:0;transition:opacity .35s ease;will-change:transform}
.framework-score-display.active{opacity:1}
.framework-score-label{font-family:'JetBrains Mono',monospace;font-size:.6rem;font-weight:700;color:var(--text-dim);letter-spacing:3px;text-transform:uppercase}
.framework-score-digits{display:inline-flex;align-items:center;gap:2px;font-family:'Outfit',sans-serif;font-size:1.6rem;font-weight:800;color:var(--accent);line-height:1;letter-spacing:-.5px;text-shadow:0 0 14px rgba(102,192,244,.45)}
.framework-score-digit{position:relative;display:inline-block;width:.6em;height:1em;overflow:hidden;vertical-align:middle}
.framework-score-digit-track{position:absolute;left:0;top:0;display:flex;flex-direction:column;transition:transform .45s cubic-bezier(.4,1.4,.5,1)}
.framework-score-digit-track span{display:flex;align-items:center;justify-content:center;width:.6em;height:1em}
.framework-score-combo{display:none;font-family:'JetBrains Mono',monospace;font-size:.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#ffcc4c;margin-top:2px;animation:framework-combo-pulse .6s ease}
.framework-score-combo.visible{display:block}
@keyframes framework-combo-pulse{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.15);opacity:1}100%{transform:scale(1);opacity:1}}
.framework-score-digits.pop{animation:framework-digit-pop .35s cubic-bezier(.2,.8,.2,1)}
@keyframes framework-digit-pop{0%{transform:scale(1)}50%{transform:scale(1.2)}100%{transform:scale(1)}}
.framework-floating-point{position:fixed;z-index:951;pointer-events:none;font-family:'Outfit',sans-serif;font-weight:800;font-size:1.1rem;color:#fff;text-shadow:0 0 12px currentColor;animation:framework-float-up 1s cubic-bezier(.2,.8,.2,1) forwards;white-space:nowrap}
@keyframes framework-float-up{0%{transform:translate(-50%,0) scale(.6);opacity:0}20%{transform:translate(-50%,-10px) scale(1.1);opacity:1}100%{transform:translate(-50%,-60px) scale(1);opacity:0}}

.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;padding:14px clamp(16px,3vw,32px);background:rgba(14,17,25,.78);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--border);flex-wrap:wrap}
.brand{font-weight:700;letter-spacing:.04em;font-size:clamp(14px,1.4vw,17px);color:var(--text-bright)}
.brand .sub{color:var(--accent);font-weight:600;margin-left:7px}
.badge{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 14px;border-radius:999px;font-weight:600;background:var(--green-bg);color:#7ee094;border:1px solid rgba(63,185,80,.3)}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}

main{max-width:min(1600px,95vw);margin:0 auto;padding:clamp(16px,2.5vw,28px);display:flex;flex-direction:column;gap:clamp(20px,3vw,30px)}
.section-label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.section-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}
.stat{background:linear-gradient(160deg,var(--bg-card),var(--bg-dark));border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);opacity:.5}
.stat .k{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-weight:600}
.stat .v{font-family:'JetBrains Mono',monospace;font-size:clamp(22px,2.4vw,28px);color:var(--text-bright);margin-top:8px;font-weight:600;line-height:1}
.stat .s{font-size:12px;color:var(--text-muted);margin-top:6px}

.charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.chart{background:linear-gradient(160deg,var(--bg-card),var(--bg-dark));border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px 8px;box-shadow:var(--shadow-card)}
.chart h3{font-size:13px;color:var(--text);font-weight:600;display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.chart h3 .now{font-family:'JetBrains Mono',monospace;color:var(--accent-hover);font-size:15px}

.tenants{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
@media(max-width:560px){.tenants{grid-template-columns:1fr}}
.tcard{background:linear-gradient(160deg,var(--bg-card),var(--bg-dark));border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s}
.tcard:hover{border-color:var(--accent-dim);transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.tcard .head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:10px}
.tcard .name{font-weight:700;color:var(--text-bright);font-size:15px;letter-spacing:.01em}
.tcard .st{display:flex;align-items:center;gap:7px;font-size:12px;color:#7ee094;font-family:'JetBrains Mono',monospace;white-space:nowrap}
.tcard .st .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.tspark{height:64px;margin:4px -4px 12px}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:380px){.tgrid{grid-template-columns:repeat(2,1fr)}}
.tgrid .m{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}
.tgrid .m .mk{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}
.tgrid .m .mv{font-family:'JetBrains Mono',monospace;font-size:15px;color:var(--text-bright);margin-top:3px}

.u-legend{display:none!important}

/* tenant detail modal (fade + scale) */
.modal-backdrop{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:clamp(12px,3vw,32px);background:rgba(5,8,12,.55);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s ease}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal-card{width:min(1040px,96vw);max-height:90vh;overflow:auto;background:linear-gradient(160deg,var(--bg-card),var(--bg-dark));border:1px solid var(--border-strong);border-radius:16px;box-shadow:0 24px 80px rgba(0,0,0,.6),var(--shadow-glow);padding:clamp(16px,2.5vw,24px);transform:scale(.92) translateY(12px);opacity:0;transition:transform .28s cubic-bezier(.2,.8,.2,1),opacity .28s ease}
.modal-backdrop.open .modal-card{transform:scale(1) translateY(0);opacity:1}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.modal-title{display:flex;align-items:center;gap:10px;font-family:'Outfit',sans-serif;font-weight:800;font-size:clamp(17px,2.4vw,22px);color:var(--text-bright)}
.modal-title .dot{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green)}
.modal-close{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);width:36px;height:36px;border-radius:9px;font-size:22px;line-height:1;cursor:pointer;transition:all .15s;flex-shrink:0}
.modal-close:hover{border-color:var(--red);color:#ff8a82;background:var(--red-bg)}
.modal-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin-bottom:18px}
.modal-metrics .m{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 11px}
.modal-metrics .m .mk{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}
.modal-metrics .m .mv{font-family:'JetBrains Mono',monospace;font-size:16px;color:var(--text-bright);margin-top:3px}
.modal-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.modal-detail{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:18px}
.dtbl{background:#0d141d;border:1px solid var(--border);border-radius:8px;padding:10px 12px;min-width:0}
.dttl{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-weight:600;margin-bottom:8px}
.dtbl table{width:100%;border-collapse:collapse;font-family:'JetBrains Mono',monospace;font-size:12px}
.dtbl th{text-align:right;color:var(--text-dim);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.05em;padding:3px 6px;border-bottom:1px solid var(--border)}
.dtbl th:first-child{text-align:left}
.dtbl td{text-align:right;padding:4px 6px;border-bottom:1px solid #131c26;color:var(--text)}
.dtbl td:first-child{text-align:left;color:var(--text-bright);word-break:break-all}

.foot{text-align:center;color:var(--text-dim);font-size:12px;padding:10px 0 36px}
*{scrollbar-width:thin;scrollbar-color:var(--accent-dim) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--accent-grad-1),var(--accent-grad-2));border-radius:10px;border:2px solid transparent;background-clip:padding-box}
.badge-ok{background:var(--green-bg);color:#7ee094;border:1px solid rgba(63,185,80,.3)}
.badge-bad{background:var(--red-bg);color:#ff8a82;border:1px solid rgba(248,81,73,.3)}
