/* ════════════════════════════════════
   RESET & TOKENS
════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --red:#E8163A;--red-d:#C0102E;--navy:#1A2B8F;--nvy-l:#2A4CC8;
  --off:#B8BEDD;--bg:#06080F;--card:#0A0D1A;
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:#fff;font-family:'Barlow',sans-serif;overflow-x:hidden;cursor:none;}

/* ── CURSOR ── */
.cur-dot{position:fixed;width:7px;height:7px;background:var(--red);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s;}
.cur-ring{position:fixed;width:32px;height:32px;border:1.5px solid rgba(232,22,58,.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s;}

/* ── BG ── */
.bg-grid{position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(rgba(232,22,58,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(232,22,58,.02) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);}
.orb{position:fixed;border-radius:50%;pointer-events:none;z-index:0;filter:blur(90px);}
.orb-a{width:600px;height:600px;top:-180px;left:-180px;background:radial-gradient(circle,rgba(26,43,143,.35) 0%,transparent 70%);}
.orb-b{width:520px;height:520px;bottom:-140px;right:-140px;background:radial-gradient(circle,rgba(232,22,58,.2) 0%,transparent 70%);}

/* ════════════════════════════════════
   NAVBAR
════════════════════════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;height:64px;display:flex;align-items:center;justify-content:center;background:rgba(5,7,18,.92);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);}.nav-inner{width:100%;max-width:1200px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,3vw,40px);gap:16px;}
.nav-logo{display:flex;align-items:center;text-decoration:none;}
.nav-logo-img-wrap{display:flex;align-items:center;height:44px;}
.nav-logo-img{height:42px;width:auto;filter:none;mix-blend-mode:screen;transition:opacity .2s,transform .2s;object-fit:contain;}
.nav-logo:hover .nav-logo-img{opacity:.8;transform:scale(.97);}
.nav-logo:active .nav-logo-img{opacity:.6;}
.footer-logo-img{height:42px;width:auto;filter:none;mix-blend-mode:screen;object-fit:contain;display:block;}
.nav-links{display:flex;align-items:center;justify-content:center;list-style:none;gap:4px;flex:1;}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.6);text-decoration:none;padding:6px 18px;position:relative;transition:color .2s;}
.nav-links a::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%) scaleX(0);width:16px;height:2px;background:var(--red);border-radius:2px;transition:transform .28s cubic-bezier(.34,1.56,.64,1);}
.nav-links a:hover,.nav-links a.active{color:#fff;}
.nav-links a:hover::after,.nav-links a.active::after{transform:translateX(-50%) scaleX(1);}
.nav-cta-wrap{display:flex;align-items:center;gap:8px;}
.nav-cta{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;color:#fff;text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;border:1.5px solid var(--red);background:#0D1437;transition:background .2s,transform .15s;white-space:nowrap;}
.nav-cta:hover{background:var(--red);transform:translateY(-1px);box-shadow:0 4px 16px rgba(232,22,58,.4);}
.wa-icon{width:14px;height:14px;fill:#fff;flex-shrink:0;}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:none;padding:6px;}
.nav-burger span{display:block;width:22px;height:1.5px;background:#fff;transition:all .3s;}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
.mobile-nav{position:fixed;top:72px;left:16px;right:16px;background:rgba(5,7,18,.97);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:10px;z-index:890;transform:translateY(-8px) scale(.98);opacity:0;pointer-events:none;transition:all .3s;display:flex;flex-direction:column;gap:2px;}
.mobile-nav.open{transform:none;opacity:1;pointer-events:all;}
.mobile-nav a{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:15px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55);text-decoration:none;padding:13px 16px;border-radius:8px;border-left:2px solid transparent;transition:all .2s;}
.mobile-nav a:hover{color:#fff;background:rgba(255,255,255,.05);border-left-color:var(--red);}
@media(max-width:900px){.nav-links,.nav-cta{display:none;}.nav-burger{display:flex;}}

/* ════════════════════════════════════
   HERO
════════════════════════════════════ */
.svc-hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding-top:clamp(80px,10vh,100px);overflow:hidden;
}
.svc-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:12%;background:linear-gradient(to bottom,transparent,var(--bg));
  pointer-events:none;z-index:2;
}
#heroBars{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;}
.hero-centre{
  position:relative;z-index:3;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;width:min(92vw,860px);
  padding:0 clamp(20px,4vw,56px);
  gap:0;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;
  letter-spacing:6px;text-transform:uppercase;color:var(--red);
  margin:0 0 clamp(14px,2vh,22px);
  opacity:0;animation:fadeUp .7s ease .3s forwards;
}
.hero-eyebrow-line{display:inline-block;width:10px;height:1.5px;background:var(--red);border-radius:2px;}
.hero-pre{
  font-family:'Barlow Condensed',sans-serif;font-size:clamp(22px,2.6vw,34px);font-weight:400;
  letter-spacing:6px;text-transform:uppercase;color:rgba(184,190,221,.4);
  margin:0 0 2px;display:flex;align-items:center;justify-content:center;gap:10px;
  opacity:0;animation:fadeUp .7s ease .42s forwards;
}
.rotate-slot{
  height:clamp(82px,9.5vw,130px);overflow:hidden;
  width:100%;
  margin:0;
  opacity:0;animation:fadeUp .7s ease .52s forwards;
}
.rotate-list{
  display:flex;flex-direction:column;
  transition:transform .9s cubic-bezier(.16,1,.3,1);
}
.rotate-item{
  height:clamp(82px,9.5vw,130px);
  display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-weight:700;
  font-size:clamp(50px,7vw,114px);line-height:1;
  text-transform:uppercase;letter-spacing:-1px;white-space:nowrap;
  width:100%;
}
.rotate-item.r{color:var(--red);}
.rotate-item.n{color:var(--nvy-l);}
.rotate-item.w{color:#fff;}
.hero-post{
  font-family:'Barlow Condensed',sans-serif;font-size:clamp(22px,2.6vw,34px);font-weight:400;
  letter-spacing:6px;text-transform:uppercase;color:rgba(184,190,221,.4);
  margin:2px 0 clamp(18px,2.5vh,28px);
  opacity:0;animation:fadeUp .7s ease .62s forwards;
}
.hero-desc{
  font-size:clamp(15px,1.3vw,18px);font-weight:300;line-height:1.6;
  color:rgba(184,190,221,.42);max-width:560px;
  margin:0 0 clamp(20px,2.8vh,32px);
  opacity:0;animation:fadeUp .7s ease .72s forwards;
}
.hero-desc strong{color:rgba(255,255,255,.8);font-weight:600;}
.hero-btns{
  display:flex;gap:12px;flex-wrap:wrap;justify-content:center;
  margin:0;
  opacity:0;animation:fadeUp .7s ease .84s forwards;
}
.svc-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:6;opacity:.4;}
.svc-scroll span{font-family:'Barlow Condensed',sans-serif;font-size:9px;letter-spacing:4px;text-transform:uppercase;color:rgba(184,190,221,.35);}
.svc-scroll-line{width:1px;height:44px;background:rgba(184,190,221,.1);overflow:hidden;position:relative;}
.svc-scroll-line::after{content:'';position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(to bottom,var(--red),transparent);animation:scrollA 2s ease-in-out infinite;}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes scrollA{0%{transform:translateY(-100%);}100%{transform:translateY(280%);}}

