/*
Theme Name: SolidMark Technology Systems
Theme URI: https://solidmarktechnology.example
Author: SolidMark Technology Systems
Description: Software and IT services company. Deep navy #0D1B2A with electric blue #1E7FD8 and clean white #F7F9FC. Plus Jakarta Sans + Epilogue. Sharp, enterprise-grade layouts for a St. Louis MO technology company.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: solidmark
Tags: software, technology, IT services, navy, blue, st-louis, enterprise
*/
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Epilogue:wght@700;800;900&display=swap');

:root {
  --sm-navy:    #0D1B2A;
  --sm-deep:    #070F1A;
  --sm-dark:    #111F30;
  --sm-card:    #152536;
  --sm-panel:   #1A2D40;
  --sm-blue:    #1E7FD8;
  --sm-blue2:   #3594E8;
  --sm-sky:     #7DC2F8;
  --sm-white:   #F7F9FC;
  --sm-cream:   #EFF3F8;
  --sm-warm:    #E5ECF5;
  --sm-text:    #0D1420;
  --sm-muted:   #546070;
  --sm-silver:  #8898A8;
  --sm-line:    rgba(30,127,216,0.18);
  --font-d:     'Epilogue', sans-serif;
  --font-b:     'Plus Jakarta Sans', sans-serif;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-b); font-size: 16px; line-height: 1.72; color: var(--sm-text); background: var(--sm-white); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
ul { list-style: none; }
.wrap { max-width: 1280px; margin: 0 auto; padding: 0 52px; position: relative; z-index: 1; }

/* IMAGES */
.bg-stlouis { background: url("https://images.unsplash.com/photo-1477959858617-67f85cf4f1df?w=1600&q=95") center/cover no-repeat; }
.bg-server { background: url("https://images.unsplash.com/photo-1558494949-ef010cbdcc31?w=1600&q=95") center/cover no-repeat; }
.bg-code { background: url("https://images.unsplash.com/photo-1587620962725-abab7fe55159?w=1600&q=95") center/cover no-repeat; }
.bg-team { background: url("https://images.unsplash.com/photo-1531482615713-2afd69097998?w=1600&q=95") center/cover no-repeat; }
.bg-dashboard { background: url("https://images.unsplash.com/photo-1460925895917-afdab827c52f?w=1600&q=95") center/cover no-repeat; }
.bg-support { background: url("https://images.unsplash.com/photo-1553877522-43269d4ea984?w=1600&q=95") center/cover no-repeat; }
.bg-cloud { background: url("https://images.unsplash.com/photo-1667372393119-3d4c48d07fc9?w=1600&q=95") center/cover no-repeat; }
.bg-security { background: url("https://images.unsplash.com/photo-1614064641938-3bbee52942c7?w=1600&q=95") center/cover no-repeat; }
.bg-network { background: url("https://images.unsplash.com/photo-1544197150-b99a580bb7a8?w=1600&q=95") center/cover no-repeat; }
.bg-exec { background: url("https://images.unsplash.com/photo-1573496359142-b8d87734a5a2?w=1600&q=95") center/cover no-repeat; }
.bg-meeting { background: url("https://images.unsplash.com/photo-1542744094-3a31f272c490?w=1600&q=95") center/cover no-repeat; }
.bg-enterprise { background: url("https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=1600&q=95") center/cover no-repeat; }

