:root {
  --blue:    #1a6fc4;
  --blue-2:  #38bdf8;
  --dark:    #07101f;
  --dark-2:  #0f1d30;
  --text:    #0f172a;
  --muted:   #64748b;
  --bg:      #ffffff;
  --bg-alt:  #f8fafc;
  --border:  #e2e8f0;
  --max:     1200px;
  --radius:  22px;
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text); background:var(--bg);
  line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}

/* ━━━━ PAGE CURSOR GLOW ━━━━ */
#page-glow {
  position:fixed; inset:0; pointer-events:none; z-index:9998;
  background:radial-gradient(800px circle at 50% 50%, rgba(26,111,196,.04), transparent 55%);
  transition:background .15s ease;
}
a { color:inherit; }

.container { width:min(var(--max), 100%); padding:0 48px; margin:0 auto; }

/* ━━━━ NAV ━━━━ */
nav {
  position:fixed; inset:0 0 auto 0; z-index:1000; height:80px;
  display:flex; align-items:center;
  transition:background .3s, box-shadow .3s;
}
nav.scrolled {
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(18px);
  box-shadow:0 1px 0 var(--border);
}
.nav-wrap { display:flex; align-items:center; justify-content:space-between; width:100%; }
.nav-logo { width:400px; height:auto; display:block; }

/* show white logo on dark hero, colored logo after scroll */
nav:not(.scrolled) .logo-dark  { display:none; }
nav:not(.scrolled) .logo-light { display:block; }
nav.scrolled .logo-dark        { display:block; }
nav.scrolled .logo-light       { display:none; }

.nav-links { list-style:none; display:flex; align-items:center; gap:30px; }
.nav-links a {
  text-decoration:none; font-size:.9rem; font-weight:600;
  position:relative; transition:color .2s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0;
  height:2px; background:var(--blue); border-radius:2px;
  transform:scaleX(0); transform-origin:left; transition:transform .22s;
}
nav:not(.scrolled) .nav-links a { color:rgba(255,255,255,.8); }
nav.scrolled .nav-links a { color:var(--text); }
.nav-links a:hover { color:var(--blue) !important; }
.nav-links a:hover::after { transform:scaleX(1); }

.nav-btn {
  padding:11px 24px; border-radius:9999px; text-decoration:none;
  font-weight:700; font-size:.875rem; transition:all .22s;
}
.nav-btn::after { display:none !important; }
nav:not(.scrolled) .nav-btn {
  background:rgba(255,255,255,.13); color:white;
  border:1.5px solid rgba(255,255,255,.26);
}
nav:not(.scrolled) .nav-btn:hover { background:rgba(255,255,255,.22); }
nav.scrolled .nav-btn {
  background:var(--blue); color:white;
  box-shadow:0 4px 18px rgba(26,111,196,.32);
}
nav.scrolled .nav-btn:hover { transform:translateY(-1px); box-shadow:0 6px 26px rgba(26,111,196,.44); }

.burger { display:none; background:none; border:none; cursor:pointer; padding:4px; }
.burger svg { width:26px; height:26px; fill:none; stroke-width:2.2; stroke-linecap:round; }
nav:not(.scrolled) .burger svg { stroke:white; }
nav.scrolled .burger svg { stroke:var(--text); }

.mobile-nav {
  display:none; position:fixed; top:80px; inset-inline:0; z-index:999;
  background:white; border-bottom:1px solid var(--border);
  box-shadow:0 16px 40px rgba(15,23,42,.09);
}
.mobile-nav.open { display:block; }
.mobile-nav a {
  display:block; padding:16px 24px; text-decoration:none;
  font-weight:600; border-top:1px solid var(--border); color:var(--text);
}

/* ━━━━ HERO ━━━━ */
#hero {
  min-height:100vh; display:flex; align-items:center;
  background:linear-gradient(160deg,#020c1b 0%,#071525 55%,#0b1e35 100%);
  color:white; position:relative; overflow:hidden;
}

/* Dot grid */
#hero::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.18) 1px,transparent 1px);
  background-size:38px 38px;
}

/* Top-edge glow */
#hero::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,rgba(56,189,248,.6),rgba(139,92,246,.4),transparent);
}

/* Floating orbs */
.orb {
  position:absolute; border-radius:50%; pointer-events:none;
  filter:blur(90px);
}
.orb-1 {
  width:700px; height:700px;
  background:radial-gradient(circle,rgba(26,111,196,.55) 0%,transparent 68%);
  top:-220px; left:-180px;
  animation:orbFloat1 20s ease-in-out infinite;
}
.orb-2 {
  width:520px; height:520px;
  background:radial-gradient(circle,rgba(56,189,248,.3) 0%,transparent 65%);
  top:80px; right:-120px;
  animation:orbFloat2 25s ease-in-out infinite;
}
.orb-3 {
  width:420px; height:420px;
  background:radial-gradient(circle,rgba(139,92,246,.22) 0%,transparent 65%);
  bottom:-80px; left:38%;
  animation:orbFloat3 18s ease-in-out infinite;
}

@keyframes orbFloat1 {
  0%,100% { transform:translate(0,0) scale(1); }
  33%     { transform:translate(70px,55px) scale(1.08); }
  66%     { transform:translate(-35px,80px) scale(0.96); }
}
@keyframes orbFloat2 {
  0%,100% { transform:translate(0,0) scale(1); }
  40%     { transform:translate(-90px,50px) scale(1.12); }
  75%     { transform:translate(-30px,-40px) scale(0.94); }
}
@keyframes orbFloat3 {
  0%,100% { transform:translate(0,0) scale(1); }
  30%     { transform:translate(55px,-45px) scale(1.1); }
  70%     { transform:translate(-45px,30px) scale(0.92); }
}

.hero-grid {
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.1fr .9fr;
  gap:44px; align-items:center; width:100%; padding-top:88px;
}
.hero-center {
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center;
  text-align:center; padding-top:120px; padding-bottom:80px;
  max-width:820px; margin:0 auto;
}

.eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 18px; border-radius:9999px;
  font-size:.76rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.78); background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15); margin-bottom:28px;
}
.eyebrow .dot {
  width:8px; height:8px; border-radius:50%; background:#22c55e; flex-shrink:0;
  box-shadow:0 0 0 0 rgba(34,197,94,.35); animation:ping 2s infinite;
}
@keyframes ping {
  0%   { box-shadow:0 0 0 0 rgba(34,197,94,.35); }
  70%  { box-shadow:0 0 0 10px rgba(34,197,94,0); }
  100% { box-shadow:0 0 0 0 rgba(34,197,94,0); }
}

.hero-copy h1, .hero-center h1 {
  font-size:clamp(3rem,6vw,5.2rem); line-height:1.0;
  letter-spacing:-.05em; font-weight:800; margin-bottom:28px;
}
.hero-copy h1 em, .hero-center h1 em {
  font-style:normal;
  background:linear-gradient(100deg,#7dd3fc 0%,#38bdf8 30%,#c084fc 60%,#7dd3fc 100%);
  background-size:200% auto;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  animation:shimmer 5s linear infinite;
}
@keyframes shimmer {
  0%   { background-position:0% center; }
  100% { background-position:200% center; }
}
.hero-copy > p { font-size:1.1rem; color:rgba(255,255,255,.68); max-width:520px; margin-bottom:24px; }
.hero-center > p { font-size:1.18rem; color:rgba(255,255,255,.62); max-width:600px; margin-bottom:40px; line-height:1.75; }

.hero-bullets { list-style:none; display:grid; gap:11px; margin-bottom:36px; max-width:520px; }
.hero-bullets li {
  display:flex; align-items:center; gap:12px;
  color:rgba(255,255,255,.84); font-size:.95rem; font-weight:500;
}
.hero-bullets li::before {
  content:''; width:9px; height:9px; border-radius:50%;
  background:var(--blue-2); flex-shrink:0;
  box-shadow:0 0 0 4px rgba(56,189,248,.15);
}

/* Scroll indicator */
.scroll-hint {
  position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:6px;
  text-decoration:none; z-index:2;
  animation:scrollBob 2.4s ease-in-out infinite;
}
.scroll-hint-line {
  display:block; width:1.5px; height:52px;
  background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);
  position:relative;
}
.scroll-hint-line::after {
  content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:6px; height:6px; border-radius:50%;
  background:rgba(56,189,248,.85);
  box-shadow:0 0 10px rgba(56,189,248,.6);
  animation:dropDown 2.4s ease-in-out infinite;
}
@keyframes scrollBob {
  0%,100% { opacity:.5; }
  50%      { opacity:1; }
}
@keyframes dropDown {
  0%   { top:0; opacity:1; }
  80%  { top:42px; opacity:.2; }
  100% { top:0; opacity:0; }
}

