
:root{
  --blue:#003d7a;
  --blue-2:#0057a8;
  --blue-3:#0073cf;
  --sky:#e8f4fd;
  --ink:#102033;
  --muted:#5b6b7e;
  --line:#dce8f4;
  --white:#fff;
  --dark:#071b36;
  --shadow:0 18px 45px rgba(0,61,122,.12);
  --radius:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.65}
a{color:inherit}
img{max-width:100%}
.container{width:min(1180px,calc(100% - 42px));margin:0 auto}
.top-strip{height:4px;background:linear-gradient(90deg,var(--blue),var(--blue-3))}
.site-header{position:sticky;top:0;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);z-index:1000;border-bottom:1px solid rgba(0,61,122,.08);box-shadow:0 8px 30px rgba(0,0,0,.04)}
.nav{height:86px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo-wrap{display:flex;align-items:center;gap:14px;text-decoration:none;min-width:265px}
.logo-img{width:78px;height:auto;display:block}
.logo-copy strong{display:block;color:var(--blue);font-size:1.18rem;line-height:1.1}
.logo-copy span{display:block;color:var(--muted);font-size:.78rem;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none;padding:0;margin:0}
.nav-links a{text-decoration:none;font-weight:700;font-size:.98rem;color:#152235;position:relative}
.nav-links a:after{content:"";position:absolute;left:0;bottom:-8px;width:0;height:2px;background:var(--blue-3);transition:.25s}
.nav-links a:hover:after,.nav-links a.active:after{width:100%}
.nav-cta{background:var(--blue-2);color:#fff;text-decoration:none;font-weight:800;padding:13px 22px;border-radius:10px;box-shadow:0 10px 24px rgba(0,87,168,.22);white-space:nowrap}
.menu-toggle{display:none;background:none;border:0;font-size:2rem;color:var(--blue);cursor:pointer}
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#04275c 0%,#06498c 58%,#0b77c7 100%);color:#fff}
.hero:before{content:"";position:absolute;inset:0;background:url('assets/pattern-molecules.svg') repeat;opacity:.38}
.hero:after{content:"";position:absolute;inset:auto -10% -40% -10%;height:65%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 60%)}
.hero-grid{position:relative;z-index:1;min-height:650px;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:78px 0}
.kicker{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.08);padding:8px 14px;border-radius:999px;font-weight:800;color:#cce7ff;font-size:.9rem}
.hero h1{font-size:clamp(2.6rem,5vw,5.2rem);line-height:1.02;margin:22px 0 22px;letter-spacing:-2px}
.hero h1 span{color:#8dd0ff}
.hero p{font-size:1.15rem;color:#e6f4ff;max-width:650px;margin:0 0 30px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:12px;font-weight:850;text-decoration:none;border:1px solid transparent}
.btn-primary{background:#fff;color:var(--blue);box-shadow:0 18px 38px rgba(0,0,0,.18)}
.btn-outline{border-color:rgba(255,255,255,.35);color:#fff;background:rgba(255,255,255,.08)}
.hero-card{position:relative}
.hero-image{border-radius:28px;overflow:hidden;box-shadow:0 28px 70px rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.22);background:#fff}
.hero-image img{height:455px;width:100%;object-fit:cover;display:block}
.hero-badge{position:absolute;left:-26px;bottom:28px;background:#fff;color:var(--blue);border-radius:18px;padding:18px 20px;box-shadow:var(--shadow);min-width:245px}
.hero-badge strong{font-size:1.8rem;display:block;line-height:1}
.hero-badge span{font-weight:700;color:var(--muted)}
.stats{background:#fff;margin-top:-46px;position:relative;z-index:3}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:22px;padding:20px}
.stat{text-align:center;padding:18px;border-radius:16px;background:linear-gradient(180deg,#fff,#f7fbff)}
.stat strong{display:block;color:var(--blue);font-size:2rem;line-height:1}
.stat span{display:block;color:var(--muted);font-weight:700;margin-top:6px}
.section{padding:92px 0}
.section-soft{background:linear-gradient(180deg,#f7fbff,#fff)}
.section-title{text-align:center;max-width:820px;margin:0 auto 48px}
.section-title .eyebrow{color:var(--blue-3);font-weight:900;text-transform:uppercase;letter-spacing:1px;font-size:.82rem}
.section-title h2{margin:8px 0 12px;color:var(--blue);font-size:clamp(2rem,4vw,3rem);line-height:1.15;letter-spacing:-1px}
.section-title p{color:var(--muted);font-size:1.05rem;margin:0}
.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:58px;align-items:center}
.image-panel{border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#fff}
.image-panel img{height:430px;width:100%;object-fit:cover;display:block}
.check-list{display:grid;gap:14px;margin-top:26px}
.check{display:flex;gap:14px;align-items:flex-start;padding:16px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 8px 26px rgba(0,61,122,.06)}
.check i{width:28px;height:28px;border-radius:50%;background:#0c9b72;color:#fff;display:grid;place-items:center;font-style:normal;font-weight:900;flex:0 0 auto}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:0 12px 32px rgba(0,61,122,.07);transition:.25s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.icon{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,var(--blue),var(--blue-3));color:#fff;display:grid;place-items:center;font-size:1.6rem;margin-bottom:18px}
.card h3{color:var(--blue);font-size:1.25rem;line-height:1.25;margin:0 0 12px}
.card p{color:var(--muted);margin:0}
.feature-band{background:linear-gradient(135deg,#05255a,#064b8e);color:#fff;position:relative;overflow:hidden}
.feature-band:before{content:"";position:absolute;inset:0;background:url('assets/pattern-molecules.svg') repeat;opacity:.25}
.feature-grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:26px}
.feature h3{margin:0 0 8px;color:#fff}
.feature p{margin:0;color:#cfe8ff}
.instrument-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:stretch}
.instrument-main{border-radius:28px;background:linear-gradient(135deg,#003d7a,#0073cf);padding:34px;color:#fff;position:relative;overflow:hidden}
.instrument-main:before{content:"";position:absolute;inset:0;background:url('assets/pattern-molecules.svg') repeat;opacity:.22}
.instrument-main>*{position:relative}
.instrument-main h3{font-size:2rem;margin:0 0 14px}
.instrument-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
.pill{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:13px;font-weight:800}
.side-cards{display:grid;gap:18px}
.mini-card{padding:22px;border-radius:18px;border:1px solid var(--line);background:#fff;box-shadow:0 10px 30px rgba(0,61,122,.07)}
.mini-card strong{display:block;color:var(--blue);font-size:1.1rem;margin-bottom:8px}
.cta{background:linear-gradient(135deg,#eef8ff,#fff);border:1px solid var(--line);border-radius:28px;padding:42px;display:flex;align-items:center;justify-content:space-between;gap:28px;box-shadow:var(--shadow)}
.cta h2{margin:0;color:var(--blue);font-size:2rem}
.cta p{margin:8px 0 0;color:var(--muted)}
.page-hero{background:linear-gradient(135deg,#04275c,#064b8e);color:#fff;position:relative;overflow:hidden}
.page-hero:before{content:"";position:absolute;inset:0;background:url('assets/pattern-molecules.svg') repeat;opacity:.32}
.page-hero .container{position:relative;padding:76px 0;text-align:center}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);margin:0 0 10px;line-height:1.1}
.breadcrumb{color:#c9e6ff;font-weight:700}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.content-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px;box-shadow:0 10px 30px rgba(0,61,122,.06)}
.content-card h2,.content-card h3{color:var(--blue);margin-top:0}
.download-card{max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:24px;padding:38px;text-align:center;box-shadow:var(--shadow)}
.download-icon{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;background:linear-gradient(135deg,var(--blue),var(--blue-3));color:#fff;font-size:2rem}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:36px;align-items:start}
.contact-card,.form-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:34px;box-shadow:var(--shadow)}
.contact-item{display:flex;gap:16px;margin-bottom:22px}
.contact-item .ci{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--sky);color:var(--blue)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group.full{grid-column:1/-1}
label{font-weight:800;color:var(--blue)}
input,select,textarea{width:100%;border:1px solid #cddced;border-radius:10px;padding:12px 14px;font:inherit}
textarea{min-height:130px;resize:vertical}
.faq-list{max-width:920px;margin:0 auto;display:grid;gap:16px}
details{background:#fff;border:1px solid var(--line);border-left:5px solid var(--blue-3);border-radius:18px;box-shadow:0 10px 30px rgba(0,61,122,.07);overflow:hidden}
summary{cursor:pointer;list-style:none;padding:22px 26px;font-weight:900;color:var(--blue);display:flex;justify-content:space-between;gap:16px}
summary::-webkit-details-marker{display:none}
summary:after{content:"+";color:var(--blue-3);font-size:1.4rem}
details[open] summary:after{content:"×"}
details p{padding:0 26px 24px;margin:0;color:var(--muted)}
/* Footer */
.footer{position:relative;overflow:hidden;margin-top:60px;background:linear-gradient(135deg,#03285f 0%,#002a68 45%,#012f79 100%);color:#eaf2ff;padding:72px 0 0}
.footer:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.26;background:url('assets/pattern-molecules.svg') repeat;background-size:540px auto}
.footer:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 0% 0%,rgba(255,255,255,.08),transparent 22%),radial-gradient(circle at 100% 30%,rgba(255,255,255,.08),transparent 20%)}
.footer-container{position:relative;z-index:1;max-width:1380px;margin:0 auto;padding:0 44px}
.footer-main{display:grid;grid-template-columns:1.65fr 1fr 1.15fr 1.1fr;gap:52px;align-items:start}
.brand-logo{width:156px;max-width:100%;display:block;margin-bottom:18px}
.footer-brand h3{color:#fff;font-size:1.15rem;line-height:1.35;margin:0 0 10px;font-weight:800}
.footer-brand .tagline{color:#82b7ff;font-size:1rem;font-weight:800;margin:0 0 16px}
.footer-brand .desc{color:rgba(234,242,255,.9);font-size:.98rem;line-height:1.75;margin:0;max-width:420px}
.footer-title{color:#fff;font-size:1.02rem;font-weight:900;letter-spacing:1px;text-transform:uppercase;margin:8px 0 18px}
.footer-title:after{content:"";display:block;width:54px;height:3px;background:#2d8cff;border-radius:999px;margin-top:12px}
.footer ul{list-style:none;margin:0;padding:0}
.footer li{margin:0 0 14px}
.footer a{color:#eef5ff;text-decoration:none}
.footer-links a,.footer-services a{display:inline-flex;align-items:center;gap:10px;transition:.25s}
.footer-links a:before,.footer-services a:before{content:"›";font-size:1.45rem;line-height:1;color:#2d8cff}
.footer-links a:hover,.footer-services a:hover{color:#82b7ff;transform:translateX(3px)}
.footer-contact-list li{display:flex;gap:16px;align-items:flex-start;color:#eef5ff}
.footer-contact-icon{width:46px;height:46px;min-width:46px;border-radius:50%;border:1px solid rgba(69,149,255,.8);display:flex;align-items:center;justify-content:center;color:#56a3ff;font-size:1.2rem;background:rgba(255,255,255,.02)}
.footer-contact-text{line-height:1.6}
.footer-bottom{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.16);margin-top:42px}
.footer-bottom-inner{max-width:1380px;margin:0 auto;padding:22px 44px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer-copy{color:#eef5ff}
.footer-meta{color:#82b7ff;text-align:center;flex:1 1 300px}
.footer-social{display:flex;align-items:center;gap:14px}
.footer-social a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(89,159,255,.8);display:inline-flex;align-items:center;justify-content:center;font-weight:800;background:rgba(255,255,255,.03)}
@media (max-width:1100px){
  .nav-links{display:none;position:absolute;left:20px;right:20px;top:90px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow);flex-direction:column;align-items:flex-start}
  .nav-links.open{display:flex}
  .menu-toggle{display:block}.nav-cta{display:none}.nav{height:82px}.hero-grid,.about-grid,.instrument-wrap,.contact-grid{grid-template-columns:1fr}.hero-grid{min-height:auto}.stats-grid,.card-grid,.feature-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .logo-copy{display:none}.logo-wrap{min-width:auto}.logo-img{width:68px}
  .hero-grid{padding:54px 0}.hero-image img{height:320px}.hero-badge{left:16px;right:16px;bottom:16px}
  .stats-grid,.card-grid,.feature-grid,.two-col,.form-grid,.footer-main{grid-template-columns:1fr}
  .section{padding:66px 0}.cta{flex-direction:column;align-items:flex-start}
  .footer-container,.footer-bottom-inner{padding-left:24px;padding-right:24px}.footer-bottom-inner{align-items:flex-start;flex-direction:column}.footer-meta{text-align:left}
}


/* Professional homepage banner upgrade */
.hero{background:linear-gradient(135deg,#031d49 0%,#05498b 52%,#0a6fc0 100%)}
.hero-grid{min-height:700px;gap:64px;padding:88px 0 96px;align-items:center}
.kicker{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);color:#d8efff;font-size:.88rem;letter-spacing:.4px}
.hero h1{max-width:700px;font-size:clamp(2.9rem,5vw,5.5rem);line-height:.98;margin:20px 0 20px}
.hero p{max-width:640px;font-size:1.08rem;color:#e9f5ff}
.hero-subpoints{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:28px 0 28px;max-width:720px}
.hero-subpoint{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);padding:12px 14px;border-radius:14px;color:#f7fbff;font-weight:700;font-size:.95rem;backdrop-filter:blur(8px)}
.hero-subpoint span{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.16);font-size:.95rem}
.hero-trust{display:flex;gap:18px;flex-wrap:wrap;margin-top:22px;color:#d8ecff;font-weight:700;font-size:.92rem}
.hero-trust div{display:flex;align-items:center;gap:8px}
.hero-card{min-height:520px;display:flex;align-items:center;justify-content:center}
.hero-image{width:100%;position:relative;border-radius:30px;overflow:hidden;border:1px solid rgba(255,255,255,.16);box-shadow:0 28px 80px rgba(0,0,0,.28)}
.hero-image:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,37,90,.06),rgba(4,37,90,.28))}
.hero-image img{height:520px}
.hero-badge{left:20px;bottom:20px;border-radius:18px;padding:18px 20px;min-width:260px}
.hero-badge strong{font-size:1.7rem}
.hero-float{position:absolute;z-index:3;background:rgba(255,255,255,.92);color:#0a2b59;padding:14px 16px;border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,.18);min-width:200px}
.hero-float .mini{display:block;color:#64758b;font-size:.85rem;font-weight:700;margin-bottom:3px}
.hero-float strong{display:block;font-size:1rem;line-height:1.3}
.hero-float.top{top:20px;right:-20px}
.hero-float.mid{top:150px;right:-38px}
.hero-float small{color:#52739a;font-weight:700}
.hero-float.bottom{left:-22px;bottom:132px}
@media (max-width:1100px){
  .hero-subpoints{grid-template-columns:1fr 1fr 1fr}
  .hero-card{min-height:auto}.hero-image img{height:420px}
  .hero-float.top,.hero-float.mid{right:16px}.hero-float.bottom{left:16px}
}
@media (max-width:760px){
  .hero-grid{padding:54px 0 72px;gap:28px}.hero h1{font-size:clamp(2.35rem,12vw,3.5rem);letter-spacing:-1.5px}
  .hero-subpoints{grid-template-columns:1fr}.hero-image img{height:320px}
  .hero-float{position:static;min-width:auto;margin-top:12px}.hero-card{display:block}.hero-badge{position:static;margin-top:14px}.hero-image{margin-bottom:14px}
}



/* === Premium redesign refresh === */
body{background:linear-gradient(180deg,#ffffff 0%,#f7fbff 50%,#ffffff 100%)}
.site-header{background:rgba(255,255,255,.96);border-bottom:1px solid rgba(0,61,122,.07);box-shadow:0 10px 26px rgba(6,42,90,.06)}
.nav{height:90px}
.nav-cta{border-radius:14px;padding:14px 24px}
.section{padding:96px 0}
.card,.content-card,.contact-card,.form-card,.download-card,.mini-card,.stat,.feature,.check,.image-panel,.cta{border-radius:24px}
.card,.content-card,.contact-card,.form-card,.download-card,.mini-card,.stat,.check,.image-panel,.cta{box-shadow:0 18px 40px rgba(0,61,122,.08)}
.section-title h2{font-size:clamp(2.1rem,4vw,3.15rem)}
.page-hero .container{padding:88px 0}
.btn-outline-dark{background:#fff;border-color:#cfe0f1;color:var(--blue)}
.btn-outline-dark:hover{background:#f3f9ff}
.homepage .hero{background:linear-gradient(180deg,#eff7ff 0%,#ffffff 100%);color:var(--ink)}
.homepage .hero:before,.homepage .hero:after{display:none}
.homepage .hero-redesign{padding:34px 0 26px;overflow:visible}
.homepage .hero-banner-wrap{position:relative;border-radius:32px;overflow:hidden;box-shadow:0 35px 90px rgba(4,35,86,.22);border:1px solid rgba(255,255,255,.9);background:#062d66}
.homepage .hero-banner-wrap:after{content:"";position:absolute;inset:auto 0 0 0;height:110px;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(5,32,71,.10))}
.homepage .hero-banner-img{display:block;width:100%;height:auto}
.homepage .hero-intro-bar{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:30px 34px;margin-top:-26px;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border:1px solid rgba(221,234,246,.95);border-radius:28px;box-shadow:0 20px 45px rgba(0,61,122,.10);position:relative;z-index:2}
.homepage .hero-intro-copy h2{font-size:clamp(1.6rem,2.4vw,2.3rem);line-height:1.15;color:var(--blue);margin:8px 0 10px;max-width:760px}
.homepage .hero-intro-copy p{margin:0;color:var(--muted);max-width:760px;font-size:1rem}
.homepage .hero-intro-actions{display:flex;gap:14px;flex-wrap:wrap;min-width:max-content}
.homepage .hero-highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:28px}
.homepage .hero-highlight-card{background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid var(--line);border-radius:22px;padding:24px 22px;box-shadow:0 14px 34px rgba(0,61,122,.08)}
.homepage .hero-highlight-card strong{display:block;font-size:1.08rem;color:var(--blue);margin-bottom:8px}
.homepage .hero-highlight-card span{display:block;color:var(--muted);line-height:1.7}
.homepage .stats{margin-top:24px}
.homepage .stats-grid{box-shadow:none;border:none;background:transparent;padding:0}
.homepage .stat{background:#fff;border:1px solid var(--line)}
.feature-band{border-radius:36px;width:min(1240px,calc(100% - 32px));margin:20px auto;box-shadow:0 28px 70px rgba(0,61,122,.18)}
.footer{margin-top:80px}
@media (max-width:1100px){
  .homepage .hero-intro-bar{flex-direction:column;align-items:flex-start}
  .homepage .hero-intro-actions{min-width:0}
  .homepage .hero-highlights-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav{height:82px}
  .section{padding:72px 0}
  .homepage .hero-redesign{padding:18px 0 10px}
  .homepage .hero-banner-wrap{border-radius:22px}
  .homepage .hero-intro-bar{padding:22px 20px;margin-top:16px;border-radius:20px}
  .homepage .hero-intro-copy h2{font-size:1.45rem}
  .homepage .hero-intro-actions{width:100%}
  .homepage .hero-intro-actions .btn{width:100%}
}


/* === 100% width website update === */
.container{
  width:100% !important;
  max-width:none !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:5vw !important;
  padding-right:5vw !important;
}
.site-header .container,
.footer-container,
.footer-bottom-inner{
  max-width:none !important;
  width:100% !important;
  padding-left:5vw !important;
  padding-right:5vw !important;
}
.homepage .hero-redesign .container{
  padding-left:0 !important;
  padding-right:0 !important;
}
.homepage .hero-banner-wrap{
  border-radius:0 !important;
  border-left:0 !important;
  border-right:0 !important;
  box-shadow:none !important;
}
.homepage .hero-banner-img{
  width:100% !important;
  display:block !important;
}
.homepage .hero-intro-bar,
.homepage .hero-highlights-grid{
  margin-left:5vw !important;
  margin-right:5vw !important;
}
.stats .container,
.section > .container,
.page-hero .container{
  width:100% !important;
  max-width:none !important;
}
.card-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.footer-main{
  grid-template-columns:1.5fr 1fr 1.1fr 1.25fr;
}
@media (min-width:1500px){
  .card-grid{grid-template-columns:repeat(4,minmax(0,1fr));}
  .services-page .card-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .hero-highlights-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media (max-width:1100px){
  .container,
  .site-header .container,
  .footer-container,
  .footer-bottom-inner{
    padding-left:24px !important;
    padding-right:24px !important;
  }
  .homepage .hero-intro-bar,
  .homepage .hero-highlights-grid{
    margin-left:24px !important;
    margin-right:24px !important;
  }
}
@media (max-width:760px){
  .container,
  .site-header .container,
  .footer-container,
  .footer-bottom-inner{
    padding-left:18px !important;
    padding-right:18px !important;
  }
  .homepage .hero-intro-bar,
  .homepage .hero-highlights-grid{
    margin-left:18px !important;
    margin-right:18px !important;
  }
}


/* === homepage cleanup colourful cards update === */
.homepage .hero-redesign{padding:18px 0 18px}
.homepage .hero-highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:26px;margin-left:5vw !important;margin-right:5vw !important}
.homepage .hero-highlight-card{border-radius:24px;padding:26px 24px;box-shadow:0 16px 38px rgba(0,61,122,.10);border:1px solid rgba(255,255,255,.7)}
.homepage .hero-highlight-card strong{display:block;font-size:1.12rem;color:#073f7d;margin-bottom:10px}
.homepage .hero-highlight-card span{display:block;color:#445a73;line-height:1.65;font-size:1rem}
.homepage .hero-highlight-card:nth-child(1){background:linear-gradient(135deg,#fff8e9 0%,#fff1cc 100%);border-color:#f7df97}
.homepage .hero-highlight-card:nth-child(2){background:linear-gradient(135deg,#ecf7ff 0%,#d9eeff 100%);border-color:#b7dcff}
.homepage .hero-highlight-card:nth-child(3){background:linear-gradient(135deg,#eefcf3 0%,#d8f5e4 100%);border-color:#b6e9cc}
.homepage .stats{margin-top:26px}
.homepage .stat{border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.8);box-shadow:0 14px 36px rgba(0,61,122,.10);padding:26px 18px}
.homepage .stat strong{font-size:3rem}
.homepage .stat span{font-size:1rem;font-weight:800}
.homepage .stat:nth-child(1){background:linear-gradient(135deg,#eef6ff 0%,#dcecff 100%);border-color:#c4dcff}
.homepage .stat:nth-child(2){background:linear-gradient(135deg,#f3efff 0%,#e3daff 100%);border-color:#d2c3ff}
.homepage .stat:nth-child(3){background:linear-gradient(135deg,#fff3ea 0%,#ffe1c9 100%);border-color:#ffcaa0}
.homepage .stat:nth-child(4){background:linear-gradient(135deg,#ecfff2 0%,#d6f7e3 100%);border-color:#b6ebcb}
.section-title h2{font-size:clamp(1.8rem,3.2vw,2.5rem) !important;line-height:1.12}
.page-hero h1{font-size:clamp(2rem,4vw,3rem) !important}
.card h3,.content-card h3,.mini-card strong{font-size:1.1rem}
@media (max-width:1100px){
  .homepage .hero-highlights-grid{grid-template-columns:1fr;margin-left:24px !important;margin-right:24px !important}
}
@media (max-width:760px){
  .homepage .hero-highlight-card{padding:22px 18px}
  .homepage .stat strong{font-size:2.4rem}
  .homepage .hero-highlights-grid{margin-left:18px !important;margin-right:18px !important}
}


/* === compact section spacing update === */
.section{padding:54px 0 !important}
.section-title{margin:0 auto 26px !important}
.section-title h2{margin:6px 0 8px !important}
.section-title p{margin:0 !important}
.homepage .stats{margin-top:18px !important}
.homepage .hero-highlights-grid{margin-top:18px !important}
.feature-band{margin:8px auto !important}
.cta{padding:28px 32px !important}
.footer{margin-top:36px !important}
@media (max-width:760px){
  .section{padding:38px 0 !important}
  .section-title{margin:0 auto 20px !important}
  .cta{padding:22px 20px !important}
}


/* === homepage banner size refinement === */
.homepage .hero-redesign{
  padding: 10px 0 14px !important;
}
.homepage .hero-banner-wrap{
  width: 100%;
  min-height: 620px;
  max-height: 620px;
  border-radius: 0 !important;
  overflow: hidden;
}
.homepage .hero-banner-img{
  width: 100% !important;
  height: 620px !important;
  object-fit: cover;
  object-position: center center;
  display: block;
}
.homepage .hero-highlights-grid{
  margin-top: 12px !important;
}
@media (max-width: 1400px){
  .homepage .hero-banner-wrap{
    min-height: 560px;
    max-height: 560px;
  }
  .homepage .hero-banner-img{
    height: 560px !important;
  }
}
@media (max-width: 1100px){
  .homepage .hero-banner-wrap{
    min-height: 470px;
    max-height: 470px;
  }
  .homepage .hero-banner-img{
    height: 470px !important;
  }
}
@media (max-width: 760px){
  .homepage .hero-banner-wrap{
    min-height: 320px;
    max-height: 320px;
  }
  .homepage .hero-banner-img{
    height: 320px !important;
  }
}


/* === contained website layout update === */
.container{
  width:min(92%, 1400px) !important;
  max-width:1400px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:0 !important;
  padding-right:0 !important;
}
.site-header .container,
.footer-container,
.footer-bottom-inner,
.stats .container,
.section > .container,
.page-hero .container{
  width:min(92%, 1400px) !important;
  max-width:1400px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:0 !important;
  padding-right:0 !important;
}
.homepage .hero-redesign .container{
  width:min(92%, 1500px) !important;
  max-width:1500px !important;
  padding-left:0 !important;
  padding-right:0 !important;
}
.homepage .hero-banner-wrap{
  width:100%;
  max-width:1500px;
  min-height:560px;
  max-height:560px;
  margin:0 auto;
  border-radius:26px !important;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(0,61,122,.16) !important;
  border:1px solid rgba(220,232,245,.9);
}
.homepage .hero-banner-img{
  width:100% !important;
  height:560px !important;
  object-fit:cover;
  object-position:center center;
  display:block;
}
.homepage .hero-highlights-grid{
  width:min(92%, 1400px);
  max-width:1400px;
  margin:18px auto 0 !important;
}
.feature-band{
  width:min(92%, 1400px) !important;
}
@media (max-width:1400px){
  .container,
  .site-header .container,
  .footer-container,
  .footer-bottom-inner,
  .stats .container,
  .section > .container,
  .page-hero .container,
  .homepage .hero-redesign .container,
  .homepage .hero-highlights-grid,
  .feature-band{
    width:min(94%, 1280px) !important;
  }
  .homepage .hero-banner-wrap{
    min-height:500px;
    max-height:500px;
  }
  .homepage .hero-banner-img{
    height:500px !important;
  }
}
@media (max-width:1100px){
  .container,
  .site-header .container,
  .footer-container,
  .footer-bottom-inner,
  .stats .container,
  .section > .container,
  .page-hero .container,
  .homepage .hero-redesign .container,
  .homepage .hero-highlights-grid,
  .feature-band{
    width:calc(100% - 40px) !important;
  }
  .homepage .hero-banner-wrap{
    min-height:420px;
    max-height:420px;
    border-radius:22px !important;
  }
  .homepage .hero-banner-img{
    height:420px !important;
  }
}
@media (max-width:760px){
  .container,
  .site-header .container,
  .footer-container,
  .footer-bottom-inner,
  .stats .container,
  .section > .container,
  .page-hero .container,
  .homepage .hero-redesign .container,
  .homepage .hero-highlights-grid,
  .feature-band{
    width:calc(100% - 24px) !important;
  }
  .homepage .hero-banner-wrap{
    min-height:260px;
    max-height:260px;
    border-radius:18px !important;
  }
  .homepage .hero-banner-img{
    height:260px !important;
  }
}
