@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=Manrope:wght@300;400;500;600;700&display=swap');

:root {
    --vr-paper: #ffffff;
    --vr-paper-2: #fafafa;
    --vr-paper-3: #f5f5f4;
    --vr-line: #ececea;
    --vr-line-2: #e3e3e0;
    --vr-mute: #94948f;
    --vr-text-3: #6b6b67;
    --vr-text-2: #3a3a37;
    --vr-text: #18181a;
    --vr-accent: #1f4e5f;
    --vr-accent-soft: #1f4e5f14;
    --vr-accent-line: #1f4e5f33;
    --vr-up: #2e6b4a;
    --vr-down: #8b3a3a;
    --vr-warn: #8a6a1f;
    --vr-sans: 'Manrope', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', sans-serif;
    --vr-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
    --vr-radius: 8px;
    --vr-shadow: 0 12px 34px rgba(24, 24, 26, 0.06);
}

* { box-sizing: border-box; }
html { background: var(--vr-paper-3); }
body {
    margin: 0;
    font-family: var(--vr-sans);
    color: var(--vr-text);
    background: var(--vr-paper-3);
    -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
.vr-num { font-family: var(--vr-mono); font-variant-numeric: tabular-nums; letter-spacing: 0; }
.muted { color: var(--vr-text-3); }
.vr-up { color: var(--vr-up); }
.vr-down { color: var(--vr-down); }

.shell { display: grid; grid-template-columns: 232px minmax(0, 1fr); min-height: 100vh; }
.sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    background: var(--vr-paper-2);
    border-right: 1px solid var(--vr-line);
    padding: 18px 14px;
    display: flex;
    flex-direction: column;
}
.brand-lockup { display: inline-flex; align-items: center; gap: 8px; padding: 4px 10px 18px; }
.logo-mark { width: 18px; height: 18px; color: var(--vr-accent); }
.wordmark { font-size: 16px; font-weight: 600; letter-spacing: 0; }
.wordmark span { font-weight: 300; color: var(--vr-text-2); }
.brand-sub { padding: 0 10px 10px; color: var(--vr-mute); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }
.nav { display: grid; gap: 2px; }
.nav a, .logout {
    min-height: 36px;
    border: 0;
    border-radius: 6px;
    padding: 8px 12px;
    background: transparent;
    color: var(--vr-text-2);
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    text-align: left;
    cursor: pointer;
    font-size: 13px;
    font-weight: 400;
}
.nav a:hover, .logout:hover { background: var(--vr-paper-3); color: var(--vr-text); }
.nav a.active { background: var(--vr-accent-soft); color: var(--vr-accent); font-weight: 500; }
.nav-icon { width: 15px; height: 15px; flex: 0 0 15px; color: currentColor; opacity: 0.78; }
.sidebar-footer { margin-top: auto; padding: 16px 10px 4px; display: grid; gap: 8px; }
.sidebar-footer .model-row { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--vr-text-2); }
.status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--vr-up); }

