/* ================================================
   DREAMSOFT GAME STUDIO — DARK CYBERPUNK REDESIGN
   Aesthetic: Cyberpunk 2077 × Riot Games × Blizzard
   Palette: Neon Purple + Electric Cyan on Void Black
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600;700;800;900&family=Barlow+Condensed:wght@300;400;500;600;700;800&family=Barlow:wght@300;400;500;600&display=swap');

/* ── Design Tokens ──────────────────────────────── */
:root {
  --void:     #050510;
  --deep:     #080820;
  --surface:  #0D0B28;
  --card:     rgba(120,60,220,0.06);
  --card-hover: rgba(0,229,255,0.05);

  --neon:     #9B30FF;
  --neon-mid: #C77DFF;
  --neon-dim: rgba(155,48,255,0.15);
  --neon-glow: 0 0 40px rgba(155,48,255,0.45), 0 0 90px rgba(155,48,255,0.15);

  --cyan:     #00E5FF;
  --cyan-mid: #40F0FF;
  --cyan-dim: rgba(0,229,255,0.08);
  --cyan-glow: 0 0 30px rgba(0,229,255,0.4), 0 0 70px rgba(0,229,255,0.12);

  --border:      rgba(155,48,255,0.2);
  --border-cyan: rgba(0,229,255,0.25);

  --bright: #EDE0FF;
  --mid:    #8B7BA8;
  --dim:    #3A2E55;

  --tx: all 0.3s cubic-bezier(0.4,0,0.2,1);

  --clip-btn:     polygon(12px 0%, 100% 0%, calc(100% - 12px) 100%, 0% 100%);
  --clip-card-tl: polygon(0 0, calc(100% - 24px) 0, 100% 24px, 100% 100%, 0 100%);
}

/* ── Global ─────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

::selection      { background-color: var(--neon); color: #fff; }
::-moz-selection { background-color: var(--neon); color: #fff; }

body {
  font-family: 'Barlow', sans-serif !important;
  background: var(--void) !important;
  color: var(--bright) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Barlow Condensed', sans-serif !important;
  color: var(--bright) !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

p, .text {
  color: var(--mid) !important;
  font-family: 'Barlow', sans-serif !important;
  font-size: 0.9375rem !important;
  line-height: 1.75 !important;
  text-transform: none !important;
}

a { color: var(--neon) !important; text-decoration: none; transition: var(--tx); }
a:hover { color: var(--cyan) !important; }

input, button, select, textarea {
  font-family: 'Barlow', sans-serif !important;
}

/* ── Scanline texture ───────────────────────────── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(155,48,255,0.012) 2px,
    rgba(155,48,255,0.012) 4px
  );
  pointer-events: none;
  z-index: 0;
}

/* Cross-grid dot pattern overlay */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%239B30FF' fill-opacity='0.018'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.page-wrapper { position: relative; z-index: 1; }
.preloader   { background: var(--void) !important; }

/* ── Header ─────────────────────────────────────── */
.site-header {
  background: transparent !important;
  background-image: none !important;
  padding: 1.25rem 0 !important;
  position: fixed !important;
  inset: auto 0 auto 0;
  top: 0 !important;
  z-index: 9999;
  transition: background 0.4s ease, padding 0.4s ease, box-shadow 0.4s ease;
  border-bottom: 1px solid transparent;
  width: 100% !important;
}

.site-header::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--neon), var(--cyan), var(--neon), transparent);
  opacity: 0;
  transition: opacity 0.4s ease;
}

.site-header.is-scrolled {
  background: rgba(5,5,16,0.95) !important;
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  padding: 0.75rem 0 !important;
  box-shadow: 0 8px 48px rgba(0,0,0,0.8), 0 0 0 1px rgba(155,48,255,0.1);
}

.site-header.is-scrolled::after { opacity: 1; }

.site-header-inner {
  max-width: 1340px !important;
  margin: 0 auto !important;
  padding: 0 2rem !important;
  display: flex !important;
  align-items: center !important;
}

.site-branding { flex-shrink: 0; }
.site-branding a { display: inline-block !important; }
.site-branding img {
  height: 42px !important;
  width: auto !important;
  display: block !important;
  max-width: none !important;
  transition: var(--tx);
  filter: drop-shadow(0 0 12px rgba(155,48,255,0.5));
}

.site-branding img:hover {
  filter: drop-shadow(0 0 18px rgba(0,229,255,0.6));
}

/* ── Desktop Nav ────────────────────────────────── */
.main-navigation {
  margin-left: 3rem !important;
  margin-right: auto !important;
}

.main-navigation .menu {
  display: flex !important;
  flex-wrap: nowrap !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0;
}

.main-navigation .menu li { flex: 0 0 auto !important; }

.main-navigation .menu a {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(237,224,255,0.65) !important;
  padding: 0.5rem 1.125rem !important;
  display: block;
  position: relative;
  transition: var(--tx);
}

/* Cyan underline on hover */
.main-navigation .menu a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1.125rem;
  right: 1.125rem;
  height: 1.5px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.3s ease;
}

.main-navigation .menu a:hover,
.main-navigation .menu .current a {
  color: var(--cyan) !important;
}

.main-navigation .menu a:hover::after,
.main-navigation .menu .current a::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* ── Header Social Icons ────────────────────────── */
.site-header__toggles {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem;
  margin-left: 1.5rem;
}

.site-header__toggles a {
  color: rgba(237,224,255,0.45) !important;
  font-size: 12px !important;
  width: 32px;
  height: 32px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 2px;
  transition: var(--tx);
}

.site-header__toggles a:hover {
  color: var(--cyan) !important;
  border-color: var(--border-cyan) !important;
  background: var(--cyan-dim);
  box-shadow: var(--cyan-glow);
}

/* ── Hamburger Button ───────────────────────────── */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: 2px;
  cursor: pointer;
  padding: 8px;
  margin-left: 1rem;
  flex-shrink: 0;
  transition: var(--tx);
}

.nav-toggle span {
  display: block;
  height: 1.5px;
  background: var(--mid);
  border-radius: 1px;
  transition: var(--tx);
}

.nav-toggle:hover {
  border-color: var(--border-cyan) !important;
  background: var(--cyan-dim) !important;
}

.nav-toggle:hover span { background: var(--cyan); }

/* ── Mobile Nav Drawer ──────────────────────────── */
.mobile-nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(5,5,16,0.85);
  z-index: 10000;
  backdrop-filter: blur(6px);
  opacity: 0;
  transition: opacity 0.35s ease;
}

.mobile-nav-overlay.open { display: block; opacity: 1; }

.mobile-nav-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(360px, 90vw);
  height: 100vh;
  background: var(--deep);
  border-left: 1px solid var(--border);
  z-index: 10001;
  padding: 2rem 1.75rem;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.mobile-nav-drawer.open { transform: translateX(0); }

/* Neon edge glow on left */
.mobile-nav-drawer::before {
  content: '';
  position: absolute;
  top: 0; bottom: 0; left: -1px;
  width: 1px;
  background: linear-gradient(to bottom, transparent, var(--neon), var(--cyan), transparent);
}

.mobile-nav-close {
  align-self: flex-end;
  width: 36px;
  height: 36px;
  background: none !important;
  border: 1px solid var(--border) !important;
  border-radius: 2px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--mid);
  font-size: 1.25rem;
  transition: var(--tx);
  margin-bottom: 2rem;
}

.mobile-nav-close:hover {
  border-color: var(--neon) !important;
  color: var(--neon);
  box-shadow: var(--neon-glow);
}

.mobile-nav-logo {
  margin-bottom: 2rem;
}

.mobile-nav-logo img {
  height: 40px;
  width: auto;
}

.mobile-nav-menu {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  flex: 1;
}

.mobile-nav-menu li + li { border-top: 1px solid rgba(155,48,255,0.1); }

.mobile-nav-menu a {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(237,224,255,0.7) !important;
  padding: 1rem 0 !important;
  display: flex !important;
  align-items: center;
  gap: 10px;
  transition: var(--tx);
}

.mobile-nav-menu a::before {
  content: '';
  display: block;
  width: 16px;
  height: 1.5px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
  flex-shrink: 0;
  opacity: 0;
  transform: scaleX(0);
  transition: var(--tx);
}

.mobile-nav-menu a:hover,
.mobile-nav-menu .current a {
  color: var(--cyan) !important;
  padding-left: 0.5rem !important;
}

.mobile-nav-menu a:hover::before,
.mobile-nav-menu .current a::before {
  opacity: 1;
  transform: scaleX(1);
}

.mobile-nav-cta {
  background: linear-gradient(135deg, var(--neon), #6A1ADB) !important;
  clip-path: var(--clip-btn);
  color: #fff !important;
  padding: 0.6rem 1rem !important;
  display: inline-block !important;
  margin-top: 0.5rem;
}

.mobile-nav-cta:hover {
  color: #fff !important;
  padding-left: 0.5rem !important;
  box-shadow: var(--neon-glow);
}

.mobile-nav-cta::before { display: none !important; }

/* Hamburger → X animation when open */
.nav-toggle.is-active span:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
  background: var(--cyan);
}
.nav-toggle.is-active span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.nav-toggle.is-active span:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
  background: var(--cyan);
}

