/* 7vision — styles.css */
:root{
  --navy:#06205d;
  --navy-deep:#050f30;
  --navy-mid:#0b2d7a;
  --bg:#e5e9ef;
  --bg-soft:#eef1f6;
  --ink:#1a1d23;
  --ink-soft:#4d5360;
  --ink-mute:#6b7280;
  --accent:#2563eb;
  --accent-bright:#60a5fa;
  --accent-cyan:#22d3ee;
  --green:#22c55e;
  --card:#ffffff;
  --border:rgba(26,29,35,0.08);
  --border-strong:rgba(26,29,35,0.14);
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(6,32,93,0.04), 0 2px 6px rgba(6,32,93,0.04);
  --shadow-md:0 6px 18px rgba(6,32,93,0.08), 0 2px 6px rgba(6,32,93,0.04);
  --shadow-lg:0 20px 50px rgba(6,32,93,0.14), 0 6px 14px rgba(6,32,93,0.06);
  --font:'Plus Jakarta Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --container:1200px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden}
body{
  margin:0;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.menu-open{overflow:hidden; position:fixed; width:100%; height:100%; top:0; left:0}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:none; background:none}

.container{max-width:var(--container); margin:0 auto; padding:0 24px}

/* ───────── HEADER ───────── */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--navy);
  color:#fff;
  transition:box-shadow .25s ease, background .25s ease;
}
.site-header.scrolled{box-shadow:0 6px 24px rgba(6,32,93,.18)}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.logo-link{display:flex; align-items:center; gap:10px}
.logo-link img{height:36px; width:auto; filter:brightness(0) invert(1)}
.logo-text{font-weight:800; font-size:18px; letter-spacing:-0.01em}

.nav{display:flex; align-items:center; gap:6px}
.nav-item{position:relative}
.nav-link{
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 14px;
  font-size:14.5px; font-weight:500;
  color:rgba(255,255,255,.86);
  border-radius:8px;
  transition:color .2s, background .2s;
}
.nav-link:hover{color:#fff; background:rgba(255,255,255,.06)}
.nav-link .chev{width:12px; height:12px; transition:transform .25s}
.nav-item:hover .chev{transform:rotate(180deg)}

.header-right{display:flex; align-items:center; gap:12px}
.cta-circle{
  width:44px; height:44px; border-radius:50%;
  background:var(--accent);
  display:flex; align-items:center; justify-content:center;
  color:#fff;
  transition:transform .25s, background .25s, box-shadow .25s;
}
.cta-circle:hover{background:var(--accent-bright); transform:translateX(2px) rotate(-8deg); box-shadow:0 10px 24px rgba(37,99,235,.4)}
.cta-circle svg{width:18px; height:18px}

.burger{display:none; width:40px; height:40px; border-radius:8px; align-items:center; justify-content:center}
.burger span{display:block; width:20px; height:2px; background:#fff; border-radius:2px; position:relative}
.burger span::before,.burger span::after{content:""; position:absolute; left:0; width:20px; height:2px; background:#fff; border-radius:2px; transition:transform .25s}
.burger span::before{top:-6px}
.burger span::after{top:6px}
.burger.open span{background:transparent}
.burger.open span::before{transform:translateY(6px) rotate(45deg)}
.burger.open span::after{transform:translateY(-6px) rotate(-45deg)}

/* ───────── MEGA-MENU ───────── */
.mega-menu{
  position:absolute;
  top:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%) translateY(8px);
  width:min(880px, 92vw);
  background:#fff;
  color:var(--ink);
  border-radius:18px;
  box-shadow:var(--shadow-lg);
  padding:28px;
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease, transform .22s ease;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.nav-item:hover .mega-menu,
.nav-item:focus-within .mega-menu{
  opacity:1; pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.mega-menu::before{
  content:""; position:absolute; top:-8px; left:0; right:0; height:16px;
}
.mega-col h4{
  margin:0 0 12px;
  font-size:11px; font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--ink-mute);
}
.mega-link{
  display:block;
  padding:10px 12px;
  margin:0 -12px;
  border-radius:10px;
  transition:background .18s;
}
.mega-link:hover{background:var(--bg-soft)}
.mega-link .t{font-weight:600; font-size:14px; color:var(--ink); display:block}
.mega-link .d{font-size:12.5px; color:var(--ink-soft); display:block; margin-top:2px; line-height:1.4}

/* ───────── HERO ───────── */
.hero{
  background:var(--navy);
  color:#fff;
  position:relative;
  overflow:hidden;
  padding:88px 0 96px;
}
.hero::before, .hero::after{
  content:""; position:absolute; border-radius:50%; pointer-events:none;
}
.hero::before{
  width:520px; height:520px;
  right:-180px; top:-160px;
  background:radial-gradient(circle at 30% 30%, rgba(96,165,250,.35), transparent 60%);
}
.hero::after{
  width:360px; height:360px;
  left:-120px; bottom:-140px;
  background:radial-gradient(circle at 60% 40%, rgba(34,211,238,.18), transparent 65%);
}
.hero-inner{position:relative; z-index:1; max-width:880px}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 16px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  font-size:13.5px; font-weight:500;
  margin-bottom:28px;
  backdrop-filter:blur(8px);
}
.hero h1{
  font-size:clamp(36px, 5.6vw, 64px);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-0.025em;
  margin:0 0 22px;
}
.hero h1 .accent{
  background:linear-gradient(90deg, var(--accent-bright), var(--accent-cyan));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-desc{
  font-size:18px;
  color:rgba(255,255,255,.78);
  max-width:640px;
  margin:0 0 32px;
  line-height:1.6;
}
.dot-cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  font-size:14.5px; font-weight:500;
  color:#fff;
  transition:background .2s, border-color .2s, transform .2s;
}
.dot-cta:hover{background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.22); transform:translateY(-1px)}
.dot-cta .dot{
  width:10px; height:10px; border-radius:50%; background:var(--green);
  box-shadow:0 0 0 4px rgba(34,197,94,.18);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(34,197,94,.18)} 50%{box-shadow:0 0 0 8px rgba(34,197,94,.05)}}