.main { min-width: 0; }
.topbar {
    height: 56px;
    border-bottom: 1px solid var(--vr-line);
    background: var(--vr-paper);
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 0 22px;
}
.crumbs { display: flex; align-items: center; gap: 12px; color: var(--vr-text-3); font-size: 13px; min-width: 0; }
.crumbs strong { color: var(--vr-text); font-weight: 500; }
.timeframes { display: flex; gap: 4px; padding: 3px; background: var(--vr-paper-3); border-radius: 6px; }
.timeframes span { padding: 4px 10px; border-radius: 4px; color: var(--vr-text-3); font-size: 11px; font-weight: 500; }
.timeframes span.active { background: var(--vr-paper); color: var(--vr-text); box-shadow: 0 1px 2px rgba(0,0,0,0.04), 0 0 0 1px var(--vr-line); }
.topbar-actions { margin-left: auto; display: flex; align-items: center; gap: 12px; }
.user {
    border: 1px solid var(--vr-line-2);
    border-radius: 18px;
    padding: 4px 10px 4px 4px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--vr-text-2);
    font-size: 12px;
}
.avatar { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg, #b08e5c, #4a3722); color: #fff; display: grid; place-items: center; font-size: 11px; font-weight: 600; }
.page { padding: 18px 20px 28px; display: grid; gap: 16px; }
.page-heading { display: none; }

.vr-label, .metric-label, th, label {
    color: var(--vr-mute);
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 500;
}
.vr-small { color: var(--vr-text-3); font-size: 12px; line-height: 1.5; }
.panel, .vr-card {
    background: var(--vr-paper);
    border: 1px solid var(--vr-line);
    border-radius: var(--vr-radius);
    box-shadow: none;
    padding: 18px;
}
.panel h2 { margin: 0 0 14px; font-size: 16px; font-weight: 600; letter-spacing: 0; }
.grid { display: grid; gap: 16px; }
.grid.metrics { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid.two { grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.65fr); }
.metric-card, .grid.metrics .panel { padding: 14px; }
.metric-value { margin-top: 4px; font-family: var(--vr-mono); font-size: 24px; font-weight: 500; letter-spacing: 0; color: var(--vr-text); }

.badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 22px;
    border-radius: 4px;
    padding: 3px 8px;
    border: 1px solid var(--vr-line-2);
    background: var(--vr-paper);
    color: var(--vr-text-2);
    font-size: 11px;
    font-weight: 500;
}
.badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--vr-mute); }
.badge.ok { color: var(--vr-up); border-color: #b8d5c4; background: #f0f7f3; }
.badge.ok::before { background: var(--vr-up); }
.badge.warn { color: var(--vr-warn); border-color: #d6c08a; background: #fbf6e9; }
.badge.warn::before { background: var(--vr-warn); }
.badge.danger { color: var(--vr-down); border-color: #d8b3b3; background: #fbeeee; }
.badge.danger::before { background: var(--vr-down); }

table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { padding: 10px 8px; border-bottom: 1px solid var(--vr-line); text-align: left; vertical-align: top; }
td { color: var(--vr-text-2); }
tr:last-child td { border-bottom: 0; }
.actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.button {
    border: 1px solid var(--vr-accent);
    background: var(--vr-accent);
    color: #fff;
    min-height: 36px;
    border-radius: 6px;
    padding: 0 14px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.button:hover { filter: brightness(1.06); }
.button.secondary { background: var(--vr-paper); color: var(--vr-accent); }
.button.compact { min-height: 30px; width: fit-content; padding: 0 10px; font-size: 12px; }
input, select, textarea {
    width: 100%;
    border: 1px solid var(--vr-line-2);
    border-radius: 6px;
    padding: 9px 10px;
    background: var(--vr-paper);
    color: var(--vr-text);
    outline: none;
}
input:focus, select:focus, textarea:focus { border-color: var(--vr-accent); box-shadow: 0 0 0 3px var(--vr-accent-soft); }
label { display: grid; gap: 6px; }
.form-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.form-grid.single { grid-template-columns: 1fr; }
.status, .errors {
    margin: 0 20px 16px;
    padding: 12px 14px;
    border-radius: 8px;
    font-size: 13px;
}
.status { border: 1px solid #b8d5c4; background: #f0f7f3; color: var(--vr-up); }
.errors { border: 1px solid #d8b3b3; background: #fbeeee; color: var(--vr-down); }
pre { white-space: pre-wrap; word-break: break-word; font-size: 12px; background: var(--vr-paper-2); padding: 10px; border-radius: 6px; border: 1px solid var(--vr-line); }

.chart-card { padding: 0; overflow: hidden; }
.chart-head { display: flex; justify-content: space-between; gap: 18px; padding: 16px 20px; border-bottom: 1px solid var(--vr-line); }
.chart-price { display: flex; align-items: baseline; gap: 12px; margin-top: 4px; }
.chart-price strong { font-family: var(--vr-mono); font-size: 28px; font-weight: 500; }
.mini-stats { display: flex; gap: 26px; }
.mini-stat strong { display: block; margin-top: 4px; font-family: var(--vr-mono); font-size: 14px; font-weight: 500; }
.candle-board {
    height: 330px;
    padding: 22px 18px 18px;
    display: grid;
    grid-template-columns: repeat(46, 1fr);
    align-items: end;
    gap: 5px;
    background-image: linear-gradient(to right, var(--vr-line) 1px, transparent 1px), linear-gradient(to bottom, var(--vr-line) 1px, transparent 1px);
    background-size: 60px 40px;
}
.candle { position: relative; min-height: 26px; border-radius: 1px; opacity: .95; }
.candle::before { content: ""; position: absolute; left: 50%; top: -12px; bottom: -12px; width: 1px; transform: translateX(-50%); background: currentColor; opacity: .9; }
.candle.up { color: var(--vr-up); background: color-mix(in srgb, var(--vr-up) 26%, transparent); border: 1px solid var(--vr-up); }
.candle.down { color: var(--vr-down); background: var(--vr-down); border: 1px solid var(--vr-down); }
.candle.active { outline: 1px solid var(--vr-accent); outline-offset: 3px; }
.chart-axis { display: flex; justify-content: space-between; color: var(--vr-text-3); font-size: 11px; padding: 0 20px 14px; }
.radar-panel { display: grid; gap: 16px; }
.radar-split { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 12px 0; border-top: 1px solid var(--vr-line); border-bottom: 1px solid var(--vr-line); }
.radar-big { font-family: var(--vr-mono); font-size: 26px; font-weight: 500; color: var(--vr-accent); }
.sync-block { display: grid; gap: 8px; padding: 12px 0; border-bottom: 1px solid var(--vr-line); }
.sync-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.sync-progress { height: 7px; border-radius: 4px; background: var(--vr-line); overflow: hidden; }
.sync-progress span { display: block; height: 100%; width: 0; background: var(--vr-accent); transition: width .25s ease; }
.scenario { border: 1px solid var(--vr-line); border-radius: 6px; padding: 10px 12px; display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 10px; }
.scenario.active { border-color: var(--vr-accent); background: var(--vr-accent-soft); }
.scenario-bar { width: 60px; height: 4px; border-radius: 2px; background: var(--vr-line); overflow: hidden; }
.scenario-bar span { display: block; height: 100%; background: var(--vr-accent); }
.pivot-panel { max-width: 760px; display: grid; gap: 18px; }
.pivot-panel h2 { margin-bottom: 8px; font-size: 22px; }
.pivot-rows { display: grid; gap: 10px; }
.pivot-row { display: flex; align-items: center; gap: 12px; padding: 12px; border: 1px solid var(--vr-line); border-radius: 6px; color: var(--vr-text-2); font-size: 13px; }
.geo-hero {
    display: grid;
    grid-template-columns: minmax(340px, 0.72fr) minmax(520px, 1.28fr);
    gap: 24px;
    align-items: stretch;
    overflow: hidden;
}
.geo-hero h2 { margin: 0 0 10px; font-size: 28px; line-height: 1.18; letter-spacing: 0; }
.geo-search { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; margin-top: 18px; }
.population-search {
    grid-template-columns: minmax(0, 1fr) auto auto;
}
.hero-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-top: 16px;
}
.hero-facts div {
    border: 1px solid var(--vr-line);
    border-radius: 6px;
    padding: 10px;
    display: grid;
    gap: 4px;
}
.hero-facts strong { font-size: 13px; color: var(--vr-text-2); font-weight: 600; }
.neighborhood-strip {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 14px;
}
.neighborhood-strip a {
    min-height: 28px;
    border: 1px solid var(--vr-line-2);
    border-radius: 6px;
    padding: 5px 9px;
    color: var(--vr-text-2);
    background: var(--vr-paper);
    font-size: 12px;
}
.neighborhood-strip a:hover {
    border-color: var(--vr-accent-line);
    color: var(--vr-accent);
    background: var(--vr-accent-soft);
}
.municipality-loaded {
    display: grid;
    grid-template-columns: minmax(0, 0.48fr) minmax(0, 0.52fr);
    gap: 16px;
    align-items: start;
}
.municipality-loaded h2 { margin: 4px 0 8px; }
.geo-mini-map {
    border: 1px solid var(--vr-line-2);
    border-radius: 8px;
    overflow: hidden;
    background: var(--vr-paper-3);
}
.geo-mini-map svg { width: 100%; height: auto; display: block; }
.geo-mini-map.large { margin-top: 8px; }
.official-map-shell {
    position: relative;
    border: 1px solid var(--vr-line-2);
    border-radius: 8px;
    overflow: hidden;
    background: var(--vr-paper-3);
}
.official-map {
    width: 100%;
    min-height: 260px;
    background: #d7ddd2;
}
.official-map .leaflet-control-layers,
.official-map .leaflet-control-zoom a,
.official-map .leaflet-popup-content-wrapper {
    border-radius: 6px;
    font-family: var(--vr-sans);
}
.official-map .leaflet-control-attribution {
    font-family: var(--vr-sans);
    font-size: 10px;
}
.official-map-legend {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 8px 10px;
    border-top: 1px solid var(--vr-line);
    background: rgba(255, 255, 255, .94);
    color: var(--vr-text-3);
    font-size: 11px;
}
.official-map-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.official-map-legend span::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--vr-accent);
}
.parcel-scan-widget {
    position: absolute;
    inset: 0;
    z-index: 700;
    font-family: var(--vr-sans);
    pointer-events: none;
}
.parcel-scan-button {
    position: absolute;
    left: 18px;
    bottom: 52px;
    min-height: 54px;
    border: 1px solid rgba(255, 255, 255, .58);
    border-radius: 8px;
    padding: 0 22px;
    background: var(--vr-accent);
    color: #ffffff;
    box-shadow: 0 16px 34px rgba(16, 28, 38, .22);
    cursor: pointer;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0;
    pointer-events: auto;
}
.parcel-scan-button:hover,
.parcel-scan-widget.is-open .parcel-scan-button {
    background: #173d4b;
    color: #ffffff;
}
.parcel-scan-panel {
    position: absolute;
    top: 18px;
    right: 18px;
    bottom: 48px;
    width: min(380px, calc(100% - 128px));
    border: 1px solid var(--vr-line);
    border-radius: 8px;
    background: rgba(255, 255, 255, .98);
    box-shadow: 0 18px 44px rgba(16, 28, 38, .18);
    overflow: hidden;
    pointer-events: auto;
    display: flex;
    flex-direction: column;
}
.parcel-scan-panel[hidden] {
    display: none;
}
.parcel-scan-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--vr-line);
}
.parcel-scan-head strong {
    min-width: 0;
    font-size: 13px;
    font-weight: 700;
}
.parcel-scan-head button {
    width: 26px;
    height: 26px;
    border: 1px solid var(--vr-line);
    border-radius: 6px;
    background: var(--vr-paper);
    color: var(--vr-text-2);
    cursor: pointer;
}
.parcel-scan-status {
    margin: 0;
    padding: 9px 12px;
    color: var(--vr-text-3);
    font-size: 11px;
    line-height: 1.45;
    border-bottom: 1px solid var(--vr-line);
}
.parcel-scan-list {
    min-height: 0;
    flex: 1;
    overflow: auto;
    padding: 10px;
    display: grid;
    gap: 6px;
    align-content: start;
}
.parcel-scan-row,
.parcel-scan-empty {
    border: 1px solid var(--vr-line);
    border-radius: 7px;
    padding: 8px 9px;
    display: grid;
    gap: 2px;
    background: var(--vr-paper);
}
.parcel-scan-row:hover {
    border-color: var(--vr-accent-line);
    background: var(--vr-accent-soft);
}
.parcel-scan-row strong {
    color: var(--vr-text);
    font-family: var(--vr-mono);
    font-size: 12px;
    font-weight: 700;
    overflow-wrap: anywhere;
}
.parcel-scan-row span,
.parcel-scan-empty {
    color: var(--vr-text-3);
    font-size: 11px;
    overflow-wrap: anywhere;
}
.parcel-scan-map-label {
    border: 1px solid rgba(31, 78, 95, .22);
    border-radius: 6px;
    background: rgba(255, 255, 255, .94);
    color: var(--vr-text);
    box-shadow: 0 6px 16px rgba(16, 28, 38, .16);
    font-family: var(--vr-mono);
    font-size: 10px;
    font-weight: 700;
    padding: 2px 5px;
}
.parcel-scan-map-label::before {
    display: none;
}
.dashboard-official-map { min-height: 430px; }
.parcel-official-map { min-height: 380px; }
.geo-map-panel { display: grid; gap: 14px; }
.geo-facts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.geo-facts div {
    border: 1px solid var(--vr-line);
    border-radius: 6px;
    padding: 10px;
    display: grid;
    gap: 4px;
}
.geo-facts strong { font-size: 13px; color: var(--vr-text-2); font-weight: 500; }
.source-stack { display: grid; gap: 10px; }
.source-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    border: 1px solid var(--vr-line);
    border-radius: 6px;
    padding: 10px;
}
.source-row strong { font-size: 13px; color: var(--vr-text); font-weight: 600; }
.report-panel { display: grid; gap: 16px; }
.report-head { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; }
.report-score { display: grid; gap: 8px; min-width: 190px; }
.report-score span {
    border: 1px solid var(--vr-line-2);
    border-radius: 6px;
    padding: 8px 10px;
    font-family: var(--vr-mono);
    color: var(--vr-accent);
    background: var(--vr-accent-soft);
}
.report-evidence {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--vr-line);
}
.report-evidence:last-child { border-bottom: 0; }