.mobile-nav-socials {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 0.5rem;
}

.mobile-nav-socials a {
  width: 36px !important;
  height: 36px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border) !important;
  border-radius: 2px;
  color: var(--mid) !important;
  font-size: 12px !important;
  transition: var(--tx);
}

.mobile-nav-socials a:hover {
  color: var(--cyan) !important;
  border-color: var(--border-cyan) !important;
  background: var(--cyan-dim);
  box-shadow: var(--cyan-glow);
}

/* ── Hero Banner ────────────────────────────────── */
.banner-section {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  background:
    /* Bottom-centre neon heat-rise */
    radial-gradient(ellipse 110% 55% at 50% 115%, rgba(155,48,255,0.09) 0%, transparent 55%),
    /* Top-centre cyan cold breath */
    radial-gradient(ellipse 70%  35% at 50%  -8%, rgba(0,229,255,0.05)  0%, transparent 50%),
    var(--void);
}

/* Neon purple orb top-left */
.banner-section::before {
  content: '';
  position: absolute;
  top: -25vh; left: -20vw;
  width: 85vw; height: 85vw;
  background: radial-gradient(
    circle,
    rgba(155,48,255,0.10) 0%,
    rgba(155,48,255,0.04) 35%,
    transparent 65%
  );
  border-radius: 50%;
  animation: orb-neon 22s ease-in-out infinite;
  pointer-events: none;
}

/* Cyan orb bottom-right */
.banner-section::after {
  content: '';
  position: absolute;
  bottom: -20vh; right: -15vw;
  width: 60vw; height: 60vw;
  background: radial-gradient(
    circle,
    rgba(0,229,255,0.07) 0%,
    rgba(155,48,255,0.04) 40%,
    transparent 65%
  );
  border-radius: 50%;
  animation: orb-cyan 30s ease-in-out infinite;
  pointer-events: none;
}

@keyframes orb-neon {
  0%,100% { transform: translate(0,0)    scale(1);    opacity: 0.8;  }
  40%     { transform: translate(5%,4%)  scale(1.1);  opacity: 1;    }
  70%     { transform: translate(-3%,6%) scale(0.93); opacity: 0.65; }
}

@keyframes orb-cyan {
  0%,100% { transform: translate(0,0)     scale(1);    opacity: 0.85; }
  35%     { transform: translate(-5%,-5%) scale(1.12); opacity: 1;    }
  65%     { transform: translate(4%,-3%)  scale(0.92); opacity: 0.7;  }
}

/* HUD grid lines */
.ds-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(155,48,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155,48,255,0.025) 1px, transparent 1px);
  background-size: 72px 72px;
  pointer-events: none;
  z-index: 1;
}

/* Diagonal speed lines — slow background parallax drift */
.ds-hero-grid::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    -55deg,
    transparent               0,
    transparent             120px,
    rgba(155,48,255,0.016)  120px,
    rgba(155,48,255,0.016)  121px
  );
  background-size: 170px 170px;
  animation: streak-drift 32s linear infinite;
  pointer-events: none;
  z-index: 0;
}

/* Horizontal scanline sweep */
.ds-hero-grid::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(0,229,255,0.02) 50%,
    transparent 100%
  );
  animation: scan-sweep 6s linear infinite;
  pointer-events: none;
}

@keyframes scan-sweep {
  0%   { transform: translateY(-100%); }
  100% { transform: translateY(100%); }
}

/* Carousel */
.banner-carousel .slide-item {
  background-size: cover !important;
  background-position: center center !important;
  min-height: 100vh !important;
  display: flex !important;
  align-items: center !important;
  position: relative;
}

/* Cinematic gradient */
.banner-carousel .slide-item::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(5,5,16,0.96) 0%, rgba(5,5,16,0.72) 55%, rgba(5,5,16,0.35) 100%),
    linear-gradient(0deg, rgba(5,5,16,0.65) 0%, transparent 55%);
}

.banner-carousel .slide-item .container {
  position: relative;
  z-index: 3;
  padding-top: 120px;
  padding-bottom: 60px;
}

.slide-item .content-box { max-width: 840px; }

/* Eyebrow */
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--cyan) !important;
  margin-bottom: 1.5rem;
  opacity: 0;
  animation: rise 0.9s ease 0.2s forwards;
}

.hero-eyebrow::before {
  content: '';
  display: block;
  width: 30px;
  height: 1.5px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
}

/* Hero title */
.hero-title {
  font-family: 'Orbitron', sans-serif !important;
  font-size: clamp(3.5rem, 8.5vw, 8.5rem) !important;
  font-weight: 900 !important;
  line-height: 0.9 !important;
  letter-spacing: -0.02em !important;
  color: var(--bright) !important;
  margin-bottom: 1.75rem !important;
  text-transform: uppercase !important;
  opacity: 0;
  text-shadow: 2px 0 0 rgba(155,48,255,0.35), -2px 0 0 rgba(0,229,255,0.25);
  animation: rise 0.9s ease 0.4s forwards, glitch 9s ease-in-out 3s infinite;
}

.hero-title em {
  font-style: normal;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
}

@keyframes glitch {
  0%,90%,100% { text-shadow: 2px 0 0 rgba(155,48,255,0.35), -2px 0 0 rgba(0,229,255,0.25); }
  91%  { text-shadow: 4px 2px 0 rgba(155,48,255,0.6), -4px -2px 0 rgba(0,229,255,0.5); transform: skewX(-1.5deg); }
  93%  { text-shadow: -4px -2px 0 rgba(155,48,255,0.5), 4px 2px 0 rgba(0,229,255,0.4); transform: skewX(1.5deg); }
  95%  { text-shadow: 2px 0 0 rgba(155,48,255,0.35), -2px 0 0 rgba(0,229,255,0.25); transform: skewX(0); }
}

/* Hero description */
.hero-desc {
  font-size: 1.0625rem !important;
  color: rgba(139,123,168,0.9) !important;
  max-width: 520px;
  line-height: 1.75 !important;
  margin-bottom: 2.5rem !important;
  text-transform: none !important;
  opacity: 0;
  animation: rise 0.9s ease 0.65s forwards;
}

/* CTA group */
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
  opacity: 0;
  animation: rise 0.9s ease 0.85s forwards;
}

/* Scroll hint */
.hero-scroll-hint {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  opacity: 0;
  animation: rise 0.9s ease 1.1s forwards;
}

.hero-scroll-hint span {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.5625rem !important;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--dim) !important;
}

.scroll-needle {
  width: 1px;
  height: 44px;
  background: linear-gradient(to bottom, var(--neon), transparent);
  animation: needle-pulse 2.2s ease-in-out infinite;
}

@keyframes needle-pulse {
  0%       { transform: scaleY(0); transform-origin: top; opacity: 1; }
  50%      { transform: scaleY(1); transform-origin: top; opacity: 1; }
  50.001%  { transform: scaleY(1); transform-origin: bottom; opacity: 1; }
  100%     { transform: scaleY(0); transform-origin: bottom; opacity: 0; }
}

@keyframes rise {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Buttons ─────────────────────────────────────── */
.btn-glow {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  padding: 0.9375rem 2.5rem !important;
  background: linear-gradient(90deg, var(--neon), var(--neon-mid)) !important;
  color: #fff !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.15em;
  text-transform: uppercase !important;
  clip-path: var(--clip-btn);
  border: none !important;
  border-radius: 0 !important;
  box-shadow: var(--neon-glow);
  transition: var(--tx);
  position: relative;
}

.btn-glow:hover {
  background: linear-gradient(90deg, var(--neon-mid), var(--cyan)) !important;
  color: var(--void) !important;
  box-shadow: 0 0 60px rgba(155,48,255,0.55), 0 0 120px rgba(0,229,255,0.2);
  transform: translateY(-2px) scale(1.02);
}

.btn-ghost {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  padding: 0.9375rem 2.5rem !important;
  background: transparent !important;
  color: var(--bright) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.15em;
  text-transform: uppercase !important;
  clip-path: var(--clip-btn);
  border: 1px solid var(--border-cyan) !important;
  border-radius: 0 !important;
  transition: var(--tx);
}

.btn-ghost:hover {
  background: var(--cyan-dim) !important;
  border-color: var(--cyan) !important;
  color: var(--cyan) !important;
  box-shadow: var(--cyan-glow);
}

.theme-btn.btn-style-one,
.theme-btn.btn-style-three,
.btn-theme.btn-style-five {
  display: inline-flex !important;
  align-items: center;
  padding: 0.8125rem 2rem !important;
  background: linear-gradient(90deg, var(--neon), var(--neon-mid)) !important;
  color: #fff !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.15em;
  text-transform: uppercase !important;
  clip-path: var(--clip-btn) !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: var(--neon-glow);
  transition: var(--tx);
}

.theme-btn.btn-style-one:hover,
.theme-btn.btn-style-three:hover,
.btn-theme.btn-style-five:hover {
  background: linear-gradient(90deg, var(--neon-mid), var(--cyan)) !important;
  color: var(--void) !important;
  transform: translateY(-2px);
  box-shadow: 0 0 50px rgba(155,48,255,0.5), 0 0 100px rgba(0,229,255,0.15);
}

.theme-btn.btn-style-four {
  display: inline-flex !important;
  align-items: center;
  padding: 0.8125rem 2rem !important;
  background: transparent !important;
  color: var(--cyan) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.15em;
  text-transform: uppercase !important;
  clip-path: var(--clip-btn) !important;
  border-radius: 0 !important;
  border: 1px solid rgba(0,229,255,0.35) !important;
  transition: var(--tx);
}

.theme-btn.btn-style-four:hover {
  background: var(--cyan-dim) !important;
  color: var(--cyan) !important;
  box-shadow: var(--cyan-glow);
}

.purchased.btn-style-three {
  display: inline-flex !important;
  align-items: center;
  padding: 0.8125rem 2rem !important;
  background: linear-gradient(90deg, var(--neon), var(--neon-mid)) !important;
  color: #fff !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.15em;
  text-transform: uppercase !important;
  clip-path: var(--clip-btn) !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: var(--neon-glow);
  transition: var(--tx);
  width: 100%;
  justify-content: center;
  margin-top: 1.5rem;
}

.purchased.btn-style-three:hover {
  background: linear-gradient(90deg, var(--neon-mid), var(--cyan)) !important;
  color: var(--void) !important;
}

/* ── Section Eyebrow Labels ─────────────────────── */
.ds-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--cyan) !important;
  margin-bottom: 1rem;
}

