
:root{
  --bg:#020306; --panel:#0b111d; --panel2:#111827; --ink:#f7fbff; --muted:#aab7ca;
  --line:rgba(255,255,255,.14); --red:#e11d2e; --red2:#7d0611; --blue:#287dff;
  --gold:#ffd166; --green:#7dffab; --warn:#ff9f1c;
}
*{box-sizing:border-box}
body{
  margin:0;
  background:
    radial-gradient(circle at 12% 0%,rgba(225,29,46,.31),transparent 34%),
    radial-gradient(circle at 90% 8%,rgba(40,125,255,.21),transparent 36%),
    linear-gradient(180deg,#020306,#05070c 72%,#020306);
  color:var(--ink);
  font-family:Segoe UI,Arial,sans-serif;
}
body:before{
  content:"";position:fixed;inset:0;pointer-events:none;opacity:.16;
  background-image:linear-gradient(rgba(125,255,171,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(125,255,171,.06) 1px,transparent 1px);
  background-size:32px 32px;
}
.wrap{position:relative;z-index:1;width:min(1620px,calc(100% - 28px));margin:auto;padding:24px 0 80px}
.header{
  border:1px solid var(--line);background:rgba(5,7,12,.88);border-radius:30px;padding:20px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;box-shadow:0 28px 90px rgba(0,0,0,.54)
}
.brand{display:flex;align-items:center;gap:16px}
.mark{width:78px;height:78px;border-radius:20px;background:#020306;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;overflow:hidden;box-shadow:0 0 30px rgba(225,29,46,.24)}
.mark svg{width:74px;height:74px}
h1{font-size:clamp(34px,5vw,66px);line-height:.90;letter-spacing:-.055em;margin:0}
.subline{display:block;color:var(--gold);font-weight:950;text-transform:uppercase;letter-spacing:.12em;font-size:12px;margin-top:8px}
.actions,.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
button,.btn,label.btn{
  border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.07);color:#fff!important;text-decoration:none;
  border-radius:999px;padding:10px 13px;font:950 13px/1 Segoe UI,Arial,sans-serif;cursor:pointer;display:inline-flex;gap:7px;align-items:center;justify-content:center
}
button:hover,.btn:hover{border-color:#ff6a78;box-shadow:0 0 24px rgba(225,29,46,.18)}
.primary{background:linear-gradient(135deg,var(--red),var(--red2))!important;border-color:#ff6a78!important}
.blue{background:linear-gradient(135deg,var(--blue),#102a75)!important;border-color:#6ba5ff!important}
.green{background:linear-gradient(135deg,#128a4a,#064d2b)!important;border-color:#7dffab!important}
.gold{background:linear-gradient(135deg,#9b6a00,#5b3d00)!important;border-color:#ffd166!important}
.panel{margin-top:16px;border:1px solid var(--line);background:rgba(11,17,29,.88);border-radius:28px;padding:20px;box-shadow:0 22px 76px rgba(0,0,0,.38)}
.panel h2{font-size:clamp(24px,3.4vw,46px);line-height:.96;letter-spacing:-.04em;margin:0 0 10px}
.panel p{color:var(--muted);line-height:1.58;margin:8px 0}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:16px}
.kpi{border:1px solid var(--line);background:#05070c;border-radius:20px;padding:16px;min-height:112px}
.kpi b{display:block;font-size:34px;color:var(--gold);line-height:1}
.kpi span{display:block;color:var(--muted);font-weight:800;margin-top:7px}
label.caption{display:block;color:#ffd166;font-weight:950;font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 6px}
input,select,textarea{
  width:100%;border:1px solid rgba(255,255,255,.15);background:#05070c;color:#fff;border-radius:14px;padding:11px 12px;
  font:500 14px/1.45 Segoe UI,Arial,sans-serif;outline:none
}
input:focus,select:focus,textarea:focus{border-color:#6ba5ff;box-shadow:0 0 0 3px rgba(40,125,255,.16)}
textarea{min-height:98px}
.note,.goodnote{border-radius:18px;padding:14px;line-height:1.5;margin-top:12px}
.note{border:1px solid rgba(255,209,102,.34);background:rgba(255,209,102,.08);color:#fff3c6}
.goodnote{border:1px solid rgba(125,255,171,.34);background:rgba(125,255,171,.08);color:#d8ffe5}
.card{border:1px solid rgba(255,255,255,.12);background:linear-gradient(145deg,rgba(18,26,39,.86),rgba(7,10,16,.95));border-radius:22px;padding:18px;min-height:150px}
.card b{display:block;font-size:18px;margin-bottom:8px}.card span,.card p{color:var(--muted);line-height:1.45;margin:0}
.card .big{font-size:28px;color:var(--gold);font-weight:950}
.tablewrap{overflow:auto;border:1px solid rgba(255,255,255,.12);border-radius:22px;max-height:72vh;background:#05070c;margin-top:14px}
table{width:100%;border-collapse:separate;border-spacing:0;min-width:1100px;font-size:13px}
th,td{border-bottom:1px solid rgba(255,255,255,.08);padding:12px;text-align:left;vertical-align:top}
th{position:sticky;top:0;z-index:2;background:#111827;color:#fff;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
td{color:#d5e2f7}
.pill{display:inline-flex;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:4px 7px;font-size:11px;font-weight:950;color:#fff;margin:2px}
.pill.red{border-color:#ff6a78;background:rgba(225,29,46,.18)}
.pill.gold{border-color:#ffd166;background:rgba(255,209,102,.12);color:#fff3c6}
.pill.blue{border-color:#6ba5ff;background:rgba(40,125,255,.12)}
.pill.green{border-color:#7dffab;background:rgba(125,255,171,.10);color:#d8ffe5}
.zoneRow{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr auto;gap:8px;align-items:end;margin:10px 0;padding:10px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(255,255,255,.035)}
.mapCard{border:1px solid rgba(255,255,255,.12);background:#05070c;border-radius:22px;padding:12px;min-height:360px}
.mapTitle{font-weight:900;color:#ffd166;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.mapFrame{width:100%;height:360px;border:none;border-radius:16px;background:#111827}
.aerialImage{width:100%;height:360px;object-fit:cover;border-radius:16px;background:#111827;border:1px solid rgba(255,255,255,.08)}
.plannerBoard{
  position:relative;height:560px;border:1px solid rgba(255,255,255,.14);border-radius:22px;background:
  linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),
  #05070c;
  background-size:32px 32px,32px 32px,auto;
  background-position:0 0,0 0,center center;background-repeat:repeat,repeat,no-repeat;
  overflow:hidden;margin-top:12px
}
.plannerHint{position:absolute;inset:18px auto auto 18px;background:rgba(5,7,12,.86);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:10px 12px;color:#d5e2f7;max-width:330px}
.marker{
  position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;gap:6px;
  background:rgba(5,7,12,.92);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:5px 8px;font-size:12px;font-weight:900;color:#fff;white-space:nowrap;box-shadow:0 10px 28px rgba(0,0,0,.38)
}
.marker[data-type="camera"]{border-color:#ff6a78}
.marker[data-type="entry"]{border-color:#ffd166}
.marker[data-type="nvr"], .marker[data-type="rack"], .marker[data-type="switch"]{border-color:#6ba5ff}
.marker[data-type="fiber"], .marker[data-type="coax"], .marker[data-type="ap"]{border-color:#7dffab}
.marker .icon{font-size:15px}
.miniList{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
.miniList .item{border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:10px;background:#05070c;color:#d5e2f7;font-size:12px}
.quoteCard{border:1px solid rgba(255,255,255,.12);background:linear-gradient(145deg,rgba(18,26,39,.86),rgba(7,10,16,.95));border-radius:22px;padding:18px}
.quoteCard h3{margin:0 0 10px;font-size:20px}
.quoteLinks{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.small{font-size:12px;color:#9fb0c7}
.hidden{display:none!important}
.proposal{background:#fff;color:#111;border-radius:18px;padding:24px;font-family:Segoe UI,Arial,sans-serif}
.proposal h2,.proposal h3{color:#7d0611}.proposal p,.proposal td{color:#222}.proposal table{min-width:0;border-collapse:collapse}.proposal th{background:#111827;color:#fff;position:static}.proposal td,.proposal th{border:1px solid #ddd}
.footer{text-align:center;color:var(--muted);padding:28px 0}
@media(max-width:1120px){.grid{grid-template-columns:1fr 1fr}.grid3{grid-template-columns:1fr}.grid2{grid-template-columns:1fr}.zoneRow{grid-template-columns:1fr 1fr}.header{flex-direction:column;align-items:flex-start}.miniList{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.grid{grid-template-columns:1fr}.zoneRow{grid-template-columns:1fr}.mark{width:60px;height:60px}h1{font-size:32px}.plannerBoard{height:420px}.miniList{grid-template-columns:1fr}}
@media print{body:before,.actions,.toolbar,.panel:not(.printable){display:none!important}.wrap{width:100%;padding:0}.proposal{box-shadow:none}.header{display:none}.printable{border:none;box-shadow:none;background:#fff;padding:0}}



/* V3.1 Public Records / Site Intelligence Add-on */
.intelPanel{
  margin-top:16px;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 10% 0%,rgba(225,29,46,.22),transparent 32%),
    radial-gradient(circle at 92% 4%,rgba(40,125,255,.18),transparent 36%),
    linear-gradient(145deg,rgba(11,17,29,.90),rgba(5,7,12,.97));
  border-radius:28px;
  padding:20px;
  box-shadow:0 22px 76px rgba(0,0,0,.38);
}
.intelPanel h2{font-size:clamp(25px,3.7vw,48px);line-height:.96;letter-spacing:-.04em;margin:0 0 10px}
.intelGrid{display:grid;grid-template-columns:1.05fr .95fr;gap:16px;margin-top:14px}
.intelLinks{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.intelLinks a,.intelLinks button{
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.07);
  color:#fff!important;
  text-decoration:none;
  border-radius:999px;
  padding:10px 12px;
  font:950 12px/1 Segoe UI,Arial,sans-serif;
  cursor:pointer;
}
.intelLinks .primary{background:linear-gradient(135deg,#e11d2e,#7d0611)!important;border-color:#ff6a78!important}
.intelLinks .blue{background:linear-gradient(135deg,#287dff,#102a75)!important;border-color:#6ba5ff!important}
.intelLinks .green{background:linear-gradient(135deg,#128a4a,#064d2b)!important;border-color:#7dffab!important}
.docDrop{
  border:1px dashed rgba(255,255,255,.22);
  border-radius:20px;
  padding:16px;
  background:#05070c;
}
.docList{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px}
.docCard{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  border-radius:18px;
  padding:12px;
  color:#d5e2f7;
  min-height:110px;
}
.docCard b{display:block;color:#fff;margin-bottom:5px}
.docCard small{display:block;color:#9fb0c7;word-break:break-all}
.docCard img{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  margin:8px 0;
}
.docCard .docActions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.docCard .docActions button,.docCard .docActions a{
  color:#fff!important;text-decoration:none;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);border-radius:999px;padding:7px 9px;font-size:11px;font-weight:900;cursor:pointer
}
.intelStatus{
  border:1px solid rgba(125,255,171,.28);
  background:rgba(125,255,171,.08);
  color:#d8ffe5;
  border-radius:18px;
  padding:12px;
  line-height:1.45;
  margin-top:12px;
}
.intelWarn{
  border:1px solid rgba(255,209,102,.34);
  background:rgba(255,209,102,.08);
  color:#fff3c6;
  border-radius:18px;
  padding:12px;
  line-height:1.45;
  margin-top:12px;
}
@media(max-width:980px){.intelGrid,.docList{grid-template-columns:1fr}}


/* RedHawk V6.8.6 - camera app site integration */
.rhd-site-bridge{
  margin:0 0 14px;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 5% 0%,rgba(225,29,46,.22),transparent 34%),
    linear-gradient(135deg,rgba(8,11,18,.92),rgba(2,3,6,.95));
  border-radius:22px;
  padding:13px 15px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.rhd-site-bridge b{color:#fff;font-size:14px;letter-spacing:.08em;text-transform:uppercase}
.rhd-site-bridge span{color:#aab7ca;font-size:13px}
.rhd-site-bridge .bridge-links{display:flex;gap:8px;flex-wrap:wrap}
.rhd-site-bridge .bridge-links a{
  display:inline-flex;
  color:#fff!important;
  text-decoration:none!important;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.07);
  border-radius:999px;
  padding:8px 11px;
  font-weight:950;
  font-size:12px;
}
.rhd-site-bridge .bridge-links a.primary{
  background:linear-gradient(135deg,#e11d2e,#7d0611);
  border-color:#ff6a78;
}
.header .mark img,.topbar .mark img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