.login-page {
    min-height: 100vh;
    background: var(--vr-paper);
    color: var(--vr-text);
}
.login-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(430px, 0.78fr) minmax(560px, 1.22fr);
}
.login-hero { padding: 42px 54px; display: flex; flex-direction: column; justify-content: space-between; gap: 60px; }
.login-copy { max-width: 720px; }
.login-copy h1 { margin: 0; font-size: clamp(44px, 6vw, 78px); line-height: 1.02; letter-spacing: 0; font-weight: 500; }
.login-copy p { margin: 24px 0 0; max-width: 560px; color: var(--vr-text-2); font-size: 16px; line-height: 1.6; }
.login-actions { display: flex; align-items: center; gap: 14px; margin-top: 30px; flex-wrap: wrap; }
.ticker-strip { display: flex; gap: 24px; align-items: center; font-family: var(--vr-mono); font-size: 11px; color: var(--vr-text-3); flex-wrap: wrap; }
.ticker-strip b { color: var(--vr-text-2); font-weight: 500; }
.login-preview { border-left: 1px solid var(--vr-line); background: var(--vr-paper-2); padding: 28px; display: flex; align-items: stretch; }
.preview-card { width: 100%; min-height: calc(100vh - 56px); background: var(--vr-paper); border: 1px solid var(--vr-line); border-radius: 10px; overflow: hidden; box-shadow: var(--vr-shadow); display: flex; flex-direction: column; }
.preview-header { padding: 16px 18px; border-bottom: 1px solid var(--vr-line); display: flex; justify-content: space-between; align-items: center; }
.preview-chart { flex: 1; min-height: 520px; padding: 14px; }
.preview-chart .official-map-shell,
.preview-chart .official-map { height: 100%; }
.preview-chart .official-map-shell { display: flex; flex-direction: column; }
.preview-chart .official-map { flex: 1; min-height: 0; }
.login-map-preview { width: 100%; height: 100%; border-radius: 8px; border: 1px solid var(--vr-line); }