.ds-label::before {
  content: '';
  display: block;
  width: 24px;
  height: 1.5px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
}

/* ── Section Titles ──────────────────────────────── */
.sec-title { margin-bottom: 3.5rem !important; }

.sec-title h2 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: clamp(2rem, 4vw, 3.5rem) !important;
  font-weight: 800 !important;
  color: var(--bright) !important;
  line-height: 1.05 !important;
  margin-bottom: 1rem !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

.sec-title .text {
  color: var(--mid) !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
  max-width: 580px;
  text-transform: none !important;
}

.sec-title.centered .text { margin: 0 auto; }
.sec-title .separater { display: none !important; }

/* ── Page Title (inner page banner) ────────────── */
.page-title {
  background: var(--surface) !important;
  background-image: none !important;
  padding: 9rem 0 4rem !important;
  position: relative;
  overflow: hidden;
}

/* Grid overlay */
.page-title::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(155,48,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155,48,255,0.04) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

/* Bottom gradient line */
.page-title::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.7;
}

/* Neon orb accent */
.page-title .container { position: relative; z-index: 1; }

.page-title .inner-container {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.page-title .title-box h1 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: clamp(2.25rem, 5vw, 4rem) !important;
  font-weight: 800 !important;
  color: var(--bright) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em;
  margin: 0 !important;
  line-height: 1 !important;
  position: relative;
}

/* Neon underline on h1 */
.page-title .title-box h1::after {
  content: '';
  display: block;
  width: 3rem;
  height: 2px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
  margin-top: 0.5rem;
}

.page-title .bread-crumb ul {
  display: flex !important;
  align-items: center;
  gap: 0.75rem;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.page-title .bread-crumb ul li {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mid) !important;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.page-title .bread-crumb ul li + li::before {
  content: '//';
  color: var(--neon);
  font-size: 0.75rem;
}

.page-title .bread-crumb ul li a {
  color: var(--dim) !important;
  transition: var(--tx);
}

.page-title .bread-crumb ul li a:hover { color: var(--cyan) !important; }

/* ── About / Mission Section ────────────────────── */
.our-mission-section {
  /* Bottom-left neon pool | top-centre purple breathe */
  background:
    radial-gradient(ellipse 40% 55% at -4%  100%, rgba(155,48,255,0.06)  0%, transparent 55%),
    radial-gradient(ellipse 55% 30% at  50%  -5%, rgba(155,48,255,0.045) 0%, transparent 50%),
    radial-gradient(ellipse 35% 50% at 105%  35%, rgba(0,229,255,0.035)  0%, transparent 50%),
    var(--deep) !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}

.our-mission-section .bg-loaded,
.our-mission-section .bg,
.our-mission-section .fill { display: none !important; }

/* Diagonal neon slash — slowly breathes */
.our-mission-section::before {
  content: '';
  position: absolute;
  top: -100px; right: 30%;
  width: 1px; height: 130%;
  background: linear-gradient(to bottom, transparent, var(--neon), transparent);
  transform: rotate(-18deg);
  opacity: 0.18;
  pointer-events: none;
  animation: slash-breathe 9s ease-in-out infinite;
}

/* Cyan glow top-right */
.our-mission-section::after {
  content: '';
  position: absolute;
  top: -10%; right: -5%;
  width: 40%; height: 75%;
  background: radial-gradient(ellipse, rgba(0,229,255,0.04) 0%, transparent 60%);
  pointer-events: none;
}

.our-mission-section .inner-box .text {
  font-size: 1rem !important;
  color: var(--mid) !important;
  line-height: 1.85 !important;
  text-transform: none !important;
}

.our-mission-section .link-box { margin-top: 2.5rem; }

/* Mission / Vision HUD cards */
.our-mission-section .innner-box { margin-bottom: 1.25rem !important; }

.our-mission-section .info-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-left: 3px solid var(--neon) !important;
  padding: 1.5rem 1.875rem !important;
  clip-path: var(--clip-card-tl);
  transition: var(--tx);
  position: relative;
}

.our-mission-section .info-box::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 24px; height: 24px;
  border-top: 1.5px solid var(--cyan);
  border-right: 1.5px solid var(--cyan);
  opacity: 0.4;
  pointer-events: none;
}

.our-mission-section .info-box:hover {
  background: var(--card-hover) !important;
  border-color: rgba(155,48,255,0.3) !important;
  border-left-color: var(--neon) !important;
  box-shadow: var(--neon-glow);
}

.our-mission-section .info-box h4 {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  color: var(--cyan) !important;
  letter-spacing: 0.2em;
  text-transform: uppercase !important;
  margin-bottom: 0.75rem !important;
}

.our-mission-section .info-box .text {
  font-size: 0.9375rem !important;
  color: var(--mid) !important;
  text-transform: none !important;
}

/* ── Counters ─────────────────────────────────── */
.fun-fact-section {
  margin-top: 4.5rem !important;
  padding-top: 4.5rem !important;
  border-top: 1px solid var(--border) !important;
}

.count-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  padding: 2.25rem 1.5rem !important;
  text-align: center !important;
  clip-path: var(--clip-card-tl);
  transition: var(--tx);
  margin-bottom: 1.5rem;
  position: relative;
}

.count-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 24px;
  height: 2px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
}

.count-box:hover {
  background: var(--card-hover) !important;
  box-shadow: var(--neon-glow);
  transform: translateY(-4px);
}

.count-box .count {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 3.75rem !important;
  font-weight: 900 !important;
  background: linear-gradient(135deg, var(--bright), var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1 !important;
  margin-bottom: 0.5rem !important;
}

.count-box .count-text {
  background: linear-gradient(135deg, var(--bright), var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.count-box .separater { display: none !important; }

.count-box .counter-title {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.2em;
  text-transform: uppercase !important;
  color: var(--mid) !important;
}

/* ── Why Choose Us ───────────────────────────────── */
.why-choose-us {
  background: var(--surface) !important;
  background-image: none !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}

.why-choose-us::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.6;
}

.why-choose-us .embed-responsive {
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

.why-choose-us .embed-responsive::before {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px solid transparent;
  background: linear-gradient(var(--surface), var(--surface)) padding-box,
              linear-gradient(135deg, var(--neon), var(--cyan)) border-box;
  pointer-events: none;
  z-index: 1;
}

.why-choose-us .inner-column {
  padding-left: 3rem !important;
  position: relative;
  z-index: 1;
}

.why-choose-us .sec-title.left h2 {
  font-size: clamp(1.75rem, 3.5vw, 3rem) !important;
}

.why-choose-us p {
  color: var(--mid) !important;
  line-height: 1.8 !important;
  margin-bottom: 1.5rem;
  text-transform: none !important;
}

/* Why-us checklist */
.list-why-us {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 2.5rem !important;
  display: flex;
  flex-wrap: wrap;
  gap: 0.875rem;
}

.list-why-us li {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  color: var(--bright) !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
  width: calc(50% - 0.4375rem);
}

.list-why-us li::before {
  content: '';
  display: block;
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--neon);
  border-radius: 2px;
  flex-shrink: 0;
  background: var(--neon-dim);
  position: relative;
}

.list-why-us li::after {
  content: '✓';
  position: absolute;
  font-size: 0.625rem;
  color: var(--cyan);
  margin-left: 3px;
}

/* ── Services Section ───────────────────────────── */
.services-section {
  /* Layered: left purple orb | right cyan orb | bottom heat-rise */
  background:
    radial-gradient(ellipse 42% 65% at -4%   50%,  rgba(155,48,255,0.055) 0%, transparent 55%),
    radial-gradient(ellipse 50% 42% at 104%  75%,  rgba(0,229,255,0.04)   0%, transparent 55%),
    radial-gradient(ellipse 60% 32% at  50%  108%, rgba(155,48,255,0.035) 0%, transparent 50%),
    var(--void) !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}

.services-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, transparent 10%, var(--neon) 40%, var(--cyan) 60%, transparent 90%);
  opacity: 0.6;
  animation: line-pulse 5s ease-in-out infinite;
}