/* ════════════════════════════════════
   GLOBAL BUTTONS
════════════════════════════════════ */
.btn-red{padding:14px 34px;background:var(--red);color:#fff;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:13px;letter-spacing:2.5px;text-transform:uppercase;text-decoration:none;border:2px solid var(--red);position:relative;overflow:hidden;box-shadow:0 4px 28px rgba(232,22,58,.45);transition:transform .22s,box-shadow .25s,background .25s,border-color .25s;display:inline-flex;align-items:center;justify-content:center;gap:9px;line-height:1;}
.btn-red:hover{background:var(--navy);border-color:var(--nvy-l);transform:translateY(-2px);box-shadow:0 8px 40px rgba(26,43,143,.55);}
.btn-red:active{transform:scale(.95)!important;}
.btn-ghost{padding:14px 30px;background:rgba(255,255,255,.04);color:rgba(255,255,255,.7);font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:13px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;border:1.5px solid rgba(255,255,255,.18);transition:all .22s;display:inline-flex;align-items:center;justify-content:center;gap:9px;line-height:1;}
.btn-ghost:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-2px);box-shadow:0 8px 32px rgba(232,22,58,.5);}

/* ════════════════════════════════════
   SECTION COMMON
════════════════════════════════════ */
.section-wrap{position:relative;z-index:1;padding:clamp(70px,9vw,120px) clamp(24px,6vw,80px);}
.section-header{max-width:1280px;margin:0 auto clamp(44px,6vw,72px);display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;}
.eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:14px;}
.eyebrow::before,.eyebrow::after{content:'';width:40px;height:1.5px;background:var(--red);opacity:.7;}
.section-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(42px,6vw,80px);line-height:.92;text-transform:uppercase;letter-spacing:2px;color:#fff;}
.section-title em{color:var(--red);font-style:normal;}
.section-sub{font-size:14px;font-weight:300;line-height:1.9;color:rgba(184,190,221,.38);max-width:520px;}

/* ════════════════════════════════════
   SERVICES — 6 CARDS, 2 PER ROW
   v13 icon system + corner brackets
════════════════════════════════════ */
.svc-grid{
  max-width:1280px;margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(14px,2vw,24px);
}

/* ── Card shell (v13 style) ── */
.svc-card{
  position:relative;
  cursor:pointer;
  user-select:none;
}

.svc-card-body{
  position:relative;
  background:linear-gradient(135deg,rgba(26,43,143,.18) 0%,rgba(8,11,22,.94) 50%,rgba(232,22,58,.05) 100%);
  border:1px solid rgba(255,255,255,.08);
  padding:clamp(32px,3.5vw,52px) clamp(28px,3.5vw,52px);
  overflow:hidden;
  height:100%;
  transition:border-color .4s,background .4s,box-shadow .4s,transform .25s cubic-bezier(.34,1.2,.64,1);
}
.svc-card-body::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,22,58,.35),transparent);
  opacity:0;transition:opacity .4s;
}
.svc-card:hover .svc-card-body::after{opacity:1;}
.svc-card:hover .svc-card-body{
  border-color:rgba(26,43,143,.12);
  background:linear-gradient(135deg,rgba(26,43,143,.26) 0%,rgba(10,13,26,.96) 50%,rgba(232,22,58,.09) 100%);
  box-shadow:0 0 80px rgba(26,43,143,.18),0 0 40px rgba(232,22,58,.06),0 24px 60px rgba(0,0,0,.55);
}

/* corner pip system */
.svc-corners{position:absolute;inset:0;pointer-events:none;z-index:3;}
.svc-pip{position:absolute;width:7px;height:7px;background:var(--red);transition:opacity .35s,transform .35s,width .4s cubic-bezier(.34,1.56,.64,1),height .4s cubic-bezier(.34,1.56,.64,1);opacity:.5;}
.svc-pip.tl{top:-1px;left:-1px;}.svc-pip.tr{top:-1px;right:-1px;}.svc-pip.bl{bottom:-1px;left:-1px;}.svc-pip.br{bottom:-1px;right:-1px;}
.svc-arm-h{position:absolute;height:1.5px;background:var(--red);width:0;transition:width .4s cubic-bezier(.22,1,.36,1),opacity .3s;opacity:0;}
.svc-arm-v{position:absolute;width:1.5px;background:var(--red);height:0;transition:height .4s cubic-bezier(.22,1,.36,1),opacity .3s;opacity:0;}
.svc-arm-h.tl{top:-1px;left:7px;}.svc-arm-v.tl{top:7px;left:-1px;}
.svc-arm-h.tr{top:-1px;right:7px;transform-origin:right;}.svc-arm-v.tr{top:7px;right:-1px;}
.svc-arm-h.bl{bottom:-1px;left:7px;}.svc-arm-v.bl{bottom:7px;left:-1px;top:auto;}
.svc-arm-h.br{bottom:-1px;right:7px;transform-origin:right;}.svc-arm-v.br{bottom:7px;right:-1px;top:auto;}
.svc-card:hover .svc-arm-h{width:36px;opacity:.85;}
.svc-card:hover .svc-arm-v{height:36px;opacity:.85;}
.svc-card:hover .svc-pip{width:9px;height:9px;opacity:.9;box-shadow:0 0 8px rgba(232,22,58,.6);}

/* ── Card layout ── */
.svc-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:clamp(20px,2.5vw,30px);}
.svc-num-badge{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:10px;letter-spacing:4px;
  color:rgba(232,22,58,.38);transition:color .3s;
}
.svc-card:hover .svc-num-badge{color:rgba(232,22,58,.7);}

.svc-icon-wrap{
  width:52px;height:52px;border-radius:12px;
  background:rgba(26,43,143,.18);
  border:1px solid rgba(26,43,143,.28);
  display:flex;align-items:center;justify-content:center;
  transition:background .35s,border-color .35s,box-shadow .35s;
  flex-shrink:0;
}
.svc-icon-wrap svg{width:26px;height:26px;color:rgba(184,190,221,.5);transition:color .35s;}
.svc-card:hover .svc-icon-wrap{background:rgba(232,22,58,.1);border-color:rgba(232,22,58,.28);box-shadow:0 0 20px rgba(232,22,58,.18);}
.svc-card:hover .svc-icon-wrap svg{color:rgba(232,22,58,.85);}

.svc-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:clamp(26px,2.8vw,40px);
  letter-spacing:.5px;color:#fff;line-height:1;
  margin-bottom:12px;
}
.svc-name em{color:var(--red);font-style:normal;}

.svc-tagline{
  font-size:clamp(13px,1.1vw,15px);font-weight:300;
  line-height:1.85;color:rgba(184,190,221,.5);
  margin-bottom:clamp(16px,2vw,24px);
  max-width:520px;
}
.svc-tagline strong{color:rgba(255,255,255,.75);font-weight:500;}

/* Detail rows */
.svc-detail-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(16px,2vw,28px);
  margin-bottom:clamp(18px,2vw,26px);
}
.svc-detail-label{
  font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:600;
  letter-spacing:3px;text-transform:uppercase;
  color:rgba(184,190,221,.25);margin-bottom:10px;display:block;
}
.svc-detail-list{display:flex;flex-direction:column;gap:6px;}
.svc-detail-item{
  font-size:12px;font-weight:300;color:rgba(184,190,221,.48);
  display:flex;align-items:center;gap:8px;
  transition:color .2s;
}
.svc-detail-item::before{content:'→';color:rgba(232,22,58,.45);font-size:10px;flex-shrink:0;}