.territory-page { min-height: 100vh; background: var(--vr-paper); }
.public-topbar {
    height: 64px;
    border-bottom: 1px solid var(--vr-line);
    background: rgba(255, 255, 255, .96);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 0 20px;
}
.public-topbar .brand-lockup { padding: 0; }
.public-nav { display: flex; align-items: center; gap: 6px; }
.public-nav a {
    min-height: 34px;
    border-radius: 6px;
    padding: 8px 10px;
    color: var(--vr-text-2);
    font-size: 13px;
    font-weight: 500;
}
.public-nav a:hover,
.public-nav a.active {
    background: var(--vr-accent-soft);
    color: var(--vr-accent);
}
.territory-shell {
    min-height: calc(100vh - 64px);
    display: grid;
    grid-template-columns: minmax(360px, .34fr) minmax(0, 1.66fr);
    background: var(--vr-paper);
}
.territory-side {
    max-height: calc(100vh - 64px);
    overflow: auto;
    border-right: 1px solid var(--vr-line);
    padding: 26px 22px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.territory-side h1 {
    margin: 0;
    font-size: 34px;
    line-height: 1.12;
    letter-spacing: 0;
    font-weight: 600;
}
.territory-side p { margin: 12px 0 0; line-height: 1.55; font-size: 14px; }
.territory-map-column {
    min-width: 0;
    padding: 12px 12px 12px 0;
    background: var(--vr-paper-2);
}
.territory-map-shell,
.territory-map {
    height: 100%;
}
.territory-main-map {
    min-height: 560px;
}
.territory-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
}
.territory-highlight {
    border: 1px solid var(--vr-line);
    border-radius: 8px;
    padding: 12px;
    display: grid;
    gap: 8px;
    background: var(--vr-paper-2);
}
.territory-highlight a,
.territory-highlight strong {
    display: grid;
    gap: 3px;
}
.territory-highlight span:not(.vr-label) { color: var(--vr-text-3); font-size: 12px; }
.planning-mini-list {
    display: grid;
    gap: 4px;
}
.planning-mini-list span {
    color: var(--vr-text-3);
    font-size: 11px;
    overflow-wrap: anywhere;
}
.territory-list { display: grid; gap: 8px; }
.province-population-list {
    max-height: clamp(220px, calc(100vh - 420px), 420px);
    overflow: auto;
    padding-right: 2px;
}
.territory-list-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 2px;
}
.province-grid-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
}
.province-grid-list a,
.nucleus-row,
.coverage-empty {
    border: 1px solid var(--vr-line);
    border-radius: 7px;
    padding: 9px 10px;
    display: grid;
    gap: 3px;
    background: var(--vr-paper);
}
.province-grid-list a:hover,
.nucleus-row:hover {
    border-color: var(--vr-accent-line);
    background: var(--vr-accent-soft);
    color: var(--vr-accent);
}
.nucleus-row.active {
    border-color: var(--vr-accent);
    background: var(--vr-accent-soft);
    color: var(--vr-accent);
}
.province-grid-list strong,
.nucleus-row strong,
.coverage-empty strong {
    min-width: 0;
    overflow-wrap: anywhere;
    font-size: 13px;
    font-weight: 600;
}
.province-grid-list span,
.nucleus-row span,
.coverage-empty span {
    min-width: 0;
    overflow-wrap: anywhere;
    color: var(--vr-text-3);
    font-size: 11px;
}
.territory-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    color: var(--vr-text-3);
    font-size: 12px;
}
.territory-breadcrumb a:hover { color: var(--vr-accent); }
.territory-breadcrumb strong { color: var(--vr-text); font-weight: 600; }
.territory-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.territory-stats div {
    border: 1px solid var(--vr-line);
    border-radius: 7px;
    padding: 10px;
    display: grid;
    gap: 4px;
    background: var(--vr-paper);
}
.territory-stats strong { font-size: 22px; font-weight: 500; }