/* Sub-page hero variant */
.hero.compact{padding:64px 0 72px}
.hero.compact h1{font-size:clamp(32px, 4.6vw, 52px)}
.back-link{
  display:inline-flex; align-items:center; gap:6px;
  font-size:14px; color:rgba(255,255,255,.75);
  margin-bottom:18px;
  transition:color .2s;
}
.back-link:hover{color:#fff}

/* About hero — gradient mesh subtle */
.hero-mesh{
  position:absolute; inset:0; overflow:hidden; pointer-events:none;
  mix-blend-mode:screen;
}
.hero-mesh .mesh-blob{
  position:absolute; border-radius:50%;
  filter:blur(80px);
  opacity:.55;
}
.hero-mesh .mesh-blob-1{
  width:520px; height:520px;
  right:-80px; top:-120px;
  background:radial-gradient(circle, rgba(37,99,235,.85), transparent 70%);
}
.hero-mesh .mesh-blob-2{
  width:440px; height:440px;
  right:120px; top:60px;
  background:radial-gradient(circle, rgba(34,211,238,.6), transparent 70%);
}
.hero-mesh .mesh-blob-3{
  width:380px; height:380px;
  right:-40px; bottom:-140px;
  background:radial-gradient(circle, rgba(139,92,246,.55), transparent 70%);
}

/* WhatsApp floating button */
.wa-float{
  position:fixed; bottom:24px; right:24px; z-index:200;
  width:60px; height:60px; border-radius:50%;
  background:#25D366;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.4), 0 2px 8px rgba(0,0,0,.18);
  transition:transform .25s ease, box-shadow .25s ease;
  animation:wa-pulse 3s ease-in-out infinite;
}
.wa-float svg{width:32px; height:32px}
.wa-float:hover{
  transform:scale(1.08);
  box-shadow:0 12px 32px rgba(37,211,102,.55), 0 4px 12px rgba(0,0,0,.22);
}
.wa-tooltip{
  position:absolute; right:72px; top:50%; transform:translateY(-50%);
  background:#1a1d23; color:#fff; font-size:13px; font-weight:500;
  padding:8px 12px; border-radius:8px; white-space:nowrap;
  opacity:0; pointer-events:none; transition:opacity .2s ease;
  box-shadow:0 4px 12px rgba(0,0,0,.2);
}
.wa-tooltip::after{
  content:""; position:absolute; right:-4px; top:50%; transform:translateY(-50%) rotate(45deg);
  width:8px; height:8px; background:#1a1d23;
}
.wa-float:hover .wa-tooltip{opacity:1}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 8px 24px rgba(37,211,102,.4), 0 2px 8px rgba(0,0,0,.18), 0 0 0 0 rgba(37,211,102,.5)}
  50%{box-shadow:0 8px 24px rgba(37,211,102,.4), 0 2px 8px rgba(0,0,0,.18), 0 0 0 14px rgba(37,211,102,0)}
}
@media (max-width:720px){
  .wa-float{width:54px; height:54px; bottom:18px; right:18px}
  .wa-float svg{width:28px; height:28px}
  .wa-tooltip{display:none}
}