.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.btn-fill {
  display:inline-flex; align-items:center; justify-content:center;
  padding:0 30px; min-height:52px; border-radius:9999px;
  font-weight:700; font-size:.95rem; text-decoration:none; transition:all .22s;
  background:var(--blue); color:white; box-shadow:0 8px 26px rgba(26,111,196,.42);
}
.btn-fill:hover { transform:translateY(-2px); filter:brightness(1.08); box-shadow:0 12px 36px rgba(26,111,196,.55); }
.btn-ghost {
  display:inline-flex; align-items:center; justify-content:center;
  padding:0 30px; min-height:52px; border-radius:9999px;
  font-weight:600; font-size:.95rem; text-decoration:none; transition:all .22s;
  border:1.5px solid rgba(255,255,255,.24); color:rgba(255,255,255,.88);
  background:rgba(255,255,255,.05);
}
.btn-ghost:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.46); transform:translateY(-2px); }

/* Hero right card */
/* ━━━━ VS CODE HERO PANEL ━━━━ */
.vsc-win {
  background:#1e1e1e; border-radius:14px;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 32px 80px rgba(0,0,0,.55);
  overflow:hidden;
  font-family:'Cascadia Code','Fira Code','JetBrains Mono','Courier New',monospace;
  font-size:.76rem; line-height:1;
}
.vsc-bar {
  display:flex; align-items:center; gap:7px;
  padding:10px 14px; background:#2d2d2d;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.vsc-dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.vd-r { background:#ff5f57; }
.vd-y { background:#febc2e; }
.vd-g { background:#28c840; }
.vsc-tabs { display:flex; gap:1px; margin-left:10px; }
.vsc-tab {
  padding:5px 16px; font-size:.71rem; color:rgba(255,255,255,.35);
  border-radius:4px 4px 0 0; cursor:default;
}
.vsc-tab-active { background:#1e1e1e; color:rgba(255,255,255,.82); border-top:1.5px solid #569cd6; }
.vsc-body { display:flex; padding:18px 0 22px; min-height:300px; }
.vsc-gutter {
  padding:0 14px; text-align:right; color:#3e3e3e;
  font-size:.72rem; line-height:1.85; user-select:none; min-width:42px;
  border-right:1px solid rgba(255,255,255,.05); flex-shrink:0;
}
.vsc-code { padding:0 20px; flex:1; overflow:hidden; }
.vsc-line {
  line-height:1.85; white-space:pre;
  opacity:0; transform:translateX(-6px);
  transition:opacity .18s ease, transform .18s ease;
}
.vsc-line.show { opacity:1; transform:translateX(0); }
.vs-c { color:#6a9955; }
.vs-k { color:#569cd6; }
.vs-s { color:#ce9178; }
.vs-p { color:#9cdcfe; }
.vs-b { color:#569cd6; }
.vs-n { color:#b5cea8; }
.vs-x { color:#d4d4d4; }
.vsc-cursor {
  display:inline-block; width:2px; height:13px;
  background:#aeafad; vertical-align:middle; margin-left:1px;
  animation:vscblink .65s step-end infinite;
}
@keyframes vscblink { 0%,100%{opacity:1} 50%{opacity:0} }

.hero-card {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  border-radius:24px; padding:30px;
  backdrop-filter:blur(14px); box-shadow:0 30px 80px rgba(0,0,0,.24);
}
.hero-card .card-label {
  display:block; font-size:.72rem; font-weight:800; letter-spacing:.18em;
  text-transform:uppercase; color:rgba(255,255,255,.38); margin-bottom:20px;
}
.proof-item {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  border-radius:16px; padding:18px; margin-bottom:12px; transition:all .2s;
}
.proof-item:last-of-type { margin-bottom:0; }
.proof-item:hover { background:rgba(255,255,255,.09); transform:translateX(3px); }
.proof-item strong { display:block; color:white; font-size:.95rem; margin-bottom:5px; }
.proof-item span { color:rgba(255,255,255,.58); font-size:.86rem; line-height:1.5; }
.hero-metrics { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:18px; }
.hmetric {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  border-radius:16px; padding:18px; text-align:center;
}
.hmetric strong { display:block; font-size:1.9rem; line-height:1; letter-spacing:-.05em; color:white; font-weight:800; }
.hmetric span { display:block; margin-top:6px; color:rgba(255,255,255,.38); font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; }

/* ━━━━ TRUST BAR ━━━━ */
.trustbar {
  background:var(--dark); border-top:none; border-bottom:none;
}

/* ━━━━ SECTIONS ━━━━ */
.section { padding:120px 0; }
.section-alt { background:var(--bg-alt); }
.section-dark { background:var(--dark-2); }

.sec-head { margin-bottom:72px; }
.sec-label {
  display:block; font-size:.74rem; font-weight:800;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--blue); margin-bottom:14px;
}
.sec-label-light { color:#5ba3e8; }
.sec-title {
  font-size:clamp(1.9rem,3.8vw,2.9rem); font-weight:800;
  letter-spacing:-.04em; line-height:1.1; margin-bottom:16px;
}
.sec-title-light { color:white; }
.sec-copy { font-size:1.04rem; color:var(--muted); max-width:680px; line-height:1.78; }
.sec-copy-light { color:rgba(255,255,255,.48); }

/* ━━━━ SERVICE CARDS ━━━━ */
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc-card {
  background:white; border:1.5px solid var(--border);
  border-radius:var(--radius); padding:32px;
  display:flex; flex-direction:column;
  box-shadow:0 4px 24px rgba(15,23,42,.06);
  transition:transform .25s, box-shadow .25s, border-color .25s;
  position:relative; overflow:hidden;
}

/* permanent colored top accent */
.svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
}
.svc-card.svc-1::before { background:linear-gradient(90deg,#1a6fc4,#38bdf8); }
.svc-card.svc-2::before { background:linear-gradient(90deg,#7c3aed,#c084fc); }
.svc-card.svc-3::before { background:linear-gradient(90deg,#0891b2,#22d3ee); }

/* per-card hover */
.svc-card.svc-1:hover { transform:translateY(-5px); border-color:rgba(26,111,196,.3);  box-shadow:0 0 0 1px rgba(26,111,196,.12), 0 24px 64px rgba(26,111,196,.13); }
.svc-card.svc-2:hover { transform:translateY(-5px); border-color:rgba(124,58,237,.3);  box-shadow:0 0 0 1px rgba(124,58,237,.12), 0 24px 64px rgba(124,58,237,.13); }
.svc-card.svc-3:hover { transform:translateY(-5px); border-color:rgba(8,145,178,.3);   box-shadow:0 0 0 1px rgba(8,145,178,.12),  0 24px 64px rgba(8,145,178,.13); }

/* styled icon container */
.svc-ico {
  width:52px; height:52px; border-radius:14px;
  display:grid; place-items:center;
  margin-bottom:22px; flex-shrink:0;
}
.svc-ico svg { width:24px; height:24px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.svc-card.svc-1 .svc-ico { background:rgba(26,111,196,.1);  border:1px solid rgba(26,111,196,.18); color:#1a6fc4; }
.svc-card.svc-2 .svc-ico { background:rgba(124,58,237,.1);  border:1px solid rgba(124,58,237,.18); color:#7c3aed; }
.svc-card.svc-3 .svc-ico { background:rgba(8,145,178,.1);   border:1px solid rgba(8,145,178,.18);  color:#0891b2; }

.svc-card h3 { font-size:1.06rem; font-weight:800; margin-bottom:10px; }
.svc-card > p { color:var(--muted); font-size:.93rem; margin-bottom:18px; line-height:1.7; }
.svc-list { list-style:none; display:grid; gap:9px; }
.svc-list li { display:flex; gap:10px; color:var(--muted); font-size:.88rem; }
.svc-card.svc-1 .svc-list li::before { content:'→'; color:#1a6fc4; font-weight:800; flex-shrink:0; }
.svc-card.svc-2 .svc-list li::before { content:'→'; color:#7c3aed; font-weight:800; flex-shrink:0; }
.svc-card.svc-3 .svc-list li::before { content:'→'; color:#0891b2; font-weight:800; flex-shrink:0; }

/* tech tags */
.svc-tech {
  display:flex; flex-wrap:wrap; gap:6px;
  margin-top:auto; padding-top:18px; border-top:1px solid var(--border);
}
.svc-tech span { font-size:.71rem; font-weight:600; padding:3px 10px; border-radius:9999px; letter-spacing:.03em; white-space:nowrap; }
.svc-card.svc-1 .svc-tech span { background:rgba(26,111,196,.07);  color:#1a6fc4; border:1px solid rgba(26,111,196,.16); }
.svc-card.svc-2 .svc-tech span { background:rgba(124,58,237,.07);  color:#7c3aed; border:1px solid rgba(124,58,237,.16); }
.svc-card.svc-3 .svc-tech span { background:rgba(8,145,178,.07);   color:#0891b2; border:1px solid rgba(8,145,178,.16); }

/* ━━━━ RESULTS ━━━━ */
.results-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:860px; margin:0 auto; }
.result {
  background:white; border:1.5px solid var(--border);
  border-radius:20px; padding:28px 22px 26px; text-align:center;
  box-shadow:0 4px 20px rgba(15,23,42,.05); transition:all .3s;
  position:relative; overflow:hidden;
  border-top-width:3px;
}
.result:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(15,23,42,.1); }
.result::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 110%, var(--res-glow,rgba(26,111,196,.1)), transparent 65%);
  opacity:0; transition:opacity .4s;
}
.result:hover::before { opacity:1; }

/* per-card accent colours */
.res-1 { border-top-color:#1a6fc4; --res-glow:rgba(26,111,196,.12); }
.res-2 { border-top-color:#7c3aed; --res-glow:rgba(124,58,237,.12); }
.res-3 { border-top-color:#0891b2; --res-glow:rgba(8,145,178,.12);  }
.res-1:hover { border-color:#1a6fc4; }
.res-2:hover { border-color:#7c3aed; }
.res-3:hover { border-color:#0891b2; }


.result strong { display:block; font-size:2.6rem; line-height:1; letter-spacing:-.06em; font-weight:800; }
.res-1 strong { color:#1a6fc4; }
.res-2 strong { color:#7c3aed; }
.res-3 strong { color:#0891b2; }

.result span { display:block; margin-top:10px; color:var(--text); font-size:.8rem; text-transform:uppercase; letter-spacing:.09em; font-weight:700; }
.res-sub { display:block !important; margin-top:6px !important; font-size:.72rem !important; color:var(--muted) !important; text-transform:none !important; letter-spacing:0 !important; font-weight:400 !important; line-height:1.4; }

/* ━━━━ SPLIT SECTIONS ━━━━ */
.split {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:580px; align-items:stretch;
}
.split-text {
  display:flex; flex-direction:column; justify-content:center;
  padding:90px 8% 90px 0;
}
.split-text.pad-l { padding:90px 0 90px 8%; }
.split-visual {
  display:flex; align-items:center; justify-content:center;
  padding:60px 0 60px 8%; background:var(--bg-alt);
}
.split-visual.pad-r { padding:60px 8% 60px 0; background:var(--bg-alt); }
.split-visual.dark-vis { background:var(--dark); padding:60px 0 60px 8%; }
.split-visual.dark-vis-r { background:var(--dark); padding:60px 8% 60px 0; }
.split-bg-light { background:var(--bg); }
.split-bg-alt { background:var(--bg-alt); }
.split-bg-dark { background:var(--dark-2); }

/* Split padding helpers */
.split-pad-left  { padding:90px 6% 90px clamp(24px, calc((100vw - 1200px)/2 + 48px), 15%); }
.split-pad-right { padding:90px clamp(24px, calc((100vw - 1200px)/2 + 48px), 15%) 90px 6%; }
.split-visual.split-pad-left  { padding:60px 11% 60px clamp(24px, calc((100vw - 1200px)/2 + 48px), 15%); }
.split-visual.split-pad-right { padding:60px clamp(24px, calc((100vw - 1200px)/2 + 48px), 15%) 60px 11%; }

.split-text .cta-link {
  display:inline-flex; align-items:center; gap:8px; margin-top:32px;
  color:var(--blue); font-weight:700; font-size:.95rem;
  text-decoration:none; transition:gap .2s;
}
.split-text .cta-link:hover { gap:14px; }
.split-text .cta-link.light { color:#5ba3e8; }

/* Visual panels */
.vis-dark {
  background:var(--dark-2); border:1px solid rgba(255,255,255,.07);
  border-radius:22px; padding:32px; width:100%;
  box-shadow:0 24px 64px rgba(0,0,0,.28);
}
.vis-light {
  background:white; border:1.5px solid var(--border);
  border-radius:22px; padding:32px; width:100%;
  box-shadow:0 12px 48px rgba(26,111,196,.08);
}
.vis-lbl { font-size:.68rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.3); display:block; margin-bottom:20px; }
.vis-lbl-d { font-size:.68rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); display:block; margin-bottom:20px; }

.feat-list { list-style:none; display:grid; gap:10px; }
.feat-list li {
  display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:13px 15px;
  font-size:.88rem; color:rgba(255,255,255,.84); font-weight:500; transition:all .2s;
}
.feat-list li:hover { background:rgba(255,255,255,.09); transform:translateX(4px); }
.feat-list li .fi {
  width:32px; height:32px; flex-shrink:0; border-radius:8px;
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  display:grid; place-items:center; font-size:.95rem;
}
.feat-list li .fi svg { width:16px; height:16px; stroke:white; fill:none; }
.feat-list-light { list-style:none; display:grid; gap:10px; }
.feat-list-light li {
  display:flex; align-items:center; gap:14px;
  background:var(--bg-alt); border:1.5px solid var(--border);
  border-radius:12px; padding:13px 15px;
  font-size:.88rem; color:var(--text); font-weight:500; transition:all .2s;
}
.feat-list-light li:hover { border-color:rgba(26,111,196,.25); transform:translateX(4px); }
.feat-list-light li .fi {
  width:32px; height:32px; flex-shrink:0; border-radius:8px;
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  display:grid; place-items:center; font-size:.95rem;
}

/* Terminal block */
.term-block {
  background:#0d1117; border:1px solid rgba(255,255,255,.1);
  border-radius:16px; overflow:hidden; width:100%;
  box-shadow:0 24px 64px rgba(0,0,0,.45);
  font-family:'Fira Code','Courier New',monospace;
}
.term-header {
  background:#161b22; border-bottom:1px solid rgba(255,255,255,.07);
  padding:13px 18px; display:flex; align-items:center; gap:7px;
}
.term-dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.td-r { background:#ff5f57; }
.td-y { background:#febc2e; }
.td-g { background:#28c840; }
.term-title { margin-left:10px; font-size:.72rem; color:rgba(255,255,255,.3); letter-spacing:.02em; }
.term-body { padding:22px 22px 24px; display:flex; flex-direction:column; gap:2px; }
.term-line {
  font-size:.76rem; line-height:1.7; color:rgba(255,255,255,.65);
  display:flex; gap:6px; align-items:baseline; white-space:pre;
}
.term-line.t-blank { height:8px; }
.term-line.t-divider { height:1px; background:rgba(255,255,255,.07); margin:8px 0; }
.term-line.t-indent { padding-left:20px; }
.t-prompt { color:#7c3aed; font-weight:700; flex-shrink:0; }
.t-cmd    { color:#7dd3fc; font-weight:600; }
.t-arg    { color:rgba(255,255,255,.45); }
.t-add    { color:#34d399; font-weight:700; flex-shrink:0; }
.t-key    { color:#7dd3fc; }
.t-str    { color:#fbbf24; }
.t-attr   { color:rgba(255,255,255,.5); }
.t-val    { color:#c084fc; }
.t-success { color:#34d399; font-weight:700; flex-shrink:0; }
.t-ok     { color:rgba(255,255,255,.9); font-weight:600; }

.mini-metric-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:20px; }
.mini-metric {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.09);
  border-radius:14px; padding:18px; text-align:center;
}
.mini-metric strong { display:block; font-size:1.7rem; font-weight:800; color:white; letter-spacing:-.04em; line-height:1; }
.mini-metric span { display:block; margin-top:7px; color:rgba(255,255,255,.36); font-size:.7rem; text-transform:uppercase; letter-spacing:.09em; }
.mini-metric-light { background:var(--bg-alt); border:1.5px solid var(--border); border-radius:14px; padding:18px; text-align:center; }
.mini-metric-light strong { display:block; font-size:1.7rem; font-weight:800; color:var(--text); letter-spacing:-.04em; line-height:1; }
.mini-metric-light span { display:block; margin-top:7px; color:var(--muted); font-size:.7rem; text-transform:uppercase; letter-spacing:.09em; }

/* Security terminal additions */
.score-bar { height:4px; background:rgba(255,255,255,.1); border-radius:2px; margin:8px 0 2px; }
.score-fill { height:100%; background:linear-gradient(90deg,#34d399,#10b981); border-radius:2px; }
.term-line.t-status-row { display:flex; gap:10px; align-items:baseline; }
.t-muted-label { color:rgba(255,255,255,.4); flex:1; }
.t-score-val { color:rgba(255,255,255,.92); font-weight:700; }
.t-skey { flex:1; color:rgba(255,255,255,.7); }
.t-sval { color:#34d399; font-size:.7rem; font-weight:700; letter-spacing:.04em; }
.t-bracket { color:rgba(255,255,255,.55); }
.t-dim { color:rgba(255,255,255,.3); }
.term-line.t-indent-2 { padding-left:40px; }

/* ━━━━ SKILLS ━━━━ */
.skills-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.skill-card {
  background:white; border:1.5px solid var(--border);
  border-radius:20px; overflow:hidden; transition:all .3s;
  border-top-width:3px;
}
.skill-head {
  padding:22px 24px 16px;
  display:flex; align-items:flex-start; gap:14px;
}
.ski { width:38px; height:38px; border-radius:10px; display:grid; place-items:center; flex-shrink:0; margin-top:2px; }
.ski svg { width:18px; height:18px; stroke:currentColor; fill:none; }
.sk-1 .ski { background:rgba(26,111,196,.1);  color:#1a6fc4; }
.sk-2 .ski { background:rgba(124,58,237,.1);  color:#7c3aed; }
.sk-3 .ski { background:rgba(8,145,178,.1);   color:#0891b2; }
.sk-4 .ski { background:rgba(217,119,6,.1);   color:#d97706; }
.sk-5 .ski { background:rgba(5,150,105,.1);   color:#059669; }
.sk-6 .ski { background:rgba(79,70,229,.1);   color:#4f46e5; }
.skill-head-text { display:flex; flex-direction:column; gap:4px; }
.skill-head h3 { font-size:.95rem; font-weight:700; color:var(--text); line-height:1.3; }
.skill-desc { font-size:.76rem; color:var(--muted); line-height:1.45; margin:0; }
.skill-body { padding:20px 24px 22px; }
.skill-outcomes { list-style:none; display:grid; gap:9px; margin:0 0 0 0; }
.skill-outcomes li {
  display:flex; gap:9px; align-items:flex-start;
  font-size:.83rem; color:var(--muted); line-height:1.5;
}
.skill-outcomes li::before { content:'→'; font-weight:700; flex-shrink:0; margin-top:1px; }
.sk-1 .skill-outcomes li::before { color:#1a6fc4; }
.sk-2 .skill-outcomes li::before { color:#7c3aed; }
.sk-3 .skill-outcomes li::before { color:#0891b2; }
.sk-4 .skill-outcomes li::before { color:#d97706; }
.sk-5 .skill-outcomes li::before { color:#059669; }
.sk-6 .skill-outcomes li::before { color:#4f46e5; }
.skill-divider { height:1px; background:var(--border); margin:16px 0 14px; }
.skill-chips { display:flex; flex-wrap:wrap; gap:7px; }

/* per-card accent colours */
.sk-1 { border-top-color:#1a6fc4; }
.sk-1 .ski { background:linear-gradient(135deg,#1a6fc4,#2563eb); color:white; }
.sk-1:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(26,111,196,.14); border-color:#1a6fc4; }
.sk-1 .chip-core { background:rgba(26,111,196,.09); border-color:rgba(26,111,196,.3); color:#1a6fc4; }

.sk-2 { border-top-color:#7c3aed; }
.sk-2 .ski { background:linear-gradient(135deg,#7c3aed,#6d28d9); color:white; }
.sk-2:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(124,58,237,.14); border-color:#7c3aed; }
.sk-2 .chip-core { background:rgba(124,58,237,.09); border-color:rgba(124,58,237,.3); color:#7c3aed; }

.sk-3 { border-top-color:#0891b2; }
.sk-3 .ski { background:linear-gradient(135deg,#0891b2,#0e7490); color:white; }
.sk-3:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(8,145,178,.14); border-color:#0891b2; }
.sk-3 .chip-core { background:rgba(8,145,178,.09); border-color:rgba(8,145,178,.3); color:#0891b2; }

.sk-4 { border-top-color:#d97706; }
.sk-4 .ski { background:linear-gradient(135deg,#d97706,#b45309); color:white; }
.sk-4:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(217,119,6,.14); border-color:#d97706; }
.sk-4 .chip-core { background:rgba(217,119,6,.09); border-color:rgba(217,119,6,.3); color:#d97706; }

.sk-5 { border-top-color:#059669; }
.sk-5 .ski { background:linear-gradient(135deg,#059669,#047857); color:white; }
.sk-5:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(5,150,105,.14); border-color:#059669; }
.sk-5 .chip-core { background:rgba(5,150,105,.09); border-color:rgba(5,150,105,.3); color:#059669; }

.sk-6 { border-top-color:#4f46e5; }
.sk-6 .ski { background:linear-gradient(135deg,#4f46e5,#4338ca); color:white; }
.sk-6:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(79,70,229,.14); border-color:#4f46e5; }
.sk-6 .chip-core { background:rgba(79,70,229,.09); border-color:rgba(79,70,229,.3); color:#4f46e5; }

.chip-core { font-weight:700; }

/* ━━━━ PROJECTS ━━━━ */
.project-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.proj {
  background:white; border:1.5px solid var(--border);
  border-radius:22px; overflow:hidden;
  box-shadow:0 4px 24px rgba(15,23,42,.06); transition:all .3s;
}
.proj:hover { transform:translateY(-6px); box-shadow:0 22px 60px rgba(26,111,196,.14); border-color:rgba(26,111,196,.2); }
.proj-top { background:var(--dark-2); color:white; padding:28px 26px; }
.proj-top .proj-cat { display:block; font-size:.72rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.38); margin-bottom:10px; }
.proj-top h3 { font-size:1.02rem; font-weight:700; line-height:1.3; }
.proj-body { padding:22px 26px; }
.proj-body p { color:var(--muted); font-size:.9rem; line-height:1.68; margin-bottom:18px; }
.tags { display:flex; flex-wrap:wrap; gap:7px; }
.tag {
  display:inline-flex; align-items:center; min-height:28px; padding:0 11px;
  border-radius:9999px; font-size:.72rem; font-weight:700;
  background:var(--bg-alt); border:1.5px solid var(--border); color:var(--muted);
}

/* ━━━━ CERTS ━━━━ */
.cert-groups { display:flex; flex-direction:column; gap:48px; }
.cert-group-label {
  display:flex; align-items:center; gap:16px; margin-bottom:20px;
}
.cert-group-label span {
  font-size:.75rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.35); white-space:nowrap;
}
.cert-group-label::after {
  content:''; flex:1; height:1px; background:rgba(255,255,255,.08);
}
.certs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.cert-card {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09);
  border-radius:22px; padding:30px; transition:all .3s;
}
.cert-card:hover { background:rgba(255,255,255,.08); border-color:rgba(91,163,232,.28); transform:translateY(-3px); box-shadow:0 20px 50px rgba(0,0,0,.3); }
.cert-head { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.cert-ico {
  width:48px; height:48px; border-radius:13px; flex-shrink:0;
  display:grid; place-items:center;
}
.cert-ico-aws  { background:rgba(255,153,0,.12); border:1px solid rgba(255,153,0,.25); color:#FF9900; }
.cert-ico-ionos { background:rgba(0,61,143,.25); border:1px solid rgba(0,130,255,.3); color:#4da6ff; }
.cert-ico-ms      { background:rgba(0,120,212,.15); border:1px solid rgba(0,120,212,.3); color:#60b0ff; }
.cert-ico-stackit { background:rgba(0,200,100,.12); border:1px solid rgba(0,200,100,.25); color:#3dd68c; }
.cert-ico-k8s     { background:rgba(50,108,229,.15); border:1px solid rgba(50,108,229,.3); color:#6b9eff; }
.cert-badges { display:flex; flex-direction:column; gap:5px; }
.cert-issuer {
  display:inline-block; font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:2px 8px; border-radius:6px;
}
.issuer-aws  { background:rgba(255,153,0,.18); color:#ffb84d; border:1px solid rgba(255,153,0,.3); }
.issuer-ionos { background:rgba(0,130,255,.18); color:#4da6ff; border:1px solid rgba(0,130,255,.3); }
.issuer-ms      { background:rgba(0,120,212,.18); color:#60b0ff; border:1px solid rgba(0,120,212,.3); }
.issuer-stackit { background:rgba(0,200,100,.15); color:#3dd68c; border:1px solid rgba(0,200,100,.28); }
.issuer-k8s     { background:rgba(50,108,229,.18); color:#6b9eff; border:1px solid rgba(50,108,229,.32); }.cert-card h3 { font-size:.97rem; font-weight:700; color:white; margin-bottom:8px; line-height:1.3; }
.cert-card p { font-size:.85rem; color:rgba(255,255,255,.48); line-height:1.6; }

/* ━━━━ CTA PANEL ━━━━ */
.cta-panel {
  background:linear-gradient(135deg,var(--dark-2),var(--dark));
  color:white; border-radius:28px; padding:48px;
  display:grid; grid-template-columns:1.2fr .8fr; gap:32px; align-items:center;
  box-shadow:0 30px 80px rgba(7,16,31,.24);
  border:1px solid rgba(255,255,255,.06);
}
.cta-panel p { color:rgba(255,255,255,.65); margin-top:14px; max-width:560px; line-height:1.75; font-size:1.02rem; }
.cta-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.btn-fill-sm {
  display:inline-flex; align-items:center; padding:0 24px; min-height:48px;
  border-radius:9999px; font-weight:700; font-size:.9rem;
  text-decoration:none; background:var(--blue); color:white;
  box-shadow:0 6px 20px rgba(26,111,196,.4); transition:all .22s;
}
.btn-fill-sm:hover { transform:translateY(-2px); filter:brightness(1.08); }
.btn-ghost-sm {
  display:inline-flex; align-items:center; padding:0 24px; min-height:48px;
  border-radius:9999px; font-weight:600; font-size:.9rem; text-decoration:none;
  border:1.5px solid rgba(255,255,255,.24); color:rgba(255,255,255,.86);
  background:rgba(255,255,255,.05); transition:all .22s;
}
.btn-ghost-sm:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.44); }
.cta-points { list-style:none; display:grid; gap:13px; }
.cta-points li { display:flex; gap:12px; color:rgba(255,255,255,.84); font-size:.93rem; }
.cta-points li::before { content:'✓'; color:#7dd3fc; font-weight:800; flex-shrink:0; }

/* ━━━━ CONTACT ━━━━ */
.contact-grid { display:grid; grid-template-columns:.9fr 1.1fr; gap:26px; }
.contact-card, .contact-form-wrap {
  background:white; border:1.5px solid var(--border);
  border-radius:22px; padding:34px;
  box-shadow:0 8px 40px rgba(15,23,42,.07);
}
.contact-card {
  display:flex; flex-direction:column;
}
.contact-card .ci-row { margin-top:auto; }

/* dark variant */
.contact-card-dark {
  background:var(--dark-2);
  border-color:rgba(255,255,255,.07);
  box-shadow:0 8px 40px rgba(0,0,0,.28);
}
.contact-card-dark h3 { color:white; }
.contact-card-dark > p { color:rgba(255,255,255,.5); }
.contact-quote {
  font-size:.88rem; font-style:italic; line-height:1.65;
  color:rgba(255,255,255,.55); margin:0 0 24px;
  border-left:3px solid var(--blue); padding-left:14px;
}
.contact-card-dark .cstep strong { color:rgba(255,255,255,.9); }
.contact-card-dark .cstep > div > span { color:rgba(255,255,255,.45); }
.contact-card-dark .ci-row { border-top-color:rgba(255,255,255,.1); }
.contact-card-dark .ci-svg {
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.1);
}
.contact-card-dark .ci-svg svg { stroke:rgba(255,255,255,.6); }
.contact-card-dark .ci-item a,
.contact-card-dark .ci-item span { color:rgba(255,255,255,.55); }
.contact-card-dark .ci-item a:hover { color:white; }
.contact-card h3, .contact-form-wrap h3 { font-size:1.25rem; font-weight:800; margin-bottom:8px; }
.contact-card > p, .contact-form-wrap > p { color:var(--muted); font-size:.93rem; margin-bottom:24px; }
.avail {
  display:inline-flex; align-items:center; gap:9px;
  background:#f0fdf4; border:1.5px solid #bbf7d0;
  padding:7px 18px; border-radius:9999px;
  font-size:.82rem; color:#15803d; font-weight:700; margin-bottom:26px;
}
.avail::before { content:''; width:8px; height:8px; background:#22c55e; border-radius:50%; animation:ping 2s infinite; }
/* contact steps */
.contact-steps { display:grid; gap:18px; margin:24px 0; }
.cstep { display:flex; gap:14px; align-items:flex-start; }
.cstep-num {
  width:28px; height:28px; border-radius:50%; background:var(--blue);
  color:white; font-size:.74rem; font-weight:800;
  display:grid; place-items:center; flex-shrink:0; margin-top:2px;
}
.cstep strong { display:block; font-size:.87rem; font-weight:700; color:var(--text); margin-bottom:3px; }
.cstep > div > span { font-size:.81rem; color:var(--muted); line-height:1.5; display:block; }

/* contact info row */
.ci-row { display:grid; gap:11px; padding-top:20px; border-top:1px solid var(--border); }
.ci-item { display:flex; align-items:center; gap:11px; }
.ci-svg {
  width:32px; height:32px; flex-shrink:0; border-radius:8px;
  background:rgba(26,111,196,.07); border:1.5px solid rgba(26,111,196,.14);
  display:grid; place-items:center;
}
.ci-svg svg { width:14px; height:14px; stroke:var(--blue); }
.ci-item a, .ci-item span { font-size:.85rem; color:var(--muted); text-decoration:none; }
.ci-item a:hover { color:var(--blue); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field { display:grid; gap:7px; margin-bottom:16px; }
.field label { font-size:.83rem; font-weight:700; }
.field input, .field textarea, .field select {
  width:100%; min-height:50px; padding:12px 15px;
  border-radius:12px; border:1.5px solid var(--border);
  font:inherit; color:var(--text); background:#fafbff;
  transition:all .2s; outline:none;
}
.field textarea { min-height:130px; resize:vertical; }
.field input:focus, .field textarea:focus, .field select:focus {
  border-color:var(--blue); box-shadow:0 0 0 4px rgba(26,111,196,.09);
  background:white;
}
.submit {
  margin-top:6px; width:100%; min-height:52px; border:0;
  border-radius:9999px; background:var(--dark); color:white;
  font:inherit; font-weight:800; font-size:.95rem; cursor:pointer; transition:all .22s;
}
.submit:hover { background:var(--blue); transform:translateY(-2px); box-shadow:0 8px 26px rgba(26,111,196,.38); }
.submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }
#formMsg { margin-top:12px; font-size:.86rem; font-weight:600; padding:12px; border-radius:10px; display:none; }
#formMsg.ok  { background:#f0fdf4; color:#15803d; border:1px solid #bbf7d0; }
#formMsg.err { background:#fef2f2; color:#b91c1c; border:1px solid #fecaca; }

/* ━━━━ FOOTER ━━━━ */
footer { background:var(--dark); border-top:1px solid rgba(255,255,255,.07); padding:56px 0 40px; }
.footer-top {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:48px; padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-brand p { font-size:.88rem; color:rgba(255,255,255,.36); line-height:1.72; max-width:240px; margin-top:16px; }
.footer-col h4 {
  font-size:.74rem; font-weight:800; letter-spacing:.18em;
  text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:18px;
}
.footer-col a {
  display:block; font-size:.88rem; color:rgba(255,255,255,.38);
  text-decoration:none; margin-bottom:11px; transition:color .2s;
}
.footer-col a:hover { color:white; }
.footer-bottom {
  padding-top:32px; display:flex; align-items:center;
  justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:.83rem; color:rgba(255,255,255,.28);
}
.footer-bottom a { color:rgba(255,255,255,.38); text-decoration:none; }
.footer-bottom a:hover { color:white; }
/* footer logo */
.footer-logo {
  width:148px; height:auto;
  filter: brightness(0) invert(1);
  opacity: 0.6;
}

/* ━━━━ ANIMATIONS ━━━━ */
/* Initial hidden state — GSAP takes over from here */
.fade-up, .fade-left, .fade-right, .fade-scale { opacity:0; }

/* Hero headline line reveal — animated by GSAP */
.hero-line { display:block; overflow:hidden; }
.hero-line-inner { display:block; transform:translateY(110%); }

/* Mouse-tracking glow in hero */
#hero-glow {
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background:radial-gradient(700px circle at 50% 50%, rgba(56,189,248,.15), transparent 60%);
  transition:background .1s;
}

/* Trust bar marquee */
.marquee-wrap { overflow:hidden; position:relative; }
.marquee-track {
  display:flex; gap:0; width:max-content;
  animation:marquee 36s linear infinite;
}
.marquee-track:hover { animation-play-state:paused; }
.marquee-item {
  display:flex; align-items:center; padding:0 52px;
  font-weight:600; font-size:.82rem; color:rgba(255,255,255,.72);
  letter-spacing:.08em; text-transform:uppercase; white-space:nowrap;
  min-height:72px;
}
.marquee-item::after {
  content:''; margin-left:52px;
  display:inline-block; width:4px; height:4px; border-radius:50%;
  background:rgba(56,189,248,.6); flex-shrink:0;
}
.marquee-item .trust-ico { display:none; }

@keyframes fadeInDown {
  from { opacity:0; transform:translateY(-14px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.hero-copy > p    { opacity:0; animation:fadeInUp .7s .7s forwards; }
.hero-bullets      { opacity:0; animation:fadeInUp .7s .9s forwards; }
.hero-actions      { opacity:0; animation:fadeInUp .7s 1.1s forwards; }
.hero-card         { opacity:0; animation:fadeInUp .8s .5s forwards; }

@keyframes marquee {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* Counter animation */
.count-num { display:inline-block; }

/* Card tilt (set via JS) */
.tilt {
  transform-style:preserve-3d;
  transition:transform .15s ease, box-shadow .3s ease;
}

/* Floating animation for hero metrics */
@keyframes float {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-6px); }
}
.hmetric { animation:float 4s ease-in-out infinite; }
.hmetric:nth-child(2) { animation-delay:.5s; }
.hmetric:nth-child(3) { animation-delay:1s; }
.hmetric:nth-child(4) { animation-delay:1.5s; }

/* Proof items slide in hero card */
.proof-item { transition:background .2s, transform .2s, box-shadow .2s; }
.proof-item:hover { box-shadow:0 0 0 1px rgba(56,189,248,.3), 0 8px 24px rgba(0,0,0,.18); }

/* Gradient shimmer on dark section titles */
.sec-title-light {
  background:linear-gradient(90deg, #fff 30%, #7dd3fc 60%, #fff 80%);
  background-size:200% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:shimmerTitle 4s linear infinite;
}
@keyframes shimmerTitle {
  from { background-position:200% center; }
  to   { background-position:-200% center; }
}

/* ━━━━ RESPONSIVE ━━━━ */
@media (max-width:1080px) {
  .hero-grid { grid-template-columns:1fr; }
  .hero-card { display:none; }
  .grid-3, .skills-grid, .project-grid { grid-template-columns:repeat(2,1fr); }
  .results-grid { grid-template-columns:repeat(3,1fr); }
  .trustbar-wrap { grid-template-columns:repeat(2,1fr); }
  .split { grid-template-columns:1fr; min-height:auto; }
  .split-text { padding:70px 5%; }
  .split-visual, .split-visual.pad-r, .split-visual.dark-vis, .split-visual.dark-vis-r { padding:0 5% 70px; }
  .cta-panel { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; gap:36px; }
}
@media (max-width:680px) {
  .container { padding:0 24px; }
  .nav-links { display:none; }
  .burger { display:block; }
  .grid-3, .skills-grid, .project-grid { grid-template-columns:1fr; }
  .results-grid { grid-template-columns:1fr; }
  .trustbar-wrap { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .section { padding:70px 0; }
  .cta-panel { padding:28px; }
  .hero-grid { padding-top:70px; }
  .split-pad-left, .split-pad-right,
  .split-visual.split-pad-left, .split-visual.split-pad-right { padding:60px 24px; }
}

/* ━━━━ LANGUAGE SWITCHER ━━━━ */
.lang-switch { display:flex; align-items:center; gap:4px; }
.lang-sep { font-size:.8rem; opacity:.4; }
.lang-btn { background:none; border:none; cursor:pointer; font-family:inherit; font-size:.82rem; font-weight:700; padding:4px 2px; opacity:.55; transition:opacity .2s, color .2s; }
.lang-btn:hover { opacity:1; }
.lang-btn.lang-active { opacity:1; color:var(--blue); }
nav:not(.scrolled) .lang-btn { color:rgba(255,255,255,.8); }
nav:not(.scrolled) .lang-btn.lang-active { color:white; opacity:1; }
nav:not(.scrolled) .lang-sep { color:rgba(255,255,255,.4); }

/* ━━━━ TRUST SIGNALS ━━━━ */
.trust-signals-section { padding:72px 0; }
.trust-signals-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
  text-align:center;
}
.trust-signal {
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.ts-num {
  font-size:2.2rem; font-weight:800; color:var(--blue); line-height:1;
  letter-spacing:-0.02em;
}
.ts-label {
  font-size:.85rem; color:var(--muted); line-height:1.5; max-width:160px;
}
@media(max-width:1080px) {
  .trust-signals-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:680px) {
  .trust-signals-grid { grid-template-columns:1fr 1fr; gap:24px; }
  .ts-num { font-size:1.8rem; }
}

/* ━━━━ BLOG PREVIEW (homepage teaser) ━━━━ */
.blog-preview-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.blog-preview-card {
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:28px;
  background:var(--bg);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  text-decoration:none;
  color:var(--text);
  transition:box-shadow .22s, transform .22s, border-color .22s;
}
.blog-preview-card:hover {
  box-shadow:0 10px 36px rgba(26,111,196,.11);
  transform:translateY(-3px);
  border-color:rgba(26,111,196,.3);
}
.blog-preview-card h3 {
  font-size:1rem;
  font-weight:700;
  line-height:1.4;
  flex:1;
}
.blog-preview-tag {
  font-size:.7rem;
  font-weight:700;
  padding:3px 10px;
  border-radius:9999px;
  letter-spacing:.04em;
  text-transform:uppercase;
  width:fit-content;
}
.blog-preview-meta {
  font-size:.78rem;
  color:var(--muted);
}
@media(max-width:1080px) {
  .blog-preview-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:680px) {
  .blog-preview-grid { grid-template-columns:1fr; }
}

/* ━━━━ FORM REASSURANCE ━━━━ */
.form-reassurance {
  font-size:.82rem; color:var(--muted); margin-bottom:20px;
  line-height:1.55; font-style:italic;
}

/* ━━━━ SECTION DECORATIVE NUMBERS ━━━━ */
.sec-head[data-num] { position:relative; }
.sec-head[data-num]::before {
  content: attr(data-num);
  position:absolute;
  top:-0.55em; left:-0.12em;
  font-size:clamp(6rem,14vw,11rem);
  font-weight:800;
  letter-spacing:-0.06em;
  line-height:1;
  color:transparent;
  -webkit-text-stroke:2px rgba(26,111,196,.22);
  pointer-events:none;
  user-select:none;
  z-index:0;
}
.sec-head[data-num] > * { position:relative; z-index:1; }

/* ━━━━ TRUST BAR EDGE FADE ━━━━ */
.marquee-wrap {
  -webkit-mask-image:linear-gradient(to right,transparent 0%,black 10%,black 90%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,black 10%,black 90%,transparent 100%);
}


/* ━━━━ COOKIE CONSENT BANNER ━━━━ */
#cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999;
  background: rgba(7, 16, 31, 0.97);
  backdrop-filter: blur(20px) saturate(160%);
  border-top: 1px solid rgba(255,255,255,.08);
  transform: translateY(100%);
  transition: transform .4s cubic-bezier(.16,1,.3,1);
  pointer-events: none;
}
#cookie-banner.cb-visible {
  transform: translateY(0);
  pointer-events: all;
}
#cookie-banner.cb-hidden {
  display: none;
}
.cb-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px; padding: 20px 48px;
  max-width: var(--max); margin: 0 auto;
}
.cb-text strong {
  display: block; font-size: .875rem; font-weight: 700;
  color: rgba(255,255,255,.92); margin-bottom: 3px;
}
.cb-text p {
  font-size: .8rem; color: rgba(255,255,255,.45); line-height: 1.5; margin: 0;
}
.cb-text a {
  color: var(--blue-2); text-decoration: none;
}
.cb-text a:hover { text-decoration: underline; }
.cb-actions {
  display: flex; gap: 10px; flex-shrink: 0;
}
.cb-reject {
  padding: 9px 20px; border-radius: 9999px; font-size: .8rem; font-weight: 600;
  background: transparent; border: 1.5px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.6); cursor: pointer; transition: all .2s;
  white-space: nowrap;
}
.cb-reject:hover {
  border-color: rgba(255,255,255,.4); color: rgba(255,255,255,.9);
}
.cb-accept {
  padding: 9px 22px; border-radius: 9999px; font-size: .8rem; font-weight: 700;
  background: var(--blue); border: none; color: white;
  cursor: pointer; transition: all .2s; white-space: nowrap;
  box-shadow: 0 4px 14px rgba(26,111,196,.35);
}
.cb-accept:hover {
  background: #1a7fe0; box-shadow: 0 4px 20px rgba(26,111,196,.5);
}
@media (max-width: 640px) {
  .cb-inner { flex-direction: column; align-items: flex-start; padding: 20px 24px; }
  .cb-actions { width: 100%; }
  .cb-reject, .cb-accept { flex: 1; text-align: center; }
}

/* ━━━━ CARD GLOW HOVER ━━━━ */
.proj {
  transition:transform .22s, box-shadow .22s, border-color .22s;
}
.proj:hover {
  border-color:rgba(26,111,196,.25) !important;
  box-shadow:0 0 0 1px rgba(26,111,196,.12), 0 16px 48px rgba(26,111,196,.1) !important;
  transform:translateY(-4px);
}
.cert-card {
  transition:transform .22s, box-shadow .22s, border-color .22s;
}
.cert-card:hover {
  border-color:rgba(56,189,248,.25) !important;
  box-shadow:0 0 0 1px rgba(56,189,248,.12), 0 16px 48px rgba(56,189,248,.1) !important;
  transform:translateY(-4px);
}
.skill-card {
  transition:transform .22s, box-shadow .22s, border-color .22s;
}

/* ━━━━ CTA PANEL ANIMATED BORDER ━━━━ */
.cta-panel {
  position:relative;
  isolation:isolate;
}
.cta-panel::before {
  content:'';
  position:absolute; inset:-1.5px;
  border-radius:calc(var(--radius) + 2px);
  background:linear-gradient(130deg,
    rgba(56,189,248,.7),
    rgba(26,111,196,.4) 30%,
    rgba(139,92,246,.5) 60%,
    rgba(56,189,248,.7) 100%);
  background-size:300% 300%;
  animation:borderSpin 6s ease infinite;
  z-index:-1;
}
.cta-panel::after {
  content:'';
  position:absolute; inset:0;
  border-radius:var(--radius);
  background:inherit;
  z-index:-1;
}
@keyframes borderSpin {
  0%   { background-position:0% 50%; }
  50%  { background-position:100% 50%; }
  100% { background-position:0% 50%; }
}

/* ━━━━ AVAILABILITY BANNER ━━━━ */
#avail-banner {
  background:linear-gradient(90deg,#052e16,#14532d);
  color:#bbf7d0;
  font-size:.82rem; font-weight:600;
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:10px 24px;
  position:relative; z-index:1001;
  letter-spacing:.01em;
}
#avail-banner a { color:#86efac; text-decoration:underline; text-underline-offset:2px; }
#avail-banner a:hover { color:white; }
.avail-dot {
  width:7px; height:7px; border-radius:50%; background:#22c55e; flex-shrink:0;
  box-shadow:0 0 0 0 rgba(34,197,94,.4); animation:ping 2s infinite;
}
#banner-close {
  position:absolute; right:16px;
  background:none; border:none; cursor:pointer;
  color:rgba(187,247,208,.6); font-size:1rem; line-height:1;
  transition:color .18s;
}
#banner-close:hover { color:white; }
body.banner-hidden #avail-banner { display:none; }

/* ━━━━ GLASSMORPHISM NAV ━━━━ */
nav.scrolled {
  background:rgba(255,255,255,.7) !important;
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  box-shadow:0 1px 0 rgba(226,232,240,.6), 0 4px 24px rgba(15,23,42,.05) !important;
}

/* ━━━━ DARK MODE TOGGLE ━━━━ */
.theme-btn {
  background:none; border:none; cursor:pointer;
  width:32px; height:32px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s;
  padding:0;
}
.theme-btn:hover { background:rgba(26,111,196,.1); }
.theme-btn svg {
  width:17px; height:17px; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round;
  transition:opacity .2s;
}
nav:not(.scrolled) .theme-btn svg { stroke:rgba(255,255,255,.8); }
nav.scrolled .theme-btn svg { stroke:var(--text); }
.icon-moon { display:none; }
[data-theme="dark"] .icon-sun  { display:none; }
[data-theme="dark"] .icon-moon { display:block; }

/* Dark mode overrides */
[data-theme="dark"] {
  --text:    #e2e8f0;
  --muted:   #94a3b8;
  --bg:      #0b1121;
  --bg-alt:  #111827;
  --border:  #1f2d42;
}
[data-theme="dark"] nav.scrolled {
  background:rgba(11,17,33,.82) !important;
  box-shadow:0 1px 0 rgba(31,45,66,.8), 0 4px 24px rgba(0,0,0,.3) !important;
}
[data-theme="dark"] .mobile-nav { background:var(--bg); }
[data-theme="dark"] .svc-card,
[data-theme="dark"] .skill-card,
[data-theme="dark"] .proj,
[data-theme="dark"] .cert-card,
[data-theme="dark"] .contact-card,
[data-theme="dark"] .contact-form-wrap { background:var(--bg-alt); }
[data-theme="dark"] .chip { background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.08); color:var(--text); }
[data-theme="dark"] .chip:hover { background:rgba(26,111,196,.15); border-color:rgba(26,111,196,.35); }
[data-theme="dark"] input, [data-theme="dark"] textarea, [data-theme="dark"] select {
  background:var(--bg); border-color:var(--border); color:var(--text);
}
[data-theme="dark"] .vis-light { background:var(--bg-alt); }
[data-theme="dark"] .split-bg-light { background:#0d1929; }
[data-theme="dark"] footer { background:#070e1c; }

/* ━━━━ TYPED TEXT CURSOR ━━━━ */
.typed-cursor {
  display:inline-block;
  font-weight:300;
  margin-left:2px;
  animation:cursorBlink .7s step-end infinite;
  background:none;
  -webkit-text-fill-color:rgba(125,211,252,.8);
}
@keyframes cursorBlink {
  0%,100% { opacity:1; }
  50%      { opacity:0; }
}

/* ━━━━ SKILL CHIPS ━━━━ */
.skill-chips { display:flex; flex-wrap:wrap; gap:8px; padding-top:4px; }
.chip {
  background:var(--bg-alt);
  border:1.5px solid var(--border);
  border-radius:8px;
  padding:5px 13px;
  font-size:.8rem; font-weight:600;
  color:var(--muted);
  cursor:default;
  transition:all .18s;
  white-space:nowrap;
}
.chip:hover {
  background:rgba(26,111,196,.07);
  border-color:rgba(26,111,196,.3);
  color:var(--blue);
  transform:translateY(-1px);
}

/* ━━━━ PROJECT CARD CATEGORY ACCENTS ━━━━ */
.proj { border-top:3px solid var(--border); }
.proj.cat-public     { border-top-color:#3b82f6; }
.proj.cat-enterprise { border-top-color:#8b5cf6; }
.proj.cat-hybrid     { border-top-color:#f97316; }
.proj.cat-net        { border-top-color:#06b6d4; }
.proj.cat-modern     { border-top-color:#22c55e; }
.proj.cat-sec        { border-top-color:#ef4444; }

/* ━━━━ ACTIVE NAV LINK ━━━━ */
nav.scrolled .nav-link-active-scroll { color:var(--blue) !important; }
nav.scrolled .nav-link-active-scroll::after { transform:scaleX(1) !important; }

/* ━━━━ TESTIMONIALS ━━━━ */
.testimonials-wrap {
  max-width:820px; margin:0 auto;
  position:relative;
}
.testimonials-track {
  position:relative; overflow:hidden;
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg);
}
.testimonial {
  display:none;
  padding:44px 48px;
  flex-direction:column; gap:28px;
  animation:fadeTestimonial .4s ease;
}
.testimonial.active { display:flex; }
@keyframes fadeTestimonial {
  from { opacity:0; transform:translateY(10px); }
  to   { opacity:1; transform:translateY(0); }
}
.testimonial-quote {
  font-size:1.08rem; line-height:1.8;
  color:var(--text);
  position:relative;
  padding-left:24px;
}
.testimonial-quote::before {
  content:'"';
  position:absolute; left:0; top:-8px;
  font-size:3.5rem; line-height:1;
  color:var(--blue); opacity:.25;
  font-family:Georgia,serif;
}
.testimonial-author {
  display:flex; align-items:center; gap:14px;
  border-top:1px solid var(--border);
  padding-top:24px;
}
.testimonial-avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--blue),#38bdf8);
  color:white; font-size:.8rem; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.testimonial-author strong { display:block; font-size:.9rem; }
.testimonial-author span   { font-size:.8rem; color:var(--muted); }
.testimonials-nav {
  display:flex; justify-content:center; gap:8px;
  margin-top:20px;
}
.t-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--border); border:none; cursor:pointer;
  transition:all .22s; padding:0;
}
.t-dot.active { background:var(--blue); width:24px; border-radius:4px; }
@media(max-width:680px) {
  .testimonial { padding:28px 24px; }
  .testimonial-quote { font-size:.95rem; }
}

/* ━━━━ BACK TO TOP ━━━━ */
#back-to-top {
  position:fixed; bottom:28px; right:28px; z-index:500;
  width:48px; height:48px;
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:50%; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(15,23,42,.12);
  opacity:0; transform:translateY(16px);
  transition:opacity .3s, transform .3s, box-shadow .22s;
  pointer-events:none;
}
#back-to-top.visible {
  opacity:1; transform:translateY(0); pointer-events:auto;
}
#back-to-top:hover { box-shadow:0 6px 28px rgba(26,111,196,.22); }
.btt-arrow {
  position:absolute;
  width:16px; height:16px;
  stroke:var(--blue); fill:none; stroke-width:2.2;
  stroke-linecap:round; stroke-linejoin:round;
}
.btt-progress {
  position:absolute; inset:0; width:100%; height:100%;
  transform:rotate(-90deg);
}
.btt-track {
  fill:none; stroke:var(--border); stroke-width:2;
}
.btt-fill {
  fill:none; stroke:var(--blue); stroke-width:2;
  stroke-linecap:round;
  stroke-dasharray:94.25;
  stroke-dashoffset:94.25;
  transition:stroke-dashoffset .1s linear;
}

/* ━━━━ PAGE TRANSITION OVERLAY ━━━━ */
#page-transition {
  position:fixed; inset:0; z-index:9999;
  background:var(--dark);
  opacity:0; pointer-events:none;
  transition:opacity .25s ease;
}
#page-transition.fade-in  { opacity:1;  pointer-events:auto; }
#page-transition.fade-out { opacity:0;  pointer-events:none; }

/* ━━━━ BLOG CARD HOVER TOOLTIP ━━━━ */
.blog-preview-card { position:relative; }
.blog-preview-card[data-tip]:hover::after {
  content:attr(data-tip);
  position:absolute; bottom:calc(100% + 10px); left:0; right:0;
  background:var(--dark); color:rgba(255,255,255,.85);
  font-size:.78rem; line-height:1.55; font-weight:400;
  padding:12px 14px; border-radius:12px;
  box-shadow:0 8px 28px rgba(0,0,0,.2);
  pointer-events:none; z-index:10;
  border:1px solid rgba(255,255,255,.08);
}
.blog-preview-card[data-tip]:hover::before {
  content:'';
  position:absolute; bottom:calc(100% + 4px); left:24px;
  border:6px solid transparent;
  border-top-color:var(--dark);
  pointer-events:none; z-index:10;
}
