
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#161616;--navy2:#242424;--teal:#155A42;--teal2:#104632;--teal-lt:#D2D8BC;--teal-pale:#EEF2E2;
  --gold:#D2D8BC;--cream:#F3F5EA;--white:#fff;--text:#161616;--muted:#5f675c;--border:#dde2cf;
  --serif:'Playfair Display',Georgia,serif;--sans:'DM Sans',sans-serif;
  --max:1260px;--r:12px;--r2:20px;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--white);overflow-x:hidden;line-height:1.65}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ── UTILITY ── */
.container{max-width:var(--max);margin:0 auto;padding:0 2rem}
.eyebrow{font-size:.72rem;font-weight:600;letter-spacing:1.6px;text-transform:uppercase;color:var(--teal);display:block;margin-bottom:.6rem}
.btn{display:inline-flex;align-items:center;gap:8px;padding:.8rem 1.75rem;border-radius:8px;font-family:var(--sans);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}
.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover{background:var(--teal2);transform:translateY(-1px)}
.btn-white{background:#fff;color:var(--navy)}.btn-white:hover{background:var(--cream)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.25);color:#fff}.btn-ghost:hover{border-color:var(--teal-lt);color:var(--teal-lt)}
.btn-navy-ghost{border:1.5px solid var(--border);color:var(--navy);background:transparent}.btn-navy-ghost:hover{border-color:var(--teal);color:var(--teal)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.vis{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── NAV ── */
nav{position:fixed;inset:0 0 auto;z-index:200;background:rgba(22,22,22,.97);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.07)}
.nav-wrap{max-width:var(--max);margin:0 auto;padding:0 2rem;height:68px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo-mark{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--teal),var(--teal-lt));display:flex;align-items:center;justify-content:center}
.nav-logo-mark svg{width:18px;height:18px}
.nav-logo-text{font-family:var(--serif);font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:-.3px}
.nav-logo-text em{font-style:normal;color:var(--teal-lt)}
.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none}
.nav-links a{color:rgba(255,255,255,.68);font-size:.84rem;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--teal-lt)}
.nav-right{display:flex;align-items:center;gap:.65rem}
.nav-info{color:rgba(255,255,255,.55);font-size:.8rem;border:1px solid rgba(255,255,255,.18);padding:.38rem .9rem;border-radius:6px;transition:all .2s}
.nav-info:hover{color:var(--teal-lt);border-color:var(--teal-lt)}
.nav-apply{background:var(--teal);color:#fff;font-size:.84rem;font-weight:600;padding:.45rem 1.1rem;border-radius:7px;transition:background .2s}
.nav-apply:hover{background:var(--teal2)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{width:22px;height:2px;background:rgba(255,255,255,.7);border-radius:2px;transition:all .3s}
.mob-menu{display:none;position:fixed;top:68px;left:0;right:0;z-index:199;background:rgba(22,22,22,.98);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.1);flex-direction:column;gap:0}
.mob-menu.open{display:flex}
.mob-menu a{color:rgba(255,255,255,.75);font-size:.95rem;padding:.9rem 2rem;border-bottom:1px solid rgba(255,255,255,.07);transition:color .2s}
.mob-menu a:hover{color:var(--teal-lt)}
.mob-apply{color:var(--teal-lt)!important;font-weight:600}

/* ── PAGE SWITCHER ── */
.page{display:none}.page.active{display:block}

/* ══════════════════════════════
   HOME PAGE
══════════════════════════════ */

/* HERO */
.hero{min-height:100vh;background:var(--navy);display:flex;align-items:center;padding:80px 0 0;position:relative;overflow:hidden}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none}
.hero-orb-1{width:640px;height:640px;background:radial-gradient(circle,rgba(21,90,66,.14) 0%,transparent 70%);top:-15%;right:-8%}
.hero-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(210,216,188,.07) 0%,transparent 70%);bottom:5%;left:-5%}
.hero-inner{max-width:var(--max);margin:0 auto;padding:0 2rem;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;padding-bottom:80px;position:relative;z-index:1}
.hero-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(21,90,66,.18);border:1px solid rgba(210,216,188,.32);color:var(--teal-lt);font-size:.72rem;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;padding:6px 14px;border-radius:20px;margin-bottom:1.5rem}
.hero-pill::before{content:'';width:6px;height:6px;background:var(--teal-lt);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-family:var(--serif);font-size:clamp(2.5rem,4.2vw,4rem);color:#fff;line-height:1.1;font-weight:700;letter-spacing:-1px;margin-bottom:1.4rem}
.hero h1 em{font-style:italic;color:var(--teal-lt)}
.hero-desc{color:rgba(255,255,255,.58);font-size:1.02rem;font-weight:300;line-height:1.8;max-width:460px;margin-bottom:2.4rem}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap}
/* hero visual */
.hero-vis{display:flex;flex-direction:column;gap:1rem}
.hero-glass{background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);padding:1.6rem 2rem}
.hero-glass-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.hero-glass-hd h3{font-family:var(--serif);color:#fff;font-size:1.1rem;font-style:italic}
.badge{background:rgba(21,90,66,.25);border:1px solid rgba(210,216,188,.4);color:var(--teal-lt);font-size:.7rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;padding:4px 10px;border-radius:20px}
.svc-links{display:flex;flex-direction:column}
.svc-link{display:flex;align-items:center;justify-content:space-between;color:rgba(255,255,255,.68);font-size:.86rem;font-weight:300;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.07);cursor:pointer;transition:color .2s}
.svc-link:last-child{border-bottom:none}
.svc-link:hover{color:var(--teal-lt)}
.svc-link .arr{opacity:0;transition:opacity .2s;font-size:.8rem}
.svc-link:hover .arr{opacity:1}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
.stat-box{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:1.2rem;text-align:center}
.stat-num{font-family:var(--serif);font-size:1.9rem;font-weight:700;color:var(--teal-lt);line-height:1}
.stat-lbl{font-size:.72rem;color:rgba(255,255,255,.42);margin-top:4px;font-weight:300}

/* TICKER */
.ticker{background:var(--teal);overflow:hidden}
.ticker-inner{display:flex;animation:scroll 32s linear infinite;width:max-content}
.ticker-inner:hover{animation-play-state:paused}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tick-item{display:flex;align-items:center;gap:10px;padding:.72rem 2.4rem;white-space:nowrap;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.88)}
.tick-dot{width:4px;height:4px;background:rgba(255,255,255,.45);border-radius:50%}

/* BENEFITS */
.benefits{background:var(--cream);padding:5rem 0}
.benefits h2{font-family:var(--serif);font-size:clamp(1.8rem,2.8vw,2.5rem);color:var(--navy);font-style:italic;margin-bottom:2.8rem}
.benefits-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.2rem}
.ben-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:1.6rem 1.1rem;text-align:center;transition:all .22s;cursor:default}
.ben-card:hover{border-color:var(--teal);transform:translateY(-4px);box-shadow:0 10px 28px rgba(21,90,66,.1)}
.ben-ico{font-size:1.9rem;margin-bottom:.8rem;display:block}
.ben-card h4{font-size:.86rem;font-weight:600;color:var(--navy);margin-bottom:.35rem}
.ben-card p{font-size:.76rem;color:var(--muted);line-height:1.45;font-weight:300}

/* MORTGAGES SECTION */
.mort-section{background:#fff;padding:6rem 0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.visual-panel{background:var(--navy);border-radius:var(--r2);overflow:hidden;position:relative;min-height:500px;display:flex;flex-direction:column;justify-content:flex-end;padding:2.5rem}
.visual-panel::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 20%,rgba(21,90,66,.22) 0%,transparent 60%)}
.visual-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:2rem}
.v-box{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:1rem;text-align:center}
.v-box span{font-size:1.6rem;display:block;margin-bottom:4px}
.v-box p{font-size:.72rem;color:rgba(255,255,255,.5);font-weight:300}
.visual-caption{position:relative;z-index:1;font-family:var(--serif);font-size:1.55rem;font-style:italic;color:#fff;line-height:1.3}
.visual-caption strong{color:var(--teal-lt);font-weight:400}
.split-content .eyebrow{margin-bottom:.5rem}
.split-content h2{font-family:var(--serif);font-size:clamp(1.9rem,2.8vw,2.8rem);color:var(--navy);font-weight:700;line-height:1.15;margin-bottom:.9rem;letter-spacing:-.3px}
.split-content .lead{color:var(--muted);font-size:.96rem;font-weight:300;line-height:1.75;margin-bottom:1.8rem;max-width:420px}
.svc-list{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.8rem}
.svc-row{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.1rem;border-radius:10px;background:var(--cream);border:1px solid var(--border);cursor:pointer;transition:all .2s;font-size:.88rem;font-weight:400;color:var(--navy)}
.svc-row:hover{background:var(--teal-pale);border-color:var(--teal);color:var(--teal);transform:translateX(4px)}
.svc-row .sico{font-size:1.05rem}
.svc-arr{color:var(--teal);opacity:0;transition:opacity .2s;font-size:.85rem}
.svc-row:hover .svc-arr{opacity:1}

/* CALCULATOR BANNER */
.calc-banner{background:var(--navy);padding:4.5rem 0}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:center}
.calc-left h2{font-family:var(--serif);font-size:clamp(1.7rem,2.5vw,2.2rem);font-style:italic;color:#fff;margin-bottom:.8rem}
.calc-left p{color:rgba(255,255,255,.52);font-size:.9rem;font-weight:300;line-height:1.7;margin-bottom:2rem}
.calc-box{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);padding:2rem}
.cfield{margin-bottom:1.2rem}
.cfield label{display:block;font-size:.76rem;color:rgba(255,255,255,.48);margin-bottom:5px;font-weight:400}
.cfield .cval{font-size:1.05rem;font-weight:600;color:var(--teal-lt);font-family:var(--serif)}
input[type=range]{width:100%;accent-color:var(--teal-lt);cursor:pointer;margin-top:3px}
.freq-wrap{display:flex;gap:.45rem;margin-top:5px;flex-wrap:wrap}
.fbtn{font-family:var(--sans);font-size:.76rem;padding:5px 11px;border-radius:6px;cursor:pointer;border:1px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.55);transition:all .18s}
.fbtn.active{background:var(--teal-lt);border-color:var(--teal-lt);color:var(--navy);font-weight:600}
.calc-result{background:linear-gradient(135deg,var(--teal),#104632);border-radius:var(--r);padding:1.25rem 1.5rem;text-align:center;margin-top:1.4rem}
.calc-result-num{font-family:var(--serif);font-size:2.1rem;font-weight:700;color:#fff}
.calc-result-lbl{font-size:.78rem;color:rgba(255,255,255,.72);margin-top:2px}

/* COMMERCIAL */
.comm-section{background:var(--cream);padding:6rem 0}
.comm-panel{background:var(--navy);border-radius:var(--r2);padding:2.8rem;position:relative;overflow:hidden}
.comm-panel::after{content:'';position:absolute;bottom:-30px;right:-30px;width:200px;height:200px;background:radial-gradient(circle,rgba(210,216,188,.18) 0%,transparent 70%)}
.comm-panel h3{font-family:var(--serif);font-size:1.45rem;font-style:italic;color:#fff;margin-bottom:.75rem;position:relative;z-index:1}
.comm-panel p{color:rgba(255,255,255,.5);font-size:.88rem;font-weight:300;line-height:1.7;position:relative;z-index:1;margin-bottom:1.8rem}
.comm-stats{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;position:relative;z-index:1}
.comm-stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:1.1rem}
.comm-stat-num{font-family:var(--serif);font-size:1.7rem;font-style:italic;color:var(--teal-lt)}
.comm-stat-lbl{font-size:.73rem;color:rgba(255,255,255,.42);margin-top:3px;font-weight:300}

/* TESTIMONIALS */
.testi-section{background:#fff;padding:6rem 0}
.testi-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2.8rem;flex-wrap:wrap;gap:1.5rem}
.testi-hd h2{font-family:var(--serif);font-size:clamp(1.9rem,2.8vw,2.6rem);color:var(--navy);font-style:italic}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.testi-card{background:var(--cream);border:1px solid var(--border);border-radius:var(--r2);padding:1.9rem;display:flex;flex-direction:column;transition:all .22s}
.testi-card:hover{border-color:var(--teal);box-shadow:0 8px 28px rgba(21,90,66,.09)}
.stars{color:var(--gold);font-size:.82rem;font-weight:700;letter-spacing:0;margin-bottom:.9rem}
.testi-q{font-size:.88rem;color:var(--text);line-height:1.72;font-weight:300;flex:1;font-style:italic}
.testi-author{margin-top:1.4rem;display:flex;align-items:center;gap:12px}
.testi-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--navy));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.95rem;color:#fff;font-weight:700;flex-shrink:0}
.testi-name{font-size:.85rem;font-weight:600;color:var(--navy)}
.testi-role{font-size:.75rem;color:var(--muted);font-weight:300}
.testi-cta{text-align:center;margin-top:2.5rem}

/* TEAM */
.team-section{background:var(--cream);padding:6rem 0}
.team-hd{max-width:540px;margin-bottom:3rem}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:720px}
.team-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:2rem;display:flex;gap:1.4rem;align-items:flex-start;transition:all .22s}
.team-card:hover{border-color:var(--teal);box-shadow:0 6px 24px rgba(21,90,66,.09)}
.team-av{width:60px;height:60px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--teal));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.4rem;color:#fff;font-weight:700;flex-shrink:0}
.team-card h4{font-family:var(--serif);font-size:1.1rem;color:var(--navy);margin-bottom:.2rem}
.team-card .role{font-size:.78rem;color:var(--teal);font-weight:500;text-transform:uppercase;letter-spacing:.8px;margin-bottom:.6rem}
.team-card .contact a{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--muted);margin-bottom:.25rem;transition:color .2s}
.team-card .contact a:hover{color:var(--teal)}

