/* =========================================================
   ZEARCH DIGITAL — bright editorial theme
   Palette: logo gradient  magenta #E14EC8 -> violet #7854FF
   Light, high-contrast, color-blocked. Fonts: Bricolage + Manrope
   ========================================================= */

:root {
  --bg:        #FAF7F4;   /* warm white */
  --bg-2:      #F1ECF6;   /* faint lavender */
  --surface:   #FFFFFF;
  --surface-2: #F6F1FB;   /* tinted tile */
  --text:      #1B1126;   /* dark plum-black */
  --muted:     #6B6376;
  --muted-2:   #9b94a3;
  --magenta:   #E14EC8;
  --violet:    #7854FF;
  --accent:    #E14EC8;   /* solid uses */
  --coral:     #7854FF;   /* maps old "coral" -> violet */
  --grad:      linear-gradient(120deg, #E14EC8 0%, #9B49E6 45%, #7854FF 100%);
  --grad-soft: linear-gradient(135deg, rgba(225,78,200,.12), rgba(120,84,255,.12));
  --dark:      #160E22;   /* footer block */
  --line:      rgba(27,17,38,.10);
  --line-2:    rgba(27,17,38,.06);
  --radius:    20px;
  --radius-sm: 13px;
  --maxw:      1240px;
  --ease:      cubic-bezier(.22,.61,.36,1);
  --shadow:    0 26px 60px -28px rgba(95,40,140,.30);
  --shadow-sm: 0 10px 30px -14px rgba(95,40,140,.22);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body {
  font-family:'Manrope',-apple-system,sans-serif;
  background:var(--bg); color:var(--text);
  line-height:1.6; font-size:17px; overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ambient brand tint + faint grain, kept subtle for clarity */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(48% 38% at 8% -4%, rgba(225,78,200,.12), transparent 60%),
    radial-gradient(42% 40% at 102% 2%, rgba(120,84,255,.12), transparent 58%),
    radial-gradient(40% 36% at 50% 118%, rgba(225,78,200,.10), transparent 60%);
  animation:aurora 18s ease-in-out infinite alternate;
}
body::after{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,h4{ font-family:'Bricolage Grotesque',sans-serif; font-weight:700; line-height:1.03; letter-spacing:-.02em; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; position:relative; z-index:1; }

/* gradient text accent on highlighted words */
.accent{
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.coral{ color:var(--violet); }

/* ============ NAV ============ */
.nav{
  position:sticky; top:0; z-index:100;
  backdrop-filter:blur(14px); background:rgba(250,247,244,.78);
  border-bottom:1px solid var(--line-2);
}
.nav::before{ content:""; position:absolute; left:0; right:0; top:0; height:3px; background:var(--grad); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:78px; }
.logo{ display:flex; align-items:center; gap:11px; }
.logo-img{ height:46px; width:auto; display:block; transition:transform .4s var(--ease); }
.logo:hover .logo-img{ transform:scale(1.04); }

.nav-links{ display:flex; align-items:center; gap:34px; list-style:none; }
.nav-links a{ font-weight:600; font-size:15px; color:var(--muted); position:relative; transition:color .25s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--grad); transition:width .3s var(--ease); }
.nav-links a:hover, .nav-links a.active{ color:var(--text); }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }

.btn{ display:inline-flex; align-items:center; gap:9px; font-family:'Manrope'; font-weight:700; font-size:15px;
  padding:13px 24px; border-radius:100px; cursor:pointer; border:none;
  transition:transform .25s var(--ease), box-shadow .25s, filter .25s; }
.btn-primary{ background:var(--grad); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 34px -10px rgba(150,60,210,.5); filter:saturate(1.1); }
.btn-ghost{ background:transparent; color:var(--text); border:1.5px solid var(--line); }
.btn-ghost:hover{ border-color:var(--magenta); color:var(--magenta); transform:translateY(-2px); }
.btn-arrow{ transition:transform .3s var(--ease); }
.btn:hover .btn-arrow{ transform:translateX(4px); }

.nav-toggle{ display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; }
.nav-toggle span{ width:24px; height:2px; background:var(--text); transition:.3s; }

/* ============ HELPERS ============ */
section{ position:relative; z-index:1; }
.eyebrow{ display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:12px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--magenta); margin-bottom:22px; }
.eyebrow::before{ content:""; width:26px; height:2px; border-radius:2px; background:var(--grad); }
.section-pad{ padding:110px 0; }
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ============ HERO ============ */
.hero{ padding:92px 0 82px; overflow:hidden; position:relative; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:60px; align-items:center; }
.hero-tag{ display:inline-flex; align-items:center; gap:10px; background:var(--surface); border:1px solid var(--line);
  border-radius:100px; padding:7px 16px 7px 8px; font-size:13px; font-weight:600; color:var(--muted); margin-bottom:28px; box-shadow:var(--shadow-sm); }
.hero-tag b{ background:var(--grad); color:#fff; font-weight:800; padding:3px 11px; border-radius:100px; font-size:11px; letter-spacing:.04em; }
.hero h1{ font-size:clamp(42px,6vw,80px); margin-bottom:26px; }
.hero h1 .out{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; font-style:italic; }
.hero p.lead{ font-size:19px; color:var(--muted); max-width:540px; margin-bottom:36px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero-stats{ display:flex; gap:40px; margin-top:54px; }
.hero-stat .num{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:40px; letter-spacing:-.03em;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-stat .lbl{ font-size:13px; color:var(--muted); font-weight:600; }

.hero-visual{ position:relative; aspect-ratio:1/1.08; }
.orb{ position:absolute; inset:0; border-radius:26px; background:var(--surface); border:1px solid var(--line); overflow:hidden; box-shadow:var(--shadow); }
.orb-glow{ position:absolute; width:80%; height:70%; left:-12%; top:-10%; background:var(--grad); opacity:.16; filter:blur(34px); }
.orb-grid{ position:absolute; inset:0; opacity:.5;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px); background-size:38px 38px; }
.chart{ position:absolute; left:28px; right:28px; bottom:34px; height:46%; display:flex; align-items:flex-end; gap:11px; }
.bar{ flex:1; background:var(--grad); border-radius:6px 6px 0 0; transform-origin:bottom; animation:grow 1.1s var(--ease) both; opacity:.92; }
@keyframes grow{ from{ transform:scaleY(0); } }
.orb-badge{ position:absolute; top:26px; left:26px; right:26px; display:flex; justify-content:space-between; align-items:center;
  font-family:'Bricolage Grotesque'; font-weight:700; font-size:14px; color:var(--muted); }
.orb-badge .live{ display:flex; align-items:center; gap:7px; color:var(--magenta); }
.orb-badge .dot{ width:8px; height:8px; border-radius:50%; background:var(--magenta); animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%,100%{opacity:1;} 50%{opacity:.3;} }
.float-card{ position:absolute; background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:14px 16px;
  box-shadow:var(--shadow); display:flex; align-items:center; gap:12px; }
.float-card .ic{ width:38px; height:38px; border-radius:10px; background:var(--grad-soft); display:grid; place-items:center; }
.float-card .t{ font-family:'Bricolage Grotesque'; font-weight:700; font-size:18px; line-height:1;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.float-card .s{ font-size:11px; color:var(--muted); }
.fc-1{ right:-22px; top:24%; animation:bob 4s ease-in-out infinite; }
.fc-2{ left:-26px; bottom:20%; animation:bob 4s ease-in-out infinite .8s; }
@keyframes bob{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(-12px);} }

/* ============ MARQUEE ============ */
.marquee{ border-block:1px solid var(--line); padding:26px 0; overflow:hidden; background:var(--bg-2); }
.marquee-track{ display:flex; gap:60px; width:max-content; animation:scroll 26s linear infinite; }
.marquee-track span{ font-family:'Bricolage Grotesque'; font-weight:700; font-size:22px; color:var(--muted-2);
  display:flex; align-items:center; gap:60px; white-space:nowrap; }
.marquee-track span::after{ content:"✦"; font-size:14px;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ============ SECTION HEAD ============ */
.head{ max-width:720px; margin-bottom:64px; }
.head h2{ font-size:clamp(32px,4.4vw,54px); margin-bottom:18px; }
.head p{ color:var(--muted); font-size:18px; }
.head.center{ margin-inline:auto; text-align:center; }
.head.center .eyebrow{ justify-content:center; }

/* ============ SERVICES ============ */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:34px 30px;
  position:relative; overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease), box-shadow .4s, border-color .4s; }
.svc::before{ content:""; position:absolute; left:0; top:0; height:4px; width:0; background:var(--grad); transition:width .45s var(--ease); }
.svc:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:rgba(225,78,200,.3); }
.svc:hover::before{ width:100%; }
.svc-ic{ width:56px; height:56px; border-radius:15px; display:grid; place-items:center; font-size:25px;
  background:var(--grad-soft); border:1px solid var(--line); margin-bottom:24px; transition:transform .4s; }
.svc:hover .svc-ic{ transform:rotate(-6deg) scale(1.05); }
.svc h3{ font-size:23px; margin-bottom:12px; }
.svc p{ color:var(--muted); font-size:15.5px; }
.svc .tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:20px; }
.svc .tags span{ font-size:12px; font-weight:600; color:var(--violet); background:var(--grad-soft); border-radius:100px; padding:5px 12px; }