/* tags */
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:clamp(18px,2vw,26px);}
.svc-tags span{
  padding:4px 12px;
  font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:600;
  letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(184,190,221,.38);background:rgba(184,190,221,.03);
  border:1px solid rgba(184,190,221,.07);border-radius:100px;
  transition:color .3s,border-color .3s,background .3s;
}
.svc-card:hover .svc-tags span{color:rgba(232,22,58,.65);border-color:rgba(232,22,58,.18);background:rgba(232,22,58,.04);}

/* explore link */
.svc-explore{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(184,190,221,.28);text-decoration:none;
  transition:color .3s,gap .3s;
}
.svc-explore svg{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s;}
.svc-card:hover .svc-explore{color:rgba(232,22,58,.7);gap:13px;}
.svc-card:hover .svc-explore svg{transform:translate(3px,-3px);}

/* divider inside card */
.svc-divider{height:1px;background:linear-gradient(90deg,rgba(255,255,255,.06),transparent);margin:clamp(16px,2vw,24px) 0;}

@media(max-width:900px){
  .svc-grid{grid-template-columns:1fr;}
  .svc-detail-row{grid-template-columns:1fr;}
}
@media(max-width:540px){
  .svc-card-body{padding:28px 22px;}
}

/* ════════════════════════════════════
   PROCESS
════════════════════════════════════ */
.process-section{position:relative;z-index:1;padding:clamp(60px,8vw,100px) clamp(24px,6vw,80px);}
.process-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;position:relative;
}
.process-connector{
  position:absolute;top:clamp(24px,3vw,30px);left:12.5%;right:12.5%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,22,58,.2),rgba(42,76,200,.2),rgba(232,22,58,.2),transparent);
  pointer-events:none;
}
.pstep{display:flex;flex-direction:column;align-items:center;gap:clamp(14px,2vw,22px);padding:0 clamp(10px,2vw,24px);text-align:center;position:relative;z-index:1;}
.pnum{width:clamp(48px,5.5vw,60px);height:clamp(48px,5.5vw,60px);background:linear-gradient(135deg,rgba(26,43,143,.4),rgba(8,11,22,.9));border:1px solid rgba(232,22,58,.25);display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-weight:700;font-size:clamp(16px,2vw,22px);color:var(--red);letter-spacing:1px;transition:border-color .3s,box-shadow .3s,transform .3s;}
.pstep:hover .pnum{border-color:var(--red);box-shadow:0 0 28px rgba(232,22,58,.35);transform:translateY(-4px);}
.pstep-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(14px,1.8vw,18px);letter-spacing:1px;text-transform:uppercase;color:#fff;}
.pstep-text{font-size:12px;font-weight:300;line-height:1.8;color:rgba(184,190,221,.35);}
@media(max-width:760px){.process-grid{grid-template-columns:repeat(2,1fr);gap:40px;}.process-connector{display:none;}}
@media(max-width:480px){.process-grid{grid-template-columns:1fr;}}

/* ════════════════════════════════════
   SKILLS & STACK
════════════════════════════════════ */
.skills-bg{position:relative;z-index:1;padding:clamp(70px,9vw,120px) 0;overflow:hidden;}
.skills-inner{max-width:1280px;margin:0 auto;padding:0 clamp(24px,6vw,80px);overflow:visible;}
.expertise-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(16px,2.5vw,32px) clamp(40px,6vw,100px);
}
.exp-item{position:relative;}
.exp-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;}
.exp-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(13px,1.3vw,16px);letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.8);}
.exp-pct{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:300;color:var(--bar-c,var(--red));letter-spacing:1px;}
.exp-track{height:3px;background:rgba(255,255,255,.05);position:relative;overflow:visible;}
.exp-track::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.03));}
.exp-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--bar-c,var(--red)),color-mix(in srgb,var(--bar-c,var(--red)) 60%,white));width:0;transition:width 1.4s cubic-bezier(.22,1,.36,1);box-shadow:0 0 12px var(--bar-c,var(--red));}
.exp-fill.animated{width:var(--pct);}
.exp-dot{position:absolute;top:50%;right:0;transform:translate(50%,-50%);width:8px;height:8px;border-radius:50%;background:var(--bar-c,var(--red));box-shadow:0 0 10px var(--bar-c,var(--red));opacity:0;transition:opacity .3s .8s;}
.exp-fill.animated+.exp-dot,.exp-fill.animated~.exp-dot{opacity:1;}
.exp-sub{font-size:10px;font-weight:300;color:rgba(184,190,221,.25);letter-spacing:1.5px;text-transform:uppercase;margin-top:8px;}
@media(max-width:740px){.expertise-grid{grid-template-columns:1fr;}}

