:root{
  --bg:#faf7f2; --ink:#1f2933; --muted:#6b7280; --paper:#ffffff; --line:#e7e2d9;
  --brand:#0b6b53; --brand-ink:#08543f; --accent:#c2410c; --gold:#b88a00;
  --maxw:1080px; --radius:14px; --shadow:0 1px 3px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.05);
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --serif:'Playfair Display',Georgia,serif;
  --pill-green:#1a7f5a; --pill-amber:#b8860b; --pill-red:#b4413c;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font:16px/1.55 var(--font);}
a{color:var(--brand-ink);}
h1{font:700 2rem/1.15 var(--serif);margin:.2em 0 .3em;}
h2.sec-title{font:700 1.25rem/1.2 var(--serif);margin:1.6em 0 .6em;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px;}
.muted{color:var(--muted);} .num{text-align:right;font-variant-numeric:tabular-nums;}

/* header + search */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,247,242,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.header-inner{display:flex;align-items:center;gap:18px;padding:12px 0;}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;}
.brand-name{font:700 19px var(--serif);color:var(--brand-ink);}
.search{position:relative;margin-left:auto;width:min(420px,46vw);}
.search.big{margin:18px auto 0;width:min(560px,100%);}
.search input{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:999px;background:var(--paper);font-size:15px;}
.search.big input{padding:14px 18px;font-size:17px;}
.results{position:absolute;top:112%;left:0;right:0;background:var(--paper);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);max-height:60vh;overflow:auto;z-index:60;}
.results a{display:block;padding:10px 12px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);}
.results a:last-child{border-bottom:0;} .results a:hover{background:var(--bg);}
.results a.see-all{font-size:13px;font-weight:600;color:var(--brand-ink);text-align:center;background:#f6f3ec;}
.breadcrumbs{border-bottom:1px solid var(--line);background:var(--paper);}
.breadcrumbs .wrap{padding:8px 18px;font-size:13px;color:var(--muted);}
.breadcrumbs a{color:var(--muted);text-decoration:none;} .breadcrumbs a:hover{color:var(--brand-ink);}

/* glossary (?) tooltip links */
.term{white-space:nowrap;}
.term-q{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;margin-left:3px;border-radius:50%;border:1px solid var(--line);background:var(--paper);color:var(--muted);font-size:10px;font-weight:700;line-height:1;text-decoration:none;vertical-align:super;}
.term-q:hover{background:var(--brand);color:#fff;border-color:var(--brand);}
.prose h2[id]{scroll-margin-top:80px;}

/* hero + homepage */
.hero{text-align:center;padding:34px 0 8px;}
.hero h1{font-size:2.6rem;margin:0;}
.lede{color:var(--muted);max-width:680px;margin:.5em auto 0;font-size:1.05rem;}
.region-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}
.region-card{display:flex;flex-direction:column;gap:4px;padding:16px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);text-decoration:none;color:var(--ink);box-shadow:var(--shadow);transition:transform .08s;}
.region-card:hover{transform:translateY(-2px);}
.rc-name{font-weight:600;} .rc-meta{color:var(--muted);font-size:13px;}
.top-lists{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
@media(max-width:640px){.top-lists{grid-template-columns:1fr;}}
.rank-list{list-style:none;margin:0;padding:0;}
.rank-list li{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);}
.rank-list li a{font-weight:600;text-decoration:none;flex:1;}
.rank-list .muted{font-size:13px;}
.explain{margin:26px 0;padding:18px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);}

