/* TaxTune — premium platform design system v2 */
:root{
  --ink:#04070e; --ink-1:#070c17; --ink-2:#0b1322; --panel:#0e1828; --panel-2:#13203440;
  --blue:#3f74f7; --blue-2:#7aa0ff; --mint:#2ee0b0; --emerald:#13bd94; --violet:#8a7bf0; --gold:#f3cd86;
  --white:#fff; --paper:#f5f8fd; --paper-2:#f0f5fb; --mist:#eef3fb; --line:#e6ecf5; --line-2:#f0f4fa;
  --line-d:rgba(255,255,255,.1); --line-d2:rgba(255,255,255,.06);
  --text:#0a1120; --muted:#54627d; --soft:#8493ab; --ondark:#c6d4ec; --ondark-2:#90a2c2;
  --display:'Sora',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --grad:linear-gradient(118deg,var(--blue),var(--mint));
  --grad-3:linear-gradient(120deg,#3f74f7,#8a7bf0 50%,#2ee0b0);
  --soft-card:linear-gradient(150deg,#eff4ff,#e9fbf4);
  --glass:linear-gradient(160deg,rgba(255,255,255,.14),rgba(255,255,255,.035));
  --shadow:0 50px 110px -45px rgba(4,9,22,.6); --shadow-s:0 22px 50px -26px rgba(4,9,22,.45);
  --shadow-xs:0 8px 22px -12px rgba(4,9,22,.28);
  --glow:0 0 0 1px rgba(63,116,247,.4),0 18px 40px -16px rgba(63,116,247,.55);
  --r:26px; --r-2:18px; --r-3:13px; --nav-h:78px; --maxw:1220px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:96px;-webkit-text-size-adjust:100%}
body{font-family:var(--body);color:var(--text);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-.035em;line-height:1.04}
h1{font-size:clamp(3rem,6.4vw,5.6rem);font-weight:800;letter-spacing:-.045em}
h2{font-size:clamp(2.1rem,4.2vw,3.4rem);letter-spacing:-.04em}
h3{font-size:1.22rem}
p{margin:0 0 1rem}a{text-decoration:none;color:inherit}img,svg{display:block;max-width:100%}
.wrap{width:min(var(--maxw),92%);margin-inline:auto}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blue)}
.eyebrow:before{content:"";width:22px;height:1.5px;background:currentColor;opacity:.5}
.muted{color:var(--muted)}.lead{font-size:1.18rem;color:var(--muted);max-width:58ch;line-height:1.6}
.center{text-align:center}.mx{margin-inline:auto}
section{padding:clamp(4rem,7vw,7rem) 0;position:relative}
.sec-head{max-width:60ch;margin-bottom:3rem}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:6px}
.skip{position:absolute;left:-999px}.skip:focus{left:1rem;top:1rem;z-index:300;background:#fff;padding:.6rem 1rem;border-radius:8px}

/* buttons */
.btn{position:relative;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:600;font-size:.95rem;padding:.92rem 1.5rem;border-radius:14px;border:1px solid transparent;cursor:pointer;transition:transform .35s cubic-bezier(.2,.85,.25,1),box-shadow .35s,background .35s,border-color .35s;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(63,116,247,.5),0 26px 50px -18px rgba(63,116,247,.7)}
.btn-light{background:rgba(255,255,255,.07);color:#fff;border-color:rgba(255,255,255,.2);backdrop-filter:blur(8px)}
.btn-light:hover{background:rgba(255,255,255,.16);transform:translateY(-2px);border-color:rgba(255,255,255,.34)}
.btn-ink{background:var(--ink);color:#fff}.btn-ink:hover{transform:translateY(-2px);box-shadow:var(--shadow-s)}
.btn-ghost{background:#fff;color:var(--text);border:1px solid var(--line)}.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-xs)}
.btn-soft{background:var(--mist);color:var(--text)}.btn-soft:hover{transform:translateY(-2px)}
.btn-sm{padding:.58rem 1.05rem;font-size:.88rem;border-radius:11px}
.btn-lg{padding:1.05rem 1.8rem;font-size:1rem}

/* logo */
.logo{height:32px;width:auto}
.logo .bar{transform-origin:bottom;animation:eq 2.8s ease-in-out infinite}
.logo .bar:nth-child(2){animation-delay:.16s}.logo .bar:nth-child(3){animation-delay:.32s}.logo .bar:nth-child(4){animation-delay:.48s}
@keyframes eq{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.56)}}
.logo .wm{font-family:var(--display);font-size:26px;font-weight:800;letter-spacing:-1.2px}

/* ===== NAV ===== */
header.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;transition:.45s cubic-bezier(.2,.8,.2,1)}
header.nav:before{content:"";position:absolute;inset:0;background:rgba(8,13,24,0);backdrop-filter:saturate(160%) blur(0px);border-bottom:1px solid transparent;transition:.45s}
header.nav.scrolled:before{background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(22px);border-bottom:1px solid var(--line);box-shadow:0 14px 40px -28px rgba(4,9,22,.5)}
header.nav.light:before,header.nav.scrolled.light:before{background:rgba(255,255,255,.82)}
.nav-in{position:relative;z-index:2;width:min(var(--maxw),94%);margin-inline:auto;display:flex;align-items:center;gap:2rem}
.brand{display:flex;align-items:center;color:var(--text)}
header.nav:not(.scrolled) .brand{color:#fff}
header.nav:not(.scrolled) .logo .wm{fill:#fff}
.nav-links{display:flex;align-items:center;gap:.35rem;margin-left:.4rem}
.nav-links>a,.nav-item>button{font-family:var(--body);font-weight:500;font-size:.95rem;color:var(--text);opacity:.82;background:none;border:0;cursor:pointer;padding:.6rem .85rem;border-radius:11px;display:inline-flex;align-items:center;gap:.35rem;transition:.25s}
header.nav:not(.scrolled) .nav-links>a,header.nav:not(.scrolled) .nav-item>button{color:#eaf1ff;opacity:.85}
.nav-links>a:hover,.nav-item>button:hover{opacity:1;background:rgba(120,150,230,.12)}
.nav-item{position:relative}
.nav-item>button svg{width:13px;height:13px;transition:transform .3s;opacity:.6}
.nav-item:hover>button svg{transform:rotate(180deg)}
.mega{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(10px);width:640px;background:rgba(255,255,255,.96);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:.7rem;opacity:0;visibility:hidden;transition:.3s cubic-bezier(.2,.8,.2,1);display:grid;grid-template-columns:1.4fr 1fr;gap:.6rem}
.nav-item:hover .mega,.nav-item:focus-within .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega-list{display:grid;grid-template-columns:1fr 1fr;gap:.15rem}
.mega-list a{display:flex;gap:.7rem;align-items:flex-start;padding:.7rem .75rem;border-radius:13px;transition:.22s}
.mega-list a:hover{background:var(--paper)}
.mega .di{width:36px;height:36px;border-radius:10px;background:var(--soft-card);display:grid;place-items:center;flex:0 0 36px}
.mega .di svg{width:18px;height:18px;color:var(--blue)}
.mega .dt{font-weight:600;font-size:.9rem;color:var(--text);display:block}
.mega .dd{font-size:.76rem;color:var(--muted);line-height:1.3}
.mega-feat{background:var(--ink-2);border-radius:16px;padding:1.1rem;color:#fff;display:flex;flex-direction:column;justify-content:space-between;background-image:radial-gradient(120% 80% at 100% 0%,rgba(46,224,176,.25),transparent 60%)}
.mega-feat h4{color:#fff;font-size:1.05rem;margin-bottom:.3rem}.mega-feat p{font-size:.82rem;color:var(--ondark);margin:0 0 .9rem}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:.6rem}
header.nav:not(.scrolled) .nav-cta .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.22)}
.burger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:13px;background:#fff;cursor:pointer}
header.nav:not(.scrolled) .burger{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25)}
.burger i{display:block;width:18px;height:2px;background:var(--text);margin:4px auto;border-radius:2px}
header.nav:not(.scrolled) .burger i{background:#fff}
.m-panel{position:fixed;inset:0;z-index:130;background:rgba(4,8,16,.55);backdrop-filter:blur(5px);opacity:0;visibility:hidden;transition:.32s}
.m-panel.open{opacity:1;visibility:visible}
.m-sheet{position:absolute;top:0;right:0;bottom:0;width:min(380px,88vw);background:#fff;padding:1.5rem 1.3rem;display:flex;flex-direction:column;gap:.1rem;transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.85,.25,1);overflow:auto}
.m-panel.open .m-sheet{transform:none}
.m-sheet .mh{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);margin:1rem 0 .3rem}
.m-sheet a{padding:.8rem .5rem;border-radius:10px;font-weight:500;color:#2a3650}
.m-sheet a:hover{background:var(--mist)}
.m-sheet .m-cta{margin-top:1.2rem;display:grid;gap:.6rem}

/* reveal — only hidden when JS is active, so content is never lost if JS fails */
.rv{opacity:1;transform:none}
html.js .rv{opacity:0;transform:translateY(26px) scale(.992);transition:opacity .75s ease,transform .75s cubic-bezier(.2,.85,.25,1)}
html.js .rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.07s}.rv.d2{transition-delay:.14s}.rv.d3{transition-delay:.21s}.rv.d4{transition-delay:.28s}.rv.d5{transition-delay:.35s}

/* ===== HERO ===== */
.hero{position:relative;background:var(--ink);color:#eaf1ff;overflow:hidden;padding:calc(var(--nav-h) + clamp(3rem,6vw,5rem)) 0 clamp(4rem,8vw,7rem)}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg .mesh{position:absolute;inset:-35%;background:
  radial-gradient(38% 46% at 22% 26%,rgba(63,116,247,.6),transparent 60%),
  radial-gradient(34% 42% at 82% 22%,rgba(46,224,176,.5),transparent 60%),
  radial-gradient(40% 48% at 64% 84%,rgba(138,123,240,.42),transparent 62%);
  filter:blur(24px);animation:drift 30s ease-in-out infinite}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-2.5%,2%) scale(1.05)}}
.hero-bg .grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(130% 96% at 50% 0%,#000 38%,transparent 78%)}
.hero-bg .noise{position:absolute;inset:0;opacity:.035;background-image:radial-gradient(#fff 1px,transparent 1.3px);background-size:3px 3px}
.hero-bg .glow{position:absolute;inset:0;background:radial-gradient(520px circle at var(--mx,72%) var(--my,30%),rgba(122,160,255,.2),transparent 62%);transition:background .3s}
.hero-in{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:3.6rem;align-items:center}
.hero .eyebrow{color:var(--mint)}.hero .eyebrow:before{background:var(--mint)}
.hero h1{color:#fff;margin:1.1rem 0 1.3rem}
.hero h1 .g{background:linear-gradient(96deg,#cfe0ff,#7df0cf 60%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero .lead{color:#bccbe8;font-size:1.2rem;max-width:42ch}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.9rem 0 1rem}
.reassure{display:flex;align-items:center;gap:.55rem;font-size:.86rem;color:var(--ondark-2)}
.reassure svg{width:15px;height:15px;color:var(--mint)}
.reassure b{color:#dbe6fb;font-weight:600}

/* hero product (window chrome) */
.hero-visual{position:relative;perspective:1600px}
.workspace{transform:rotateY(-9deg) rotateX(3deg);transform-style:preserve-3d;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.hero-visual:hover .workspace{transform:rotateY(-4deg) rotateX(1deg)}
.win{background:var(--glass);border:1px solid rgba(255,255,255,.16);border-radius:20px;backdrop-filter:blur(22px);box-shadow:var(--shadow);overflow:hidden}
.win-bar{display:flex;align-items:center;gap:.5rem;padding:.7rem .9rem;border-bottom:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.win-bar .dots{display:flex;gap:.35rem}.win-bar .dots i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.22);display:block}
.win-bar .ttl{font-size:.8rem;color:#cdd9f0;font-weight:600;margin-left:.4rem}
.win-bar .acc{margin-left:auto;width:24px;height:24px;border-radius:7px;background:var(--grad)}
.win-body{padding:1.15rem}
.tabs{display:flex;gap:.3rem;background:rgba(255,255,255,.05);border-radius:11px;padding:.25rem;margin-bottom:1rem;font-size:.8rem}
.tabs span{flex:1;text-align:center;padding:.42rem;border-radius:8px;color:#a8bbdb;font-weight:600;transition:.2s}
.tabs span.on{background:rgba(255,255,255,.12);color:#fff}
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.9rem}
.tile{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:13px;padding:.75rem .85rem}
.tile .l{font-size:.7rem;color:#9fb2d6}.tile .v{font-family:var(--display);font-weight:700;font-size:1.32rem;color:#fff;margin-top:.1rem}
.tile .v.mint{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.wrow{display:flex;align-items:center;gap:.6rem;padding:.55rem 0;border-top:1px solid rgba(255,255,255,.07);font-size:.86rem;color:#d3deef}
.wrow:first-of-type{border-top:0}
.wrow .ic{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.07);display:grid;place-items:center}.wrow .ic svg{width:15px;height:15px;color:var(--mint)}
.wrow .r{margin-left:auto}
.pill{font-size:.7rem;font-weight:600;padding:.22rem .58rem;border-radius:999px;background:rgba(46,224,176,.15);color:#86f0d2;border:1px solid rgba(46,224,176,.28)}
.pill.amber{background:rgba(243,205,134,.15);color:#f6d79e;border-color:rgba(243,205,134,.28)}
.pill.blue{background:rgba(122,160,255,.16);color:#bcd0ff;border-color:rgba(122,160,255,.3)}
.pill.grey{background:rgba(255,255,255,.08);color:#b9c6e0;border-color:rgba(255,255,255,.12)}
/* progress ring */
.ring{position:relative;width:60px;height:60px;flex:0 0 60px}
.ring svg{transform:rotate(-90deg)}.ring .bg{stroke:rgba(255,255,255,.1)}.ring .fg{stroke:url(#rg);stroke-linecap:round}
.ring .t{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:.85rem;color:#fff}
.float-card{position:absolute;background:rgba(12,20,34,.86);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:.7rem .85rem;box-shadow:var(--shadow);backdrop-filter:blur(10px);display:flex;align-items:center;gap:.6rem;animation:bob 7s ease-in-out infinite}
.float-card svg{width:18px;height:18px;color:var(--mint)}.float-card .x{font-size:.78rem;color:#dbe6fb;font-weight:600}.float-card .y{font-size:.7rem;color:#92a4c4}
.float-card.a{right:-26px;top:16%;animation-delay:-2s}.float-card.b{left:-30px;bottom:12%}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* trust strip */
.proof{background:var(--ink-1);border-top:1px solid var(--line-d2);color:var(--ondark-2)}
.proof-in{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 2.6rem;padding:1.2rem 0;font-size:.83rem;font-weight:600}
.proof-in span{display:inline-flex;align-items:center;gap:.5rem}.proof-in b{color:#e4ecf9}.proof-in svg{width:16px;height:16px;color:var(--mint)}

/* selector */
.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.5rem}
.chip-btn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.62rem 1.1rem;font-weight:600;font-size:.9rem;cursor:pointer;color:#37445e;transition:.22s}
.chip-btn:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-xs)}
.chip-btn[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.sel-panel{display:grid;grid-template-columns:62px 1fr auto;gap:1.3rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1.7rem;box-shadow:var(--shadow-xs)}
.sel-panel .pic{width:62px;height:62px;border-radius:16px;background:var(--soft-card);display:grid;place-items:center}.sel-panel .pic svg{width:28px;height:28px;color:var(--blue)}
.sel-panel h3{font-size:1.3rem;margin-bottom:.15rem}.sel-panel p{margin:0;color:var(--muted)}
@media(max-width:720px){.sel-panel{grid-template-columns:1fr;text-align:left}}

/* cards */
.grid{display:grid;gap:1.1rem}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.6rem;transition:transform .35s cubic-bezier(.2,.85,.25,1),box-shadow .35s,border-color .35s;position:relative;overflow:hidden;display:block;color:var(--text)}
.card:before{content:"";position:absolute;inset:0;background:radial-gradient(300px circle at var(--cx,50%) var(--cy,0),rgba(63,116,247,.07),transparent 55%);opacity:0;transition:.3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#d0ddf4}.card:hover:before{opacity:1}
.card .ic{width:50px;height:50px;border-radius:14px;background:var(--soft-card);display:grid;place-items:center;margin-bottom:1.1rem}.card .ic svg{width:24px;height:24px;color:var(--blue)}
.card h3{margin-bottom:.4rem}.card p{font-size:.92rem;color:var(--muted);margin:0}
.card .go{display:inline-flex;align-items:center;gap:.3rem;margin-top:1rem;font-weight:600;font-size:.86rem;color:var(--blue)}.card .go svg{width:15px;height:15px;transition:.25s}.card:hover .go svg{transform:translateX(4px)}

/* split feature */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:3.2rem;align-items:center}
.feature.rev .ftext{order:2}
@media(max-width:880px){.feature{grid-template-columns:1fr;gap:2.2rem}.feature.rev .ftext{order:0}}
.flist{list-style:none;display:grid;gap:.65rem;margin-top:1.3rem}
.flist li{display:flex;gap:.65rem;align-items:flex-start;font-size:.97rem;color:#35435e}
.flist svg{width:20px;height:20px;color:var(--emerald);flex:0 0 20px;margin-top:.12rem}

/* product mock (light) */
.prod{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-s);overflow:hidden}
.prod-bar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--line-2);background:var(--paper)}
.prod-bar .dots{display:flex;gap:.35rem}.prod-bar .dots i{width:9px;height:9px;border-radius:50%;background:#d3deec;display:block}
.prod-bar .ttl{font-size:.82rem;color:#46546e;font-weight:600;margin-left:.4rem}
.prod-bar .acc{margin-left:auto;display:flex;gap:.4rem;align-items:center;font-size:.74rem;color:var(--soft)}
.prod-body{padding:1.3rem}
.ptabs{display:flex;gap:.3rem;background:var(--mist);border-radius:12px;padding:.25rem;margin-bottom:1.1rem}
.ptabs button{flex:1;border:0;background:none;cursor:pointer;padding:.5rem;border-radius:9px;font-weight:600;font-size:.84rem;color:#5a6884;font-family:var(--body)}
.ptabs button.on{background:#fff;color:var(--text);box-shadow:var(--shadow-xs)}
.field-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.55rem 0}
.field-row label{font-size:.88rem;color:#46546e}
.field-row input{width:140px;text-align:right;border:1px solid var(--line);border-radius:10px;padding:.5rem .7rem;font-family:var(--display);font-weight:700;color:var(--text);font-size:1rem}
.calc-result{margin-top:.8rem;padding:1.1rem;border-radius:16px;background:linear-gradient(135deg,#0e1828,#0b1322);color:#fff;display:flex;justify-content:space-between;align-items:center}
.calc-result .l{font-size:.84rem;color:#9fb2d6}.calc-result .big{font-family:var(--display);font-weight:800;font-size:2.1rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.bars{display:flex;gap:.4rem;margin-top:.9rem}
.bars .b{height:8px;border-radius:6px;background:var(--mist);overflow:hidden;flex:1}.bars .b i{display:block;height:100%;border-radius:6px}
.bars .b.t i{background:var(--blue);width:72%}.bars .b.n i{background:var(--mint);width:28%}
.legend{display:flex;gap:1.2rem;margin-top:.5rem;font-size:.78rem;color:var(--muted)}
.legend i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:.35rem}

/* portal mock */
.portal{display:grid;grid-template-columns:120px 1fr;min-height:300px}
.portal-side{background:var(--paper);border-right:1px solid var(--line-2);padding:1rem .7rem;display:flex;flex-direction:column;gap:.2rem}
.portal-side .pl{display:flex;align-items:center;gap:.5rem;padding:.5rem .55rem;border-radius:9px;font-size:.82rem;font-weight:600;color:#5a6884}
.portal-side .pl.on{background:#fff;color:var(--text);box-shadow:var(--shadow-xs)}.portal-side .pl svg{width:15px;height:15px}
.portal-main{padding:1.2rem}
.pstat{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#eef4ff,#e9fbf4);border:1px solid var(--line);border-radius:14px;padding:.9rem 1rem;margin-bottom:.9rem}
.pstat .l{font-size:.78rem;color:var(--muted)}.pstat .v{font-family:var(--display);font-weight:700;font-size:1.05rem}
.pitem{display:flex;align-items:center;gap:.7rem;padding:.6rem 0;border-top:1px solid var(--line-2);font-size:.88rem}
.pitem:first-of-type{border-top:0}.pitem .ic{width:30px;height:30px;border-radius:9px;background:var(--mist);display:grid;place-items:center}.pitem .ic svg{width:15px;height:15px;color:var(--blue)}
.pitem .r{margin-left:auto}
.tag{font-size:.7rem;font-weight:600;padding:.2rem .55rem;border-radius:999px}
.tag.ok{background:#e3f7ef;color:#0f9b73}.tag.warn{background:#fdf0dd;color:#bd7c1e}.tag.info{background:#e8eefe;color:#3f63d8}
.up{height:7px;border-radius:5px;background:var(--mist);overflow:hidden;margin-top:.3rem}.up i{display:block;height:100%;width:78%;background:var(--grad);border-radius:5px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.5rem;transition:.3s;position:relative}
.step:hover{transform:translateY(-5px);box-shadow:var(--shadow-s)}
.step .n{width:40px;height:40px;border-radius:12px;background:var(--ink);color:#fff;font-family:var(--display);font-weight:700;display:grid;place-items:center;margin-bottom:.9rem}
.step h3{font-size:1.06rem;margin-bottom:.3rem}.step p{font-size:.88rem;color:var(--muted);margin:0}

/* trust pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.pillar{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.5rem;transition:.3s}.pillar:hover{box-shadow:var(--shadow-s);transform:translateY(-4px)}
.pillar .ic{width:46px;height:46px;border-radius:13px;background:var(--soft-card);display:grid;place-items:center;margin-bottom:.9rem}.pillar .ic svg{width:22px;height:22px;color:var(--emerald)}
.pillar h3{font-size:1.06rem;margin-bottom:.3rem}.pillar p{font-size:.9rem;color:var(--muted);margin:0}

/* case studies */
.case{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.6rem;height:100%;transition:.3s;position:relative;overflow:hidden}
.case:hover{box-shadow:var(--shadow);transform:translateY(-5px)}
.case .qt{position:absolute;top:1rem;right:1.3rem;font-family:var(--display);font-size:3rem;color:var(--mist);font-weight:800;line-height:1}
.case .tag{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue)}
.case h3{font-size:1.12rem;margin:.5rem 0 .8rem}
.case .blk{margin:.55rem 0}.case .blk .k{font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--soft)}.case .blk p{font-size:.9rem;color:#3a485f;margin:.15rem 0 0}
.case .res{margin-top:.9rem;padding-top:.8rem;border-top:1px solid var(--line-2);display:flex;gap:.45rem;align-items:flex-start;font-weight:600;font-size:.9rem;color:var(--emerald)}.case .res svg{width:17px;height:17px;flex:0 0 17px;margin-top:.1rem}

/* knowledge hub */
.hub{background:var(--ink);color:#eaf1ff;border-radius:var(--r);padding:clamp(2rem,4vw,3.4rem);position:relative;overflow:hidden}
.hub:before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 100% 0,rgba(46,224,176,.16),transparent 60%);pointer-events:none}
.hub h2{color:#fff}.hub .lead{color:#bccbe8}
.hub-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:1rem;margin-top:2rem;position:relative}
.hub-feat{background:linear-gradient(160deg,rgba(255,255,255,.08),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:1.5rem;display:flex;flex-direction:column;justify-content:flex-end;min-height:230px}
.hub-feat .k{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mint);font-weight:600}
.hub-feat h3{color:#fff;font-size:1.3rem;margin:.4rem 0 .3rem}.hub-feat p{color:#aebdda;font-size:.9rem;margin:0}
.hub-col{display:flex;flex-direction:column;gap:.6rem}
.hub-link{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:13px;padding:.85rem 1rem;transition:.25s;display:block;color:#eaf1ff}
.hub-link:hover{background:rgba(255,255,255,.1);transform:translateX(3px)}
.hub-link .t{font-weight:600;font-size:.92rem;display:flex;justify-content:space-between;align-items:center}.hub-link .t svg{width:14px;height:14px;color:var(--mint)}
.hub-link .d{font-size:.78rem;color:#92a4c4;margin-top:.15rem}
.hub-cats{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.6rem;position:relative}
.hub-cats a{font-size:.82rem;font-weight:600;color:#cdd9f0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:.45rem .85rem;border-radius:999px;transition:.2s}
.hub-cats a:hover{background:rgba(255,255,255,.13)}
@media(max-width:880px){.hub-grid{grid-template-columns:1fr}}

/* pricing (restrained, premium) */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;align-items:stretch}
.price{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;display:flex;flex-direction:column;transition:.35s}
.price:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price.feat{border-color:transparent;background:linear-gradient(#fff,#fff) padding-box,var(--grad) border-box;border:1.5px solid transparent;box-shadow:0 30px 70px -34px rgba(63,116,247,.45);position:relative}
.price.feat:before{content:"Most chosen";position:absolute;top:-12px;left:1.8rem;background:var(--grad);color:#fff;font-size:.72rem;font-weight:700;padding:.26rem .72rem;border-radius:999px}
.price .nm{font-family:var(--display);font-weight:700;font-size:1.15rem}
.price .who{font-size:.84rem;color:var(--muted);margin:.1rem 0 .9rem}
.price .amt{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--text);padding-top:.6rem;border-top:1px solid var(--line-2);margin-top:auto}
.price .amt small{font-size:.8rem;color:var(--soft);font-weight:500}
.price ul{list-style:none;margin:.4rem 0 1.2rem;display:grid;gap:.55rem;flex:1}
.price li{display:flex;gap:.55rem;font-size:.91rem;color:#41506b}.price li svg{width:18px;height:18px;color:var(--emerald);flex:0 0 18px;margin-top:.12rem}
.price .pa{margin-top:1rem}

/* docs panel */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-xs);padding:1.8rem;margin-top:1.4rem}
.doc-list{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.6rem}
.doc-list span{display:inline-flex;align-items:center;gap:.45rem;background:var(--mist);border:1px solid var(--line);border-radius:11px;padding:.55rem .85rem;font-size:.88rem;font-weight:500;color:#2c3a55;animation:pop .42s both}
@keyframes pop{from{opacity:0;transform:scale(.9) translateY(6px)}to{opacity:1;transform:none}}.doc-list span svg{width:15px;height:15px;color:var(--blue)}

/* cta band */
.cta{position:relative;border-radius:var(--r);padding:clamp(2.6rem,5.4vw,4.2rem);text-align:center;overflow:hidden;background:var(--ink);color:#fff;border:1px solid var(--line-d)}
.cta:before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 20% 0,rgba(63,116,247,.4),transparent 60%),radial-gradient(46% 80% at 85% 100%,rgba(46,224,176,.34),transparent 60%);pointer-events:none}
.cta h2{color:#fff;position:relative}.cta p{color:#c6d4ec;max-width:54ch;margin-inline:auto;position:relative}

/* content / service pages */
.content{font-size:1.05rem;color:#27364f}
.content h2{margin:2.4rem 0 .9rem}.content h3{margin:1.6rem 0 .5rem;font-size:1.18rem}
.content ul,.content ol{padding-left:1.3rem;margin:0 0 1.2rem}.content li{margin:.42rem 0}
.content a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.crumbs{font-size:.84rem;color:var(--ondark-2);margin-bottom:1rem}.crumbs a{color:#9ec1ff}
.page-hero{background:var(--ink);color:#eaf1ff;position:relative;overflow:hidden;padding:calc(var(--nav-h) + 2.8rem) 0 3rem}
.page-hero .hero-bg{position:absolute;inset:0;z-index:0}.page-hero .in{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:clamp(2.2rem,4.6vw,3.4rem);max-width:20ch}.page-hero .lead{color:#bccbe8}
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.1rem 0 1.4rem}
.tpill{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;color:#cdd9f0;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);padding:.42rem .85rem;border-radius:999px}
.tpill svg{width:14px;height:14px;color:var(--mint)}
.split{display:grid;grid-template-columns:1fr 350px;gap:2.6rem;align-items:start}
@media(max-width:920px){.split{grid-template-columns:1fr}}
.aside{position:sticky;top:96px;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-s);padding:1.6rem;overflow:hidden}
.aside:before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:var(--grad)}
.aside .eyebrow{margin-top:.3rem}
.aside .val{font-family:var(--display);font-weight:700;font-size:1.15rem;margin:.5rem 0 .2rem}
.aside .price-line{font-size:.92rem;color:var(--muted);padding-bottom:1rem;border-bottom:1px solid var(--line-2);margin-bottom:1rem}
.aside .price-line b{font-family:var(--display);color:var(--text);font-size:1.05rem}
.aside .cta-list{display:grid;gap:.6rem;margin:0 0 1rem}
.aside .mini{font-size:.84rem;color:#41506b;display:flex;gap:.5rem;align-items:flex-start;margin-top:.55rem}.aside .mini svg{width:16px;height:16px;color:var(--emerald);flex:0 0 16px;margin-top:.12rem}
.feature-box{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-2);padding:1.4rem 1.6rem;margin:1.5rem 0}
.incl{display:grid;grid-template-columns:1fr 1fr;gap:.55rem 1.4rem;list-style:none;padding:0;margin:.6rem 0 0}
.incl li{display:flex;gap:.5rem;font-size:.95rem;color:#33425c}.incl svg{width:18px;height:18px;color:var(--emerald);flex:0 0 18px;margin-top:.15rem}
@media(max-width:560px){.incl{grid-template-columns:1fr}}
.miss{display:flex;gap:.65rem;align-items:flex-start;padding:.7rem 0;border-bottom:1px solid var(--line-2)}.miss svg{width:18px;height:18px;color:#e1923b;flex:0 0 18px;margin-top:.15rem}
.faq{border:1px solid var(--line);border-radius:var(--r-2);overflow:hidden;background:#fff}
.faq details{border-bottom:1px solid var(--line-2)}.faq details:last-child{border-bottom:0}
.faq summary{list-style:none;cursor:pointer;padding:1.15rem 1.4rem;font-family:var(--display);font-weight:600;font-size:1.02rem;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}.faq summary:after{content:"+";font-size:1.4rem;color:var(--blue);transition:.25s;font-weight:300}
.faq details[open] summary:after{transform:rotate(45deg)}.faq .a{padding:0 1.4rem 1.3rem;color:var(--muted);font-size:.96rem}

/* footer */
footer.ft{background:var(--ink);color:#94a6c4;padding:4rem 0 1.8rem;font-size:.92rem;position:relative;overflow:hidden}
footer.ft:before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(46,224,176,.4),transparent)}
.fcols{display:grid;grid-template-columns:1.9fr 1fr 1fr 1.2fr;gap:2rem;padding-bottom:2.2rem;border-bottom:1px solid var(--line-d2)}
footer .brand .logo .wm{fill:#fff}footer .brand{margin-bottom:.8rem}
footer h4{color:#fff;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
footer ul{list-style:none}footer li{padding:.24rem 0}footer a{color:#94a6c4}footer a:hover{color:#fff}
.fbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-top:1.4rem;font-size:.82rem;color:#6e8099}
.compliance{font-size:.8rem;color:#6e8099;margin-top:1.2rem;max-width:94ch;line-height:1.6}

@media(max-width:1080px){.nav-links{display:none}.burger{display:block}.nav-cta .btn-ghost{display:none}}
@media(max-width:920px){.hero-in{grid-template-columns:1fr;gap:2.6rem}.workspace{transform:none}.g3,.g4,.steps,.price-grid,.pillars{grid-template-columns:repeat(2,1fr)}.portal{grid-template-columns:1fr}.portal-side{flex-direction:row;flex-wrap:wrap;border-right:0;border-bottom:1px solid var(--line-2)}.fcols{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.g3,.g4,.steps,.price-grid,.pillars,.tiles{grid-template-columns:1fr}.float-card{display:none}}

/* ============================================================
   MOTION LAYER  —  smooth animations applied across the site
   ============================================================ */
/* directional reveal variants (gated on html.js so content is safe without JS) */
.rv-l,.rv-r,.rv-s,.rv-f,.rv-b{opacity:1;transform:none}
html.js .rv-l{opacity:0;transform:translateX(-42px);transition:opacity .85s ease,transform .85s cubic-bezier(.2,.85,.25,1)}
html.js .rv-r{opacity:0;transform:translateX(42px);transition:opacity .85s ease,transform .85s cubic-bezier(.2,.85,.25,1)}
html.js .rv-s{opacity:0;transform:scale(.9);transition:opacity .85s ease,transform .85s cubic-bezier(.2,.85,.25,1)}
html.js .rv-b{opacity:0;transform:translateY(-26px);transition:opacity .85s ease,transform .85s cubic-bezier(.2,.85,.25,1)}
html.js .rv-f{opacity:0;transition:opacity 1.1s ease}
html.js .rv-l.in,html.js .rv-r.in,html.js .rv-s.in,html.js .rv-b.in,html.js .rv-f.in{opacity:1;transform:none}
.d6{transition-delay:.42s}.d7{transition-delay:.5s}.d8{transition-delay:.58s}.d9{transition-delay:.66s}

/* gradient-text shimmer */
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:220% 50%}}
.hero h1 .g,.shine-text{background-size:220% auto;animation:shimmer 7s linear infinite alternate}

/* primary button sheen sweep */
.btn-primary{overflow:hidden}
.btn-primary:after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);transition:left .6s ease;pointer-events:none}
.btn-primary:hover:after{left:150%}

/* animated underline link */
.lnk{position:relative;color:var(--blue);font-weight:600;display:inline-flex;align-items:center;gap:.35rem}
.lnk svg{width:15px;height:15px;transition:transform .3s}
.lnk:hover svg{transform:translateX(4px)}
.lnk:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1.5px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.2,.85,.25,1)}
.lnk:hover:after{transform:scaleX(1);transform-origin:left}

/* ambient float + soft pulse */
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes pulseSoft{0%,100%{opacity:.45;transform:scale(1)}50%{opacity:.9;transform:scale(1.04)}}
.floaty{animation:floaty 6.5s ease-in-out infinite}
.pulse-dot{animation:pulseSoft 2.6s ease-in-out infinite}

/* icon pop on hover for any card-like block */
.card .ic,.pillar .ic,.step .n,.sel-panel .pic,.mega .di{transition:transform .45s cubic-bezier(.2,.85,.25,1)}
.card:hover .ic,.pillar:hover .ic,.step:hover .n,.mega-list a:hover .di{transform:translateY(-3px) rotate(-4deg) scale(1.07)}

/* lift utility for any reveal block */
.lift{transition:transform .4s cubic-bezier(.2,.85,.25,1),box-shadow .4s}
.lift:hover{transform:translateY(-5px);box-shadow:var(--shadow-s)}

/* auto entrance for internal page heroes (runs on load, no scroll needed) */
@keyframes heroRise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
html.js .page-hero .in>*{opacity:0;animation:heroRise .9s cubic-bezier(.2,.85,.25,1) forwards}
html.js .page-hero .in>*:nth-child(1){animation-delay:.06s}
html.js .page-hero .in>*:nth-child(2){animation-delay:.16s}
html.js .page-hero .in>*:nth-child(3){animation-delay:.26s}
html.js .page-hero .in>*:nth-child(4){animation-delay:.36s}
html.js .page-hero .in>*:nth-child(5){animation-delay:.46s}
html.js .page-hero .in>*:nth-child(6){animation-delay:.56s}

/* auto entrance for the home hero text column */
html.js .hero .hero-copy>*{opacity:0;animation:heroRise 1s cubic-bezier(.2,.85,.25,1) forwards}
html.js .hero .hero-copy>*:nth-child(1){animation-delay:.1s}
html.js .hero .hero-copy>*:nth-child(2){animation-delay:.22s}
html.js .hero .hero-copy>*:nth-child(3){animation-delay:.34s}
html.js .hero .hero-copy>*:nth-child(4){animation-delay:.46s}
html.js .hero .hero-copy>*:nth-child(5){animation-delay:.58s}
html.js .hero .hero-copy>*:nth-child(6){animation-delay:.7s}

/* scroll progress bar (width set by JS) */
#scrollbar{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:200;box-shadow:0 0 12px rgba(63,116,247,.6);transition:width .08s linear}

/* nav link soft underline */
.nav-links>a,.nav-item>button{position:relative}
.nav-links>a:before{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.35rem;height:1.5px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .3s;border-radius:2px}
.nav-links>a:hover:before{transform:scaleX(1)}
header.nav:not(.scrolled) .nav-links>a:before{background:var(--mint)}

/* gentle scale-in for images/mocks on reveal */
html.js .zoom-in{opacity:0;transform:scale(.96);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.85,.25,1)}
html.js .zoom-in.in{opacity:1;transform:none}
.zoom-in{opacity:1;transform:none}

/* hover sheen for service cards already uses .card:before; add subtle border glow */
.card:hover,.case:hover,.step:hover,.pillar:hover,.price:hover{border-color:#cdd9f4}

/* FAQ answer slide */
.faq details[open] .a{animation:faqOpen .4s ease}
@keyframes faqOpen{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* count chips entrance handled by .doc-list pop */

/* FINAL: respect reduced-motion preference (overrides everything above) */
@media(prefers-reduced-motion:reduce){
  *,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .rv,.rv-l,.rv-r,.rv-s,.rv-b,.rv-f,.zoom-in{opacity:1!important;transform:none!important}
  html.js .page-hero .in>*,html.js .hero .hero-copy>*{opacity:1!important;animation:none!important}
  .workspace{transform:none!important}
}

/* ===================== FORMS ===================== */
.form-row{display:grid;gap:.9rem;margin-top:1.3rem;max-width:580px}
.form-2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
@media(max-width:560px){.form-2{grid-template-columns:1fr}}
.fld{display:grid;gap:.35rem;font-size:.86rem;color:#46546e;font-weight:500}
.fld input,.fld select,.fld textarea{border:1px solid var(--line);border-radius:12px;padding:.8rem .9rem;font-family:var(--body);font-size:.95rem;color:var(--text);background:#fff;transition:border-color .2s,box-shadow .2s;width:100%}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(63,116,247,.13)}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.form-success{display:none;background:linear-gradient(150deg,#eef4ff,#e9fbf4);border:1px solid var(--line);border-radius:var(--r);padding:2.2rem;text-align:center}
.form-success .ok{width:64px;height:64px;border-radius:50%;background:var(--grad);display:grid;place-items:center;margin:0 auto 1rem;animation:pop .5s both}
.form-success .ok svg{width:30px;height:30px;color:#fff}
.form-success h3{font-size:1.45rem;margin-bottom:.4rem}
.form-success p{color:var(--muted);max-width:46ch;margin:0 auto}
.form-err{display:none;color:#c0392b;font-size:.9rem;font-weight:600;margin-top:.6rem}

/* ===================== QUOTE QUIZ ===================== */
.quiz{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-s);padding:clamp(1.5rem,3.5vw,2.6rem);max-width:760px;margin:0 auto;position:relative;overflow:hidden}
.quiz:before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:var(--grad)}
.q-top{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--muted);font-weight:600;margin-bottom:.8rem}
.q-bar{height:7px;border-radius:6px;background:var(--mist);overflow:hidden;margin-bottom:1.8rem}
.q-bar i{display:block;height:100%;width:0;background:var(--grad);border-radius:6px;transition:width .45s cubic-bezier(.2,.85,.25,1)}
.q-step h3{font-size:1.5rem;margin-bottom:.4rem}
.q-step .sub{color:var(--muted);margin-bottom:1.3rem;font-size:.95rem}
.q-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
@media(max-width:560px){.q-grid{grid-template-columns:1fr}}
.q-opt{display:flex;align-items:center;gap:.7rem;text-align:left;border:1.5px solid var(--line);background:#fff;border-radius:14px;padding:.95rem 1.1rem;font-family:var(--body);font-size:.95rem;font-weight:600;color:#2c3a55;cursor:pointer;transition:.2s;width:100%}
.q-opt .qi{width:34px;height:34px;border-radius:10px;background:var(--soft-card);display:grid;place-items:center;flex:0 0 34px;font-size:1.05rem}
.q-opt:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-xs)}
.q-opt.on{border-color:var(--blue);background:linear-gradient(150deg,#eff4ff,#e9fbf4);box-shadow:0 0 0 2px rgba(63,116,247,.18)}
.q-opt.on:after{content:"\2713";margin-left:auto;color:var(--blue);font-weight:800}
.q-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:1.6rem}
.q-hint{font-size:.8rem;color:var(--soft);margin-top:.9rem}
.shake{animation:shake .45s}
@keyframes shake{0%,100%{transform:none}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}

/* ===================== CALCULATOR SUITE ===================== */
.calc-tabs{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;margin-bottom:2rem}
.calc-tab{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--line);background:#fff;border-radius:999px;padding:.55rem 1rem;font-weight:600;font-size:.86rem;color:#37445e;cursor:pointer;font-family:var(--body);transition:.2s}
.calc-tab:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.calc-tab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.calc-wrap{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;align-items:start}
@media(max-width:880px){.calc-wrap{grid-template-columns:1fr}}
.calc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-xs);padding:1.7rem}
.calc-card h3{font-size:1.3rem;margin-bottom:.3rem}
.calc-card .cdesc{color:var(--muted);font-size:.92rem;margin-bottom:1.1rem}
.calc-field{margin:.95rem 0}
.calc-field label{display:flex;justify-content:space-between;font-size:.88rem;color:#46546e;font-weight:500;margin-bottom:.35rem}
.calc-field .ip{display:flex;align-items:center;border:1px solid var(--line);border-radius:12px;padding:0 .8rem;transition:.2s;background:#fff}
.calc-field .ip:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(63,116,247,.13)}
.calc-field .ip .pre{color:var(--soft);font-weight:700}
.calc-field .ip input{border:0;outline:none;width:100%;padding:.65rem .5rem;font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--text);background:transparent}
.calc-field select{border:1px solid var(--line);border-radius:12px;outline:none;width:100%;padding:.7rem .8rem;font-family:var(--body);font-weight:600;font-size:.95rem;color:var(--text);background:#fff}
.calc-field input[type=range]{width:100%;accent-color:var(--blue);margin-top:.6rem}
.calc-out{background:linear-gradient(140deg,#0e1828,#0b1322);border-radius:var(--r-2);padding:1.6rem;color:#fff;position:sticky;top:96px;overflow:hidden}
.calc-out:before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 100% 0,rgba(46,224,176,.16),transparent 60%);pointer-events:none}
.calc-out .ol{font-size:.85rem;color:#9fb2d6;position:relative}
.calc-out .obig{font-family:var(--display);font-weight:800;font-size:2.6rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.05;margin:.2rem 0;position:relative}
.calc-out .osub{font-size:.85rem;color:#aebdda;position:relative}
.calc-rows{margin-top:1.2rem;border-top:1px solid rgba(255,255,255,.1);padding-top:.6rem;position:relative}
.calc-rows .cr{display:flex;justify-content:space-between;padding:.42rem 0;font-size:.9rem;color:#cdd9f0;border-top:1px solid rgba(255,255,255,.06)}
.calc-rows .cr:first-child{border-top:0}
.calc-rows .cr b{color:#fff;font-family:var(--display);font-weight:700}
.calc-bars{display:flex;height:12px;border-radius:7px;overflow:hidden;margin-top:1.2rem;background:rgba(255,255,255,.08);position:relative}
.calc-bars span{height:100%;transition:width .5s}
.calc-legend{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:.7rem;font-size:.76rem;color:#aebdda;position:relative}
.calc-legend i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:.35rem}
.calc-note{font-size:.82rem;color:var(--muted);text-align:center;max-width:64ch;margin:1.6rem auto 0}

/* ===================== TAX NEWS ===================== */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:880px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.news-grid{grid-template-columns:1fr}}
.news{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.4rem;transition:.3s;display:flex;flex-direction:column}
.news:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#d0ddf4}
.news .meta{display:flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.7rem}
.news .cat{color:var(--blue)}.news .date{color:var(--soft)}
.news h3{font-size:1.08rem;margin-bottom:.5rem;line-height:1.25}
.news p{font-size:.9rem;color:var(--muted);margin:0}
.news-feature{background:var(--ink);color:#fff;border-radius:var(--r);padding:clamp(1.6rem,3vw,2.4rem);position:relative;overflow:hidden;margin-bottom:1.6rem}
.news-feature:before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 100% 0,rgba(46,224,176,.18),transparent 60%);pointer-events:none}
.news-feature h2{color:#fff;position:relative}.news-feature p{color:#bccbe8;position:relative;max-width:60ch}

/* ===================== MEGA / NAV EXTRAS ===================== */
.mega.wide{width:760px}
.mega-list.g3{grid-template-columns:1fr 1fr 1fr}
.mega-cols{display:grid;grid-template-columns:1fr 1fr;gap:.3rem 1rem}
.mega-h{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);padding:.5rem .75rem .2rem}
@media(max-width:1180px){.mega.wide{width:560px}.mega-list.g3{grid-template-columns:1fr 1fr}}

/* ===================== CLIENT JOURNEY ===================== */
.jgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:880px){.jgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.jgrid{grid-template-columns:1fr}}
.jstep{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.5rem;position:relative;transition:.3s}
.jstep:hover{transform:translateY(-4px);box-shadow:var(--shadow-s);border-color:#cdd9f4}
.jstep .jn{width:38px;height:38px;border-radius:11px;background:var(--grad);color:#fff;font-family:var(--display);font-weight:700;display:grid;place-items:center;margin-bottom:.9rem}
.jstep h3{font-size:1.05rem;margin-bottom:.3rem}.jstep p{font-size:.9rem;color:var(--muted);margin:0}

/* ===================== ARTICLES HUB ===================== */
.art-search{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:.7rem .9rem;box-shadow:var(--shadow-xs);max-width:560px;margin:0 auto 1.4rem}
.art-search input{border:0;outline:none;flex:1;font-family:var(--body);font-size:.98rem;padding:.4rem;background:transparent;min-width:140px}
.art-search svg{width:20px;height:20px;color:var(--soft)}
.art-cats{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2rem}
.art-cat{font-size:.82rem;font-weight:600;color:#37445e;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.45rem .9rem;cursor:pointer;transition:.2s}
.art-cat:hover,.art-cat.on{border-color:var(--blue);color:var(--blue);background:var(--mist)}
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:880px){.art-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.art-grid{grid-template-columns:1fr}}
.art-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.5rem;transition:.3s;color:var(--text)}
.art-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#cdd9f4}
.art-card .lab{display:inline-flex;align-self:flex-start;font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);background:var(--mist);border-radius:999px;padding:.28rem .7rem;margin-bottom:.8rem}
.art-card h3{font-size:1.12rem;line-height:1.25;margin-bottom:.5rem}
.art-card p{font-size:.9rem;color:var(--muted);margin:0 0 1rem;flex:1}
.art-card .am{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--soft);font-weight:600}
.art-card .am .go{margin-left:auto;color:var(--blue);display:inline-flex;align-items:center;gap:.3rem}
.art-card .am .go svg{width:14px;height:14px;transition:.25s}.art-card:hover .go svg{transform:translateX(3px)}
.art-feature{display:grid;grid-template-columns:1.2fr 1fr;gap:0;background:var(--ink);border-radius:var(--r);overflow:hidden;color:#fff;margin-bottom:1.8rem}
@media(max-width:760px){.art-feature{grid-template-columns:1fr}}
.art-feature .af-body{padding:clamp(1.6rem,3vw,2.6rem)}
.art-feature .af-side{background:linear-gradient(150deg,#13203a,#0b1322);position:relative;min-height:200px;display:grid;place-items:center;overflow:hidden}
.art-feature .af-side:before{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 70% 20%,rgba(46,224,176,.25),transparent 60%)}
.art-feature .af-side svg{width:84px;height:84px;color:var(--mint);opacity:.85;position:relative}
.art-feature .lab{color:var(--mint)}.art-feature h2{color:#fff}.art-feature p{color:#bccbe8}

/* article body */
.article-body{max-width:760px}
.article-body .lead{font-size:1.18rem;color:#33425c}
.toc{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-2);padding:1.2rem 1.4rem;margin:1.5rem 0}
.toc strong{font-family:var(--display);font-size:.95rem}.toc ul{margin:.5rem 0 0;padding-left:1.1rem}.toc a{color:var(--blue)}
.keytake{background:linear-gradient(150deg,#eef4ff,#e9fbf4);border:1px solid var(--line);border-radius:var(--r-2);padding:1.4rem 1.6rem;margin:1.6rem 0}
.keytake strong{font-family:var(--display)}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:760px){.related{grid-template-columns:1fr}}

/* ===================== DEADLINES ===================== */
.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:880px){.dl-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.dl-grid{grid-template-columns:1fr}}
.dl-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.4rem;transition:.3s;position:relative;overflow:hidden}
.dl-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-s)}
.dl-card .when{display:inline-flex;font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--blue);background:var(--mist);border-radius:10px;padding:.3rem .7rem;margin-bottom:.7rem}
.dl-card h3{font-size:1.05rem;margin-bottom:.35rem}.dl-card p{font-size:.88rem;color:var(--muted);margin:0}
.dl-card.warn{border-color:#f3d9a8;background:linear-gradient(150deg,#fff,#fff7ea)}
.dl-card.warn .when{color:#bd7c1e;background:#fdf0dd}

/* ===================== CHECKLISTS ===================== */
.chk-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:880px){.chk-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.chk-grid{grid-template-columns:1fr}}
.chk-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-2);padding:1.3rem;text-align:left;transition:.3s;cursor:pointer}
.chk-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-s);border-color:#cdd9f4}
.chk-card .ic{width:44px;height:44px;border-radius:12px;background:var(--soft-card);display:grid;place-items:center;margin-bottom:.8rem}.chk-card .ic svg{width:22px;height:22px;color:var(--blue)}
.chk-card h3{font-size:1rem;margin-bottom:.25rem}.chk-card p{font-size:.84rem;color:var(--muted);margin:0}

/* ===================== COMPARISON ===================== */
.vs-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;align-items:start}
@media(max-width:760px){.vs-grid{grid-template-columns:1fr}}
.vs-col{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.7rem;transition:.3s}
.vs-col:hover{box-shadow:var(--shadow-s)}
.vs-col.a{border-top:4px solid var(--blue)}.vs-col.b{border-top:4px solid var(--mint)}
.vs-col h3{font-size:1.25rem;margin-bottom:.2rem}.vs-col .who{font-size:.86rem;color:var(--muted);margin-bottom:1rem}
.vs-col ul{list-style:none;display:grid;gap:.6rem}.vs-col li{display:flex;gap:.55rem;font-size:.92rem;color:#3a485f}.vs-col li svg{width:18px;height:18px;flex:0 0 18px;margin-top:.15rem;color:var(--emerald)}
.vs-col li.con svg{color:#e1923b}
.vs-mid{display:grid;place-items:center;font-family:var(--display);font-weight:800;color:var(--soft);font-size:1.1rem}

/* ===================== ASK TAXTUNE ===================== */
.ask{background:var(--ink);border-radius:var(--r);padding:clamp(1.8rem,4vw,3rem);color:#fff;position:relative;overflow:hidden}
.ask:before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 15% 0,rgba(63,116,247,.4),transparent 60%),radial-gradient(46% 80% at 90% 100%,rgba(46,224,176,.34),transparent 60%);pointer-events:none}
.ask h2{color:#fff;position:relative}.ask .lead{color:#bccbe8;position:relative}
.ask-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:1.6rem;position:relative}
@media(max-width:760px){.ask-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.ask-grid{grid-template-columns:1fr}}
.ask-opt{display:flex;align-items:center;gap:.7rem;text-align:left;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:.9rem 1rem;color:#eaf1ff;font-family:var(--body);font-weight:600;font-size:.92rem;cursor:pointer;transition:.2s;text-decoration:none}
.ask-opt:hover{background:rgba(255,255,255,.13);transform:translateY(-2px);border-color:rgba(122,160,255,.5)}
.ask-opt .ai{width:34px;height:34px;border-radius:10px;background:rgba(122,160,255,.18);display:grid;place-items:center;flex:0 0 34px}.ask-opt .ai svg{width:18px;height:18px;color:var(--mint)}

/* ===================== QUOTE SUMMARY ===================== */
.q-summary{background:linear-gradient(150deg,#eff4ff,#e9fbf4);border:1px solid var(--line);border-radius:var(--r-2);padding:1.3rem 1.5rem;margin-bottom:1.4rem}
.q-summary .qs-h{display:flex;align-items:center;gap:.5rem;font-family:var(--display);font-weight:700;margin-bottom:.4rem}
.q-summary .qs-h svg{width:18px;height:18px;color:var(--blue)}
.q-summary p{margin:0;color:#33425c;font-size:.95rem}
.q-summary b{color:var(--text)}

/* ===================== misc ===================== */
.section-soft{background:var(--paper)}
.scenario{background:var(--ink);color:#fff;border-radius:var(--r);padding:clamp(1.6rem,3vw,2.4rem);position:relative;overflow:hidden}
.scenario:before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 100% 0,rgba(46,224,176,.16),transparent 60%);pointer-events:none}
.scenario h3{color:#fff;position:relative}.scenario p{color:#c6d4ec;position:relative;margin:.5rem 0 0}
.scenario .tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mint);position:relative;margin-bottom:.4rem}

/* ===================== PREMIUM DROPDOWN BEHAVIOUR ===================== */
.mega{top:calc(100% + 6px);transition:opacity .3s cubic-bezier(.2,.85,.25,1),visibility .3s,transform .3s cubic-bezier(.2,.85,.25,1);max-width:calc(100vw - 32px)}
.mega:before{content:"";position:absolute;left:0;right:0;top:-14px;height:16px}
.nav-item.open>.mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-item>button{transition:.25s}
.nav-item.open>button{opacity:1;background:rgba(120,150,230,.12)}
.nav-item.open>button svg{transform:rotate(180deg)}
.mega-list a,.mega-cols a{align-items:center}
.mega-list a:hover,.mega-cols a:hover{background:var(--paper);transform:translateX(3px)}
.mega .dd{font-size:.74rem;color:var(--muted);line-height:1.2;display:block;margin-top:1px}
.mega .di{transition:transform .28s cubic-bezier(.2,.85,.25,1)}
.mega-list a:hover .di,.mega-cols a:hover .di{transform:scale(1.08) rotate(-4deg)}
.mega-feat{transition:transform .3s}.nav-item.open .mega-feat{}

/* ===== real brand logo (uploaded) ===== */
.brand .logo{height:32px;width:auto;display:block}
.brand .logo-dark{display:none}
header.nav.scrolled .brand .logo-light{display:none}
header.nav.scrolled .brand .logo-dark{display:block}
footer .brand .logo-foot{height:52px;width:auto;display:block;margin-bottom:.2rem}
.m-brand{display:block!important;margin:.1rem .2rem .9rem;padding:0!important;background:none!important}
.m-brand:hover{background:none!important}
.m-brand img{height:30px;width:auto;display:block}
.form-success .logo-success{height:30px;width:auto;margin:0 auto 1.1rem;display:block}
@media(max-width:560px){.brand .logo{height:28px}.footer .brand .logo-foot{height:46px}}

/* ===== inline lead capture form ===== */
.lead-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;box-shadow:0 34px 70px -42px rgba(4,9,22,.4)}
.lead-card .lead-head h3{font-family:var(--display);font-size:1.3rem;margin:.35rem 0 .45rem;color:var(--text)}
.lead-card .lead-head p{color:var(--muted);font-size:.9rem;margin-bottom:1.1rem;line-height:1.5}
.lf-field{margin-bottom:.7rem;display:flex;flex-direction:column}
.lf-field label{font-size:.82rem;font-weight:600;margin-bottom:.32rem;color:var(--text)}
.lf-field label span{font-weight:400;color:var(--soft)}
.lf-field input,.lf-field select,.lf-field textarea{font-family:var(--body);font-size:.95rem;padding:.72rem .85rem;border:1px solid var(--line-2);border-radius:11px;background:var(--mist);transition:.2s;width:100%;color:var(--text)}
.lf-field textarea{resize:vertical}
.lf-field input:focus,.lf-field select:focus,.lf-field textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(63,116,247,.14)}
.lf-note{display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--soft);margin-top:.8rem}
.lf-note svg{width:15px;height:15px;color:var(--mint);flex:none}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.lead-band{background:linear-gradient(150deg,var(--ink),var(--ink-2));color:#eaf1ff;border-radius:var(--r);padding:2.2rem;display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.lead-band h2{color:#fff;font-size:1.7rem;margin-bottom:.6rem}
.lead-band p{color:#b9c6dd;max-width:42ch}
.lead-band .lead-card{margin:0}
@media(max-width:820px){.lead-band{grid-template-columns:1fr;padding:1.5rem}}

/* ===== What Can I Claim tool ===== */
.wci-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.8rem;margin-bottom:1.6rem}
.wci-opt{display:flex;flex-direction:column;align-items:flex-start;gap:.6rem;padding:1.1rem;background:#fff;border:1px solid var(--line);border-radius:14px;cursor:pointer;font-family:var(--body);font-size:.96rem;font-weight:600;color:var(--text);text-align:left;transition:.2s}
.wci-opt:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 18px 40px -28px rgba(4,9,22,.4)}
.wci-opt.on{border-color:var(--blue);background:linear-gradient(180deg,rgba(63,116,247,.08),#fff);box-shadow:0 0 0 2px var(--blue) inset}
.wci-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--mist);color:var(--blue)}
.wci-ic svg{width:20px;height:20px}
.wci-result{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;box-shadow:0 30px 60px -42px rgba(4,9,22,.35)}
.wci-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.wci-col h3{font-family:var(--display);font-size:1.02rem;margin-bottom:.7rem;padding-bottom:.5rem;border-bottom:2px solid var(--line-2)}
.wci-col.claim h3{color:#0f9b73;border-color:#cdeee1}
.wci-col.care h3{color:#c47d12;border-color:#f3e2c2}
.wci-col.rec h3{color:var(--blue);border-color:#d4e0fb}
.wci-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.wci-col li{font-size:.92rem;color:var(--muted);padding-left:1.1rem;position:relative;line-height:1.45}
.wci-col li:before{content:"";position:absolute;left:0;top:.55rem;width:6px;height:6px;border-radius:50%;background:var(--blue);opacity:.45}
.wci-note{margin-top:1.4rem;font-size:.9rem;color:var(--soft)}
@media(max-width:760px){.wci-cols{grid-template-columns:1fr}}

/* ===== 3 column resources mega + MTD checker ===== */
.mega.res{width:920px;max-width:calc(100vw - 32px)}
.mega-cols.c3{grid-template-columns:repeat(3,1fr)}
.mtd-q{margin:0 0 1.4rem}
.mtd-q h3{font-family:var(--display);font-size:1.05rem;margin-bottom:.7rem}
.mtd-opts{display:flex;flex-wrap:wrap;gap:.6rem}
.mtd-opts .wci-opt{flex-direction:row;align-items:center;width:auto;padding:.6rem 1rem;font-size:.9rem}
.ns-links .btn{text-decoration:none}

/* footer trust + credentials (v10) */
.ft-trust{font-size:.78rem;color:#8fa1c0;margin-top:.55rem;letter-spacing:.2px}
.trust-creds{display:flex;flex-wrap:wrap;gap:.7rem;margin:1.5rem 0}
.trust-creds .tc{display:inline-flex;align-items:center;gap:.5rem;background:var(--paper,#f4f8ff);border:1px solid var(--line-2,#e4ebf5);border-radius:12px;padding:.55rem .85rem;font-size:.85rem;font-weight:600;color:var(--ink,#0f1b33)}
.trust-creds .tc svg{width:17px;height:17px;color:var(--blue,#3f74f7);flex:none}

/* topic cluster cross-link block (v10) */
.cluster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:1.5rem}
.cluster-col{background:var(--card,#fff);border:1px solid var(--line-2,#e4ebf5);border-radius:16px;padding:1.3rem 1.4rem}
.cluster-col h3{font-size:1rem;margin:0 0 .8rem;font-family:var(--display,'Sora',sans-serif)}
.cluster-col ul{list-style:none;margin:0;padding:0}
.cluster-col li{margin:0 0 .6rem;line-height:1.35}
.cluster-col a{color:var(--ink,#0f1b33);text-decoration:none;font-size:.9rem;font-weight:500}
.cluster-col a:hover{color:var(--blue,#3f74f7);text-decoration:underline}
@media(max-width:820px){.cluster-grid{grid-template-columns:1fr}}

/* tick list (v10) */
ul.ticks{list-style:none;margin:1rem 0;padding:0;display:grid;gap:.5rem}
ul.ticks li{position:relative;padding-left:1.7rem;line-height:1.45}
ul.ticks li::before{content:"";position:absolute;left:0;top:.35em;width:13px;height:7px;border-left:2.4px solid var(--blue,#3f74f7);border-bottom:2.4px solid var(--blue,#3f74f7);transform:rotate(-45deg)}

/* E-E-A-T byline (v11) */
.byline{display:flex;flex-wrap:wrap;gap:.35rem .7rem;align-items:center;font-size:.82rem;color:var(--muted,#5b6b86);margin:.2rem 0 1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--line-2,#e4ebf5)}
.byline a{color:var(--blue,#3f74f7);font-weight:600;text-decoration:none}
.byline a:hover{text-decoration:underline}
.byline .sep{opacity:.5}

/* cookie consent (v11) */
.cc-banner{position:fixed;left:0;right:0;bottom:0;z-index:9999;background:#0f1b33;color:#fff;border-top:1px solid rgba(255,255,255,.12);box-shadow:0 -8px 30px rgba(0,0,0,.28)}
.cc-banner .cc-inner{max-width:1100px;margin:0 auto;padding:1rem 1.2rem;display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cc-text{flex:1;min-width:240px}
.cc-text strong{display:block;font-family:var(--display,'Sora',sans-serif);margin-bottom:.25rem}
.cc-text p{margin:0;font-size:.84rem;color:#c7d2e6;line-height:1.45}
.cc-text a{color:#7fb0ff}
.cc-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cc-btn{cursor:pointer;border-radius:10px;padding:.6rem 1.05rem;font-size:.85rem;font-weight:600;border:1px solid rgba(255,255,255,.28);background:transparent;color:#fff}
.cc-btn.cc-accept{background:var(--blue,#3f74f7);border-color:var(--blue,#3f74f7)}
.cc-link{background:none;border:0;color:inherit;font:inherit;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}
@media(max-width:640px){.cc-banner .cc-inner{flex-direction:column;align-items:stretch}.cc-actions{justify-content:stretch}.cc-btn{flex:1;text-align:center}}
