/* ============================================================
   FOOTING — Linear/Vercel precision design system
   CSS-layer redesign. Every selector preserved for app.js.
   ============================================================ */
:root{
  --bg:#0a0c10;
  --panel:#0d1014;
  --panel-2:#13171e;
  --line:#1c222c;          /* hairline border */
  --line-soft:#161b22;
  --ink:#e7ebf2;
  --ink-soft:#9aa6b6;
  --muted:#5b6675;
  --neon:#1fe6a4;          /* signal green — used sparingly */
  --neon-dim:#16b682;
  --amber:#ffc24b;
  --danger:#ff6b6b;
  --blue:#5aa8ff;
  --shadow:0 12px 40px rgba(0,0,0,.55);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --r:10px;
  --r-sm:8px;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-0.011em;
}
#app{display:flex;height:100vh;width:100vw;overflow:hidden}

/* ---------- PANEL ---------- */
#panel{
  width:430px; min-width:430px; height:100%;
  background:var(--panel);
  border-right:1px solid var(--line);
  display:flex; flex-direction:column;
  overflow-y:auto; overflow-x:hidden;
}
#panel::-webkit-scrollbar{width:8px}
#panel::-webkit-scrollbar-thumb{background:#1b212b;border-radius:8px}
#panel::-webkit-scrollbar-thumb:hover{background:#252d3a}

.panel-head{
  padding:24px 24px 16px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),transparent);
  border-bottom:1px solid var(--line-soft);
}
.mark{display:flex;align-items:center;gap:10px}
.mark-pin{
  width:14px;height:14px;border-radius:50% 50% 50% 0;
  background:var(--neon);transform:rotate(-45deg);
  box-shadow:0 0 0 3px rgba(31,230,164,.12);
}
.mark-word{font-weight:800;font-size:20px;letter-spacing:-.03em}
.mark-word em{font-style:normal;font-weight:800;color:var(--neon)}
.kicker{margin:11px 0 0;color:var(--ink-soft);font-size:13px;line-height:1.5;letter-spacing:-.005em}
.metro-wrap{margin:16px 0 0;display:flex;align-items:center;gap:9px}
.metro-wrap label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
#metro{flex:1;padding:10px 12px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);
  color:var(--ink);font-size:13.5px;font-family:inherit;font-weight:600;cursor:pointer;transition:.15s}
#metro:hover{border-color:#2a3340}
#metro:focus{outline:none;border-color:var(--neon);box-shadow:0 0 0 3px rgba(31,230,164,.14)}
#metro optgroup{color:var(--muted);font-weight:700;font-style:normal}
#metro option{color:var(--ink);font-weight:600}