/* ───────── SECTIONS ───────── */
.section{padding:88px 0}
.section.tight{padding:64px 0}
.section-head{margin-bottom:48px; max-width:760px}
.eyebrow{
  font-size:12px; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--accent);
  margin:0 0 12px;
}
.section-head h2{
  font-size:clamp(28px, 3.4vw, 42px);
  font-weight:800;
  letter-spacing:-0.02em;
  line-height:1.15;
  margin:0 0 14px;
}
.section-head p{color:var(--ink-soft); font-size:17px; margin:0; max-width:620px}

/* ───────── CARDS ───────── */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.cards-grid.cols-2{grid-template-columns:repeat(2, 1fr)}
.card{
  background:var(--card);
  border-radius:var(--radius);
  padding:28px;
  border:1px solid var(--border);
  transition:transform .28s, box-shadow .28s, border-color .28s;
  display:flex; flex-direction:column;
  position:relative;
}
a.card{color:inherit}
.card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--border-strong)}
.icon-badge{
  width:48px; height:48px;
  border-radius:12px;
  background:linear-gradient(135deg, var(--accent), var(--accent-bright));
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:20px;
  box-shadow:0 6px 16px rgba(37,99,235,.28);
}
.icon-badge.cyan{background:linear-gradient(135deg, #0ea5e9, var(--accent-cyan))}
.icon-badge.navy{background:linear-gradient(135deg, var(--navy), var(--navy-mid))}
.icon-badge.green{background:linear-gradient(135deg, #16a34a, #4ade80)}
.icon-badge.violet{background:linear-gradient(135deg, #7c3aed, #a78bfa)}
.icon-badge.amber{background:linear-gradient(135deg, #d97706, #fbbf24)}
.icon-badge svg{width:24px; height:24px}
.card h3{font-size:19px; font-weight:700; letter-spacing:-0.01em; margin:0 0 8px}
.card p{font-size:14.5px; color:var(--ink-soft); margin:0; line-height:1.55}
.card .link-arrow{
  margin-top:18px;
  font-size:14px; font-weight:600; color:var(--accent);
  display:inline-flex; align-items:center; gap:6px;
  transition:gap .2s;
}
.card:hover .link-arrow{gap:10px}

/* ───────── ABOUT TEASER ───────── */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.split h2{font-size:clamp(28px, 3.2vw, 38px); margin:0 0 18px; font-weight:800; letter-spacing:-0.02em; line-height:1.15}
.split p{color:var(--ink-soft); margin:0 0 14px; font-size:16px}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 22px;
  border-radius:999px;
  font-weight:600; font-size:14.5px;
  transition:transform .2s, box-shadow .2s, background .2s, color .2s;
}
.btn-primary{background:var(--navy); color:#fff}
.btn-primary:hover{background:var(--navy-mid); transform:translateY(-1px); box-shadow:0 12px 24px rgba(6,32,93,.22)}
.btn-ghost{background:transparent; color:var(--navy); border:1.5px solid var(--border-strong)}
.btn-ghost:hover{background:#fff; border-color:var(--navy)}
.btn-accent{background:var(--accent); color:#fff}
.btn-accent:hover{background:var(--accent-bright); transform:translateY(-1px); box-shadow:0 12px 24px rgba(37,99,235,.32)}

/* Abstract block */
.abstract-block{
  position:relative;
  aspect-ratio:1/1;
  border-radius:24px;
  background:linear-gradient(135deg, #f1f4fa, #dee5f0);
  overflow:hidden;
  box-shadow:inset 0 0 0 1px var(--border);
}
.abstract-block .circle{position:absolute; border-radius:50%}
.abstract-block .c1{width:62%; height:62%; left:8%; top:10%;
  background:radial-gradient(circle at 35% 30%, var(--accent), var(--navy) 80%);
  box-shadow:0 30px 60px rgba(6,32,93,.25);
}
.abstract-block .c2{width:36%; height:36%; right:10%; bottom:14%;
  background:radial-gradient(circle at 40% 40%, var(--accent-cyan), #0891b2);
  box-shadow:0 20px 40px rgba(8,145,178,.3);
}
.abstract-block .ring-deco{
  position:absolute; right:14%; top:10%;
  width:120px; height:120px;
  border:2px solid rgba(6,32,93,.18);
  border-radius:50%;
}
.abstract-block .dots-deco{
  position:absolute; left:14%; bottom:10%;
  width:120px; height:80px;
  background-image:radial-gradient(rgba(6,32,93,.32) 1.4px, transparent 1.4px);
  background-size:14px 14px;
}

/* ───────── FAQ ───────── */
.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 28px;
}
.faq{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  transition:border-color .2s, box-shadow .2s;
}
.faq[open]{border-color:var(--border-strong); box-shadow:var(--shadow-sm)}
.faq summary{
  list-style:none;
  cursor:pointer;
  padding:18px 22px;
  font-weight:600; font-size:15.5px;
  display:flex; justify-content:space-between; align-items:center;
  gap:16px;
  color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq .plus{
  width:22px; height:22px;
  position:relative;
  flex-shrink:0;
  transition:transform .25s;
}
.faq .plus::before,.faq .plus::after{
  content:""; position:absolute;
  background:var(--ink);
  left:50%; top:50%;
}
.faq .plus::before{width:12px; height:2px; transform:translate(-50%,-50%)}
.faq .plus::after{width:2px; height:12px; transform:translate(-50%,-50%)}
.faq[open] .plus{transform:rotate(45deg)}
.faq .answer{padding:0 22px 20px; color:var(--ink-soft); font-size:14.8px; line-height:1.62}

/* ───────── CTA STRIP ───────── */
.cta-strip{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  color:#fff;
  border-radius:var(--radius-lg);
  padding:56px;
  text-align:center;
  position:relative; overflow:hidden;
}
.cta-strip::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(96,165,250,.25), transparent 50%);
  pointer-events:none;
}
.cta-strip h2{
  position:relative;
  font-size:clamp(26px, 3.4vw, 38px);
  font-weight:800; letter-spacing:-0.02em; margin:0 0 22px;
}
.cta-strip-actions{position:relative; display:flex; justify-content:center; gap:14px; flex-wrap:wrap}
.cta-strip .btn-primary{background:#fff; color:var(--navy)}
.cta-strip .btn-primary:hover{background:#f1f4fa}
.cta-strip .btn-ghost{color:#fff; border-color:rgba(255,255,255,.3)}
.cta-strip .btn-ghost:hover{background:rgba(255,255,255,.08); border-color:#fff}

/* ───────── STEPS ───────── */
.steps{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:22px;
}
.step{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:28px;
}
.step .num{
  font-size:13px; font-weight:700;
  color:var(--accent);
  letter-spacing:.04em;
  margin-bottom:10px;
}
.step h4{font-size:17px; font-weight:700; margin:0 0 8px}
.step p{font-size:14px; color:var(--ink-soft); margin:0; line-height:1.55}

/* ───────── SERVICE PAGE ───────── */
.service-content{display:grid; grid-template-columns:1fr; gap:64px; max-width:920px; margin:0 auto}
.block h2{font-size:clamp(24px, 2.4vw, 30px); font-weight:800; letter-spacing:-0.015em; margin:0 0 18px}
.block p{color:var(--ink-soft); font-size:16px; margin:0 0 12px}
.checks{list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(2, 1fr); gap:10px 22px}
.checks li{position:relative; padding:6px 0 6px 30px; color:var(--ink); font-size:15px}
.checks li::before{
  content:""; position:absolute; left:0; top:8px;
  width:18px; height:18px; border-radius:50%;
  background:var(--accent);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-position:center; background-repeat:no-repeat;
}
.process-steps{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:18px}
.pricing-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:18px}
.price{background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:28px}
.price.highlight{border-color:var(--accent); box-shadow:0 0 0 1px var(--accent) inset, var(--shadow-md)}
.price h4{font-size:14px; font-weight:600; color:var(--ink-soft); margin:0 0 10px; text-transform:uppercase; letter-spacing:.06em}
.price .amount{font-size:36px; font-weight:800; letter-spacing:-0.02em; margin-bottom:6px; color:var(--navy)}
.price .amount small{font-size:14px; font-weight:500; color:var(--ink-soft); margin-left:4px}
.price ul{list-style:none; padding:0; margin:14px 0 0; font-size:14px; color:var(--ink-soft); line-height:1.7}
.price ul li{padding-left:22px; position:relative}
.price ul li::before{content:""; position:absolute; left:0; top:9px; width:10px; height:10px; border-radius:50%; background:var(--accent)}

/* ───────── CONTACT ───────── */
.contact-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:48px; align-items:start}
.form{background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:36px; box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block; font-size:13px; font-weight:600; color:var(--ink); margin-bottom:6px}
.field input, .field textarea, .field select{
  width:100%;
  padding:13px 16px;
  border:1.5px solid var(--border-strong);
  border-radius:10px;
  font-family:inherit; font-size:15px;
  background:#fff; color:var(--ink);
  transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}
.field textarea{resize:vertical; min-height:140px}
.contact-info{background:var(--navy); color:#fff; border-radius:var(--radius); padding:36px}
.contact-info h3{margin:0 0 18px; font-size:20px; font-weight:700}
.info-item{padding:14px 0; border-top:1px solid rgba(255,255,255,.12)}
.info-item:first-of-type{border-top:0}
.info-item .lbl{font-size:12px; text-transform:uppercase; letter-spacing:.08em; color:rgba(255,255,255,.6); margin-bottom:4px}
.info-item .val{font-size:15.5px; font-weight:500; color:#fff}
.availability{
  margin-top:24px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:14px 16px;
  display:flex; align-items:center; gap:10px;
  font-size:14px;
}
.availability .dot{width:10px; height:10px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px rgba(34,197,94,.2)}

/* ───────── LEGAL ───────── */
.legal{max-width:780px; margin:0 auto}
.legal h2{margin-top:36px; font-size:22px; font-weight:700}
.legal h3{margin-top:24px; font-size:17px; font-weight:700}
.legal p, .legal li{color:var(--ink-soft); font-size:15px; line-height:1.7}
.legal ul{padding-left:20px}

/* ───────── VALUES ───────── */
.values-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.value{background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:28px}
.value .icon-badge{margin-bottom:18px}
.value h4{margin:0 0 8px; font-size:18px; font-weight:700}
.value p{margin:0; color:var(--ink-soft); font-size:14.5px}
.clients-intro{font-size:18px; color:var(--ink-soft); max-width:640px; margin:0 0 36px}

/* ───────── FOOTER ───────── */
.site-footer{
  background:#0b0f1a;
  color:rgba(255,255,255,.7);
  padding:64px 0 32px;
  margin-top:88px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:48px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-brand .logo-link{margin-bottom:14px}
.footer-brand .logo-link img{height:36px; filter:brightness(0) invert(1)}
.footer-brand .logo-text{color:#fff}
.footer-brand p{font-size:14px; line-height:1.6; max-width:320px; margin:0}
.footer-col h5{
  color:#fff;
  font-size:12px; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  margin:0 0 14px;
}
.footer-col ul{list-style:none; padding:0; margin:0}
.footer-col li{margin-bottom:8px}
.footer-col a{font-size:14px; color:rgba(255,255,255,.7); transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{
  padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  font-size:13px; color:rgba(255,255,255,.5);
  flex-wrap:wrap; gap:12px;
}

/* ───────── RESPONSIVE ───────── */
@media (max-width: 960px){
  .split, .contact-grid{grid-template-columns:1fr; gap:36px}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero{padding:64px 0 72px}
  .section{padding:64px 0}
  .cta-strip{padding:40px 28px}
  .checks{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .nav, .header-right .cta-circle{display:none}
  .burger{display:flex}
  .nav.open{
    display:flex;
    position:fixed; top:72px; left:0; right:0; bottom:0;
    flex-direction:column; align-items:stretch;
    background:var(--navy);
    padding:14px 24px 80px;
    gap:4px;
    box-shadow:0 18px 36px rgba(0,0,0,.24);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    z-index:99;
  }
  .nav.open .nav-link{padding:14px 12px; font-size:16px}
  .nav.open .mega-menu{
    position:static; transform:none; width:100%; opacity:1; pointer-events:auto;
    grid-template-columns:1fr; box-shadow:none; padding:8px 0 0;
    background:transparent; color:#fff;
  }
  .nav.open .mega-col h4{color:rgba(255,255,255,.55)}
  .nav.open .mega-link .t{color:#fff}
  .nav.open .mega-link .d{color:rgba(255,255,255,.6)}
  .nav.open .mega-link:hover{background:rgba(255,255,255,.06)}
  .cards-grid, .cards-grid.cols-2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
}