/* pills */
.pill{display:inline-block;min-width:38px;text-align:center;padding:2px 9px;border-radius:999px;color:#fff;font-weight:700;font-size:13px;}
.pill-green{background:var(--pill-green);} .pill-amber{background:var(--pill-amber);} .pill-red{background:var(--pill-red);} .pill-na{background:#c7c2b8;}

/* tables */
.data-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.data-table th,.data-table td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;}
.data-table th{background:#f3efe7;font-size:13px;letter-spacing:.02em;}
.data-table tr:last-child td{border-bottom:0;}
.data-table a{text-decoration:none;font-weight:600;}

/* MSOA page */
.entity-head{margin-top:18px;} .entity-head .sub{color:var(--muted);margin:.2em 0 0;}
.area-summary{margin:14px 0;padding:16px 20px;background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:var(--radius);box-shadow:var(--shadow);}
.area-summary h2{font:700 .78rem var(--font);letter-spacing:.08em;text-transform:uppercase;color:var(--brand-ink);margin:0 0 .35em;}
.area-summary p{margin:0;font-size:1.02rem;line-height:1.6;}

/* share buttons */
.share{display:flex;align-items:center;flex-wrap:wrap;gap:7px;margin:10px 0 2px;}
.share .sh-lead{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-right:2px;}
.sh{display:inline-block;padding:5px 11px;border-radius:999px;font-size:12.5px;font-weight:600;color:#fff;text-decoration:none;border:0;cursor:pointer;line-height:1.3;transition:filter .1s,transform .06s;}
.sh:hover{filter:brightness(1.08);transform:translateY(-1px);}
.sh-x{background:#111;} .sh-wa{background:#25d366;} .sh-fb{background:#1877f2;}
.sh-li{background:#0a66c2;} .sh-em{background:#6b7280;} .sh-copy{background:var(--brand);}
/* similar-areas list: reuse .rank-list; add a price column */
.similar .rank-list li,.nearby .rank-list li{gap:8px;}
.sim-price{font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums;min-width:74px;text-align:right;}
.score-hero{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center;margin:14px 0;padding:18px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);}
.callout{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px 22px;border-radius:var(--radius);min-width:120px;}
.callout.area{background:var(--brand);color:#fff;}
.callout .big{font:800 2.8rem/1 var(--serif);} .callout .lbl{font-size:12px;opacity:.92;margin-top:4px;text-align:center;}
.callout.price{background:#f3efe7;}
.rank-facts{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 18px;}
.rank-facts li{font-size:14px;color:var(--muted);} .rank-facts b{color:var(--ink);}
.rank-facts .band{grid-column:1/-1;font-weight:600;color:var(--brand-ink);}
.cta{grid-column:1/-1;justify-self:start;margin-top:4px;display:inline-block;padding:9px 16px;background:var(--accent);color:#fff;border-radius:999px;text-decoration:none;font-weight:600;font-size:14px;}

/* affordability-adjusted (value) score */
.callout.value{background:var(--brand-ink);color:#fff;}
.value-score{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center;margin:14px 0;padding:18px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);}
.value-score .sec-title{grid-column:1/-1;margin:0 0 2px;}
.value-score .rank-facts{grid-template-columns:1fr;}
.value-score .cta{background:var(--brand);}
@media(max-width:560px){.value-score{grid-template-columns:1fr;}}

/* compare tool */
.compare-pickers{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:14px 0;}
.cp-slot{position:relative;}
.cp-slot input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--paper);font-size:15px;}
.cp-dd{position:absolute;top:104%;left:0;right:0;background:var(--paper);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);z-index:60;max-height:50vh;overflow:auto;}
.cp-dd a{display:block;padding:9px 12px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);font-size:14px;}
.cp-dd a:last-child{border-bottom:0;} .cp-dd a:hover{background:var(--bg);}
.compare-grid th{text-align:left;vertical-align:bottom;} .compare-grid td:first-child,.compare-grid th:first-child{color:var(--muted);}
.bars{display:flex;flex-direction:column;gap:9px;}
.bar-row{display:grid;grid-template-columns:130px 1fr 86px;align-items:center;gap:12px;}
.bar-lbl{font-size:14px;} .bar-track{height:12px;background:#eee7da;border-radius:999px;overflow:hidden;}
.bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--pill-red),var(--gold),var(--pill-green));}
.bar-val{font-size:13px;text-align:right;font-variant-numeric:tabular-nums;}
.prices-table td:first-child,.prices-table th:first-child{text-align:left;}
.supp{font-style:italic;}
.bench-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:14px 0;}
.bench{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:10px;text-align:center;}
.bench .bl{display:block;font-size:12px;color:var(--muted);} .bench .bv{font-weight:700;}
.chart{margin:16px 0;padding:14px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);}
.sources ul,.nearby{margin:0;padding:0;} .sources li{margin:4px 0;}
section{margin:18px 0;}