/* INSURANCE */
.ins-section{background:var(--navy);padding:6rem 0;position:relative;overflow:hidden}
.ins-section::before{content:'';position:absolute;top:0;right:0;width:55%;height:100%;background:radial-gradient(ellipse at top right,rgba(21,90,66,.12) 0%,transparent 55%);pointer-events:none}
.ins-inner{position:relative;z-index:1}
.ins-header{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:2.8rem}
.ins-header h2{font-family:var(--serif);font-size:clamp(1.9rem,2.8vw,2.8rem);color:#fff;font-style:italic;line-height:1.2}
.ins-header .sub{color:rgba(255,255,255,.52);font-size:.92rem;font-weight:300;line-height:1.72}
.ins-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
.ins-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:var(--r);padding:1.7rem 1.2rem;cursor:pointer;transition:all .22s;display:block}
.ins-card:hover{background:rgba(21,90,66,.14);border-color:rgba(210,216,188,.38);transform:translateY(-3px)}
.ins-ico{width:46px;height:46px;border-radius:12px;background:rgba(21,90,66,.2);border:1px solid rgba(210,216,188,.18);display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:.9rem}
.ins-card h4{font-family:var(--serif);font-size:.98rem;color:#fff;font-style:italic;margin-bottom:.45rem}
.ins-card p{font-size:.78rem;color:rgba(255,255,255,.42);font-weight:300;line-height:1.5}
.ins-more{display:flex;align-items:center;gap:6px;color:var(--teal-lt);font-size:.76rem;font-weight:500;margin-top:1.1rem}

/* HOW WE HELP */
.how-section{background:#fff;padding:6rem 0}
.how-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.steps-v{display:flex;flex-direction:column;gap:0;position:relative}
.steps-v::before{content:'';position:absolute;left:22px;top:28px;bottom:28px;width:2px;background:linear-gradient(to bottom,var(--teal),transparent)}
.step-v{display:flex;gap:1.4rem;padding:1.4rem 0}
.step-num{width:44px;height:44px;border-radius:12px;background:var(--navy);border:2px solid var(--teal);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1rem;font-weight:700;color:var(--teal-lt);flex-shrink:0}
.step-v h4{font-size:.95rem;font-weight:600;color:var(--navy);margin-bottom:.35rem}
.step-v p{font-size:.84rem;color:var(--muted);font-weight:300;line-height:1.62}
.why-panel{background:var(--cream);border-radius:var(--r2);padding:2.2rem}
.why-panel h3{font-family:var(--serif);font-size:1.35rem;font-style:italic;color:var(--navy);margin-bottom:1.4rem}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.why-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:1.2rem;transition:all .2s}
.why-card:hover{border-color:var(--teal)}
.why-card span{font-size:1.4rem;display:block;margin-bottom:.6rem}
.why-card h4{font-size:.84rem;font-weight:600;color:var(--navy);margin-bottom:.28rem}
.why-card p{font-size:.76rem;color:var(--muted);font-weight:300;line-height:1.48}

/* BLOG */
.blog-section{background:var(--cream);padding:6rem 0}
.blog-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:2.8rem;flex-wrap:wrap;gap:1rem}
.blog-hd h2{font-family:var(--serif);font-size:clamp(1.8rem,2.5vw,2.4rem);color:var(--navy);font-style:italic}
.blog-all{color:var(--teal);font-size:.86rem;font-weight:500;display:flex;align-items:center;gap:5px;transition:gap .2s}
.blog-all:hover{gap:9px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:all .22s}
.blog-card:hover{border-color:var(--teal);box-shadow:0 8px 28px rgba(21,90,66,.1);transform:translateY(-3px)}
.blog-thumb{height:158px;display:flex;align-items:center;justify-content:center;font-size:2.8rem}
.bt1{background:linear-gradient(135deg,#161616,#155A42)}.bt2{background:linear-gradient(135deg,#155A42,#104632)}.bt3{background:linear-gradient(135deg,#161616,#155A42)}
.blog-body{padding:1.4rem}
.blog-cat{font-size:.7rem;font-weight:600;color:var(--teal);letter-spacing:1px;text-transform:uppercase;margin-bottom:.5rem;display:block}
.blog-card h3{font-family:var(--serif);font-size:1rem;color:var(--navy);line-height:1.38;margin-bottom:.5rem;font-style:italic}
.blog-card p{font-size:.8rem;color:var(--muted);line-height:1.55;font-weight:300;margin-bottom:.9rem}
.blog-read{color:var(--teal);font-size:.8rem;font-weight:500;display:flex;align-items:center;gap:4px;transition:gap .2s}
.blog-read:hover{gap:8px}
.blog-meta-row{display:flex;justify-content:space-between;gap:.75rem;flex-wrap:wrap;font-size:.76rem;color:var(--muted);margin-bottom:1rem}
.blog-feature-band{background:#fff;padding:4.5rem 0 1rem}
.blog-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.blog-feature-card{display:block;background:#fff;border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:all .22s}
.blog-feature-card:hover{border-color:var(--teal);box-shadow:0 8px 28px rgba(21,90,66,.1);transform:translateY(-3px)}
.blog-feature-thumb{height:220px;display:flex;align-items:center;justify-content:center;font-size:4rem}
.blog-feature-body{padding:1.5rem}
.blog-feature-body h2{font-family:var(--serif);font-size:1.35rem;color:var(--navy);font-style:italic;line-height:1.3;margin-bottom:.6rem}
.blog-feature-body p{font-size:.88rem;color:var(--muted);line-height:1.65;font-weight:300;margin-bottom:1rem}
.blog-empty{background:#fff;border:1px dashed var(--border);border-radius:var(--r2);padding:2rem;text-align:center}
.blog-empty h3{font-family:var(--serif);font-size:1.4rem;color:var(--navy);font-style:italic;margin-bottom:.5rem}
.blog-empty p{font-size:.9rem;color:var(--muted)}
.blog-post-hero{display:grid;grid-template-columns:1.4fr .8fr;gap:2rem;align-items:center}
.blog-post-hero-card{min-height:280px;border-radius:var(--r2);display:flex;align-items:center;justify-content:center;font-size:5rem}
.blog-post-hero-meta{display:flex;gap:.9rem;flex-wrap:wrap;color:rgba(255,255,255,.58);font-size:.82rem}
.blog-post-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.7fr);gap:2rem}
.blog-post-article{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:2.2rem}
.blog-post-content h2{font-family:var(--serif);font-size:1.6rem;font-style:italic;color:var(--navy);margin:1.8rem 0 .7rem}
.blog-post-content h3{font-size:1.06rem;color:var(--navy);margin:1.4rem 0 .55rem}
.blog-post-content p{font-size:.95rem;line-height:1.85;color:var(--text);font-weight:300;margin-bottom:1rem}
.blog-post-content ul,.blog-post-content ol{padding-left:1.2rem;margin:0 0 1rem}
.blog-post-content li{margin-bottom:.5rem;color:var(--text)}
.blog-post-tags{display:flex;gap:.6rem;flex-wrap:wrap;padding-top:1rem;margin-top:1.2rem;border-top:1px solid var(--border)}
.blog-related-list{display:flex;flex-direction:column;gap:.8rem}
.blog-related-item{display:flex;flex-direction:column;gap:.2rem;padding:.9rem 1rem;background:#fff;border:1px solid var(--border);border-radius:12px;transition:border-color .2s,transform .2s}
.blog-related-item:hover{border-color:var(--teal);transform:translateX(3px)}
.blog-related-item strong{font-size:.88rem;color:var(--navy)}
.blog-related-item span{font-size:.76rem;color:var(--muted)}

/* NEWSLETTER */
.nl-section{background:var(--teal);padding:4.2rem 0}
.nl-inner{max-width:580px;margin:0 auto;text-align:center;padding:0 2rem}
.nl-inner h2{font-family:var(--serif);font-size:1.9rem;font-style:italic;color:#fff;margin-bottom:.5rem}
.nl-inner p{color:rgba(255,255,255,.78);font-size:.92rem;font-weight:300;margin-bottom:1.8rem}
.nl-form{display:flex;gap:.65rem}
.nl-form input{flex:1;padding:.8rem 1.1rem;border:none;border-radius:8px;font-family:var(--sans);font-size:.88rem;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);color:#fff;outline:none;transition:border-color .2s}
.nl-form input::placeholder{color:rgba(255,255,255,.5)}
.nl-form input:focus{border-color:rgba(255,255,255,.6)}
.nl-form button{background:var(--navy);color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-family:var(--sans);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}
.nl-form button:hover{background:var(--navy2)}

/* FOOTER */
footer{background:var(--navy);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand .fl{display:flex;align-items:center;gap:10px;margin-bottom:1.2rem}
.footer-brand p{color:rgba(255,255,255,.42);font-size:.82rem;font-weight:300;line-height:1.7;max-width:290px;margin-bottom:1rem}
.fsp{display:inline-block;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.38);font-size:.7rem;padding:3px 9px;border-radius:4px}
.footer-col h5{font-family:var(--serif);color:#fff;font-size:.96rem;font-style:italic;margin-bottom:1.1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-col li a{color:rgba(255,255,255,.42);font-size:.82rem;transition:color .2s}
.footer-col li a:hover{color:var(--teal-lt)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:1.8rem}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.28)}
.social-row{display:flex;gap:.6rem}
.social-btn{width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.42);font-size:.72rem;font-weight:700;transition:all .2s}
.social-btn:hover{border-color:var(--teal-lt);color:var(--teal-lt)}

/* CTA BAND */
.cta-band{background:linear-gradient(135deg,var(--teal),#104632);padding:4rem 0;text-align:center}
.cta-band h2{font-family:var(--serif);font-size:clamp(1.8rem,2.8vw,2.5rem);color:#fff;font-style:italic;margin-bottom:.7rem}
.cta-band p{color:rgba(255,255,255,.78);font-size:.96rem;font-weight:300;max-width:480px;margin:0 auto 2.2rem}

/* ══════════════════════════════
   INNER PAGES
══════════════════════════════ */
.inner-hero{background:var(--navy);padding:110px 0 60px;position:relative;overflow:hidden}
.inner-hero::before{content:'';position:absolute;top:-20%;right:-10%;width:58%;height:140%;background:radial-gradient(ellipse at center,rgba(21,90,66,.13) 0%,transparent 68%);pointer-events:none}
.inner-hero-inner{max-width:var(--max);margin:0 auto;padding:0 2rem;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:1.4rem}
.breadcrumb a,.breadcrumb span{font-size:.78rem;color:rgba(255,255,255,.38)}
.breadcrumb a{transition:color .2s}.breadcrumb a:hover{color:var(--teal-lt)}
.breadcrumb .sep{color:rgba(255,255,255,.18)}
.breadcrumb .cur{color:rgba(255,255,255,.6)}
.inner-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.inner-hero h1{font-family:var(--serif);font-size:clamp(2.1rem,3.5vw,3.4rem);color:#fff;font-weight:700;line-height:1.12;letter-spacing:-.8px;margin-bottom:1.2rem}
.inner-hero h1 em{font-style:italic;color:var(--teal-lt)}
.inner-hero-desc{color:rgba(255,255,255,.58);font-size:1rem;font-weight:300;line-height:1.78;max-width:500px;margin-bottom:2.2rem}
.tag-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.8rem}
.ptag{background:rgba(21,90,66,.15);border:1px solid rgba(210,216,188,.25);color:var(--teal-lt);font-size:.75rem;font-weight:500;padding:4px 11px;border-radius:20px}
.why-box{background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);padding:1.9rem}
.why-box h3{font-family:var(--serif);color:#fff;font-size:1.05rem;font-style:italic;margin-bottom:1.2rem}
.why-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.why-list li{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.68);font-size:.84rem;font-weight:300}
.why-list li::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--teal-lt);flex-shrink:0}

/* inner content */
.inner-content{padding:5.5rem 0;background:#fff}
.inner-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:start}
.checklist{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.8rem}
.check-item{display:flex;align-items:flex-start;gap:12px;padding:.9rem 1.1rem;background:var(--cream);border:1px solid var(--border);border-radius:10px;transition:border-color .2s}
.check-item:hover{border-color:var(--teal)}
.check-ico{width:22px;height:22px;border-radius:6px;background:var(--teal-pale);border:1.5px solid rgba(21,90,66,.25);display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--teal);flex-shrink:0;margin-top:1px}
.check-item h4{font-size:.87rem;font-weight:600;color:var(--navy);margin-bottom:2px}
.check-item p{font-size:.79rem;color:var(--muted);font-weight:300;line-height:1.42}
.sticky-panel{position:sticky;top:84px}
.dark-box{background:var(--navy);border-radius:var(--r2);padding:2.2rem;margin-bottom:1.4rem}
.dark-box h3{font-family:var(--serif);color:#fff;font-style:italic;font-size:1.3rem;margin-bottom:.9rem}
.dark-box p{color:rgba(255,255,255,.52);font-size:.86rem;font-weight:300;line-height:1.68;margin-bottom:1.5rem}
.dark-box ul{list-style:none;display:flex;flex-direction:column;gap:.55rem;margin-bottom:1.7rem}
.dark-box ul li{display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.68);font-size:.84rem;font-weight:300}
.dark-box ul li::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--teal-lt);flex-shrink:0}
.enquiry-form{background:var(--cream);border:1px solid var(--border);border-radius:var(--r2);padding:2.2rem}
.enquiry-form h3{font-family:var(--serif);font-size:1.2rem;font-style:italic;color:var(--navy);margin-bottom:1.4rem}
.form-row{margin-bottom:1.1rem}
.form-row label{display:block;font-size:.76rem;font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.3px;margin-bottom:5px}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:8px;font-family:var(--sans);font-size:.88rem;color:var(--text);background:#fff;transition:border-color .2s;outline:none}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--teal)}
.form-row textarea{min-height:90px;resize:vertical}
.form-2{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}

/* inner steps */
.inner-steps{padding:5rem 0;background:var(--cream)}
.inner-steps h2{font-family:var(--serif);font-size:clamp(1.7rem,2.5vw,2.3rem);color:var(--navy);font-style:italic;margin-bottom:2.4rem}

