/* ═══════════════════════════════════════════
   KODEIQ — Premium Digital Agency
   style.css  v2 — Immersive Unified Design
═══════════════════════════════════════════ */

/* ─── Variables ─── */
:root {
  --bg:        #04040a;
  --bg2:       #07070f;
  --surface:   rgba(255,255,255,0.05);
  --surface-h: rgba(255,255,255,0.088);
  --border:    rgba(255,255,255,0.07);
  --border-h:  rgba(255,255,255,0.14);

  --blue:      #00d4ff;
  --blue-l:    #33ddff;
  --blue-d:    #0099cc;
  --violet:    #8c00cc;
  --violet-l:  #b040e0;
  --pink:      #ec4899;
  --cyan:      #00d4ff;
  --green:     #22c55e;

  --tx1: #f1f5f9;
  --tx2: #94a3b8;
  --tx3: #475569;

  --grad:      linear-gradient(135deg, #00d4ff 0%, #5278f5 50%, #8c00cc 100%);
  --grad-text: linear-gradient(135deg, #00d4ff 0%, #5278f5 45%, #9900dd 100%);
  --grad-rev:  linear-gradient(135deg, #8c00cc 0%, #5278f5 50%, #00d4ff 100%);

  --fh: 'Sora', sans-serif;
  --fb: 'Inter', sans-serif;

  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;

  --ease:  cubic-bezier(0.4, 0, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --t:     all 0.3s var(--ease);
}

/* ─── Reset ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--tx1);
  font-family: var(--fb);
  overflow-x: hidden;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ─── Film grain overlay ─── */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 99999;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='250' height='250'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 250px 250px;
  opacity: 0.032;
  mix-blend-mode: overlay;
}

a  { text-decoration:none; color:inherit; }
ul { list-style:none; }

h1,h2,h3,h4,h5 { font-family:var(--fh); line-height:1.15; }

.gradient-text {
  background: var(--grad-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ─── Layout ─── */
.container { max-width:1180px; margin:0 auto; padding:0 28px; }

.section-header { text-align:center; margin-bottom:64px; position:relative; z-index:2; }
.section-label {
  display: inline-block;
  font-size: 11px; font-weight:600;
  letter-spacing:3px; text-transform:uppercase;
  color: var(--blue);
  padding: 5px 16px;
  border: 1px solid rgba(14,165,233,0.3);
  border-radius: 100px;
  background: rgba(14,165,233,0.06);
  margin-bottom: 18px;
}
.section-title { font-size:clamp(2rem,4vw,3rem); font-weight:700; margin-bottom:14px; }
.section-desc  { font-size:1.05rem; color:var(--tx2); max-width:580px; margin:0 auto; line-height:1.75; }

/* ─── Ripple keyframe ─── */
@keyframes btnRipple {
  0%   { transform: scale(1);   opacity: 0.6; }
  100% { transform: scale(60);  opacity: 0; }
}

/* ─── Premium Scrollbar ─── */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(14,165,233,0.8) rgba(255,255,255,0.06);
}

::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}

::-webkit-scrollbar-track {
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  border-left: 1px solid rgba(255,255,255,0.06);
}

::-webkit-scrollbar-thumb {
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: padding-box;
  background-image: linear-gradient(180deg, rgba(0,212,255,0.9), rgba(82,120,245,0.85) 50%, rgba(140,0,204,0.85));
  box-shadow: 0 0 18px rgba(14,165,233,0.35), inset 0 0 10px rgba(255,255,255,0.15);
}

::-webkit-scrollbar-thumb:hover {
  background-image: linear-gradient(180deg, rgba(51,221,255,1), rgba(95,136,255,0.95) 50%, rgba(176,64,224,0.95));
  box-shadow: 0 0 24px rgba(14,165,233,0.6), inset 0 0 12px rgba(255,255,255,0.25);
}

::-webkit-scrollbar-corner {
  background: rgba(255,255,255,0.02);
}

/* ═════════════════════════════════════════
   AURORA CANVAS — fixed global background
═════════════════════════════════════════ */
#aurora-canvas {
  position: fixed;
  inset: 0;
  width: 100%; height: 100%;
  z-index: 0;
  pointer-events: none;
}

/* all sections sit above aurora */
section, nav, footer { position:relative; z-index:1; }

/* ═════════════════════════════════════════
   SECTION BACKGROUNDS — shared system
═════════════════════════════════════════ */
.sec-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

/* Section edge fade — blends each section smoothly into the page background */
.sec-bg::before,
.sec-bg::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 160px;
  z-index: 3;
  pointer-events: none;
}
.sec-bg::before {
  top: 0;
  background: linear-gradient(to bottom, var(--bg), transparent);
}
.sec-bg::after {
  bottom: 0;
  background: linear-gradient(to top, var(--bg), transparent);
}
section > .container, section > .section-header { position:relative; z-index:2; }

/* glow blobs per section */
.sec-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  pointer-events: none;
}
.sg-blue       { width:600px; height:600px; background:radial-gradient(circle, rgba(14,165,233,0.1), transparent 70%);  top:-150px; left:-100px; }
.sg-violet     { width:500px; height:500px; background:radial-gradient(circle, rgba(139,92,246,0.12), transparent 70%); bottom:-100px; right:-100px; }
.sg-blue-right { width:500px; height:500px; background:radial-gradient(circle, rgba(14,165,233,0.08), transparent 70%); top:0; right:-80px; }
.sg-blue-left  { width:500px; height:500px; background:radial-gradient(circle, rgba(14,165,233,0.08), transparent 70%); bottom:0; left:-80px; }
.sg-violet-center {
  width:900px; height:900px;
  background:radial-gradient(circle, rgba(139,92,246,0.08), transparent 70%);
  top:50%; left:50%; transform:translate(-50%,-50%);
}

/* hex grid background */
.sec-hex-grid {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='80' height='92' viewBox='0 0 80 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M40 4L4 24v44l36 20 36-20V24z' fill='none' stroke='rgba(14,165,233,0.04)' stroke-width='1'/%3E%3C/svg%3E");
  background-size: 80px 92px;
  mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 40%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 40%, transparent 100%);
  opacity: 0.7;
}

/* dot grid */
.sec-dot-grid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(14,165,233,0.18) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 100%);
  opacity: 0.5;
}

/* diagonal slash lines (showcase) */
.sec-diagonal-lines {
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 60px,
    rgba(139,92,246,0.025) 60px,
    rgba(139,92,246,0.025) 61px
  );
}

/* circuit lines SVG (services) */
.circuit-lines {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  width: 100%; height: auto;
  opacity: 0.6;
  pointer-events: none;
}

/* node connections SVG (why) */
.node-connections {
  position: absolute;
  bottom: 48px; left: 50%;
  transform: translateX(-50%);
  width: 100%; max-width: 1100px;
  height: auto;
  pointer-events: none;
}

/* ═════════════════════════════════════════
   TECH GLYPHS — floating code decorations
═════════════════════════════════════════ */
.deco-glyph {
  position: absolute;
  font-family: var(--fh);
  font-weight: 800;
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  line-height: 1;
  z-index: 0;
}