.services-section::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(0,229,255,0.03) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
  animation: dot-drift 45s linear infinite;
}

.services-section .container { position: relative; z-index: 1; }

/* Service cards */
.service-block { height: 100%; padding-bottom: 1rem !important; }

.service-block .inner-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  overflow: hidden;
  transition: var(--tx);
  height: 100%;
  position: relative;
  display: flex !important;
  flex-direction: column;
}

/* Top bar */
.service-block .inner-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 24px;
  height: 2px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
  z-index: 2;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}

/* Corner accent */
.service-block .inner-box::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 24px; height: 24px;
  border-top: 1.5px solid var(--cyan);
  border-right: 1.5px solid var(--cyan);
  opacity: 0.35;
  pointer-events: none;
  z-index: 2;
  transition: opacity 0.3s ease;
}

.service-block .inner-box:hover {
  border-color: rgba(155,48,255,0.3) !important;
  background: var(--card-hover) !important;
  transform: translateY(-8px);
  box-shadow: 0 24px 64px rgba(0,0,0,0.6), var(--neon-glow);
}

.service-block .inner-box:hover::before { transform: scaleX(1); }
.service-block .inner-box:hover::after  { opacity: 1; }

.service-block .image-box {
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}

.service-block .image-box figure { margin: 0; }

.service-block .image-box img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
  filter: brightness(0.65) saturate(0.7);
  transition: transform 0.55s ease, filter 0.55s ease;
}

.service-block .inner-box:hover .image-box img {
  transform: scale(1.09);
  filter: brightness(0.45) saturate(0.65) hue-rotate(10deg);
}

.service-block .image-box .overlay-box,
.service-block .overlay-box {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(155,48,255,0.88) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0;
  transition: opacity 0.35s ease !important;
}

.service-block .inner-box:hover .image-box .overlay-box,
.service-block .inner-box:hover .overlay-box { opacity: 1 !important; }

.service-block .image-box .overlay-box a,
.service-block .overlay-box a {
  position: static !important;
  right: auto !important; bottom: auto !important;
  border-radius: 0 !important;
  background-color: transparent !important;
  background: transparent !important;
  height: auto !important; width: auto !important;
  padding: 0 !important;
  box-shadow: none !important;
  color: #fff !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.2em;
  text-transform: uppercase !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  transition: gap 0.2s ease !important;
}

.service-block .image-box .overlay-box a::after,
.service-block .overlay-box a::after {
  content: '▶';
  font-size: 0.6rem;
}

.service-block .image-box .overlay-box a:hover,
.service-block .overlay-box a:hover {
  color: var(--cyan) !important;
  background-color: transparent !important;
  gap: 14px;
}

.service-block .lower-content {
  padding: 1.625rem !important;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.service-block .lower-content h3 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1.125rem !important;
  font-weight: 700 !important;
  color: var(--bright) !important;
  line-height: 1.25 !important;
  margin: 0 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em;
}

.service-block .lower-content h3 a { color: var(--bright) !important; transition: var(--tx); }
.service-block .lower-content h3 a:hover { color: var(--cyan) !important; }

.service-block .lower-content .text {
  font-size: 0.875rem !important;
  color: var(--dim) !important;
  line-height: 1.65 !important;
  flex: 1;
  text-transform: none !important;
}

/* ── Work Process (Featured Section) ─────────────── */
.feautred-section,
.feautred-section.style-two {
  background: var(--deep) !important;
  background-image: none !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}

.feautred-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.5;
}

.feautred-section .inner-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  padding: 2rem !important;
  transition: var(--tx);
  position: relative;
  height: 100%;
  margin-bottom: 1.5rem;
}

/* Animated number connector line */
.feautred-section .inner-box::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 24px; height: 24px;
  border-top: 1.5px solid var(--cyan);
  border-right: 1.5px solid var(--cyan);
  opacity: 0.35;
  pointer-events: none;
}

.feautred-section .inner-box:hover {
  background: var(--card-hover) !important;
  border-color: rgba(155,48,255,0.3) !important;
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), var(--neon-glow);
}

.feautred-section .inner-box:hover::after { opacity: 1; }

.feautred-section .title-box { margin-bottom: 1rem; }

.feautred-section .title-box h4 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  color: var(--bright) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em;
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 !important;
}

/* Step number badge */
.feautred-section .numbe-post {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, var(--neon), var(--neon-mid));
  color: #fff;
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  border-radius: 2px;
  flex-shrink: 0;
  box-shadow: var(--neon-glow);
}

.feautred-section .lower-content .text {
  color: var(--dim) !important;
  font-size: 0.875rem !important;
  line-height: 1.7 !important;
  text-transform: none !important;
}

/* ── Portfolio / Gallery ─────────────────────────── */
.gallery-section {
  /* Left-purple + right-cyan ambient orbs */
  background:
    radial-gradient(ellipse 60% 55% at 12%  60%, rgba(155,48,255,0.05) 0%, transparent 55%),
    radial-gradient(ellipse 48% 38% at 92%  28%, rgba(0,229,255,0.04)  0%, transparent 55%),
    var(--surface) !important;
  padding: 7rem 0 !important;
  position: relative;
}

.gallery-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 30%, var(--cyan) 70%, transparent 95%);
  opacity: 0.5;
  z-index: 1;
}

/* Cross-hatch grid masked to a central ellipse, gently drifting */
.gallery-section::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(155,48,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155,48,255,0.022) 1px, transparent 1px);
  background-size: 48px 48px;
  -webkit-mask-image: radial-gradient(ellipse 78% 75% at 50% 50%, black 20%, transparent 72%);
  mask-image: radial-gradient(ellipse 78% 75% at 50% 50%, black 20%, transparent 72%);
  pointer-events: none;
  z-index: 0;
  animation: grid-drift 55s linear infinite;
}

/* Filter tabs */
.filters.row { margin-bottom: 2.5rem !important; }

.filter-tabs {
  display: flex !important;
  flex-wrap: wrap;
  gap: 0.5rem;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.filter-tabs li {
  display: inline-block;
  padding: 0.5rem 1.375rem !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.8125rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mid) !important;
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-btn);
  cursor: pointer;
  transition: var(--tx);
  user-select: none;
}

.filter-tabs li:hover,
.filter-tabs li.active {
  color: var(--void) !important;
  background: linear-gradient(90deg, var(--neon), var(--cyan)) !important;
  border-color: transparent !important;
  box-shadow: var(--neon-glow);
}

/* ── Portfolio Cards — Premium Gaming Hover ─────── */

/* Card base */
.default-portfolio-item .inner-box {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 4px;
  margin-bottom: 1.5rem;
  display: block;
  cursor: pointer;
  transition:
    transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1),
    border-color 0.35s ease,
    box-shadow 0.45s ease;
  will-change: transform;
}

/* HUD corner: top-right cyan bracket */
.default-portfolio-item .inner-box::before {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 22px; height: 22px;
  border-top: 1.5px solid var(--cyan);
  border-right: 1.5px solid var(--cyan);
  opacity: 0.35;
  z-index: 4;
  transition:
    width 0.35s ease,
    height 0.35s ease,
    opacity 0.35s ease,
    border-width 0.35s ease,
    border-color 0.35s ease;
  pointer-events: none;
}

/* HUD corner: bottom-left neon bracket */
.default-portfolio-item .inner-box::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 22px; height: 22px;
  border-bottom: 1.5px solid var(--neon);
  border-left: 1.5px solid var(--neon);
  opacity: 0.25;
  z-index: 4;
  transition:
    width 0.35s ease,
    height 0.35s ease,
    opacity 0.35s ease,
    border-width 0.35s ease;
  pointer-events: none;
}

/* ── Hover: lift + intense multi-layer glow ── */
.default-portfolio-item .inner-box:hover {
  transform: translateY(-8px);
  border-color: rgba(155, 48, 255, 0.65);
  box-shadow:
    0 0 0 1px rgba(0, 229, 255, 0.3),
    0 0 35px rgba(155, 48, 255, 0.55),
    0 0 90px rgba(155, 48, 255, 0.22),
    0 0 18px rgba(0, 229, 255, 0.18),
    0 32px 72px rgba(0, 0, 0, 0.75);
}

/* HUD corners grow + glow on hover */
.default-portfolio-item .inner-box:hover::before {
  width: 40px; height: 40px;
  opacity: 1;
  border-width: 2px;
  border-color: var(--cyan);
  box-shadow: 2px -2px 14px rgba(0, 229, 255, 0.55);
}