/* TOPBAR */
.topbar { background: var(--sm-blue); padding: 8px 52px; display: flex; justify-content: space-between; align-items: center; font-family: var(--font-b); font-size: 11px; font-weight: 600; letter-spacing: .08em; color: rgba(255,255,255,.78); }
.topbar a { color: #fff; transition: opacity .2s; }
.topbar a:hover { opacity: .75; }
.topbar-badge { background: rgba(255,255,255,.2); padding: 2px 10px; border-radius: 99px; font-size: 10px; }

/* HEADER */
.site-header { background: rgba(13,27,42,.98); border-bottom: 1px solid var(--sm-line); position: sticky; top: 0; z-index: 100; }
.hdr { max-width: 1280px; margin: 0 auto; padding: 0 52px; height: 72px; display: flex; align-items: center; justify-content: space-between; }
.logo { display: flex; align-items: center; gap: 12px; }
.logo-mark { width: 36px; height: 36px; background: linear-gradient(135deg, var(--sm-blue), var(--sm-blue2)); border-radius: 7px; display: flex; align-items: center; justify-content: center; font-family: var(--font-d); font-size: 15px; font-weight: 900; color: #fff; flex-shrink: 0; }
.logo-name { font-family: var(--font-d); font-size: 16px; font-weight: 900; color: var(--sm-white); letter-spacing: -.02em; line-height: 1.1; }
.logo-sub { font-family: var(--font-b); font-size: 9px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: rgba(30,127,216,.42); display: block; margin-top: 2px; }
.nav ul { display: flex; gap: 28px; }
.nav a { font-family: var(--font-b); font-size: 13px; font-weight: 500; color: rgba(247,249,252,.38); transition: color .2s; }
.nav a:hover { color: var(--sm-blue2); }
.btn { display: inline-block; padding: 10px 22px; font-family: var(--font-b); font-size: 13px; font-weight: 700; letter-spacing: .01em; cursor: pointer; border: none; transition: all .22s; border-radius: 6px; }
.btn-blue { background: var(--sm-blue); color: #fff; }
.btn-blue:hover { background: var(--sm-blue2); }
.btn-ghost { border: 1px solid rgba(30,127,216,.34); color: var(--sm-blue2); background: transparent; border-radius: 6px; }
.btn-ghost:hover { background: rgba(30,127,216,.08); }
.btn-dark { background: var(--sm-dark); color: var(--sm-white); border-radius: 6px; }
.btn-dark:hover { background: var(--sm-card); }
.btn-outline { border: 1.5px solid var(--sm-blue); color: var(--sm-text); background: transparent; border-radius: 6px; }
.btn-outline:hover { background: var(--sm-blue); color: #fff; }
.btn-white { background: var(--sm-white); color: var(--sm-navy); border-radius: 6px; }
.btn-white:hover { background: var(--sm-cream); }
.btn-lg { padding: 14px 32px; font-size: 14px; }

/* HERO */
.hero { min-height: 100vh; background: var(--sm-deep); position: relative; overflow: hidden; display: flex; align-items: center; }
.hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(30,127,216,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(30,127,216,.05) 1px, transparent 1px); background-size: 54px 54px; pointer-events: none; }
.hero-glow { position: absolute; top: -15%; right: -8%; width: 650px; height: 650px; background: radial-gradient(circle, rgba(30,127,216,.12) 0%, transparent 60%); pointer-events: none; }
.hero-glow2 { position: absolute; bottom: -20%; left: -5%; width: 450px; height: 450px; background: radial-gradient(circle, rgba(30,127,216,.07) 0%, transparent 60%); pointer-events: none; }
.hero-content { position: relative; z-index: 2; padding: 0 52px; max-width: 1280px; margin: 0 auto; width: 100%; display: grid; grid-template-columns: 1.1fr 1fr; gap: 72px; align-items: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(30,127,216,.15); border: 1px solid rgba(30,127,216,.28); border-radius: 99px; padding: 5px 16px; font-family: var(--font-b); font-size: 11px; font-weight: 600; color: var(--sm-sky); margin-bottom: 26px; letter-spacing: .05em; text-transform: uppercase; }
.hero-badge-dot { width: 6px; height: 6px; background: var(--sm-blue); border-radius: 50%; flex-shrink: 0; }
.hero h1 { font-family: var(--font-d); font-size: clamp(50px, 7vw, 116px); font-weight: 900; line-height: .91; color: var(--sm-white); margin-bottom: 26px; letter-spacing: -.04em; }
.hero h1 em { font-style: normal; background: linear-gradient(90deg, var(--sm-blue), var(--sm-sky)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero-sub { font-family: var(--font-b); font-size: 17px; line-height: 1.84; color: rgba(247,249,252,.5); max-width: 580px; margin-bottom: 40px; font-weight: 300; }
.hero-btns { display: flex; gap: 11px; margin-bottom: 64px; flex-wrap: wrap; }
.hero-trust { display: flex; align-items: center; gap: 14px; font-family: var(--font-b); font-size: 11px; color: rgba(247,249,252,.28); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; }
.hero-trust-logos { display: flex; gap: 8px; }
.trust-logo { height: 24px; background: rgba(255,255,255,.07); border-radius: 4px; padding: 0 12px; display: flex; align-items: center; font-family: var(--font-b); font-size: 10px; font-weight: 700; color: rgba(255,255,255,.3); letter-spacing: .06em; }

/* HERO VISUAL — stylised app window */
.hero-visual { position: relative; }
.app-window { background: var(--sm-card); border: 1px solid var(--sm-line); border-radius: 10px; overflow: hidden; }
.app-bar { background: var(--sm-panel); padding: 12px 16px; display: flex; align-items: center; gap: 7px; border-bottom: 1px solid var(--sm-line); }
.app-dot { width: 10px; height: 10px; border-radius: 50%; }
.app-title { font-family: var(--font-b); font-size: 11px; color: rgba(247,249,252,.3); margin-left: 8px; font-weight: 500; }
.app-body { padding: 20px; }
.app-row { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.app-label { font-family: var(--font-b); font-size: 11px; color: rgba(247,249,252,.35); width: 90px; flex-shrink: 0; }
.app-bar-wrap { flex: 1; height: 7px; background: rgba(255,255,255,.06); border-radius: 4px; overflow: hidden; }
.app-fill { height: 100%; background: linear-gradient(90deg, var(--sm-blue), var(--sm-sky)); border-radius: 4px; }
.app-val { font-family: var(--font-b); font-size: 11px; color: var(--sm-blue2); font-weight: 600; width: 36px; text-align: right; }
.app-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 14px; }
.app-metric { background: rgba(30,127,216,.07); border: 1px solid var(--sm-line); border-radius: 6px; padding: 12px; }
.app-metric-n { font-family: var(--font-d); font-size: 26px; font-weight: 900; color: var(--sm-blue2); line-height: 1; letter-spacing: -.02em; }
.app-metric-l { font-family: var(--font-b); font-size: 10px; color: rgba(247,249,252,.3); margin-top: 4px; }

/* SECTIONS */
.sec { padding: 108px 0; position: relative; z-index: 1; }
.sec-navy  { background: var(--sm-navy); color: var(--sm-white); }
.sec-dark  { background: var(--sm-dark); color: var(--sm-white); }
.sec-card  { background: var(--sm-card); color: var(--sm-white); }
.sec-blue  { background: var(--sm-blue); color: #fff; }
.sec-warm  { background: var(--sm-warm); }
.sec-cream { background: var(--sm-cream); }

.eyebrow { font-family: var(--font-b); font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--sm-blue); margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.eyebrow::before { content: ''; width: 18px; height: 2px; background: var(--sm-blue); border-radius: 1px; display: block; flex-shrink: 0; }
.sec-navy .eyebrow, .sec-dark .eyebrow, .sec-card .eyebrow { color: var(--sm-sky); }
.sec-navy .eyebrow::before, .sec-dark .eyebrow::before, .sec-card .eyebrow::before { background: var(--sm-sky); }
.sec-blue .eyebrow { color: rgba(255,255,255,.65); }
.sec-blue .eyebrow::before { background: rgba(255,255,255,.5); }

.sec-title { font-family: var(--font-d); font-size: clamp(34px, 5vw, 74px); font-weight: 900; line-height: .94; margin-bottom: 18px; color: var(--sm-text); letter-spacing: -.04em; }
.sec-title em { font-style: normal; color: var(--sm-blue); }
.sec-navy .sec-title, .sec-dark .sec-title, .sec-card .sec-title { color: var(--sm-white); }
.sec-navy .sec-title em, .sec-dark .sec-title em, .sec-card .sec-title em { color: var(--sm-sky); }
.sec-blue .sec-title { color: #fff; }

.sec-lead { font-family: var(--font-b); font-size: 17px; line-height: 1.85; color: var(--sm-muted); max-width: 700px; font-weight: 300; }
.sec-navy .sec-lead, .sec-dark .sec-lead, .sec-card .sec-lead { color: rgba(247,249,252,.5); }
.sec-blue .sec-lead { color: rgba(255,255,255,.82); }

/* SERVICES */
.svc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--sm-line); margin-top: 50px; }
.svc-card { background: var(--sm-card); padding: 42px 34px; position: relative; overflow: hidden; transition: background .28s; }
.svc-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--sm-blue), var(--sm-sky)); transform: scaleX(0); transform-origin: left; transition: transform .38s; }
.svc-card:hover { background: var(--sm-panel); }
.svc-card:hover::before { transform: scaleX(1); }
.svc-icon { width: 44px; height: 44px; background: rgba(30,127,216,.12); border-radius: 10px; display: flex; align-items: center; justify-content: center; margin-bottom: 18px; font-size: 20px; }
.svc-card h3 { font-family: var(--font-d); font-size: 19px; font-weight: 900; color: var(--sm-white); margin-bottom: 10px; letter-spacing: -.02em; }
.svc-card p { font-family: var(--font-b); font-size: 13px; color: rgba(247,249,252,.46); line-height: 1.8; font-weight: 300; }
.svc-tag { font-family: var(--font-b); font-size: 11px; color: var(--sm-blue2); font-weight: 600; margin-top: 12px; }

/* STATS */
.stats-band { background: var(--sm-blue); padding: 58px 0; }
.stats-row { display: grid; grid-template-columns: repeat(4,1fr); }
.stat-item { text-align: center; padding: 0 18px; border-right: 1px solid rgba(255,255,255,.16); }
.stat-item:last-child { border-right: none; }
.stat-n { font-family: var(--font-d); font-size: 56px; font-weight: 900; color: #fff; line-height: 1; margin-bottom: 7px; letter-spacing: -.04em; }
.stat-l { font-family: var(--font-b); font-size: 10px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.56); }

/* SPLIT */
.split { display: grid; grid-template-columns: 1fr 1fr; }
.sp-img { position: relative; min-height: 500px; overflow: hidden; }
.sp-img-inner { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 7s ease; }
.sp-img:hover .sp-img-inner { transform: scale(1.05); }
.sp-fade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(7,15,26,.9) 0%, rgba(7,15,26,.08) 54%); }
.sp-cap { position: absolute; bottom: 0; left: 0; right: 0; padding: 28px 38px; z-index: 2; }
.sp-cat { font-family: var(--font-b); font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--sm-blue2); margin-bottom: 5px; }
.sp-title { font-family: var(--font-d); font-size: 18px; font-weight: 800; color: #fff; line-height: 1.2; letter-spacing: -.02em; }
.sp-content { padding: 72px 64px; display: flex; flex-direction: column; justify-content: center; }

/* TEAM */
.team-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 50px; }
.team-card { overflow: hidden; border: 1px solid var(--sm-line); border-radius: 8px; transition: border-color .28s; }
.team-card:hover { border-color: var(--sm-blue); }
.team-photo { height: 290px; overflow: hidden; }
.team-photo-inner { width: 100%; height: 100%; background-size: cover; background-position: center top; transition: transform .5s; }
.team-card:hover .team-photo-inner { transform: scale(1.055); }
.team-body { padding: 24px 20px; background: var(--sm-card); }
.team-name { font-family: var(--font-d); font-size: 18px; font-weight: 900; color: var(--sm-white); margin-bottom: 3px; letter-spacing: -.02em; }
.team-role { font-family: var(--font-b); font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--sm-blue2); margin-bottom: 9px; }
.team-bio { font-family: var(--font-b); font-size: 13px; color: rgba(247,249,252,.44); line-height: 1.75; font-weight: 300; }

