@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800&family=Fraunces:ital,opsz,wght@0,9..144,600;1,9..144,400&family=Inter:wght@400;500;600&display=swap');

  html,body{margin:0; padding:0;}
  #site{
    --ink:#12223f; --ink2:#3c4a66; --bg:#ffffff; --bg2:#f7f4ee;
    --line:#e8e2d6; --muted:#6b6657; --accent:#b07d28; --accent-d:#8f6418;
    --accent-soft:#b07d2814; --navy2:#1d3252;
    font-family:'Inter',system-ui,sans-serif; color:var(--ink); line-height:1.55; background-color:var(--bg); background-image:linear-gradient(to right, rgba(18,34,63,0.07) 1px, transparent 1px), linear-gradient(to bottom, rgba(18,34,63,0.07) 1px, transparent 1px); background-size:52px 52px; box-sizing:border-box;
  }
  #site *,#site *::before,#site *::after{box-sizing:border-box;}
  #site a{color:inherit; text-decoration:none;}
  .wrap{max-width:1140px; margin:0 auto; padding:0 32px;}
  h1,h2,h3,h4{font-family:'Archivo',sans-serif; letter-spacing:-.02em;}

  /* ---- top utility bar ---- */
  .util{background:var(--ink); color:#aebbd4; font-size:12px; padding:7px 0;}
  .util .wrap{display:flex; justify-content:space-between; align-items:center; gap:10px;}
  .util b{color:#fff; font-weight:600;}

  /* ---- NAV ---- */
  .nav{position:sticky; top:0; z-index:100; background:rgba(255,255,255,.96); backdrop-filter:blur(10px); border-bottom:1px solid var(--line);}
  .nav .inner{max-width:1140px; margin:0 auto; padding:0 32px; height:66px; display:flex; align-items:center; justify-content:space-between;}
  .logo{font-family:'Fraunces',serif; font-weight:600; font-size:25px; letter-spacing:-.01em; cursor:pointer; color:var(--ink); display:flex; align-items:baseline; gap:8px;}
  .logo .rs{font-family:'Fraunces',serif; font-weight:400; font-style:italic; font-size:25px; color:var(--accent); letter-spacing:0;}
  .logo .d{color:var(--accent);}
  .menu{display:flex; align-items:center; gap:4px; height:100%; margin-left:64px;}
  .mi{position:relative; height:100%; display:flex; align-items:center;}
  .ml{font-size:14px; font-weight:500; color:var(--ink2); padding:10px 11px; cursor:pointer; display:flex; align-items:center; gap:5px; border-radius:7px;}
  .ml:after{content:"\25BE"; font-size:11px; color:var(--muted); transform:translateY(-2px);}
  .ml.solo:after{display:none;}
  .mi:hover .ml{color:var(--accent); background:var(--accent-soft);}
  .mega{position:absolute; top:62px; left:0; min-width:300px; background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:0 18px 44px rgba(12,26,53,.14); padding:10px; opacity:0; visibility:hidden; transform:translateY(6px); transition:all .16s;}
  .mi:hover .mega{opacity:1; visibility:visible; transform:none;}
  .mega a{display:block; padding:10px 12px; border-radius:8px; cursor:pointer;}
  .mega a:hover{background:var(--bg2);}
  .mega a .t{font-size:14px; font-weight:600; color:var(--ink);}
  .mega a .d{font-size:12px; color:var(--muted); margin-top:1px;}
  .navcta{background:var(--accent); color:#fff!important; padding:10px 18px; border-radius:8px; font-size:14px; font-weight:600; cursor:pointer;}
  .navcta:hover{background:var(--accent-d);}
  .burger{display:none; flex-direction:column; gap:4px; cursor:pointer; padding:8px;}
  .burger span{width:22px; height:2px; background:var(--ink); border-radius:2px;}

  /* ---- page system ---- */
  .page{display:none; animation:fade .45s ease;}
  .page.active{display:block;}
  @keyframes fade{from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:none;}}

  /* ---- HERO ---- */
  .hero{background:linear-gradient(160deg,#10203c 0%,#1c3354 100%); color:#eef2f8; padding:84px 0 70px; position:relative; overflow:hidden;}
  .hero:before{content:""; position:absolute; right:-160px; top:-80px; width:520px; height:520px; border-radius:50%; background:radial-gradient(circle,#b07d2833,transparent 70%);}
  .hero .wrap{position:relative;}
  .eyebrow{font-size:11.5px; text-transform:uppercase; letter-spacing:.2em; color:#d8b878; font-weight:600; margin-bottom:18px;}
  .hero h1{font-weight:800; font-size:clamp(36px,5.4vw,62px); line-height:1.04; margin:0 0 20px; color:#fff; max-width:17ch;}
  .hero p.lede{font-size:18px; color:#bcc7dd; max-width:58ch; margin:0 0 30px; line-height:1.6;}
  .hbtns{display:flex; gap:13px; flex-wrap:wrap;}
  .btnP{background:var(--accent); color:#1c1305; padding:14px 26px; border-radius:9px; font-weight:700; font-size:15px; cursor:pointer; border:none;}
  .btnP:hover{background:var(--accent-d);}
  .btnG{border:1px solid #34466b; color:#dde4f0; padding:14px 24px; border-radius:9px; font-weight:500; font-size:15px; cursor:pointer; background:transparent;}
  .btnG:hover{border-color:#d8b878; color:#fff;}
  .btnP,.btnG{display:inline-block; text-decoration:none;}
  /* hero carousel */
  .carousel{position:relative; overflow:hidden; min-height:256px;}
  .slides{display:flex; transition:transform .6s cubic-bezier(.4,0,.2,1);}
  .slide{min-width:100%; padding-right:8px;}
  .dots{display:flex; gap:9px; margin-top:10px;}
  .dot{width:9px; height:9px; border-radius:50%; background:#3a4866; cursor:pointer; transition:all .25s;}
  .dot.active{background:var(--accent); width:24px; border-radius:5px;}
  /* join button */
  .navjoin{border:1px solid var(--accent); color:var(--accent)!important; padding:9px 15px; border-radius:8px; font-size:14px; font-weight:600; cursor:pointer;}
  .navjoin:hover{background:var(--accent-soft);}
  /* cookie banner (large) */
  .cookie{position:fixed; left:0; right:0; bottom:0; z-index:200; background:#fff; border-top:1px solid var(--line); box-shadow:0 -14px 44px rgba(12,26,53,.18); transform:translateY(110%); transition:transform .45s ease;}
  .cookie.show{transform:none;}
  .cookie-in{max-width:1140px; margin:0 auto; padding:26px 32px; display:flex; align-items:flex-start; justify-content:space-between; gap:44px; flex-wrap:wrap;}
  .cookie-main{flex:1; min-width:280px;}
  .cookie-h{font-family:'Archivo'; font-weight:700; font-size:18px; color:var(--ink); margin-bottom:9px;}
  .cookie-txt{font-size:13.5px; color:var(--ink2); line-height:1.65; max-width:82ch; margin:0;}
  .cookie-links{margin-top:14px; display:flex; gap:20px; flex-wrap:wrap;}
  .cookie-links a{font-size:12.5px; color:var(--accent); cursor:pointer; font-weight:500;}
  .cookie-side{display:flex; flex-direction:column; gap:16px; align-items:flex-end; min-width:230px;}
  .cookie-toggle{display:flex; align-items:center; gap:11px; font-size:13px; color:var(--ink2); cursor:pointer; text-align:right;}
  .cookie-toggle .tg{position:relative; display:inline-block; width:42px; height:22px; flex:none;}
  .cookie-toggle input{opacity:0; width:0; height:0;}
  .cookie-toggle .sl{position:absolute; inset:0; background:#cfd8e6; border-radius:22px; transition:.2s;}
  .cookie-toggle .sl:before{content:""; position:absolute; height:16px; width:16px; left:3px; top:3px; background:#fff; border-radius:50%; transition:.2s;}
  .cookie-toggle input:checked + .sl{background:var(--accent);}
  .cookie-toggle input:checked + .sl:before{transform:translateX(20px);}
  .ck-accept{background:var(--ink); color:#fff; border:none; padding:13px 46px; border-radius:8px; font-weight:600; font-size:14px; cursor:pointer; font-family:inherit;}
  .ck-accept:hover{background:var(--navy2);}
  /* video box */
  .videobox{display:block; position:relative; border-radius:16px; overflow:hidden; background:linear-gradient(135deg,#0c1a35,#1e3a6e); aspect-ratio:16/9; max-width:780px; box-shadow:0 22px 54px rgba(12,26,53,.2); cursor:pointer; text-decoration:none; margin-top:6px;}
  .videobox:before{content:""; position:absolute; right:-80px; top:-60px; width:360px; height:360px; border-radius:50%; background:radial-gradient(circle,#b07d2844,transparent 70%);}
  .vid-play{position:absolute; left:50%; top:46%; transform:translate(-50%,-50%); width:74px; height:74px; border-radius:50%; background:rgba(255,255,255,.96); color:var(--accent); display:flex; align-items:center; justify-content:center; font-size:24px; padding-left:5px; transition:transform .2s; box-shadow:0 10px 30px rgba(0,0,0,.25);}
  .videobox:hover .vid-play{transform:translate(-50%,-50%) scale(1.09);}
  .vid-cap{position:absolute; left:26px; bottom:24px; right:26px; color:#fff; font-family:'Archivo'; font-weight:600; font-size:19px; line-height:1.3;}
  .vid-tag{position:absolute; left:26px; top:22px; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#d8bd84; font-weight:600;}
  .videowrap{position:relative; width:100%; max-width:780px; aspect-ratio:16/9; border-radius:16px; overflow:hidden; box-shadow:0 22px 54px rgba(12,26,53,.2); background:#0c1a35; margin-top:6px;}
  .videowrap iframe{position:absolute; inset:0; width:100%; height:100%; border:0;}
  /* insights */
  .ins-feat{background:linear-gradient(135deg,#12223f,#243f63); color:#fff; border-radius:16px; padding:36px 38px; margin-bottom:20px; cursor:pointer; transition:transform .16s; display:block; text-decoration:none;}
  .ins-feat:hover{transform:translateY(-3px);}
  .ins-cat{font-size:11px; text-transform:uppercase; letter-spacing:.14em; font-weight:600; color:var(--accent); margin-bottom:10px;}
  .ins-feat .ins-cat{color:#e3c489;}
  .ins-feat h3{font-family:'Archivo'; font-weight:700; font-size:25px; line-height:1.2; margin:0 0 13px; color:#fff; max-width:26ch; letter-spacing:-.01em;}
  a.ins-feat p{font-size:15px; color:#e8eef8; margin:0 0 17px; max-width:72ch; line-height:1.62;}
  .ins-feat .read{color:#fff; font-weight:600; font-size:14px;}
  .icard{background:#fff; border:1px solid var(--line); border-radius:14px; padding:24px 22px; cursor:pointer; transition:transform .16s, box-shadow .16s, border-color .16s; display:block; text-decoration:none;}
  .icard:hover{transform:translateY(-4px); box-shadow:0 14px 36px rgba(18,34,63,.1); border-color:#ddcfb2;}
  .icard h3{font-family:'Archivo'; font-weight:700; font-size:17px; line-height:1.28; margin:0 0 9px; color:var(--ink); letter-spacing:-.01em;}
  .icard p{font-size:13.5px; color:var(--muted); margin:0 0 13px; line-height:1.55;}
  .icard .read{color:var(--accent); font-weight:600; font-size:13px;}
  .tags{display:flex; flex-wrap:wrap; gap:10px; margin-top:20px;}
  .tag-pill{background:var(--bg2); border:1px solid var(--line); border-radius:30px; padding:9px 16px; font-size:13.5px; color:var(--ink2); font-weight:500;}
  .secbanner{background:linear-gradient(135deg,#12223f,#243f63); border-radius:16px; padding:30px 34px; display:flex; align-items:center; gap:26px; color:#fff; flex-wrap:wrap;}
  .secbanner .sicon{flex:none; width:60px; height:60px; color:#e3c489;}
  .secbanner h2{color:#fff; margin:0;}
  div.secbanner p{color:#e8eef8; margin:7px 0 0; font-size:14.5px; line-height:1.55;}
  .nlbox{display:flex; justify-content:space-between; align-items:center; gap:30px; flex-wrap:wrap;}
  .nlform{display:flex; gap:10px; flex-wrap:wrap;}
  .nlform input[type=email]{padding:13px 16px; border:1px solid var(--line); border-radius:9px; font-size:15px; min-width:240px; font-family:inherit; background:#fff;}
  .nlform input[type=email]:focus{outline:none; border-color:var(--accent);}
  /* stats band */
  .statsband{background:var(--ink);}
  .stats{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; margin-top:18px;}
  .stat .num{font-family:'Archivo'; font-weight:800; font-size:42px; color:#fff; letter-spacing:-.02em; line-height:1;}
  .stat .lbl{font-size:12px; color:#aebbd4; margin-top:10px; text-transform:uppercase; letter-spacing:.1em;}
  @media(max-width:680px){ .stats{grid-template-columns:1fr 1fr; gap:30px 16px;} .stat .num{font-size:34px;} }

  .pipeline{display:flex; margin-top:54px; flex-wrap:wrap; border-top:1px solid #28385a; padding-top:26px; gap:0;}
  .pn{flex:1; min-width:120px; padding-right:16px; position:relative;}
  .pn .num{font-family:'Archivo'; font-weight:700; font-size:13px; color:#d8bd84;}
  .pn .nm{font-size:14px; color:#eef2f8; margin-top:4px; font-weight:600;}
  .pn .ds{font-size:12px; color:#8493b0; margin-top:2px;}
  .pn .pbar{height:3px; background:#2c3a57; border-radius:2px; margin-top:10px; position:relative; overflow:hidden;}
  .pn .pbar:after{content:""; position:absolute; left:0; top:0; height:100%; width:0; background:linear-gradient(90deg,#b07d28,#d8b878); transition:width .55s ease;}
  .pn.active .pbar:after{width:100%;}
  .pn.active .nm{color:#fff;}
  .pn.active .num{color:#d8b878;}
  .pn.active .ds{color:#aab8d4;}
  .pn:not(:last-child):after{content:"→"; position:absolute; right:8px; top:0; color:#3c4f74; font-size:14px;}

  /* ---- inner page head ---- */
  .phead{background:radial-gradient(820px 320px at 88% -20%, rgba(176,125,40,0.24), transparent 62%), linear-gradient(to right, rgba(255,255,255,0.07) 1px, transparent 1px) 0 0/52px 52px, linear-gradient(to bottom, rgba(255,255,255,0.07) 1px, transparent 1px) 0 0/52px 52px, linear-gradient(160deg,#0c1a35,#16284a); color:#eef2f8; padding:60px 0 48px;}
  .phead h1{font-weight:800; font-size:clamp(32px,4.4vw,48px); line-height:1.06; margin:12px 0 14px; color:#fff; max-width:18ch;}
  .phead p{font-size:17px; color:#bcc7dd; max-width:60ch; margin:0; line-height:1.6;}

  /* ---- sections ---- */
  .sec{padding:66px 0;}
  .sec.grey{background-color:var(--bg2); background-image:linear-gradient(to right, rgba(18,34,63,0.06) 1px, transparent 1px), linear-gradient(to bottom, rgba(18,34,63,0.06) 1px, transparent 1px); background-size:52px 52px; border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
  .kick{font-size:11.5px; text-transform:uppercase; letter-spacing:.16em; color:var(--accent); font-weight:600; margin-bottom:10px;}
  .sec h2{font-weight:700; font-size:30px; line-height:1.12; margin:0 0 10px;}
  .lead{color:var(--muted); font-size:16px; max-width:62ch; margin:0 0 36px; line-height:1.6;}
  .sec p{font-size:15.5px; color:var(--ink2); margin:0 0 15px; max-width:68ch; line-height:1.65;}
  .sec h3{font-weight:700; font-size:19px; margin:30px 0 10px;}

  .grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
  .grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:20px;}
  .card{background:#fff; border:1px solid var(--line); border-radius:14px; padding:26px 24px; cursor:pointer; transition:transform .16s,box-shadow .16s,border-color .16s;}
  .card:hover{transform:translateY(-4px); box-shadow:0 14px 36px rgba(12,26,53,.1); border-color:#cdd9ec;}
  .card .ic{width:38px; height:38px; border-radius:10px; background:var(--accent-soft); color:var(--accent); display:flex; align-items:center; justify-content:center; font-family:'Archivo'; font-weight:700; font-size:16px; margin-bottom:15px;}
  .card h3{font-size:18px; margin:0 0 8px;}
  .card p{font-size:13.5px; color:var(--muted); margin:0 0 13px; line-height:1.55;}
  .card .more{font-size:13px; color:var(--accent); font-weight:600;}

  .twocol{display:grid; grid-template-columns:1.35fr 1fr; gap:44px; align-items:start;}
  .panel{background:var(--bg2); border:1px solid var(--line); border-radius:14px; padding:26px;}
  .panel h4{font-weight:700; font-size:16px; margin:0 0 14px;}
  .checks{list-style:none; padding:0; margin:0;}
  .checks li{display:flex; gap:11px; align-items:flex-start; margin-bottom:12px; font-size:14.5px; color:var(--ink2); line-height:1.5;}
  .checks .c{flex:none; width:20px; height:20px; border-radius:50%; background:var(--accent); color:#fff; font-size:11px; font-weight:700; display:flex; align-items:center; justify-content:center; margin-top:2px;}

  .why{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
  .why .item .tick{width:40px; height:40px; border-radius:11px; background:var(--ink); color:#fff; display:flex; align-items:center; justify-content:center; font-size:17px; margin-bottom:13px;}
  .why .item h4{font-size:16px; margin:0 0 6px;}
  .why .item p{font-size:14px; color:var(--muted); margin:0; line-height:1.55;}

  .steps{display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--line); border-radius:14px; overflow:hidden; background:#fff;}
  .step{padding:24px 22px; border-right:1px solid var(--line);}
  .step:last-child{border-right:none;}
  .step .n{font-family:'Archivo'; color:var(--accent); font-weight:700; font-size:22px;}
  .step h4{font-size:15px; margin:9px 0 5px;}
  .step p{font-size:13px; color:var(--muted); margin:0; line-height:1.5;}

  .ctaband{background:linear-gradient(135deg,#0c1a35,#1e3a6e); color:#fff; border-radius:18px; padding:46px 48px; display:flex; justify-content:space-between; align-items:center; gap:26px; flex-wrap:wrap;}
  .ctaband h3{font-weight:700; font-size:27px; margin:0 0 8px;}
  .ctaband p{color:#c0cbe0; font-size:15px; margin:0; max-width:46ch;}

  .formgrid{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
  .field label{display:block; font-size:12px; text-transform:uppercase; letter-spacing:.08em; font-weight:600; color:var(--ink2); margin-bottom:6px;}
  .field input,.field textarea{width:100%; border:1px solid var(--line); border-radius:9px; padding:12px 14px; font-family:inherit; font-size:14px; background:#fff;}
  .field input:focus,.field textarea:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft);}
  .field.full{grid-column:1/-1;}
  .formnote{font-size:12.5px; color:var(--muted); margin-top:10px;}

  /* ---- live data cleaning demo ---- */
  .cleanwrap{background:#0c1a35; border-radius:16px; padding:22px 22px 20px; color:#e8edf6; box-shadow:0 20px 50px rgba(12,26,53,.2);}
  .cleanhead{display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; flex-wrap:wrap; gap:8px;}
  .cl-title{font-family:'Archivo'; font-weight:700; font-size:15px; color:#fff; display:flex; align-items:center; gap:9px;}
  .cl-live{width:8px; height:8px; border-radius:50%; background:#3ad07f; animation:pulse 1.4s infinite;}
  @keyframes pulse{0%{box-shadow:0 0 0 0 #3ad07f88;}70%{box-shadow:0 0 0 8px #3ad07f00;}100%{box-shadow:0 0 0 0 #3ad07f00;}}
  .cl-stat{font-size:12.5px; color:#9fb0d0; font-variant-numeric:tabular-nums;}
  .cl-row{display:grid; grid-template-columns:56px 42px 74px 1fr 104px; gap:8px; align-items:center; padding:9px 10px; border-radius:8px; background:#13284a; margin-bottom:6px; transition:opacity .5s,transform .5s,height .5s,padding .5s,margin .5s,background .3s,box-shadow .2s; font-size:12.5px;}
  .cl-row.head{background:transparent; color:#7e90b4; font-size:10.5px; text-transform:uppercase; letter-spacing:.07em; padding:2px 10px; margin-bottom:5px;}
  .cl-row.scanning{box-shadow:0 0 0 2px #b07d28; background:#16335f;}
  .cl-row.bad{background:#3a1d29;}
  .cl-row.fixed{background:#143524;}
  .cl-row.removing{opacity:0; transform:translateX(24px); height:0; padding-top:0; padding-bottom:0; margin:0;}
  .cl-cell{white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:#dbe3f1;}
  .cl-tag{font-size:10.5px; font-weight:600; padding:3px 8px; border-radius:5px; display:inline-block;}
  .cl-tag.ok{background:#15402c; color:#62dd9c;}
  .cl-tag.flag{background:#5a2230; color:#ff9aa6;}
  .cl-tag.fix{background:#163a6b; color:#d8bd84;}
  .cl-tag.pending{color:#6b7c9e;}
  .cl-foot{display:flex; justify-content:space-between; align-items:center; margin-top:13px; padding-top:12px; border-top:1px solid #20355c; font-size:12.5px; color:#9fb0d0; flex-wrap:wrap; gap:6px;}
  .cl-quality{font-weight:700; color:#62dd9c;}
  .cd-row{display:grid; grid-template-columns:1fr 150px 96px; gap:8px; align-items:center; padding:9px 10px; border-radius:8px; background:#13284a; margin-bottom:6px; transition:background .3s,box-shadow .2s; font-size:12.5px;}
  .cd-row.head{background:transparent; color:#7e90b4; font-size:10.5px; text-transform:uppercase; letter-spacing:.07em; padding:2px 10px; margin-bottom:5px;}
  .cd-row.scanning{box-shadow:0 0 0 2px #b07d28; background:#16335f;}
  .cd-verb{color:#dbe3f1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-style:italic;}
  .cl-row.g-sp{grid-template-columns:62px 1fr 124px;}
  .cl-row.g-2{grid-template-columns:1fr 118px;}
  /* report chart */
  .rp-bar{display:grid; grid-template-columns:118px 1fr 46px; gap:10px; align-items:center; margin-bottom:11px; font-size:12.5px; color:#dbe3f1;}
  .rp-track{height:14px; background:#13284a; border-radius:7px; overflow:hidden;}
  .rp-fill{height:100%; width:0; background:linear-gradient(90deg,#b07d28,#cda14f); border-radius:7px; transition:width 1.1s cubic-bezier(.2,.7,.2,1);}
  .rp-val{text-align:right; color:#9fb0d0; font-variant-numeric:tabular-nums;}
  .cd-bars{margin-top:14px; padding-top:14px; border-top:1px solid #20355c;}
  .cd-bars .lbl{font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:#7e90b4; margin-bottom:10px;}
  /* FAQ */
  .faq{border:1px solid var(--line); border-radius:12px; overflow:hidden; background:#fff;}
  .faq-item{border-bottom:1px solid var(--line);}
  .faq-item:last-child{border-bottom:none;}
  .faq-q{padding:17px 20px; font-weight:600; font-size:15px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:12px; color:var(--ink);}
  .faq-q:after{content:"+"; color:var(--accent); font-size:20px; font-weight:400;}
  .faq-item.open .faq-q:after{content:"–";}
  .faq-a{max-height:0; overflow:hidden; transition:max-height .3s ease, padding .3s ease; padding:0 20px; font-size:14.5px; color:var(--ink2); line-height:1.6;}
  .faq-item.open .faq-a{max-height:240px; padding:0 20px 18px;}

  /* ---- footer ---- */
  .footer{background:var(--ink); color:#9fadc8; padding:56px 0 30px;}
  .footer .top{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:30px;}
  .footer .logo{color:#fff; margin-bottom:12px;}
  .footer p{font-size:13.5px; color:#8c9bb8; max-width:32ch; margin:0; line-height:1.6;}
  .footer h5{color:#fff; font-size:12px; text-transform:uppercase; letter-spacing:.1em; margin:0 0 14px;}
  .footer a{display:block; font-size:13.5px; color:#9fadc8; margin-bottom:9px; cursor:pointer;}
  .footer a:hover{color:#d8bd84;}
  .footbar{border-top:1px solid #243352; margin-top:38px; padding-top:20px; font-size:12.5px; color:#728099; text-align:center;}

  @media(max-width:920px){
    .menu{display:none; position:absolute; top:66px; left:0; right:0; background:#fff; flex-direction:column; align-items:stretch; height:auto; padding:14px 20px; border-bottom:1px solid var(--line); box-shadow:0 14px 30px rgba(0,0,0,.08); gap:0;}
    .menu.open{display:flex;}
    .mi{height:auto; flex-direction:column; align-items:stretch; border-bottom:1px solid var(--line);}
    .mega{position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:none; padding:0 0 8px 12px; display:none; min-width:auto;}
    .mi.open .mega{display:block;}
    .ml{padding:14px 6px;}
    .burger{display:flex;}
    .grid3,.grid2,.twocol,.why,.steps,.formgrid,.footer .top,.util .wrap{grid-template-columns:1fr;}
    .util .wrap{display:none;}
    .step{border-right:none; border-bottom:1px solid var(--line);}
    .step:last-child{border-bottom:none;}
    .pn:not(:last-child):after{display:none;}
    .ctaband{padding:32px 26px;}
  }