.default-portfolio-item .inner-box:hover::after {
  width: 40px; height: 40px;
  opacity: 1;
  border-width: 2px;
  box-shadow: -2px 2px 14px rgba(155, 48, 255, 0.55);
}

/* ── Image: zoom + heavy darken ── */
.default-portfolio-item .image-box img,
.default-portfolio-item figure.image-box { width: 100%; display: block; }

.default-portfolio-item .image-box img {
  aspect-ratio: 4/3;
  object-fit: cover;
  filter: brightness(0.82) saturate(0.75);
  display: block;
  width: 100%;
  transition:
    transform 0.65s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    filter 0.55s ease;
}

.default-portfolio-item .inner-box:hover .image-box img {
  transform: scale(1.12);
  filter: brightness(0.32) saturate(0.5) hue-rotate(18deg);
}

/* ── Overlay: gradient dark + neon top-edge tint ── */
.default-portfolio-item .overlay-box {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background:
    linear-gradient(
      to top,
      rgba(5,  5, 16, 0.97) 0%,
      rgba(8,  8, 32, 0.82) 48%,
      rgba(155, 48, 255, 0.12) 100%
    ) !important;
  opacity: 0;
  transition: opacity 0.4s ease, box-shadow 0.4s ease;
  display: flex !important;
  align-items: flex-end;
  padding: 1.75rem !important;
  z-index: 3;
  box-shadow: inset 0 0 0 1px rgba(155, 48, 255, 0.15);
  overflow: hidden;
}

.default-portfolio-item .inner-box:hover .overlay-box {
  opacity: 1;
  box-shadow:
    inset 0 0 0 1px rgba(155, 48, 255, 0.38),
    inset 0 0 70px rgba(155, 48, 255, 0.06);
}

/* Scan-line sweeper via overlay pseudo-element */
.default-portfolio-item .overlay-box::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  top: -4px;
  height: 3px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--neon)  30%,
    var(--cyan)  60%,
    transparent  100%
  );
  opacity: 0;
  pointer-events: none;
  z-index: 10;
}

.default-portfolio-item .inner-box:hover .overlay-box::after {
  animation: pflio-scan 2.6s linear infinite 0.25s;
  opacity: 1;
}

@keyframes pflio-scan {
  0%   { top: -4px;   opacity: 0;   }
  6%   {              opacity: 0.9; }
  88%  {              opacity: 0.6; }
  100% { top: 100%;   opacity: 0;   }
}

/* ── Content: spring slide up ── */
.default-portfolio-item .overlay-inner { width: 100%; }

.default-portfolio-item .content {
  display: flex !important;
  flex-direction: column;
  gap: 0.5rem;
  transform: translateY(14px);
  transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.default-portfolio-item .inner-box:hover .content { transform: translateY(0); }

/* Tags line */
.default-portfolio-item .tags {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.5625rem !important;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--neon) !important;
  font-weight: 600 !important;
  opacity: 0.9;
  transition: color 0.3s ease, text-shadow 0.3s ease, opacity 0.3s ease;
}

.default-portfolio-item .inner-box:hover .tags {
  color: var(--cyan) !important;
  opacity: 1;
  text-shadow:
    0 0 14px rgba(0, 229, 255, 0.75),
    0 0 30px rgba(0, 229, 255, 0.35);
}

/* Title */
.default-portfolio-item h3 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1.125rem !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
}

.default-portfolio-item h3 a {
  color: var(--bright) !important;
  transition: color 0.3s ease, text-shadow 0.35s ease;
}

.default-portfolio-item .inner-box:hover h3 a {
  color: #fff !important;
  text-shadow:
    0 0 18px rgba(155, 48, 255, 0.9),
    0 0 40px rgba(155, 48, 255, 0.5),
    0 0 80px rgba(155, 48, 255, 0.2);
}

/* View Project button — revealed on hover */
.default-portfolio-item .link-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.8125rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bright) !important;
  background: rgba(155, 48, 255, 0.1) !important;
  border: 1px solid rgba(155, 48, 255, 0.32);
  clip-path: var(--clip-btn);
  padding: 0.45rem 1.125rem;
  margin-top: 0.5rem;
  opacity: 0;
  transform: translateY(6px);
  transition:
    opacity   0.35s ease 0.08s,
    transform 0.35s ease 0.08s,
    color       0.25s ease,
    background  0.25s ease,
    border-color 0.25s ease,
    box-shadow  0.35s ease,
    letter-spacing 0.25s ease;
}

.default-portfolio-item .link-btn::after {
  content: '▶';
  font-size: 0.5rem;
  transition: transform 0.3s ease;
}

.default-portfolio-item .inner-box:hover .link-btn {
  opacity: 1;
  transform: translateY(0);
  color: #fff !important;
  background: linear-gradient(135deg, var(--neon) 0%, #6A1ADB 100%) !important;
  border-color: transparent;
  letter-spacing: 0.2em;
  box-shadow:
    0 0 20px rgba(155, 48, 255, 0.65),
    0 0 45px rgba(155, 48, 255, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.default-portfolio-item .inner-box:hover .link-btn::after {
  transform: translateX(4px);
}

.load-more-btn { margin-top: 3.5rem !important; }

/* ── Mobile: always-visible overlay, :active lift ── */
@media (hover: none) {
  .default-portfolio-item .overlay-box {
    opacity: 1 !important;
    background:
      linear-gradient(
        to top,
        rgba(5, 5, 16, 0.93) 0%,
        rgba(5, 5, 16, 0.45) 55%,
        transparent           100%
      ) !important;
    box-shadow: none !important;
  }
  .default-portfolio-item .content {
    transform: translateY(0) !important;
  }
  .default-portfolio-item .link-btn {
    opacity: 1 !important;
    transform: translateY(0) !important;
    transition: box-shadow 0.2s ease, background 0.2s ease !important;
  }
  .default-portfolio-item .overlay-box::after {
    animation: none !important;
    opacity: 0 !important;
  }

  /* Tap feedback */
  .default-portfolio-item .inner-box:active {
    transform: translateY(-4px) !important;
    border-color: rgba(155, 48, 255, 0.6) !important;
    box-shadow:
      0 0 0 1px rgba(0, 229, 255, 0.28),
      0 0 30px rgba(155, 48, 255, 0.5),
      0 16px 40px rgba(0, 0, 0, 0.65) !important;
  }
  .default-portfolio-item .inner-box:active .link-btn {
    background: linear-gradient(135deg, var(--neon) 0%, #6A1ADB 100%) !important;
    border-color: transparent !important;
    box-shadow: 0 0 20px rgba(155, 48, 255, 0.6) !important;
  }
  .default-portfolio-item .inner-box:active h3 a {
    text-shadow:
      0 0 14px rgba(155, 48, 255, 0.8),
      0 0 30px rgba(155, 48, 255, 0.4) !important;
  }
}

/* ── Pricing ─────────────────────────────────────── */
.price-section {
  background: var(--void) !important;
  background-image: none !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}

.price-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.6;
}

/* Neon orb */
.price-section::after {
  content: '';
  position: absolute;
  top: 30%; left: 50%;
  transform: translate(-50%, -50%);
  width: 60vw; height: 60vw;
  background: radial-gradient(circle, rgba(155,48,255,0.04) 0%, transparent 65%);
  pointer-events: none;
}

.price-section .container { position: relative; z-index: 1; }

.price-block .inner-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  padding: 2.5rem 2rem !important;
  transition: var(--tx);
  text-align: center;
  position: relative;
  height: 100%;
  margin-bottom: 1.5rem;
  display: flex !important;
  flex-direction: column;
}

.price-block .inner-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 24px;
  height: 2px;
  background: linear-gradient(90deg, var(--neon), var(--cyan));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}

.price-block .inner-box::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 24px; height: 24px;
  border-top: 1.5px solid var(--cyan);
  border-right: 1.5px solid var(--cyan);
  opacity: 0.3;
  pointer-events: none;
}

.price-block .inner-box:hover {
  background: var(--card-hover) !important;
  border-color: rgba(155,48,255,0.3) !important;
  transform: translateY(-8px);
  box-shadow: 0 28px 72px rgba(0,0,0,0.6), var(--neon-glow);
}

.price-block .inner-box:hover::before { transform: scaleX(1); }
.price-block .inner-box:hover::after  { opacity: 1; }

.price-block .upper-box { margin-bottom: 1.75rem; }

.price-block .upper-box h3 {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 700 !important;
  color: var(--cyan) !important;
  letter-spacing: 0.2em;
  text-transform: uppercase !important;
  margin: 0 !important;
}

.price-block .price {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 3.5rem !important;
  font-weight: 900 !important;
  background: linear-gradient(135deg, var(--bright), var(--neon-mid));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1 !important;
  margin-bottom: 1.75rem !important;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0.25rem;
}

.price-block .price sub {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  margin-top: 0.75rem;
  background: linear-gradient(135deg, var(--bright), var(--neon-mid));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  vertical-align: top;
}