/* TESTIMONIALS */
.testi-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; margin-top: 50px; }
.tst-card { background: var(--sm-white); padding: 40px 36px; border: 1px solid rgba(30,127,216,.12); border-radius: 8px; border-top: 3px solid var(--sm-blue); }
.tst-mark { font-family: var(--font-d); font-size: 56px; font-weight: 900; color: rgba(30,127,216,.08); line-height: .5; display: block; margin-bottom: 13px; }
.tst-text { font-family: var(--font-b); font-size: 16px; color: var(--sm-text); line-height: 1.75; margin-bottom: 18px; }
.tst-name { font-family: var(--font-d); font-size: 13px; font-weight: 900; color: var(--sm-navy); letter-spacing: -.01em; }
.tst-co { font-family: var(--font-b); font-size: 12px; color: var(--sm-muted); margin-top: 3px; }

/* INSIGHTS */
.ins-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 50px; }
.ins-card { border-bottom: 2px solid rgba(30,127,216,.1); padding-bottom: 20px; transition: border-color .28s; }
.ins-card:hover { border-bottom-color: var(--sm-blue); }
.ins-img { height: 195px; overflow: hidden; margin-bottom: 16px; border-radius: 5px; }
.ins-img-inner { width: 100%; height: 100%; background-size: cover; background-position: center; transition: transform .5s; }
.ins-card:hover .ins-img-inner { transform: scale(1.055); }
.ins-cat { font-family: var(--font-b); font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--sm-blue); margin-bottom: 7px; }
.ins-title { font-family: var(--font-d); font-size: 18px; font-weight: 900; color: var(--sm-text); margin-bottom: 7px; line-height: 1.15; letter-spacing: -.02em; }
.ins-text { font-family: var(--font-b); font-size: 13px; color: var(--sm-muted); line-height: 1.76; font-weight: 300; }