/* Hero glyphs */
.deco-code-main {
  font-size: clamp(8rem, 18vw, 18rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(14,165,233,0.07);
  right: -2%;
  top: 15%;
  animation: glyphDrift 16s ease-in-out infinite;
  letter-spacing: -8px;
}
.deco-bracket-left {
  font-size: clamp(6rem, 12vw, 12rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(139,92,246,0.06);
  left: 2%;
  bottom: 20%;
  animation: glyphDrift 20s ease-in-out infinite reverse;
}
.deco-bracket-right {
  font-size: clamp(6rem, 12vw, 12rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(139,92,246,0.06);
  left: 8%;
  bottom: 20%;
  animation: glyphDrift 20s ease-in-out infinite reverse;
  animation-delay: -3s;
}

/* Services glyphs */
.deco-svc-curly {
  font-size: clamp(6rem, 10vw, 11rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(14,165,233,0.05);
  top: 8%;  right: 2%;
  animation: glyphDrift 18s ease-in-out infinite;
  letter-spacing: 8px;
}
.deco-svc-angle {
  font-size: clamp(5rem, 8vw, 9rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(139,92,246,0.05);
  bottom: 5%; left: 1%;
  animation: glyphDrift 22s ease-in-out infinite reverse;
  letter-spacing: 4px;
}

/* Why section */
.deco-why-slash {
  font-size: clamp(7rem, 12vw, 14rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(14,165,233,0.05);
  top: 5%; right: 3%;
  letter-spacing: 6px;
  animation: glyphDrift 20s ease-in-out infinite;
}

/* Pricing big R */
.deco-pricing-r {
  font-size: clamp(14rem, 24vw, 28rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(139,92,246,0.04);
  top: -5%; right: -2%;
  animation: glyphDrift 24s ease-in-out infinite;
}

@keyframes glyphDrift {
  0%,100% { transform: translateY(0) rotate(0deg); }
  33%      { transform: translateY(-18px) rotate(1deg); }
  66%      { transform: translateY(10px) rotate(-0.5deg); }
}

/* ═════════════════════════════════════════
   GEOMETRIC FLOATING SHAPES
═════════════════════════════════════════ */
.geo-float { position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:0; }
.geo       { position:absolute; }

/* rotating diamonds */
.geo-diamond {
  width: 40px; height: 40px;
  border: 1px solid rgba(14,165,233,0.18);
  transform: rotate(45deg);
  animation: diamondSpin 12s linear infinite;
}
.geo-diamond::before {
  content: '';
  position: absolute; inset: 5px;
  background: rgba(14,165,233,0.06);
}
.g1 { width:50px; height:50px; top:18%; right:12%; animation-duration:14s; border-color:rgba(14,165,233,0.2); }
.g2 { width:28px; height:28px; bottom:22%; left:8%;  animation-duration:10s; border-color:rgba(139,92,246,0.2); animation-direction:reverse; }

@keyframes diamondSpin {
  from { transform:rotate(45deg); }
  to   { transform:rotate(405deg); }
}

/* ring geo */
.geo-ring {
  width: 120px; height: 120px;
  border-radius: 50%;
  border: 1px solid rgba(139,92,246,0.12);
  bottom: 15%; right: 20%;
  animation: ringPulse 8s ease-in-out infinite;
}
.geo-ring::before {
  content:'';
  position:absolute; inset:14px;
  border-radius:50%;
  border: 1px solid rgba(139,92,246,0.08);
}
.g3 { bottom:15%; right:18%; }

@keyframes ringPulse {
  0%,100% { transform:scale(1);    opacity:1;   }
  50%      { transform:scale(1.12); opacity:0.6; }
}

/* dot cluster */
.geo-dot-cluster {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 10px;
  top: 62%; left: 5%;
  animation: clusterFloat 10s ease-in-out infinite;
}
.geo-dot-cluster span {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(14,165,233,0.25);
  display: block;
}
.geo-dot-cluster span:nth-child(2n) { background:rgba(139,92,246,0.2); }

@keyframes clusterFloat {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-10px); }
}

/* showcase geo */
.showcase-geo { position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:0; }

.sd1 { width:60px; height:60px; top:12%; left:5%; animation-duration:16s; border-color:rgba(139,92,246,0.2); }
.sd1::before { background:rgba(139,92,246,0.06); }
.sd2 { width:35px; height:35px; bottom:15%; right:8%; animation-duration:11s; border-color:rgba(14,165,233,0.2); animation-direction:reverse; }

.geo-hex {
  position: absolute;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  animation: hexFloat 14s ease-in-out infinite;
}
.sh1 {
  width:80px; height:80px;
  background: rgba(14,165,233,0.04);
  border-radius:2px;
  top:20%; right:5%;
  animation-delay:-4s;
}
.sh2 {
  width:50px; height:50px;
  background: rgba(139,92,246,0.05);
  bottom:25%; left:3%;
  animation-delay:-8s;
  animation-direction:reverse;
}

@keyframes hexFloat {
  0%,100% { transform:translateY(0) rotate(0deg); }
  50%      { transform:translateY(-20px) rotate(30deg); }
}

/* ═════════════════════════════════════════
   PRICING RINGS
═════════════════════════════════════════ */
.pricing-rings {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  pointer-events: none;
  z-index: 0;
}
.pring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  animation: pringExpand 6s ease-out infinite;
}
.pring-1 { width:300px; height:300px; border-color:rgba(14,165,233,0.12);  animation-delay:0s; }
.pring-2 { width:500px; height:500px; border-color:rgba(139,92,246,0.08); animation-delay:1.5s; }
.pring-3 { width:700px; height:700px; border-color:rgba(14,165,233,0.05);  animation-delay:3s; }
.pring-4 { width:900px; height:900px; border-color:rgba(139,92,246,0.03); animation-delay:4.5s; }

@keyframes pringExpand {
  0%   { transform:translate(-50%,-50%) scale(0.7); opacity:0.8; }
  100% { transform:translate(-50%,-50%) scale(1.2); opacity:0; }
}

/* sparkles */
.sparkles { position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:0; }
.sparkle {
  position: absolute;
  width: 4px; height: 4px;
  background: var(--blue-l);
  border-radius: 50%;
  animation: sparkleTwinkle 3s ease-in-out infinite;
  box-shadow: 0 0 6px rgba(56,189,248,0.8);
}
.s1 { top:15%; left:8%;  animation-delay:0s;   }
.s2 { top:25%; right:12%; animation-delay:0.7s; background:var(--violet-l); box-shadow:0 0 6px rgba(167,139,250,0.8); }
.s3 { top:70%; left:15%; animation-delay:1.4s; }
.s4 { bottom:20%; right:20%; animation-delay:2s; background:var(--violet-l); box-shadow:0 0 6px rgba(167,139,250,0.8); }
.s5 { top:45%; left:5%;  animation-delay:0.4s; }
.s6 { top:55%; right:5%; animation-delay:1.8s; }

@keyframes sparkleTwinkle {
  0%,100% { transform:scale(1);   opacity:0.8; }
  50%      { transform:scale(1.8); opacity:0.2; }
}

/* ═════════════════════════════════════════
   CONTACT RINGS
═════════════════════════════════════════ */
.contact-rings { position:absolute; inset:0; pointer-events:none; }
.cring {
  position:absolute;
  border-radius:50%;
  border:1px solid;
  left:25%; top:50%;
  transform:translate(-50%,-50%);
  animation:cringPulse 5s ease-out infinite;
}
.cr1 { width:200px; height:200px; border-color:rgba(14,165,233,0.12);  animation-delay:0s;   }
.cr2 { width:350px; height:350px; border-color:rgba(14,165,233,0.07);  animation-delay:1.5s; }
.cr3 { width:500px; height:500px; border-color:rgba(14,165,233,0.035); animation-delay:3s;   }

@keyframes cringPulse {
  0%   { transform:translate(-50%,-50%) scale(0.8); opacity:0.6; }
  100% { transform:translate(-50%,-50%) scale(1.3); opacity:0; }
}

/* chat bubbles */
.chat-bubble-deco {
  position: absolute;
  border-radius: 18px;
  border: 1px solid;
  pointer-events: none;
  z-index: 0;
}
.cb1 {
  width:120px; height:70px;
  border-color:rgba(14,165,233,0.08);
  background:rgba(14,165,233,0.03);
  top:12%; right:5%;
  border-bottom-right-radius:4px;
  animation:bubbleFloat 10s ease-in-out infinite;
}
.cb2 {
  width:80px; height:50px;
  border-color:rgba(139,92,246,0.08);
  background:rgba(139,92,246,0.03);
  bottom:18%; left:2%;
  border-bottom-left-radius:4px;
  animation:bubbleFloat 13s ease-in-out infinite reverse;
}

@keyframes bubbleFloat {
  0%,100% { transform:translateY(0) rotate(-2deg); }
  50%      { transform:translateY(-14px) rotate(1deg); }
}

/* browser chrome bar (above laptop) */
.browser-top-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-bottom: none;
  border-radius: 12px 12px 0 0;
  max-width: 500px;
  margin: 0 auto;
}
.btb-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.btb-red    { background:#ff5f57; }
.btb-yellow { background:#febc2e; }
.btb-green  { background:#28c840; }
.btb-url {
  flex:1; height:20px;
  background:rgba(255,255,255,0.05);
  border-radius:6px;
  margin-left:8px;
  position:relative;
}
.btb-url::before {
  content:'kodeiq.co.za';
  position:absolute;
  left:10px; top:50%;
  transform:translateY(-50%);
  font-size:0.65rem;
  color:var(--tx3);
  font-family:var(--fb);
}

/* ═════════════════════════════════════════
   CURSOR GLOW
═════════════════════════════════════════ */
.cursor-glow {
  position: fixed;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(14,165,233,0.04) 0%, transparent 70%);
  pointer-events: none;
  transform: translate(-50%,-50%);
  z-index: 9000;
  transition: opacity 0.4s ease;
  will-change: left, top;
}

/* ═════════════════════════════════════════
   FLOATING WHATSAPP FAB
═════════════════════════════════════════ */
.wa-fab {
  position: fixed;
  bottom: 28px; right: 28px;
  z-index: 9900;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 62px; height: 62px;
  border-radius: 50%;
  background: linear-gradient(135deg, #25d366, #128c7e);
  box-shadow: 0 4px 28px rgba(37,211,102,0.45), 0 0 0 0 rgba(37,211,102,0.3);
  transition: transform 0.3s var(--ease-spring), box-shadow 0.3s var(--ease);
  text-decoration: none;
}
.wa-fab:hover {
  transform: scale(1.12);
  box-shadow: 0 6px 36px rgba(37,211,102,0.6), 0 0 0 0 rgba(37,211,102,0);
}
.wa-fab:hover .wa-fab-tip { opacity:1; transform:translateY(-50%) translateX(0); pointer-events:none; }

.wa-fab-pulse {
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid rgba(37,211,102,0.4);
  animation: waPulse 2.4s ease-out infinite;
}
.wa-fab-pulse.p2 { animation-delay:1.2s; }

@keyframes waPulse {
  0%   { transform:scale(1);   opacity:0.8; }
  100% { transform:scale(2);   opacity:0; }
}

@keyframes fabTipIntro {
  0%   { opacity: 0; transform: translateY(-50%) translateX(8px); }
  15%  { opacity: 1; transform: translateY(-50%) translateX(0); }
  75%  { opacity: 1; transform: translateY(-50%) translateX(0); }
  100% { opacity: 0; transform: translateY(-50%) translateX(8px); }
}

.wa-fab-inner {
  position: relative;
  z-index: 2;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wa-fab-tip {
  position: absolute;
  right: calc(100% + 14px);
  top: 50%;
  transform: translateY(-50%) translateX(8px);
  background: rgba(7,7,15,0.95);
  color: var(--tx1);
  font-size: 0.8rem;
  font-weight: 600;
  font-family: var(--fb);
  padding: 9px 16px;
  border-radius: 10px;
  white-space: nowrap;
  border: 1px solid rgba(255,255,255,0.1);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
  animation: fabTipIntro 4.5s ease-in-out 2.5s both;
}
.wa-fab-tip::after {
  content: '';
  position: absolute;
  right: -6px; top: 50%;
  transform: translateY(-50%);
  border: 6px solid transparent;
  border-left-color: rgba(7,7,15,0.95);
  border-right: none;
}

/* ═════════════════════════════════════════
   NAVBAR
═════════════════════════════════════════ */
.navbar {
  position: fixed;
  top:0; left:0; right:0;
  z-index: 1000;
  padding: 22px 0;
  transition: var(--t);
}
.navbar.scrolled {
  background: rgba(4,4,10,0.88);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-bottom: 1px solid var(--border);
  padding: 14px 0;
  box-shadow: 0 4px 40px rgba(0,0,0,0.3);
}
.nav-container {
  max-width:1180px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.logo-mark {
  height: 32px;
  width: auto;
  flex-shrink: 0;
}
.logo-wordmark {
  font-family: var(--fh);
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: 1px;
  color: var(--tx1);
}
.footer-logo-link {
  margin-bottom: 16px;
}
.footer-logo-link .logo-mark { height: 36px; }
.footer-logo-link .logo-wordmark { font-size: 1.45rem; }
.accent { color: var(--blue); }
.logo-tag { color: var(--blue); opacity: 0.75; font-weight: 700; }

.nav-links { display:flex; align-items:center; gap:4px; }
.nav-links a {
  color:var(--tx2); font-size:0.88rem; font-weight:500;
  padding:8px 16px; border-radius:var(--r-sm); transition:var(--t);
}
.nav-links a:hover { color:var(--tx1); background:rgba(255,255,255,0.05); }
.nav-links .nav-cta {
  background:var(--grad); color:#fff;
  padding:9px 22px; border-radius:var(--r-sm); font-weight:600;
}
.nav-links .nav-cta:hover { opacity:0.88; transform:translateY(-1px); }

.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:8px; z-index:1001;
}
.hamburger span { display:block; width:22px; height:2px; background:var(--tx1); border-radius:2px; transition:var(--t); }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ─── Services Dropdown ─── */
.has-dropdown { position:relative; }
.dropdown-trigger {
  display:inline-flex !important; align-items:center; gap:5px; cursor:pointer;
}
.chevron { flex-shrink:0; transition:transform 0.25s ease; }
.has-dropdown.open .chevron,
.has-dropdown:focus-within .chevron { transform:rotate(180deg); }

.dropdown-panel {
  position:absolute; top:calc(100% + 10px); left:50%;
  transform:translateX(-50%) translateY(-6px);
  opacity:0; pointer-events:none; min-width:250px;
  background:rgba(4,4,10,0.94); backdrop-filter:blur(22px) saturate(1.5);
  border:1px solid rgba(255,255,255,0.11); border-radius:16px;
  padding:6px; list-style:none;
  transition:opacity 0.22s ease, transform 0.22s ease;
  z-index:2000; box-shadow:0 20px 60px rgba(0,0,0,0.5);
}
.has-dropdown:hover .dropdown-panel,
.has-dropdown:focus-within .dropdown-panel,
.has-dropdown.open .dropdown-panel {
  opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0);
}
.dropdown-panel li { list-style:none; }
.dropdown-panel li a {
  display:flex !important; justify-content:space-between; align-items:center;
  padding:9px 14px; border-radius:10px;
  color:var(--tx2) !important; font-size:0.84rem; font-weight:500;
  background:none !important; transition:background 0.18s ease, color 0.18s ease;
  text-decoration:none;
}
.dropdown-panel li a:hover {
  background:rgba(0,212,255,0.09) !important; color:var(--tx1) !important;
}
.dropdown-panel li a span { font-size:0.72rem; color:var(--blue); opacity:0.85; }
.dropdown-all { border-top:1px solid rgba(255,255,255,0.08); margin-top:4px; padding-top:4px; }
.dropdown-all a { color:var(--blue) !important; font-weight:600; justify-content:center !important; }
.dropdown-all a:hover { background:rgba(0,212,255,0.12) !important; }

/* Mobile: dropdown in hamburger menu */
@media (max-width: 768px) {
  .dropdown-panel {
    position:static; transform:none; opacity:1; pointer-events:all;
    background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.07);
    border-radius:10px; margin-top:6px; box-shadow:none; backdrop-filter:none;
    display:none;
  }
  .has-dropdown.open .dropdown-panel { display:block; }
  .dropdown-panel li a span { display:none; }
}

/* ═════════════════════════════════════════
   HERO
═════════════════════════════════════════ */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

#hero-canvas {
  position: absolute;
  inset: 0; width:100%; height:100%;
  opacity: 0.5;
}

.hero-grid {
  position: absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black, transparent);
  -webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black, transparent);
}

.hero-orbs { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.orb {
  position:absolute; border-radius:50%;
  filter:blur(100px);
  animation:orbFloat 12s ease-in-out infinite;
  will-change:transform;
}
.orb-1 { width:550px; height:550px; background:radial-gradient(circle, rgba(14,165,233,0.17), transparent 70%);  top:-140px; right:-100px; animation-delay:0s; }
.orb-2 { width:450px; height:450px; background:radial-gradient(circle, rgba(139,92,246,0.2),  transparent 70%); bottom:-120px; left:-80px; animation-delay:-6s; }
.orb-3 { width:300px; height:300px; background:radial-gradient(circle, rgba(236,72,153,0.1),  transparent 70%); top:40%; left:50%; animation-delay:-3s; }
@keyframes orbFloat {
  0%,100% { transform:translateY(0) scale(1); }
  50%      { transform:translateY(-30px) scale(1.05); }
}

.hero-content {
  position:relative; z-index:2;
  text-align:center;
  max-width:920px;
  padding: 110px 28px 60px;
}

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-size:0.75rem; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--tx2);
  padding:8px 22px;
  border:1px solid var(--border-h);
  border-radius:100px;
  background:rgba(255,255,255,0.03);
  backdrop-filter:blur(14px);
  margin-bottom:36px;
}
.badge-dot {
  width:6px; height:6px; background:var(--blue);
  border-radius:50%; animation:badgeBlink 2s ease-in-out infinite;
  box-shadow:0 0 8px rgba(14,165,233,0.8);
}
@keyframes badgeBlink {
  0%,100% { opacity:1; box-shadow:0 0 8px rgba(14,165,233,0.8); }
  50%      { opacity:0.4; box-shadow:none; }
}

.hero-title {
  font-size: clamp(3.2rem, 8.5vw, 7rem);
  font-weight: 800;
  letter-spacing: -3px;
  line-height: 1.03;
  margin-bottom: 28px;
}
.title-gradient {
  background: var(--grad-text);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  display: inline-block;
  font-size: 1.12em;
  letter-spacing: -4px;
  filter: drop-shadow(0 0 40px rgba(14,165,233,0.55)) drop-shadow(0 0 90px rgba(139,92,246,0.3));
}

.hero-subtitle { font-size:clamp(1rem,2vw,1.2rem); color:var(--tx2); line-height:1.8; margin-bottom:52px; }
.br-hide { display:block; }

.hero-buttons { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:72px; }

/* ─── Buttons ─── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 28px; border-radius:var(--r-md);
  font-weight:600; font-size:0.93rem; font-family:var(--fb);
  transition:var(--t); cursor:pointer; border:none;
}
.btn svg { width:17px; height:17px; transition:transform 0.3s var(--ease); flex-shrink:0; }
.btn:hover svg { transform:translateX(4px); }

.btn-primary {
  background:var(--grad); color:#fff;
  box-shadow:0 0 32px rgba(14,165,233,0.28), inset 0 1px 0 rgba(255,255,255,0.15);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 0 52px rgba(14,165,233,0.48); }

.btn-secondary {
  background:rgba(255,255,255,0.06); color:var(--tx1);
  border:1px solid var(--border-h); backdrop-filter:blur(10px);
}
.btn-secondary:hover { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.22); transform:translateY(-2px); }

/* hero stats */
.hero-stats {
  display:inline-flex; align-items:center; gap:36px;
  padding:22px 44px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:20px;
  backdrop-filter:blur(14px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 8px 32px rgba(0,0,0,0.2);
}
.stat { display:flex; flex-direction:column; align-items:center; gap:4px; }
.stat-number {
  font-family:var(--fh); font-size:1.8rem; font-weight:700;
  background:var(--grad-text); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1;
}
.stat-label  { font-size:0.7rem; color:var(--tx3); text-transform:uppercase; letter-spacing:1px; }
.stat-divider { width:1px; height:38px; background:var(--border); }

/* scroll indicator */
.scroll-indicator {
  position:absolute; bottom:32px; left:50%;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:var(--tx3); font-size:0.65rem; letter-spacing:2px; text-transform:uppercase; z-index:2;
}
.scroll-line { width:1px; height:44px; background:linear-gradient(to bottom, var(--blue), transparent); animation:scrollAnim 2.2s ease-in-out infinite; }
@keyframes scrollAnim {
  0%   { opacity:0; transform:scaleY(0); transform-origin:top; }
  45%  { opacity:1; transform:scaleY(1); transform-origin:top; }
  55%  { opacity:1; transform:scaleY(1); transform-origin:bottom; }
  100% { opacity:0; transform:scaleY(0); transform-origin:bottom; }
}

/* ═════════════════════════════════════════
   SERVICES
═════════════════════════════════════════ */
.services { padding:130px 0; }

.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; position:relative; z-index:2; }

.service-card {
  position:relative;
  display:flex; flex-direction:column;
  padding:36px 30px;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition:transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease), background 0.35s var(--ease);
  overflow:hidden;
  backdrop-filter:blur(18px);
}
.service-card:hover {
  background:rgba(255,255,255,0.085);
  border-color:rgba(14,165,233,0.28);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(0,0,0,0.35), 0 0 60px rgba(14,165,233,0.1), inset 0 1px 0 rgba(255,255,255,0.08);
}
.service-card--violet:hover { border-color:rgba(139,92,246,0.2); box-shadow:0 20px 60px rgba(0,0,0,0.3), 0 0 40px rgba(139,92,246,0.06); }

