:root{
  --navy:#0F172A; --blue:#2563EB; --blue-dark:#1D4ED8; --white:#fff;
  --bg:#F8FAFC; --light:#F1F5F9; --border:#E2E8F0; --text:#1E293B; --muted:#64748B;
  --green:#16A34A; --amber:#F59E0B; --radius:14px; --maxw:1080px;
  --shadow:0 1px 3px rgba(15,23,42,.06),0 8px 24px rgba(15,23,42,.06);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-dark)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3{color:var(--navy);line-height:1.2;margin:0 0 .4em}
h1{font-size:2.6rem;font-weight:800;letter-spacing:-.02em}
h2{font-size:1.8rem;font-weight:700;letter-spacing:-.01em}
h3{font-size:1.15rem;font-weight:700}
p{margin:0 0 1rem}
.muted{color:var(--muted)}
.center{text-align:center}

/* Header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--navy);font-size:1.15rem}
.brand .star{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--navy),var(--blue));display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:14px}
.nav nav a{color:var(--navy);font-weight:600;margin-left:26px;font-size:.95rem}
.nav nav a:hover{color:var(--blue)}
.menu-links a.cta{margin-left:26px}

/* Buttons */
.btn{display:inline-block;background:var(--blue);color:#fff;font-weight:700;padding:13px 24px;border-radius:10px;border:0;cursor:pointer;font-size:1rem;transition:.15s}
.btn:hover{background:var(--blue-dark);color:#fff;transform:translateY(-1px)}
.btn.outline{background:#fff;color:var(--navy);border:1.5px solid var(--border)}
.btn.outline:hover{border-color:var(--blue);color:var(--blue);background:#fff}
.btn.lg{padding:15px 30px;font-size:1.05rem}

/* Hero */
.hero{background:linear-gradient(180deg,#fff, var(--bg));padding:72px 0 48px;border-bottom:1px solid var(--border)}
.hero h1{max-width:14ch}
.hero p.lead{font-size:1.2rem;color:var(--muted);max-width:60ch;margin:0 0 28px}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap}

/* Trust strip */
.trust{display:flex;gap:28px;flex-wrap:wrap;justify-content:center;padding:18px 0;color:var(--muted);font-size:.92rem;font-weight:600}
.trust span{display:inline-flex;align-items:center;gap:8px}
.trust .dot{color:var(--green)}

/* Sections */
section.block{padding:56px 0}
.grid{display:grid;gap:22px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.eyebrow{color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;margin-bottom:8px}

/* Product cards */
.product{display:grid;grid-template-columns:1.1fr 1fr;gap:0;overflow:hidden}
.product .shot{background:var(--light);display:flex;align-items:center;justify-content:center;padding:18px;border-right:1px solid var(--border)}
.product .shot img{max-width:100%;border-radius:8px;box-shadow:var(--shadow)}
.product .info{padding:28px}
.price{font-size:1.5rem;font-weight:800;color:var(--navy)}
.price small{font-size:.85rem;color:var(--muted);font-weight:600}
.tag{display:inline-block;background:#EFF6FF;color:var(--blue);font-weight:700;font-size:.72rem;padding:4px 10px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase}
.feature-list{list-style:none;padding:0;margin:14px 0}
.feature-list li{padding:4px 0 4px 26px;position:relative;color:var(--text)}
.feature-list li:before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}
.note{font-size:.82rem;color:var(--muted);margin-top:12px}

/* Market filter */
.filter{display:flex;gap:10px;justify-content:center;margin:8px 0 30px}
.filter button{background:#fff;border:1.5px solid var(--border);color:var(--navy);font-weight:700;padding:9px 18px;border-radius:999px;cursor:pointer}
.filter button.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* Footer */
footer.site{background:var(--navy);color:#cbd5e1;padding:46px 0 30px;margin-top:40px}
footer.site a{color:#cbd5e1}
footer.site a:hover{color:#fff}
.fcols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px;margin-bottom:26px}
footer .brand{color:#fff}
footer h4{color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px}
footer ul{list-style:none;padding:0;margin:0}
footer ul li{margin-bottom:8px;font-size:.92rem}
.fbar{border-top:1px solid #1e293b;padding-top:18px;font-size:.82rem;color:#94a3b8;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* Content pages */
.page{padding:48px 0}
.page .narrow{max-width:760px}
.page h2{margin-top:32px}
.banner{background:linear-gradient(135deg,var(--navy),#1e293b);color:#fff;padding:40px 0}
.banner h1{color:#fff;margin:0}
.banner p{color:#cbd5e1;margin:6px 0 0}

/* Form */
.form label{display:block;font-weight:600;color:var(--navy);margin:14px 0 6px}
.form input,.form textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:1rem}
.form textarea{min-height:130px;resize:vertical}

@media(max-width:820px){
  h1{font-size:2rem}
  .grid.cols-3,.grid.cols-2,.fcols{grid-template-columns:1fr}
  .product{grid-template-columns:1fr}
  .product .shot{border-right:0;border-bottom:1px solid var(--border)}
  .nav nav a{margin-left:16px}
}

/* === Knowledge Centre / Resources / visuals === */
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero-visual{width:100%;height:auto;display:block}
img.hero-visual{border-radius:16px;box-shadow:0 10px 30px rgba(15,23,42,.12);object-fit:cover;aspect-ratio:3/2;border:1px solid var(--border)}
.icon{width:46px;height:46px;border-radius:12px;background:#EFF6FF;display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px}
.icon svg{width:24px;height:24px}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.res-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);transition:.15s;color:var(--text)}
.res-card:hover{transform:translateY(-2px);border-color:var(--blue);color:var(--text)}
.res-card h3{margin:0 0 6px;font-size:1.08rem}
.res-card p{margin:0;color:var(--muted);font-size:.93rem;flex:1}
.res-card .read{color:var(--blue);font-weight:700;font-size:.86rem;margin-top:14px}
.article{max-width:760px}
.article p{font-size:1.02rem;line-height:1.72}
.article h2{margin-top:30px;font-size:1.45rem}
.article ul{padding-left:0;list-style:none;margin:10px 0}
.article ul li{padding:5px 0 5px 26px;position:relative}
.article ul li:before{content:"\2192";position:absolute;left:0;color:var(--blue);font-weight:800}
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:10px}
.breadcrumb a{color:var(--muted)}
.keyfacts{background:#EFF6FF;border:1px solid #BFDBFE;border-radius:12px;padding:18px 22px;margin:24px 0}
.keyfacts h4{margin:0 0 10px;color:var(--navy);font-size:.82rem;text-transform:uppercase;letter-spacing:.06em}
.keyfacts ul{margin:0}
.source{font-size:.84rem;color:var(--muted);border-left:3px solid var(--border);padding-left:12px;margin:20px 0}
.cta-box{background:linear-gradient(135deg,var(--navy),#1e293b);color:#fff;border-radius:16px;padding:30px;margin:34px 0}
.cta-box h3{color:#fff;margin:0 0 8px}
.cta-box p{color:#cbd5e1;margin:0 0 18px}
.cta-box .btn.ghost{background:transparent;color:#fff;border:1.5px solid #334155;font-weight:700;padding:13px 24px;border-radius:10px;display:inline-block}
.cta-box .btn.ghost:hover{border-color:#fff;color:#fff}
.timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0}
.tl{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px;text-align:center}
.tl .yr{font-size:1.35rem;font-weight:800;color:var(--blue)}
.tl .th{font-weight:700;color:var(--navy);margin-top:4px}
.tl .dt{font-size:.84rem;col