/* ROLES */
.roles { margin-top: 42px; }
.role-item { display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: center; padding: 33px 0; border-bottom: 1px solid var(--sm-line); }
.role-item:first-child { border-top: 1px solid var(--sm-line); }
.sec-warm .role-item { border-color: rgba(30,127,216,.09); }
.role-dept { font-family: var(--font-b); font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--sm-blue2); margin-bottom: 6px; }
.role-title { font-family: var(--font-d); font-size: 20px; font-weight: 900; color: var(--sm-white); letter-spacing: -.02em; margin-bottom: 6px; }
.sec-warm .role-title { color: var(--sm-text); }
.role-desc { font-family: var(--font-b); font-size: 13px; color: rgba(247,249,252,.44); max-width: 580px; line-height: 1.76; font-weight: 300; }
.sec-warm .role-desc { color: var(--sm-muted); }

/* CTA */
.cta-band { background: var(--sm-deep); padding: 116px 0; text-align: center; position: relative; overflow: hidden; }
.cta-band::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(30,127,216,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(30,127,216,.05) 1px, transparent 1px); background-size: 54px 54px; pointer-events: none; }
.cta-band::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 660px; height: 660px; background: radial-gradient(circle, rgba(30,127,216,.13) 0%, transparent 60%); pointer-events: none; }
.cta-band h2 { font-family: var(--font-d); font-size: clamp(46px, 7.5vw, 104px); font-weight: 900; color: var(--sm-white); line-height: .92; margin-bottom: 20px; letter-spacing: -.04em; position: relative; z-index: 1; }
.cta-band h2 em { font-style: normal; background: linear-gradient(90deg, var(--sm-blue), var(--sm-sky)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.cta-band p { font-family: var(--font-b); font-size: 17px; color: rgba(247,249,252,.42); max-width: 520px; margin: 0 auto 44px; font-weight: 300; position: relative; z-index: 1; }
.cta-btns { display: flex; gap: 11px; justify-content: center; position: relative; z-index: 1; flex-wrap: wrap; }

/* CONTACT */
.contact-wrap { display: grid; grid-template-columns: 1fr 1.62fr; }
.cinfo { background: linear-gradient(160deg, var(--sm-blue), #1260A8); padding: 72px 50px; }
.cform { background: var(--sm-dark); padding: 72px 58px; }
.ci-label { font-family: var(--font-b); font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.52); margin-bottom: 7px; }
.ci-block { margin-bottom: 24px; }
.ci-block p, .ci-block a { font-family: var(--font-b); font-size: 16px; font-weight: 600; color: #fff; }
.ci-block a:hover { opacity: .75; }
.form { display: flex; flex-direction: column; gap: 18px; }
.field label { display: block; font-family: var(--font-b); font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: rgba(247,249,252,.26); margin-bottom: 7px; }
.field input, .field select, .field textarea { width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--sm-line); padding: 11px 0; font-family: var(--font-b); font-size: 15px; font-weight: 400; color: var(--sm-white); outline: none; transition: border-color .2s; }
.field input:focus, .field select:focus, .field textarea:focus { border-bottom-color: var(--sm-blue); }
.field select option { background: var(--sm-dark); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

/* FOOTER */
.site-footer { background: var(--sm-deep); color: var(--sm-white); border-top: 1px solid var(--sm-line); padding: 68px 0 26px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 42px; margin-bottom: 44px; }
.footer-about p { font-family: var(--font-b); font-size: 13px; color: rgba(247,249,252,.24); max-width: 264px; margin-top: 12px; line-height: 1.84; font-weight: 300; }
.footer-col h4 { font-family: var(--font-b); font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--sm-blue2); margin-bottom: 16px; }
.footer-col li { margin-bottom: 9px; }
.footer-col a { font-family: var(--font-b); font-size: 13px; color: rgba(247,249,252,.24); font-weight: 300; transition: color .2s; }
.footer-col a:hover { color: var(--sm-blue2); }
.footer-bottom { border-top: 1px solid var(--sm-line); padding-top: 22px; display: flex; justify-content: space-between; font-family: var(--font-b); font-size: 10px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: rgba(30,127,216,.18); }

@media (max-width: 1060px) {
  .hero-content { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .svc-grid { grid-template-columns: repeat(2,1fr); }
  .team-grid, .testi-grid, .ins-grid { grid-template-columns: repeat(2,1fr); }
  .split { grid-template-columns: 1fr; }
  .sp-img { min-height: 360px; }
  .stats-row { grid-template-columns: repeat(2,1fr); gap: 0; }
  .contact-wrap { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 34px; }
}
@media (max-width: 640px) {
  .wrap { padding: 0 22px; }
  .topbar, .hdr { padding-left: 22px; padding-right: 22px; }
  .nav { display: none; }
  .svc-grid, .team-grid, .testi-grid, .ins-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .cta-btns { flex-direction: column; align-items: center; }
  .footer-grid { grid-template-columns: 1fr; }
  .sp-content { padding: 50px 26px; }
}