/* animated gradient border on hover */
.service-card::after {
  content:'';
  position:absolute; inset:0;
  border-radius:var(--r-lg);
  padding:1px;
  background:var(--grad);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:0; transition:opacity 0.4s ease;
  pointer-events:none;
}
.service-card:hover::after { opacity:0.5; }

.card-glow {
  position:absolute; inset:0;
  background:radial-gradient(circle at 50% -20%, rgba(14,165,233,0.08), transparent 65%);
  opacity:0; transition:opacity 0.5s ease; pointer-events:none;
}
.service-card--violet .card-glow { background:radial-gradient(circle at 50% -20%, rgba(139,92,246,0.1), transparent 65%); }

/* card shine sweep */
.card-shine {
  position:absolute; top:-50%; left:-75%;
  width:50%; height:200%;
  background:linear-gradient(to right, transparent, rgba(255,255,255,0.03), transparent);
  transform:skewX(-20deg);
  transition:left 0.7s ease;
  pointer-events:none;
}
.service-card:hover .card-shine { left:125%; }

.card-icon {
  width:50px; height:50px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(14,165,233,0.09);
  border:1px solid rgba(14,165,233,0.2);
  border-radius:14px;
  color:var(--blue); margin-bottom:20px; transition:var(--t);
}
.card-icon--violet { background:rgba(139,92,246,0.09); border-color:rgba(139,92,246,0.2); color:var(--violet-l); }
.service-card:hover .card-icon { transform:scale(1.1) rotate(-4deg); box-shadow:0 0 20px rgba(14,165,233,0.3); }
.service-card--violet:hover .card-icon { box-shadow:0 0 20px rgba(139,92,246,0.3); }
.card-icon svg { width:23px; height:23px; }

