:root{--bg:#fafbfc;--hero:#ffffff;--ink:#0f172a;--muted:#61686b;--primary:#e24d11;--secondary:#f4a600;--dark:#393d3f;--ring:rgba(226,77,17,.28);--radius:16px;--shadow:0 20px 60px rgba(2,6,23,.06);--border:#e8edf2;--max:1200px} *{box-sizing:border-box} html,body{height:100%} body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)} .container{max-width:var(--max);margin:0 auto;padding:24px} .site-header{position:sticky;top:0;background:#ffffffcc;backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border);z-index:10} .nav a{padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--dark);font-weight:700;margin-right:8px;text-decoration:none} .nav a:hover{box-shadow:0 6px 20px rgba(2,6,23,.08)} .brand{font-weight:900;text-decoration:none;color:inherit} .page-title{margin:8px 0 10px;font-size:28px} .card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:16px} .filters{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;margin:12px 0} .filters .row{display:flex;gap:10px;align-items:end;flex-wrap:wrap} .filters label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:6px} .filters select,input[type="text"],input[type="email"],textarea{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff} .btn{appearance:none;border:1px solid var(--border);background:#fff;padding:10px 14px;border-radius:10px;cursor:pointer;font-weight:800} .btn.primary{background:var(--secondary);border-color:var(--secondary);color:#000} .btn.ghost{background:#fff} .grid-cards{display:grid;grid-template-columns:1fr;gap:16px} @media(min-width:700px){.grid-cards{grid-template-columns:repeat(2,1fr)}} @media(min-width:1024px){.grid-cards{grid-template-columns:repeat(3,1fr)}} .card .provider{display:flex;align-items:center;gap:10px} .logo-sq{width:40px;height:40px;border-radius:10px;background:#fff;border:1px solid var(--border);display:grid;place-items:center;font-weight:900;color:var(--dark)} .title-sm{margin:0 0 2px;font-size:18px} .meta{display:flex;gap:8px;flex-wrap:wrap} .pill{background:#f8fafc;border:1px solid var(--border);padding:6px 10px;border-radius:999px;font-size:12px} .price{display:flex;align-items:baseline;gap:8px} .price .now{font-size:24px;font-weight:900} .cta-row{display:flex;gap:10px;margin-top:auto} .cta-row a{flex:1;text-align:center;text-decoration:none;padding:12px 14px;border-radius:12px;font-weight:900} .cta-row a.primary{background:var(--secondary);color:#000} .cta-row a.secondary{background:#fff;border:1px solid var(--border);color:var(--dark)} .empty{padding:16px;border:1px dashed #cbd5e1;border-radius:12px;color:var(--muted);text-align:center} .cookie-banner{position:fixed;left:0;right:0;bottom:0;background:#0f172a;color:#fff;z-index:50;box-shadow:0 -8px 30px rgba(0,0,0,.15)} .cookie-inner{max-width:var(--max);margin:0 auto;padding:14px 24px;display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap} .cookie-text{margin:0;opacity:.9} .cookie-text a{color:#fff;text-decoration:underline} .cookie-actions{display:flex;gap:10px} .cookie-banner .btn.ghost{background:#fff;color:#0f172a;border-color:#fff} .bv-hero{width:100%;background:linear-gradient(120deg, rgba(226,77,17,.08), rgba(244,166,0,.06));border-bottom:1px solid var(--border);padding:48px 16px;margin:0} .bv-hero .container{max-width:var(--max);margin:0 auto;padding:0 8px} .bv-hero .title{margin:0 0 6px;font-size:clamp(28px,5vw,48px);line-height:1.1;color:var(--dark)} .bv-hero .title .accent{color:var(--primary)} .bv-hero .subtitle{margin:0;color:var(--muted);font-size:clamp(14px,2vw,18px)} .bv-hero .searchwrap{margin-top:18px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:16px} .postcode-form{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end} .postcode-form label{font-weight:800;color:var(--dark)} .postcode-form .hint{font-size:12px;color:var(--muted);margin-top:2px} .postcode-form .btn.primary{background:var(--primary);border-color:var(--primary)} .postcode-form .btn.primary:hover{filter:brightness(.98)} @media (max-width:640px){.postcode-form{grid-template-columns:1fr}} .header-info{display:flex;gap:18px;align-items:center;flex-wrap:wrap} .header-info-item{display:flex;gap:8px;align-items:center;background:#f7f7f7;border:1px solid var(--border);border-radius:9999px;padding:6px 12px;font-weight:700;color:var(--dark)} .header-info-item i{width:16px;height:16px;display:inline-block;opacity:.7;background:#6b7280;border-radius:50%} /* Sticky filter button (mobile) */ .sticky-filter{ position:fixed; right:16px; bottom:84px; z-index:49; background:#fff; border:1px solid var(--border); box-shadow:var(--shadow); border-radius:9999px; padding:12px 16px; font-weight:900; display:none; } @media (max-width: 840px){ .sticky-filter{display:inline-block} form.filters[data-collapsible="1"]{display:none} form.filters[data-open="1"]{display:block} .sticky-filter[aria-expanded="true"]{background:var(--secondary);} } /* Compare selection + bar + modal */ .btn.compare{background:#fff;border:1px dashed var(--border);} .card.selected{outline:2px solid var(--secondary)} .compare-bar{ position:fixed; left:16px; right:16px; bottom:16px; z-index:48; background:#fff; border:1px solid var(--border); border-radius:14px; padding:10px 12px; display:flex; align-items:center; justify-content:space-between; box-shadow:var(--shadow); } .compare-actions{display:flex; gap:8px; align-items:center} .compare-modal .compare-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.35); } .compare-modal .compare-dialog{ position:fixed; left:50%; top:50%; transform:translate(-50%,-50%); width:min(100% - 32px, 980px); max-height:80vh; overflow:auto; background:#fff; border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow); } .compare-header{display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--border)} .compare-body{padding:12px 16px} .compare-table{width:100%; border-collapse:collapse} .compare-table th, .compare-table td{border:1px solid var(--border); padding:10px; text-align:left; vertical-align:top} .compare-table th{background:#f8fafc} /* Clean header layout */ .header-row{display:flex;align-items:center;justify-content:space-between;gap:16px} .site-header.clean .logo{height:84px} @media(max-width:900px){ .site-header.clean .nav{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end} }