/* faq */
.faq-section{padding:5rem 0;background:#fff}
.faq-section h2{font-family:var(--serif);font-size:clamp(1.7rem,2.5vw,2.3rem);color:var(--navy);font-style:italic;margin-bottom:2.2rem}
.faq{max-width:700px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 0;cursor:pointer;font-weight:500;font-size:.92rem;color:var(--navy);transition:color .2s}
.faq-q:hover{color:var(--teal)}
.faq-ico{width:22px;height:22px;border-radius:6px;background:var(--teal-pale);border:1px solid rgba(21,90,66,.2);display:flex;align-items:center;justify-content:center;font-size:.82rem;color:var(--teal);flex-shrink:0;transition:all .3s}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}
.faq-a.open{max-height:220px;padding-bottom:1.2rem}
.faq-a p{font-size:.86rem;color:var(--muted);line-height:1.7;font-weight:300}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.3rem}
.cinfo-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:1.4rem;display:flex;align-items:flex-start;gap:1rem}
.cinfo-ico{width:42px;height:42px;border-radius:10px;background:var(--teal-pale);border:1.5px solid rgba(21,90,66,.2);display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.cinfo-card h4{font-size:.87rem;font-weight:600;color:var(--navy);margin-bottom:.22rem}
.cinfo-card p,.cinfo-card a{font-size:.84rem;color:var(--muted);font-weight:300;line-height:1.55}
.cinfo-card a{transition:color .2s}.cinfo-card a:hover{color:var(--teal)}

/* calculators page */
.calc-tabs{display:flex;gap:.65rem;margin-bottom:2.8rem;flex-wrap:wrap}
.ctab{padding:.55rem 1.4rem;border-radius:8px;border:1.5px solid var(--border);background:transparent;font-family:var(--sans);font-size:.86rem;font-weight:500;color:var(--muted);cursor:pointer;transition:all .2s}
.ctab.active{background:var(--navy);border-color:var(--navy);color:#fff}
.cpanel{display:none}.cpanel.active{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.cbox{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:2.4rem}
.cbox h3{font-family:var(--serif);font-size:1.3rem;font-style:italic;color:var(--navy);margin-bottom:.45rem}
.cbox .sub{color:var(--muted);font-size:.84rem;font-weight:300;margin-bottom:2rem}
.cf{margin-bottom:1.4rem}
.cf label{display:block;font-size:.76rem;font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.3px;margin-bottom:5px}
.cf .cv{font-size:1rem;font-weight:600;color:var(--teal)}
.cf input[type=range]{width:100%;accent-color:var(--teal);cursor:pointer;margin-top:3px}
.cf select,.cf input[type=number]{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:8px;font-family:var(--sans);font-size:.88rem;color:var(--text);outline:none;transition:border-color .2s}
.cf select:focus,.cf input[type=number]:focus{border-color:var(--teal)}
.res-panel{background:var(--navy);border-radius:var(--r2);padding:2.4rem}
.res-panel h3{font-family:var(--serif);color:#fff;font-style:italic;margin-bottom:1.8rem;font-size:1.1rem}
.res-row{display:flex;justify-content:space-between;align-items:center;padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.res-row:last-child{border-bottom:none}
.res-lbl{font-size:.82rem;color:rgba(255,255,255,.5);font-weight:300}
.res-val{font-family:var(--serif);font-size:1.25rem;font-weight:700;color:var(--teal-lt)}
.c-ffreq{display:flex;gap:.45rem;margin-top:5px;flex-wrap:wrap}
.c-fbtn{font-family:var(--sans);font-size:.76rem;padding:5px 12px;border-radius:6px;cursor:pointer;border:1.5px solid var(--border);background:transparent;color:var(--muted);transition:all .18s}
.c-fbtn.active{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:600}
.cdisclaim{font-size:.73rem;color:var(--muted);margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid var(--border);line-height:1.6}

/* RESPONSIVE */
@media(max-width:1024px){.benefits-grid{grid-template-columns:repeat(3,1fr)}.ins-grid{grid-template-columns:repeat(3,1fr)}.footer-grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:1024px){.blog-feature-grid,.blog-post-layout,.blog-post-hero{grid-template-columns:1fr}}
@media(max-width:900px){
  .hero-inner,.split,.calc-grid,.comm-section .split,.ins-header,.how-grid,.inner-hero-grid,.inner-grid,.contact-grid,.cpanel.active{grid-template-columns:1fr}
  .hero-vis,.ins-grid{display:none}
  .testi-grid,.blog-grid{grid-template-columns:1fr 1fr}
  .blog-feature-grid{grid-template-columns:1fr}
  .nav-links,.nav-right{display:none}
  .hamburger{display:flex}
  .team-grid{grid-template-columns:1fr}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .testi-grid,.blog-grid,.footer-grid,.why-grid,.comm-stats,.form-2,.benefits-grid{grid-template-columns:1fr}
  .nl-form{flex-direction:column}
  .stats-row{grid-template-columns:1fr 1fr}
}

/* Standalone page extras */
.footer-brand .fl{display:flex;align-items:center;gap:10px;margin-bottom:1.2rem}
.footer-brand p{color:rgba(255,255,255,.42);font-size:.82rem;font-weight:300;line-height:1.7;max-width:290px;margin-bottom:1rem}
.fsp{display:inline-block;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.38);font-size:.7rem;padding:3px 9px;border-radius:4px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-col h5{font-family:var(--serif);color:#fff;font-size:.96rem;font-style:italic;margin-bottom:1.1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-col li a{color:rgba(255,255,255,.42);font-size:.82rem;transition:color .2s}
.footer-col li a:hover{color:var(--teal-lt)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:1.8rem}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.28)}
.social-row{display:flex;gap:.6rem}
.social-btn{width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.42);text-decoration:none;font-size:.72rem;font-weight:700;transition:all .2s}
.social-btn:hover{border-color:var(--teal-lt);color:var(--teal-lt)}
footer{background:var(--navy);padding:4rem 0 2rem}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr}}

/* Finnovo CodeIgniter redesign layer */
:root{
  --ink:#132018;
  --forest:#16372b;
  --deep:#102842;
  --fern:#227a57;
  --mint:#dff2e9;
  --sage:#edf5ef;
  --linen:#fbf7ef;
  --paper:#fffdf8;
  --clay:#b88655;
  --mist:#e7ece8;
  --shadow:0 18px 50px rgba(19,32,24,.1);
  --shadow-soft:0 10px 28px rgba(19,32,24,.08);
  --max:1180px;
  --r:8px;
  --r2:8px;
}

html{background:var(--paper)}
body{
  color:var(--ink);
  background:
    linear-gradient(180deg,rgba(251,247,239,.72),rgba(255,253,248,1) 520px),
    var(--paper);
  font-size:16px;
  letter-spacing:0;
}

a,button,input,select,textarea{font:inherit}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid rgba(34,122,87,.35);
  outline-offset:3px;
}

.container,.nav-wrap,.hero-inner,.inner-hero-inner{max-width:var(--max)}
.eyebrow{
  color:var(--fern);
  font-size:.72rem;
  letter-spacing:1.1px;
  font-weight:800;
}

.btn{
  border-radius:6px;
  padding:.82rem 1.2rem;
  min-height:44px;
  font-weight:800;
  letter-spacing:0;
  box-shadow:none;
}
.btn-teal{
  color:#fff;
  background:var(--forest);
  border:1px solid var(--forest);
}
.btn-teal:hover{
  background:var(--fern);
  border-color:var(--fern);
  transform:translateY(-1px);
}
.btn-white{
  color:var(--forest);
  background:var(--paper);
  border:1px solid rgba(22,55,43,.18);
}
.btn-ghost,.btn-navy-ghost{
  color:var(--forest);
  background:rgba(255,253,248,.76);
  border:1px solid rgba(22,55,43,.2);
}
.btn-ghost:hover,.btn-navy-ghost:hover{
  color:var(--forest);
  border-color:var(--forest);
  background:#fff;
}

nav{
  background:rgba(255,253,248,.9);
  border-bottom:1px solid rgba(22,55,43,.11);
  box-shadow:0 12px 34px rgba(19,32,24,.07);
}
.nav-wrap{height:74px}
.nav-logo-mark{
  width:36px;
  height:36px;
  border-radius:8px;
  background:var(--forest);
}
.nav-logo-text{color:var(--forest);font-size:1.28rem}
.nav-logo-text em{color:var(--fern)}
.nav-links{gap:1.2rem}
.nav-links a{
  color:rgba(19,32,24,.64);
  font-size:.82rem;
  font-weight:800;
  padding:.55rem 0;
}
.nav-links a:hover,.nav-links a.active{color:var(--forest)}
.nav-info{
  color:var(--forest);
  background:rgba(237,245,239,.75);
  border:1px solid rgba(22,55,43,.14);
  border-radius:6px;
  font-weight:700;
}
.nav-info:hover{color:var(--fern);border-color:rgba(34,122,87,.4)}
.nav-apply{
  background:var(--forest);
  border-radius:6px;
  font-weight:800;
}
.nav-apply:hover{background:var(--fern)}
.hamburger span{background:var(--forest)}
.mob-menu{
  top:74px;
  background:rgba(255,253,248,.98);
  border-bottom:1px solid rgba(22,55,43,.12);
}
.mob-menu a{
  color:rgba(19,32,24,.75);
  border-bottom:1px solid rgba(22,55,43,.09);
  font-weight:700;
}
.mob-menu a:hover,.mob-apply{color:var(--fern)!important}

.hero{
  min-height:92vh;
  padding:112px 0 34px;
  background:
    linear-gradient(90deg,rgba(255,253,248,.98) 0%,rgba(255,253,248,.9) 41%,rgba(255,253,248,.16) 68%,rgba(255,253,248,.08) 100%);
  align-items:end;
}
.hero-orb{display:none}
.hero-inner{
  grid-template-columns:minmax(0,.92fr) minmax(360px,.62fr);
  gap:2.25rem;
  align-items:end;
  padding-bottom:3.4rem;
}
.hero-pill{
  color:var(--forest);
  background:rgba(223,242,233,.92);
  border:1px solid rgba(34,122,87,.22);
  border-radius:999px;
  padding:7px 13px;
  letter-spacing:1px;
}
.hero-pill::before{background:var(--fern);animation:none}
.hero h1{
  color:var(--forest);
  font-size:clamp(2.7rem,5.2vw,5.35rem);
  line-height:.98;
  letter-spacing:0;
  max-width:740px;
}
.hero h1 em{color:var(--fern)}
.hero-desc{
  color:rgba(19,32,24,.72);
  font-size:1.06rem;
  line-height:1.72;
  max-width:560px;
  margin-bottom:1.8rem;
}
.hero-vis{
  gap:.9rem;
  align-self:end;
}
.hero-glass,.stat-box{
  background:rgba(255,253,248,.86);
  border:1px solid rgba(22,55,43,.12);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(14px);
}
.hero-glass{padding:1.35rem}
.hero-glass-hd h3{color:var(--forest);font-size:1.18rem}
.badge{
  color:var(--fern);
  background:rgba(223,242,233,.86);
  border-color:rgba(34,122,87,.2);
}
.svc-link{
  color:rgba(19,32,24,.7);
  border-bottom:1px solid rgba(22,55,43,.09);
  font-weight:650;
}
.svc-link:hover{color:var(--fern)}
.svc-link .arr{opacity:1;color:var(--fern)}
.stats-row{gap:.75rem}
.stat-box{padding:1rem}
.stat-num{color:var(--forest);font-size:1.72rem}
.stat-lbl{color:rgba(19,32,24,.56);font-weight:700}