.service-card h3 { font-size:1.05rem; font-weight:600; margin-bottom:10px; }
.service-card p  { font-size:0.87rem; color:var(--tx2); line-height:1.75; margin-bottom:0; flex:1; }

.card-footer {
  display:flex; align-items:center; justify-content:space-between;
  margin-top:24px; padding-top:18px;
  border-top:1px solid rgba(255,255,255,0.06);
  gap:12px;
}
.card-tag {
  display:inline-block;
  align-self: flex-start;
  font-size:0.67rem; font-weight:600; letter-spacing:1px; text-transform:uppercase;
  color:var(--blue); padding:4px 10px;
  background:rgba(14,165,233,0.07); border:1px solid rgba(14,165,233,0.15); border-radius:100px;
  margin-bottom:20px;
}
.card-tag--violet { color:var(--violet-l); background:rgba(139,92,246,0.07); border-color:rgba(139,92,246,0.15); }

.service-price {
  font-family: var(--fh);
  font-size: 1rem;
  font-weight: 700;
  color: var(--tx1);
  margin: 0;
  white-space: nowrap;
}
.service-price span {
  font-family: var(--fb);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--tx3);
  margin-left: 6px;
}
.service-link {
  display: inline-flex;
  flex-shrink: 0;
  padding: 8px 14px;
  border-radius: 10px;
  border: 1px solid rgba(14,165,233,0.22);
  background: rgba(14,165,233,0.08);
  color: var(--blue-l);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.4px;
  transition: var(--t);
  white-space: nowrap;
}
.service-link:hover {
  color: #fff;
  background: rgba(14,165,233,0.2);
  border-color: rgba(14,165,233,0.45);
  transform: translateY(-1px);
}
.services-more {
  margin-top: 26px;
  text-align: center;
}

/* ═════════════════════════════════════════
   SHOWCASE
═════════════════════════════════════════ */
.showcase { padding:130px 0; position:relative; overflow:hidden; }

.showcase-scene { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; position:relative; z-index:2; }

.laptop-wrap { display:flex; flex-direction:column; align-items:center; }
.laptop {
  position:relative; width:100%; max-width:500px;
  filter:drop-shadow(0 40px 80px rgba(14,165,233,0.12)) drop-shadow(0 20px 40px rgba(139,92,246,0.1));
  animation:laptopFloat 7s ease-in-out infinite;
}
@keyframes laptopFloat {
  0%,100% { transform:perspective(1200px) rotateY(-5deg) rotateX(2deg) translateY(0); }
  50%      { transform:perspective(1200px) rotateY(-5deg) rotateX(2deg) translateY(-14px); }
}