.price-block .price del {
  font-size: 1.125rem !important;
  font-weight: 400 !important;
  color: var(--dim) !important;
  -webkit-text-fill-color: var(--dim) !important;
  margin-top: 0.5rem;
  margin-left: 0.5rem;
}

.price-block .price span {
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  color: var(--mid) !important;
  -webkit-text-fill-color: var(--mid) !important;
  letter-spacing: 0.1em;
  align-self: flex-end;
  padding-bottom: 0.25rem;
}

.price-block .middle-box {
  flex: 1;
  margin-bottom: 1.5rem;
  text-align: left;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 1.25rem 0;
}

.price-block .middle-box ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.price-block .middle-box ul li {
  font-size: 0.9375rem !important;
  color: var(--mid) !important;
  padding: 0.5rem 0 !important;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid rgba(155,48,255,0.07);
}

.price-block .middle-box ul li::before {
  content: '◆';
  color: var(--neon);
  font-size: 0.45rem;
  flex-shrink: 0;
}

/* ── Team Section ───────────────────────────────── */
.team-section,
.team-section.style-two {
  background: var(--void) !important;
  padding: 7rem 0 !important;
  position: relative;
}

.team-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.5;
}

.team-block .inner-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  overflow: hidden;
  transition: var(--tx);
  margin: 0 0.5rem 1.5rem;
  position: relative;
}

.team-block .inner-box::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 24px; height: 24px;
  border-top: 1.5px solid var(--cyan);
  border-right: 1.5px solid var(--cyan);
  opacity: 0.25;
  pointer-events: none;
}

.team-block .inner-box:hover {
  border-color: rgba(155,48,255,0.25) !important;
  transform: translateY(-5px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.55), var(--neon-glow);
}

.team-block .inner-box:hover::after { opacity: 0.9; }

.team-block .image-box { position: relative; overflow: hidden; }

.team-block .image-box .image img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  object-position: top center;
  filter: grayscale(40%) brightness(0.75) saturate(0.85);
  transition: transform 0.55s ease, filter 0.55s ease;
  display: block;
}

.team-block .inner-box:hover .image-box .image img {
  transform: scale(1.05);
  filter: grayscale(0) brightness(0.9) saturate(1.1);
}

/* Cyan gradient overlay bottom */
.team-block .image-box::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 40%;
  background: linear-gradient(to top, rgba(5,5,16,0.9), transparent);
  pointer-events: none;
  z-index: 1;
}

.team-block .info-box {
  padding: 1.375rem !important;
  background: none !important;
  border: none !important;
  margin: 0 !important;
}

.team-block .info-box h3.name {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1.125rem !important;
  font-weight: 700 !important;
  color: var(--bright) !important;
  margin-bottom: 0.25rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em;
}

.team-block .info-box h3.name a { color: var(--bright) !important; }

.team-block .info-box .designation {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.5625rem !important;
  font-weight: 600 !important;
  color: var(--neon) !important;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 0.75rem;
}

.team-block .info-box span {
  font-size: 0.8125rem !important;
  color: var(--dim) !important;
  display: flex !important;
  align-items: center;
  gap: 6px;
  margin-bottom: 0.25rem;
  text-transform: none !important;
}

.team-block .social-links {
  padding: 0.75rem 1.375rem 1.375rem !important;
  display: flex !important;
  gap: 6px;
  list-style: none !important;
  margin: 0 !important;
}

.team-block .social-links li a {
  display: inline-flex !important;
  width: 30px; height: 30px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border) !important;
  border-radius: 2px !important;
  font-size: 11px;
  color: var(--dim) !important;
  transition: var(--tx);
}

.team-block .social-links li a:hover {
  color: var(--cyan) !important;
  border-color: var(--border-cyan) !important;
  background: var(--cyan-dim) !important;
  box-shadow: var(--cyan-glow);
}

/* ── Testimonials ───────────────────────────────── */
.testimonial-section {
  background: var(--deep) !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}

/* Giant neon quote mark */
.testimonial-section::before {
  content: '\201C';
  position: absolute;
  top: -4rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'Orbitron', sans-serif !important;
  font-size: 22rem;
  background: linear-gradient(135deg, rgba(155,48,255,0.06), rgba(0,229,255,0.03));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  pointer-events: none;
  line-height: 1;
  user-select: none;
}

.testimonial-block .inner-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  padding: 2rem !important;
  display: flex !important;
  gap: 1.5rem;
  align-items: flex-start;
  transition: var(--tx);
  margin: 0 0.75rem;
}

.testimonial-block .inner-box:hover {
  border-color: rgba(155,48,255,0.25) !important;
  background: var(--card-hover) !important;
  box-shadow: var(--neon-glow);
}

.testimonial-block .image-box { flex-shrink: 0; }

.testimonial-block .image-box .thumb {
  width: 60px; height: 60px;
  border-radius: 2px;
  overflow: hidden;
  border: 2px solid var(--neon);
  box-shadow: var(--neon-glow);
}

.testimonial-block .image-box .thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.testimonial-block .info-box { flex: 1; min-width: 0; }

.testimonial-block .info-box .text {
  font-size: 0.9375rem !important;
  color: var(--mid) !important;
  line-height: 1.8 !important;
  font-style: italic;
  margin-bottom: 1.25rem !important;
  text-transform: none !important;
}

.testimonial-block .info-box h5.name {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--bright) !important;
  margin-bottom: 0.25rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em;
}

.testimonial-block .info-box .company-name {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 0.5625rem !important;
  color: var(--neon) !important;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600 !important;
}

/* ── News / Blog ─────────────────────────────────── */
.news-section {
  background: var(--void) !important;
  padding: 7rem 0 !important;
}

.news-block .inner-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  overflow: hidden;
  transition: var(--tx);
  height: 100%;
  display: flex !important;
  flex-direction: column;
}

.news-block .inner-box:hover {
  border-color: rgba(155,48,255,0.25) !important;
  transform: translateY(-4px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.55), var(--neon-glow);
}

.news-block .image-box { position: relative; overflow: hidden; flex-shrink: 0; }
.news-block .image-box figure { margin: 0; }
.news-block .image-box .image { position: relative; overflow: hidden; }

.news-block .image-box .image img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
  filter: brightness(0.7) saturate(0.8);
  transition: transform 0.55s ease, filter 0.55s ease;
}

.news-block .inner-box:hover .image-box .image img {
  transform: scale(1.05);
  filter: brightness(0.5) saturate(0.75) hue-rotate(10deg);
}

.news-block .image-box .overlay-box {
  position: absolute;
  inset: 0;
  background: rgba(155,48,255,0.85) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.35s ease;
}

.news-block .inner-box:hover .image-box .overlay-box { opacity: 1; }

.news-block .image-box .overlay-box .link-btn {
  color: #fff !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.news-block .caption-box {
  padding: 1.625rem !important;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.news-block .caption-box h3 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1.1875rem !important;
  font-weight: 700 !important;
  color: var(--bright) !important;
  line-height: 1.3 !important;
  margin-bottom: 0.75rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em;
}

.news-block .caption-box h3 a { color: var(--bright) !important; transition: var(--tx); }
.news-block .caption-box h3 a:hover { color: var(--cyan) !important; }

.news-block .caption-box .text {
  font-size: 0.875rem !important;
  color: var(--dim) !important;
  line-height: 1.7 !important;
  flex: 1;
  margin-bottom: 1rem !important;
  text-transform: none !important;
}

.news-block .post-meta {
  display: flex !important;
  list-style: none !important;
  padding: 0 !important;
  margin-top: auto !important;
}

.news-block .post-meta li {
  font-size: 0.75rem !important;
  color: var(--dim) !important;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

/* Small blog sidebar */
.news-block-two .inner-box {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  overflow: hidden;
  margin-bottom: 1.25rem !important;
  transition: var(--tx);
}

.news-block-two .inner-box:hover {
  border-color: rgba(155,48,255,0.25) !important;
  background: var(--card-hover) !important;
}

.news-block-two .image-box .image figure { margin: 0; }
.news-block-two .image-box .image img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.7) saturate(0.8);
  transition: transform 0.4s ease;
  display: block;
}

.news-block-two .inner-box:hover .image-box .image img { transform: scale(1.04); }

.news-block-two .image-box .overlay-box {
  position: absolute;
  inset: 0;
  background: rgba(155,48,255,0.82) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.35s ease;
}

.news-block-two .inner-box:hover .image-box .overlay-box { opacity: 1; }

.news-block-two .image-box .overlay-box .link-btn {
  color: #fff !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 0.8125rem !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.news-block-two .caption-box { padding: 1rem 1.25rem !important; }
.news-block-two .caption-box h3 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--bright) !important;
  line-height: 1.35 !important;
  margin-bottom: 0.5rem !important;
  text-transform: uppercase !important;
}

.news-block-two .caption-box h3 a { color: var(--bright) !important; transition: var(--tx); }
.news-block-two .caption-box h3 a:hover { color: var(--cyan) !important; }

.news-block-two .caption-box .text {
  font-size: 0.8125rem !important;
  color: var(--dim) !important;
  text-transform: none !important;
  margin-bottom: 0.5rem !important;
}

