/* StreetLightingFla visual system - visual pass applied by Hermes */
:root{
  --ink:#0b1220;
  --ink-2:#111827;
  --slate:#172033;
  --slate-2:#223047;
  --muted:#64748b;
  --line:#d7dfeb;
  --soft:#f6f7ef;
  --soft-2:#eef3ea;
  --panel:#ffffff;
  --brand:#facc15;
  --brand-2:#f59e0b;
  --accent:#2563eb;
  --green:#22c55e;
  --green-2:#16a34a;
  --ok:#12805c;
  --warn:#b7791f;
  --bad:#b42318;
  --night:#07111f;
  --shadow:0 22px 60px rgba(8,15,30,.14);
  --shadow-soft:0 12px 34px rgba(15,23,42,.10);
  --radius:24px;
}
*{box-sizing:border-box}
html{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:var(--soft);line-height:1.55;text-rendering:optimizeLegibility;overflow-x:hidden;max-width:100%}
body{margin:0;background:linear-gradient(180deg,#f7f5e9 0,#f8fafc 36%,#f5f7ef 100%);overflow-x:hidden}
a{color:#0f5cc0;text-decoration:none}
a:hover{text-decoration:none;color:#0b4ca0}.wrap{width:min(1180px,calc(100% - 32px));margin:0 auto}
.top{position:sticky;top:0;z-index:30;background:rgba(7,17,31,.96);backdrop-filter:blur(14px);border-bottom:1px solid rgba(250,204,21,.18);box-shadow:0 10px 28px rgba(7,17,31,.18)}
.top:after{content:"";display:block;height:3px;background:repeating-linear-gradient(90deg,var(--brand) 0 72px,transparent 72px 96px,var(--green) 96px 104px,transparent 104px 132px)}
.top-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:13px 0}.brand{font-weight:900;letter-spacing:-.025em;color:#f8fafc}.brand span{color:var(--brand)}.nav{display:flex;gap:8px;flex-wrap:wrap;font-size:.93rem;scrollbar-width:none;-ms-overflow-style:none;overscroll-behavior-inline:contain}.nav::-webkit-scrollbar,.chip-row::-webkit-scrollbar{display:none}.nav a{color:#cbd5e1;padding:8px 10px;border-radius:999px;border:1px solid transparent}.nav a:hover{color:var(--brand);background:rgba(250,204,21,.08);border-color:rgba(250,204,21,.22)}
.hero{padding:72px 0 54px;background:radial-gradient(circle at 88% 18%,rgba(250,204,21,.14),transparent 30%),radial-gradient(circle at 7% 35%,rgba(34,197,94,.12),transparent 26%),linear-gradient(135deg,#07111f,#101827 54%,#172033)}
.hero-grid{display:grid;grid-template-columns:1.03fr .97fr;gap:38px;align-items:center}.hero-copy{color:#f8fafc;position:relative;isolation:isolate}.hatch-bg:before{content:"";position:absolute;inset:-26px -16px -20px -20px;z-index:-1;opacity:.18;background:repeating-linear-gradient(135deg,transparent 0 13px,rgba(250,204,21,.35) 13px 15px,transparent 15px 28px);border-radius:32px}.kicker,.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;font-weight:900;color:var(--brand)}.kicker{display:inline-flex;padding:7px 11px;border:1px solid rgba(250,204,21,.35);border-radius:999px;background:rgba(250,204,21,.09)}.hero h1{font-size:clamp(2.25rem,5.2vw,5.35rem);line-height:.94;margin:16px 0 18px;letter-spacing:-.068em;color:#fff;max-width:820px}.lead{font-size:1.12rem;color:#334155;max-width:760px;overflow-wrap:anywhere}.hero .lead{color:#d9e5f3}.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:25px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 19px;border-radius:999px;border:1px solid rgba(250,204,21,.7);background:var(--brand);color:#111827;font-weight:850;box-shadow:0 14px 34px rgba(250,204,21,.24);transition:.18s transform,.18s box-shadow,.18s border-color}.btn.secondary{background:#f8fafc;color:#0f172a;border-color:#d8e0ea;box-shadow:0 10px 26px rgba(0,0,0,.12)}.btn.ghost{background:#f8fafc;color:#0f172a;border-color:#e2e8f0;box-shadow:none}.btn:hover{transform:translateY(-1px);box-shadow:0 18px 40px rgba(250,204,21,.28)}.chip-row,.pillrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;scrollbar-width:none;-ms-overflow-style:none}.meas-chip,.pillrow span{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:7px 10px;font-size:.78rem;font-weight:850;letter-spacing:.02em;color:#fde68a;background:rgba(250,204,21,.08);border:1px solid rgba(250,204,21,.25)}.meas-chip:before{content:"";width:12px;height:3px;background:var(--brand);border-radius:99px}.context-note{margin-top:18px;color:#b7c6d8;font-size:.96rem;max-width:690px}.mock{background:linear-gradient(180deg,#0b1425,#060b14);border:1px solid rgba(148,163,184,.18);border-radius:30px;padding:17px;box-shadow:var(--shadow);color:#dbeafe}.mock svg{width:100%;height:auto;display:block;border-radius:22px;background:#07111f}.board-label{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 3px 11px;color:#cbd5e1;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em}.board-label b{color:var(--brand)}.statbar{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}.statbar div{background:rgba(255,255,255,.055);border:1px solid rgba(148,163,184,.22);border-radius:14px;padding:12px 10px;min-width:0}.statbar b{color:#f8fafc;font-size:1.05rem}.statbar span{display:block;color:#cbd5e1;font-size:.86rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section{padding:62px 0;background:#f8fafc}.section.alt{background:linear-gradient(180deg,#0b1220,#111827);color:#e5edf7;position:relative}.section.alt:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:repeating-linear-gradient(90deg,var(--brand) 0 80px,transparent 80px 106px)}.section h1{font-size:clamp(2.15rem,4.6vw,4.4rem);line-height:1;margin:10px 0 16px;letter-spacing:-.055em}.section h2{font-size:clamp(1.75rem,3vw,2.75rem);line-height:1.04;margin:0 0 16px;letter-spacing:-.04em}.section h3{letter-spacing:-.02em}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:22px;position:relative;padding-left:18px}.section-head:before{content:"";position:absolute;left:0;top:3px;bottom:5px;width:5px;border-radius:99px;background:linear-gradient(var(--brand),var(--green))}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{position:relative;display:flex;flex-direction:column;min-height:230px;background:linear-gradient(180deg,#fff,#f9fbff);border:1px solid #dbe4ef;border-radius:22px;padding:22px;box-shadow:var(--shadow-soft);color:var(--ink);overflow:hidden;transition:.18s transform,.18s box-shadow,.18s border-color}.card:before{content:"";position:absolute;inset:0 0 auto;height:6px;background:linear-gradient(90deg,var(--brand),rgba(250,204,21,.15),var(--green));opacity:.85}.card:after{content:"";position:absolute;right:-38px;top:-42px;width:140px;height:140px;border-radius:999px;background:radial-gradient(circle,rgba(250,204,21,.18),transparent 62%)}.card:hover{transform:translateY(-4px);border-color:rgba(250,204,21,.95);box-shadow:0 22px 52px rgba(15,23,42,.16)}.card.feature{background:linear-gradient(180deg,#0f172a,#172033);color:#f8fafc;border-color:rgba(250,204,21,.34)}.card.feature p{color:#c9d6e6}.card-icon{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;margin:7px 0 10px;border-radius:15px;background:#0b1220;color:var(--brand);font-size:.78rem;font-weight:950;letter-spacing:.04em;border:1px solid rgba(250,204,21,.35);box-shadow:inset 0 -12px 24px rgba(250,204,21,.05)}.card.feature .card-icon{background:rgba(250,204,21,.12)}.card h3{margin:2px 0 9px;font-size:1.22rem;line-height:1.15;color:inherit}.card p{margin:0;color:#526174}.tag{display:inline-flex;width:max-content;padding:5px 9px;border-radius:999px;background:rgba(250,204,21,.14);color:#92400e;font-size:.75rem;font-weight:900;text-transform:uppercase;letter-spacing:.07em;border:1px solid rgba(250,204,21,.34)}.feature .tag{color:#fde68a;background:rgba(250,204,21,.1)}.out{margin-top:auto;padding-top:16px;color:#0f766e;font-size:.84rem;font-weight:850}.feature .out{color:#fde68a}.split{display:grid;grid-template-columns:1.02fr .98fr;gap:30px;align-items:start}.panel{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow-soft);color:var(--ink)}.section.alt .panel{background:rgba(248,250,252,.06);border-color:rgba(148,163,184,.22);color:#e5edf7}.scope-panel{border-left:5px solid var(--green)!important}.panel h3{margin-top:0}.panel ul{padding-left:1.1rem}.panel li+li{margin-top:7px}.evidence-panel{border:1px solid rgba(250,204,21,.22);border-radius:28px;padding:28px;background:linear-gradient(135deg,rgba(250,204,21,.09),rgba(34,197,94,.06) 46%,rgba(15,23,42,.2))}.tool-layout{display:grid;grid-template-columns:380px minmax(0,1fr);gap:24px;align-items:start;min-width:0}.tool-layout>*,.hero-grid>*,.grid2>*,.result-grid>*,.cards>*,.split>*{min-width:0}.panel,.canvas-card,.links-box,.result-grid,.metric{max-width:100%}.panel.sticky{position:sticky;top:86px}.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.field{display:grid;gap:6px;margin-bottom:12px}.field label{font-size:.84rem;font-weight:850;color:#223047}.field input,.field select,.field textarea{width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:11px 12px;font:inherit;background:#fff;color:#0f172a;box-shadow:inset 0 1px 0 rgba(15,23,42,.03)}.field input:focus,.field select:focus,.field textarea:focus{outline:3px solid rgba(250,204,21,.32);border-color:#facc15}.result-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 14px}.metric,.result-grid>div{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #dbe4ef;border-radius:18px;padding:16px;box-shadow:0 8px 22px rgba(15,23,42,.07)}.metric b,.result-grid b{font-size:1.45rem;display:block;color:#0f172a}.metric span,.result-grid span{font-size:.82rem;color:#64748b}.result{min-height:140px}.status{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;margin:0 0 12px;font-weight:900;font-size:.84rem;border:1px solid}.status.ok{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.status.warn,.warn{color:#92400e;background:#fffbeb;border-color:#fde68a}.status.bad{color:#991b1b;background:#fef2f2;border-color:#fecaca}.plan-svg,.globe-svg{width:100%;height:auto;display:block;border-radius:22px;box-shadow:var(--shadow-soft);background:#0f172a;margin-top:18px;border:1px solid rgba(148,163,184,.18)}.canvas-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow-soft)}.mark-svg{width:100%;height:auto;display:block}.photo-preview{max-width:100%;border-radius:18px;border:1px solid var(--line);box-shadow:var(--shadow-soft)}.links-box{background:#f8fafc;border:1px solid #dbe4ef;border-radius:20px;padding:18px}.note{color:#64748b;font-size:.94rem}.breadcrumbs{font-size:.9rem;color:#64748b;margin-bottom:14px}.breadcrumbs a{font-weight:850;color:#2563eb}.result h2{margin-top:0}.table{width:100%;max-width:100%;table-layout:fixed;border-collapse:collapse;background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-soft)}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);text-align:left;overflow-wrap:anywhere}.scope-sheet{background:#fff;border:1px dashed #94a3b8;border-radius:18px;padding:16px;margin-top:14px}.roadmark{display:grid;grid-template-columns:1fr 1.2fr;gap:18px;align-items:center;background:#fff;border:1px solid #dbe4ef;border-radius:22px;padding:18px;box-shadow:var(--shadow-soft)}.foot{background:#07111f;color:#cbd5e1;border-top:1px solid rgba(250,204,21,.18);padding:28px 0}.foot p{margin:0;max-width:860px}.foot:before{content:"";display:block;height:3px;margin:-28px 0 25px;background:repeating-linear-gradient(90deg,var(--brand) 0 72px,transparent 72px 96px,var(--green) 96px 104px,transparent 104px 132px)}
@media(max-width:980px){.hero-grid,.tool-layout,.split{grid-template-columns:1fr}.cards{grid-template-columns:1fr 1fr}.result-grid{grid-template-columns:1fr 1fr}.panel.sticky{position:static}.top-inner{align-items:flex-start;flex-direction:column;gap:10px}.nav{width:100%;flex-wrap:nowrap;overflow-x:auto;padding-bottom:3px}.nav a{white-space:nowrap}.hero{padding-top:46px}.mock{max-width:680px}.section-head{align-items:flex-start;flex-direction:column}.tool-layout{gap:18px}}
@media(max-width:640px){.wrap{width:min(100% - 24px,1180px)}.top-inner{padding:11px 0}.brand{font-size:.98rem}.brand span{display:block;font-size:.82rem;letter-spacing:0}.nav{font-size:.8rem;flex-wrap:wrap;overflow-x:visible;padding-bottom:0;gap:5px}.nav a{white-space:normal;padding:6px 8px}.hero{padding:34px 0 36px}.hero h1{font-size:clamp(2.35rem,15vw,3.35rem);letter-spacing:-.06em}.hero-copy{max-width:100%}.hatch-bg:before{inset:-18px -8px -14px -8px}.kicker{max-width:100%;white-space:normal;overflow-wrap:anywhere;line-height:1.25}.hero .lead,.lead{font-size:1rem}.actions{display:grid;grid-template-columns:1fr;gap:10px}.btn{width:100%;padding:12px 15px}.chip-row{flex-wrap:wrap;overflow-x:visible;padding-bottom:0}.meas-chip{white-space:normal}.mock{border-radius:22px;padding:12px}.board-label{display:none}.statbar{grid-template-columns:1fr}.cards,.grid2{grid-template-columns:1fr}.card{min-height:0;padding:20px}.section{padding:42px 0}.result-grid{grid-template-columns:1fr}.roadmark{grid-template-columns:1fr}.evidence-panel{padding:20px}.section h1{font-size:2.25rem}.section h2{font-size:2rem}}
.plan-svg,.globe-svg{width:100%;height:auto;display:block;margin:16px 0 6px;border-radius:22px;box-shadow:var(--shadow-soft);background:#07111f}.sim-canvas{width:100%;max-width:100%;height:auto;display:block;border-radius:22px;background:#07111f;box-shadow:0 18px 48px rgba(7,17,31,.22);border:1px solid rgba(250,204,21,.2)}.visual-canvas{margin:16px 0 6px;max-width:100%}.canvas-card.has-visual-layer #simSvg,.visual-layer-active > .plan-svg{display:none}.svg-caption{margin:8px 0 10px;color:#475569;font-size:.92rem}.print-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:10px 0 18px}.print-actions .btn{box-shadow:none;padding:10px 14px;font-size:.9rem}.photo-preview img{max-width:100%;height:auto;border-radius:18px;display:block}.field input[type="checkbox"]{width:auto;accent-color:var(--brand);transform:translateY(1px)}.tag{display:inline-flex;border:1px solid rgba(37,99,235,.18);background:#eff6ff;color:#1e3a8a;border-radius:999px;padding:6px 10px;font-size:.85rem;font-weight:800;margin:3px}
.method-note{padding-top:26px}.method-note h2{font-size:clamp(1.35rem,2.4vw,1.8rem);letter-spacing:-.035em;margin-bottom:10px}
@media(max-width:640px){.tool-layout.result-first{display:flex;flex-direction:column}.tool-layout.result-first>.panel.sticky{order:2}.tool-layout.result-first>div{order:1;display:flex;flex-direction:column}.tool-layout.result-first>div>*{order:3}.tool-layout.result-first .plan-svg,.tool-layout.result-first .globe-svg,.tool-layout.result-first .canvas-card,.tool-layout.result-first .visual-canvas{order:1}.tool-layout.result-first .svg-caption,.tool-layout.result-first .print-actions{order:2}.tool-layout.result-first .result-grid{order:3;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tool-layout.result-first .metric{padding:16px}.tool-layout.result-first .metric b{font-size:clamp(1.55rem,8vw,2.3rem)}.tool-layout.result-first .metric span{font-size:.9rem}.tool-layout.result-first .status{order:4}.tool-layout.result-first .panel.result{order:5}.tool-layout.result-first>.panel.sticky:before{content:"Adjust the assumptions";display:block;margin:0 0 12px;font-weight:950;color:#0f172a;letter-spacing:-.02em}.print-actions{display:grid;grid-template-columns:1fr}.print-actions .btn{width:100%}.svg-caption{font-size:.86rem}.plan-svg,.globe-svg,.visual-canvas{border-radius:18px}}
@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.top,.nav,.actions,.print-actions,.btn,.foot,.footer,#simCanvas,.visual-canvas{display:none!important}.canvas-card.has-visual-layer #simSvg,.visual-layer-active > .plan-svg{display:block!important}body{background:#fff!important}.panel,.card,.plan-svg,.globe-svg,.metric,.roadmark{box-shadow:none!important}.section{padding:12px 0;background:#fff!important;color:#111827!important}.tool-layout{display:block}.panel.sticky{position:static!important}.plan-svg,.globe-svg{page-break-inside:avoid;max-height:58vh}.result-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}input,select,textarea{border:1px solid #94a3b8!important;background:#fff!important;color:#111827!important}}

/* 2026-06-18 WOW TOOL UI PASS - mobile-first premium tool lab */
.top{background:rgba(7,17,31,.985)}
.brand{white-space:nowrap}.brand span{display:inline;color:var(--brand)}
.tool-page{background:linear-gradient(180deg,#f8fafc 0,#eef3ea 100%)}
.tool-page .lead{max-width:780px}.tool-output{min-width:0}.tool-output .panel.result{margin-top:0}.tool-output .links-box{margin-top:14px}
.tools-index{background:radial-gradient(circle at 88% 12%,rgba(250,204,21,.12),transparent 28%),linear-gradient(180deg,#f8fafc 0,#eef3ea 100%)}
.tool-hub-hero{position:relative;overflow:hidden;border-radius:36px;margin:0 0 22px;padding:34px;background:radial-gradient(circle at 85% 18%,rgba(250,204,21,.22),transparent 32%),radial-gradient(circle at 14% 90%,rgba(34,197,94,.18),transparent 32%),linear-gradient(135deg,#07111f 0,#101827 62%,#172033 100%);color:#f8fafc;border:1px solid rgba(250,204,21,.24);box-shadow:0 28px 70px rgba(7,17,31,.22)}
.tool-hub-hero:before{content:"";position:absolute;inset:0;opacity:.14;background:repeating-linear-gradient(135deg,transparent 0 22px,rgba(250,204,21,.42) 22px 24px,transparent 24px 46px);pointer-events:none}.tool-hub-hero>*{position:relative}.tool-hub-hero h1{color:#fff;margin:14px 0 14px;font-size:clamp(2.2rem,5vw,4.3rem);line-height:.96;letter-spacing:-.065em}.tool-hub-hero .lead{color:#dbeafe;font-size:1.08rem;max-width:720px}.hub-path{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:24px}.hub-path a{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:14px 15px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);color:#e2e8f0}.hub-path b{display:grid;place-items:center;width:32px;height:32px;border-radius:999px;background:var(--brand);color:#07111f;font-size:.8rem}.hub-path span{font-weight:850;line-height:1.15}.tool-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.tool-card{position:relative;overflow:hidden;display:flex;min-height:245px;flex-direction:column;gap:12px;padding:22px;border-radius:30px;color:#f8fafc;background:radial-gradient(circle at 88% 12%,rgba(250,204,21,.18),transparent 32%),linear-gradient(145deg,#0b1220,#172033);border:1px solid rgba(250,204,21,.22);box-shadow:0 18px 44px rgba(15,23,42,.14)}.tool-card:before{content:"";position:absolute;inset:0 0 auto 0;height:6px;background:linear-gradient(90deg,var(--brand),var(--green));opacity:.9}.tool-card:after{content:"";position:absolute;right:-60px;bottom:-70px;width:160px;height:160px;border-radius:50%;background:rgba(250,204,21,.08);pointer-events:none}.tool-card.is-primary{background:radial-gradient(circle at 92% 8%,rgba(34,197,94,.22),transparent 35%),linear-gradient(145deg,#07111f,#14243b)}.tool-badge{position:relative;z-index:1;align-self:flex-start;border-radius:999px;padding:6px 10px;background:rgba(250,204,21,.14);border:1px solid rgba(250,204,21,.32);color:#fde68a;font-size:.72rem;font-weight:950;letter-spacing:.12em}.tool-card h3{position:relative;z-index:1;color:#fff;margin:8px 0 0;font-size:1.55rem;line-height:1.05;letter-spacing:-.04em}.tool-card p{position:relative;z-index:1;color:#dbeafe;font-size:.98rem;line-height:1.45;margin:0}.tool-cta{position:relative;z-index:1;margin-top:auto;color:#07111f;background:var(--brand);border-radius:999px;padding:9px 12px;font-weight:950;text-align:center;box-shadow:0 12px 26px rgba(250,204,21,.22)}
@media(max-width:980px){.tool-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hub-path{grid-template-columns:1fr}.tool-card{min-height:210px}}
@media(max-width:640px){
  .top-inner{padding:8px 0 9px;gap:7px}.brand{font-size:.95rem;line-height:1.05;letter-spacing:-.03em}.brand span{display:none}.nav{width:100%;display:flex;flex-wrap:nowrap;overflow-x:auto;gap:6px;padding:0 0 1px}.nav a{white-space:nowrap;font-size:.76rem;line-height:1;padding:7px 9px;background:rgba(255,255,255,.035);border-color:rgba(255,255,255,.08);color:#dbeafe}.top:after{height:2px;background:linear-gradient(90deg,var(--brand) 0 42%,var(--green) 42% 48%,transparent 48% 54%,var(--brand) 54% 88%,var(--green) 88% 100%)}
  .section{padding:30px 0}.breadcrumbs{display:none}.section h1{font-size:clamp(1.95rem,9.7vw,2.55rem);line-height:.99;letter-spacing:-.055em;margin:0 0 13px}.lead{font-size:1.02rem;line-height:1.52;color:#334155}.tool-page .lead{font-size:1rem;margin-bottom:18px}.tool-page .tool-layout{margin-top:14px}
  .tools-index{padding-top:0}.tool-hub-hero{border-radius:28px;padding:22px 18px;margin-bottom:16px}.tool-hub-hero h1{font-size:clamp(1.95rem,10vw,2.55rem);line-height:.97;margin:11px 0}.tool-hub-hero .lead{font-size:.98rem;line-height:1.48}.hub-path{gap:8px;margin-top:18px}.hub-path a{padding:11px 12px;border-radius:17px}.hub-path b{width:28px;height:28px}.tool-card-grid{grid-template-columns:1fr;gap:12px}.tool-card{min-height:0;border-radius:24px;padding:18px 17px}.tool-card h3{font-size:1.36rem}.tool-card p{font-size:.94rem}.tool-cta{padding:8px 10px;font-size:.86rem;text-align:left;background:rgba(250,204,21,.95)}
  .tool-layout.result-first{display:flex;flex-direction:column;gap:14px}.tool-layout.result-first>.panel.sticky{order:2;border-radius:24px;padding:17px;box-shadow:0 12px 34px rgba(15,23,42,.08)}.tool-layout.result-first>.panel.sticky:before{content:"Adjust assumptions";display:block;margin:0 0 12px;font-weight:950;color:#0f172a;letter-spacing:-.025em}.tool-output{order:1;display:flex;flex-direction:column;gap:12px;padding:12px;border-radius:28px;background:radial-gradient(circle at 86% 10%,rgba(250,204,21,.22),transparent 34%),radial-gradient(circle at 12% 88%,rgba(34,197,94,.16),transparent 30%),linear-gradient(145deg,#07111f,#101827 60%,#172033);border:1px solid rgba(250,204,21,.24);box-shadow:0 24px 60px rgba(7,17,31,.22);color:#e2e8f0}.tool-output>*{order:5}.tool-output .canvas-card,.tool-output .plan-svg,.tool-output .globe-svg,.tool-output .visual-canvas{order:1}.tool-output .canvas-card.panel{padding:0;background:transparent;border:0;box-shadow:none}.tool-output .sim-canvas,.tool-output .plan-svg,.tool-output .globe-svg,.tool-output .visual-canvas{margin:0;border-radius:22px;border:1px solid rgba(250,204,21,.34);box-shadow:0 18px 44px rgba(0,0,0,.34);background:#07111f}.tool-output .svg-caption{order:5;margin:0 4px;color:#aebdd2;font-size:.78rem;line-height:1.35}.tool-output .print-actions{order:6;display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0 0 2px}.tool-output .print-actions .btn{width:100%;padding:8px 9px;font-size:.72rem;box-shadow:none;background:rgba(255,255,255,.06);color:#e2e8f0;border-color:rgba(255,255,255,.14)}.tool-output .result-grid{order:2;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin:0}.tool-output .metric{padding:13px 12px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(226,232,240,.12);box-shadow:none;color:#e2e8f0;min-height:96px}.tool-output .metric b{display:block;color:#fff;font-size:clamp(1.55rem,8vw,2.28rem);line-height:.96;letter-spacing:-.06em;white-space:nowrap}.tool-output .metric span{display:block;margin-top:9px;color:#aebdd2;font-size:.72rem;line-height:1.18;font-weight:850;text-transform:uppercase;letter-spacing:.055em}.tool-output .status{order:3;margin:0;padding:12px 14px;border-radius:18px;font-size:.95rem;line-height:1.22;font-weight:950;text-align:left}.tool-output .panel.result{order:4;margin:0;padding:17px;border-radius:22px;background:rgba(255,255,255,.07);border:1px solid rgba(226,232,240,.12);box-shadow:none;color:#dbeafe}.tool-output .panel.result h2{font-size:1.2rem;line-height:1.08;color:#fff;margin:0 0 9px}.tool-output .panel.result p{font-size:.95rem;line-height:1.5;margin:0 0 10px}.tool-output .links-box{padding:13px 14px;border-radius:18px;background:rgba(7,17,31,.56);border-color:rgba(250,204,21,.16);color:#dbeafe}.tool-output .links-box h3{margin:0 0 6px;color:#fde68a;font-size:1rem}.tool-output a{color:#fde68a}.tool-output ul,.tool-output ol{padding-left:20px}.result-grid{grid-template-columns:1fr}.panel{border-radius:22px}.field{gap:5px}.field label{font-size:.82rem}.field input,.field select,.field textarea{padding:10px 11px;border-radius:14px}.note{font-size:.88rem;line-height:1.42}
}

/* WOW pass correction: remove nested white cards/clutter inside mobile tool stage */
@media(max-width:640px){
  .tool-layout.result-first .tool-output .canvas-card{order:1;padding:0!important;background:transparent!important;border:0!important;box-shadow:none!important;color:#e2e8f0!important}.tool-layout.result-first .tool-output .canvas-card.has-visual-layer #simSvg,.tool-layout.result-first .tool-output.visual-layer-active>.plan-svg{display:none!important}.tool-layout.result-first .tool-output .svg-caption,.tool-layout.result-first .tool-output .print-actions{display:none!important}.tool-layout.result-first .tool-output .result-grid{order:2!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:9px!important;margin:0!important}.tool-layout.result-first .tool-output #simStatus,.tool-layout.result-first .tool-output [id$="Status"]{order:3!important}.tool-layout.result-first .tool-output .status{margin:0!important;padding:12px 14px!important;border-radius:18px!important;font-size:.92rem!important;line-height:1.22!important}.tool-layout.result-first .tool-output>.panel,.tool-layout.result-first .tool-output .panel.result{order:4!important;margin:0!important;padding:16px!important;border-radius:22px!important;background:rgba(255,255,255,.07)!important;border:1px solid rgba(226,232,240,.12)!important;box-shadow:none!important;color:#dbeafe!important}.tool-layout.result-first .tool-output>.panel h2,.tool-layout.result-first .tool-output .panel.result h2{font-size:1.18rem!important;color:#fff!important;margin:0 0 8px!important}.tool-layout.result-first .tool-output>.panel p,.tool-layout.result-first .tool-output .panel.result p{font-size:.94rem!important;line-height:1.48!important;margin:0 0 10px!important}.tool-layout.result-first .tool-output>.links-box,.tool-layout.result-first .tool-output .links-box{order:5!important;margin:0!important;padding:13px 14px!important;border-radius:18px!important;background:rgba(7,17,31,.58)!important;border-color:rgba(250,204,21,.16)!important;color:#dbeafe!important}.tool-layout.result-first .tool-output>.links-box h3,.tool-layout.result-first .tool-output .links-box h3{font-size:1rem!important;color:#fde68a!important;margin:0 0 6px!important}.tool-layout.result-first .tool-output .links-box p{font-size:.92rem!important;line-height:1.45!important}.tool-layout.result-first .tool-output .sim-canvas,.tool-layout.result-first .tool-output .plan-svg,.tool-layout.result-first .tool-output .globe-svg,.tool-layout.result-first .tool-output .visual-canvas{width:100%!important;max-width:100%!important;margin:0!important;border-radius:22px!important;border:1px solid rgba(250,204,21,.34)!important;box-shadow:0 18px 44px rgba(0,0,0,.34)!important;background:#07111f!important}.tool-layout.result-first .tool-output .metric{padding:13px 12px!important;border-radius:18px!important;background:rgba(255,255,255,.08)!important;border:1px solid rgba(226,232,240,.12)!important;box-shadow:none!important;color:#e2e8f0!important;min-height:96px}.tool-layout.result-first .tool-output .metric b{display:block!important;color:#fff!important;font-size:clamp(1.55rem,8vw,2.28rem)!important;line-height:.96!important;letter-spacing:-.06em!important;white-space:nowrap!important}.tool-layout.result-first .tool-output .metric span{display:block!important;margin-top:9px!important;color:#b9c7dd!important;font-size:.72rem!important;line-height:1.18!important;font-weight:850!important;text-transform:uppercase!important;letter-spacing:.055em!important}
}

/* 2026-06-18 CLARITY PASS - fix human-visible mobile crowding, not just scrollWidth */
code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;font-size:.86em;line-height:1.2;border-radius:8px;padding:.12em .38em;background:#eef3ff;color:#1e3a8a;white-space:normal;overflow-wrap:anywhere;word-break:break-word}.panel h2,.card h3,.links-box h3{overflow-wrap:anywhere;word-break:normal;line-height:1.12}.panel p,.card p,.links-box p{overflow-wrap:anywhere}.atlas-page{background:linear-gradient(180deg,#f8fafc 0,#eef3ea 100%)}.atlas-page .lead{max-width:760px}.atlas-lab{display:grid;grid-template-columns:1.02fr .98fr;gap:18px;align-items:start;margin-top:22px}.atlas-card{background:#fff;border:1px solid #d8e0ea;border-radius:28px;padding:24px;box-shadow:var(--shadow-soft);min-width:0}.atlas-card.dark{background:radial-gradient(circle at 86% 12%,rgba(250,204,21,.18),transparent 34%),linear-gradient(145deg,#07111f,#172033);border-color:rgba(250,204,21,.24);color:#e2e8f0}.atlas-card.dark h2{color:#fff}.atlas-card.dark p{color:#cbd5e1}.atlas-kicker{display:inline-flex;border-radius:999px;padding:6px 10px;margin-bottom:10px;background:rgba(250,204,21,.13);border:1px solid rgba(250,204,21,.28);color:#b7791f;font-size:.72rem;font-weight:950;letter-spacing:.12em;text-transform:uppercase}.atlas-card.dark .atlas-kicker{color:#fde68a}.atlas-card h2{font-size:clamp(1.35rem,2.4vw,2rem);letter-spacing:-.045em;margin:0 0 10px}.atlas-card p{margin:0 0 12px;color:#475569}.atlas-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px}.atlas-stat{border-radius:18px;padding:14px 13px;background:rgba(255,255,255,.08);border:1px solid rgba(226,232,240,.13)}.atlas-stat b{display:block;color:#fff;font-size:clamp(1.35rem,3vw,2rem);line-height:1;letter-spacing:-.055em}.atlas-stat span{display:block;margin-top:8px;color:#aebdd2;font-size:.74rem;font-weight:850;text-transform:uppercase;letter-spacing:.06em;line-height:1.16}.atlas-route{display:grid;gap:10px;margin-top:14px}.atlas-route a{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;padding:12px 13px;border-radius:18px;background:#f8fafc;border:1px solid #e2e8f0;color:#0f172a;font-weight:850}.atlas-route a b{display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:var(--brand);color:#07111f;font-size:.76rem}.atlas-route a span{line-height:1.2}.atlas-bars{display:grid;gap:10px;margin-top:14px}.atlas-bar-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:13px;border-radius:18px;background:#f8fafc;border:1px solid #e2e8f0}.atlas-region{min-width:0}.atlas-region b{display:block;color:#0f172a;line-height:1.1}.atlas-region span{display:block;margin-top:3px;color:#64748b;font-size:.82rem}.atlas-count{font-weight:950;color:#0f172a;font-variant-numeric:tabular-nums}.atlas-meter{grid-column:1/-1;height:9px;background:#dbeafe;border-radius:999px;overflow:hidden}.atlas-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#22c55e);min-width:2px}.atlas-note-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}.atlas-note-grid .links-box{margin:0}.atlas-plain-list{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:9px}.atlas-plain-list li{position:relative;padding-left:22px;color:#334155}.atlas-plain-list li:before{content:"";position:absolute;left:0;top:.62em;width:9px;height:9px;border-radius:50%;background:var(--brand)}
@media(max-width:980px){.atlas-lab,.atlas-note-grid{grid-template-columns:1fr}.atlas-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:640px){
  .section h2{font-size:clamp(1.22rem,5.8vw,1.55rem)!important;letter-spacing:-.032em;line-height:1.12}.panel{padding:18px;border-radius:22px}.panel p{font-size:.96rem;line-height:1.5}.table{font-size:.86rem}.table th,.table td{padding:10px 8px;vertical-align:top;overflow-wrap:anywhere}.table th{font-size:.78rem;line-height:1.2}.table td{line-height:1.28}
  .atlas-page .section{padding-top:24px}.atlas-page .section h1{font-size:clamp(2rem,9.3vw,2.45rem);line-height:1;letter-spacing:-.055em;margin-bottom:12px}.atlas-page .lead{font-size:.98rem;line-height:1.46}.atlas-lab{gap:12px;margin-top:16px}.atlas-card{border-radius:24px;padding:17px}.atlas-card h2{font-size:1.32rem!important}.atlas-card p{font-size:.94rem;line-height:1.48}.atlas-kicker{font-size:.68rem;padding:5px 9px}.atlas-stats{grid-template-columns:1fr;gap:8px}.atlas-stat{padding:13px;border-radius:16px}.atlas-stat b{font-size:1.85rem}.atlas-stat span{font-size:.7rem}.atlas-bar-row{grid-template-columns:1fr;gap:7px;padding:12px;border-radius:16px}.atlas-count{font-size:1.15rem}.atlas-route a{padding:11px;border-radius:16px}.atlas-note-grid{gap:10px;margin-top:12px}.atlas-plain-list{gap:7px}.atlas-plain-list li{font-size:.94rem;line-height:1.42}
}

/* Atlas mobile compact correction after visual QA */
@media(max-width:640px){
  .atlas-page .section{padding-top:20px}.atlas-page .section h1{font-size:clamp(1.75rem,8vw,2.08rem)!important;line-height:1.03!important;letter-spacing:-.045em!important;margin-bottom:9px!important}.atlas-page .lead{font-size:.92rem!important;line-height:1.42!important;margin-bottom:0!important}.atlas-lab{gap:10px;margin-top:13px}.atlas-card{border-radius:20px;padding:14px}.atlas-card.dark{box-shadow:0 16px 38px rgba(7,17,31,.18)}.atlas-card h2{font-size:1.16rem!important;line-height:1.12!important;margin-bottom:7px}.atlas-card p{font-size:.88rem!important;line-height:1.38!important;margin-bottom:8px}.atlas-kicker{font-size:.61rem!important;padding:4px 8px;margin-bottom:8px;letter-spacing:.1em}.atlas-stats{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:6px!important;margin-top:10px!important}.atlas-stat{padding:9px 7px!important;border-radius:13px!important;min-height:74px}.atlas-stat b{font-size:clamp(.96rem,4.2vw,1.28rem)!important;line-height:1!important;letter-spacing:-.045em}.atlas-stat span{font-size:.64rem!important;line-height:1.1!important;margin-top:6px!important;letter-spacing:.04em}.atlas-bars{gap:7px;margin-top:10px}.atlas-bar-row{grid-template-columns:minmax(0,1fr) auto!important;gap:6px!important;padding:9px 10px!important;border-radius:14px}.atlas-region b{font-size:.95rem}.atlas-region span{font-size:.7rem;margin-top:2px}.atlas-count{font-size:.92rem!important}.atlas-meter{height:7px}.atlas-note-grid{gap:10px;margin-top:10px}.atlas-route{gap:8px;margin-top:10px}.atlas-route a{padding:9px 10px}.atlas-route a b{width:24px;height:24px;font-size:.68rem}.atlas-route a span{font-size:.88rem}.atlas-plain-list li{font-size:.88rem;line-height:1.35}
}
/* Photo audit: AI issue text can be a comma list; allow wrapping inside metric card */
.metric.text-metric b{white-space:normal!important;overflow-wrap:anywhere;word-break:normal;font-size:clamp(1.05rem,4.4vw,1.35rem)!important;line-height:1.08!important}

/* 2026-06-18 Interactive globe upgrade */
.interactive-globe{position:relative;min-height:520px;border-radius:28px;overflow:hidden;background:radial-gradient(circle at 50% 45%,rgba(56,189,248,.18),transparent 38%),linear-gradient(145deg,#07111f,#0f172a 56%,#172033);border:1px solid rgba(250,204,21,.25);box-shadow:0 24px 60px rgba(7,17,31,.25);color:#e2e8f0;touch-action:pan-y;isolation:isolate}.globe-stage{position:absolute;inset:0}.globe-live-svg{display:block;width:100%;height:100%;cursor:grab}.globe-live-svg:active{cursor:grabbing}.globe-ocean{fill:#07111f;stroke:#334155;stroke-width:1.4}.globe-graticule{fill:none;stroke:#26364f;stroke-width:.8;opacity:.78}.globe-country{stroke:#07111f;stroke-width:.55;transition:opacity .15s}.globe-country.has-data{cursor:pointer}.globe-country.no-data{pointer-events:auto}.globe-country:hover{opacity:1;stroke:#fde68a;stroke-width:1.3}.globe-selected-outline{fill:none;stroke:#facc15;stroke-width:2.2;pointer-events:none;filter:drop-shadow(0 0 10px rgba(250,204,21,.45))}.globe-controls{position:absolute;top:14px;right:14px;display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end;max-width:250px}.globe-controls button{appearance:none;border:1px solid rgba(250,204,21,.35);background:rgba(7,17,31,.74);color:#f8fafc;border-radius:999px;padding:8px 11px;font-weight:900;font-size:.82rem;box-shadow:0 10px 28px rgba(0,0,0,.20)}.globe-controls button:hover,.globe-controls button.is-active{background:#facc15;color:#07111f}.globe-hint{position:absolute;left:14px;top:14px;max-width:min(340px,58%);border-radius:999px;padding:8px 11px;background:rgba(7,17,31,.68);border:1px solid rgba(226,232,240,.13);color:#dbeafe;font-size:.8rem;font-weight:800}.globe-tooltip{position:absolute;z-index:3;min-width:180px;max-width:230px;padding:10px 11px;border-radius:16px;background:rgba(248,250,252,.97);color:#0f172a;border:1px solid #e2e8f0;box-shadow:0 18px 44px rgba(0,0,0,.25);pointer-events:none}.globe-tooltip b{display:block;font-size:.95rem;line-height:1.1}.globe-tooltip span{display:block;margin-top:4px;color:#475569;font-size:.82rem;line-height:1.25}.globe-attribution{position:absolute;right:14px;bottom:12px;max-width:52%;text-align:right;color:#94a3b8;font-size:.68rem;line-height:1.18}.atlas-interactive-stage{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(280px,.82fr);gap:14px;align-items:stretch;margin:18px 0}.atlas-interactive-side{display:flex;flex-direction:column;gap:12px;min-width:0}.atlas-interactive-side .result-grid{grid-template-columns:1fr 1fr}.interactive-globe + .result-grid{margin-top:12px}.tool-output .interactive-globe{min-height:520px;margin:0}.tool-output .interactive-globe .globe-live-svg{border-radius:28px}.globe-map-note{margin:9px 0 0;color:#64748b;font-size:.9rem;line-height:1.45}.globemap-upgrade-link{margin-top:12px}.globemap-upgrade-link a{font-weight:900}
@media(max-width:980px){.atlas-interactive-stage{grid-template-columns:1fr}.atlas-interactive-side .result-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.tool-output .interactive-globe{min-height:500px}}
@media(max-width:640px){.interactive-globe{min-height:430px;border-radius:24px}.tool-output .interactive-globe{min-height:430px}.globe-controls{top:10px;right:10px;gap:5px;max-width:168px}.globe-controls button{padding:7px 9px;font-size:.74rem}.globe-hint{left:10px;top:auto;bottom:32px;max-width:calc(100% - 20px);font-size:.72rem;padding:7px 9px;border-radius:14px}.globe-attribution{left:10px;right:10px;bottom:9px;max-width:none;text-align:left;font-size:.62rem}.globe-tooltip{display:none}.globe-legend-svg{display:none}.atlas-interactive-stage{gap:10px;margin:14px 0}.atlas-interactive-side .result-grid{grid-template-columns:1fr 1fr!important}.atlas-interactive-side .panel.result{padding:15px!important;border-radius:20px}.atlas-interactive-side .panel.result h2{font-size:1.14rem!important}.atlas-interactive-side .panel.result p{font-size:.9rem!important}}
/* Interactive globe order/metric readability inside result-first tool pages */
.tool-output .interactive-globe{order:1!important}.tool-output .interactive-globe + .result-grid{order:2!important}.tool-output .interactive-globe + .result-grid .metric b{font-size:clamp(1.25rem,6vw,1.95rem)!important;white-space:normal!important;overflow-wrap:anywhere}.tool-output .interactive-globe + .result-grid .metric span{font-size:.76rem!important;line-height:1.14!important}
@media(max-width:640px){.tool-output .interactive-globe + .result-grid .metric{min-height:88px!important}.tool-output .interactive-globe + .result-grid .metric b{font-size:clamp(1.18rem,5.7vw,1.75rem)!important}}

/* 2026-06-18 Phase 2 Florida streetlight map */
.streetlight-map-shell{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(300px,.65fr);gap:16px;align-items:stretch;margin:20px 0}.streetlight-region-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:16px 0 4px}.streetlight-region-strip div{border:1px solid #dbeafe;background:linear-gradient(180deg,#fff,#f8fafc);border-radius:18px;padding:12px;box-shadow:0 12px 28px rgba(15,23,42,.06)}.streetlight-region-strip b{display:block;color:#0f172a;font-size:clamp(1.2rem,4vw,1.8rem);line-height:1}.streetlight-region-strip span{display:block;margin-top:6px;color:#64748b;font-size:.76rem;text-transform:uppercase;font-weight:900;letter-spacing:.04em}.streetlight-map-panel{min-width:0}.streetlight-map{position:relative;min-height:640px;border-radius:28px;overflow:hidden;border:1px solid rgba(15,23,42,.12);box-shadow:0 28px 70px rgba(15,23,42,.18);background:#dbeafe;touch-action:pan-y}.streetlight-map.is-loading:before{content:'Loading real mapped lamp points...';position:absolute;z-index:5;inset:0;display:grid;place-items:center;background:linear-gradient(135deg,rgba(7,17,31,.86),rgba(15,23,42,.72));color:#fff;font-weight:900;letter-spacing:.02em;text-align:center;padding:20px}.streetlight-controls{display:flex;flex-direction:column;gap:12px}.streetlight-controls .field{margin:0}.streetlight-filter-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.streetlight-filter-chips button{appearance:none;border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:999px;padding:9px 11px;font-weight:900;font-size:.82rem;line-height:1.1;box-shadow:0 8px 18px rgba(15,23,42,.08)}.streetlight-filter-chips button span{color:#64748b;margin-left:3px}.streetlight-filter-chips button.is-active{background:#0f172a;color:#f8fafc;border-color:#0f172a}.streetlight-filter-chips button.is-active span{color:#fde68a}.chip-note{display:block;width:100%;color:#64748b;font-size:.86rem;line-height:1.35}.streetlight-map-meta{font-size:.86rem;line-height:1.45;color:#475569}.streetlight-map-meta b{color:#0f172a}.streetlight-map .maplibregl-ctrl-attrib{font-size:10px}.streetlight-map .maplibregl-ctrl-bottom-right{max-width:80%}.lamp-popup{font-family:inherit;min-width:190px}.lamp-popup b{display:block;color:#0f172a;margin-bottom:8px;font-size:15px}.lamp-popup dl{display:grid;grid-template-columns:82px minmax(0,1fr);gap:5px 8px;margin:0 0 8px}.lamp-popup dt{font-size:11px;color:#64748b;text-transform:uppercase;font-weight:900}.lamp-popup dd{margin:0;color:#0f172a;font-weight:800;overflow-wrap:anywhere}.lamp-popup a{font-weight:900;color:#2563eb}.streetlight-map-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.streetlight-map-links a,.streetlight-map-links button{appearance:none;border:0;border-radius:999px;background:#0f172a;color:#fff;text-decoration:none;padding:10px 13px;font-weight:900;font-size:.86rem}.streetlight-map-links button{cursor:pointer}.streetlight-map-links a.secondary{background:#e0f2fe;color:#075985}.streetlight-source-box{border:1px solid #dbeafe;background:#f8fafc;border-radius:20px;padding:14px;margin-top:12px}.streetlight-source-box h3{margin:.1rem 0 .45rem;font-size:1.02rem}.streetlight-source-box p{margin:0;color:#475569;font-size:.92rem;line-height:1.45}.streetlight-tag-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}.streetlight-tag-grid div{border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:11px}.streetlight-tag-grid b{display:block;color:#0f172a;font-size:1.05rem}.streetlight-tag-grid span{display:block;color:#64748b;font-size:.78rem;text-transform:uppercase;font-weight:900;letter-spacing:.03em}.streetlight-map .maplibregl-popup-content{border-radius:18px;box-shadow:0 20px 50px rgba(15,23,42,.22)}.street-map-cta{margin-top:14px;padding:15px;border-radius:20px;background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#fff}.street-map-cta h3{margin:.1rem 0 .35rem;color:#fff}.street-map-cta p{margin:0 0 .8rem;color:#dbeafe}.street-map-cta a{display:inline-flex;background:#facc15;color:#111827;text-decoration:none;border-radius:999px;padding:9px 12px;font-weight:900}
@media(max-width:980px){.streetlight-map-shell{grid-template-columns:1fr}.streetlight-map{min-height:590px}.streetlight-controls{order:2}.streetlight-map-panel{order:1}}
@media(max-width:640px){.streetlight-map-shell{gap:12px;margin:14px 0}.streetlight-region-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin:12px 0 2px}.streetlight-region-strip div{padding:9px 7px;border-radius:14px}.streetlight-region-strip b{font-size:clamp(1rem,4.4vw,1.35rem)}.streetlight-region-strip span{font-size:.62rem;line-height:1.12}.streetlight-map{min-height:72vh;border-radius:24px}.streetlight-filter-chips{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x proximity}.streetlight-filter-chips button{white-space:nowrap;scroll-snap-align:start}.streetlight-tag-grid{grid-template-columns:1fr 1fr}.streetlight-map-links a,.streetlight-map-links button{font-size:.8rem;padding:9px 11px}.streetlight-map-meta{font-size:.82rem}.streetlight-map .maplibregl-ctrl-top-right{top:8px;right:8px}.streetlight-map .maplibregl-ctrl-bottom-left{display:none}.streetlight-map .maplibregl-ctrl-bottom-right{max-width:88%}}
/* Phase 2 map mobile overflow hard guard */
.streetlight-map-shell,.streetlight-map-panel,.streetlight-map{min-width:0!important;max-width:100%!important}.streetlight-map-panel{width:100%;overflow:hidden}.streetlight-map{width:100%;box-sizing:border-box}.streetlight-map .maplibregl-canvas-container,.streetlight-map .maplibregl-canvas{max-width:100%!important}
/* Phase 2 mobile grid hard reset: prevent MapLibre intrinsic canvas from widening the page */
@media(max-width:980px){.streetlight-map-shell{display:block!important;width:100%!important;max-width:100%!important}.streetlight-map-panel,.streetlight-controls{display:block!important;width:100%!important;max-width:100%!important;min-width:0!important}.streetlight-controls{margin-top:12px}.streetlight-map{contain:layout paint;overflow:hidden!important}}
/* 2026-06-18 Global globe clarity: all countries visible, extracted data highlighted */
.globe-country.no-data{fill:#253348!important;opacity:.72!important;stroke:#475569!important;stroke-width:.62!important;cursor:pointer}.globe-country.has-data{stroke:rgba(250,204,21,.82)!important;stroke-width:.9!important;filter:drop-shadow(0 0 4px rgba(250,204,21,.18))}.globe-country.has-data:hover,.globe-country.no-data:hover{opacity:1!important;stroke:#fde68a!important;stroke-width:1.35!important}.globe-country.is-selected{opacity:1!important;stroke:#facc15!important;stroke-width:1.65!important}.globe-data-marker{pointer-events:none;fill:#facc15;stroke:#07111f;stroke-width:1.4;opacity:.95;filter:drop-shadow(0 0 8px rgba(250,204,21,.45))}.globe-data-marker-ring{pointer-events:none;fill:none;stroke:#fde68a;stroke-width:1.25;opacity:.78}.globe-key{position:absolute;left:14px;bottom:14px;max-width:43%;display:grid;gap:5px;border-radius:16px;padding:9px 11px;background:rgba(7,17,31,.70);border:1px solid rgba(226,232,240,.14);box-shadow:0 12px 30px rgba(0,0,0,.20);color:#dbeafe;font-size:.72rem;line-height:1.18;font-weight:800}.globe-key span{display:flex;align-items:center;gap:7px}.globe-key span:before{content:'';width:12px;height:12px;border-radius:999px;display:inline-block;flex:0 0 12px}.globe-key .key-data:before{background:#facc15;box-shadow:0 0 0 2px rgba(250,204,21,.22)}.globe-key .key-land:before{background:#253348;border:1px solid #64748b}.globe-attribution{bottom:14px}
@media(max-width:640px){.globe-key{display:none}.globe-hint{bottom:36px;line-height:1.2}.globe-country.no-data{opacity:.76!important}}

/* 2026-06-18 Phase 2C street-level region bridge */
.legacy-route-note{margin:10px 0 0;color:#64748b;font-size:.92rem;line-height:1.45;max-width:780px}.street-region-bridge-panel{margin:16px 0 18px;padding:18px;border-radius:24px;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #dbeafe;box-shadow:0 12px 30px rgba(15,23,42,.07)}.street-region-bridge-panel.compact{margin:14px 0}.street-region-bridge-panel h2{font-size:clamp(1.25rem,2.2vw,1.65rem);margin:0 0 7px;letter-spacing:-.035em}.street-region-bridge-panel p{margin:0;color:#475569;max-width:860px}.street-region-links{display:flex;gap:9px;flex-wrap:wrap;margin-top:12px}.street-region-links a,.street-region-bridge a{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:9px 12px;background:#0f172a;color:#f8fafc;font-weight:900;font-size:.86rem;border:1px solid rgba(250,204,21,.22)}.street-region-links a:nth-child(2){background:#facc15;color:#111827}.street-region-bridge{margin-top:12px}.street-region-bridge h3{margin-bottom:6px}.street-region-bridge p{margin-bottom:8px}@media(max-width:640px){.legacy-route-note{font-size:.84rem}.street-region-bridge-panel{border-radius:20px;padding:13px;margin:12px 0}.street-region-bridge-panel h2{font-size:1.12rem}.street-region-bridge-panel p{font-size:.88rem;line-height:1.38}.street-region-links{display:grid;grid-template-columns:1fr;gap:7px}.street-region-links a,.street-region-bridge a{width:100%;font-size:.82rem;padding:9px 10px}.street-region-bridge p{font-size:.88rem!important}}