.laptop-screen {
  background:#09090f; border-radius:12px 12px 0 0;
  border:2px solid rgba(255,255,255,0.1); border-bottom:none;
  overflow:hidden; aspect-ratio:16/10; position:relative;
}
.laptop-screen::after {
  content:''; position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:5px; height:5px; background:rgba(255,255,255,0.18); border-radius:50%; z-index:10;
}
.laptop-chin {
  background:linear-gradient(180deg,#16162a,#0d0d1c); height:22px;
  border-radius:0 0 8px 8px; border:2px solid rgba(255,255,255,0.08); border-top:none;
  display:flex; align-items:flex-end; justify-content:center;
}
.laptop-notch { width:72px; height:7px; background:rgba(255,255,255,0.04); border-radius:4px 4px 0 0; }

/* mock website inside */
.mock-site {
  width:100%; height:100%;
  background:linear-gradient(145deg,#05050d,#0c0c1a);
  display:flex; flex-direction:column; padding:10px; gap:8px;
}
.mock-nav-bar { display:flex; align-items:center; justify-content:space-between; height:18px; padding:0 4px; }
.mock-logo    { width:36px; height:8px; background:var(--grad); border-radius:4px; }
.mock-nav-links { display:flex; gap:6px; }
.mock-nav-links div { width:20px; height:5px; background:rgba(255,255,255,0.1); border-radius:3px; }
.mock-hero-area {
  display:flex; gap:10px; align-items:center; flex:1;
  padding:14px 8px;
  background:rgba(255,255,255,0.02); border-radius:8px; border:1px solid rgba(255,255,255,0.04);
}
.mock-avatar-circle { width:52px; height:52px; border-radius:50%; background:var(--grad); flex-shrink:0; box-shadow:0 0 20px rgba(14,165,233,0.35); }
.mock-text-lines { display:flex; flex-direction:column; gap:6px; flex:1; }
.mock-line { height:6px; background:rgba(255,255,255,0.08); border-radius:3px; }
.ml-70 { width:70%; } .ml-50 { width:50%; } .ml-40 { width:40%; } .ml-bright { background:rgba(255,255,255,0.18); }
.mock-btns { display:flex; gap:6px; margin-top:4px; }
.mock-btns div:first-child { width:50px; height:16px; background:var(--grad); border-radius:4px; }
.mock-btns div:last-child  { width:40px; height:16px; background:rgba(255,255,255,0.06); border-radius:4px; border:1px solid rgba(255,255,255,0.1); }
.mock-cards-row { display:flex; gap:6px; }
.mock-mini-card { flex:1; height:40px; background:rgba(255,255,255,0.04); border-radius:6px; border:1px solid rgba(255,255,255,0.06); }
.mc-blue { background:linear-gradient(135deg,rgba(14,165,233,0.15),rgba(139,92,246,0.15)); border-color:rgba(14,165,233,0.2); }

.showcase-info { display:flex; flex-direction:column; gap:16px; }
.showcase-tag {
  display:flex; align-items:center; gap:16px;
  padding:18px 22px;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  backdrop-filter:blur(18px);
  transition:var(--t); position:relative; overflow:hidden;
}
.showcase-tag::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--grad); border-radius:3px; }
.showcase-tag:hover { background:rgba(255,255,255,0.055); border-color:var(--border-h); transform:translateX(6px); }
.stag-icon { width:38px; height:38px; display:flex; align-items:center; justify-content:center; border-radius:10px; flex-shrink:0; }
.stag-icon svg { width:18px; height:18px; }
.stag-blue   { background:rgba(14,165,233,0.1);  color:var(--blue); }
.stag-violet { background:rgba(139,92,246,0.1); color:var(--violet-l); }
.stag-pink   { background:rgba(236,72,153,0.1);  color:var(--pink); }
.stag-text { flex:1; }
.stag-text h4 { font-size:0.88rem; font-weight:600; margin-bottom:2px; }
.stag-text p  { font-size:0.78rem; color:var(--tx2); }
.work-link {
  display:inline-block;
  margin-top:6px;
  font-size:0.74rem;
  color:var(--blue-l);
  text-decoration:none;
  border-bottom:1px dashed rgba(125,211,252,0.45);
  line-height:1.25;
  word-break:break-all;
}
.work-link:hover {
  color:#fff;
  border-bottom-color:rgba(255,255,255,0.65);
}
.live-badge {
  font-size:0.62rem; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  color:var(--green); padding:3px 8px;
  background:rgba(34,197,94,0.08); border:1px solid rgba(34,197,94,0.22); border-radius:100px;
}
.showcase-quote {
  padding:22px 24px; background:rgba(139,92,246,0.04);
  border:1px solid rgba(139,92,246,0.12); border-radius:var(--r-md); border-left:3px solid var(--violet);
  backdrop-filter:blur(8px);
}
.showcase-quote p { font-size:0.88rem; font-style:italic; color:var(--tx2); line-height:1.75; }

/* ═════════════════════════════════════════
   WHY KODEIQ
═════════════════════════════════════════ */
.why { padding:130px 0; }
.why-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; position:relative; z-index:2; }

.why-card {
  padding:30px 22px;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  backdrop-filter:blur(18px);
  transition:transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease);
  position:relative; overflow:hidden;
}
.why-card-glow {
  position:absolute; bottom:0; left:0; right:0; height:2px;
  background:var(--grad); transform:scaleX(0); transition:transform 0.35s var(--ease); transform-origin:left;
}
.why-card:hover { transform:translateY(-6px); border-color:rgba(14,165,233,0.2); box-shadow:0 16px 48px rgba(0,0,0,0.25), 0 0 30px rgba(14,165,233,0.05); }
.why-card:hover .why-card-glow { transform:scaleX(1); }

.why-num { font-family:var(--fh); font-size:2.2rem; font-weight:800; color:rgba(255,255,255,0.04); line-height:1; margin-bottom:14px; }
.why-icon { width:42px; height:42px; display:flex; align-items:center; justify-content:center; background:rgba(14,165,233,0.08); border:1px solid rgba(14,165,233,0.15); border-radius:12px; color:var(--blue); margin-bottom:14px; transition:var(--t); }
.why-card:hover .why-icon { transform:scale(1.1); background:rgba(14,165,233,0.14); box-shadow:0 0 16px rgba(14,165,233,0.2); }
.why-icon svg { width:21px; height:21px; }
.why-card h3 { font-size:0.93rem; font-weight:600; margin-bottom:8px; }
.why-card p  { font-size:0.82rem; color:var(--tx2); line-height:1.7; }

/* ═════════════════════════════════════════
   PRICING
═════════════════════════════════════════ */
.pricing { padding:130px 0; position:relative; overflow:hidden; }

/* ── Services pricing grid ── */
.pricing-services-grid {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 32px;
}

.ps-card {
  position: relative;
  display: flex; flex-direction: column;
  gap: 10px;
  padding: 26px 24px;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: var(--r-lg);
  backdrop-filter: blur(14px);
  text-decoration: none;
  color: var(--tx1);
  transition: transform 0.25s var(--ease), border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
  overflow: hidden;
}
.ps-card:hover {
  transform: translateY(-5px);
  border-color: rgba(0,212,255,0.28);
  background: rgba(255,255,255,0.07);
  box-shadow: 0 16px 48px rgba(0,0,0,0.25);
}
.ps-card.ps-featured {
  border-color: rgba(140,0,204,0.4);
  box-shadow: 0 14px 50px rgba(140,0,204,0.12);
  background: rgba(140,0,204,0.06);
}
.ps-card.ps-featured:hover {
  border-color: rgba(140,0,204,0.6);
  box-shadow: 0 20px 60px rgba(140,0,204,0.2);
}

.ps-border-glow {
  position: absolute; inset: -1px;
  border-radius: var(--r-lg);
  background: conic-gradient(from var(--angle), #0ea5e9, #8b5cf6, #ec4899, #0ea5e9);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 1px;
  animation: borderRotate 6s linear infinite;
  opacity: 0.45;
}

.ps-badge {
  display: inline-block; align-self: flex-start;
  font-size: 0.63rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: #fff; padding: 4px 10px; background: var(--grad); border-radius: 100px;
}
.ps-icon { font-size: 1.7rem; line-height: 1; }
.ps-card h3 { font-size: 1.02rem; font-weight: 700; margin: 0; }
.ps-card p { font-size: 0.82rem; color: var(--tx2); line-height: 1.6; flex: 1; margin: 0; }
  display: flex; align-items: baseline; gap: 6px;
  font-family: var(--fh);
}
.ps-from { font-size: 0.72rem; color: var(--tx3); }
.ps-price strong { font-size: 1.45rem; font-weight: 800; color: var(--tx1); }
.ps-price small { font-size: 0.72rem; color: var(--tx3); }
.ps-cta {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 0.78rem; font-weight: 600; color: var(--blue);
  margin-top: 2px;
}
.ps-card:hover .ps-cta { gap: 8px; }