.news-block-two .post-meta { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.news-block-two .post-meta li {
  font-size: 0.6875rem !important;
  color: var(--dim) !important;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* ── Contact Section ─────────────────────────────── */
.contact-section {
  background: var(--deep) !important;
  padding: 7rem 0 !important;
  position: relative;
  overflow: hidden;
}

.contact-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.6;
}

/* ── Form Styles ─────────────────────────────────── */
.contact-form .form-group { margin-bottom: 1.25rem !important; }

.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form input[type="number"],
.contact-form select,
.contact-form textarea {
  width: 100%;
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 0.875rem 1.25rem !important;
  color: var(--bright) !important;
  font-family: 'Barlow', sans-serif !important;
  font-size: 0.9375rem !important;
  transition: var(--tx);
  outline: none !important;
  clip-path: var(--clip-card-tl);
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  border-color: var(--border-cyan) !important;
  background: rgba(0,229,255,0.04) !important;
  box-shadow: 0 0 0 2px rgba(0,229,255,0.12), var(--cyan-glow) !important;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: var(--dim) !important;
  font-size: 0.875rem !important;
}

.contact-form textarea {
  min-height: 140px;
  resize: vertical;
}

.contact-form label {
  color: var(--mid) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 0.625rem !important;
  display: block;
}

/* Custom radio / checkbox */
.custom-control-label {
  color: var(--mid) !important;
  font-size: 0.875rem !important;
  cursor: pointer;
}

.custom-control-input:checked ~ .custom-control-label::before {
  background-color: var(--neon) !important;
  border-color: var(--neon) !important;
}

.custom-control-label::before {
  background-color: var(--card) !important;
  border-color: var(--border) !important;
}

/* Custom file input */
.custom-file-label {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: 0 !important;
  color: var(--dim) !important;
  font-size: 0.875rem !important;
  padding: 0.875rem 1.25rem !important;
}

.custom-file-label::after {
  background: linear-gradient(90deg, var(--neon), var(--neon-mid)) !important;
  color: #fff !important;
  border-radius: 0 !important;
  border: none !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.8125rem !important;
  letter-spacing: 0.1em;
}

/* Contact info sidebar */
.contact-info {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.contact-info li {
  padding: 1.25rem !important;
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-left: 3px solid var(--neon) !important;
  clip-path: var(--clip-card-tl);
  margin-bottom: 1rem;
  color: var(--mid) !important;
  font-size: 0.9375rem !important;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  line-height: 1.6;
  transition: var(--tx);
}

.contact-info li:hover {
  background: var(--card-hover) !important;
  border-color: rgba(0,229,255,0.2) !important;
  border-left-color: var(--cyan) !important;
}

.contact-info li i,
.contact-info li .icon {
  color: var(--neon) !important;
  font-size: 1.25rem !important;
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.contact-info li span {
  color: var(--cyan) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 0.25rem;
}

/* ── Map Section ─────────────────────────────────── */
.map-section {
  position: relative;
}

.map-section .embed-responsive {
  filter: grayscale(100%) brightness(0.4) invert(10%) sepia(20%) hue-rotate(200deg);
  transition: filter 0.4s ease;
  border-top: 2px solid var(--border);
}

.map-section .embed-responsive:hover {
  filter: grayscale(80%) brightness(0.55) invert(5%) sepia(20%) hue-rotate(200deg);
}

/* ── FAQ Section ─────────────────────────────────── */
.faq-section-two {
  background: var(--void) !important;
  background-image: none !important;
  padding: 7rem 0 !important;
  position: relative;
}

.faq-section-two::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.6;
}

/* FAQ category sidebar */
.faq-list-sidebar {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  overflow: hidden;
  margin-bottom: 2rem;
}

.faq-cat {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.faq-cat li {
  border-bottom: 1px solid rgba(155,48,255,0.1);
}

.faq-cat li:last-child { border-bottom: none; }

.faq-cat li a {
  display: flex !important;
  align-items: center;
  gap: 10px;
  padding: 0.875rem 1.25rem !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mid) !important;
  transition: var(--tx);
}

.faq-cat li a::before {
  content: '▶';
  font-size: 0.45rem;
  color: var(--neon);
  opacity: 0;
  transition: var(--tx);
  flex-shrink: 0;
}

.faq-cat li a:hover,
.faq-cat li.active a {
  color: var(--cyan) !important;
  background: var(--cyan-dim) !important;
  padding-left: 1.625rem !important;
}

.faq-cat li a:hover::before,
.faq-cat li.active a::before { opacity: 1; }

/* Accordion */
.accordion-box {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.accordion.block {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  clip-path: var(--clip-card-tl);
  margin-bottom: 0.875rem;
  overflow: hidden;
  transition: var(--tx);
}

.accordion.block:hover {
  border-color: rgba(155,48,255,0.3) !important;
}

.acc-btn {
  padding: 1.125rem 1.5rem !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--bright) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em;
  cursor: pointer;
  display: flex !important;
  align-items: center;
  gap: 12px;
  transition: var(--tx);
  background: none !important;
  border-bottom: 1px solid transparent;
}

.acc-btn.active {
  color: var(--cyan) !important;
  border-bottom-color: var(--border) !important;
  background: var(--card-hover) !important;
}

.acc-btn:hover { color: var(--cyan) !important; background: var(--cyan-dim) !important; }

.icon-outer {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: 1.5px solid var(--border);
  border-radius: 2px;
  flex-shrink: 0;
  transition: var(--tx);
}

.acc-btn.active .icon-outer {
  border-color: var(--cyan);
  background: var(--cyan-dim);
}

.icon_plus  { display: block; }
.icon_minus { display: none; }
.acc-btn.active .icon_plus  { display: none; }
.acc-btn.active .icon_minus { display: block; }

.acc-btn .icon { color: var(--neon) !important; font-size: 0.75rem !important; }
.acc-btn.active .icon { color: var(--cyan) !important; }

.acc-content { display: none; }
.acc-content.current { display: block; }

.acc-content .content {
  padding: 1.25rem 1.5rem !important;
}

.acc-content .content .text {
  color: var(--mid) !important;
  font-size: 0.9375rem !important;
  line-height: 1.75 !important;
  text-transform: none !important;
}

/* ── Clients ─────────────────────────────────────── */
.clients-section.style-two {
  background: var(--surface) !important;
  padding: 3.5rem 0 !important;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.clients-section .sponsors-carousel .slide-item {
  display: flex !important;
  align-items: center;
  justify-content: center;
}

.clients-section .sponsors-carousel .slide-item img {
  max-height: 48px !important;
  width: auto !important;
  object-fit: contain;
  filter: grayscale(100%) brightness(0.4) !important;
  opacity: 0.55;
  transition: var(--tx);
}

.clients-section .sponsors-carousel .slide-item:hover img {
  filter: grayscale(0%) brightness(1.1) !important;
  opacity: 1;
}

/* ── Alert Styles ────────────────────────────────── */
.alert {
  border-radius: 0 !important;
  clip-path: var(--clip-card-tl);
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em;
  padding: 1rem 1.5rem !important;
  border-width: 1px !important;
  margin-bottom: 1.5rem;
}

.alert-success {
  background: rgba(0,229,255,0.08) !important;
  border-color: rgba(0,229,255,0.35) !important;
  color: var(--cyan) !important;
}

.alert-danger {
  background: rgba(155,48,255,0.1) !important;
  border-color: rgba(155,48,255,0.4) !important;
  color: var(--neon-mid) !important;
}

.alert .close { color: inherit !important; opacity: 0.7; }

/* ── Footer ─────────────────────────────────────── */
.main-footer {
  /* Deep-space: bottom centre purple nebula + left cyan mist */
  background:
    radial-gradient(ellipse 90% 55% at 50% 110%, rgba(155,48,255,0.07)  0%, transparent 55%),
    radial-gradient(ellipse 45% 55% at  0%  50%, rgba(0,229,255,0.03)   0%, transparent 50%),
    radial-gradient(ellipse 40% 40% at 100% 0%,  rgba(155,48,255,0.035) 0%, transparent 50%),
    var(--deep) !important;
  border-top: 1px solid var(--border);
  position: relative;
}

.main-footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 5%, var(--neon) 35%, var(--cyan) 65%, transparent 95%);
  opacity: 0.7;
  z-index: 1;
}

/* Star field — tiny neon & cyan sparkle points */
.main-footer::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1.5px 1.5px at  10%  22%, rgba(155,48,255,0.55) 0%, transparent 100%),
    radial-gradient(1px   1px   at  78%  14%, rgba(0,229,255,0.45)  0%, transparent 100%),
    radial-gradient(1px   1px   at  33%  68%, rgba(155,48,255,0.45) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at  62%  44%, rgba(0,229,255,0.4)   0%, transparent 100%),
    radial-gradient(1px   1px   at  88%  78%, rgba(155,48,255,0.45) 0%, transparent 100%),
    radial-gradient(1px   1px   at  47%   9%, rgba(237,224,255,0.3) 0%, transparent 100%),
    radial-gradient(1px   1px   at  72%  61%, rgba(0,229,255,0.35)  0%, transparent 100%),
    radial-gradient(1.5px 1.5px at  23%  48%, rgba(155,48,255,0.4)  0%, transparent 100%),
    radial-gradient(1px   1px   at  56%  84%, rgba(237,224,255,0.28)0%, transparent 100%),
    radial-gradient(1px   1px   at   6%  58%, rgba(0,229,255,0.3)   0%, transparent 100%),
    radial-gradient(1px   1px   at  42%  35%, rgba(155,48,255,0.28) 0%, transparent 100%),
    radial-gradient(1px   1px   at  91%  30%, rgba(237,224,255,0.22)0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
  animation: stars-twinkle 7s ease-in-out infinite;
}