.ticker{
  background:var(--forest);
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.tick-item{
  color:rgba(255,255,255,.88);
  font-weight:800;
}

.benefits,.comm-section,.blog-section,.inner-steps{
  background:var(--linen);
}
.mort-section,.testi-section,.how-section,.faq-section,.inner-content{
  background:var(--paper);
}
.ins-section,.calc-banner,.cta-band{
  background:var(--forest);
}
.ins-section::before,.inner-hero::before,.comm-panel::after{display:none}

.benefits,.mort-section,.comm-section,.testi-section,.team-section,.ins-section,.how-section,.blog-section,.inner-content,.inner-steps,.faq-section{
  padding:5.8rem 0;
}
.benefits h2,.split-content h2,.testi-hd h2,.ins-header h2,.blog-hd h2,.inner-steps h2,.faq-section h2,.cta-band h2{
  color:var(--forest);
  font-style:normal;
  letter-spacing:0;
}
.ins-header h2,.cta-band h2{color:#fff}
.split-content .lead,.ins-header .sub,.blog-card p,.blog-feature-body p,.check-item p,.step-v p,.why-card p,.faq-a p{
  color:rgba(19,32,24,.67);
}
.ins-header .sub{color:rgba(255,255,255,.72)}

.ben-card,.blog-card,.blog-feature-card,.testi-card,.team-card,.why-card,.check-item,.cinfo-card,.cbox,.blog-post-article,.blog-related-item,.blog-empty{
  border-radius:8px;
  border:1px solid rgba(22,55,43,.12);
  background:rgba(255,253,248,.94);
  box-shadow:0 1px 0 rgba(22,55,43,.03);
}
.ben-card:hover,.blog-card:hover,.blog-feature-card:hover,.testi-card:hover,.team-card:hover,.why-card:hover,.check-item:hover,.cinfo-card:hover,.blog-related-item:hover{
  border-color:rgba(34,122,87,.38);
  box-shadow:var(--shadow-soft);
}
.ben-card{
  text-align:left;
  min-height:178px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.ben-ico,.ins-ico,.cinfo-ico{
  width:42px;
  height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--sage);
  border:1px solid rgba(34,122,87,.14);
  margin-bottom:.9rem;
}

.visual-panel,.comm-panel,.dark-box,.res-panel,.why-panel,.calc-box{
  border-radius:8px;
  background:var(--forest);
  border:1px solid rgba(255,255,255,.09);
  box-shadow:var(--shadow);
}
.visual-panel{
  min-height:460px;
  background:
    linear-gradient(180deg,rgba(22,55,43,.04),rgba(22,55,43,.92));
}
.visual-panel::before{display:none}
.v-box{
  background:rgba(255,253,248,.12);
  border-color:rgba(255,255,255,.16);
}
.visual-caption strong,.comm-stat-num,.res-val,.cfield .cval,.inner-hero h1 em{color:var(--mint)}
.svc-row{
  background:var(--sage);
  border-color:rgba(22,55,43,.11);
  border-radius:8px;
  font-weight:800;
}
.svc-row:hover{
  background:var(--mint);
  border-color:rgba(34,122,87,.36);
  color:var(--forest);
}

.calc-grid,.split,.how-grid,.inner-grid,.contact-grid,.cpanel.active{
  gap:3rem;
}
.calc-left h2,.calc-left p{color:#fff}
.calc-left p{color:rgba(255,255,255,.7)}
.fbtn,.c-fbtn{
  border-radius:6px;
  font-weight:800;
}
.fbtn.active,.c-fbtn.active{
  color:var(--forest);
  background:var(--mint);
  border-color:var(--mint);
}
.calc-result{
  background:var(--paper);
  border-radius:8px;
}
.calc-result-num{color:var(--forest)}
.calc-result-lbl{color:rgba(19,32,24,.6);font-weight:700}

.ins-grid{gap:1rem}
.ins-card{
  border-radius:8px;
  background:rgba(255,253,248,.08);
  border-color:rgba(255,255,255,.12);
}
.ins-card:hover{
  background:rgba(255,253,248,.13);
  border-color:rgba(223,242,233,.45);
}
.ins-card h4{font-style:normal}
.ins-more{color:var(--mint);font-weight:800}

.inner-hero{
  background:
    linear-gradient(90deg,rgba(22,55,43,.93),rgba(22,55,43,.72));
  padding:122px 0 70px;
}
.breadcrumb a,.breadcrumb span{color:rgba(255,255,255,.6)}
.breadcrumb .cur{color:#fff}
.inner-hero h1{
  color:#fff;
  letter-spacing:0;
  font-size:clamp(2.35rem,4.4vw,4.45rem);
}
.inner-hero-desc{color:rgba(255,255,255,.77)}
.ptag{
  color:#fff;
  background:rgba(255,255,255,.13);
  border-color:rgba(255,255,255,.18);
}
.why-box{
  background:rgba(255,253,248,.11);
  border-color:rgba(255,255,255,.16);
}
.why-list li::before,.dark-box ul li::before{color:var(--mint)}

.blog-thumb,.blog-feature-thumb,.blog-post-hero-card{
  background:
    linear-gradient(180deg,rgba(22,55,43,.05),rgba(22,55,43,.72))!important;
  color:#fff;
}
.blog-cat,.blog-all,.blog-read{color:var(--fern);font-weight:800}
.blog-card h3,.blog-feature-body h2,.blog-post-content h2,.blog-post-content h3,.blog-empty h3,.enquiry-form h3,.dark-box h3,.why-panel h3,.cbox h3,.res-panel h3{
  color:var(--forest);
  font-style:normal;
}
.dark-box h3,.res-panel h3{color:#fff}
.blog-post-layout{align-items:start}
.blog-post-article{box-shadow:var(--shadow-soft)}
.blog-post-content p{color:rgba(19,32,24,.76)}
.blog-related-item:hover{transform:none}

.nl-section{background:var(--forest)}
.nl-form input{
  border-radius:6px;
  background:rgba(255,255,255,.1);
}
.nl-form button{
  border-radius:6px;
  background:var(--mint);
  color:var(--forest);
}

.enquiry-form{
  background:rgba(255,253,248,.96)!important;
  border-color:rgba(22,55,43,.12);
  border-radius:8px;
  box-shadow:var(--shadow-soft);
}
.form-row input,.form-row select,.form-row textarea,.cf select,.cf input[type=number]{
  border-radius:6px;
  border-color:rgba(22,55,43,.16);
  background:#fff;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus,.cf select:focus,.cf input[type=number]:focus{
  border-color:var(--fern);
  box-shadow:0 0 0 4px rgba(34,122,87,.1);
}
.ctab{
  border-radius:6px;
  background:#fff;
  font-weight:800;
}
.ctab.active{
  background:var(--forest);
  border-color:var(--forest);
}
.res-panel{background:var(--forest)}

footer{
  background:var(--ink);
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-col h5{font-style:normal}
.footer-brand p,.footer-col li a,.footer-bottom p,.social-btn,.fsp{
  color:rgba(255,255,255,.58);
}
.social-btn{border-radius:6px}
.social-btn:hover,.footer-col li a:hover{color:var(--mint);border-color:var(--mint)}

@media(max-width:1024px){
  .hero{
    background:
      linear-gradient(180deg,rgba(255,253,248,.98),rgba(255,253,248,.82));
  }
  .hero-inner{grid-template-columns:1fr}
  .hero-vis{max-width:620px}
  .benefits-grid,.ins-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:900px){
  .nav-wrap{height:68px}
  .mob-menu{top:68px}
  .hero{padding-top:104px;min-height:auto}
  .hero-inner{padding-bottom:2.5rem}
  .nav-links,.nav-right{display:none}
  .hamburger{display:flex}
  .split,.calc-grid,.how-grid,.inner-grid,.contact-grid,.cpanel.active,.inner-hero-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:600px){
  .container,.hero-inner,.inner-hero-inner,.nav-wrap{padding-left:1.1rem;padding-right:1.1rem}
  .hero h1{font-size:2.75rem}
  .hero-vis{display:none}
  .benefits-grid,.ins-grid,.blog-grid,.testi-grid,.team-grid,.why-grid,.stats-row,.form-2{
    grid-template-columns:1fr;
  }
  .nl-form,.hero-btns{flex-direction:column}
  .btn,.nl-form button{width:100%;justify-content:center}
}

/* Premium reusable icon system */
.fi{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:1em;
  height:1em;
  color:currentColor;
  flex-shrink:0;
  vertical-align:-.14em;
}
.fi svg{
  width:100%;
  height:100%;
  fill:none;
  stroke:currentColor;
  stroke-width:1.85;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.brand-icon{
  width:19px;
  height:19px;
  color:#fff;
}
.text-icon{
  width:1.05em;
  height:1.05em;
  margin-right:.42rem;
  color:var(--fern);
}
.tick-icon{
  width:18px;
  height:18px;
  color:var(--mint);
}
.tick-item .text-icon{
  color:var(--mint);
  margin-right:0;
}
.ben-ico.fi,.ins-ico.fi,.cinfo-ico.fi,.check-ico.fi,.sico.fi,.icon-card__icon{
  margin-right:0;
}
.ben-ico .fi,.ins-ico .fi,.cinfo-ico .fi{
  width:24px;
  height:24px;
}
.ben-ico,
.ins-ico,
.cinfo-ico,
.check-ico{
  color:var(--forest);
}
.check-ico.fi{
  width:24px;
  height:24px;
  border-radius:7px;
}
.sico .fi,.sico.fi{
  width:20px;
  height:20px;
  color:var(--fern);
}
.hero{
  background:
    radial-gradient(circle at 74% 30%,rgba(223,242,233,.96) 0 12%,transparent 13%),
    radial-gradient(circle at 84% 54%,rgba(34,122,87,.14) 0 11%,transparent 12%),
    radial-gradient(circle at 68% 70%,rgba(184,134,85,.18) 0 10%,transparent 11%),
    linear-gradient(90deg,rgba(255,253,248,.99) 0%,rgba(255,253,248,.96) 45%,rgba(255,253,248,.7) 72%,rgba(255,253,248,.92) 100%);
}
.hero::after{
  content:"";
  position:absolute;
  right:max(2rem,calc((100vw - var(--max))/2));
  top:150px;
  width:min(430px,34vw);
  aspect-ratio:1;
  border:1px solid rgba(22,55,43,.12);
  border-radius:8px;
  background:
    linear-gradient(135deg,rgba(255,253,248,.88),rgba(237,245,239,.84)),
    radial-gradient(circle at 30% 28%,rgba(34,122,87,.18),transparent 22%),
    radial-gradient(circle at 70% 70%,rgba(184,134,85,.16),transparent 24%);
  box-shadow:var(--shadow);
  z-index:0;
}
.hero::before{
  content:"";
  position:absolute;
  right:calc(max(2rem,calc((100vw - var(--max))/2)) + 52px);
  top:205px;
  width:min(315px,25vw);
  aspect-ratio:1;
  background:
    linear-gradient(var(--forest),var(--forest)) 50% 12%/42px 2px no-repeat,
    linear-gradient(var(--forest),var(--forest)) 50% 88%/42px 2px no-repeat,
    linear-gradient(var(--forest),var(--forest)) 12% 50%/2px 42px no-repeat,
    linear-gradient(var(--forest),var(--forest)) 88% 50%/2px 42px no-repeat,
    radial-gradient(circle at 50% 16%,var(--forest) 0 18px,transparent 19px),
    radial-gradient(circle at 84% 50%,var(--fern) 0 18px,transparent 19px),
    radial-gradient(circle at 50% 84%,var(--clay) 0 18px,transparent 19px),
    radial-gradient(circle at 16% 50%,var(--deep) 0 18px,transparent 19px),
    radial-gradient(circle at 50% 50%,rgba(255,253,248,.96) 0 56px,transparent 57px);
  border:1px solid rgba(22,55,43,.14);
  border-radius:999px;
  z-index:0;
}
.hero-inner{z-index:1}
.visual-panel{
  background:
    linear-gradient(180deg,rgba(22,55,43,.08),rgba(22,55,43,.96)),
    radial-gradient(circle at 72% 22%,rgba(223,242,233,.26),transparent 32%),
    var(--forest);
}
.inner-hero{
  background:
    linear-gradient(90deg,rgba(22,55,43,.95),rgba(22,55,43,.78)),
    radial-gradient(circle at 82% 38%,rgba(223,242,233,.18),transparent 24%),
    radial-gradient(circle at 68% 74%,rgba(184,134,85,.18),transparent 24%),
    var(--forest);
}
.blog-thumb,.blog-feature-thumb,.blog-post-hero-card{
  background:
    radial-gradient(circle at 30% 25%,rgba(223,242,233,.2),transparent 28%),
    linear-gradient(135deg,var(--forest),#214836)!important;
}
.blog-thumb .text-icon,.blog-feature-thumb .text-icon,.blog-post-hero-card .text-icon{
  width:64px;
  height:64px;
  margin:0;
  color:var(--mint);
}
.blog-feature-thumb .text-icon,.blog-post-hero-card .text-icon{
  width:82px;
  height:82px;
}
.icon-card{
  display:block;
  border:1px solid rgba(22,55,43,.12);
  border-radius:8px;
  background:rgba(255,253,248,.94);
  padding:1.4rem;
  color:var(--ink);
  transition:border-color .2s,box-shadow .2s,transform .2s;
}
.icon-card:hover{
  border-color:rgba(34,122,87,.38);
  box-shadow:var(--shadow-soft);
  transform:translateY(-2px);
}
.icon-card__icon{
  width:42px;
  height:42px;
  border-radius:8px;
  color:var(--forest);
  background:var(--sage);
  border:1px solid rgba(34,122,87,.14);
  padding:9px;
  margin-bottom:.9rem;
}
.icon-card h3{
  color:var(--forest);
  font-size:1rem;
  margin-bottom:.35rem;
}
.icon-card p{
  color:rgba(19,32,24,.67);
  font-size:.86rem;
  line-height:1.58;
}
@media(max-width:1024px){
  .hero::after,.hero::before{opacity:.18}
}
@media(max-width:700px){
  .hero::after,.hero::before{display:none}
}
/* Icon cleanup for nested reusable icons */
.tick-item .fi,
.sico .fi,
.ben-ico .fi,
.ins-ico .fi,
.cinfo-ico .fi,
.why-card > span .fi,
.blog-thumb .fi,
.blog-feature-thumb .fi,
.blog-post-hero-card .fi{
  margin-right:0;
}
h4 .text-icon{
  vertical-align:-.18em;
}
.check-item h4{
  display:flex;
  align-items:center;
  gap:.46rem;
}
.check-item h4 .text-icon{
  margin-right:0;
}

/* Blue-grey palette layer */
:root{
  --ink:#111827;
  --forest:#16283f;
  --deep:#10243a;
  --fern:#3e6f96;
  --mint:#dbe8f2;
  --sage:#eef3f7;
  --linen:#f2f4f6;
  --paper:#f8fafc;
  --clay:#8fa5b8;
  --mist:#d7e0e8;
  --shadow:0 18px 50px rgba(17,24,39,.1);
  --shadow-soft:0 10px 28px rgba(17,24,39,.08);
}

body{
  color:var(--ink);
  background:
    linear-gradient(180deg,rgba(242,244,246,.9),rgba(248,250,252,1) 540px),
    var(--paper);
}

nav{
  background:rgba(248,250,252,.92);
  border-bottom-color:rgba(22,40,63,.12);
}

.nav-logo-mark,
.nav-apply,
.btn-teal,
.ctab.active,
.c-fbtn.active{
  background:var(--forest);
  border-color:var(--forest);
}

.nav-logo-text,
.nav-info,
.nav-links a:hover,
.nav-links a.active,
.hero h1,
.hero-glass-hd h3,
.stat-num,
.benefits h2,
.split-content h2,
.testi-hd h2,
.blog-hd h2,
.blog-card h3,
.blog-feature-body h2,
.blog-post-content h2,
.blog-post-content h3,
.enquiry-form h3,
.dark-box h3,
.why-panel h3,
.cbox h3,
.res-panel h3,
.faq-section h2,
.inner-steps h2,
.check-item h4,
.cinfo-card h4,
.faq-q{
  color:var(--forest);
}

.nav-logo-text em,
.hero h1 em,
.eyebrow,
.blog-cat,
.blog-all,
.blog-read,
.svc-arr,
.cf .cv{
  color:var(--fern);
}

.nav-apply,
.btn-teal,
.ctab.active,
.c-fbtn.active{
  color:#fff;
}

.nav-apply:hover,
.btn-teal:hover{
  background:var(--fern);
  border-color:var(--fern);
}

.hero{
  background:
    radial-gradient(circle at 74% 30%,rgba(219,232,242,.96) 0 12%,transparent 13%),
    radial-gradient(circle at 84% 54%,rgba(62,111,150,.14) 0 11%,transparent 12%),
    radial-gradient(circle at 68% 70%,rgba(143,165,184,.18) 0 10%,transparent 11%),
    linear-gradient(90deg,rgba(248,250,252,.99) 0%,rgba(248,250,252,.96) 45%,rgba(238,243,247,.74) 72%,rgba(248,250,252,.92) 100%);
}

.hero-pill,
.badge{
  color:var(--forest);
  background:rgba(219,232,242,.9);
  border-color:rgba(62,111,150,.24);
}

.hero-desc,
.split-content .lead,
.blog-card p,
.blog-feature-body p,
.check-item p,
.step-v p,
.why-card p,
.faq-a p,
.cbox .sub,
.cdisclaim,
.cinfo-card p,
.cinfo-card a{
  color:rgba(17,24,39,.66);
}

.hero-glass,
.stat-box,
.ben-card,
.blog-card,
.blog-feature-card,
.testi-card,
.team-card,
.why-card,
.check-item,
.cinfo-card,
.cbox,
.blog-post-article,
.blog-related-item,
.blog-empty,
.enquiry-form,
.icon-card{
  background:rgba(248,250,252,.96);
  border-color:rgba(22,40,63,.12);
}

.benefits,
.comm-section,
.blog-section,
.inner-steps{
  background:var(--linen);
}

.mort-section,
.testi-section,
.how-section,
.faq-section,
.inner-content{
  background:var(--paper);
}

.visual-panel,
.comm-panel,
.dark-box,
.res-panel,
.why-panel,
.calc-box,
.ins-section,
.calc-banner,
.cta-band{
  background:var(--forest);
}

.visual-panel{
  background:
    linear-gradient(180deg,rgba(22,40,63,.08),rgba(22,40,63,.96)),
    radial-gradient(circle at 72% 22%,rgba(219,232,242,.24),transparent 32%),
    var(--forest);
}

.inner-hero{
  background:
    linear-gradient(90deg,rgba(22,40,63,.95),rgba(22,40,63,.78)),
    radial-gradient(circle at 82% 38%,rgba(219,232,242,.16),transparent 24%),
    radial-gradient(circle at 68% 74%,rgba(143,165,184,.18),transparent 24%),
    var(--forest);
}

.blog-thumb,
.blog-feature-thumb,
.blog-post-hero-card{
  background:
    radial-gradient(circle at 30% 25%,rgba(219,232,242,.2),transparent 28%),
    linear-gradient(135deg,var(--forest),#274463)!important;
}

.ticker{
  background:var(--forest);
}

.tick-item .text-icon,
.tick-item,
.visual-caption strong,
.comm-stat-num,
.res-val,
.inner-hero h1 em,
.ins-more,
.footer-col li a:hover,
.social-btn:hover{
  color:var(--mint);
}

.ben-ico,
.ins-ico,
.cinfo-ico,
.check-ico,
.icon-card__icon{
  color:var(--forest);
  background:var(--mint);
  border-color:rgba(62,111,150,.16);
}

.svc-row{
  background:#fff;
  border-color:rgba(22,40,63,.12);
}

.svc-row:hover{
  background:var(--sage);
  border-color:rgba(62,111,150,.32);
  color:var(--forest);
}

.calc-result,
.fbtn.active{
  background:var(--mint);
}

.calc-result-num,
.calc-result-lbl,
.fbtn.active{
  color:var(--forest);
}

.form-row input,
.form-row select,
.form-row textarea,
.cf select,
.cf input[type=number]{
  background:#fff;
  border-color:rgba(22,40,63,.16);
}

.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus,
.cf select:focus,
.cf input[type=number]:focus{
  border-color:var(--fern);
  box-shadow:0 0 0 4px rgba(62,111,150,.1);
}

footer{
  background:#111827;
}

.footer-brand .nav-logo-text{
  color:#fff;
}

@media(max-width:1024px){
  .hero{
    background:
      linear-gradient(180deg,rgba(248,250,252,.99),rgba(238,243,247,.86));
  }
}

/* Reduce true white: light-grey surfaces with the blue-grey palette */
:root{
  --surface:#eef2f6;
  --surface-soft:#f5f7f9;
}

html,
body,
main{
  background:var(--surface);
}

nav{
  background:rgba(245,247,249,.94);
}

.hero{
  background:
    radial-gradient(circle at 74% 30%,rgba(219,232,242,.96) 0 12%,transparent 13%),
    radial-gradient(circle at 84% 54%,rgba(62,111,150,.14) 0 11%,transparent 12%),
    radial-gradient(circle at 68% 70%,rgba(143,165,184,.18) 0 10%,transparent 11%),
    linear-gradient(90deg,var(--surface-soft) 0%,var(--surface-soft) 45%,var(--surface) 72%,var(--surface-soft) 100%);
}

.mort-section,
.testi-section,
.how-section,
.faq-section,
.inner-content,
.blog-section{
  background:var(--surface-soft);
}

.benefits,
.comm-section,
.inner-steps,
.blog-feature-band{
  background:var(--surface);
}

.hero-glass,
.stat-box,
.ben-card,
.blog-card,
.blog-feature-card,
.testi-card,
.team-card,
.why-card,
.check-item,
.cinfo-card,
.cbox,
.blog-post-article,
.blog-related-item,
.blog-empty,
.enquiry-form,
.icon-card,
.svc-row,
.calc-box,
.form-row input,
.form-row select,
.form-row textarea,
.cf select,
.cf input[type=number]{
  background:var(--surface-soft);
}

.btn-white,
.btn-ghost,
.btn-navy-ghost,
.nav-info{
  background:var(--surface-soft);
}

.hero-pill,
.badge,
.calc-result,
.fbtn.active{
  background:var(--mint);
}

@media(max-width:1024px){
  .hero{
    background:linear-gradient(180deg,var(--surface-soft),var(--surface));
  }
}

/* Mortgage help section spacing */
.mort-section{
  padding-top:7.5rem;
  padding-bottom:5.5rem;
  scroll-margin-top:88px;
}

.mort-section .split{
  align-items:start;
}

.mort-section .visual-panel{
  min-height:460px;
  padding:2.4rem;
}

.mort-section .split-content{
  padding-top:.1rem;
}

.mort-section .split-content .eyebrow{
  margin-bottom:.65rem;
}

.mort-section .split-content h2{
  margin-bottom:1rem;
}

.mort-section .svc-list{
  gap:.55rem;
}

.mort-section .svc-row{
  min-height:56px;
}

@media(max-width:1024px){
  .mort-section{
    padding-top:4.5rem;
  }

  .mort-section .visual-panel{
    min-height:390px;
  }
}

/* Final client-approved palette - must remain last */
:root{
  --soil:#161616;
  --forest:#155A42;
  --olive:#D2D8BC;
  --navy:#161616;
  --navy2:#242424;
  --teal:#155A42;
  --teal2:#104632;
  --teal-lt:#D2D8BC;
  --teal-pale:#EEF2E2;
  --gold:#D2D8BC;
  --cream:#F3F5EA;
  --text:#161616;
  --muted:#5f675c;
  --border:#dde2cf;
  --aqua:#D2D8BC;
  --cyan:#155A42;
  --blue:#155A42;
  --deep-blue:#161616;
  --navy-blue:#161616;
  --ink:#161616;
  --deep:#161616;
  --fern:#155A42;
  --mint:#D2D8BC;
  --sage:#EEF2E2;
  --linen:#F3F5EA;
  --paper:#FAFBF6;
  --clay:#155A42;
  --mist:#dde2cf;
  --surface:#F3F5EA;
  --surface-soft:#FAFBF6;
  --shadow:0 18px 50px rgba(22,22,22,.1);
  --shadow-soft:0 10px 28px rgba(22,22,22,.08);
}

html,
body,
main{
  background:var(--surface);
}

body{
  color:var(--soil);
}

nav{
  background:rgba(250,251,246,.94);
  border-bottom-color:rgba(22,22,22,.12);
}

.nav-logo-mark,
.nav-apply,
.btn-teal,
.ctab.active,
.c-fbtn.active{
  background:var(--soil);
  border-color:var(--soil);
}

.nav-apply:hover,
.btn-teal:hover{
  background:var(--forest);
  border-color:var(--forest);
}

.hero{
  background:
    radial-gradient(circle at 74% 30%,rgba(210,216,188,.72) 0 12%,transparent 13%),
    radial-gradient(circle at 84% 54%,rgba(21,90,66,.18) 0 11%,transparent 12%),
    linear-gradient(90deg,rgba(250,251,246,.99) 0%,rgba(250,251,246,.96) 45%,rgba(243,245,234,.78) 72%,rgba(250,251,246,.92) 100%);
}

.hero::before,
.hero::after{
  border-color:rgba(22,22,22,.12);
  background:
    linear-gradient(135deg,rgba(250,251,246,.88),rgba(238,242,226,.84)),
    radial-gradient(circle at 30% 28%,rgba(21,90,66,.16),transparent 22%),
    radial-gradient(circle at 70% 70%,rgba(210,216,188,.4),transparent 24%);
}

.hero h1,
.hero-glass-hd h3,
.nav-logo-text,
.nav-info,
.nav-links a,
.stat-num,
.benefits h2,
.split-content h2,
.testi-hd h2,
.blog-hd h2,
.blog-card h3,
.blog-feature-body h2,
.blog-post-content h2,
.blog-post-content h3,
.enquiry-form h3,
.dark-box h3,
.why-panel h3,
.cbox h3,
.res-panel h3,
.faq-section h2,
.inner-steps h2,
.check-item h4,
.cinfo-card h4,
.faq-q{
  color:var(--soil);
}

.hero h1 em,
.nav-logo-text em,
.nav-links a:hover,
.nav-links a.active,
.eyebrow,
.blog-cat,
.blog-all,
.blog-read,
.svc-arr,
.cf .cv{
  color:var(--forest);
}

.hero-pill,
.badge,
.calc-result,
.fbtn.active,
.ben-ico,
.ins-ico,
.cinfo-ico,
.check-ico,
.icon-card__icon{
  color:var(--soil);
  background:var(--olive);
  border-color:rgba(21,90,66,.18);
}

.hero-glass,
.stat-box,
.ben-card,
.blog-card,
.blog-feature-card,
.testi-card,
.team-card,
.why-card,
.check-item,
.cinfo-card,
.cbox,
.blog-post-article,
.blog-related-item,
.blog-empty,
.enquiry-form,
.icon-card,
.svc-row,
.calc-box,
.form-row input,
.form-row select,
.form-row textarea,
.cf select,
.cf input[type=number]{
  background:var(--surface-soft);
  border-color:rgba(21,90,66,.15);
}

.benefits,
.comm-section,
.inner-steps,
.blog-feature-band{
  background:var(--surface);
}

.mort-section,
.testi-section,
.how-section,
.faq-section,
.inner-content,
.blog-section{
  background:var(--surface-soft);
}

.visual-panel,
.comm-panel,
.dark-box,
.res-panel,
.why-panel,
.calc-banner,
.ins-section,
.cta-band{
  background:var(--soil);
}

.visual-panel{
  background:
    linear-gradient(180deg,rgba(21,90,66,.08),rgba(22,22,22,.94)),
    radial-gradient(circle at 72% 22%,rgba(210,216,188,.24),transparent 32%),
    var(--soil);
}

.comm-panel{
  background:
    linear-gradient(160deg,rgba(21,90,66,.28),transparent 34%),
    var(--soil);
}

.inner-hero{
  background:
    linear-gradient(90deg,rgba(22,22,22,.96),rgba(21,90,66,.82)),
    radial-gradient(circle at 82% 38%,rgba(210,216,188,.18),transparent 24%),
    radial-gradient(circle at 68% 74%,rgba(21,90,66,.18),transparent 24%),
    var(--soil);
}

.ticker,
footer{
  background:var(--soil);
}

.blog-thumb,
.blog-feature-thumb,
.blog-post-hero-card{
  background:
    radial-gradient(circle at 30% 25%,rgba(210,216,188,.2),transparent 28%),
    linear-gradient(135deg,var(--soil),var(--forest))!important;
}

.tick-item,
.tick-item .text-icon,
.visual-caption strong,
.comm-stat-num,
.res-val,
.inner-hero h1 em,
.ins-more,
.footer-col li a:hover,
.social-btn:hover{
  color:var(--olive);
}

.split-content .lead,
.blog-card p,
.blog-feature-body p,
.check-item p,
.step-v p,
.why-card p,
.faq-a p,
.cbox .sub,
.cdisclaim,
.cinfo-card p,
.cinfo-card a,
.hero-desc,
.svc-link,
.stat-lbl{
  color:rgba(22,22,22,.68)!important;
}

.svc-row:hover,
a[style*="border:1px solid var(--border)"]:hover,
a[style*="background:#fff;border:1px solid var(--border)"]:hover,
a[style*="background:var(--cream);border:1px solid var(--border)"]:hover{
  background:var(--teal-pale)!important;
  border-color:var(--forest)!important;
  color:var(--soil)!important;
}

.ben-card:hover,
.testi-card:hover,
.team-card:hover,
.why-card:hover,
.blog-card:hover,
.blog-feature-card:hover,
.blog-related-item:hover,
.check-item:hover{
  border-color:var(--forest)!important;
  box-shadow:0 10px 28px rgba(22,22,22,.1)!important;
}

span[style*="color:var(--teal)"],
a[style*="color:var(--teal)"],
div[style*="color:var(--teal)"]{
  color:var(--forest)!important;
}

.calc-box .cfield .cval,
.cbox .cf .cv,
.calc-result-num{
  color:var(--soil)!important;
}

.calc-box input[type=range],
.cbox input[type=range]{
  accent-color:var(--forest)!important;
}

.calc-box .fbtn.active,
.cbox .c-fbtn.active{
  background:var(--soil)!important;
  border-color:var(--soil)!important;
}

.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus,
.cf select:focus,
.cf input[type=number]:focus{
  border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(21,90,66,.14);
}

@media(max-width:1024px){
  .hero{
    background:linear-gradient(180deg,var(--surface-soft),var(--surface));
  }
}

/* Mortgage help section spacing - final override */
.mort-section{
  padding-top:7.5rem;
  padding-bottom:5.5rem;
  scroll-margin-top:88px;
}

.mort-section .split{
  align-items:start;
}

.mort-section .visual-panel{
  min-height:460px;
  padding:2.4rem;
}

.mort-section .split-content{
  padding-top:.1rem;
}

.mort-section .split-content .eyebrow{
  margin-bottom:.65rem;
}

.mort-section .split-content h2{
  margin-bottom:1rem;
}

.mort-section .svc-list{
  gap:.55rem;
}

.mort-section .svc-row{
  min-height:56px;
}

@media(max-width:1024px){
  .mort-section{
    padding-top:4.5rem;
  }

  .mort-section .visual-panel{
    min-height:390px;
  }
}

/* Final client-approved palette */
:root{
  --navy:#161616;
  --soil:#161616;
  --navy2:#242424;
  --teal:#155A42;
  --forest:#155A42;
  --teal2:#104632;
  --teal-lt:#D2D8BC;
  --olive:#D2D8BC;
  --teal-pale:#EEF2E2;
  --gold:#D2D8BC;
  --cream:#F3F5EA;
  --text:#161616;
  --muted:#5f675c;
  --border:#dde2cf;
  --aqua:#D2D8BC;
  --cyan:#D2D8BC;
  --blue:#155A42;
  --deep-blue:#161616;
  --navy-blue:#161616;
  --ink:#161616;
  --deep:#161616;
  --fern:#155A42;
  --mint:#D2D8BC;
  --sage:#EEF2E2;
  --linen:#F3F5EA;
  --paper:#FAFBF6;
  --clay:#155A42;
  --mist:#dde2cf;
  --surface:#F3F5EA;
  --surface-soft:#FAFBF6;
  --shadow:0 18px 50px rgba(22,22,22,.1);
  --shadow-soft:0 10px 28px rgba(22,22,22,.08);
}

body{
  color:var(--soil);
  background:var(--surface-soft);
}

nav{
  background:rgba(250,251,246,.94);
  border-bottom-color:rgba(22,22,22,.12);
}

.nav-logo-mark,
.nav-apply,
.btn-teal,
.ctab.active,
.c-fbtn.active{
  background:var(--soil);
  border-color:var(--soil);
}

.nav-apply:hover,
.btn-teal:hover{
  background:var(--forest);
  border-color:var(--forest);
}

.hero{
  background:
    radial-gradient(circle at 74% 30%,rgba(210,216,188,.72) 0 12%,transparent 13%),
    radial-gradient(circle at 84% 54%,rgba(21,90,66,.18) 0 11%,transparent 12%),
    linear-gradient(90deg,rgba(250,251,246,.99) 0%,rgba(250,251,246,.96) 45%,rgba(243,245,234,.78) 72%,rgba(250,251,246,.92) 100%);
}

.hero::before,
.hero::after{
  border-color:rgba(22,22,22,.12);
  background:
    linear-gradient(135deg,rgba(250,251,246,.88),rgba(238,242,226,.84)),
    radial-gradient(circle at 30% 28%,rgba(21,90,66,.16),transparent 22%),
    radial-gradient(circle at 70% 70%,rgba(210,216,188,.4),transparent 24%);
}

.hero h1,
.hero-glass-hd h3,
.nav-logo-text,
.nav-info,
.nav-links a,
.stat-num,
.benefits h2,
.split-content h2,
.testi-hd h2,
.blog-hd h2,
.blog-card h3,
.blog-feature-body h2,
.blog-post-content h2,
.blog-post-content h3,
.enquiry-form h3,
.dark-box h3,
.why-panel h3,
.cbox h3,
.res-panel h3,
.faq-section h2,
.inner-steps h2,
.check-item h4,
.cinfo-card h4,
.faq-q{
  color:var(--soil);
}

.hero h1 em,
.nav-logo-text em,
.nav-links a:hover,
.nav-links a.active,
.eyebrow,
.blog-cat,
.blog-all,
.blog-read,
.svc-arr,
.cf .cv{
  color:var(--forest);
}

.hero-pill,
.badge,
.calc-result,
.fbtn.active,
.ben-ico,
.ins-ico,
.cinfo-ico,
.check-ico,
.icon-card__icon{
  color:var(--soil);
  background:var(--olive);
  border-color:rgba(21,90,66,.18);
}

.hero-glass,
.stat-box,
.ben-card,
.blog-card,
.blog-feature-card,
.testi-card,
.team-card,
.why-card,
.check-item,
.cinfo-card,
.cbox,
.blog-post-article,
.blog-related-item,
.blog-empty,
.enquiry-form,
.icon-card,
.svc-row,
.calc-box,
.form-row input,
.form-row select,
.form-row textarea,
.cf select,
.cf input[type=number]{
  background:var(--surface-soft);
  border-color:rgba(21,90,66,.15);
}

.visual-panel,
.comm-panel,
.dark-box,
.res-panel,
.why-panel,
.calc-banner,
.ins-section,
.cta-band{
  background:var(--soil);
}

.visual-panel{
  background:
    linear-gradient(180deg,rgba(21,90,66,.08),rgba(22,22,22,.94)),
    radial-gradient(circle at 72% 22%,rgba(210,216,188,.24),transparent 32%),
    var(--soil);
}

.comm-panel{
  background:
    linear-gradient(160deg,rgba(21,90,66,.28),transparent 34%),
    var(--soil);
}

.inner-hero{
  background:
    linear-gradient(90deg,rgba(22,22,22,.96),rgba(21,90,66,.82)),
    radial-gradient(circle at 82% 38%,rgba(210,216,188,.18),transparent 24%),
    radial-gradient(circle at 68% 74%,rgba(21,90,66,.18),transparent 24%),
    var(--soil);
}

.ticker,
footer{
  background:var(--soil);
}

.blog-thumb,
.blog-feature-thumb,
.blog-post-hero-card{
  background:
    radial-gradient(circle at 30% 25%,rgba(210,216,188,.2),transparent 28%),
    linear-gradient(135deg,var(--soil),var(--forest))!important;
}

.tick-item,
.tick-item .text-icon,
.visual-caption strong,
.comm-stat-num,
.res-val,
.inner-hero h1 em,
.ins-more,
.footer-col li a:hover,
.social-btn:hover{
  color:var(--olive);
}

.split-content .lead,
.blog-card p,
.blog-feature-body p,
.check-item p,
.step-v p,
.why-card p,
.faq-a p,
.cbox .sub,
.cdisclaim,
.cinfo-card p,
.cinfo-card a,
.hero-desc,
.svc-link,
.stat-lbl{
  color:rgba(22,22,22,.68)!important;
}

.svc-row:hover,
a[style*="border:1px solid var(--border)"]:hover,
a[style*="background:#fff;border:1px solid var(--border)"]:hover,
a[style*="background:var(--cream);border:1px solid var(--border)"]:hover{
  background:var(--teal-pale)!important;
  border-color:var(--forest)!important;
  color:var(--soil)!important;
}

.ben-card:hover,
.testi-card:hover,
.team-card:hover,
.why-card:hover,
.blog-card:hover,
.blog-feature-card:hover,
.blog-related-item:hover,
.check-item:hover{
  border-color:var(--forest)!important;
  box-shadow:0 10px 28px rgba(22,22,22,.1)!important;
}

.calc-box input[type=range],
.cbox input[type=range]{
  accent-color:var(--forest)!important;
}

.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus,
.cf select:focus,
.cf input[type=number]:focus{
  border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(21,90,66,.14);
}

@media(max-width:1024px){
  .hero{
    background:linear-gradient(180deg,var(--surface-soft),var(--surface));
  }
}
/* Final client-approved palette - must remain last */
:root{
  --soil:#161616;
  --forest:#155A42;
  --olive:#D2D8BC;
  --navy:#161616;
  --navy2:#242424;
  --teal:#155A42;
  --teal2:#104632;
  --teal-lt:#D2D8BC;
  --teal-pale:#EEF2E2;
  --gold:#D2D8BC;
  --cream:#F3F5EA;
  --text:#161616;
  --muted:#5f675c;
  --border:#dde2cf;
  --aqua:#D2D8BC;
  --cyan:#155A42;
  --blue:#155A42;
  --deep-blue:#161616;
  --navy-blue:#161616;
  --ink:#161616;
  --deep:#161616;
  --fern:#155A42;
  --mint:#D2D8BC;
  --sage:#EEF2E2;
  --linen:#F3F5EA;
  --paper:#FAFBF6;
  --clay:#155A42;
  --mist:#dde2cf;
  --surface:#F3F5EA;
  --surface-soft:#FAFBF6;
}

html,
body,
main{
  background:var(--surface);
}

body{
  color:var(--soil);
}

nav{
  background:rgba(250,251,246,.94);
  border-bottom-color:rgba(22,22,22,.12);
}

.nav-logo-mark,
.nav-apply,
.btn-teal,
.ctab.active,
.c-fbtn.active{
  background:var(--soil);
  border-color:var(--soil);
}

.nav-apply:hover,
.btn-teal:hover{
  background:var(--forest);
  border-color:var(--forest);
}

.hero{
  background:
    radial-gradient(circle at 74% 30%,rgba(210,216,188,.72) 0 12%,transparent 13%),
    radial-gradient(circle at 84% 54%,rgba(21,90,66,.18) 0 11%,transparent 12%),
    linear-gradient(90deg,rgba(250,251,246,.99) 0%,rgba(250,251,246,.96) 45%,rgba(243,245,234,.78) 72%,rgba(250,251,246,.92) 100%);
}

.hero::before,
.hero::after{
  border-color:rgba(22,22,22,.12);
  background:
    linear-gradient(135deg,rgba(250,251,246,.88),rgba(238,242,226,.84)),
    radial-gradient(circle at 30% 28%,rgba(21,90,66,.16),transparent 22%),
    radial-gradient(circle at 70% 70%,rgba(210,216,188,.4),transparent 24%);
}

.hero h1,
.hero-glass-hd h3,
.nav-logo-text,
.nav-info,
.nav-links a,
.stat-num,
.benefits h2,
.split-content h2,
.testi-hd h2,
.blog-hd h2,
.blog-card h3,
.blog-feature-body h2,
.blog-post-content h2,
.blog-post-content h3,
.enquiry-form h3,
.dark-box h3,
.why-panel h3,
.cbox h3,
.res-panel h3,
.faq-section h2,
.inner-steps h2,
.check-item h4,
.cinfo-card h4,
.faq-q{
  color:var(--soil);
}

.hero h1 em,
.nav-logo-text em,
.nav-links a:hover,
.nav-links a.active,
.eyebrow,
.blog-cat,
.blog-all,
.blog-read,
.svc-arr,
.cf .cv{
  color:var(--forest);
}

.hero-pill,
.badge,
.calc-result,
.fbtn.active,
.ben-ico,
.ins-ico,
.cinfo-ico,
.check-ico,
.icon-card__icon{
  color:var(--soil);
  background:var(--olive);
  border-color:rgba(21,90,66,.18);
}

.hero-glass,
.stat-box,
.ben-card,
.blog-card,
.blog-feature-card,
.testi-card,
.team-card,
.why-card,
.check-item,
.cinfo-card,
.cbox,
.blog-post-article,
.blog-related-item,
.blog-empty,
.enquiry-form,
.icon-card,
.svc-row,
.calc-box,
.form-row input,
.form-row select,
.form-row textarea,
.cf select,
.cf input[type=number]{
  background:var(--surface-soft);
  border-color:rgba(21,90,66,.15);
}

.benefits,
.comm-section,
.inner-steps,
.blog-feature-band{
  background:var(--surface);
}

.mort-section,
.testi-section,
.how-section,
.faq-section,
.inner-content,
.blog-section{
  background:var(--surface-soft);
}

.visual-panel,
.comm-panel,
.dark-box,
.res-panel,
.why-panel,
.calc-banner,
.ins-section,
.cta-band{
  background:var(--soil);
}

.visual-panel{
  background:
    linear-gradient(180deg,rgba(21,90,66,.08),rgba(22,22,22,.94)),
    radial-gradient(circle at 72% 22%,rgba(210,216,188,.24),transparent 32%),
    var(--soil);
}

.comm-panel{
  background:
    linear-gradient(160deg,rgba(21,90,66,.28),transparent 34%),
    var(--soil);
}

.inner-hero{
  background:
    linear-gradient(90deg,rgba(22,22,22,.96),rgba(21,90,66,.82)),
    radial-gradient(circle at 82% 38%,rgba(210,216,188,.18),transparent 24%),
    radial-gradient(circle at 68% 74%,rgba(21,90,66,.18),transparent 24%),
    var(--soil);
}

.ticker,
footer{
  background:var(--soil);
}

.blog-thumb,
.blog-feature-thumb,
.blog-post-hero-card{
  background:
    radial-gradient(circle at 30% 25%,rgba(210,216,188,.2),transparent 28%),
    linear-gradient(135deg,var(--soil),var(--forest))!important;
}

.tick-item,
.tick-item .text-icon,
.visual-caption strong,
.comm-stat-num,
.res-val,
.inner-hero h1 em,
.ins-more,
.footer-col li a:hover,
.social-btn:hover{
  color:var(--olive);
}

.split-content .lead,
.blog-card p,
.blog-feature-body p,
.check-item p,
.step-v p,
.why-card p,
.faq-a p,
.cbox .sub,
.cdisclaim,
.cinfo-card p,
.cinfo-card a,
.hero-desc,
.svc-link,
.stat-lbl{
  color:rgba(22,22,22,.68)!important;
}

.svc-row:hover,
a[style*="border:1px solid var(--border)"]:hover,
a[style*="background:#fff;border:1px solid var(--border)"]:hover,
a[style*="background:var(--cream);border:1px solid var(--border)"]:hover{
  background:var(--teal-pale)!important;
  border-color:var(--forest)!important;
  color:var(--soil)!important;
}

.ben-card:hover,
.testi-card:hover,
.team-card:hover,
.why-card:hover,
.blog-card:hover,
.blog-feature-card:hover,
.blog-related-item:hover,
.check-item:hover{
  border-color:var(--forest)!important;
  box-shadow:0 10px 28px rgba(22,22,22,.1)!important;
}

span[style*="color:var(--teal)"],
a[style*="color:var(--teal)"],
div[style*="color:var(--teal)"]{
  color:var(--forest)!important;
}

.calc-box .cfield .cval,
.cbox .cf .cv,
.calc-result-num{
  color:var(--soil)!important;
}

.calc-box input[type=range],
.cbox input[type=range]{
  accent-color:var(--forest)!important;
}

.calc-box .fbtn.active,
.cbox .c-fbtn.active{
  background:var(--soil)!important;
  border-color:var(--soil)!important;
}

.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus,
.cf select:focus,
.cf input[type=number]:focus{
  border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(21,90,66,.14);
}

/* Mortgage help section spacing */
.mort-section{
  padding-top:7.5rem;
  padding-bottom:5.5rem;
  scroll-margin-top:88px;
}

.mort-section .split{
  align-items:start;
}

.mort-section .visual-panel{
  min-height:460px;
  padding:2.4rem;
}

.mort-section .split-content{
  padding-top:.1rem;
}

.mort-section .split-content .eyebrow{
  margin-bottom:.65rem;
}

.mort-section .split-content h2{
  margin-bottom:1rem;
}

.mort-section .svc-list{
  gap:.55rem;
}

.mort-section .svc-row{
  min-height:56px;
}

@media(max-width:1024px){
  .hero{
    background:linear-gradient(180deg,var(--surface-soft),var(--surface));
  }

  .mort-section{
    padding-top:4.5rem;
  }

  .mort-section .visual-panel{
    min-height:390px;
  }
}

/* Client palette previews */
body.palette-forest{
  --surface:#155A42;
  --surface-soft:#155A42;
  --paper:#D2D8BC;
  --cream:#D2D8BC;
  --teal-pale:#D2D8BC;
  --border:rgba(210,216,188,.42);
  --muted:rgba(210,216,188,.78);
}

body.palette-forest nav{
  background:rgba(22,22,22,.96);
  border-bottom-color:rgba(210,216,188,.18);
}

body.palette-forest .nav-logo-text,
body.palette-forest .nav-info,
body.palette-forest .nav-links a{
  color:var(--olive);
}

body.palette-forest .hero{
  background:
    radial-gradient(circle at 78% 24%,rgba(210,216,188,.28) 0 13%,transparent 14%),
    radial-gradient(circle at 86% 60%,rgba(22,22,22,.16) 0 10%,transparent 11%),
    linear-gradient(100deg,var(--forest) 0%,var(--forest) 56%,#104632 100%);
}

body.palette-forest .hero h1,
body.palette-forest .hero-desc,
body.palette-forest .hero-pill,
body.palette-forest .hero h1 em{
  color:var(--olive);
}

body.palette-forest .hero-pill,
body.palette-forest .badge{
  background:rgba(210,216,188,.18);
  border-color:rgba(210,216,188,.4);
}

body.palette-forest .hero-glass,
body.palette-forest .stat-box{
  background:rgba(210,216,188,.96);
  border-color:rgba(210,216,188,.55);
}

body.palette-forest .nav-logo-mark,
body.palette-forest .nav-apply,
body.palette-forest .btn-teal,
body.palette-forest .ctab.active,
body.palette-forest .c-fbtn.active{
  background:var(--soil);
  border-color:var(--soil);
  color:var(--olive);
}

body.palette-forest .btn-ghost,
body.palette-forest .btn-navy-ghost,
body.palette-forest .nav-info{
  background:rgba(210,216,188,.08);
  border-color:rgba(210,216,188,.4);
  color:var(--olive);
}

body.palette-forest .benefits,
body.palette-forest .mort-section,
body.palette-forest .comm-section,
body.palette-forest .testi-section,
body.palette-forest .team-section,
body.palette-forest .how-section,
body.palette-forest .blog-section,
body.palette-forest .blog-feature-band,
body.palette-forest .inner-content,
body.palette-forest .inner-steps,
body.palette-forest .faq-section{
  background:var(--forest);
}

body.palette-forest .benefits h2,
body.palette-forest .split-content h2,
body.palette-forest .testi-hd h2,
body.palette-forest .blog-hd h2,
body.palette-forest .inner-steps h2,
body.palette-forest .faq-section h2,
body.palette-forest .eyebrow{
  color:var(--olive);
}

body.palette-forest .split-content .lead,
body.palette-forest .blog-card p,
body.palette-forest .blog-feature-body p,
body.palette-forest .check-item p,
body.palette-forest .step-v p,
body.palette-forest .why-card p,
body.palette-forest .faq-a p,
body.palette-forest .cinfo-card p,
body.palette-forest .cinfo-card a{
  color:rgba(210,216,188,.82)!important;
}

body.palette-forest .hero-glass-hd h3,
body.palette-forest .stat-num,
body.palette-forest .ben-card h4,
body.palette-forest .blog-card h3,
body.palette-forest .blog-feature-body h2,
body.palette-forest .check-item h4,
body.palette-forest .cinfo-card h4,
body.palette-forest .faq-q,
body.palette-forest .svc-row{
  color:var(--soil);
}

body.palette-forest .hero-glass,
body.palette-forest .stat-box,
body.palette-forest .ben-card,
body.palette-forest .blog-card,
body.palette-forest .blog-feature-card,
body.palette-forest .testi-card,
body.palette-forest .team-card,
body.palette-forest .why-card,
body.palette-forest .check-item,
body.palette-forest .cinfo-card,
body.palette-forest .cbox,
body.palette-forest .blog-post-article,
body.palette-forest .blog-related-item,
body.palette-forest .blog-empty,
body.palette-forest .enquiry-form,
body.palette-forest .icon-card,
body.palette-forest .svc-row,
body.palette-forest .calc-box{
  background:var(--olive);
  border-color:rgba(22,22,22,.16);
}

body.palette-forest .benefits-grid{
  align-items:stretch;
}

body.palette-forest .ben-card{
  min-height:0;
  padding:1.45rem 1.15rem;
  text-align:left;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

body.palette-forest .ben-ico{
  color:var(--forest);
  background:rgba(21,90,66,.08);
  border-color:rgba(21,90,66,.2);
  margin-bottom:1rem;
}

body.palette-forest .ben-card h4{
  color:var(--soil);
  font-size:.9rem;
  line-height:1.35;
  margin-bottom:.65rem;
}

body.palette-forest .ben-card p{
  display:block;
  color:rgba(22,22,22,.78)!important;
  font-size:.8rem;
  line-height:1.55;
  font-weight:400;
  margin:0;
}

body.palette-forest .ticker,
body.palette-forest footer,
body.palette-forest .visual-panel,
body.palette-forest .comm-panel,
body.palette-forest .dark-box,
body.palette-forest .res-panel,
body.palette-forest .why-panel,
body.palette-forest .calc-banner,
body.palette-forest .ins-section,
body.palette-forest .cta-band{
  background:var(--soil);
}

body.palette-forest .visual-panel{
  background:
    linear-gradient(180deg,rgba(21,90,66,.12),rgba(22,22,22,.94)),
    radial-gradient(circle at 72% 22%,rgba(210,216,188,.24),transparent 32%),
    var(--soil);
}

body.palette-forest .visual-caption,
body.palette-forest .visual-caption strong,
body.palette-forest .comm-stat-num,
body.palette-forest .res-val,
body.palette-forest .footer-col li a:hover,
body.palette-forest .social-btn:hover{
  color:var(--olive);
}

body.palette-soil{
  --surface:#161616;
  --surface-soft:#161616;
  --paper:#D2D8BC;
  --cream:#D2D8BC;
  --teal-pale:#D2D8BC;
  --border:rgba(210,216,188,.28);
  --muted:rgba(210,216,188,.72);
  background:
    radial-gradient(circle at 18% 18%,rgba(21,90,66,.38),transparent 34%),
    radial-gradient(circle at 82% 30%,rgba(210,216,188,.12),transparent 26%),
    linear-gradient(135deg,#161616 0%,#1b211d 48%,#161616 100%);
}

body.palette-soil main{
  background:
    radial-gradient(circle at 12% 20%,rgba(21,90,66,.26),transparent 32%),
    radial-gradient(circle at 88% 46%,rgba(210,216,188,.1),transparent 30%),
    linear-gradient(135deg,#161616 0%,#1b211d 52%,#161616 100%);
}

body.palette-soil nav{
  background:rgba(22,22,22,.96);
  border-bottom-color:rgba(210,216,188,.18);
}

body.palette-soil .nav-logo-text,
body.palette-soil .nav-info,
body.palette-soil .nav-links a{
  color:var(--olive);
}

body.palette-soil .hero{
  background:
    radial-gradient(circle at 76% 26%,rgba(210,216,188,.22) 0 14%,transparent 15%),
    radial-gradient(circle at 86% 58%,rgba(21,90,66,.42) 0 12%,transparent 13%),
    linear-gradient(100deg,#161616 0%,#1b211d 46%,#155A42 100%);
}

body.palette-soil .hero h1,
body.palette-soil .hero-desc,
body.palette-soil .hero h1 em,
body.palette-soil .hero-pill{
  color:var(--olive);
}

body.palette-soil .hero-glass,
body.palette-soil .stat-box{
  background:rgba(210,216,188,.94);
  border-color:rgba(210,216,188,.34);
}

body.palette-soil .btn-ghost,
body.palette-soil .btn-navy-ghost,
body.palette-soil .nav-info{
  background:rgba(210,216,188,.08);
  border-color:rgba(210,216,188,.38);
  color:var(--olive);
}

body.palette-soil .nav-logo-mark,
body.palette-soil .nav-apply,
body.palette-soil .btn-teal,
body.palette-soil .ctab.active,
body.palette-soil .c-fbtn.active{
  background:var(--forest);
  border-color:var(--forest);
  color:var(--olive);
}

body.palette-soil .nav-apply:hover,
body.palette-soil .btn-teal:hover{
  background:var(--olive);
  border-color:var(--olive);
  color:var(--soil);
}

body.palette-soil .hero-pill,
body.palette-soil .badge,
body.palette-soil .calc-result,
body.palette-soil .fbtn.active,
body.palette-soil .ben-ico,
body.palette-soil .ins-ico,
body.palette-soil .cinfo-ico,
body.palette-soil .check-ico,
body.palette-soil .icon-card__icon{
  background:var(--forest);
  color:var(--olive);
  border-color:rgba(210,216,188,.18);
}

body.palette-soil .benefits,
body.palette-soil .mort-section,
body.palette-soil .comm-section,
body.palette-soil .testi-section,
body.palette-soil .team-section,
body.palette-soil .ins-section,
body.palette-soil .how-section,
body.palette-soil .blog-section,
body.palette-soil .blog-feature-band,
body.palette-soil .inner-content,
body.palette-soil .inner-steps,
body.palette-soil .faq-section,
body.palette-soil .calc-banner,
body.palette-soil .cta-band,
body.palette-soil footer{
  background:
    radial-gradient(circle at 16% 16%,rgba(21,90,66,.24),transparent 30%),
    radial-gradient(circle at 86% 58%,rgba(210,216,188,.08),transparent 28%),
    linear-gradient(135deg,#161616 0%,#1b211d 55%,#161616 100%);
}

body.palette-soil .benefits h2,
body.palette-soil .split-content h2,
body.palette-soil .testi-hd h2,
body.palette-soil .blog-hd h2,
body.palette-soil .inner-steps h2,
body.palette-soil .faq-section h2,
body.palette-soil .eyebrow{
  color:var(--olive);
}

body.palette-soil .hero-glass-hd h3,
body.palette-soil .stat-num,
body.palette-soil .ben-card h4,
body.palette-soil .blog-card h3,
body.palette-soil .blog-feature-body h2,
body.palette-soil .check-item h4,
body.palette-soil .cinfo-card h4,
body.palette-soil .faq-q,
body.palette-soil .svc-row{
  color:var(--soil);
}

body.palette-soil .split-content .lead,
body.palette-soil .blog-card p,
body.palette-soil .blog-feature-body p,
body.palette-soil .check-item p,
body.palette-soil .step-v p,
body.palette-soil .why-card p,
body.palette-soil .faq-a p,
body.palette-soil .cinfo-card p,
body.palette-soil .cinfo-card a{
  color:rgba(210,216,188,.78)!important;
}

body.palette-soil .hero-glass,
body.palette-soil .stat-box,
body.palette-soil .ben-card,
body.palette-soil .blog-card,
body.palette-soil .blog-feature-card,
body.palette-soil .testi-card,
body.palette-soil .team-card,
body.palette-soil .why-card,
body.palette-soil .check-item,
body.palette-soil .cinfo-card,
body.palette-soil .cbox,
body.palette-soil .blog-post-article,
body.palette-soil .blog-related-item,
body.palette-soil .blog-empty,
body.palette-soil .enquiry-form,
body.palette-soil .icon-card,
body.palette-soil .svc-row,
body.palette-soil .calc-box{
  background:var(--olive);
  border-color:rgba(210,216,188,.22);
}

body.palette-soil .ben-card{
  text-align:left;
}

body.palette-soil .ben-card p{
  color:rgba(22,22,22,.74)!important;
  font-weight:400;
}

body.palette-soil .ticker,
body.palette-soil footer,
body.palette-soil .visual-panel,
body.palette-soil .comm-panel,
body.palette-soil .dark-box,
body.palette-soil .res-panel,
body.palette-soil .why-panel,
body.palette-soil .calc-banner,
body.palette-soil .ins-section,
body.palette-soil .cta-band{
  background:
    radial-gradient(circle at 20% 18%,rgba(21,90,66,.26),transparent 30%),
    linear-gradient(135deg,#161616 0%,#1b211d 58%,#161616 100%);
}

body.palette-soil .visual-panel{
  background:
    linear-gradient(180deg,rgba(21,90,66,.14),rgba(22,22,22,.94)),
    radial-gradient(circle at 72% 22%,rgba(210,216,188,.18),transparent 32%),
    var(--soil);
}

body.palette-soil .visual-caption,
body.palette-soil .visual-caption strong,
body.palette-soil .comm-stat-num,
body.palette-soil .res-val,
body.palette-soil .footer-col li a:hover,
body.palette-soil .social-btn:hover{
  color:var(--olive);
}

body.palette-olive{
  --surface:#D2D8BC;
  --surface-soft:#D2D8BC;
  --paper:#D2D8BC;
  --cream:#D2D8BC;
  --teal-pale:#E7EBD8;
  --border:rgba(22,22,22,.22);
  --muted:#4e5548;
}

body.palette-olive nav{
  background:rgba(210,216,188,.95);
  border-bottom-color:rgba(22,22,22,.14);
}

body.palette-olive .nav-logo-text,
body.palette-olive .nav-info,
body.palette-olive .nav-links a{
  color:var(--soil);
}

body.palette-olive .hero{
  background:
    radial-gradient(circle at 76% 28%,rgba(21,90,66,.16) 0 12%,transparent 13%),
    radial-gradient(circle at 86% 58%,rgba(22,22,22,.12) 0 11%,transparent 12%),
    linear-gradient(100deg,var(--olive) 0%,var(--olive) 62%,#e2e6d0 100%);
}

body.palette-olive .nav-logo-mark,
body.palette-olive .nav-apply,
body.palette-olive .btn-teal,
body.palette-olive .ctab.active,
body.palette-olive .c-fbtn.active{
  background:var(--forest);
  border-color:var(--forest);
  color:var(--olive);
}

body.palette-olive .btn-ghost,
body.palette-olive .btn-navy-ghost,
body.palette-olive .nav-info{
  background:rgba(22,22,22,.04);
  border-color:rgba(22,22,22,.2);
  color:var(--soil);
}

body.palette-olive .hero h1,
body.palette-olive .hero-glass-hd h3,
body.palette-olive .nav-logo-text,
body.palette-olive .nav-info,
body.palette-olive .nav-links a,
body.palette-olive .stat-num,
body.palette-olive .benefits h2,
body.palette-olive .split-content h2,
body.palette-olive .testi-hd h2,
body.palette-olive .blog-hd h2,
body.palette-olive .blog-card h3,
body.palette-olive .blog-feature-body h2,
body.palette-olive .check-item h4,
body.palette-olive .cinfo-card h4,
body.palette-olive .faq-q{
  color:var(--soil);
}

body.palette-olive .hero h1 em,
body.palette-olive .nav-logo-text em,
body.palette-olive .nav-links a:hover,
body.palette-olive .nav-links a.active,
body.palette-olive .eyebrow,
body.palette-olive .blog-cat,
body.palette-olive .blog-all,
body.palette-olive .blog-read,
body.palette-olive .svc-arr,
body.palette-olive .cf .cv{
  color:var(--forest);
}

body.palette-olive .hero-desc,
body.palette-olive .split-content .lead,
body.palette-olive .blog-card p,
body.palette-olive .blog-feature-body p,
body.palette-olive .check-item p,
body.palette-olive .step-v p,
body.palette-olive .why-card p,
body.palette-olive .faq-a p,
body.palette-olive .cinfo-card p,
body.palette-olive .cinfo-card a{
  color:rgba(22,22,22,.72)!important;
}

body.palette-olive .hero-pill,
body.palette-olive .badge,
body.palette-olive .calc-result,
body.palette-olive .fbtn.active,
body.palette-olive .ben-ico,
body.palette-olive .ins-ico,
body.palette-olive .cinfo-ico,
body.palette-olive .check-ico,
body.palette-olive .icon-card__icon{
  background:var(--soil);
  color:var(--olive);
  border-color:rgba(22,22,22,.16);
}

body.palette-olive .benefits,
body.palette-olive .mort-section,
body.palette-olive .comm-section,
body.palette-olive .testi-section,
body.palette-olive .team-section,
body.palette-olive .how-section,
body.palette-olive .blog-section,
body.palette-olive .blog-feature-band,
body.palette-olive .inner-content,
body.palette-olive .inner-steps,
body.palette-olive .faq-section{
  background:var(--olive);
}

body.palette-olive .hero-glass,
body.palette-olive .stat-box,
body.palette-olive .ben-card,
body.palette-olive .blog-card,
body.palette-olive .blog-feature-card,
body.palette-olive .testi-card,
body.palette-olive .team-card,
body.palette-olive .why-card,
body.palette-olive .check-item,
body.palette-olive .cinfo-card,
body.palette-olive .cbox,
body.palette-olive .blog-post-article,
body.palette-olive .blog-related-item,
body.palette-olive .blog-empty,
body.palette-olive .enquiry-form,
body.palette-olive .icon-card,
body.palette-olive .svc-row,
body.palette-olive .calc-box{
  background:rgba(250,251,246,.55);
  border-color:rgba(22,22,22,.16);
}

body.palette-olive .ben-card{
  text-align:left;
}

body.palette-olive .ben-card p{
  color:rgba(22,22,22,.72)!important;
  font-weight:400;
}

body.palette-olive .visual-panel,
body.palette-olive .comm-panel,
body.palette-olive .dark-box,
body.palette-olive .res-panel,
body.palette-olive .why-panel,
body.palette-olive .calc-banner,
body.palette-olive .ins-section,
body.palette-olive .cta-band{
  background:var(--forest);
}

body.palette-olive .ticker,
body.palette-olive footer{
  background:var(--soil);
}

body.palette-olive .visual-panel{
  background:
    linear-gradient(180deg,rgba(21,90,66,.08),rgba(21,90,66,.94)),
    radial-gradient(circle at 72% 22%,rgba(210,216,188,.22),transparent 32%),
    var(--forest);
}

body.palette-olive .visual-caption,
body.palette-olive .visual-caption strong,
body.palette-olive .comm-stat-num,
body.palette-olive .res-val,
body.palette-olive .footer-col li a:hover,
body.palette-olive .social-btn:hover{
  color:var(--olive);
}

/* Soil option readability pass */
body.palette-soil{
  color:var(--olive);
}

body.palette-soil .hero h1,
body.palette-soil .hero h1 em,
body.palette-soil .hero-desc,
body.palette-soil .hero-pill,
body.palette-soil .benefits h2,
body.palette-soil .split-content h2,
body.palette-soil .testi-hd h2,
body.palette-soil .blog-hd h2,
body.palette-soil .ins-header h2,
body.palette-soil .calc-left h2,
body.palette-soil .inner-steps h2,
body.palette-soil .faq-section h2,
body.palette-soil .cta-band h2,
body.palette-soil .eyebrow{
  color:var(--olive)!important;
}

body.palette-soil .hero-desc,
body.palette-soil .split-content .lead,
body.palette-soil .calc-left p,
body.palette-soil .ins-header .sub,
body.palette-soil .cta-band p,
body.palette-soil .inner-hero-desc,
body.palette-soil .breadcrumb a,
body.palette-soil .breadcrumb span{
  color:rgba(210,216,188,.88)!important;
}

body.palette-soil .hero-glass,
body.palette-soil .stat-box,
body.palette-soil .ben-card,
body.palette-soil .blog-card,
body.palette-soil .blog-feature-card,
body.palette-soil .testi-card,
body.palette-soil .team-card,
body.palette-soil .why-card,
body.palette-soil .check-item,
body.palette-soil .cinfo-card,
body.palette-soil .cbox,
body.palette-soil .blog-post-article,
body.palette-soil .blog-related-item,
body.palette-soil .blog-empty,
body.palette-soil .enquiry-form,
body.palette-soil .icon-card,
body.palette-soil .svc-row,
body.palette-soil .calc-box,
body.palette-soil .form-row input,
body.palette-soil .form-row select,
body.palette-soil .form-row textarea,
body.palette-soil .cf select,
body.palette-soil .cf input[type=number]{
  background:var(--olive)!important;
  color:var(--soil)!important;
  border-color:rgba(210,216,188,.28)!important;
}

body.palette-soil .hero-glass h3,
body.palette-soil .stat-num,
body.palette-soil .ben-card h4,
body.palette-soil .blog-card h3,
body.palette-soil .blog-feature-body h2,
body.palette-soil .blog-post-content h2,
body.palette-soil .blog-post-content h3,
body.palette-soil .team-card h4,
body.palette-soil .why-card h4,
body.palette-soil .check-item h4,
body.palette-soil .cinfo-card h4,
body.palette-soil .cbox h3,
body.palette-soil .enquiry-form h3,
body.palette-soil .faq-q,
body.palette-soil .svc-row,
body.palette-soil .blog-related-item strong{
  color:var(--soil)!important;
}

body.palette-soil .hero-glass p,
body.palette-soil .stat-lbl,
body.palette-soil .ben-card p,
body.palette-soil .blog-card p,
body.palette-soil .blog-feature-body p,
body.palette-soil .blog-post-content p,
body.palette-soil .blog-post-content li,
body.palette-soil .blog-meta-row,
body.palette-soil .testi-q,
body.palette-soil .testi-role,
body.palette-soil .team-card .role,
body.palette-soil .team-card .contact a,
body.palette-soil .why-card p,
body.palette-soil .check-item p,
body.palette-soil .step-v p,
body.palette-soil .faq-a p,
body.palette-soil .cdisclaim,
body.palette-soil .cbox .sub,
body.palette-soil .cinfo-card p,
body.palette-soil .cinfo-card a,
body.palette-soil .form-row label,
body.palette-soil .cf label,
body.palette-soil .blog-related-item span{
  color:rgba(22,22,22,.76)!important;
}

body.palette-soil .blog-cat,
body.palette-soil .blog-all,
body.palette-soil .blog-read,
body.palette-soil .svc-arr,
body.palette-soil .cf .cv,
body.palette-soil .team-card .role{
  color:var(--forest)!important;
}

body.palette-soil .visual-panel,
body.palette-soil .comm-panel,
body.palette-soil .dark-box,
body.palette-soil .res-panel,
body.palette-soil .why-panel,
body.palette-soil .calc-banner,
body.palette-soil .ins-section,
body.palette-soil .cta-band,
body.palette-soil footer{
  color:var(--olive)!important;
}

body.palette-soil .visual-panel h3,
body.palette-soil .visual-caption,
body.palette-soil .visual-caption strong,
body.palette-soil .comm-panel h3,
body.palette-soil .dark-box h3,
body.palette-soil .res-panel h3,
body.palette-soil .calc-left h2,
body.palette-soil .ins-header h2,
body.palette-soil .cta-band h2,
body.palette-soil .footer-col h5{
  color:var(--olive)!important;
}

body.palette-soil .visual-panel p,
body.palette-soil .comm-panel p,
body.palette-soil .comm-stat-lbl,
body.palette-soil .dark-box p,
body.palette-soil .dark-box li,
body.palette-soil .res-lbl,
body.palette-soil .calc-left p,
body.palette-soil .cfield label,
body.palette-soil .ins-header .sub,
body.palette-soil .ins-card p,
body.palette-soil .cta-band p,
body.palette-soil .footer-brand p,
body.palette-soil .footer-col li a,
body.palette-soil .footer-bottom p{
  color:rgba(210,216,188,.78)!important;
}

body.palette-soil .v-box,
body.palette-soil .comm-stat,
body.palette-soil .ins-card{
  background:rgba(210,216,188,.08)!important;
  border-color:rgba(210,216,188,.18)!important;
}

body.palette-soil .v-box p,
body.palette-soil .ins-card h4{
  color:var(--olive)!important;
}

body.palette-soil .fi,
body.palette-soil .fi svg{
  color:inherit!important;
  stroke:currentColor!important;
}

body.palette-soil .nav-logo-mark,
body.palette-soil .nav-logo-mark .fi,
body.palette-soil .nav-logo-mark svg,
body.palette-soil .nav-apply,
body.palette-soil .btn-teal{
  color:var(--olive)!important;
}

body.palette-soil .ben-ico,
body.palette-soil .ben-ico.fi,
body.palette-soil .cinfo-ico,
body.palette-soil .cinfo-ico.fi,
body.palette-soil .check-ico,
body.palette-soil .check-ico.fi,
body.palette-soil .icon-card__icon{
  background:rgba(21,90,66,.12)!important;
  border-color:rgba(21,90,66,.24)!important;
  color:var(--forest)!important;
}

body.palette-soil .svc-row .sico,
body.palette-soil .svc-row .sico.fi,
body.palette-soil .svc-row .text-icon,
body.palette-soil .blog-read .fi,
body.palette-soil .blog-all .fi{
  color:var(--forest)!important;
}

body.palette-soil .tick-item .fi,
body.palette-soil .tick-item .text-icon,
body.palette-soil .visual-panel .fi,
body.palette-soil .visual-panel .text-icon,
body.palette-soil .comm-panel .fi,
body.palette-soil .dark-box .fi,
body.palette-soil .ins-card .fi,
body.palette-soil .ins-card .text-icon,
body.palette-soil footer .fi{
  color:var(--olive)!important;
}

body.palette-soil .v-box{
  color:var(--olive)!important;
}