@media (max-width: 1100px) {
    .grid.two { grid-template-columns: 1fr; }
    .mini-stats { display: none; }
    .geo-hero { grid-template-columns: 1fr; }
    .territory-shell { grid-template-columns: 1fr; }
    .territory-side { max-height: none; border-right: 0; border-bottom: 1px solid var(--vr-line); }
    .territory-map-column { padding: 12px; }
    .territory-main-map { min-height: 520px; }
}
@media (max-width: 860px) {
    .shell { grid-template-columns: 1fr; }
    .sidebar { position: static; height: auto; border-right: 0; border-bottom: 1px solid var(--vr-line); }
    .nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .sidebar-footer { display: none; }
    .topbar { height: auto; min-height: 56px; flex-wrap: wrap; padding: 12px 16px; }
    .topbar-actions { width: 100%; margin-left: 0; justify-content: space-between; }
    .timeframes { display: none; }
    .page { padding: 16px; }
    .grid.metrics, .form-grid { grid-template-columns: 1fr; }
    .geo-hero, .geo-search, .population-search, .geo-facts, .hero-facts, .municipality-loaded { grid-template-columns: 1fr; }
    .login-shell { grid-template-columns: 1fr; }
    .login-hero { padding: 28px 22px; min-height: 620px; }
    .login-preview { display: none; }
    .login-copy h1 { font-size: 42px; }
    .public-topbar { height: auto; min-height: 60px; align-items: flex-start; flex-direction: column; padding: 14px 16px; }
    .public-nav { width: 100%; overflow-x: auto; }
    .territory-shell { min-height: auto; }
    .territory-side { padding: 18px 16px; }
    .territory-side h1 { font-size: 30px; }
    .territory-search, .province-grid-list, .territory-stats { grid-template-columns: 1fr; }
    .province-grid-list { max-height: 300px; overflow: auto; padding-right: 2px; }
    .territory-map-column { padding: 0; }
    .territory-map-shell { border-left: 0; border-right: 0; border-radius: 0; }
    .territory-main-map { min-height: 460px; }
    .parcel-scan-button { left: 12px; right: 12px; bottom: 42px; justify-content: center; }
    .parcel-scan-panel {
        left: 10px;
        right: 10px;
        top: auto;
        bottom: 108px;
        width: auto;
        max-height: 330px;
    }
}
