:root{
  --gold:#d4a716;
  --gold-soft:rgba(212,167,22,.16);
  --charcoal:#20242a;
  --navy:#071827;
  --navy2:#0b2237;
  --mid:#6b7280;
  --line:#d8dee8;
  --panel:#ffffff;
  --bg:#eef2f7;
  --green:#10b981;
  --orange:#f59e0b;
  --blue:#2563eb;
  --red:#dc2626;
  --shadow:0 16px 40px rgba(15,23,42,.12);
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:"Segoe UI", Arial, sans-serif;
  color:var(--charcoal);
  background:
    radial-gradient(circle at top left, rgba(212,167,22,.10), transparent 32%),
    linear-gradient(180deg,#f8fafc 0%,#eef2f7 100%);
}

.topbar{
  height:96px;
  background:linear-gradient(90deg, #071827 0%, #0b2237 62%, #0f172a 100%);
  display:grid;
  grid-template-columns:1fr auto 320px;
  gap:22px;
  align-items:center;
  padding:14px 24px;
  border-bottom:1px solid rgba(255,255,255,.10);
  box-shadow:0 14px 34px rgba(0,0,0,.25);
  position:sticky;
  top:0;
  z-index:100;
}
.topbar-logo{
  height:68px;
  max-width:520px;
  object-fit:contain;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.35));
}
.topbar-actions{display:flex;gap:8px}
.nav-btn{
  background:rgba(255,255,255,.08);
  color:#dbeafe;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  padding:9px 14px;
  font-weight:700;
  cursor:pointer;
}
.nav-btn.active,.nav-btn:hover{
  background:var(--gold);
  color:#111827;
}
.client-block{text-align:right;color:#fff}
.client-block b{display:block;font-size:21px}
.client-block span{display:block;color:#cbd5e1;font-size:13px;margin-top:4px}

.screen{padding:22px}
.hidden{display:none!important}

.hero-grid{
  display:grid;
  grid-template-columns:minmax(420px, 0.85fr) minmax(680px, 1.55fr);
  gap:22px;
  align-items:stretch;
}
.hero-card{
  background:linear-gradient(145deg, #071827, #102840);
  color:#fff;
  border-radius:28px;
  padding:34px;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.08);
  min-height:620px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-logo{
  width:100%;
  max-width:560px;
  align-self:flex-start;
  margin-bottom:28px;
  filter:drop-shadow(0 12px 25px rgba(0,0,0,.35));
}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--gold);
  font-size:12px;
  font-weight:800;
  margin-bottom:8px;
}
h1{
  font-size:52px;
  line-height:1.02;
  margin:0 0 16px;
  letter-spacing:-1px;
}
.hero-copy{
  color:#cbd5e1;
  font-size:17px;
  line-height:1.55;
  margin:0 0 26px;
}
.hero-stats{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  margin:8px 0 28px;
}
.metric-card{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.07);
  border-radius:18px;
  padding:16px;
}
.metric-card b{
  display:block;
  font-size:27px;
  color:#fff;
  line-height:1;
}
.metric-card span{
  color:#cbd5e1;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-top:7px;
  display:block;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.primary-action,.secondary-action,.back-link{
  border:0;
  border-radius:14px;
  padding:13px 18px;
  font-weight:800;
  cursor:pointer;
}
.primary-action{
  background:var(--gold);
  color:#111827;
  box-shadow:0 10px 25px rgba(212,167,22,.28);
}
.secondary-action{
  background:rgba(255,255,255,.10);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
}
.back-link{
  background:#fff;
  color:#334155;
  border:1px solid var(--line);
  margin-bottom:12px;
}
.back-link.muted{background:#f8fafc;color:#64748b}

.precinct-hero{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  min-height:620px;
  background:#111827;
  box-shadow:var(--shadow);
  border:1px solid rgba(15,23,42,.15);
}
.precinct-hero-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.home-building-overlay{
  position:absolute;
  inset:0;
}
.hero-map-label{
  position:absolute;
  left:24px;
  bottom:24px;
  background:rgba(7,24,39,.88);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  padding:14px 18px;
  border-radius:16px;
  box-shadow:0 12px 30px rgba(0,0,0,.25);
}
.hero-map-label b{display:block;font-size:17px}
.hero-map-label span{color:#cbd5e1;font-size:13px}

.building-hotspot,.mini-building-hotspot{
  position:absolute;
  border:2px solid rgba(212,167,22,.78);
  background:rgba(212,167,22,.06);
  border-radius:14px;
  cursor:pointer;
  transition:.18s ease;
}
.building-hotspot:hover,.mini-building-hotspot:hover{
  background:rgba(212,167,22,.24);
  box-shadow:0 0 0 4px rgba(255,255,255,.75), 0 12px 30px rgba(0,0,0,.22);
}
.building-hotspot span{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  background:rgba(7,24,39,.92);
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  border-radius:13px;
  padding:9px 12px;
  min-width:142px;
  text-align:center;
  font-size:13px;
  line-height:1.25;
  opacity:0;
  transition:.18s ease;
  pointer-events:none;
}
.building-hotspot:hover span{opacity:1}

.commercial-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin:22px 0;
}
.strip-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:20px;
  box-shadow:0 8px 24px rgba(15,23,42,.06);
}
.strip-card span{
  display:inline-flex;
  width:34px;height:34px;
  align-items:center;justify-content:center;
  border-radius:50%;
  background:var(--gold-soft);
  color:#9a6d00;
  font-weight:900;
  margin-bottom:10px;
}
.strip-card b{display:block;font-size:18px}
.strip-card p{color:#64748b;margin:8px 0 0;line-height:1.45}

.building-card-section,.page-shell{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:0 8px 24px rgba(15,23,42,.06);
}
.section-heading,.page-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:18px;
}
h2{margin:0;font-size:25px}
.section-heading p,.panel-heading p,.page-head p{margin:6px 0 0;color:#64748b}
.building-cards{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.building-card,.asset-card,.drawing-card{
  border:1px solid var(--line);
  background:#fff;
  border-radius:20px;
  padding:18px;
  cursor:pointer;
  transition:.18s ease;
}
.building-card:hover,.asset-card:hover,.drawing-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
  border-color:var(--gold);
}
.building-card.active,.asset-card.active,.drawing-card.active{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(212,167,22,.16);
}
.card-kicker{
  color:var(--gold);
  font-size:12px;
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
}
.card-title{
  font-size:22px;
  font-weight:850;
  margin:6px 0;
}
.card-sub{color:#64748b;font-size:13px}
.card-stats{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
  margin-top:14px;
}
.tiny-stat{
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:12px;
  padding:9px;
}
.tiny-stat b{display:block;font-size:16px}
.tiny-stat span{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.7px}

.building-dashboard{
  display:grid;
  grid-template-columns:340px 1fr 1fr;
  gap:18px;
}
.summary-panel,.facade-panel,.drawing-panel{
  border:1px solid var(--line);
  border-radius:22px;
  padding:18px;
  background:#fff;
}
.summary-stats{
  display:grid;
  gap:10px;
  margin-bottom:14px;
}
.summary-stat{
  background:linear-gradient(135deg,#f8fafc,#fff);
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
}
.summary-stat b{font-size:26px;display:block}
.summary-stat span{color:#64748b;text-transform:uppercase;letter-spacing:.8px;font-size:11px}
.mini-map-wrap{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  border:1px solid var(--line);
  min-height:220px;
  background:#0f172a;
}
.mini-map{
  width:100%;
  height:100%;
  min-height:220px;
  object-fit:cover;
  display:block;
}
.mini-map-overlay{position:absolute;inset:0}
.asset-card-grid,.drawing-card-list{
  display:grid;
  gap:10px;
}
.selected-stats{
  font-size:13px;
  color:#475569;
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px;
  background:#f8fafc;
  line-height:1.45;
}

.viewer-layout{
  display:grid;
  grid-template-columns:310px 1fr 390px;
  gap:14px;
  height:calc(100vh - 118px);
}
.viewer-left,.viewer-main,.viewer-right{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:0 8px 24px rgba(15,23,42,.08);
  overflow:hidden;
}
.viewer-left,.viewer-right{
  padding:14px;
  overflow:auto;
}
.viewer-main{
  display:flex;
  flex-direction:column;
}
h3{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1.2px;
  color:#64748b;
  margin:16px 0 8px;
}
.side-list{display:grid;gap:8px}
.side-item{
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  padding:11px;
  cursor:pointer;
  text-align:left;
}
.side-item:hover,.side-item.active{
  border-color:var(--gold);
  box-shadow:0 0 0 2px rgba(212,167,22,.14);
}
.side-item b{display:block}
.meta{font-size:12px;color:#64748b;margin-top:4px;line-height:1.35}
.control-row{display:flex;gap:6px}
.control-row button{
  flex:1;
  border:1px solid var(--line);
  background:#fff;
  border-radius:10px;
  padding:9px;
  font-weight:800;
  cursor:pointer;
}
label{display:block;font-size:13px;color:#475569;margin:8px 0}
input[type=checkbox]{accent-color:var(--gold)}
.legend{
  display:grid;
  gap:7px;
  font-size:13px;
  color:#475569;
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px;
}
.swatch{
  display:inline-block;
  width:16px;height:12px;
  border-radius:3px;
  margin-right:8px;
  vertical-align:-1px;
  border:1px solid rgba(0,0,0,.25);
}
.swatch.si{background:rgba(245,158,11,.38);border-color:#d97706}
.swatch.scope{background:rgba(16,185,129,.38);border-color:#059669}
.swatch.linked{background:rgba(16,185,129,.30);border-color:#059669}
.swatch.empty{background:rgba(37,99,235,.12);border-color:#2563eb}
.swatch.review{background:rgba(220,38,38,.20);border-color:#dc2626}

.viewer-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:20px;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
}
.viewer-title{font-size:19px;font-weight:900}
.viewer-subtitle,.viewer-stats{color:#64748b;font-size:12px;margin-top:3px}
.viewer-stats{text-align:right}
.canvasWrap{
  overflow:auto;
  padding:16px;
  flex:1;
  background:#f8fafc;
}
.empty{
  min-height:500px;
  border:2px dashed var(--line);
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#64748b;
  background:#fff;
}
.stage{
  position:relative;
  display:inline-block;
  background:#fff;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  transform-origin:top left;
}
.stage img{display:block;max-width:none;width:auto}
.layer{position:absolute;inset:0;pointer-events:none}
.box{position:absolute;pointer-events:auto;cursor:pointer}
.grid{
  border:1px solid rgba(37,99,235,.14);
  background:rgba(37,99,235,.05);
  z-index:1;
}
.grid.linked{
  background:rgba(16,185,129,.22);
  border-color:rgba(16,185,129,.55);
}
.grid.review{outline:2px solid rgba(220,38,38,.65)}
#gridLayer{z-index:10}
#labelLayer{z-index:50}
.hotspot{
  z-index:100;
  border:3px dashed var(--orange);
  background:rgba(245,158,11,.32);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:11px;
  color:#111827;
  min-width:72px;
  min-height:28px;
  box-shadow:0 0 0 3px rgba(255,255,255,.88), 0 4px 10px rgba(0,0,0,.20);
}
.hotspot.scope{
  border-color:#047857;
  background:rgba(16,185,129,.38);
  min-width:115px;
  min-height:34px;
}
.hotspot span{
  background:rgba(255,255,255,.90);
  padding:2px 5px;
  border-radius:5px;
  white-space:nowrap;
}
.hotspot:hover{
  outline:4px solid rgba(212,167,22,.95);
  background:rgba(212,167,22,.35);
}

.card{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  margin-bottom:10px;
  background:#fff;
}
.card .k{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:#64748b;
  margin-bottom:4px;
}
.card .v{font-size:13px;word-break:break-word}
.big{font-size:21px;font-weight:900;margin-bottom:8px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.badge{
  display:inline-block;
  border-radius:999px;
  padding:4px 8px;
  font-size:11px;
  font-weight:800;
}
.green{background:rgba(16,185,129,.15);color:#047857}
.blue{background:rgba(37,99,235,.12);color:#1d4ed8}
.gold{background:rgba(212,167,22,.15);color:#9a6d00}
.red{background:rgba(220,38,38,.12);color:#b91c1c}
.path{font-size:11px;color:#64748b;word-break:break-word;margin-top:5px}
small{color:#64748b;line-height:1.45;display:block}
.record-card{border-left:4px solid var(--gold)}
.pdf-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;margin-bottom:6px}
.pdf-btn{
  display:inline-block;
  text-decoration:none;
  background:var(--gold);
  color:#111827;
  font-weight:900;
  border-radius:10px;
  padding:9px 11px;
  font-size:12px;
  border:1px solid rgba(0,0,0,.12);
}
.copy-btn{
  background:#fff;
  border:1px solid var(--line);
  color:#374151;
  font-weight:800;
  border-radius:10px;
  padding:9px 11px;
  font-size:12px;
}
.scopeList{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.scopeJump{
  border:1px solid #059669;
  background:rgba(16,185,129,.10);
  color:#047857;
  border-radius:999px;
  padding:4px 8px;
  font-size:11px;
  cursor:pointer;
}

@media(max-width:1350px){
  .hero-grid{grid-template-columns:1fr}
  .building-dashboard{grid-template-columns:1fr}
  .viewer-layout{grid-template-columns:1fr;height:auto}
  .viewer-left,.viewer-right{max-height:none}
  .topbar{grid-template-columns:1fr auto}
  .client-block{display:none}
}
@media(max-width:850px){
  .building-cards,.commercial-strip,.hero-stats{grid-template-columns:1fr}
  h1{font-size:38px}
  .topbar-logo{height:52px}
}

/* Mobile/tablet precinct map fix */
.precinct-hero{
  height:auto !important;
  min-height:0 !important;
  overflow:visible;
  background:#0f172a;
}
.precinct-hero-img{
  width:100% !important;
  height:auto !important;
  min-height:0 !important;
  object-fit:contain !important;
  display:block !important;
}
.home-building-overlay{
  position:absolute !important;
  inset:0 !important;
  pointer-events:none;
}
.building-hotspot{
  pointer-events:auto;
}
.precinct-stage{
  height:auto !important;
  min-height:0 !important;
  overflow:visible !important;
}
.precinct-img{
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  object-fit:contain !important;
}
.precinct-overlay{
  pointer-events:none;
}
.precinct-overlay .building-hotspot{
  pointer-events:auto;
}

@media(max-width:1350px){
  .hero-grid{
    grid-template-columns:1fr !important;
  }
  .precinct-hero{
    order:-1;
    width:100%;
    margin-bottom:16px;
  }
  .hero-card{
    min-height:auto !important;
  }
}

@media(max-width:900px){
  .screen{
    padding:12px;
  }
  .topbar{
    height:auto;
    min-height:76px;
    grid-template-columns:1fr auto;
    padding:10px 12px;
    gap:10px;
  }
  .topbar-logo{
    height:48px;
    max-width:68vw;
  }
  .topbar-actions{
    gap:4px;
  }
  .nav-btn{
    padding:7px 9px;
    font-size:12px;
  }
  .hero-grid{
    gap:12px;
  }
  .precinct-hero{
    border-radius:18px;
    min-height:0 !important;
  }
  .hero-map-label{
    left:10px;
    bottom:10px;
    padding:9px 11px;
    border-radius:12px;
  }
  .hero-map-label b{
    font-size:13px;
  }
  .hero-map-label span{
    font-size:11px;
  }
  .building-hotspot{
    border-width:2px;
    background:rgba(212,167,22,.16);
    border-radius:8px;
    min-width:22px;
    min-height:22px;
  }
  .building-hotspot span{
    min-width:110px;
    font-size:11px;
    padding:6px 8px;
  }
  .building-hotspot:focus span,
  .building-hotspot:active span{
    opacity:1;
  }
  .hero-card{
    padding:20px;
    border-radius:20px;
  }
  .hero-logo{
    max-width:100%;
    margin-bottom:16px;
  }
  h1{
    font-size:34px;
  }
  .hero-copy{
    font-size:14px;
  }
  .hero-stats{
    grid-template-columns:repeat(2,1fr);
  }
  .metric-card{
    padding:12px;
  }
  .metric-card b{
    font-size:21px;
  }
  .commercial-strip,
  .building-cards{
    grid-template-columns:1fr;
  }
}

@media(max-width:520px){
  .topbar{
    grid-template-columns:1fr;
  }
  .topbar-actions{
    order:2;
    overflow-x:auto;
    padding-bottom:2px;
  }
  .topbar-logo{
    height:42px;
    max-width:94vw;
  }
  .precinct-hero{
    margin-left:-2px;
    margin-right:-2px;
  }
  .hero-stats{
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
  .metric-card span{
    font-size:10px;
  }
}

.pdf-warning{
  display:inline-block;
  color:#b45309;
  background:rgba(245,158,11,.12);
  border:1px solid rgba(245,158,11,.45);
  border-radius:10px;
  padding:9px 11px;
  font-size:12px;
  font-weight:800;
}
