:root{
  /* GOV.UK-ish palette */
  --bg:#ffffff;
  --panel:#f3f2f1;         /* GOV.UK light grey */
  --ink:#0b0c0c;           /* GOV.UK text */
  --text:#0b0c0c;
  --muted:#505a5f;         /* GOV.UK secondary text */
  --border:#b1b4b6;        /* GOV.UK border */
  --accent:#1d70b8;        /* GOV.UK link blue */
  --btn:#00703c;           /* GOV.UK green */
  --btnHover:#005a30;
  --focus:#ffdd00;         /* GOV.UK focus yellow */
  --radius:0px;            /* GOV.UK is square */
  --shadow:none;
  --max:1400px;

  /* GOV.UK font stack (no external import) */
  --font:"GDS Transport", Arial, Helvetica, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.55}

/* Links */
a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
a:hover{text-decoration-thickness:2px}
a:focus,button:focus{outline:3px solid var(--focus);outline-offset:0}

/* Container */
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.muted{color:var(--muted)}
.fineprint{font-size:14px;color:var(--muted);margin:12px 0 0}

/* Skip link (GOV.UK style) */
.skip{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{
  left:18px;top:12px;width:auto;height:auto;
  background:var(--focus);color:#000;padding:10px 12px;z-index:999;
  outline:3px solid #000;
}

/* Topbar (black GOV.UK header) */
.topbar{position:sticky;top:0;z-index:50;background:#0b0c0c;color:#fff;border-bottom:0}
.topbar__inner{display:flex;align-items:center;gap:16px;min-height:64px}

/* Brand */
.brand{display:flex;align-items:center;gap:12px;flex:1}
.brand__link{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-weight:700}
.brand__link:hover{text-decoration:underline}
.brand__mark{width:22px;height:22px;border-radius:0;background:#85994b;display:inline-block}
.brand__name{font-weight:800;letter-spacing:.2px}
.brand__tag{color:#d6d6d6;font-size:14px;display:none}

/* Nav */
.nav{display:flex;align-items:center;gap:16px}
.nav a{
  color:#fff;font-weight:700;text-decoration:none;
  padding:6px 0;border-bottom:3px solid transparent;
}
.nav a:hover{border-bottom-color:#fff}
.navToggle{
  display:none;margin-left:auto;
  border:2px solid #fff;background:transparent;color:#fff;
  padding:8px 10px;font-weight:800;border-radius:0;
}

/* Green strip under header (like HMLR portal) */
.notice{
  background:#85994b;color:#0b0c0c;
  border-bottom:1px solid var(--border);
  padding:10px 0;font-size:15px;
}
.notice strong{font-weight:800}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:0;border:2px solid transparent;
  background:var(--btn);color:#fff;font-weight:800;
  text-decoration:none;box-shadow:none;
}
.btn:hover{background:var(--btnHover);text-decoration:none}
.btn:focus{outline:3px solid var(--focus);outline-offset:0}
.btn--ghost{background:transparent;border-color:#fff;color:#fff}
.btn--ghost:hover{background:rgba(255,255,255,.12)}

/* Page sections */
.section{padding:22px 0 34px}

/* Hero */
.hero{padding:18px 0 10px}
.hero__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start}

/* Cards */
.card{background:#fff;border:1px solid var(--border);border-radius:0;box-shadow:none}
.card__pad{padding:18px}

/* Headings */
.kicker{
  display:inline-flex;gap:10px;align-items:center;
  background:var(--panel);border:1px solid var(--border);
  padding:6px 10px;border-radius:0;
  font-weight:800;font-size:14px;color:var(--muted)
}
.h1{font-size:44px;line-height:1.08;margin:12px 0 10px;color:var(--ink);letter-spacing:-.4px}
.h2{font-size:24px;margin:0 0 12px;font-weight:800}
.lead{font-size:18px;color:var(--muted);margin:0 0 14px}
.hero__cta{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}

/* Tiles / panels */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tile{padding:16px;border-radius:0;border:1px solid var(--border);background:var(--panel)}
.tile strong{display:block;margin-bottom:6px;color:var(--ink);font-weight:800}
.tile p{margin:8px 0 0}

/* Posts */
.postlist{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.post{border:1px solid var(--border);border-radius:0;background:#fff;overflow:hidden}
.post__pad{padding:16px}
.post__meta{font-size:14px;color:var(--muted)}
.post__title{font-size:18px;margin:8px 0;color:var(--ink);font-weight:800}
.post__excerpt{margin:0;color:var(--muted)}

/* Content column */
.content{max-width:860px;margin:0 auto}
.content h1{font-size:38px;letter-spacing:-.3px;font-weight:800}
.content h2{font-size:24px;margin-top:22px;font-weight:800}
.content ul{padding-left:18px}

/* HR */
.hr{height:1px;background:var(--border);border:0;margin:18px 0}

/* Badges */
.badges{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 0}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--panel);border:1px solid var(--border);
  padding:6px 10px;border-radius:0;
  font-size:14px;color:var(--muted);font-weight:800
}

/* Search bar (postcode row) */
.searchbar{display:flex;gap:10px;align-items:center;margin:12px 0 16px}
.searchbar input{
  flex:1;border:4px solid var(--ink);
  border-radius:0;padding:10px 12px;font-weight:700;background:#fff;
}
.searchbar input:focus{outline:3px solid var(--focus);outline-offset:0;border-color:#000}
.searchbar select{
  border:2px solid var(--ink);
  border-radius:0;padding:10px 12px;font-weight:800;background:#fff;
}
.searchbar select:focus{outline:3px solid var(--focus);outline-offset:0}

/* CTA block (GOV panel style) */
.cta{margin:18px 0 0;padding:16px;border-radius:0;border:1px solid var(--border);background:var(--panel)}
.cta__grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cta p{margin:8px 0 0}

/* Footer */
.footer{border-top:1px solid var(--border);background:var(--panel);padding:22px 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:18px}
.footer__brand{font-weight:800}
.footer__title{font-weight:800;margin-bottom:8px}
.footer__list{list-style:none;padding:0;margin:0}
.footer__list li{margin:8px 0}
.footer__bottom{padding-top:12px;border-top:1px solid var(--border);margin-top:14px}

/* ============================
   FORM PAGE (Bootstrap-like classes)
   GOV/HMLR theme compatibility layer
   ============================ */

/* Basic body helpers */
.bg-light{background:#ffffff}
.bg-white{background:#ffffff}
.bg-dark{background:#0b0c0c;color:#fff}
.text-white{color:#fff}
.text-light{color:#f3f2f1}
.text-muted{color:var(--muted)}
.text-gray-400{color:#b1b4b6}
.text-gray-700{color:var(--muted)}
.text-primary{color:var(--accent)}
.text-decoration-none{text-decoration:none}
.text-decoration-none:hover{text-decoration:underline}

/* Sizing helpers */
.fs-sm{font-size:14px}
.fs-lg{font-size:18px}
.fw-bold{font-weight:800}
.fw-bolder{font-weight:900}
.text-uppercase{text-transform:uppercase}

/* Spacing helpers */
.mb-0{margin-bottom:0}
.mb-2{margin-bottom:.5rem}
.mb-3{margin-bottom:.75rem}
.mb-4{margin-bottom:1rem}
.mb-6{margin-bottom:1.5rem}
.mt-md-n6{margin-top:-1.25rem}
.pb-8{padding-bottom:2rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.pt-md-7{padding-top:1.75rem}
.pb-md-10{padding-bottom:2.5rem}
.my-5{margin-top:1.25rem;margin-bottom:1.25rem}
.ms-auto{margin-left:auto}
.ms-n4{margin-left:-1rem}
.d-none{display:none}
.d-lg-inline{display:inline-flex}

/* Layout system */
.container-md{max-width:var(--max);margin:0 auto;padding:0 18px}
.row{display:flex;flex-wrap:wrap;margin-left:-8px;margin-right:-8px}
.col,[class*="col-"]{padding-left:8px;padding-right:8px}
.col-auto{flex:0 0 auto;width:auto}
.col-12{flex:0 0 100%;max-width:100%}
.col-md-6{flex:0 0 50%;max-width:50%}
.col-md-12{flex:0 0 100%;max-width:100%}

/* Flex helpers */
.d-flex{display:flex}
.align-items-center{align-items:center}
.justify-content-between{justify-content:space-between}
.gap-2{gap:.5rem}
.g-3{gap:.75rem}
.g-3{display:flex;flex-wrap:wrap}
.g-3 > [class*="col-"]{margin-bottom:.75rem}

/* Navbar */
.navbar{background:#0b0c0c;color:#fff;border-bottom:0}
.navbar .container-md{display:flex;align-items:center;gap:14px;min-height:64px}
.navbar-brand{
  color:#fff;text-decoration:none;font-weight:900;
  display:inline-flex;align-items:center;gap:10px
}
.navbar-brand:hover{text-decoration:underline}
.navbar-brand-img{display:none}
.navbar-nav{list-style:none;margin:0;padding:0;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.nav-item{margin:0;padding:0}
.nav-link{
  color:#fff;text-decoration:none;font-weight:800;
  padding:6px 0;border-bottom:3px solid transparent;
}
.nav-link:hover{border-bottom-color:#fff}
.navbar-btn{white-space:nowrap}

/* Collapse */
.collapse{display:block}
.navbar-toggler{
  display:none;margin-left:auto;
  border:2px solid #fff;background:transparent;color:#fff;
  padding:8px 10px;font-weight:900;border-radius:0;
}
.navbar-toggler-icon{
  width:18px;height:2px;background:#fff;display:inline-block;position:relative;
}
.navbar-toggler-icon::before,
.navbar-toggler-icon::after{content:"";position:absolute;left:0;width:18px;height:2px;background:#fff}
.navbar-toggler-icon::before{top:-6px}
.navbar-toggler-icon::after{top:6px}

/* Dropdown */
.dropdown{position:relative}
.dropdown-menu{
  display:none;position:absolute;right:0;top:100%;
  background:#fff;color:#0b0c0c;
  border:1px solid var(--border);
  min-width:320px;z-index:100;
}
.dropdown.open .dropdown-menu{display:block}
.dropdown-menu-md{min-width:360px}
.list-group{display:block}
.list-group-flush{padding:0;margin:0}
.list-group-item{
  display:flex;gap:10px;align-items:flex-start;
  padding:12px 12px;border-bottom:1px solid var(--border);
  text-decoration:none;color:#0b0c0c;background:#fff;
}
.list-group-item:hover{background:var(--panel)}
.list-group-item:last-child{border-bottom:0}

/* Header icon */
.icon-circle{width:44px;height:44px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center}
.bg-primary{background:var(--btn)}
.icon-dot{width:16px;height:16px;background:#fff;display:block;border-radius:3px}

/* Card variants */
.card-body{padding:16px}
.card-bleed{padding:0}
.shadow-light-lg{box-shadow:none}

/* Alerts */
.alert{padding:12px 12px;border:1px solid var(--border);background:var(--panel);color:#0b0c0c;margin:12px 0}
.alert-danger{border-color:#d4351c;background:#fef7f6;color:#0b0c0c}
.alert-warning{border-color:#b58840;background:#fff7bf;color:#0b0c0c}
.alert strong{font-weight:900}

/* Form controls */
.form-label{display:block;font-weight:800;margin:0 0 6px;color:#0b0c0c}
.form-control,.form-select{
  width:100%;
  border:2px solid #0b0c0c;
  border-radius:0;
  padding:10px 12px;
  font-weight:700;
  background:#fff;
}
.form-control:focus,.form-select:focus{outline:3px solid var(--focus);outline-offset:0;border-color:#0b0c0c}
.form-select{appearance:auto}

/* Buttons variants */
.btn-sm{padding:7px 10px;font-size:14px}
.btn-lg{padding:12px 16px;font-size:16px}
.btn-primary{background:var(--btn);color:#fff;border:2px solid transparent}
.btn-primary:hover{background:var(--btnHover)}
.btn-outline-primary{background:transparent;color:var(--btn);border:2px solid var(--btn)}
.btn-outline-primary:hover{background:rgba(0,112,60,.08)}
.btn-outline-danger{background:transparent;color:#d4351c;border:2px solid #d4351c}
.btn-outline-danger:hover{background:#fef7f6}

/* ============================
   ADDRESS SELECTION (integrated cleanly)
   Works with:
   - <div id="results" class="results"><div class="result">...</div></div>
   - .addr-list / .addr-item
   - .addr-row blocks (if used)
   ============================ */

/* Results dropdown (address suggestions / selection) */
.results{
  position:relative;
  z-index:1000;
  margin-top:12px;
  border:1px solid var(--border);
  border-radius:0;
  overflow:hidden;
  background:#fff;
}
.results .result{
  cursor:pointer;
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  background:#fff;
  font-size:17px;
  line-height:1.35;
}
.results .result:last-child{border-bottom:0}
.results .result:hover{background:var(--panel)}
.results .result.active{
  background:#e8f3ff;
  border-left:4px solid var(--accent);
}
.results *{pointer-events:auto !important}

/* Address list (alternative renderer) */
.addr-list{
  border:1px solid var(--border);
  border-radius:0;
  overflow:hidden;
  background:#fff;
}
.addr-item{
  padding:12px 14px;
  border-top:1px solid var(--border);
  cursor:pointer;
}
.addr-item:first-child{border-top:0}
.addr-item:hover{background:var(--panel)}

/* Address row blocks (chosen address summary + controls) */
.addr-row{
  border:1px solid var(--border);
  border-radius:0;
  background:#fff;
  padding:12px 14px;
  margin-bottom:12px;
}
.addr-row__main{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.addr-row__address{color:var(--text)}
.addr-row__ctrls{display:flex;gap:8px;flex-wrap:wrap}
.addr-row__expander{margin-top:10px;display:none}
.addr-row--open .addr-row__expander{display:block}

/* Vue cloak */
[v-cloak]{display:none !important}

/* Responsive */
@media (max-width: 980px){
  .hero__grid{grid-template-columns:1fr}
  .grid3,.postlist,.footer__grid{grid-template-columns:1fr}
  .brand__tag{display:inline}
  .nav{
    display:none;position:absolute;left:0;right:0;top:64px;
    background:#0b0c0c;border-top:1px solid rgba(255,255,255,.2);
    padding:12px 18px;flex-direction:column;align-items:stretch;
  }
  .nav a{padding:10px 8px;border-bottom:1px solid rgba(255,255,255,.15)}
  .navToggle{display:inline-flex}
  .nav.is-open{display:flex}
  .h1{font-size:34px}
  .cta__grid{grid-template-columns:1fr}
  .navbar-nav{width:100%;flex-direction:column;align-items:stretch;gap:0}
  .nav-link{padding:10px 8px;border-bottom:1px solid rgba(255,255,255,.15)}
  .navbar-toggler{display:inline-flex}
  .collapse.navbar-collapse{display:none;width:100%}
  .collapse.navbar-collapse.is-open{display:block}
  .col-md-6{flex:0 0 100%;max-width:100%}
  .d-lg-inline{display:none}
}

@media (max-width: 560px){
  .searchbar{flex-direction:column;align-items:stretch}
}

/* Make buttons inside nav look right on black header */
.topbar .btn{background:var(--btn);border-color:transparent}
.topbar .btn:hover{background:var(--btnHover)}
.topbar .btn--ghost{border-color:#fff;background:transparent;color:#fff}