/* ============================================================
   Header (Themify) — match new design: solid bar, even spacing
   ============================================================ */
#headerwrap{background:#fff !important;border-bottom:1px solid #e6e9f2 !important;box-shadow:0 4px 22px rgba(13,20,50,.05) !important}
#headerwrap #header{padding-top:15px !important;padding-bottom:15px !important}
.main-nav{font-family:"Space Grotesk",-apple-system,BlinkMacSystemFont,sans-serif !important}
.main-nav > li{margin:0 !important}
.main-nav > li > a{
	font-size:15px !important;font-weight:500 !important;color:#1c2533 !important;
	padding:9px 16px !important;letter-spacing:.005em !important;text-transform:none !important;
	border-radius:8px;transition:color .15s,background .15s;
}
.main-nav > li > a:hover{color:#0057e7 !important;background:transparent !important}
.main-nav > li.current-menu-item > a,
.main-nav > li.current_page_item > a,
.main-nav > li.current-menu-parent > a{color:#0057e7 !important}
/* Email Login → clean branded button, consistent with everything else */
.main-nav > li.highlight-link > a{
	background:#0057e7 !important;color:#fff !important;border-radius:9px !important;
	padding:10px 20px !important;margin-left:10px !important;
}
.main-nav > li.highlight-link > a:hover{background:#151ca1 !important;color:#fff !important}
/* dropdown menus restyled to match */
.main-nav .sub-menu{border-radius:12px !important;box-shadow:0 18px 44px rgba(13,20,50,.15) !important;border:1px solid #e6e9f2 !important;padding:8px !important;background:#fff !important}
.main-nav .sub-menu li a{font-family:"Space Grotesk",sans-serif !important;font-size:14px !important;color:#1c2533 !important;border-radius:7px !important;padding:9px 14px !important}
.main-nav .sub-menu li a:hover{background:#f4f6fb !important;color:#0057e7 !important}

/* ============================================================
   Computer Geeks — design system v2
   Real brand palette + real typography + editorial/photo layouts.
   Brand colors from CG Color Palette 2026.
   ============================================================ */
.cg{
	--blue:#0057e7;      /* bright primary */
	--royal:#151ca1;     /* deep royal (logo) */
	--navy:#2e2f4b;      /* dark slate */
	--ink:#0d0d0d;       /* near-black */
	--teal:#00bfa6;      /* accent */
	--orange:#ff8c42;    /* accent / CTA */
	--amber:#ffc107;     /* accent */
	--paper:#f4f6fb;
	--line:#e6e9f2;
	--muted:#5a6273;
	--display:"Space Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
	--sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
	font-family:var(--sans);color:var(--ink);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;
}
.cg *{box-sizing:border-box}
.cg img{max-width:100%;display:block}
.cg a{text-decoration:none;color:inherit}
.cg-wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.cg-section{padding:88px 0}
.cg-section--tight{padding:64px 0}

/* type */
.cg h1,.cg h2,.cg h3{font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.04;margin:0}
.cg-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:18px}
.cg-eyebrow::before{content:"";width:26px;height:2px;background:var(--orange);display:inline-block}
.cg-h2{font-size:clamp(30px,4vw,46px)}
.cg-lead{font-size:19px;color:var(--muted);max-width:660px;margin:18px 0 0;line-height:1.6}
.cg-kicker{color:var(--blue)}

/* buttons */
.cg-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:16px;padding:15px 30px;border-radius:10px;transition:transform .12s,box-shadow .12s,background .12s;cursor:pointer}
.cg-btn svg{width:18px;height:18px}
.cg-btn--primary{background:var(--orange);color:#1a1205;box-shadow:0 10px 24px rgba(255,140,66,.32)}
.cg-btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(255,140,66,.42);color:#1a1205}
.cg-btn--dark{background:var(--ink);color:#fff}
.cg-btn--dark:hover{transform:translateY(-2px);color:#fff}
.cg-btn--ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.cg-btn--ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.cg-btn--outline{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.cg-btn--outline:hover{border-color:var(--blue);color:var(--blue)}

/* ---- HERO: editorial split with real photo ---- */
.cg-hero{display:grid;grid-template-columns:1.02fr .98fr;min-height:600px;background:linear-gradient(135deg,#151ca1 0%,#2e2f4b 52%,#0d0d0d 100%)}
.cg-hero__left{display:flex;flex-direction:column;justify-content:center;padding:84px clamp(28px,5vw,90px);color:#fff;position:relative}
.cg-hero__left .cg-eyebrow{color:#7fb0ff}
.cg-hero h1{font-size:clamp(40px,6vw,76px);color:#fff}
.cg-hero h1 .hl{color:var(--orange)}
.cg-hero__sub{font-size:20px;color:#c4ccdb;margin:24px 0 0;max-width:520px;line-height:1.55}
.cg-hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.cg-hero__trust{display:flex;align-items:center;gap:12px;margin-top:34px;color:#aeb6c6;font-size:15px}
.cg-hero__stars{display:flex;gap:3px;color:var(--amber)}
.cg-hero__stars svg{width:18px;height:18px;fill:var(--amber);stroke:none}
.cg-hero__right{position:relative;overflow:hidden;background:var(--navy)}
.cg-hero__right img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cg-hero__badge{position:absolute;left:28px;bottom:28px;z-index:2;background:rgba(13,13,13,.78);backdrop-filter:blur(6px);color:#fff;padding:14px 20px;border-radius:12px;font-family:var(--display);font-weight:600;display:flex;align-items:center;gap:12px;font-size:15px}
.cg-hero__badge b{color:var(--orange)}

/* ---- BRIGHT hero (homepage) ---- */
.cg-herolite{position:relative;background:linear-gradient(180deg,#f4f8ff 0%,#fff 78%);padding:clamp(54px,7vw,104px) 0 clamp(50px,6vw,92px);overflow:hidden}
.cg-herolite::before{content:"";position:absolute;top:-260px;right:-200px;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(0,87,231,.10),transparent 68%);pointer-events:none}
.cg-herolite .cg-wrap{position:relative;z-index:2}
.cg-herolite__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(40px,5vw,80px);align-items:center}
.cg-herolite h1{font-size:clamp(44px,6.6vw,82px);color:var(--ink);line-height:1;letter-spacing:-.035em;font-weight:700}
.cg-herolite h1 .hl{color:var(--blue)}
.cg-herolite__sub{font-size:20px;color:var(--muted);margin:26px 0 0;max-width:530px;line-height:1.55}
.cg-herolite__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.cg-herolite__trust{display:flex;align-items:center;gap:13px;margin-top:30px;color:var(--muted);font-size:15px;font-weight:500}
.cg-herolite__media{position:relative;max-width:470px;margin-left:auto}
.cg-herolite__media img.shot{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:24px;box-shadow:0 40px 80px -20px rgba(13,20,50,.34);position:relative;z-index:2}
.cg-herolite__frame{position:absolute;inset:-10px;border:1px solid rgba(0,87,231,.18);border-radius:30px;z-index:1}
/* floating trust card */
.cg-herolite__card{position:absolute;left:-30px;bottom:34px;z-index:4;background:#fff;border-radius:16px;box-shadow:0 26px 56px -12px rgba(13,20,50,.28);padding:14px 18px;display:flex;align-items:center;gap:13px;max-width:264px}
.cg-herolite__card .av{width:46px;height:46px;border-radius:12px;object-fit:cover;flex:0 0 auto}
.cg-herolite__card .stars{display:flex;gap:2px;margin-bottom:3px}
.cg-herolite__card .stars svg{width:14px;height:14px;fill:var(--amber);stroke:none}
.cg-herolite__card b{font-family:var(--display);font-size:13.5px;display:block;line-height:1.2}
.cg-herolite__card span{font-size:12px;color:var(--muted);display:block;margin-top:2px}
@media(max-width:900px){.cg-herolite__grid{grid-template-columns:1fr;gap:48px}.cg-herolite__media{margin:0 auto}.cg-herolite__card{left:0}}

/* photo-free hero panel (branded gradient + big icon) — for service pages */
.cg-herolite__panel{position:relative;aspect-ratio:1/1;max-width:460px;margin-left:auto;border-radius:28px;background:linear-gradient(140deg,#0057e7 0%,#151ca1 68%,#2e2f4b 100%);box-shadow:0 40px 80px -22px rgba(0,87,231,.45);display:flex;align-items:center;justify-content:center;overflow:hidden}
.cg-herolite__panel::before{content:"";position:absolute;top:-28%;right:-18%;width:72%;height:72%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 64%)}
.cg-herolite__panel::after{content:"";position:absolute;bottom:-24%;left:-16%;width:60%;height:60%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 66%)}
.cg-herolite__panel .pico{position:relative;z-index:2;width:38%;height:38%}
.cg-herolite__panel .pico svg{width:100%;height:100%;color:#fff;opacity:.96}
.cg-herolite__chip{position:absolute;z-index:3;left:-26px;bottom:36px;background:#fff;color:var(--ink);border-radius:14px;box-shadow:0 26px 52px -14px rgba(13,20,50,.32);padding:13px 18px;font-family:var(--display);font-weight:600;font-size:14px;display:flex;align-items:center;gap:10px}
.cg-herolite__chip svg{width:20px;height:20px;color:var(--blue);flex:0 0 auto}
@media(max-width:900px){.cg-herolite__panel{margin:0 auto}.cg-herolite__chip{left:0}}

/* trust / certification bar under hero */
.cg-trustbar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;padding:26px 0}
.cg-trustbar__inner{display:flex;align-items:center;justify-content:center;gap:clamp(22px,4vw,52px);flex-wrap:wrap}
.cg-trustbar__lbl{font-family:var(--display);font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#9aa3b5;flex:0 0 auto}
.cg-trustbar__logos{display:flex;align-items:center;gap:clamp(22px,3.4vw,40px);flex-wrap:wrap;justify-content:center}
.cg-trustbar__logos img{height:32px;width:auto;opacity:.5;filter:grayscale(1);transition:opacity .2s,filter .2s}
.cg-trustbar__logos img:hover{opacity:1;filter:none}

/* ---- service tiles (4x2 grid, last cell = CTA) ---- */
.cg-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px}
.cg-tile{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 24px;min-height:150px;display:flex;flex-direction:column;gap:16px;transition:transform .16s,box-shadow .16s,border-color .16s}
.cg-tile:hover{transform:translateY(-6px);box-shadow:0 22px 46px -12px rgba(13,20,50,.2);border-color:#cfe0ff}
.cg-tile__ico{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;background:linear-gradient(140deg,#1f6bff 0%,#0a4fd6 48%,#151ca1 100%);color:#fff;box-shadow:0 14px 24px -8px rgba(0,87,231,.55),inset 0 1px 0 rgba(255,255,255,.32),inset 0 0 0 1px rgba(255,255,255,.06);transition:box-shadow .16s,transform .16s}
.cg-tile__ico svg{width:27px;height:27px;filter:drop-shadow(0 1px 1px rgba(0,30,90,.35))}
.cg-tile:hover .cg-tile__ico{box-shadow:0 18px 30px -8px rgba(0,87,231,.7),inset 0 1px 0 rgba(255,255,255,.32);transform:translateY(-1px)}
.cg-tile h3{font-family:var(--display);font-size:17.5px;margin:0;line-height:1.25}
.cg-tile__arrow{margin-top:auto;color:#c2cbda;display:flex}
.cg-tile__arrow svg{width:19px;height:19px;transition:transform .16s,color .16s}
.cg-tile:hover .cg-tile__arrow svg{color:var(--blue);transform:translateX(4px)}
.cg-tile--cta{background:linear-gradient(140deg,#0057e7,#151ca1);color:#fff;justify-content:space-between;border:0}
.cg-tile--cta:hover{transform:translateY(-6px);box-shadow:0 22px 46px -12px rgba(0,87,231,.5)}
.cg-tile--cta .small{color:#bcd2ff;font-size:13.5px}
.cg-tile--cta .lbl{font-family:var(--display);font-weight:600;font-size:18px;color:#fff;display:inline-flex;align-items:center;gap:9px}
.cg-tile--cta .lbl svg{width:18px;height:18px}
@media(max-width:980px){.cg-tiles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cg-tiles{grid-template-columns:1fr}}

/* ---- solid dark hero (inner pages: services hub, category, about) ---- */
.cg-hed{background:var(--ink);color:#fff;padding:clamp(84px,10vw,124px) 0 clamp(76px,9vw,108px);position:relative;overflow:hidden}
.cg-hed::after{content:"";position:absolute;right:-160px;top:-160px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle at center,rgba(0,87,231,.32),transparent 64%)}
.cg-hed .cg-wrap{position:relative;z-index:2}
.cg-hed .cg-eyebrow{color:#7fb0ff}
.cg-hed h1{font-size:clamp(38px,5.5vw,68px);color:#fff;max-width:900px}
.cg-hed p{font-size:20px;color:#c4ccdb;max-width:640px;margin:22px 0 0;line-height:1.55}
.cg-hed__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}

/* ---- stat / trust strip ---- */
.cg-strip{background:var(--royal);color:#fff}
.cg-strip__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.cg-strip__i{padding:30px 26px;display:flex;flex-direction:column;gap:4px;border-left:1px solid rgba(255,255,255,.12)}
.cg-strip__i:first-child{border-left:0}
.cg-strip__i b{font-family:var(--display);font-size:30px;font-weight:700;line-height:1}
.cg-strip__i span{font-size:14px;color:#c9d2ee}

/* ---- service / feature cards ---- */
.cg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px}
.cg-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px 28px;transition:transform .15s,box-shadow .15s,border-color .15s;position:relative;overflow:hidden}
.cg-card::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--ac,var(--blue));transform:scaleX(0);transform-origin:left;transition:transform .2s}
.cg-card:hover{transform:translateY(-5px);box-shadow:0 22px 50px rgba(13,20,50,.12);border-color:transparent}
.cg-card:hover::before{transform:scaleX(1)}
.cg-ico{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(140deg,#1f6bff 0%,#0a4fd6 48%,#151ca1 100%);color:#fff;margin-bottom:20px;box-shadow:0 14px 26px -8px rgba(0,87,231,.5),inset 0 1px 0 rgba(255,255,255,.32),inset 0 0 0 1px rgba(255,255,255,.06)}
.cg-ico svg{width:28px;height:28px;filter:drop-shadow(0 1px 1px rgba(0,30,90,.35))}
.cg-card h3{font-size:21px;margin-bottom:9px}
.cg-card p{margin:0;color:var(--muted);font-size:15.5px;line-height:1.55}
.cg-more{display:inline-flex;align-items:center;gap:7px;margin-top:18px;color:var(--ac,var(--blue));font-family:var(--display);font-weight:600;font-size:14.5px}
.cg-more svg{width:16px;height:16px}
.cg-card:hover .cg-more{gap:11px}

/* ---- simple service pills (neutral, understated) ---- */
.cg-simple{display:flex;flex-wrap:wrap;gap:12px;margin-top:38px}
.cg-simple__item{font-family:var(--display);font-weight:600;font-size:16px;padding:12px 22px;border:1px solid var(--line);border-radius:999px;color:var(--ink);transition:border-color .15s,color .15s,background .15s}
.cg-simple__item:hover{border-color:var(--blue);color:var(--blue);background:#f4f8ff}

/* ---- numbered editorial service index (no icons / no AI chips) ---- */
.cg-nsvc{margin-top:48px;border-top:2px solid var(--ink)}
.cg-nsvc__row{display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:center;padding:28px 10px;border-bottom:1px solid var(--line);transition:padding .2s,background .2s}
.cg-nsvc__row:hover{background:linear-gradient(90deg,rgba(0,87,231,.05),transparent 80%);padding-left:24px}
.cg-nsvc__num{font-family:var(--display);font-weight:700;font-size:clamp(30px,3.4vw,46px);line-height:1;letter-spacing:-.02em;color:transparent;-webkit-text-stroke:1.4px #c4cdda;min-width:62px;transition:color .2s,-webkit-text-stroke-color .2s}
.cg-nsvc__row:hover .cg-nsvc__num{color:var(--blue);-webkit-text-stroke-color:var(--blue)}
.cg-nsvc__body h3{font-family:var(--display);font-weight:700;font-size:clamp(20px,2.5vw,28px);letter-spacing:-.02em;margin:0 0 3px;line-height:1.1}
.cg-nsvc__body p{margin:0;color:var(--muted);font-size:15.5px;max-width:580px;line-height:1.5}
.cg-nsvc__go{color:#c4cdda;display:flex;transition:color .2s,transform .2s}
.cg-nsvc__go svg{width:26px;height:26px}
.cg-nsvc__row:hover .cg-nsvc__go{color:var(--blue);transform:translateX(7px)}
@media(max-width:700px){.cg-nsvc__row{grid-template-columns:auto 1fr;gap:20px;padding:22px 6px}.cg-nsvc__go{display:none}.cg-nsvc__num{min-width:48px}}

/* ---- editorial service list (intro + divided rows) ---- */
.cg-svc{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(40px,5vw,72px);align-items:start}
.cg-svc__intro{position:sticky;top:96px}
.cg-svc__list{border-top:1px solid var(--line)}
.cg-svc__row{display:flex;gap:18px;align-items:center;padding:21px 16px;border-bottom:1px solid var(--line);transition:background .15s}
.cg-svc__row:hover{background:var(--paper)}
.cg-svc__ico{flex:0 0 auto;color:var(--ac,var(--blue));display:flex}
.cg-svc__ico svg{width:27px;height:27px}
.cg-svc__txt{flex:1;min-width:0}
.cg-svc__txt h3{font-family:var(--display);font-size:18.5px;margin:0 0 2px}
.cg-svc__txt p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.5}
.cg-svc__go{flex:0 0 auto;color:#aab2c2;display:flex;transition:transform .15s,color .15s}
.cg-svc__go svg{width:20px;height:20px}
.cg-svc__row:hover .cg-svc__go{color:var(--ac,var(--blue));transform:translateX(5px)}
@media(max-width:900px){.cg-svc{grid-template-columns:1fr;gap:28px}.cg-svc__intro{position:static}}

/* ---- photo band (text + real photo) ---- */
.cg-band{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;gap:0}
.cg-band--rev .cg-band__media{order:2}
.cg-band__media{position:relative;min-height:460px;overflow:hidden;background:var(--navy)}
.cg-band__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cg-band__body{padding:clamp(40px,6vw,88px);display:flex;flex-direction:column;justify-content:center}
.cg-band--dark{background:var(--ink);color:#fff}
.cg-band--dark .cg-lead{color:#bcc4d4}
.cg-band--paper{background:var(--paper)}
.cg-tag{position:absolute;z-index:2;left:24px;bottom:24px;background:#fff;color:var(--ink);font-family:var(--display);font-weight:600;font-size:14px;padding:11px 18px;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.cg-tag b{color:var(--blue)}

/* ---- checklist ---- */
.cg-checks{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;margin-top:30px;padding:0;list-style:none}
.cg-checks li{display:flex;gap:13px;align-items:flex-start;font-weight:500;font-size:16px}
.cg-checks .ck{flex:0 0 auto;width:27px;height:27px;border-radius:8px;background:linear-gradient(140deg,#1f6bff,#151ca1);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 12px -4px rgba(0,87,231,.55),inset 0 1px 0 rgba(255,255,255,.3)}
.cg-checks .ck svg{width:15px;height:15px}

/* ---- certifications ---- */
.cg-certs{text-align:center}
.cg-logos{display:grid;grid-template-columns:repeat(7,1fr);gap:16px;margin-top:40px;align-items:center}
.cg-logo{background:#fff;border:1px solid var(--line);border-radius:12px;height:92px;display:flex;align-items:center;justify-content:center;padding:16px;transition:box-shadow .15s,transform .15s}
.cg-logo:hover{box-shadow:0 12px 26px rgba(13,20,50,.1);transform:translateY(-3px)}
.cg-logo img{max-width:100%;max-height:56px;width:auto;object-fit:contain}

/* ---- team ---- */
.cg-team{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center;margin-top:6px}
.cg-team__photo{border-radius:18px;overflow:hidden;box-shadow:0 26px 60px rgba(13,20,50,.2);aspect-ratio:4/5;background:var(--paper)}
.cg-team__photo img{width:100%;height:100%;object-fit:cover}
.cg-names{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}
.cg-names span{font-family:var(--display);font-weight:600;font-size:14.5px;border-radius:999px;padding:9px 18px;background:var(--paper);border:1px solid var(--line)}
.cg-names .dog{background:color-mix(in srgb,var(--amber) 22%,#fff);border-color:transparent}

/* ---- verse ---- */
.cg-verse{background:var(--navy);color:#fff;text-align:center}
.cg-verse blockquote{max-width:780px;margin:0 auto;font-family:var(--display);font-size:clamp(24px,3vw,32px);line-height:1.45;font-weight:500;letter-spacing:-.01em}
.cg-verse cite{display:block;margin-top:22px;font-style:normal;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);font-weight:600;font-family:var(--display)}

/* ---- CTA (flat, confident) ---- */
.cg-cta{background:var(--ink);color:#fff;text-align:center}
.cg-cta--brand{background:linear-gradient(135deg,#0057e7 0%,#151ca1 58%,#2e2f4b 100%);position:relative;overflow:hidden}
.cg-cta--brand::before{content:"";position:absolute;top:-180px;right:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 65%);pointer-events:none}
.cg-cta--brand .cg-wrap{position:relative;z-index:2}
.cg-cta h2{font-size:clamp(30px,4vw,46px);color:#fff}
.cg-cta p{font-size:19px;color:#bcc4d4;margin:16px auto 0;max-width:560px}
.cg-cta__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px}

/* split (generic two-col content) */
.cg-split{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.cg-split__media{border-radius:18px;overflow:hidden;box-shadow:0 24px 56px rgba(13,20,50,.16);aspect-ratio:4/3;background:var(--paper)}
.cg-split__media img{width:100%;height:100%;object-fit:cover}

.cg-alt{background:var(--paper)}

/* responsive */
@media(max-width:1000px){.cg-logos{grid-template-columns:repeat(4,1fr)}}
@media(max-width:900px){
	.cg-hero{grid-template-columns:1fr}
	.cg-hero__right{min-height:360px}
	.cg-hero__right img{position:absolute}
	.cg-strip__grid{grid-template-columns:repeat(2,1fr)}
	.cg-strip__i:nth-child(-n+2){border-bottom:1px solid rgba(255,255,255,.12)}
	.cg-strip__i:nth-child(odd){border-left:0}
	.cg-grid,.cg-checks{grid-template-columns:1fr}
	.cg-band,.cg-band--rev .cg-band__media,.cg-split,.cg-team{grid-template-columns:1fr}
	.cg-band--rev .cg-band__media{order:0}
	.cg-band__media,.cg-team__photo{min-height:320px;aspect-ratio:auto;height:340px}
	.cg-logos{grid-template-columns:repeat(3,1fr)}
}

/* ============================================================
   Homepage v3 — MSP-grade structure: stat strip, service tiles
   with copy, "how it works" process, testimonials/reviews.
   ============================================================ */

/* service tiles now carry a one-line descriptor */
.cg-tile{min-height:auto}
.cg-tile p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.cg-tile h3{margin-bottom:2px}

/* section heading helper (centered intro) */
.cg-center{text-align:center;max-width:680px;margin:0 auto}
.cg-center .cg-eyebrow{justify-content:center}
.cg-center .cg-lead{margin-left:auto;margin-right:auto}

/* ---- How it works: numbered process ---- */
.cg-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;position:relative}
.cg-step{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:36px 30px 30px;transition:transform .15s,box-shadow .15s}
.cg-step:hover{transform:translateY(-5px);box-shadow:0 22px 50px rgba(13,20,50,.1)}
.cg-step__n{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:20px;color:#fff;background:linear-gradient(140deg,#1f6bff,#151ca1);box-shadow:0 12px 22px -8px rgba(0,87,231,.55),inset 0 1px 0 rgba(255,255,255,.3);margin-bottom:22px}
.cg-step h3{font-family:var(--display);font-size:20px;margin:0 0 9px}
.cg-step p{margin:0;color:var(--muted);font-size:15.5px;line-height:1.55}
.cg-step__line{display:none}
@media(min-width:760px){
	.cg-step:not(:last-child)::after{content:"";position:absolute;top:59px;right:-13px;width:14px;height:2px;background:#cdd6e6;z-index:2}
}

/* ---- Testimonials / reviews ---- */
.cg-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.cg-quote{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 28px;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.cg-quote:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(13,20,50,.1)}
.cg-quote__stars{display:flex;gap:3px;margin-bottom:16px}
.cg-quote__stars svg{width:18px;height:18px;fill:var(--amber);stroke:none}
.cg-quote p{margin:0 0 22px;font-size:16px;line-height:1.6;color:#2b3242}
.cg-quote__by{margin-top:auto;display:flex;align-items:center;gap:13px}
.cg-quote__av{width:44px;height:44px;border-radius:12px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:16px;color:#fff;background:linear-gradient(140deg,#1f6bff,#151ca1)}
.cg-quote__by b{font-family:var(--display);font-size:15px;display:block;line-height:1.2}
.cg-quote__by span{font-size:13px;color:var(--muted);display:block;margin-top:2px}
.cg-reviews-cta{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:34px;font-family:var(--display);font-weight:600;color:var(--muted);font-size:15px;flex-wrap:wrap}
.cg-reviews-cta .g-stars{display:inline-flex;gap:2px;color:var(--amber)}
.cg-reviews-cta .g-stars svg{width:16px;height:16px;fill:var(--amber);stroke:none}

@media(max-width:880px){
	.cg-steps,.cg-quotes{grid-template-columns:1fr}
	.cg-step:not(:last-child)::after{display:none}
}

/* ============================================================
   Homepage v4 — premium TOTAL rebuild.
   Dark hero + glass status panel, scrolling logo marquee,
   bento service grid, big-number impact band.
   ============================================================ */

/* ---- dark premium hero ---- */
.cg-phero{position:relative;background:radial-gradient(125% 120% at 78% -10%,#26309e 0%,#171d8f 24%,#141743 52%,#0a0b1f 100%);color:#fff;overflow:hidden;padding:clamp(64px,8vw,118px) 0 clamp(58px,7vw,100px)}
.cg-phero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1.4px);background-size:24px 24px;-webkit-mask-image:radial-gradient(120% 85% at 50% 0%,#000 36%,transparent 76%);mask-image:radial-gradient(120% 85% at 50% 0%,#000 36%,transparent 76%);opacity:.55;pointer-events:none}
.cg-phero::after{content:"";position:absolute;top:-22%;right:-8%;width:640px;height:640px;border-radius:50%;background:radial-gradient(circle,rgba(0,191,166,.20),transparent 62%);pointer-events:none}
.cg-phero .cg-wrap{position:relative;z-index:2}
.cg-phero__grid{display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(36px,4.5vw,68px);align-items:center}
.cg-phero .cg-eyebrow{color:#7fe6d6}
.cg-phero .cg-eyebrow::before{background:var(--teal)}
.cg-phero h1{font-size:clamp(46px,7vw,84px);line-height:.97;letter-spacing:-.04em;color:#fff;font-weight:700}
.cg-phero h1 .hl{background:linear-gradient(115deg,#00d9bd 0%,#39a8ff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cg-phero__sub{font-size:20px;color:#b7bfe2;margin:26px 0 0;max-width:520px;line-height:1.55}
.cg-phero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.cg-phero__rating{display:flex;align-items:center;gap:11px;margin-top:30px;color:#aeb6dc;font-size:14.5px;font-weight:500}
.cg-phero__rating .s{display:inline-flex;gap:2px}
.cg-phero__rating svg{width:17px;height:17px;fill:var(--amber);stroke:none}

/* glass "systems monitored" panel */
.cg-glass{position:relative;border-radius:22px;padding:8px;max-width:440px;margin-left:auto;background:linear-gradient(160deg,rgba(255,255,255,.12),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.14);box-shadow:0 50px 90px -34px rgba(0,0,0,.7);backdrop-filter:blur(12px)}
.cg-glass__top{display:flex;align-items:center;gap:10px;padding:15px 16px 13px}
.cg-glass__top .dot{width:9px;height:9px;border-radius:50%;background:#39e6a4;box-shadow:0 0 0 4px rgba(57,230,164,.18)}
.cg-glass__top b{font-family:var(--display);font-size:13.5px;color:#fff}
.cg-glass__top em{margin-left:auto;font-style:normal;font-size:11px;color:#9fa8d0;letter-spacing:.1em;text-transform:uppercase}
.cg-glass__list{background:rgba(8,9,26,.5);border-radius:16px;padding:8px}
.cg-glass__row{display:flex;align-items:center;gap:13px;padding:13px 13px;border-radius:11px;transition:background .15s}
.cg-glass__row+.cg-glass__row{margin-top:2px}
.cg-glass__row:hover{background:rgba(255,255,255,.04)}
.cg-glass__ic{width:38px;height:38px;border-radius:10px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:linear-gradient(140deg,#1f6bff,#151ca1);color:#fff}
.cg-glass__ic svg{width:19px;height:19px}
.cg-glass__rt b{font-family:var(--display);font-size:14.5px;color:#fff;display:block;line-height:1.2}
.cg-glass__rt span{font-size:12.5px;color:#9097c0}
.cg-glass__badge{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:11.5px;color:#39e6a4;background:rgba(57,230,164,.12);padding:6px 11px;border-radius:999px;white-space:nowrap}
.cg-glass__badge i{width:6px;height:6px;border-radius:50%;background:#39e6a4;display:inline-block}
@media(max-width:920px){.cg-phero__grid{grid-template-columns:1fr;gap:46px}.cg-glass{margin:0 auto}}

/* ---- animated logo marquee ---- */
.cg-marquee{background:#fff;border-bottom:1px solid var(--line);padding:26px 0;overflow:hidden;position:relative}
.cg-marquee__lbl{text-align:center;font-family:var(--display);font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#9aa3b5;margin-bottom:20px}
.cg-marquee__mask{position:relative;overflow:hidden}
.cg-marquee__mask::before,.cg-marquee__mask::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.cg-marquee__mask::before{left:0;background:linear-gradient(90deg,#fff,transparent)}
.cg-marquee__mask::after{right:0;background:linear-gradient(270deg,#fff,transparent)}
.cg-marquee__track{display:flex;align-items:center;gap:58px;width:max-content;animation:cg-scroll 36s linear infinite}
.cg-marquee:hover .cg-marquee__track{animation-play-state:paused}
.cg-marquee__track img{height:34px;width:auto;opacity:.5;filter:grayscale(1);flex:0 0 auto;transition:opacity .2s,filter .2s}
.cg-marquee__track img:hover{opacity:1;filter:none}
@keyframes cg-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.cg-marquee__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}

/* ---- bento service grid ---- */
.cg-bento{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:50px}
.cg-bento .cell{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;display:flex;flex-direction:column;gap:13px;transition:transform .16s,box-shadow .16s,border-color .16s;overflow:hidden}
.cg-bento .cell:hover{transform:translateY(-5px);box-shadow:0 26px 54px -16px rgba(13,20,50,.22);border-color:#cfe0ff}
.cg-bento .cell .ic{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(140deg,#1f6bff,#151ca1);color:#fff;box-shadow:0 12px 22px -8px rgba(0,87,231,.5),inset 0 1px 0 rgba(255,255,255,.3)}
.cg-bento .cell .ic svg{width:25px;height:25px}
.cg-bento .cell h3{font-family:var(--display);font-size:18px;margin:0;line-height:1.25}
.cg-bento .cell p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.cg-bento .cell .go{margin-top:auto;color:#c2cbda;display:flex}
.cg-bento .cell .go svg{width:19px;height:19px;transition:transform .16s,color .16s}
.cg-bento .cell:hover .go svg{color:var(--blue);transform:translateX(4px)}
.cg-bento .feat{grid-column:span 2;background:linear-gradient(150deg,#0057e7 0%,#151ca1 70%,#2e2f4b 100%);border:0;color:#fff;justify-content:space-between;min-height:210px}
.cg-bento .feat::after{content:"";position:absolute;top:-30%;right:-12%;width:58%;height:80%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.14),transparent 64%);pointer-events:none}
.cg-bento .feat>*{position:relative;z-index:2}
.cg-bento .feat .ic{background:rgba(255,255,255,.16);box-shadow:none}
.cg-bento .feat h3{font-size:25px}
.cg-bento .feat p{color:#cdd7ff;font-size:15px;max-width:330px}
.cg-bento .feat .tag{position:absolute;top:22px;right:22px;z-index:3;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.18);padding:6px 12px;border-radius:999px}
.cg-bento .feat .go{color:#fff}
.cg-bento .full{grid-column:1/-1;background:var(--paper);border:1px dashed #c7d2e6;flex-direction:row;align-items:center;justify-content:center;gap:18px;min-height:auto;padding:22px}
.cg-bento .full b{font-family:var(--display);font-weight:600;font-size:17.5px;color:var(--ink)}
@media(max-width:980px){.cg-bento{grid-template-columns:repeat(2,1fr)}.cg-bento .feat{grid-column:span 2}}
@media(max-width:560px){.cg-bento{grid-template-columns:1fr}.cg-bento .feat{grid-column:auto}.cg-bento .full{flex-direction:column;text-align:center}}

/* ---- big-number impact band (dark) ---- */
.cg-impact{background:linear-gradient(135deg,#0d0e22,#141743);color:#fff;position:relative;overflow:hidden}
.cg-impact::after{content:"";position:absolute;left:-10%;bottom:-44%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(0,87,231,.22),transparent 62%);pointer-events:none}
.cg-impact .cg-wrap{position:relative;z-index:2}
.cg-impact__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.cg-impact__i b{font-family:var(--display);font-weight:700;font-size:clamp(38px,4.6vw,56px);line-height:1;letter-spacing:-.02em;background:linear-gradient(120deg,#fff,#9fc3ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block}
.cg-impact__i span{display:block;margin-top:10px;color:#aab2d8;font-size:15px}
@media(max-width:760px){.cg-impact__grid{grid-template-columns:repeat(2,1fr);gap:34px 24px}}