/* prose / static */
.prose{max-width:760px;} .prose h2{font:700 1.3rem var(--serif);margin:1.4em 0 .4em;}
.prose p{margin:.7em 0;} .formula{background:#f3efe7;padding:12px 16px;border-radius:10px;font-family:var(--serif);}
.caveat{background:#fff7ed;border:1px solid #f3d8b8;border-radius:10px;padding:12px 14px;color:#7c4a16;font-size:14px;}
.caveat.small{font-size:12px;padding:8px 12px;}

/* ads */
.ad-slot{margin:18px 0;min-height:90px;border:1px dashed var(--line);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--muted);background:repeating-linear-gradient(45deg,#fbfaf7,#fbfaf7 10px,#f4f1ea 10px,#f4f1ea 20px);}
.ad-placeholder{font-size:12px;letter-spacing:.08em;text-transform:uppercase;}
.ad-rect{min-height:250px;max-width:336px;margin-left:auto;margin-right:auto;}

/* footer */
.site-footer{margin-top:30px;border-top:1px solid var(--line);background:var(--paper);}
.site-footer .wrap{padding:20px 18px;}
.site-footer .src{font-size:12px;color:var(--muted);} .site-footer .legal{font-size:13px;color:var(--muted);}
.site-footer a{color:var(--brand-ink);text-decoration:none;}

/* ── homepage: house-price snapshot ── */
.price-snapshot{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:20px 0 6px;}
@media(max-width:640px){.price-snapshot{grid-template-columns:1fr 1fr;}}
.price-snapshot .ps{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:13px;text-align:center;box-shadow:var(--shadow);}
.price-snapshot .ps .v{display:block;font:800 1.55rem/1 var(--serif);color:var(--brand-ink);}
.price-snapshot .ps .v.chg-pos{color:var(--pill-green);} .price-snapshot .ps .v.chg-neg{color:var(--pill-red);}
.price-snapshot .ps .k{display:block;font-size:12px;color:var(--muted);margin-top:5px;}

/* ── homepage: best value ── */
.bv-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.bv-head .sec-title{margin-bottom:0;}
.bv-more{font-weight:600;font-size:14px;text-decoration:none;}
.bv-intro{margin:.3em 0 14px;}
.bv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));gap:14px;}
.bv-card{position:relative;display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:15px 16px;text-decoration:none;color:var(--ink);transition:transform .08s;}
.bv-card:hover{transform:translateY(-2px);}
.bv-rank{position:absolute;top:-10px;left:-10px;width:30px;height:30px;border-radius:50%;background:var(--brand-ink);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);}
.bv-card.top3 .bv-rank{background:var(--gold);}
.bv-name{display:block;font-weight:700;font-size:1.02rem;}
.bv-la{display:block;color:var(--muted);font-size:13px;margin-bottom:10px;}
.bv-figs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;text-align:center;border-top:1px solid var(--line);padding-top:10px;}
.bv-figs .f .v{display:block;font-weight:700;font-size:1.02rem;}
.bv-figs .f .v.money{font-variant-numeric:tabular-nums;}
.bv-figs .f.val .v{color:var(--brand-ink);}
.bv-figs .f .k{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;}