/* ============ SPLIT ============ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; }
.split-visual{ border-radius:var(--radius); border:1px solid var(--line); overflow:hidden; aspect-ratio:1/1;
  position:relative; background:radial-gradient(120% 120% at 50% 0%, #fff, var(--surface-2)); box-shadow:var(--shadow); }
/* rotating dashed orbit rings, each carrying a glowing comet */
.o-ring{ position:absolute; border-radius:50%; border:1.5px dashed rgba(120,84,255,.22); animation:spin var(--d) linear infinite; }
.or1{ inset:7%;  --d:26s; }
.or2{ inset:21%; --d:18s; animation-direction:reverse; border-color:rgba(225,78,200,.24); }
.or3{ inset:35%; --d:12s; }
.o-comet{ position:absolute; top:-6px; left:calc(50% - 6px); width:12px; height:12px; border-radius:50%;
  background:var(--grad); box-shadow:0 0 16px 3px rgba(225,78,200,.55); }
/* pulsing gradient-edged core */
.o-core{ position:absolute; inset:0; margin:auto; width:46%; height:46%; border-radius:50%; z-index:3;
  display:grid; place-content:center; text-align:center; background:radial-gradient(circle at 50% 38%, #fff, var(--surface-2));
  border:1px solid var(--line); box-shadow:0 18px 44px -16px rgba(120,84,255,.45); animation:corepulse 3.6s ease-in-out infinite; }
@keyframes corepulse{ 0%,100%{ box-shadow:0 18px 44px -16px rgba(120,84,255,.35);} 50%{ box-shadow:0 24px 58px -14px rgba(225,78,200,.5);} }
.o-core b{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:clamp(32px,6vw,56px); line-height:1;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.o-core small{ display:block; margin-top:6px; color:var(--muted); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; }
/* floating channel chips */
.o-chip{ position:absolute; z-index:4; display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,.92);
  backdrop-filter:blur(6px); border:1px solid var(--line); border-radius:100px; padding:7px 13px; font-size:12.5px;
  font-weight:700; color:var(--text); box-shadow:var(--shadow-sm); animation:bob 4.5s ease-in-out infinite; }
.oc1{ top:11%; left:5%; }
.oc2{ top:16%; right:4%; animation-delay:.7s; }
.oc3{ bottom:17%; left:4%; animation-delay:1.4s; }
.oc4{ bottom:11%; right:6%; animation-delay:2.1s; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.feat-list{ list-style:none; margin-top:28px; display:grid; gap:16px; }
.feat-list li{ display:flex; gap:14px; align-items:flex-start; }
.feat-list .ck{ flex-shrink:0; width:26px; height:26px; border-radius:8px; background:var(--grad); color:#fff;
  display:grid; place-items:center; font-size:13px; margin-top:3px; }
.feat-list b{ font-family:'Bricolage Grotesque'; }
.feat-list p{ color:var(--muted); font-size:15px; }

/* ============ MISSION / VISION ============ */
.mv-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.mv{ border-radius:var(--radius); padding:44px 40px; position:relative; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.mv.mission{ background:linear-gradient(160deg, rgba(225,78,200,.10), var(--surface)); }
.mv.vision{ background:linear-gradient(160deg, rgba(120,84,255,.10), var(--surface)); }
.mv .num{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:15px; letter-spacing:.2em; color:var(--muted-2); }
.mv h3{ font-size:30px; margin:14px 0 16px; }
.mv p{ color:var(--muted); }
.mv .glyph{ position:absolute; right:-10px; bottom:-30px; font-size:140px; font-family:'Bricolage Grotesque'; font-weight:800;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; opacity:.10; }

/* ============ STATS STRIP ============ */
.stats-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.stat-box{ border:1px solid var(--line); border-radius:var(--radius-sm); padding:30px 26px; background:var(--surface); box-shadow:var(--shadow-sm); }
.stat-box .num{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:46px; letter-spacing:-.03em;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat-box .lbl{ color:var(--muted); font-weight:600; font-size:14px; margin-top:4px; }

/* ============ TESTIMONIALS ============ */
.test-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.test{ border:1px solid var(--line); border-radius:var(--radius); padding:34px 32px; background:var(--surface); position:relative; box-shadow:var(--shadow-sm); }
.test .quote-mark{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:60px; line-height:.6;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; opacity:.4; }
.test p{ font-size:18px; margin:8px 0 24px; }
.test .who{ display:flex; align-items:center; gap:14px; }
.avatar{ width:48px; height:48px; border-radius:50%; display:grid; place-items:center; font-family:'Bricolage Grotesque'; font-weight:800; color:#fff; }
.who b{ font-family:'Bricolage Grotesque'; display:block; }
.who .stars{ color:var(--magenta); font-size:13px; letter-spacing:2px; }

/* ============ TEAM ============ */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.member{ border:1px solid var(--line); border-radius:var(--radius); padding:32px; background:var(--surface); box-shadow:var(--shadow-sm);
  transition:border-color .4s, transform .4s, box-shadow .4s; }
.member:hover{ border-color:rgba(225,78,200,.35); transform:translateY(-5px); box-shadow:var(--shadow); }
.member .ava{ width:72px; height:72px; border-radius:18px; display:grid; place-items:center; font-family:'Bricolage Grotesque';
  font-weight:800; font-size:26px; color:#fff; margin-bottom:20px; }
.member h4{ font-size:21px; }
.member .role{ font-weight:700; font-size:14px; margin:6px 0 10px;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.member p{ color:var(--muted); font-size:14.5px; }

/* ============ VALUES ============ */
.val-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.val{ border:1px solid var(--line); border-radius:var(--radius-sm); padding:30px 28px; background:var(--surface); box-shadow:var(--shadow-sm); transition:transform .4s, box-shadow .4s; }
.val:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.val .ic{ width:48px; height:48px; border-radius:13px; background:var(--grad-soft); display:grid; place-items:center; font-size:22px; margin-bottom:18px; }
.val h4{ font-size:19px; margin-bottom:9px; }
.val p{ color:var(--muted); font-size:14.5px; }

/* ============ PROCESS ============ */
.proc-list{ display:grid; gap:0; }
.proc{ display:grid; grid-template-columns:80px 1fr; gap:28px; padding:30px 0; border-top:1px solid var(--line); align-items:start; transition:padding-left .3s var(--ease); }
.proc:last-child{ border-bottom:1px solid var(--line); }
.proc:hover{ padding-left:14px; }
.proc .pn{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:30px; color:var(--muted-2); transition:.3s; }
.proc:hover .pn{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.proc h4{ font-size:22px; margin-bottom:8px; }
.proc p{ color:var(--muted); max-width:640px; }

/* ============ PAGE HEADER ============ */
.page-head{ padding:82px 0 50px; }
.page-head h1{ font-size:clamp(40px,6vw,72px); }
.page-head .crumb{ color:var(--muted-2); font-weight:600; font-size:14px; margin-bottom:18px; }
.page-head p{ color:var(--muted); font-size:19px; max-width:620px; margin-top:18px; }

/* ============ CONTACT ============ */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:50px; align-items:start; }
.contact-info{ display:grid; gap:18px; }
.ci-card{ border:1px solid var(--line); border-radius:var(--radius-sm); padding:24px; background:var(--surface); box-shadow:var(--shadow-sm); display:flex; gap:16px; align-items:flex-start; }
.ci-card .ic{ flex-shrink:0; width:48px; height:48px; border-radius:13px; background:var(--grad-soft); display:grid; place-items:center; font-size:22px; }
.ci-card .lbl{ font-size:13px; color:var(--muted-2); font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.ci-card .val{ font-family:'Bricolage Grotesque'; font-weight:600; font-size:17px; margin-top:3px; }
.ci-card a:hover{ color:var(--magenta); }
.socials{ display:flex; gap:12px; }
.socials a{ width:44px; height:44px; border-radius:13px; border:1px solid var(--line); display:grid; place-items:center; color:var(--muted); background:var(--surface); transition:.3s; }
.socials a:hover{ border-color:transparent; background:var(--grad); color:#fff; transform:translateY(-3px); }

.form-card{ border:1px solid var(--line); border-radius:var(--radius); padding:40px; background:var(--surface); box-shadow:var(--shadow); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-weight:700; font-size:13px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); margin-bottom:9px; }
.field input, .field textarea{ width:100%; background:var(--bg); border:1.5px solid var(--line); border-radius:12px; padding:15px 17px;
  color:var(--text); font-family:'Manrope'; font-size:16px; transition:border-color .25s, background .25s, box-shadow .25s; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--magenta); background:var(--surface); box-shadow:0 0 0 4px rgba(225,78,200,.12); }
.field textarea{ resize:vertical; min-height:130px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-note{ font-size:13px; color:var(--muted-2); margin-top:14px; }
.form-success{ display:none; background:var(--grad-soft); border:1px solid rgba(225,78,200,.4); color:var(--violet); border-radius:12px; padding:16px; font-weight:700; margin-bottom:20px; }
.form-success.show{ display:block; }

.map-wrap{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-top:60px; height:420px; box-shadow:var(--shadow-sm); }
.map-wrap iframe{ width:100%; height:100%; border:0; filter:grayscale(.15) contrast(1.02); }

/* ============ CTA BANNER (gradient color-block) ============ */
.cta-banner{ border-radius:30px; padding:74px 60px; position:relative; overflow:hidden; background:var(--grad); color:#fff; text-align:center; box-shadow:var(--shadow); }
.cta-banner h2{ font-size:clamp(32px,4.5vw,56px); margin-bottom:16px; }
.cta-banner p{ font-size:19px; opacity:.92; max-width:560px; margin:0 auto 32px; font-weight:500; }
.cta-banner .btn-primary{ background:#fff; color:var(--violet); box-shadow:0 14px 30px -10px rgba(0,0,0,.3); }
.cta-banner .btn-primary:hover{ filter:none; box-shadow:0 18px 36px -10px rgba(0,0,0,.4); }
.cta-banner .glyph{ position:absolute; font-family:'Bricolage Grotesque'; font-weight:800; opacity:.14; color:#fff; }
.cta-banner .g1{ font-size:210px; left:-30px; top:-72px; }
.cta-banner .g2{ font-size:210px; right:-30px; bottom:-112px; }

/* ============ FOOTER (dark color-block) ============ */
.footer{ position:relative; z-index:1; background:var(--dark); color:#EFEAF5; padding:74px 0 36px; margin-top:110px; }
.footer::before{ content:""; position:absolute; left:0; right:0; top:0; height:3px; background:var(--grad); }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:40px; margin-bottom:50px; }
.footer .logo{ margin-bottom:18px; }
.footer .logo-img{ height:42px; }
.footer .desc{ color:#A79DB4; font-size:15px; max-width:280px; }
.footer h5{ font-family:'Bricolage Grotesque'; font-size:15px; letter-spacing:.05em; margin-bottom:18px; color:#fff; }
.footer ul{ list-style:none; display:grid; gap:11px; }
.footer ul a{ color:#A79DB4; font-size:15px; transition:color .25s; }
.footer ul a:hover{ color:var(--magenta); }
.footer .addr{ color:#A79DB4; font-size:14.5px; line-height:1.8; }
.footer .addr a:hover{ color:var(--magenta); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding-top:26px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; color:#7F7690; font-size:14px; }

/* ============ RESPONSIVE ============ */
@media (max-width:980px){
  .hero-grid, .split, .contact-grid{ grid-template-columns:1fr; gap:44px; }
  .hero-visual{ max-width:440px; margin-inline:auto; width:100%; }
  .svc-grid, .team-grid, .val-grid{ grid-template-columns:1fr 1fr; }
  .stats-strip{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:720px){
  body{ font-size:16px; }
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .logo-img{ height:40px; }
  .nav-links.open{ display:flex; flex-direction:column; position:absolute; top:78px; left:0; right:0; background:var(--surface);
    border-bottom:1px solid var(--line); padding:24px 28px; gap:20px; box-shadow:var(--shadow-sm); }
  .section-pad{ padding:74px 0; }
  .svc-grid, .team-grid, .val-grid, .mv-grid, .test-grid, .stats-strip, .field-row{ grid-template-columns:1fr; }
  .hero-stats{ gap:26px; flex-wrap:wrap; }
  .cta-banner{ padding:50px 28px; }
  .footer-grid{ grid-template-columns:1fr; gap:32px; }
  .float-card{ display:none; }
}

/* ============ BACKGROUND MOTION + SCROLL CUE ============ */
@keyframes aurora{
  0%{   transform:translate(0,0) scale(1); }
  100%{ transform:translate(-1.5%,-2.5%) scale(1.08); }
}
/* soft drifting colour blobs inside the hero */
.hero-blob{ position:absolute; border-radius:50%; filter:blur(64px); z-index:0; pointer-events:none; }
.hb1{ width:360px; height:360px; top:-70px; left:-50px;
  background:radial-gradient(circle, rgba(225,78,200,.32), transparent 70%); animation:floatblob 13s ease-in-out infinite; }
.hb2{ width:320px; height:320px; bottom:-60px; right:4%;
  background:radial-gradient(circle, rgba(120,84,255,.30), transparent 70%); animation:floatblob 16s ease-in-out infinite 1.6s; }
@keyframes floatblob{ 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(22px,-28px); } }

/* animated "scroll to explore" indicator */
.scroll-cue{ position:absolute; left:50%; bottom:20px; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px; color:var(--muted); transition:color .25s; }
.scroll-cue:hover{ color:var(--magenta); }
.scroll-cue .cue-text{ font-size:11px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; }
.scroll-cue .mouse{ width:26px; height:42px; border:2px solid var(--violet); border-radius:14px;
  display:flex; justify-content:center; padding-top:7px; }
.scroll-cue .wheel{ width:4px; height:8px; border-radius:3px; background:var(--grad); animation:wheel 1.6s ease-in-out infinite; }
@keyframes wheel{ 0%{ transform:translateY(0); opacity:1; } 55%{ transform:translateY(11px); opacity:0; }
  56%{ transform:translateY(0); opacity:0; } 100%{ transform:translateY(0); opacity:1; } }

@media (max-width:720px){
  .scroll-cue{ display:none; }
  .hero-blob{ filter:blur(50px); opacity:.7; }
}