/* ---------- STEPS ---------- */
.step{padding:18px 24px;border-top:1px solid var(--line-soft)}
.step-label{margin:0 0 13px;font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:10px;letter-spacing:-.01em}
.step-n{
  display:grid;place-items:center;width:20px;height:20px;border-radius:6px;
  background:rgba(31,230,164,.12);color:var(--neon);font-size:11px;font-weight:700;
  border:1px solid rgba(31,230,164,.25);font-family:var(--mono);
}
.concepts{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.concept{
  display:flex;align-items:center;gap:9px;padding:11px 13px;
  background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);
  cursor:pointer;font-size:13px;font-weight:500;color:var(--ink-soft);
  transition:border-color .15s,background .15s,color .15s,transform .1s;text-align:left;
}
.concept:hover{border-color:#2a3340;color:var(--ink);background:#161b23}
.concept:active{transform:translateY(1px)}
.concept .ico{font-size:16px;line-height:1}
.concept.on{
  border-color:rgba(31,230,164,.55);color:var(--ink);
  background:linear-gradient(180deg,rgba(31,230,164,.1),rgba(31,230,164,.02));
  box-shadow:inset 0 0 0 1px rgba(31,230,164,.25);
}

.site-row{display:flex;gap:8px}
#addr{
  flex:1;padding:11px 13px;background:var(--panel-2);border:1px solid var(--line);
  border-radius:var(--r-sm);color:var(--ink);font-size:13.5px;font-family:inherit;transition:.15s;
}
#addr:focus{outline:none;border-color:var(--neon);box-shadow:0 0 0 3px rgba(31,230,164,.14)}
#addr::placeholder{color:var(--muted)}
.ghost-btn{
  padding:0 14px;background:transparent;border:1px solid var(--line);border-radius:var(--r-sm);
  color:var(--ink-soft);font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap;transition:.15s;
}
.ghost-btn:hover{border-color:#2a3340;color:var(--ink)}
.site-hint{margin:11px 0 0;font-size:12.5px;color:var(--muted)}
.site-hint strong{color:var(--ink-soft);font-weight:600}

/* ---------- REPORT ---------- */
.report{padding:20px 24px 6px;border-top:1px solid var(--line)}
.report-head{display:flex;gap:16px;align-items:center}
.score-ring{
  position:relative;width:88px;height:88px;border-radius:50%;flex:none;
  display:grid;place-items:center;
  background:conic-gradient(var(--ring-c,var(--neon)) var(--ring-deg,0deg),#171c25 0deg);
  transition:.6s;
}
.score-ring::after{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--panel)}
.score-num{position:relative;font-family:var(--mono);font-size:30px;font-weight:700;line-height:1;z-index:1;letter-spacing:-.02em}
.score-of{position:relative;font-size:10px;color:var(--muted);z-index:1;margin-top:3px;font-family:var(--mono)}
.report-headtext{min-width:0}
.report-verdict{margin:0;font-size:16px;font-weight:700;letter-spacing:-.02em}
.report-addr{margin:5px 0 0;font-size:12.5px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis}
.report-concept{margin:2px 0 0;font-size:12px;color:var(--muted)}
.report-takeaway{
  margin:16px 0 16px;font-size:13.5px;line-height:1.6;color:var(--ink-soft);
  padding:13px 15px;background:var(--panel-2);border:1px solid var(--line-soft);border-left:2px solid var(--neon);border-radius:0 var(--r-sm) var(--r-sm) 0;
}

/* market-gap callout */
.gap-callout{margin:0 0 16px;padding:12px 14px;border-radius:var(--r-sm);
  background:var(--panel-2);border:1px solid var(--line);border-left:2px solid var(--gc,var(--ink-soft))}
.gap-callout[hidden]{display:none}
.gap-label{display:inline-block;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-right:8px}
.gap-text{font-size:12.5px;color:var(--ink-soft);line-height:1.5}

/* subscores */
.subscores{display:flex;flex-direction:column;gap:12px}
.sub{display:grid;grid-template-columns:1fr auto;gap:4px 10px}
.sub-top{display:flex;justify-content:space-between;align-items:baseline;grid-column:1/-1}
.sub-name{font-size:12.5px;font-weight:500;color:var(--ink)}
.sub-val{font-size:12px;font-weight:600;font-family:var(--mono);font-variant-numeric:tabular-nums}
.sub-bar{grid-column:1/-1;height:5px;background:#141a22;border-radius:6px;overflow:hidden}
.sub-bar > i{display:block;height:100%;border-radius:6px;transition:width .6s}
.sub-note{grid-column:1/-1;font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.45}

/* rent card (the moat) */
.rentcard{margin:20px 0 0;padding:15px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r)}
.rentcard-title{margin:0 0 12px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.moat-tag{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(90,168,255,.12);color:var(--blue);padding:3px 8px;border-radius:6px;border:1px solid rgba(90,168,255,.25)}
.rent-rows{display:flex;flex-direction:column;gap:8px}
.rent-line{display:flex;justify-content:space-between;font-size:12.5px}
.rent-line span:first-child{color:var(--ink-soft)}
.rent-line span:last-child{font-weight:600;font-family:var(--mono);font-variant-numeric:tabular-nums}
.rent-verdict{margin:12px 0 0;font-size:12.5px;font-weight:500;line-height:1.5;padding-top:12px;border-top:1px solid var(--line-soft)}

/* competitors */
.compblock{margin:20px 0 0}
.compblock-title{margin:0 0 10px;font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.complist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px;max-height:168px;overflow-y:auto}
.complist li{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;
  padding:9px 11px;background:var(--panel-2);border-radius:var(--r-sm);border:1px solid var(--line-soft)}
.complist .c-name{color:var(--ink);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.complist .c-dist{color:var(--muted);flex:none;font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:11.5px}
.complist .empty{color:var(--muted);font-style:italic;border-style:dashed}

/* actions */
.report-actions{margin:22px 0 4px}
.primary-btn{
  width:100%;padding:14px;border:none;border-radius:var(--r);cursor:pointer;
  background:var(--neon);color:#04120c;font-size:14.5px;font-weight:700;font-family:inherit;letter-spacing:-.01em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 8px 24px rgba(31,230,164,.16);transition:transform .12s,background .15s,box-shadow .15s;
}
.primary-btn:hover{background:#2af0b2;transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 12px 30px rgba(31,230,164,.24)}
.primary-btn:active{transform:translateY(0)}
.report-pricehint{margin:12px 0 0;font-size:11.5px;line-height:1.55;color:var(--muted);text-align:center}

/* foot */
.panel-foot{margin-top:auto;padding:18px 24px 24px;border-top:1px solid var(--line-soft)}
.src{margin:0;font-size:11px;line-height:1.6;color:var(--muted)}
.src strong{color:var(--ink-soft);font-weight:600}

/* ---------- MAP ---------- */
#map-wrap{position:relative;flex:1;height:100%}
#map{position:absolute;inset:0}
.map-badge{
  position:absolute;top:18px;left:50%;transform:translateX(-50%);
  background:rgba(13,16,20,.72);backdrop-filter:blur(14px) saturate(1.3);
  border:1px solid var(--line);color:var(--ink-soft);
  padding:8px 16px;border-radius:30px;font-size:12.5px;font-weight:500;
  pointer-events:none;box-shadow:var(--shadow);z-index:2;
}
/* basemap switcher */
.basemap-switch{
  position:absolute;top:18px;left:18px;z-index:3;display:flex;gap:0;
  background:rgba(13,16,20,.72);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);
  border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow);
}
.basemap-switch button{
  background:transparent;border:none;color:var(--ink-soft);font-family:inherit;
  font-size:12px;font-weight:600;padding:8px 14px;cursor:pointer;border-right:1px solid var(--line-soft);transition:.15s;
}
.basemap-switch button:last-child{border-right:none}
.basemap-switch button:hover{color:var(--ink);background:rgba(255,255,255,.03)}
.basemap-switch button.on{background:var(--neon);color:#04120c}

/* legend */
.map-legend{
  position:absolute;bottom:18px;left:18px;z-index:3;display:flex;gap:14px;flex-wrap:wrap;
  background:rgba(13,16,20,.72);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:9px 14px;box-shadow:var(--shadow);font-size:11.5px;color:var(--ink-soft);
}
.map-legend .lg{display:flex;align-items:center;gap:6px}
.map-legend .lg::before{content:"";width:9px;height:9px;border-radius:50%}
.map-legend .lg-indie::before{background:#3a4b60}
.map-legend .lg-chain::before{background:#7d6a3a}
.map-legend .lg-comp::before{background:#ff6b6b}

.maplibregl-popup-content{
  background:var(--panel);color:var(--ink);border:1px solid var(--line);
  border-radius:var(--r-sm);font-family:inherit;font-size:12.5px;padding:9px 12px;box-shadow:var(--shadow);
}
.maplibregl-popup-tip{border-top-color:var(--panel)!important;border-bottom-color:var(--panel)!important}

/* candidate site pulse marker */
.site-marker{
  width:18px;height:18px;border-radius:50%;background:var(--neon);
  box-shadow:0 0 0 0 rgba(31,230,164,.55);border:2px solid #04120c;
  animation:pulse 2s infinite;cursor:pointer;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(31,230,164,.5)}
  70%{box-shadow:0 0 0 15px rgba(31,230,164,0)}
  100%{box-shadow:0 0 0 0 rgba(31,230,164,0)}
}

/* mode toggle */
.mode-toggle{margin:16px 0 0;display:flex;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:3px;gap:3px}
.mode-toggle button{flex:1;background:transparent;border:none;color:var(--ink-soft);font-family:inherit;
  font-size:12.5px;font-weight:600;padding:9px;border-radius:6px;cursor:pointer;transition:.15s;letter-spacing:-.01em}
.mode-toggle button:hover{color:var(--ink)}
.mode-toggle button.on{background:var(--neon);color:#04120c;font-weight:700}

/* opportunity view */
.opp{padding:20px 24px;border-top:1px solid var(--line)}
.opp-head{margin:0;font-size:21px;font-weight:800;letter-spacing:-.03em}
.opp-head strong{color:var(--neon);font-weight:800}
.opp-peers{margin:7px 0 18px;font-size:12px;color:var(--muted);line-height:1.5}

/* metro personality card */
.pers-card{margin:14px 0 4px;padding:15px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r)}
.pers-title{margin:0 0 8px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue)}
.pers-blurb{margin:0 0 13px;font-size:13.5px;line-height:1.55;color:var(--ink)}
.pers-bar{height:8px;border-radius:6px;overflow:hidden;background:#7d6a3a;display:flex}
.pers-bar .pers-local{display:block;height:100%;background:var(--neon)}
.pers-bar-label{margin:8px 0 0;font-size:11.5px;color:var(--ink-soft)}
.pers-bar-label strong{color:var(--ink);font-weight:700;font-family:var(--mono);font-variant-numeric:tabular-nums}
.pers-sig{margin:9px 0 0;font-size:11.5px;color:var(--muted)}
.pers-sig span{color:var(--ink-soft)}
.opp-section-label{margin:18px 0 10px;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--neon)}
.opp-section-label.dim{color:var(--muted)}
.opp-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.opp-list li{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);padding:12px 14px}
.opp-row-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.opp-cat{font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.opp-more{font-size:12px;font-weight:700;color:var(--neon);white-space:nowrap;font-family:var(--mono)}
.opp-list.over .opp-more{color:var(--amber)}
.opp-detail{margin:5px 0 0;font-size:11.5px;color:var(--muted);line-height:1.45}
.opp-idea-btn{margin-top:10px;width:100%;background:transparent;border:1px solid rgba(31,230,164,.4);color:var(--neon);
  font-family:inherit;font-size:12px;font-weight:600;padding:9px;border-radius:var(--r-sm);cursor:pointer;transition:.15s}
.opp-idea-btn:hover{background:rgba(31,230,164,.1);border-color:var(--neon)}
.opp-idea-btn:disabled{opacity:.6;cursor:wait}
.idea-box{margin:18px 0 0;padding:16px;background:linear-gradient(180deg,rgba(31,230,164,.09),rgba(31,230,164,.02));
  border:1px solid rgba(31,230,164,.3);border-radius:var(--r)}
.idea-kicker{margin:0 0 9px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--neon)}
.idea-body{font-size:13px;line-height:1.6;color:var(--ink)}
.idea-body h4{margin:11px 0 2px;font-size:14.5px;color:var(--ink);letter-spacing:-.01em}
.idea-body em{color:var(--ink-soft);font-style:italic}
.plan-cta{background:var(--neon)!important;color:#04120c!important;border-color:var(--neon)!important}
.plan-cta:hover{background:#2af0b2!important}
.plan-locked{margin:13px 0 0;font-size:11.5px;color:var(--muted);line-height:1.55}
.opp-src{margin:16px 0 0;font-size:11px;color:var(--muted);line-height:1.55}

/* ---------- Footing Opportunity Score — concept ranking ---------- */
.rankblock{margin:18px 0 0}
.rank-btn{
  width:100%;padding:11px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);
  color:var(--ink);font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;transition:.15s;letter-spacing:-.01em;
}
.rank-btn:hover{border-color:rgba(31,230,164,.5);color:var(--neon)}
.rank-list{list-style:none;margin:11px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}
.rank-list[hidden]{display:none}
.rank-head{display:grid;grid-template-columns:20px 22px 1fr auto 34px;gap:9px;align-items:center;
  font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:2px 4px 6px}
.rank-head span:nth-child(3){grid-column:3}
.rank-row{display:grid;grid-template-columns:20px 22px 1fr auto 34px;gap:9px;align-items:center;
  padding:9px 10px;background:var(--panel-2);border:1px solid var(--line-soft);border-radius:var(--r-sm);
  cursor:pointer;transition:.13s}
.rank-row:hover{border-color:#2a3340;transform:translateX(2px)}
.rank-row.cur{border-color:rgba(31,230,164,.4);background:linear-gradient(180deg,rgba(31,230,164,.07),transparent)}
.rank-i{font-family:var(--mono);font-size:11px;color:var(--muted);text-align:center;font-variant-numeric:tabular-nums}
.rank-ico{font-size:15px;line-height:1;text-align:center}
.rank-name{font-size:12.5px;font-weight:500;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rank-name em{color:var(--neon);font-style:normal;font-weight:600;font-size:11px}
.rank-tag{font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;padding:2px 7px;border-radius:5px}
.rank-tag[data-cls=good]{color:var(--neon);background:rgba(31,230,164,.12)}
.rank-tag[data-cls=ok]{color:#9be86b;background:rgba(155,232,107,.1)}
.rank-tag[data-cls=warn]{color:var(--amber);background:rgba(255,194,75,.1)}
.rank-tag[data-cls=bad]{color:var(--danger);background:rgba(255,107,107,.1)}
.rank-score{font-family:var(--mono);font-size:15px;font-weight:700;text-align:right;font-variant-numeric:tabular-nums}

/* ---------- agency prospect funnel ---------- */
.prospects{margin:20px 0 0;padding:15px;background:linear-gradient(180deg,rgba(90,168,255,.07),rgba(90,168,255,.015));
  border:1px solid rgba(90,168,255,.28);border-radius:var(--r)}
.prospects[hidden]{display:none}
.prospects-title{margin:0 0 10px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.prospects-lead{margin:0;font-size:12.5px;line-height:1.55;color:var(--ink-soft)}
.prospects-lead strong{color:var(--ink);font-weight:700}
.prospects-list{margin:11px 0 0;max-height:150px}
.prospects-note{margin:10px 0 0;font-size:11px;color:var(--muted);line-height:1.5}

/* lead-capture modal */
.modal-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;
  background:rgba(5,7,11,.7);backdrop-filter:blur(6px)}
.modal-backdrop[hidden]{display:none}
.modal{position:relative;width:min(424px,92vw);background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:28px 28px 24px;box-shadow:var(--shadow)}
.modal-x{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--muted);
  font-size:22px;line-height:1;cursor:pointer;transition:.15s}
.modal-x:hover{color:var(--ink)}
.modal-kicker{margin:0;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--neon);font-weight:700}
.modal h2{margin:8px 0 4px;font-size:22px;font-weight:800;letter-spacing:-.03em}
.modal-sub{margin:0 0 20px;font-size:13px;color:var(--ink-soft);line-height:1.55}
#lead-form{display:flex;flex-direction:column;gap:13px}
#lead-form label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--ink-soft)}
#lead-form .req{color:var(--neon)}
#lead-form input,#lead-form select{padding:11px 13px;background:var(--panel-2);border:1px solid var(--line);
  border-radius:var(--r-sm);color:var(--ink);font-size:14px;font-family:inherit;transition:.15s}
#lead-form input:focus,#lead-form select:focus{outline:none;border-color:var(--neon);box-shadow:0 0 0 3px rgba(31,230,164,.14)}
.modal-cta{margin-top:7px;padding:14px;border:none;border-radius:var(--r);cursor:pointer;
  background:var(--neon);color:#04120c;font-size:14.5px;font-weight:700;font-family:inherit;letter-spacing:-.01em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 8px 24px rgba(31,230,164,.16);transition:.15s}
.modal-cta:hover{background:#2af0b2}
.modal-cta:disabled{opacity:.6;cursor:wait}
.modal-fine{margin:11px 0 0;font-size:11px;color:var(--muted);text-align:center;line-height:1.55}

@media (max-width:880px){
  #app{flex-direction:column}
  #panel{width:100%;min-width:0;height:auto;max-height:62vh;order:2;border-right:none;border-top:1px solid var(--line)}
  #map-wrap{order:1;height:38vh;flex:none}
}