/* marquee */
.marquee-wrap{position:relative;overflow:hidden;padding:clamp(10px,1.2vw,16px) 0;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);}
.marquee-wrap::before,.marquee-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;}
.marquee-wrap::before{left:0;background:linear-gradient(90deg,var(--bg),transparent);}
.marquee-wrap::after{right:0;background:linear-gradient(270deg,var(--bg),transparent);}
.marquee-track{display:flex;gap:0;animation:marqueeSpin 38s linear infinite;width:max-content;}
.marquee-track:hover{animation-play-state:paused;}
.marquee-pill{display:inline-flex;align-items:center;gap:14px;padding:0 clamp(24px,3vw,40px);white-space:nowrap;border-right:1px solid rgba(255,255,255,.06);transition:all .25s;}
/* dim all pills when track is hovered */
.marquee-track:hover .marquee-pill .mp-name{color:rgba(184,190,221,.15);}
.marquee-track:hover .marquee-pill .mp-icon{opacity:.35;}
/* bright up the one being hovered */
.marquee-track:hover .marquee-pill:hover .mp-icon{opacity:1;transform:scale(1.15);filter:brightness(1.4);}
.marquee-track:hover .marquee-pill:hover .mp-name{color:#fff;}
.mp-icon{width:clamp(32px,3.5vw,42px);height:clamp(32px,3.5vw,42px);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:clamp(11px,1.2vw,14px);letter-spacing:-.5px;box-shadow:0 4px 14px rgba(0,0,0,.5);transition:transform .3s cubic-bezier(.34,1.4,.64,1),filter .3s;flex-shrink:0;}
.mp-name{font-family:'Barlow Condensed',sans-serif;font-size:clamp(11px,1.1vw,13px);font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(184,190,221,.4);transition:color .3s;}
/* names-only marquee items */
.mp-name-only{
  display:inline-flex;align-items:center;
  padding:0 clamp(18px,2.5vw,32px);
  font-family:'Barlow Condensed',sans-serif;font-size:clamp(11px,1vw,13px);
  font-weight:700;letter-spacing:3px;text-transform:uppercase;
  color:rgba(184,190,221,.5);
  border-right:1px solid rgba(255,255,255,.06);
  white-space:nowrap;
  transition:color .25s;
}
/* When track is hovered: dim all items */
.marquee-track:hover .mp-name-only{color:rgba(184,190,221,.18);}
/* The one being hovered: go bright white */
.marquee-track:hover .mp-name-only:hover{color:#fff;}

/* marquee wrap padding adjustment for text-only row */
.marquee-wrap .marquee-track{height:clamp(22px,2vw,30px);}

@keyframes marqueeSpin{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.marquee-wrap-b .marquee-track{animation:marqueeRev 44s linear infinite;}
.marquee-wrap-b{margin-top:2px;}
@keyframes marqueeRev{0%{transform:translateX(-50%);}100%{transform:translateX(0);}}

/* icon colours */
.sw-ps{background:linear-gradient(145deg,#001E36,#003359);color:#31A8FF;}
.sw-ai{background:linear-gradient(145deg,#3a0900,#5c1500);color:#FF9A00;}
.sw-ae{background:linear-gradient(145deg,#00005B,#0a0a8a);color:#9999FF;}
.sw-pr{background:linear-gradient(145deg,#00005B,#0a0a8a);color:#9999FF;}
.sw-id{background:linear-gradient(145deg,#330040,#4d005f);color:#FD3F93;}
.sw-lr{background:linear-gradient(145deg,#001926,#003040);color:#A7D9F5;}
.sw-xd{background:linear-gradient(145deg,#470137,#6a0150);color:#FF61F6;}
.sw-dn{background:linear-gradient(145deg,#003320,#00512e);color:#34e78d;}
.sw-figma{background:linear-gradient(145deg,#0F0F14,#1a1a24);}
.sw-da{background:linear-gradient(145deg,#191919,#262626);}
.sw-blender{background:linear-gradient(145deg,#0F0F0F,#1a1a1a);}
.sw-c4d{background:linear-gradient(145deg,#001428,#001e3c);color:#00B7FF;}
.sw-vsc{background:linear-gradient(145deg,#011926,#01273a);color:#28A9E0;}
.sw-react{background:#20232A;color:#61DAFB;}
.sw-js{background:#F7DF1E;color:#1a1200;}
.sw-ts{background:linear-gradient(145deg,#3178C6,#235295);color:#fff;}
.sw-node{background:linear-gradient(145deg,#163315,#1e4a1c);color:#8CC84B;}
.sw-git{background:linear-gradient(145deg,#1a1a1a,#252525);}
.sw-wf{background:linear-gradient(145deg,#146EF5,#0d5ac4);color:#fff;}
.sw-wp{background:linear-gradient(145deg,#21759B,#165578);color:#fff;}
.sw-html{background:linear-gradient(145deg,#D04A1A,#E55A25);color:#fff;}
.sw-css{background:linear-gradient(145deg,#1572B6,#1f91e0);color:#fff;}

/* ════════════════════════════════════
   CTA
════════════════════════════════════ */
.cta-wrap{position:relative;z-index:1;padding:0 clamp(24px,6vw,80px) clamp(80px,10vw,120px);}
.cta-panel-wrap{max-width:1200px;margin:0 auto;position:relative;}
.cta-panel{
  position:relative;
  background:linear-gradient(135deg,rgba(26,43,143,.18) 0%,rgba(8,11,22,.94) 50%,rgba(232,22,58,.05) 100%);
  border:1px solid rgba(232,22,58,.2);
  overflow:visible;
  transition:border-color .35s,box-shadow .35s;
}
.cta-panel::before{
  content:'';position:absolute;top:0;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,22,58,.45),transparent);
  opacity:.35;transition:opacity .4s;pointer-events:none;
}
.cta-panel:hover{border-color:rgba(232,22,58,.45);box-shadow:0 0 80px rgba(26,43,143,.18),0 0 40px rgba(232,22,58,.06),0 24px 60px rgba(0,0,0,.5);}
.cta-panel:hover::before{opacity:.7;}
/* L-corner brackets — same as sk-card-wrap */
.cta-corner{position:absolute;width:22px;height:22px;pointer-events:none;z-index:3;opacity:.7;transition:width .4s cubic-bezier(.34,1.56,.64,1),height .4s cubic-bezier(.34,1.56,.64,1),border-color .3s,filter .3s;animation:ctaPulse 3.5s ease-in-out .8s infinite;}
.cta-corner.tl{top:-9px;left:-9px;border-top:2px solid rgba(232,22,58,.75);border-left:2px solid rgba(232,22,58,.75);}
.cta-corner.tr{top:-9px;right:-9px;border-top:2px solid rgba(232,22,58,.75);border-right:2px solid rgba(232,22,58,.75);}
.cta-corner.bl{bottom:-9px;left:-9px;border-bottom:2px solid rgba(232,22,58,.75);border-left:2px solid rgba(232,22,58,.75);}
.cta-corner.br{bottom:-9px;right:-9px;border-bottom:2px solid rgba(232,22,58,.75);border-right:2px solid rgba(232,22,58,.75);}
@keyframes ctaPulse{0%,100%{opacity:.7;}50%{opacity:.35;}}
.cta-panel:hover .cta-corner{width:34px;height:34px;border-color:var(--red);opacity:1;animation:none;filter:drop-shadow(0 0 6px rgba(232,22,58,.6));}
.cta-inner{display:grid;grid-template-columns:1fr auto;align-items:center;gap:clamp(24px,4vw,60px);padding:clamp(36px,4.5vw,56px) clamp(28px,4.5vw,60px);}
.cta-avail{display:inline-flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:rgba(34,197,94,1);background:rgba(34,197,94,.1);border:2px solid rgba(34,197,94,.8);padding:7px 18px;margin-bottom:20px;border-radius:2px;box-shadow:0 0 24px rgba(34,197,94,.25),inset 0 0 10px rgba(34,197,94,.06);}
.avail-dot{width:5px;height:5px;border-radius:50%;background:#22c55e;flex-shrink:0;}
.cta-head{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(32px,4.5vw,58px);line-height:.9;text-transform:uppercase;letter-spacing:1px;color:#fff;}
.cta-head span{display:block;color:var(--red);}
.cta-body{margin-top:16px;font-size:14px;font-weight:300;line-height:1.9;color:rgba(184,190,221,.4);max-width:480px;}
.cta-body strong{color:rgba(255,255,255,.75);font-weight:600;}
.cta-right{display:flex;flex-direction:column;gap:12px;min-width:220px;}
@media(max-width:768px){.cta-inner{grid-template-columns:1fr;}.cta-right{min-width:auto;}}

/* ════════════════════════════════════
   FOOTER
════════════════════════════════════ */
footer{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.05);}
.footer-body{max-width:1200px;margin:0 auto;padding:clamp(44px,6vw,70px) clamp(24px,6vw,80px) clamp(28px,4vw,44px);display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:clamp(32px,5vw,60px);}
.footer-brand-name{font-family:'Oswald',sans-serif;font-weight:700;font-size:28px;letter-spacing:6px;text-transform:uppercase;color:#fff;text-decoration:none;display:block;margin-bottom:14px;}
.footer-brand-name em{color:var(--red);font-style:normal;}
.footer-brand-desc{font-size:13px;font-weight:300;line-height:1.85;color:rgba(184,190,221,.32);max-width:230px;margin-bottom:24px;}
.footer-socials{display:flex;gap:10px;}
.footer-soc{width:36px;height:36px;border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:rgba(184,190,221,.35);text-decoration:none;transition:border-color .2s,color .2s,background .2s,transform .2s;isolation:isolate;}
.footer-soc:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,22,58,.4);}
.footer-soc svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.footer-col h4{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.05);}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col ul li a{font-size:13px;font-weight:300;color:rgba(184,190,221,.38);text-decoration:none;transition:color .2s,padding-left .2s;display:inline-block;}
.footer-col ul li a:hover{color:#fff;padding-left:5px;}
.footer-bottom{max-width:1200px;margin:0 auto;padding:clamp(16px,2.5vw,24px) clamp(24px,6vw,80px) clamp(24px,3vw,36px);display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(255,255,255,.04);gap:16px;flex-wrap:wrap;}
.footer-copy{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:300;letter-spacing:2px;text-transform:uppercase;color:rgba(184,190,221,.18);}
.footer-copy em{color:var(--red);font-style:normal;}
.footer-built{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(184,190,221,.14);}
.footer-built span{color:var(--red);}
@media(max-width:1024px){.footer-body{grid-template-columns:1fr 1fr;}}
@media(max-width:640px){.footer-body{grid-template-columns:1fr;}.footer-bottom{flex-direction:column;text-align:center;}}

/* ════════════════════════════════════
   HERO BRACKET CORNERS (v13 style)
   — sit at the 4 corners of the hero viewport
════════════════════════════════════ */
.brackets{
  position:absolute;
  top:clamp(70px,8vw,100px);
  bottom:clamp(30px,4vw,50px);
  left:clamp(160px,18vw,280px);
  right:clamp(160px,18vw,280px);
  pointer-events:none;z-index:3;
}
.bracket-frame{
  position:relative;
  width:100%;height:100%;
}
.bk{
  position:absolute;width:54px;height:54px;
  transition:width .5s cubic-bezier(.34,1.56,.64,1),height .5s cubic-bezier(.34,1.56,.64,1),filter .35s;
  opacity:0;transform:scale(.85);transform-origin:center;
}
.bk path{stroke:var(--red);stroke-width:2.2;stroke-linecap:square;fill:none;transition:stroke-width .3s;}
.bk.tl{top:0;left:0;}.bk.tr{top:0;right:0;}.bk.bl{bottom:0;left:0;}.bk.br{bottom:0;right:0;}
@keyframes bkPulse{0%,100%{opacity:.8;}50%{opacity:.45;}}
@keyframes bracketIn{to{opacity:.8;transform:scale(1);}}
.bk.in{animation:bracketIn .6s cubic-bezier(.34,1.56,.64,1) forwards,bkPulse 3.5s ease-in-out .6s infinite;}
.bk.tr.in{animation-delay:.12s,.72s;}
.bk.bl.in{animation-delay:.24s,.84s;}
.bk.br.in{animation-delay:.36s,.96s;}
.svc-hero:hover .bk{animation:none;opacity:1;width:72px;height:72px;filter:drop-shadow(0 0 10px rgba(232,22,58,.7));}
.svc-hero:hover .bk path{stroke-width:2.8;}

/* ════════════════════════════════════
   SKILLS CARD — v13 border style
════════════════════════════════════ */
.sk-card-wrap{
  max-width:1280px;margin:0 auto;
  position:relative;
  background:linear-gradient(135deg,rgba(26,43,143,.18) 0%,rgba(8,11,22,.94) 50%,rgba(232,22,58,.05) 100%);
  border:1px solid rgba(232,22,58,.2);
  padding:clamp(36px,4vw,56px) clamp(28px,4vw,56px);
  overflow:visible;
  margin-bottom:clamp(40px,5vw,64px);
  transition:border-color .35s,box-shadow .35s;
}
.sk-card-wrap::before{
  content:'';position:absolute;top:0;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,22,58,.45),transparent);
  opacity:.35;transition:opacity .4s;
}
.sk-card-wrap:hover{border-color:rgba(232,22,58,.45);box-shadow:0 0 80px rgba(26,43,143,.18),0 0 40px rgba(232,22,58,.06),0 24px 60px rgba(0,0,0,.5);}
.sk-card-wrap:hover::before{opacity:.7;}
/* L-corner brackets on skills card */
.sk-corners{position:absolute;inset:-9px;pointer-events:none;z-index:3;}
.sk-cor{position:absolute;width:22px;height:22px;transition:width .4s cubic-bezier(.34,1.56,.64,1),height .4s cubic-bezier(.34,1.56,.64,1),border-color .3s,filter .3s;opacity:.7;}
.sk-cor.tl{top:0;left:0;border-top:2px solid rgba(232,22,58,.75);border-left:2px solid rgba(232,22,58,.75);}
.sk-cor.tr{top:0;right:0;border-top:2px solid rgba(232,22,58,.75);border-right:2px solid rgba(232,22,58,.75);}
.sk-cor.bl{bottom:0;left:0;border-bottom:2px solid rgba(232,22,58,.75);border-left:2px solid rgba(232,22,58,.75);}
.sk-cor.br{bottom:0;right:0;border-bottom:2px solid rgba(232,22,58,.75);border-right:2px solid rgba(232,22,58,.75);}
@keyframes skCorPulse{0%,100%{opacity:.7;}50%{opacity:.35;}}
.sk-card-wrap .sk-cor{animation:skCorPulse 3.5s ease-in-out .8s infinite;}
.sk-card-wrap:hover .sk-cor{width:34px;height:34px;border-color:var(--red);opacity:1;animation:none;filter:drop-shadow(0 0 6px rgba(232,22,58,.6));}

/* ════════════════════════════════════
   QUESTION LINE — "what can't we do?"
════════════════════════════════════ */
.question-strip{
  position:relative;z-index:1;
  padding:clamp(14px,1.8vw,22px) clamp(24px,6vw,80px);
  display:flex;align-items:center;justify-content:center;
  border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
  overflow:hidden;
}
.question-strip::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(26,43,143,.06),rgba(232,22,58,.03),transparent);
  pointer-events:none;
}
.question-text{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:clamp(18px,2.5vw,32px);
  letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,.12);
  text-align:center;position:relative;z-index:1;
  transition:color .4s;
}
.question-text em{color:rgba(232,22,58,.35);font-style:normal;}
.question-strip:hover .question-text{color:rgba(255,255,255,.22);}
.question-strip:hover .question-text em{color:rgba(232,22,58,.6);}

/* ════════════════════════════════════
   SCROLL REVEAL
════════════════════════════════════ */
.rv{opacity:0;transform:translateY(22px);}
.rv.in{animation:revUp .75s cubic-bezier(.22,1,.36,1) forwards;}
@keyframes revUp{to{opacity:1;transform:translateY(0);}}

/* ════════════════════════════════════
   SECTION FRAME TITLE
════════════════════════════════════ */
.sft-wrap {
  width: 100%;
  text-align: center;
  margin-bottom: 0;
  overflow: visible;
}
.sft-wrap .section-frame-title {
  display: inline-flex;
}
/* full width variant — stretches like the stats box */
.sft-fullwidth {
  padding: 0 clamp(24px,3vw,40px);
  margin-bottom: 0;
}
.sft-fullwidth .section-frame-title {
  display: flex;
  width: 100%;
  box-sizing: border-box;
}
.section-frame-title {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 18px 32px;
  background: rgba(10,13,26,.7);
  border: 1px solid rgba(232,22,58,.28);
  text-align: center;
  box-shadow: 0 0 0 1px rgba(232,22,58,.06), 0 0 32px rgba(232,22,58,.07);
  transition: border-color .4s, box-shadow .4s;
  overflow: visible;
}
.section-frame-title:hover {
  border-color: rgba(232,22,58,.55);
  box-shadow: 0 0 0 1px rgba(232,22,58,.1), 0 0 40px rgba(232,22,58,.14);
}
/* bracket corners — L-shaped, slightly outside the border */
.sft-corner {
  position: absolute;
  width: 18px; height: 18px;
  pointer-events: none;
  transition: width .35s cubic-bezier(.22,1,.36,1),
              height .35s cubic-bezier(.22,1,.36,1),
              box-shadow .35s;
}
.sft-corner::before,
.sft-corner::after {
  content: '';
  position: absolute;
  background: var(--red);
}
.sft-corner::before { height: 1.5px; width: 100%; }
.sft-corner::after  { width: 1.5px; height: 100%; }
.sft-corner.tl { top: -6px; left: -6px; }
.sft-corner.tl::before { top: 0; left: 0; }
.sft-corner.tl::after  { top: 0; left: 0; }
.sft-corner.tr { top: -6px; right: -6px; }
.sft-corner.tr::before { top: 0; right: 0; }
.sft-corner.tr::after  { top: 0; right: 0; }
.sft-corner.bl { bottom: -6px; left: -6px; }
.sft-corner.bl::before { bottom: 0; left: 0; }
.sft-corner.bl::after  { bottom: 0; left: 0; }
.sft-corner.br { bottom: -6px; right: -6px; }
.sft-corner.br::before { bottom: 0; right: 0; }
.sft-corner.br::after  { bottom: 0; right: 0; }
/* hover — corners grow */
.section-frame-title:hover .sft-corner { width: 28px; height: 28px; }
.section-frame-title:hover .sft-corner::before,
.section-frame-title:hover .sft-corner::after {
  box-shadow: 0 0 8px rgba(232,22,58,.8);
}
.sft-eyebrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px; font-weight: 600;
  letter-spacing: 5px; text-transform: uppercase;
  color: rgba(232,22,58,.7);
}
.sft-title {
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 4vw, 48px);
  text-transform: uppercase;
  letter-spacing: 3px;
  line-height: 1;
  color: #fff;
  margin: 0;
  white-space: nowrap;
}
.sft-title em { color: var(--red); font-style: normal; }

/* ════════════════════════════════════
   SPIDER DIAGRAM & SERVICE PANEL
════════════════════════════════════ */
.lc-spoke.lit {
  stroke: rgba(232,22,58,.9);
  stroke-width: 3.5;
  filter: drop-shadow(0 0 6px rgba(232,22,58,.5));
}

/* ── ring around each card ── */
.lc-ring {
  fill: none;
  stroke: rgba(232,22,58,.18);
  stroke-width: 1;
  opacity: 0;
  transition: opacity .3s;
}
.lc-ring.visible { opacity: 1; }
.lc-ring.pulse {
  animation: lcRingPulse 1.6s ease-out forwards;
}
@keyframes lcRingPulse {
  0%   { r: 52; opacity: .7; stroke: rgba(232,22,58,.5); }
  100% { r: 78; opacity: 0;  stroke: rgba(232,22,58,.0); }
}

/* ── ambient halo behind each card ── */
.lc-halo {
  position: absolute;
  inset: -20px;
  border-radius: 14px;
  background: radial-gradient(circle, var(--hg, rgba(232,22,58,.12)) 0%, transparent 70%);
  pointer-events: none;
  transition: opacity .4s;
  opacity: .5;
  z-index: 0;
}
.lc-card:hover .lc-halo { opacity: 1; }

/* ── floating tooltip ── */
.lc-tip {
  position: absolute;
  pointer-events: none;
  z-index: 20;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .25s, transform .25s;
  white-space: nowrap;
  bottom: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(6px);
}
.lc-tip.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.lc-tip-inner {
  background: rgba(6,7,16,.96);
  border: 1px solid rgba(232,22,58,.3);
  padding: 8px 14px 10px;
  position: relative;
}
.lc-tip-inner::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1.5px;
  background: var(--red);
}
.lc-tip-cat {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 3px; text-transform: uppercase;
  color: rgba(232,22,58,.75);
  margin-bottom: 3px;
}
.lc-tip-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 15px;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: #fff; line-height: 1;
}
.logo-section {
  position: relative;
  width: 100%;
  padding: 40px 0 24px;
  overflow: visible;
  transition: background 0.22s ease;
}
.logo-section.spider-active {
  background: rgba(4,0,8,0.92);
}
.logo-section::before {
  content: '';
  position: absolute;
  left: 0; right: 0; top: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,22,58,.3), transparent);
}

.lc-stage {
  position: relative;
  width: 88%;
  max-width: 860px;
  aspect-ratio: 1000 / 720;
  margin: 0 auto;
}
.lc-svg {
  position: absolute;
  inset: 0; width: 100%; height: 100%;
  overflow: visible;
  pointer-events: none;
  z-index: 1;
}

/* ── spider silhouette — hidden by default, reveals on hover ── */
@keyframes spiderPop {
  0%   { opacity: 0; transform: scale(0.82); }
  70%  { opacity: 1; transform: scale(1.04); }
  100% { opacity: 1; transform: scale(1); }
}
@keyframes spiderBreath {
  0%,100% { transform: scale(1); }
  50%      { transform: scale(1.016); }
}
@keyframes eyePulse {
  0%,100% { opacity: 1; }
  40%      { opacity: 0.25; }
  55%      { opacity: 1; }
}
.lc-spider-ghost {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.82);
  transition: none;
  z-index: 0;
  overflow: visible;
}
.lc-spider-ghost.active {
  animation: spiderPop 0.22s cubic-bezier(0.34,1.56,0.64,1) forwards,
             spiderBreath 3.5s ease-in-out 0.25s infinite;
}
.lc-spider-ghost.active .sp-eyes path {
  animation: eyePulse 2.2s ease-in-out 0.3s infinite;
}

/* ── legs ── */
.lc-spoke {
  fill: none;
  stroke: rgba(232,22,58,.35);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1400;
  stroke-dashoffset: 1400;
  transition: stroke .35s ease, stroke-width .3s ease, filter .3s ease;
}
.lc-spoke.drawn {
  animation: spokeDraw 1.1s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes spokeDraw { to { stroke-dashoffset: 0; } }
.lc-spoke.lit {
  stroke: rgba(232,22,58,.9);
  stroke-width: 3.5;
  filter: drop-shadow(0 0 6px rgba(232,22,58,.5));
}

/* ── joint dots ── */
.lc-joint-dot {
  fill: rgba(7,9,20,1);
  stroke: rgba(232,22,58,.4);
  stroke-width: 1.5;
  opacity: 0;
  transition: opacity .5s ease, stroke .35s ease, fill .35s ease, filter .35s ease;
}
.lc-joint-dot.show { opacity: 1; }
.lc-joint-dot.lit {
  fill: rgba(232,22,58,.18);
  stroke: rgba(232,22,58,.95);
  filter: drop-shadow(0 0 6px rgba(232,22,58,.8));
}

/* card hover wrapper — handles scale without conflicting with reveal transform */
.lc-card-wrap {
  width: 100%; height: 100%;
}

/* ── node cards ── */
.lc-card {
  width: 100%; height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: rgba(20,4,8,.97);
  border-radius: 0;
  border: 1px solid rgba(232,22,58,.28);
  box-shadow:
    inset 0 0 32px rgba(0,0,0,.55),
    0 0 16px rgba(232,22,58,.06);
  cursor: pointer;
  box-sizing: border-box;
  overflow: visible;
  opacity: 0;
  transform: scale(.35) translateY(10px);
  transition:
    opacity .6s cubic-bezier(.22,1,.36,1),
    transform .6s cubic-bezier(.34,1.56,.64,1),
    border-color .25s ease,
    box-shadow .25s ease;
  position: relative;
  pointer-events: all;
}
/* L-bracket corners — top-left */
.lc-card::before {
  content: '';
  position: absolute;
  top: -1px; left: -1px;
  width: 10px; height: 10px;
  border-top: 2px solid rgba(232,22,58,.9);
  border-left: 2px solid rgba(232,22,58,.9);
  pointer-events: none;
  transition: border-color .3s, width .3s, height .3s;
}
/* L-bracket corners — bottom-right */
.lc-card::after {
  content: '';
  position: absolute;
  bottom: -1px; right: -1px;
  width: 10px; height: 10px;
  border-bottom: 2px solid rgba(232,22,58,.9);
  border-right: 2px solid rgba(232,22,58,.9);
  pointer-events: none;
  transition: border-color .3s, width .3s, height .3s;
}
.lc-card.revealed {
  opacity: 1;
  transform: scale(1) translateY(0);
}
.lc-card:hover {
  border-color: var(--hb, rgba(232,22,58,.9));
  box-shadow:
    inset 0 0 20px rgba(0,0,0,.3),
    0 0 0 1px var(--hb, rgba(232,22,58,.5)),
    0 0 28px var(--hg, rgba(232,22,58,.35)),
    0 0 60px var(--hg, rgba(232,22,58,.15));
  transform: scale(1.1);
  z-index: 30;
}
.lc-card:hover::before,
.lc-card:hover::after {
  width: 14px; height: 14px;
  border-color: var(--hb, rgba(232,22,58,1));
}
.lc-card svg {
  width: 44%; height: 44%;
  flex-shrink: 0;
  transition: filter .3s ease, transform .3s ease;
}
.lc-card:hover svg {
  filter: drop-shadow(0 0 10px var(--hb, rgba(232,22,58,.8)));
  transform: scale(1.08);
}
.lc-card-label {
  margin-top: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(6px, 0.6vw, 8px);
  font-weight: 400;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(232,22,58,.35);
  text-align: center;
  white-space: nowrap;
  transition: color .3s ease;
  line-height: 1;
}
.lc-card:hover .lc-card-label { color: rgba(232,22,58,.85); }

/* ── active state on click ── */
.lc-card.active {
  border-color: var(--hb, rgba(232,22,58,.8)) !important;
  box-shadow:
    inset 0 0 32px rgba(0,0,0,.45),
    0 0 28px var(--hg, rgba(232,22,58,.22)) !important;
}
.lc-card.active::before,
.lc-card.active::after {
  width: 14px !important; height: 14px !important;
  border-color: var(--hb, rgba(232,22,58,1)) !important;
}
.lc-card.active svg {
  filter: drop-shadow(0 0 12px var(--hb, rgba(232,22,58,.9)));
  transform: scale(1.08);
}
.lc-card.active .lc-card-label { color: rgba(232,22,58,.9); }
.lc-spoke.active {
  stroke: rgba(232,22,58,.95) !important;
  stroke-width: 3.5 !important;
  filter: drop-shadow(0 0 8px rgba(232,22,58,.7));
}
/* ── center card — fully blue, unique ── */
.lc-card-center {
  background: rgba(4,8,28,.97);
  border-color: rgba(74,111,212,.55);
  box-shadow:
    inset 0 0 32px rgba(4,8,28,.8),
    0 0 20px rgba(74,111,212,.12);
}
.lc-card-center::before {
  border-top-color: rgba(74,111,212,.9);
  border-left-color: rgba(74,111,212,.9);
}
.lc-card-center::after {
  border-bottom-color: rgba(74,111,212,.9);
  border-right-color: rgba(74,111,212,.9);
}
.lc-card-center svg { width: 50%; height: 50%; }
.lc-card-center:hover {
  border-color: rgba(74,111,212,.8);
  box-shadow:
    inset 0 0 32px rgba(4,8,28,.7),
    0 0 26px rgba(74,111,212,.2);
}
.lc-card-center:hover::before {
  border-top-color: rgba(74,111,212,1);
  border-left-color: rgba(74,111,212,1);
  width: 14px; height: 14px;
}
.lc-card-center:hover::after {
  border-bottom-color: rgba(74,111,212,1);
  border-right-color: rgba(74,111,212,1);
  width: 14px; height: 14px;
}
.lc-card-center .lc-card-label { color: rgba(74,111,212,.5); }
.lc-card-center:hover .lc-card-label { color: rgba(74,111,212,.9); }

/* footer */
.lc-footer {
  display: flex; align-items: center; justify-content: center;
  gap: 20px; margin-top: 28px;
  padding: 0 clamp(24px,4vw,72px);
}
.lc-footer-line {
  flex: 1; max-width: 200px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,22,58,.18), transparent);
}
.lc-footer-txt {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 3px; text-transform: uppercase;
  color: rgba(184,190,221,.18);
}
.lc-footer-txt em { color: rgba(232,22,58,.5); font-style: normal; }

/* ── LIGHTBOX (lgv) — UNTOUCHED ── */
.lgv-backdrop {
  position: fixed; inset: 0;
  background: rgba(4,5,14,0);
  z-index: 9100;
  pointer-events: none;
  transition: background .4s;
  display: flex; align-items: center; justify-content: center;
  padding-top: 60px;
}
.lgv-backdrop.open { background: rgba(4,5,14,1); pointer-events: all; }
.lgv-backdrop::before {
  content: '';
  position: absolute; inset: 0;
  background: repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(232,22,58,.015) 3px,rgba(232,22,58,.015) 4px);
  pointer-events: none; opacity: 0; transition: opacity .5s .1s;
}
.lgv-backdrop.open::before { opacity: 1; }
.lgv-box {
  position: relative;
  width: clamp(280px, 62vw, 600px);
  max-height: calc(100vh - 140px);
  display: flex; flex-direction: column; align-items: center;
  transform: scale(.88) translateY(32px); opacity: 0;
  transition: transform .45s cubic-bezier(.22,1,.36,1), opacity .35s;
  overflow: visible;
}
.lgv-backdrop.open .lgv-box { transform: scale(1) translateY(0); opacity: 1; }
.lgv-stage {
  width: 100%; aspect-ratio: 4/3; position: relative;
  border: 1px solid rgba(232,22,58,.22);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.lgv-stage-bg { position: absolute; inset: 0; transition: background .4s; }
.lgv-stage-corner { position: absolute; width: 22px; height: 22px; pointer-events: none; }
.lgv-stage-corner::before,.lgv-stage-corner::after { content: ''; position: absolute; background: var(--red); box-shadow: 0 0 8px rgba(232,22,58,.7); }
.lgv-stage-corner::before { height:2px; width:100%; }
.lgv-stage-corner::after  { width:2px; height:100%; }
.lgv-stage-corner.tl{top:-1px;left:-1px;} .lgv-stage-corner.tl::before{top:0;left:0;} .lgv-stage-corner.tl::after{top:0;left:0;}
.lgv-stage-corner.tr{top:-1px;right:-1px;} .lgv-stage-corner.tr::before{top:0;right:0;} .lgv-stage-corner.tr::after{top:0;right:0;}
.lgv-stage-corner.bl{bottom:-1px;left:-1px;} .lgv-stage-corner.bl::before{bottom:0;left:0;} .lgv-stage-corner.bl::after{bottom:0;left:0;}
.lgv-stage-corner.br{bottom:-1px;right:-1px;} .lgv-stage-corner.br::before{bottom:0;right:0;} .lgv-stage-corner.br::after{bottom:0;right:0;}
.lgv-scan {
  position: absolute; left:0; right:0; height:2px;
  background: linear-gradient(90deg,transparent,rgba(232,22,58,.8),transparent);
  box-shadow: 0 0 12px 2px rgba(232,22,58,.4);
  animation: lgvScan 1.8s ease-out forwards;
  pointer-events: none; z-index:5;
}
@keyframes lgvScan { from{top:0%;opacity:1;} to{top:100%;opacity:0;} }
.lgv-logo-wrap {
  position: relative; z-index:2;
  width:55%; display:flex; align-items:center; justify-content:center;
  filter: drop-shadow(0 0 40px rgba(232,22,58,.2));
}
.lgv-bar {
  width:100%; background:rgba(10,13,26,.95);
  border:1px solid rgba(232,22,58,.2); border-top:none;
  display:flex; align-items:center; justify-content:space-between; padding:14px 20px;
}
.lgv-counter { font-family:"JetBrains Mono",monospace; font-size:11px; color:rgba(232,22,58,.75); letter-spacing:3px; }
.lgv-dots { display:flex; gap:7px; align-items:center; }
.lgv-dot { width:5px; height:5px; border-radius:50%; background:rgba(255,255,255,.15); cursor:pointer; transition:background .25s,transform .25s; }
.lgv-dot.active { background:var(--red); transform:scale(1.7); }
.lgv-nav { display:flex; gap:8px; }
.lgv-btn { width:30px; height:30px; border:1px solid rgba(255,255,255,.12); background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.lgv-btn:hover { border-color:rgba(232,22,58,.5); background:rgba(232,22,58,.1); }
.lgv-btn svg { width:13px; height:13px; stroke:#fff; fill:none; stroke-width:2; }
.lgv-close { position:absolute; top:-44px; right:0; width:34px; height:34px; border:1px solid rgba(232,22,58,.3); background:rgba(10,13,26,.9); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.lgv-close:hover { background:rgba(232,22,58,.15); border-color:var(--red); }
.lgv-close svg { width:14px; height:14px; stroke:#fff; fill:none; stroke-width:2; }


/* ══════════════════════════════════════════
   SERVICES SECTION
══════════════════════════════════════════ */
.svc-section {
  position: relative;
  width: 100%;
  padding: 80px 0 100px;
  overflow: visible;
  background: rgba(4,3,10,.5);
  border-top: 1px solid rgba(232,22,58,.12);
  border-bottom: 1px solid rgba(232,22,58,.08);
}
.svc-section::before {
  content: '';
  position: absolute;
  left: 0; right: 0; top: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,22,58,.4), transparent);
}

/* heading */
.svc-heading-wrap {
  text-align: center;
  margin-bottom: 52px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.svc-sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: rgba(255,255,255,.22);
}

/* layout: spider left, panel right */
.svc-layout {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 clamp(20px,4vw,60px);
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: clamp(32px,4vw,64px);
  align-items: start;
}
@media(max-width:960px) {
  .svc-layout { grid-template-columns: 1fr; justify-items: center; }
  .svc-diagram-wrap { width: 100%; max-width: 520px; }
}

.svc-diagram-wrap {
  position: relative;
  width: 100%;
}

/* ── SERVICE DETAIL PANEL ── */
.svc-panel {
  position: relative;
  background: rgba(8,6,18,.96);
  border: 1px solid rgba(232,22,58,.22);
  padding: 28px 28px;
  min-height: unset;
  height: auto;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  box-shadow: 0 0 60px rgba(232,22,58,.04), inset 0 0 40px rgba(0,0,0,.4);
  transition: border-color .35s, box-shadow .35s;
}
.svc-panel.active {
  border-color: rgba(232,22,58,.45);
  box-shadow: 0 0 40px rgba(232,22,58,.1), inset 0 0 40px rgba(0,0,0,.4);
}

/* bracket corners on panel */
.svc-panel-corner {
  position: absolute;
  width: 16px; height: 16px;
  pointer-events: none;
  transition: width .35s cubic-bezier(.22,1,.36,1), height .35s;
}
.svc-panel-corner::before,
.svc-panel-corner::after {
  content: ''; position: absolute; background: var(--red);
}
.svc-panel-corner::before { height: 1.5px; width: 100%; }
.svc-panel-corner::after  { width: 1.5px; height: 100%; }
.svc-panel-corner.tl { top:-7px; left:-7px; }
.svc-panel-corner.tl::before { top:0; left:0; }
.svc-panel-corner.tl::after  { top:0; left:0; }
.svc-panel-corner.tr { top:-7px; right:-7px; }
.svc-panel-corner.tr::before { top:0; right:0; }
.svc-panel-corner.tr::after  { top:0; right:0; }
.svc-panel-corner.bl { bottom:-7px; left:-7px; }
.svc-panel-corner.bl::before { bottom:0; left:0; }
.svc-panel-corner.bl::after  { bottom:0; left:0; }
.svc-panel-corner.br { bottom:-7px; right:-7px; }
.svc-panel-corner.br::before { bottom:0; right:0; }
.svc-panel-corner.br::after  { bottom:0; right:0; }
.svc-panel.active .svc-panel-corner { width: 26px; height: 26px; }

/* idle state */
.svc-panel-idle {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  text-align: center;
  width: 100%;
  padding: 32px 0;
}
.svc-idle-icon {
  width: 52px; height: 52px;
  opacity: .5;
  animation: svcIdlePulse 3s ease-in-out infinite;
}
@keyframes svcIdlePulse {
  0%,100% { opacity: .4; transform: scale(1); }
  50%      { opacity: .8; transform: scale(1.05); }
}
.svc-idle-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase;
  color: rgba(255,255,255,.18);
  line-height: 1.7;
}

/* content state */
.svc-panel-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  animation: svcFadeIn .3s ease forwards;
}
@keyframes svcFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.svc-panel-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 5px;
  color: rgba(232,22,58,.7);
  text-transform: uppercase;
}
.svc-panel-title {
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  font-size: clamp(28px,3vw,40px);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #fff;
  line-height: 1;
  margin: 0;
}
.svc-panel-divider {
  height: 1px;
  background: linear-gradient(90deg, rgba(232,22,58,.5), rgba(232,22,58,.05));
  margin: 4px 0;
}
.svc-panel-desc {
  font-size: clamp(13px,1.1vw,14px);
  font-weight: 300;
  line-height: 1.85;
  color: rgba(184,190,221,.6);
  margin: 0;
}
.svc-panel-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}
.svc-panel-tags span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 2.5px; text-transform: uppercase;
  color: rgba(232,22,58,.7);
  padding: 5px 12px;
  border: 1px solid rgba(232,22,58,.22);
  background: rgba(232,22,58,.04);
}
.svc-panel-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-top: 8px;
  padding: 12px 26px;
  background: var(--red);
  color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: 10px; letter-spacing: 3px; text-transform: uppercase;
  border: none;
  cursor: pointer;
  position: relative; overflow: hidden;
  transition: background .2s, transform .15s, box-shadow .2s;
  align-self: flex-start;
}
.svc-panel-btn::before {
  content: '';
  position: absolute; top: 0; left: -80%;
  width: 55%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
  transform: skewX(-16deg);
  transition: left .5s cubic-bezier(.22,1,.36,1);
}
.svc-panel-btn:hover::before { left: 130%; }
.svc-panel-btn:hover {
  background: var(--red-d);
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(232,22,58,.5);
}
.svc-panel-btn svg {
  width: 12px; height: 12px;
  stroke: #fff; fill: none; stroke-width: 2.5;
  transition: transform .25s;
}
.svc-panel-btn:hover svg { transform: translateX(3px); }

/* ── also reclassify the logo-section since it's now svc-section ── */
.svc-section.spider-active {
  background: rgba(4,0,8,0.92);
}




/* ── MOBILE SAFE-AREA & TOUCH FIXES ── */
@media(max-width:640px){
  .back-to-top{
    bottom:calc(20px + env(safe-area-inset-bottom,0px));
    right:20px;
  }
  .footer-bottom{
    padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));
    flex-direction:column;text-align:center;gap:12px;
  }
  /* hide custom cursor on touch */
  .cur-dot,.cur-ring{display:none;}
  body{cursor:auto;}
  /* hero breathing room on small screens */
  .svc-hero{padding-top:clamp(90px,14vh,110px);}
}