.pricing-footnote {
  position: relative; z-index: 2;
  text-align: center; font-size: 0.83rem; color: var(--tx3);
}
.pricing-footnote a { color: var(--blue); text-decoration: none; }
.pricing-footnote a:hover { text-decoration: underline; }

@media (max-width: 1024px) {
  .pricing-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .pricing-services-grid { grid-template-columns: 1fr; }
}

.pricing-card {
  position:relative; padding:52px 48px;
  background:rgba(255,255,255,0.055);
  border-radius:var(--r-xl); overflow:hidden;
  backdrop-filter:blur(28px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 0 100px rgba(14,165,233,0.1), 0 40px 80px rgba(0,0,0,0.25);
}

/* animated gradient border */
.pricing-border-glow {
  position:absolute; inset:-1px;
  border-radius:var(--r-xl);
  background:conic-gradient(from var(--angle), #0ea5e9, #8b5cf6, #ec4899, #0ea5e9);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  padding:1px;
  animation:borderRotate 6s linear infinite;
  opacity:0.5;
}
@property --angle { syntax:'<angle>'; initial-value:0deg; inherits:false; }
@keyframes borderRotate { to { --angle:360deg; } }

.pricing-glow {
  position:absolute; top:-80px; right:-80px;
  width:280px; height:280px;
  background:radial-gradient(circle, rgba(14,165,233,0.14), transparent 70%);
  pointer-events:none;
}
.pricing-top-badge {
  display:inline-block; font-size:0.68rem; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:#fff; padding:6px 14px; background:var(--grad); border-radius:100px; margin-bottom:24px;
}
.pricing-head h3 { font-size:1.55rem; font-weight:700; margin-bottom:18px; }
.price-display   { display:flex; align-items:flex-start; gap:4px; margin-bottom:10px; }
.price-cur  { font-family:var(--fh); font-size:2.8rem; font-weight:700; color:var(--blue); line-height:1.4; padding-top:10px; }
.price-num  {
  font-family:var(--fh); font-size:8rem; font-weight:800; line-height:1;
  background:var(--grad-text); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  filter:drop-shadow(0 0 50px rgba(14,165,233,0.65)) drop-shadow(0 0 100px rgba(139,92,246,0.35));
}
.price-term { font-size:0.88rem; color:var(--tx2); align-self:flex-end; padding-bottom:10px; }
.price-sub  { font-size:0.93rem; color:var(--tx2); margin-bottom:32px; }

.pricing-divider { height:1px; background:var(--border); margin-bottom:30px; }

.pricing-list { display:flex; flex-direction:column; gap:14px; margin-bottom:40px; }
.pricing-list li { display:flex; align-items:center; gap:12px; font-size:0.93rem; color:var(--tx2); }
.pricing-list li svg { width:17px; height:17px; color:var(--blue); flex-shrink:0; }
.pricing-list li strong { color:var(--tx1); font-weight:600; }
.pricing-list .feature-highlight { color:var(--tx1); }
.pricing-list .feature-highlight svg { color:var(--green); filter:drop-shadow(0 0 5px rgba(34,197,94,0.6)); }

.pricing-btn   { width:100%; justify-content:center; padding:17px; font-size:1rem; border-radius:var(--r-md); margin-bottom:16px; }
.pricing-note  { font-size:0.78rem; color:var(--tx3); text-align:center; }

.pricing-aside { display:flex; flex-direction:column; gap:18px; }
.aside-card { padding:26px 22px; border-radius:var(--r-lg); border:1px solid; }
.aside-domain    { background:rgba(14,165,233,0.04);  border-color:rgba(14,165,233,0.2); }
.aside-guarantee { background:rgba(139,92,246,0.04); border-color:rgba(139,92,246,0.2); }
.aside-icon { font-size:2rem; margin-bottom:12px; }
.aside-icon-wrap { width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:rgba(139,92,246,0.1); border-radius:10px; color:var(--violet-l); margin-bottom:12px; }
.aside-icon-wrap svg { width:21px; height:21px; }
.aside-card h4 { font-size:0.95rem; font-weight:600; margin-bottom:8px; }
.aside-card p  { font-size:0.83rem; color:var(--tx2); line-height:1.65; }

/* ═════════════════════════════════════════
   CONTACT
═════════════════════════════════════════ */
.contact { padding:130px 0; }
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:stretch; position:relative; z-index:2; }

.contact-card {
  position:relative; padding:48px 40px;
  background:rgba(255,255,255,0.055);
  border-radius:var(--r-xl); overflow:hidden;
  backdrop-filter:blur(24px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 40px 80px rgba(0,0,0,0.2);
}
.contact-border-glow {
  position:absolute; inset:-1px;
  border-radius:var(--r-xl);
  background:linear-gradient(135deg, rgba(14,165,233,0.25), rgba(139,92,246,0.15), rgba(14,165,233,0.1));
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  padding:1px;
}
.contact-glow { position:absolute; top:-100px; left:-100px; width:360px; height:360px; background:radial-gradient(circle, rgba(14,165,233,0.07), transparent 70%); pointer-events:none; }

.contact-person { display:flex; align-items:center; gap:20px; margin-bottom:32px; }
.person-avatar {
  width:70px; height:70px; border-radius:50%; background:var(--grad);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--fh); font-size:1.9rem; font-weight:700; color:#fff; flex-shrink:0;
  box-shadow:0 0 30px rgba(14,165,233,0.4);
}
.person-meta h3 { font-size:1.35rem; font-weight:700; margin-bottom:4px; }
.person-meta p  { font-size:0.83rem; color:var(--tx2); margin-bottom:10px; }
.avail-badge {
  display:inline-flex; align-items:center; gap:6px;
  font-size:0.72rem; font-weight:600; color:var(--green);
  padding:4px 10px; background:rgba(34,197,94,0.07); border:1px solid rgba(34,197,94,0.2); border-radius:100px;
}
.avail-dot { width:6px; height:6px; background:var(--green); border-radius:50%; animation:badgeBlink 2s ease-in-out infinite; }

.contact-divider { height:1px; background:var(--border); margin-bottom:28px; }

.whatsapp-btn {
  display:flex; align-items:center; gap:14px; padding:18px 20px;
  background:rgba(37,211,102,0.05); border:1px solid rgba(37,211,102,0.2);
  border-radius:var(--r-md); transition:var(--t); margin-bottom:22px; text-decoration:none;
}
.whatsapp-btn:hover { background:rgba(37,211,102,0.09); border-color:rgba(37,211,102,0.45); transform:translateY(-2px); box-shadow:0 8px 32px rgba(37,211,102,0.12); }
.wa-icon { width:44px; height:44px; display:flex; align-items:center; justify-content:center; background:rgba(37,211,102,0.12); border-radius:12px; color:#25d366; flex-shrink:0; }
.wa-icon svg { width:22px; height:22px; }
.wa-text { flex:1; display:flex; flex-direction:column; min-width:0; }
.wa-label  { font-size:0.7rem; color:var(--tx3); text-transform:uppercase; letter-spacing:1px; margin-bottom:2px; white-space:nowrap; }
.wa-number { font-size:1rem; font-weight:600; color:var(--tx1); white-space:nowrap; }
.wa-arrow  { width:18px; height:18px; flex-shrink:0; color:var(--tx3); }

.contact-note { font-size:0.83rem; color:var(--tx2); line-height:1.7; }

.contact-right { display:flex; flex-direction:column; gap:14px; }
.contact-feat {
  display:flex; align-items:flex-start; gap:16px; padding:20px;
  background:rgba(255,255,255,0.03); border:1px solid var(--border);
  border-radius:var(--r-md); backdrop-filter:blur(8px); transition:var(--t);
}
.contact-feat:hover { background:rgba(255,255,255,0.055); border-color:var(--border-h); }
.feat-icon { width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:rgba(14,165,233,0.08); border-radius:10px; color:var(--blue); flex-shrink:0; }
.feat-icon svg { width:19px; height:19px; }
.contact-feat h4 { font-size:0.9rem; font-weight:600; margin-bottom:3px; }
.contact-feat p  { font-size:0.8rem; color:var(--tx2); line-height:1.6; }
.contact-quote { padding:22px; background:rgba(139,92,246,0.05); border:1px solid rgba(139,92,246,0.15); border-radius:var(--r-md); border-left:3px solid var(--violet); margin-top:6px; }
.contact-quote blockquote { font-size:0.88rem; font-style:italic; color:var(--tx2); line-height:1.75; margin-bottom:10px; }
.contact-quote cite { font-size:0.76rem; color:var(--violet-l); font-style:normal; font-weight:500; }

/* ═════════════════════════════════════════
   FOOTER
═════════════════════════════════════════ */
.footer { padding:80px 0 40px; border-top:1px solid var(--border); position:relative; overflow:hidden; }
.footer-top-glow {
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:700px; height:200px;
  background:radial-gradient(ellipse, rgba(14,165,233,0.06), transparent 70%);
  pointer-events:none;
}
.footer-body { display:grid; grid-template-columns:1fr auto; gap:80px; margin-bottom:52px; }
.footer-logo { font-family:var(--fh); font-size:1.7rem; font-weight:800; display:block; margin-bottom:14px; }
.footer-brand p { font-size:0.88rem; color:var(--tx2); max-width:280px; line-height:1.75; margin-bottom:20px; }
.footer-wa { display:inline-flex; align-items:center; gap:8px; color:#25d366; font-size:0.88rem; font-weight:500; transition:var(--t); }
.footer-wa:hover { opacity:0.75; }
.footer-links { display:flex; gap:64px; }
.footer-col h4 { font-size:0.72rem; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--tx3); margin-bottom:20px; }
.footer-col    { display:flex; flex-direction:column; }
.footer-col a  { font-size:0.88rem; color:var(--tx2); padding:5px 0; transition:var(--t); }
.footer-col a:hover { color:var(--blue); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:28px; border-top:1px solid var(--border); }
.footer-bottom p { font-size:0.8rem; color:var(--tx3); }

/* ═════════════════════════════════════════
   REVEAL ANIMATIONS
═════════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(28px); transition:opacity 0.75s var(--ease), transform 0.75s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ═════════════════════════════════════════
   HOW IT WORKS
═════════════════════════════════════════ */
.process { padding:130px 0; }

.process-steps {
  display:flex; align-items:flex-start; justify-content:center;
  position:relative; z-index:2;
}

.process-step {
  flex:1; max-width:300px; text-align:center;
  padding:44px 28px 36px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  position:relative; transition:var(--t);
}
.process-step:hover {
  background:rgba(255,255,255,0.07);
  border-color:rgba(0,212,255,0.22);
  transform:translateY(-5px);
  box-shadow:0 20px 50px rgba(0,0,0,0.3), 0 0 40px rgba(0,212,255,0.06);
}

.step-number {
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  font-family:var(--fh); font-size:0.68rem; font-weight:700; letter-spacing:2px;
  color:var(--blue); background:var(--bg);
  border:1px solid rgba(0,212,255,0.25); padding:4px 12px; border-radius:100px;
}

.step-icon {
  width:56px; height:56px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,212,255,0.07); border:1px solid rgba(0,212,255,0.18);
  border-radius:16px; color:var(--blue);
  margin:0 auto 20px; transition:var(--t);
}
.process-step:hover .step-icon { transform:scale(1.1) rotate(-4deg); box-shadow:0 0 20px rgba(0,212,255,0.25); }
.step-icon svg { width:24px; height:24px; }

.process-step h3 { font-size:1.1rem; font-weight:600; margin-bottom:12px; }
.process-step p  { font-size:0.87rem; color:var(--tx2); line-height:1.75; }

.process-connector {
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; width:80px; padding-top:90px;
}
.process-connector svg { width:80px; }

/* ═════════════════════════════════════════
   TESTIMONIALS
═════════════════════════════════════════ */
.testimonials { padding:130px 0; }

.testi-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px;
}