/* ── homepage: enriched rank tables ── */
.rank-table td,.rank-table th{vertical-align:middle;}
.rank-table .place{font-weight:600;}
.rank-table .place .rnk{display:inline-block;min-width:20px;color:var(--muted);font-weight:700;}
.rank-table .place a{text-decoration:none;}
.rank-table .place small{display:block;font-weight:400;color:var(--muted);font-size:12px;padding-left:20px;}
.subpills{display:flex;gap:4px;flex-wrap:wrap;}
.sp{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;min-width:32px;padding:2px 5px;border-radius:6px;color:#fff;font-weight:700;font-size:12px;line-height:1.1;}
.sp .spl{font-size:8px;font-weight:600;opacity:.9;letter-spacing:.03em;}
.sp-income{background:#0b6b53;} .sp-education{background:#1a6fb0;} .sp-health{background:#b4413c;}
.sp-crime{background:#7a5cc0;} .sp-living_environment{background:#b8860b;}
@media(max-width:560px){.rank-table .subcell{display:none;}}
.score-note{font-size:13px;margin:10px 0 4px;}

/* ── interactive maps (homepage region map + postcode hub map) ── */
.map-container{height:420px;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#eef3f1;margin:10px 0 0;z-index:1;}
.region-explore .map-container{height:440px;margin:4px 0 0;}
@media(max-width:640px){.region-explore .map-container{height:340px;}}
.map-legend{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin:10px 0 16px;flex-wrap:wrap;}
.map-legend .ml-cap{font-weight:600;color:var(--ink);}
.map-legend .bar{width:120px;height:10px;border-radius:6px;background:linear-gradient(90deg,rgb(180,67,60),rgb(222,176,40),rgb(26,127,90));}
.map-legend .ml-note{margin-left:auto;font-style:italic;}
.region-explore .region-grid{margin-top:4px;}
.leaflet-popup-content .pp{font:14px/1.5 var(--font);}
.leaflet-popup-content .pp b{color:var(--brand-ink);}
.leaflet-popup-content .pp a{display:inline-block;margin-top:6px;font-weight:600;color:var(--accent);text-decoration:none;}

/* ── context links (place + postcode) on area pages ── */
.context-links{margin:.35em 0 .1em;font-size:14px;color:var(--muted);}
.context-links a{color:var(--brand-ink);text-decoration:none;font-weight:600;}
.context-links a:hover{text-decoration:underline;}

/* ── area-page locator map (short) ── */
.locator-wrap{margin:14px 0 4px;}
.locator-map{height:240px;margin:0;}
@media(max-width:640px){.locator-map{height:200px;}}
.locator-wrap .small{margin:6px 0 0;font-size:11.5px;}

/* ── town/place chips on local-authority pages ── */
.places-in{margin:14px 0 18px;}
.place-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.place-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;background:var(--paper);
  border:1px solid var(--line);border-radius:999px;color:var(--brand-ink);text-decoration:none;
  font-weight:600;font-size:14px;box-shadow:var(--shadow);}
.place-chip:hover{border-color:var(--brand);background:#f3faf7;}
.place-chip .pc-n{font-weight:600;font-size:11px;color:#fff;background:var(--brand);border-radius:999px;
  min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;}

/* ── postcode index (A–Z) ── */
.pc-group{margin:0 0 14px;}
.pc-area{font:700 1.1rem var(--serif);color:var(--brand-ink);margin:.6em 0 .3em;border-bottom:1px solid var(--line);padding-bottom:.2em;}
.pc-links{display:flex;flex-wrap:wrap;gap:7px;}
.pc-links a{display:inline-block;padding:4px 10px;background:var(--paper);border:1px solid var(--line);
  border-radius:8px;color:var(--brand-ink);text-decoration:none;font-size:13.5px;font-variant-numeric:tabular-nums;}
.pc-links a:hover{border-color:var(--brand);background:#f3faf7;}

/* ── standalone search results page ── */
.search-results{margin-top:14px;}
.search-hits{list-style:none;padding:0;margin:.4em 0;}
.search-hits li{margin:0;border-bottom:1px solid var(--line);}
.search-hits li a{display:block;padding:11px 6px;text-decoration:none;color:var(--ink);}
.search-hits li a:hover{background:#f3faf7;}
.search-hits li a b{color:var(--brand-ink);}

/* ── region / local-authority overview maps ── */
.la-map{height:400px;margin:6px 0 0;}
@media(max-width:640px){.la-map{height:300px;}}