.container-footer { background: var(--deep) !important; }

.container-footer span,
.container-footer span i {
  color: var(--mid) !important;
  font-size: 0.875rem !important;
  line-height: 1.9;
}

.container-footer a { color: var(--mid) !important; font-size: 0.875rem !important; }
.container-footer a:hover { color: var(--cyan) !important; }

.container-footer .quick-links {
  border-left: 1px solid var(--border) !important;
  padding-left: 2rem !important;
}

.container-footer ul {
  font-size: 0.875rem !important;
  font-weight: 400 !important;
  line-height: 2.4 !important;
  list-style: none !important;
  padding: 0 !important;
}

.container-footer ul li a {
  color: var(--mid) !important;
  font-weight: 500 !important;
  display: inline-flex !important;
  align-items: center;
  gap: 0;
  transition: var(--tx);
}

.container-footer ul li a::before {
  content: '▶';
  font-size: 0.45rem;
  color: var(--neon);
  opacity: 0;
  transform: translateX(-6px);
  margin-right: 0;
  transition: var(--tx);
  flex-shrink: 0;
}

.container-footer ul li a:hover {
  color: var(--cyan) !important;
  gap: 6px;
}

.container-footer ul li a:hover::before {
  opacity: 1;
  transform: translateX(0);
  margin-right: 2px;
}

.container-footer .info-box {
  margin-left: 0 !important;
  color: var(--mid) !important;
}

.container-footer .info-box strong {
  color: var(--bright) !important;
  font-size: 0.875rem !important;
}

.container-footer .info-box > ul li { color: var(--mid) !important; }

.container-footer .info-box .icon-box span::before {
  font-size: 1.75rem !important;
  line-height: 1 !important;
  color: var(--neon) !important;
}

.footer-bottom {
  background: rgba(0,0,0,0.55) !important;
  border-top: 1px solid var(--border) !important;
  padding: 1.375rem 0 !important;
}

.footer-bottom .inner-container {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.footer-bottom .copyright-text,
.footer-bottom .copyright-text p,
.footer-bottom .copyright-text a {
  color: var(--dim) !important;
  font-size: 0.8125rem !important;
  line-height: 1.6;
}

.footer-bottom .copyright-text a:hover { color: var(--cyan) !important; }

/* Social icons footer */
.social-icon-two,
.social-links ul.social-icon-two {
  display: flex !important;
  gap: 6px;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.social-icon-two li a {
  display: inline-flex !important;
  width: 34px !important; height: 34px !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid var(--border) !important;
  border-radius: 2px !important;
  color: var(--dim) !important;
  font-size: 12px !important;
  transition: var(--tx);
}

.social-icon-two li a:hover {
  color: var(--cyan) !important;
  border-color: var(--border-cyan) !important;
  background: var(--cyan-dim) !important;
  box-shadow: var(--cyan-glow);
}

/* ── OWL Carousel ────────────────────────────────── */
.owl-theme .owl-dots .owl-dot span {
  background: var(--border) !important;
  width: 8px !important; height: 8px !important;
  border-radius: 2px !important;
  transition: var(--tx);
}

.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span {
  background: linear-gradient(90deg, var(--neon), var(--cyan)) !important;
  width: 24px !important;
  border-radius: 2px !important;
}

.services-section .owl-dot,
.services-carousel .owl-dot {
  background-color: var(--dim) !important;
  height: 4px !important;
  width: 24px !important;
  border-radius: 1px !important;
  opacity: 1 !important;
  transition: var(--tx) !important;
}

.services-section .owl-dot.active,
.services-section .owl-dot:hover,
.services-carousel .owl-dot.active,
.services-carousel .owl-dot:hover {
  background: linear-gradient(90deg, var(--neon), var(--cyan)) !important;
  width: 36px !important;
}

.owl-theme .owl-nav [class*=owl-] {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: 2px !important;
  color: var(--mid) !important;
  width: 42px; height: 42px;
  line-height: 42px;
  font-size: 1.125rem !important;
  transition: var(--tx);
}

.owl-theme .owl-nav [class*=owl-]:hover {
  background: linear-gradient(90deg, var(--neon), var(--cyan)) !important;
  border-color: transparent !important;
  color: var(--void) !important;
  box-shadow: var(--neon-glow);
}

/* ── Scroll to Top ──────────────────────────────── */
.scroll-to-top {
  background: linear-gradient(135deg, var(--neon), var(--cyan)) !important;
  color: var(--void) !important;
  border-radius: 2px !important;
  width: 40px !important; height: 40px !important;
  box-shadow: var(--neon-glow);
  transition: var(--tx);
  display: flex !important;
  align-items: center;
  justify-content: center;
}

.scroll-to-top:hover {
  background: linear-gradient(135deg, var(--cyan), var(--neon)) !important;
  box-shadow: 0 0 40px rgba(0,229,255,0.5);
  transform: translateY(-3px);
}

/* ── WOW ────────────────────────────────────────── */
.wow { visibility: visible !important; }

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 1280px) {
  .site-header-inner { max-width: 100% !important; padding: 0 1.5rem !important; }
}

@media (max-width: 1023px) {
  .hero-title { font-size: clamp(2.5rem, 9vw, 5rem) !important; }

  .our-mission-section, .services-section, .gallery-section,
  .team-section, .testimonial-section, .news-section,
  .contact-section, .faq-section-two, .price-section,
  .feautred-section, .why-choose-us { padding: 5rem 0 !important; }

  .main-navigation { display: none !important; }
  .nav-toggle { display: flex !important; }

  .why-choose-us .inner-column { padding-left: 0 !important; margin-top: 2rem; }
  .list-why-us li { width: 100%; }
}

@media (max-width: 767px) {
  .hero-title { font-size: clamp(2.25rem, 14vw, 3.5rem) !important; }

  .testimonial-block .inner-box { flex-direction: column !important; gap: 1rem; }

  .container-footer .quick-links {
    border-left: none !important;
    border-top: 1px solid var(--border);
    padding-top: 2rem !important;
    padding-left: 0 !important;
    margin-top: 2rem;
  }

  .footer-bottom .inner-container { flex-direction: column; text-align: center; }

  .page-title { padding: 7rem 0 3rem !important; }
  .page-title .inner-container { flex-direction: column; align-items: flex-start; }

  .count-box .count { font-size: 2.75rem !important; }
  .price-block .price { font-size: 2.75rem !important; }
}

@media (max-width: 575px) {
  .hero-actions { flex-direction: column; align-items: flex-start; }
  .filter-tabs { gap: 0.375rem; }
  .filter-tabs li { padding: 0.4375rem 1rem !important; font-size: 0.75rem !important; }
  .list-why-us { flex-direction: column; }
  .list-why-us li { width: 100%; }
}

/* ════════════════════════════════════════════════════
   BACKGROUND EFFECT KEYFRAMES
   All subtle — durations 30s+ to stay imperceptible
═════════════════════════════════════════════════════ */

/* Hero: diagonal speed lines drift */
@keyframes streak-drift {
  0%   { background-position: 0 0; }
  100% { background-position: 340px 340px; }
}

/* Services: dot grid slow wander */
@keyframes dot-drift {
  0%   { background-position: 0 0; }
  100% { background-position: 28px 28px; }
}

/* Services top-line / general neon line breathe */
@keyframes line-pulse {
  0%,100% { opacity: 0.45; }
  50%     { opacity: 0.85; }
}

/* About: diagonal slash opacity breathe */
@keyframes slash-breathe {
  0%,100% { opacity: 0.12; }
  50%     { opacity: 0.28; }
}

/* Portfolio: cross-hatch grid diagonal drift */
@keyframes grid-drift {
  0%   { background-position: 0 0, 0 0; }
  100% { background-position: 48px 48px, 48px 48px; }
}

/* Footer: star field gentle twinkle */
@keyframes stars-twinkle {
  0%,100% { opacity: 0.6; }
  33%     { opacity: 1;   }
  66%     { opacity: 0.75; }
}

/* ── Accessibility: honour reduced-motion preference ── */
@media (prefers-reduced-motion: reduce) {
  .ds-hero-grid::before,
  .ds-hero-grid::after,
  .banner-section::before,
  .banner-section::after,
  .services-section::before,
  .services-section::after,
  .gallery-section::after,
  .our-mission-section::before,
  .main-footer::after {
    animation: none !important;
    transition: none !important;
  }
}