.testi-card {
  position:relative; display:flex; flex-direction:column;
  padding:36px 30px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition:var(--t); backdrop-filter:blur(18px);
}
.testi-card:hover {
  background:rgba(255,255,255,0.07);
  border-color:rgba(139,92,246,0.25);
  transform:translateY(-5px);
  box-shadow:0 20px 50px rgba(0,0,0,0.3), 0 0 40px rgba(139,92,246,0.07);
}

.testi-stars {
  color:#f59e0b; font-size:0.95rem; letter-spacing:3px; margin-bottom:18px;
}

.testi-card blockquote {
  font-size:0.9rem; color:var(--tx2); line-height:1.8; font-style:italic;
  flex:1; margin-bottom:24px; padding-left:16px;
  border-left:2px solid rgba(139,92,246,0.4);
}

.testi-author { display:flex; align-items:center; gap:14px; }

.testi-avatar {
  width:42px; height:42px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, rgba(0,212,255,0.15), rgba(139,92,246,0.2));
  border:1px solid rgba(139,92,246,0.3);
  font-family:var(--fh); font-weight:700; font-size:1rem;
  color:var(--violet-l); flex-shrink:0;
}
.testi-author strong { display:block; font-size:0.9rem; font-weight:600; color:var(--tx1); }
.testi-author span   { font-size:0.78rem; color:var(--tx3); }

/* ═════════════════════════════════════════
   FAQ
═════════════════════════════════════════ */
.faq { padding:130px 0; }

.faq-list {
  max-width:780px; margin:0 auto;
  display:flex; flex-direction:column; gap:10px;
}

.faq-item {
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:var(--r-md); overflow:hidden;
  transition:border-color 0.3s ease;
}
.faq-item.open { border-color:rgba(0,212,255,0.22); }

.faq-q {
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:20px 24px; background:none; border:none;
  color:var(--tx1); font-family:var(--fh); font-size:0.95rem; font-weight:600;
  cursor:pointer; text-align:left; transition:color 0.3s ease;
}
.faq-q:hover { color:var(--blue-l); }
.faq-item.open .faq-q { color:var(--blue-l); }

.faq-chevron { flex-shrink:0; transition:transform 0.3s var(--ease); color:var(--tx3); }
.faq-item.open .faq-chevron { transform:rotate(180deg); color:var(--blue); }

.faq-a {
  max-height:0; overflow:hidden;
  transition:max-height 0.38s var(--ease);
}
.faq-item.open .faq-a { max-height:200px; }
.faq-a p {
  padding:0 24px 22px;
  font-size:0.88rem; color:var(--tx2); line-height:1.8;
}

/* ═════════════════════════════════════════
   RESPONSIVE 1024px
═════════════════════════════════════════ */
@media (max-width:1024px) {
  .services-grid  { grid-template-columns:repeat(2,1fr); }
  .why-grid       { grid-template-columns:repeat(3,1fr); }
  .testi-grid     { grid-template-columns:repeat(3,1fr); }
  .pricing-services-grid { grid-template-columns:repeat(2,1fr); }
  .showcase-scene { grid-template-columns:1fr; gap:44px; }
  .pricing-layout { grid-template-columns:1fr; max-width:580px; }
  .pricing-aside  { flex-direction:row; }
  .aside-card     { flex:1; }
  .deco-code-main { font-size:12rem; opacity:0.6; }
  .process-connector { width:50px; }
  .process-connector svg { width:50px; }
}

/* ═════════════════════════════════════════
   RESPONSIVE 768px
═════════════════════════════════════════ */
@media (max-width:768px) {
  .nav-links {
    position:fixed; inset:0;
    background:rgba(4,4,10,0.97); backdrop-filter:blur(28px);
    flex-direction:column; justify-content:center; align-items:center; gap:6px;
    transform:translateX(100%); transition:transform 0.35s var(--ease); z-index:999;
  }
  .nav-links.open { transform:translateX(0); }
  .nav-links a    { font-size:1.15rem; padding:14px 32px; }
  .hamburger      { display:flex; }

  .hero-title   { letter-spacing:-1.5px; }
  .br-hide      { display:none; }
  .hero-stats   { gap:20px; padding:18px 24px; flex-wrap:wrap; }
  .stat-divider { display:none; }

  .services-grid  { grid-template-columns:1fr; }
  .testi-grid     { grid-template-columns:1fr; }
  .pricing-services-grid { grid-template-columns:1fr; }
  .why-grid       { grid-template-columns:repeat(2,1fr); }
  .contact-layout { grid-template-columns:1fr; }
  .process-steps  { flex-direction:column; align-items:center; gap:36px; }
  .process-connector { width:auto; height:30px; padding-top:0; transform:rotate(90deg); }

  .footer-body   { grid-template-columns:1fr; gap:44px; }
  .footer-links  { gap:36px; }
  .footer-bottom { flex-direction:column; gap:8px; text-align:center; }

  .pricing-aside  { flex-direction:column; }

  .deco-glyph { display:none; }
  .geo-float  { display:none; }

  .wa-fab { width:54px; height:54px; bottom:20px; right:20px; }
}

/* ═════════════════════════════════════════
   RESPONSIVE 480px
═════════════════════════════════════════ */
@media (max-width:480px) {
  .why-grid     { grid-template-columns:1fr; }
  .hero-buttons { flex-direction:column; align-items:stretch; }
  .hero-buttons .btn { justify-content:center; }
  .pricing-card   { padding:36px 24px; }
  .contact-card   { padding:36px 24px; }
  .hero-stats     { width:100%; }
  .showcase-geo   { display:none; }
}

/* ═════════════════════════════════════════
   CV PROMO LIGHTBOX
═════════════════════════════════════════ */
.lb-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  background: rgba(4,4,10,0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s var(--ease);
}
.lb-overlay.lb-open {
  opacity: 1;
  pointer-events: all;
}

.lb-card {
  position: relative;
  z-index: 100001;
  display: grid;
  grid-template-columns: 1fr 1fr;
  max-width: 880px;
  width: 100%;
  background: rgba(8,8,18,0.97);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: 0 40px 120px rgba(0,0,0,0.7), 0 0 0 1px rgba(14,165,233,0.1), 0 0 80px rgba(14,165,233,0.06) inset;
  transform: translateY(28px) scale(0.96);
  transition: transform 0.45s var(--ease-spring);
}
.lb-overlay.lb-open .lb-card {
  transform: translateY(0) scale(1);
}

/* Animated top border */
.lb-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad);
  z-index: 2;
}

.lb-close {
  position: absolute;
  top: 16px; right: 16px;
  z-index: 10;
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.05);
  color: var(--tx2);
  font-size: 1.3rem;
  line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: var(--t);
  backdrop-filter: blur(8px);
}
.lb-close:hover { background: rgba(255,255,255,0.12); color: var(--tx1); border-color: rgba(255,255,255,0.2); }

/* ─── Left side (mockup) ─── */
.lb-left {
  background: linear-gradient(145deg, rgba(14,165,233,0.06), rgba(139,92,246,0.06));
  border-right: 1px solid rgba(255,255,255,0.07);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  position: relative;
  overflow: hidden;
}
.lb-left::before {
  content: '';
  position: absolute;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(14,165,233,0.12), transparent 70%);
  top: -80px; left: -60px;
  pointer-events: none;
}

.lb-mock-browser {
  width: 100%;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 30px rgba(14,165,233,0.1);
  animation: lbFloat 5s ease-in-out infinite;
}
@keyframes lbFloat {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

.lb-browser-bar {
  background: rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.lbb-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.lbb-url {
  flex: 1;
  font-size: 0.62rem;
  color: var(--tx3);
  font-family: var(--fb);
  margin-left: 8px;
  padding: 3px 8px;
  background: rgba(255,255,255,0.04);
  border-radius: 4px;
}

.lb-mock-site {
  background: linear-gradient(160deg, #05050e, #0b0b1a);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.lb-mock-header { display: flex; gap: 12px; align-items: center; }
.lb-mock-avatar {
  width: 48px; height: 48px; border-radius: 50%; flex-shrink: 0;
  background: var(--grad);
  box-shadow: 0 0 20px rgba(14,165,233,0.4);
}
.lb-mock-info { display: flex; flex-direction: column; gap: 5px; flex: 1; }
.lb-mock-line { height: 5px; background: rgba(255,255,255,0.07); border-radius: 3px; }
.lml-w60 { width: 60%; } .lml-w40 { width: 40%; } .lml-w50 { width: 50%; }
.lml-bright { background: rgba(255,255,255,0.18); }
.lb-mock-btns { display: flex; gap: 6px; margin-top: 3px; }
.lmb-primary  { width: 48px; height: 14px; background: var(--grad); border-radius: 4px; }
.lmb-secondary { width: 36px; height: 14px; background: rgba(255,255,255,0.06); border-radius: 4px; border: 1px solid rgba(255,255,255,0.1); }
.lb-mock-skills { display: flex; gap: 5px; flex-wrap: wrap; }
.lb-skill-tag { height: 16px; width: 44px; background: rgba(14,165,233,0.1); border: 1px solid rgba(14,165,233,0.2); border-radius: 20px; }
.lb-skill-tag:nth-child(2) { width: 52px; background: rgba(139,92,246,0.1); border-color: rgba(139,92,246,0.2); }
.lb-skill-tag:nth-child(3) { width: 38px; }
.lb-skill-tag:nth-child(4) { width: 60px; background: rgba(236,72,153,0.08); border-color: rgba(236,72,153,0.2); }
.lb-mock-cards { display: flex; gap: 6px; }
.lb-mock-card { flex: 1; height: 32px; background: rgba(255,255,255,0.04); border-radius: 5px; border: 1px solid rgba(255,255,255,0.06); }
.lmc-glow { background: linear-gradient(135deg, rgba(14,165,233,0.15), rgba(139,92,246,0.12)); border-color: rgba(14,165,233,0.2); }

.lb-mock-label {
  font-size: 0.7rem;
  color: var(--tx3);
  font-style: italic;
  letter-spacing: 0.5px;
}

/* ─── Right side (offer) ─── */
.lb-right {
  padding: 40px 36px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
}
.lb-right::before {
  content: '';
  position: absolute;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(139,92,246,0.1), transparent 70%);
  bottom: -60px; right: -60px;
  pointer-events: none;
}

.lb-badge-row { display: flex; gap: 8px; flex-wrap: wrap; }
.lb-badge {
  font-size: 0.68rem; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  padding: 5px 12px; border-radius: 100px;
}
.lb-badge-fire { background: rgba(236,72,153,0.12); border: 1px solid rgba(236,72,153,0.25); color: var(--pink); }
.lb-badge-timer {
  background: rgba(14,165,233,0.08); border: 1px solid rgba(14,165,233,0.2); color: var(--blue);
  font-size: 0.68rem;
}
.lb-badge-timer strong { font-weight: 800; }

.lb-title {
  font-family: var(--fh);
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 800;
  line-height: 1.15;
  margin: 0;
}
.lb-title-grad {
  background: var(--grad-text);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  filter: drop-shadow(0 0 24px rgba(14,165,233,0.5));
}

.lb-desc { font-size: 0.87rem; color: var(--tx2); line-height: 1.7; margin: 0; }

.lb-price-block {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--r-md);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.lb-price-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.lb-cur {
  font-family: var(--fh); font-size: 1.6rem; font-weight: 700;
  color: var(--blue); line-height: 1;
}
.lb-num {
  font-family: var(--fh); font-size: 3.6rem; font-weight: 800; line-height: 1;
  background: var(--grad-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  filter: drop-shadow(0 0 30px rgba(14,165,233,0.5));
}
.lb-separator { font-size: 1.4rem; color: var(--tx3); font-weight: 300; }
.lb-usd { font-family: var(--fh); font-size: 1.4rem; font-weight: 700; color: var(--tx2); }
.lb-usd-note { font-size: 0.75rem; font-weight: 500; color: var(--tx3); vertical-align: super; }
.lb-price-tag { font-size: 0.72rem; color: var(--tx3); letter-spacing: 0.5px; }

.lb-features {
  display: flex; flex-direction: column; gap: 10px;
  margin: 0; padding: 0; list-style: none;
}
.lb-features li {
  display: flex; align-items: center; gap: 10px;
  font-size: 0.87rem; color: var(--tx2);
}
.lb-features li svg { width: 15px; height: 15px; color: var(--green); flex-shrink: 0; filter: drop-shadow(0 0 4px rgba(34,197,94,0.6)); }

.lb-cta {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 16px 24px;
  background: linear-gradient(135deg, #25d366, #128c7e);
  color: #fff; font-weight: 700; font-size: 0.95rem; font-family: var(--fb);
  border-radius: var(--r-md);
  box-shadow: 0 4px 28px rgba(37,211,102,0.4), inset 0 1px 0 rgba(255,255,255,0.2);
  transition: transform 0.25s var(--ease-spring), box-shadow 0.25s ease;
  position: relative; overflow: hidden;
}
.lb-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 40px rgba(37,211,102,0.55), inset 0 1px 0 rgba(255,255,255,0.2); }

.lb-note { font-size: 0.75rem; color: var(--tx3); text-align: center; margin: -8px 0 0; }

/* ─── Responsive lightbox ─── */
@media (max-width: 680px) {
  .lb-card { grid-template-columns: 1fr; max-height: 90vh; overflow-y: auto; }
  .lb-left  { display: none; }
  .lb-right { padding: 32px 24px; }
}
