/*

Theme Name: Alturaitz

Theme URI: http://www.Alturaitz.com

Author: Alturaitz

Author URI: http://www.Alturaitz.com

Description: Simple and Responsive Wordpress theme.

*/

@font-face {
  font-family: "TrajanPro-Regular";
  src: url("fonts/TrajanPro-Regular.ttf");
  font-display: swap;
}

@font-face {
  font-family: "TrajanPro-Bold";
  src: url("fonts/TrajanPro-Bold.otf");
  font-display: swap;
}

/* -- style for common -- */

html {
  scroll-behavior: smooth !important;
}

body {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

p {
  margin: 0;
  padding: 0;
  font-size: 18px;
  line-height: 28px;
  color: var(--black);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  color: var(--black);
}

a,
input,
textarea,
button,
select {
  outline: none;
}

a:hover,
a:focus,
input:focus,
textarea:focus,
button:focus,
select:focus {
  outline: none;
  text-decoration: none;
}

a:hover {
  color: var(--black);
  text-decoration: none;
}

input,
textarea,
button,
select,
label,
a,
span,
img {
  -webkit-tap-highlight-color: transparent;
  tap-highlight-color: transparent;
}

img {
  max-width: 100%;
  height: auto;
}

:focus {
  box-shadow: none !important;
}

.container {
  width: 100%;
  max-width: 1200px;
}

ul,
ol {
  text-decoration: none;
  padding: 0;
  margin: 0;
}

a {
  color: var(--black);
  text-decoration: none;
}

/* Common Style */

:root {
  --primary: #3fe0f7;
  --black: #000;
  --white: #fff;
}

.alturaitz-hero-area {
  background: linear-gradient(180deg,
      rgba(21, 91, 101, 0) 0%,
      rgba(21, 91, 101, 0.4) 25%,
      rgba(21, 91, 101, 0.7) 50%,
      rgba(21, 91, 101, 0.4) 75%,
      rgba(21, 91, 101, 0) 100%);
}

.alturaitz-hero-it-content p {
  font-size: 20px;
  line-height: 30px;
  color: #fff;
  margin-top: 15px;
}

/* --- Vibrant Tech SaaS Hero --- */
.saas-hero-area {
  background-color: #07070a;
  min-height: 100vh;
  padding: 160px 0 60px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.saas-mesh-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  filter: blur(120px);
  opacity: 0.6;
  pointer-events: none;
}

.saas-mesh-blob {
  position: absolute;
  border-radius: 50%;
  animation: saasFluid 15s infinite alternate ease-in-out;
}

.blob-1 {
  width: 500px;
  height: 500px;
  background: #6366f1;
  top: -10%;
  left: -10%;
}

.blob-2 {
  width: 600px;
  height: 600px;
  background: #8b5cf6;
  bottom: -20%;
  right: -10%;
  animation-delay: -5s;
}

.blob-3 {
  width: 400px;
  height: 400px;
  background: #ec4899;
  top: 30%;
  left: 40%;
  animation-delay: -10s;
}

@keyframes saasFluid {
  0% {
    transform: scale(1) translate(0, 0);
  }

  100% {
    transform: scale(1.3) translate(50px, 100px);
  }
}

.saas-hero-row {
  min-height: 70vh;
}

.saas-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 8px 16px;
  border-radius: 100px;
  margin-bottom: 25px;
}

.saas-badge .badge-icon {
  font-size: 16px;
}

.saas-badge .badge-text {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  padding-top: 2px;
}

.saas-title {
  font-size: clamp(50px, 5.5vw, 80px);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  letter-spacing: -2px;
  margin-bottom: 25px;
}

.saas-subtitle {
  font-size: 20px;
  color: #a1a1aa;
  line-height: 1.6;
  max-width: 90%;
  margin-bottom: 40px;
}

.saas-btn-group {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.saas-btn-primary {
  background: linear-gradient(135deg, #6366f1, #a855f7);
  color: #fff;
  padding: 16px 36px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 16px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: 0.3s;
  box-shadow: 0 10px 30px rgba(99, 102, 241, 0.3);
}

.saas-btn-primary:hover {
  box-shadow: 0 15px 40px rgba(99, 102, 241, 0.5);
  transform: translateY(-3px);
  color: #fff;
}

.saas-btn-secondary {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  padding: 16px 36px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 16px;
  transition: 0.3s;
}

.saas-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: #fff;
  color: #fff;
  transform: translateY(-3px);
}

.saas-graphic-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.saas-graphic-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 650px;
}

.saas-circle-behind {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  height: 80%;
  background: linear-gradient(135deg, rgba(236, 72, 153, 0.3), rgba(99, 102, 241, 0.3));
  border-radius: 50%;
  filter: blur(40px);
  z-index: -1;
}

.saas-main-svg {
  width: 100%;
  height: auto;
  filter: drop-shadow(0 30px 40px rgba(0, 0, 0, 0.5));
}

.saas-massive-text-wrap {
  position: absolute;
  bottom: 80px;
  left: 0;
  width: 100%;
  text-align: center;
  z-index: 1;
  pointer-events: none;
  opacity: 0.1;
}

.saas-massive-text {
  font-size: clamp(80px, 15vw, 250px);
  font-weight: 900;
  color: transparent;
  -webkit-text-stroke: 2px #fff;
  text-transform: uppercase;
  white-space: nowrap;
  margin: 0;
  line-height: 1;
}

.saas-services-marquee {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: rgba(255, 255, 255, 0.03);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding: 15px 0;
  z-index: 5;
  backdrop-filter: blur(10px);
}

.saas-marquee-item {
  font-size: 16px;
  font-weight: 600;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 2px;
}

@media (max-width: 991px) {
  .saas-hero-row {
    text-align: center;
  }

  .saas-subtitle {
    margin: 0 auto 40px;
  }

  .saas-btn-group {
    justify-content: center;
  }

  .saas-graphic-wrap {
    margin-top: 50px;
  }
}


/* Horizontal section */
section.horizontal {
  overflow: hidden;
}

section.horizontal .pin-wrap,
section.horizontal .animation-wrap {
  display: flex;
  /* align-items: center; */
  position: relative;
  z-index: 1;
  height: 100vh;
}

.parallax-item {
  position: relative;
  width: 600px;
  height: 100%;
  overflow: hidden;
  transform: translateY(-50%);
  top: 50%;
}

.parallax-content {
  position: absolute;
  bottom: -100px;
  left: 0;
  z-index: 55;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  margin: 40px 40px 30px 35px;
  transition: 0.4s;
}

.parallax-content span {
  font-size: 24px;
  line-height: 1;
  display: block;
  font-size: 20px;
  margin-bottom: 10px;
  color: #fff;
  text-transform: capitalize;
}

.parallax-content h4 {
  font-size: 50px;
  line-height: 1;
  padding-bottom: 7px;
  display: inline-block;
  color: #fff;
}

.parallax-img {
  position: absolute;
  height: 100%;
  width: 100%;
  background-size: cover;
  background-position: center;
}

.parallax-item:hover .parallax-img::after {
  opacity: 1;
  height: 100%;
  visibility: visible;
}

.parallax-img::after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  opacity: 0;
  visibility: hidden;
  transition: 0.4s;
  background-color: rgba(0, 0, 0, 0.3);
}

.parallax-item:hover .parallax-content {
  bottom: 0;
  opacity: 1;
  visibility: visible;
}

.parallax-img img {
  object-fit: cover !important;
  height: 100%;
  width: 100%;
  object-position: center !important;
}

.alturaitz-bg-theme-new-clr {
  background-color: #ffdc7c;
}

.footer-right {
  list-style: none;
  display: grid;
  gap: 8px;
}

.footer-right a {
  font-size: 18px;
  font-weight: 500;
  line-height: 30px;
  text-transform: uppercase;
  transition: all 0.3s ease;
}

.footer-right a:hover {
  color: #fff;
}

.alturaitz-blog-item .wp-post-image {
  height: 300px;
  object-fit: cover;
}

#bg {
  position: fixed;
  top: 0;
  left: 0;
  background: transparent;
  z-index: -1;
}

svg.hero-svg-image {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 43%;
  height: auto;
  opacity: 0.5;
}

.alturaitz-service-hero-spacing {
  padding-top: 220px;
}

.alturaitz-blog-details-content h2,
.alturaitz-blog-details-content h3 {
  font-size: 30px;
  color: #fff;
  margin: 40px 0 20px;
}

.alturaitz-blog-details-content h4 {
  font-size: 24px;
  color: #fff;
  margin: 20px 0;

}

.alturaitz-blog-details-content ul {
  margin: 20px 0;
  padding-left: 30px;
}

.alturaitz-blog-details-content p,
.alturaitz-blog-details-content li,
.alturaitz-blog-details-content span {
  color: #ececec;
  font-size: 16px;
  line-height: 26px;

}

.alturaitz-text-slider-area {
  padding: 20px 0;
  overflow-x: hidden;
}



body.popup-open {
  overflow: hidden;
}

.popup-sec {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transition: 0.4s;
  z-index: 10000;
  padding: 30px 20px;
  backdrop-filter: blur(10px);
}

.popup-sec.active {
  opacity: 1;
  visibility: visible;
}

.popup-inner {
  background: #111;
  width: 100%;
  max-width: 900px;
  max-height: 85vh;
  overflow-y: auto;
  padding: 60px 40px;
  border-radius: 24px;
  transform: translateY(40px) scale(0.95);
  transition: 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5);
  overscroll-behavior: contain;
}

#popup-title {
  font-size: 30px;
  color: #fff;
  margin-bottom: 20px;
}

.popup-inner h2,
.popup-inner h3 {
  font-size: 24px;
  color: #fff;
  margin: 20px 0;
}

.popup-inner h4,
.popup-inner h5 {
  font-size: 20px;
  color: #fff;
  margin: 20px 0;
}

.popup-sec.active .popup-inner {
  transform: translateY(0) scale(1);
}

.popup-close {
  position: absolute;
  right: 30px;
  top: 20px;
  font-size: 30px;
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
}

.popup-body {
  margin-top: 20px;
  color: #ccc;
}

.popup-inner p {
  color: #ccc;
}

.forminator-label {
  color: #fff !important;
  font-size: 18px !important;
  margin-bottom: 5px !important;
  display: inline-block !important;
  font-weight: 400 !important;
  font-family: 'Kanit', sans-serif !important;
}

.forminator-ui input[type="text"],
.forminator-ui input[type="email"],
.forminator-ui textarea,
.select2-selection,
input[type="url"] {
  color: #fff !important;
  background: #00000000 !important;
  border-color: #ffffff1a !important;
  font-size: 18px !important;
  width: 100% !important;
  height: 56px !important;
  font-weight: 400 !important;
  border-radius: 5px !important;
  line-height: 52px !important;
  padding-left: 25px !important;
  padding-right: 25px !important;
  border: 1px solid #2d2d2d !important;
  outline: none !important;
  font-family: 'Kanit', sans-serif !important;
}

span.select2-selection__placeholder,
.select2-selection__rendered {
  color: #fff !important;
}

.forminator-button-upload {
  border: 1px dashed #fff !important;
  border-radius: 50px !important;
  padding: 10px 20px !important;
  color: #fff !important;
}

.forminator-file-upload {
  color: #dddddd57;
}

span.forminator-checkbox-label {
  color: #ffffff;
}

.forminator-ui textarea {
  max-height: 100px !important;
  height: 100px !important;
  resize: none !important;
}

/* CSS to trigger expanding hover effects on the custom cards safely */
.parallax-item:hover .parallax-img {
  opacity: 0.6 !important;
  transform: scale(1.05);
}

.parallax-item:hover .cta-btn-hover {
  transform: rotate(45deg) !important;
}

.title-hover-link {
  transition: color 0.3s ease;
}

.title-hover-link:hover {
  color: #e5ff4e !important;
}

.alturaitz-section-subtitle {
  width: fit-content !important;
}


.alturaitz-why-choose-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 30px;
  padding: 50px 40px;
  backdrop-filter: blur(10px);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.alturaitz-why-choose-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at top right, #3fe0f742, transparent 70%);
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 0;
}

.alturaitz-why-choose-card:hover {
  transform: translateY(-10px);
  border-color: #3fe0f780;
  background: rgba(255, 255, 255, 0.05);
}

.alturaitz-why-choose-card:hover::before {
  opacity: 1;
}

.alturaitz-why-choose-card .bg-number {
  font-size: 100px;
  font-weight: 800;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.05);
  line-height: 0.8;
  position: absolute;
  right: 40px;
  top: 40px;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1;
}

.alturaitz-why-choose-card:hover .bg-number {
  -webkit-text-stroke: 1px var(--primary);
  transform: scale(1.1) rotate(5deg);
}

.alturaitz-why-choose-card .icon-wrap {
  width: 70px;
  height: 70px;
  background: var(--primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #121212;
  position: relative;
  z-index: 2;
  margin-bottom: 30px;
  transition: transform 0.4s ease;
}

.alturaitz-why-choose-card:hover .icon-wrap {
  transform: scale(1.1);
}

.alturaitz-why-choose-card .content-wrap {
  position: relative;
  z-index: 2;
}

/* --- Ultra-Modern Tech About Page Styles --- */

/* --- Premium Services Bento Grid (Home Page) --- */
.premium-bento-services {
  background-color: #07070a;
}

.bento-card {
  position: relative;
  height: 500px;
  border-radius: 30px;
  overflow: hidden;
  background-color: #1a1a1c;
  transition: all 0.6s cubic-bezier(0.2, 1, 0.3, 1);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.4);
}

.col-lg-8 .bento-card {
  height: 500px;
}

.bento-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.bento-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.5;
  transition: transform 0.8s cubic-bezier(0.2, 1, 0.3, 1), opacity 0.5s ease;
}

.bento-card:hover .bento-img {
  transform: scale(1.1);
  opacity: 0.8;
}

.bento-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(7, 7, 10, 0) 0%, rgba(7, 7, 10, 0.9) 100%);
  z-index: 2;
}

.bento-content {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 40px;
  z-index: 5;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
}

.bento-num {
  font-size: 80px;
  font-weight: 800;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.1);
  position: absolute;
  top: 20px;
  left: 40px;
  line-height: 1;
  transition: all 0.5s ease;
}

.bento-card:hover .bento-num {
  -webkit-text-stroke: 1px #3fe0f7;
  transform: translateY(-5px);
}

.bento-title {
  font-size: 32px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 15px;
  text-transform: uppercase;
  letter-spacing: -1px;
}

.bento-desc {
  font-size: 16px;
  color: #a1a1aa;
  line-height: 1.5;
  margin-bottom: 25px;
  max-width: 80%;
  transition: all 0.5s cubic-bezier(0.2, 1, 0.3, 1) 0.1s;
  transform: translateY(0);
  opacity: 1;
}


.bento-link {
  width: 60px;
  height: 60px;
  background-color: #3fe0f7;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #000;
  transition: all 0.5s cubic-bezier(0.2, 1, 0.3, 1);
  transform: scale(0);
  position: absolute;
  bottom: 40px;
  right: 40px;
}

.bento-card:hover .bento-link {
  transform: scale(1);
}

.bento-link:hover {
  background-color: #fff;
  transform: scale(1.1) rotate(45deg);
}

/* Animations for Premium Bento SVGs */
.bento-card:hover .svg-ai-pulse {
  animation: aiPulse 2s infinite ease-in-out;
}

.bento-card:hover .svg-ai-node {
  animation: nodeFlash 1.5s infinite alternate;
}

.bento-card:hover .svg-radar-ring {
  animation: radarRipple 2s infinite linear;
}

.bento-card:hover .svg-marketing-rocket {
  animation: rocketHover 3s infinite ease-in-out;
}

.bento-card:hover .svg-strategy-path {
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
  animation: drawPath 2s forwards ease-out;
}

.bento-card:hover .svg-code-bracket {
  animation: bracketSqueeze 1s infinite alternate ease-in-out;
}

@keyframes aiPulse {
  0% {
    transform: scale(1);
    opacity: 0.1;
  }

  50% {
    transform: scale(1.4);
    opacity: 0.3;
  }

  100% {
    transform: scale(1);
    opacity: 0.1;
  }
}

@keyframes nodeFlash {
  from {
    opacity: 0.3;
    filter: blur(2px);
  }

  to {
    opacity: 1;
    filter: blur(0px);
  }
}

@keyframes radarRipple {
  from {
    transform: scale(0.5);
    opacity: 0.8;
  }

  to {
    transform: scale(2);
    opacity: 0;
  }
}

@keyframes rocketHover {

  0%,
  100% {
    transform: translate(0, 0);
  }

  50% {
    transform: translate(5px, -10px);
  }
}

@keyframes drawPath {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes bracketSqueeze {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(5px);
  }
}

/* --- Clean High-Definition Split (Service Page) --- */
.premium-clean-split {
  background-color: #07070a;
  overflow: hidden;
}

.pcs-tag {
  font-size: 13px;
  font-weight: 800;
  color: #3fe0f7;
  letter-spacing: 12px;
  display: block;
  margin-bottom: 25px;
  text-transform: uppercase;
}

.pcs-main {
  font-size: clamp(60px, 12vw, 180px);
  font-weight: 950;
  color: #fff;
  line-height: 0.8;
  letter-spacing: -10px;
  text-transform: uppercase;
  margin-bottom: 0;
  opacity: 1 !important;
  visibility: visible !important;
}

.pcs-list {
  margin-top: 50px;
}

.pcs-item {
  position: relative;
  width: 100%;
}

.pcs-reverse .pcs-row {
  flex-direction: row-reverse;
}

.pcs-meta {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 30px;
}

.pcs-num {
  font-size: 14px;
  font-weight: 800;
  color: #3fe0f7;
  letter-spacing: 2px;
}

.pcs-line {
  flex: 1;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.1);
}

.pcs-title {
  font-size: clamp(32px, 5vw, 75px);
  font-weight: 900;
  color: #fff;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 35px;
  opacity: 1 !important;
  visibility: visible !important;
}

.pcs-desc {
  font-size: 18px;
  color: #a1a1aa;
  line-height: 1.7;
  margin-bottom: 50px;
}

.pcs-btn {
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 15px;
  letter-spacing: 4px;
}

.pcs-btn svg {
  color: #3fe0f7;
  transition: transform 0.4s ease;
}

.pcs-btn:hover {
  color: #3fe0f7;
}

.pcs-btn:hover svg {
  transform: rotate(45deg);
  color: #3fe0f7;
}

.pcs-img-box {
  width: 100%;
  aspect-ratio: 4/3;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
}

.pcs-img-reveal {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.pcs-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: transform 1s cubic-bezier(0.2, 1, 0.3, 1);
}

.pcs-item:hover .pcs-img {
  transform: scale(1.05);
}

.pcs-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(7, 7, 10, 0.2);
}

@media (max-width: 991px) {
  .pcs-row {
    flex-direction: column-reverse !important;
    /* Force Image-First on Mobile Stacking */
    gap: 40px;
  }
}

/* --- Premium 3D Kinetic Mosaic (Service Page) --- */
.premium-kinetic-mosaic {
  background-color: #07070a;
  overflow: hidden;
  perspective: 2000px;
}

.pkm-header {
  max-width: 1200px;
  margin: 0 auto;
}

.pkm-sub {
  font-size: 14px;
  font-weight: 800;
  color: #3fe0f7;
  letter-spacing: 12px;
  display: block;
  margin-bottom: 30px;
  text-transform: uppercase;
}

.pkm-main {
  font-size: clamp(60px, 12vw, 220px);
  font-weight: 950;
  color: #fff;
  line-height: 0.8;
  letter-spacing: -10px;
  text-transform: uppercase;
  margin-bottom: 0;
}

.pkm-accent {
  color: #1a1a1c;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.2);
}

.pkm-viewport {
  width: 100%;
  margin-top: 100px;
  transform-style: preserve-3d;
  will-change: transform;
}

.pkm-grid {
  display: flex;
  gap: 60px;
  align-items: flex-start;
  transform-style: preserve-3d;
}

.pkm-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 60px;
  will-change: transform;
}

/* Staggered Vertical Offsets for Mosaic Feel */
.pkm-col-1 {
  margin-top: 0;
}

.pkm-col-2 {
  margin-top: 15vw;
}

.pkm-col-3 {
  margin-top: 30vw;
}

.pkm-item {
  position: relative;
  width: 100%;
  transform-style: preserve-3d;
}

.pkm-link {
  display: block;
  text-decoration: none;
}

.pkm-card {
  position: relative;
  background-color: #1a1a1c;
  padding: 40px;
  border-radius: 50px;
  transition: transform 0.6s cubic-bezier(0.2, 1, 0.3, 1);
  transform-style: preserve-3d;
}

.pkm-image-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 4/5;
  border-radius: 40px;
  overflow: hidden;
  margin-bottom: 40px;
}

.pkm-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: transform 1.2s cubic-bezier(0.2, 1, 0.3, 1);
  transform: scale(1.1);
}

.pkm-link:hover .pkm-image {
  transform: scale(1);
}

.pkm-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(7, 7, 10, 0) 50%, rgba(7, 7, 10, 0.6) 100%);
  z-index: 2;
}

.pkm-meta {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 25px;
}

.pkm-num {
  font-size: 16px;
  font-weight: 800;
  color: #3fe0f7;
  letter-spacing: 2px;
}

.pkm-line {
  flex: 1;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.1);
}

.pkm-title {
  font-size: clamp(28px, 3vw, 45px);
  font-weight: 900;
  color: #fff;
  text-transform: uppercase;
  line-height: 1;
  letter-spacing: -2px;
  margin-bottom: 25px;
}

.pkm-desc {
  font-size: 16px;
  color: #a1a1aa;
  line-height: 1.6;
  margin-bottom: 40px;
}

.pkm-arrow {
  color: #3fe0f7;
  transition: transform 0.4s ease;
}

.pkm-link:hover .pkm-arrow {
  transform: rotate(45deg) scale(1.3);
}

@media (max-width: 1200px) {
  .pkm-col-3 {
    display: none;
  }

  .pkm-col {
    width: 50%;
  }
}

@media (max-width: 767px) {
  .pkm-grid {
    flex-direction: column;
  }

  .pkm-col {
    width: 100%;
    margin-top: 0;
  }

  .pkm-card {
    padding: 30px;
  }
}

/* --- Service Header Section --- */
.alturaitz-pre-title-minimal {
  font-size: 14px;
  font-weight: 700;
  color: #3fe0f7;
  letter-spacing: 3px;
  text-transform: uppercase;
  opacity: 0.8;
}

.alturaitz-monumental-title {
  font-family: 'DM Sans', sans-serif;
  color: #fff;
  line-height: 1;
  text-transform: uppercase;
}

.alturaitz-text-gradient {
  background: linear-gradient(90deg, #fff 0%, #3fe0f7 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
}

.alturaitz-link-prestigious {
  display: inline-flex;
  align-items: center;
  gap: 15px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  transition: all 0.4s ease;
  position: relative;
  padding: 10px 0;
}

.alturaitz-link-prestigious .link-icon {
  width: 50px;
  height: 50px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #3fe0f7;
  transition: all 0.5s cubic-bezier(0.2, 1, 0.3, 1);
}

.alturaitz-link-prestigious .link-line {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background-color: #3fe0f7;
  transition: width 0.5s cubic-bezier(0.2, 1, 0.3, 1);
}

.alturaitz-link-prestigious:hover {
  color: #3fe0f7;
}

.alturaitz-link-prestigious:hover .link-icon {
  background-color: #3fe0f7;
  color: #121212;
  border-color: #3fe0f7;
  transform: rotate(45deg);
}

.alturaitz-link-prestigious:hover .link-line {
  width: calc(100% - 65px);
}

/* --- Elite Service Header Refinements --- */
.hsm-blur-orb {
  position: absolute;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(63, 224, 247, 0.05) 0%, transparent 70%);
  filter: blur(80px);
  z-index: -1;
  pointer-events: none;
}

.orb-1 {
  top: -20%;
  left: -10%;
}

.orb-2 {
  bottom: -10%;
  right: -5%;
  opacity: 0.5;
}

.hsm-status-dot {
  width: 8px;
  height: 8px;
  background-color: #3fe0f7;
  border-radius: 50%;
  box-shadow: 0 0 15px #3fe0f7;
  animation: pulse-cyan 2s infinite;
}

@keyframes pulse-cyan {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.5);
    opacity: 0.5;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.hsm-count-badge {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.4);
  letter-spacing: 2px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 8px 20px;
  border-radius: 50px;
  background-color: rgba(255, 255, 255, 0.02);
}

.hsm-service-line {
  width: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(63, 224, 247, 0.3), transparent);
  margin: 0 auto;
}

/* Updated Monumental Title Reveal Support */
.hsm-reveal {
  overflow: hidden;
}

.hsm-word {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1.2s cubic-bezier(0.2, 1, 0.3, 1);
}

.hsm-reveal.active .hsm-word {
  transform: translateY(0);
}

@media (max-width: 991px) {
  .alturaitz-monumental-title {
    font-size: 45px;
    margin-bottom: 40px;
  }

  .alturaitz-service-area {
    text-align: center;
    padding-bottom: 60px;
  }

  .text-lg-end {
    text-align: center !important;
  }
}

/* --- Masterpiece Horizontal Scroll (Home Page) --- */
.horizontal-scroll-masterpiece {
  background-color: #07070a;
  overflow: hidden;
  position: relative;
}

.hsm-pin-wrap {
  height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hsm-animation-wrap {
  display: flex;
  padding: 0 10vw;
  gap: 60px;
  will-change: transform;
}

.hsm-item {
  position: relative;
  width: 850px;
  height: 600px;
  flex-shrink: 0;
  border-radius: 40px;
  overflow: hidden;
  background-color: #1a1a1c;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 60px;
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.4);
  transition: transform 0.6s cubic-bezier(0.2, 1, 0.3, 1);
  transform-origin: center;
}

.hsm-item:hover {
  transform: scale(0.98);
}

.hsm-link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 20;
}

.hsm-bg {
  position: absolute;
  top: 0;
  left: -20%;
  width: 140%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0.4;
  z-index: 1;
  transition: opacity 0.6s ease;
}

.hsm-item:hover .hsm-bg {
  opacity: 0.7;
}

.hsm-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(7, 7, 10, 0) 0%, rgba(7, 7, 10, 0.8) 100%);
  z-index: 2;
}

.hsm-content {
  position: relative;
  z-index: 5;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  pointer-events: none;
}

.hsm-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.hsm-num {
  font-size: 100px;
  font-weight: 800;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.15);
  line-height: 0.8;
}

.hsm-arrow {
  width: 80px;
  height: 80px;
  background-color: #3fe0f7;
  color: #121212;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.4s cubic-bezier(0.2, 1, 0.3, 1);
}

.hsm-item:hover .hsm-arrow {
  transform: rotate(45deg);
  background-color: #fff;
}

.hsm-title {
  font-size: 55px;
  color: #fff;
  margin-bottom: 25px;
  font-weight: 700;
  line-height: 1.1;
  font-family: 'DM Sans', sans-serif;
  letter-spacing: -2px;
}

.hsm-desc {
  font-size: 20px;
  color: #a1a1a6;
  max-width: 85%;
  line-height: 1.6;
  margin-bottom: 0;
}

/* Responsive Stacking Policy */
@media (max-width: 991px) {
  .hsm-pin-wrap {
    height: auto;
    padding: 0px 0;
    display: block;
  }

  .hsm-animation-wrap {
    flex-direction: column;
    padding: 20px;
    gap: 40px;
    transform: none !important;
  }

  .hsm-item {
    width: 100%;
    height: auto;
    aspect-ratio: 4/5;
    padding: 40px;
  }

  .hsm-num {
    font-size: 60px;
  }

  .hsm-title {
    font-size: 38px;
  }
}

/* --- Bento Box Experience (Reflected from User Image) --- */
.alturaitz-bento-section {
  position: relative;
  overflow: hidden;
}

.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(300px, auto);
  gap: 24px;
  grid-template-areas:
    "card1 card1 card2 card2"
    "card3 card4 card4 card5"
    "card3 card6 card6 card5";
}

.bento-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 40px;
  padding: 50px;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(40px);
  -webkit-backdrop-filter: blur(40px);
  transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.bento-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(63, 224, 247, 0.4);
  transform: translateY(-5px);
  box-shadow: 0 50px 100px -20px rgba(0, 0, 0, 0.9);
}

.card-glow {
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle at center, rgba(63, 224, 247, 0.15) 0%, transparent 50%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.5s ease;
}

.bento-card:hover .card-glow {
  opacity: 1;
}

.card-1 {
  grid-area: card1;
}

.card-2 {
  grid-area: card2;
}

.card-3 {
  grid-area: card3;
}

.card-4 {
  grid-area: card4;
  padding: 0 !important;
}

.card-5 {
  grid-area: card5;
}

.card-6 {
  grid-area: card6;
}

.bento-title {
  font-size: 34px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 20px;
  letter-spacing: -1px;
}

.bento-desc {
  font-size: 18px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.6;
  margin-bottom: 30px;
}

.bento-btn {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff;
  padding: 14px 34px;
  border-radius: 100px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-self: flex-start;
  transition: all 0.4s ease;
}

.bento-btn:hover {
  background: #3fe0f7;
  color: #000;
  border-color: #3fe0f7;
  box-shadow: 0 0 20px rgba(63, 224, 247, 0.3);
}

/* Specific Card Visuals */
.bento-visual {
  position: relative;
  width: 100%;
  height: 300px;
  margin-top: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bento-visual img {
  max-width: 80%;
  object-fit: contain;
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.5));
}

.visual-full {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #00282d 0%, #050507 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.visual-code {
  font-family: 'Fira Code', monospace;
  font-size: 12px;
  color: #ff5fde;
}

.bento-card.card-3 .bento-title,
.bento-card.card-5 .bento-title {
  font-size: 24px;

}

.bento-card.card-3 .bento-desc,
.bento-card.card-5 .bento-desc {
  max-width: 100%;
  font-size: 16px;
}

/* Mobile Responsiveness */
@media (max-width: 1200px) {
  .bento-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas:
      "card1 card1"
      "card2 card2"
      "card3 card5"
      "card4 card4"
      "card6 card6";
  }
}

@media (max-width: 768px) {
  .bento-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "card1"
      "card2"
      "card3"
      "card5"
      "card6";
  }

  .card-4 {
    display: none;
  }

  /* Hide decorative visual card on small mobile */
  .bento-card {
    padding: 30px;
  }

  .bento-title {
    font-size: 24px;
  }
}

/* Visual Stage Enhancements */
.service-visual-stage {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
  position: sticky;
  top: 0;
  z-index: 2;
}

/* --- Titanium Tech Identity (Hero Section) --- */
.titanium-tech-identity {
  display: flex;
  align-items: flex-start;
  max-width: 750px;
  position: relative;
}

.tech-accent-line {
  width: 2px;
  height: 60px;
  background: linear-gradient(to bottom, var(--primary), transparent);
  border-radius: 2px;
  flex-shrink: 0;
  box-shadow: 0 0 15px rgba(63, 224, 247, 0.3);
}

.tech-text {
  margin: 0;
  font-family: 'Outfit', sans-serif;
  letter-spacing: 0.3px;
}

.tech-location-highlight {
  color: var(--primary);
  font-weight: 800;
  position: relative;
  display: inline-block;
  padding: 0 5px;
  text-shadow: 0 0 20px rgba(63, 224, 247, 0.2);
}

.tech-location-highlight::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--primary);
  opacity: 0.3;
}

.titanium-tech-identity:hover .tech-accent-line {
  height: 80px;
  background: var(--primary);
  box-shadow: 0 0 25px var(--primary);
  transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}

@media (max-width: 768px) {
  .titanium-tech-identity {
    gap: 15px;
  }

  .tech-accent-line {
    height: 100px;
  }
}

/* --- Executive About Section Modernization --- */
.alturaitz-about-it-content-modern {
  max-width: 600px;
}

.about-subtitle-badge {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: rgba(63, 224, 247, 0.08);
  border: 1px solid rgba(63, 224, 247, 0.2);
  padding: 6px 18px;
  border-radius: 100px;
}

.badge-dot {
  width: 8px;
  height: 8px;
  background: var(--primary);
  border-radius: 50%;
  box-shadow: 0 0 10px var(--primary);
  animation: badgePulse 2s infinite ease-in-out;
}

@keyframes badgePulse {

  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: 0.5;
    transform: scale(1.2);
  }
}

.badge-text {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 2px;
  color: #fff;
  text-transform: uppercase;
}

.about-title-monumental {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.about-title-monumental span {
  display: block;
}

.title-light {
  color: transparent;
  -webkit-text-stroke: 1px rgb(255 255 255 / 77%);
}

.title-bold {
  font-weight: 800;
  color: #fff;
  text-shadow: 0 0 30px rgba(255, 255, 255, 0.1);
}

.about-mission-box {
  position: relative;
  padding-left: 30px;
  margin-top: 40px;
  max-width: 90%;
}

.about-mission-box::before {
  content: '';
  position: absolute;
  left: 0;
  top: 5px;
  bottom: 5px;
  width: 2px;
  background: linear-gradient(to bottom, var(--primary), transparent);
  border-radius: 2px;
}

.mission-lead-text {
  font-family: 'Outfit', sans-serif;
  color: #fff;
}

/* --- Why Choose Us Header Modernization (Improved) --- */
.why-choose-us-header-modern {
  z-index: 5;
}

.header-monogram-bg {
  position: absolute;
  top: -40px;
  left: -20px;
  font-size: 200px;
  font-weight: 900;
  color: transparent;
  -webkit-text-stroke: 1px rgba(63, 224, 247, 0.03);
  line-height: 1;
  z-index: -1;
  pointer-events: none;
}

.why-choose-title-monumental {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.why-choose-title-monumental span {
  display: block;
}

.title-stroke {
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.4);
  transition: all 0.4s ease;
}

.title-solid {
  color: #fff;
}

.panel-icon {
  color: var(--primary);
  margin-bottom: 20px;
  opacity: 0.8;
}

.insight-text {
  font-family: 'Outfit', sans-serif;
  margin: 0;
  color: rgba(255, 255, 255, 0.8);
}

@media (max-width: 991px) {
  .header-monogram-bg {
    font-size: 120px;
    top: -20px;
  }

  .why-choose-title-monumental {
    font-size: 45px !important;
  }

  .professional-insight-panel {
    max-width: 500px;
  }

  .professional-insight-panel .panel-icon {
    display: none;
  }

  .why-choose-us-header-modern.mb-60 {
    margin-bottom: 20px;
  }
}

.stage-content {
  position: relative;
  z-index: 2;
}

.stage-num-bg {
  position: absolute;
  top: -40px;
  right: -20px;
  font-size: 180px;
  font-weight: 900;
  color: rgba(63, 224, 247, 0.05);
  line-height: 1;
  pointer-events: none;
}

.stage-title {
  font-size: 42px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 25px;
  text-transform: uppercase;
  letter-spacing: -1px;
}

.stage-desc {
  font-size: 18px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.7;
  margin-bottom: 40px;
  max-width: 90%;
}

.stage-tag {
  display: inline-block;
  padding: 8px 18px;
  background: rgba(63, 224, 247, 0.08);
  border: 1px solid rgba(63, 224, 247, 0.15);
  color: #3fe0f7;
  border-radius: 50px;
  font-size: 13px;
  font-weight: 700;
  margin: 0 10px 10px 0;
  text-transform: uppercase;
}

.stage-border {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 2px solid transparent;
  background: linear-gradient(#050507, #050507) padding-box,
    linear-gradient(45deg, transparent, rgba(63, 224, 247, 0.2), transparent) border-box;
  z-index: 1;
  border-radius: 40px;
}

/* Magnetic Utility */
.magnetic-wrap {
  display: inline-block;
  transition: transform 0.2s cubic-bezier(0.23, 1, 0.32, 1);
}

@media (max-width: 991px) {
  .service-visual-stage {
    display: none;
  }
}

.pml-left {
  display: flex;
  align-items: center;
  gap: 40px;
}

.pml-num {
  font-size: 18px;
  font-weight: 700;
  color: #3fe0f7;
}

.pml-title {
  font-size: clamp(32px, 5vw, 70px);
  font-weight: 800;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: -2px;
  transition: transform 0.5s cubic-bezier(0.2, 1, 0.3, 1);
}

.pml-item:hover .pml-title {
  transform: translateX(30px);
  color: #3fe0f7;
}

.pml-arrow {
  color: #fff;
  opacity: 0;
  transform: translateX(-30px);
  transition: all 0.5s cubic-bezier(0.2, 1, 0.3, 1);
}

.pml-item:hover .pml-arrow {
  opacity: 1;
  transform: translateX(0) rotate(45deg);
  color: #3fe0f7;
}

/* Floating Image Reveal */
/* ==========================================================================
   NEXUS CORE HERO V3 (EXACT IMAGE DESIGN)
   ========================================================================== */
.service-hero-v3 {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  padding-bottom: 60px;
}

.hero-v3-bg-beam {
  position: absolute;
  top: -20%;
  left: 0%;
  width: 100%;
  height: 150%;
  background: radial-gradient(circle at 20% 20%, rgba(63, 224, 247, 0.1) 0%, transparent 40%);
  pointer-events: none;
  z-index: 1;
}

.hero-v3-content {
  position: relative;
  z-index: 10;
  width: 100%;
}

/* Status Pill */
.hero-v3-status {
  margin-bottom: 40px;
}

.status-pill {
  background: rgba(63, 224, 247, 0.05);
  border: 1px solid rgba(63, 224, 247, 0.2);
  padding: 10px 20px;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 600;
  color: #3fe0f7;
  letter-spacing: 1px;
}

/* Typography */
.hero-v3-title {
  font-size: clamp(30px, 5vw, 60px);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 25px;
  max-width: 716px;
}

.hero-v3-title span {
  color: #3fe0f7;
}

.hero-v3-desc {
  font-size: 18px;
  color: rgba(255, 255, 255, 0.6);
  max-width: 650px;
}

/* VISUAL SYSTEM (ARC LAYOUT) */
.nexus-visual-wrap {
  position: relative;
  width: 100%;
  height: 500px;
  margin-top: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Hyper Core */
/* ==========================================================================
   ARCHITECT HYPER-CORE (MINIMALIST PRECISION)
   ========================================================================== */
.nexus-core.architect-mode {
  width: 400px;
  height: 400px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
}

/* 1. HAIRLINE CROSSHAIRS */
.architect-crosshair {
  position: absolute;
  background: rgba(63, 224, 247, 0.2);
  z-index: 1;
}

.h-line {
  width: 400px;
  height: 1px;
}

.v-line {
  width: 1px;
  height: 400px;
}

/* 2. KINETIC BRACKETS */
.architect-brackets {
  position: absolute;
  width: 120px;
  height: 120px;
  z-index: 5;
  animation: bracketPulse 4s infinite ease-in-out;
}

.bracket {
  position: absolute;
  width: 15px;
  height: 15px;
  border: 1px solid #3fe0f7;
}

.tl {
  top: 0;
  left: 0;
  border-right: none;
  border-bottom: none;
}

.tr {
  top: 0;
  right: 0;
  border-left: none;
  border-bottom: none;
}

.bl {
  bottom: 0;
  left: 0;
  border-right: none;
  border-top: none;
}

.br {
  bottom: 0;
  right: 0;
  border-left: none;
  border-top: none;
}

/* 3. THE SINGULARITY */
.architect-singularity {
  width: 4px;
  height: 4px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 10px #fff;
  z-index: 10;
  animation: singularityPulse 2s infinite ease-in-out;
}

/* 4. SCAN NODES */
.scan-node {
  position: absolute;
  width: 3px;
  height: 3px;
  background: #3fe0f7;
  border-radius: 50%;
  box-shadow: 0 0 8px #3fe0f7;
  z-index: 2;
}

/* .node-1 {
  animation: nodeScanH 3s infinite linear;
}

.node-2 {
  animation: nodeScanV 4s infinite linear reverse;
} */

/* ANIMATIONS */
@keyframes bracketPulse {

  0%,
  100% {
    transform: scale(1);
    opacity: 0.5;
  }

  50% {
    transform: scale(1.2);
    opacity: 1;
  }
}

@keyframes singularityPulse {

  0%,
  100% {
    transform: scale(1);
    opacity: 0.7;
  }

  50% {
    transform: scale(1.5);
    opacity: 1;
  }
}

@keyframes nodeScanH {
  0% {
    left: 0;
    opacity: 0;
  }

  10%,
  90% {
    opacity: 1;
  }

  100% {
    left: 100%;
    opacity: 0;
  }
}

@keyframes nodeScanV {
  0% {
    top: 0;
    opacity: 0;
  }

  10%,
  90% {
    opacity: 1;
  }

  100% {
    top: 100%;
    opacity: 0;
  }
}

/* DATA SHARDS (ARC POSITIONS) */
.data-shard {
  position: absolute;
  width: 180px;
  background: rgba(15, 15, 18, 0.4);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  padding: 15px;
  text-align: left;
  z-index: 6;
  transition: all 0.3s ease;
}

.shard-header {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 12px;
  font-weight: 600;
}

/* ARC POSITIONS */
.shard-targeting {
  top: -10%;
  left: 10%;
}

.shard-revenue {
  bottom: 0%;
  left: 15%;
}

.shard-install {
  top: -5%;
  right: 10%;
}

.shard-engagement {
  bottom: 5%;
  right: 15%;
}

/* VISUALIZATIONS */
.shard-visual {
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Radar */
.svg-radar {
  width: 100%;
  height: 100%;
}

.radar-sweep {
  transform-origin: 50px 50px;
  animation: radarRotate 3s linear infinite;
}

/* Line Chart */
.line-path {
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
  animation: lineDraw 4s infinite alternate;
}

/* Bar Chart */
.bar-chart {
  display: flex;
  gap: 4px;
  align-items: flex-end;
  width: 100%;
  height: 100%;
}

.bar {
  flex: 1;
  background: linear-gradient(to top, #3fe0f7, transparent);
  border-radius: 2px;
  animation: barRise 2s infinite alternate ease-in-out;
}

.bar:nth-child(2) {
  animation-delay: 0.2s;
}

.bar:nth-child(3) {
  animation-delay: 0.4s;
}

.bar:nth-child(4) {
  animation-delay: 0.6s;
}

/* Mobile Frame */
.mobile-frame {
  width: 40px;
  height: 70px;
  border: 2px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  position: relative;
}

.social-icon {
  position: absolute;
  color: #3fe0f7;
  font-size: 10px;
  animation: floatBubble 3s infinite ease-in-out;
}

.social-icon:nth-child(1) {
  top: -10px;
  right: -20px;
}

.social-icon:nth-child(2) {
  top: 20px;
  left: -25px;
}

.social-icon:nth-child(3) {
  bottom: 10px;
  right: -25px;
}

/* ANIMATIONS */
@keyframes radarRotate {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes lineDraw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes barRise {
  from {
    transform: scaleY(0.3);
  }

  to {
    transform: scaleY(1);
  }
}

@keyframes floatBubble {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }
}

/* Social Proof */
.hero-v2-proof {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.proof-avatars {
  display: flex;
  align-items: center;
}

.proof-avatars img {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  border: 2px solid #050709;
  margin-left: -12px;
}

.proof-avatars img:first-child {
  margin-left: 0;
}

.proof-text {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
}

@media (max-width: 991px) {
  .hero-glass-panel {
    width: 60%;
  }

  .panel-left {
    left: -30%;
  }

  .panel-right {
    right: -30%;
  }

  .hero-v2-title {
    font-size: 50px;
  }
}


.magnetic-image-reveal {
  position: fixed;
  top: 0;
  left: 0;
  width: 400px;
  height: 500px;
  pointer-events: none;
  z-index: 1000;
  overflow: hidden;
  border-radius: 20px;
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.2, 1, 0.3, 1);
}

.magnetic-image-reveal.active {
  opacity: 1;
  transform: scale(1);
}

.mir-inner {
  width: 100%;
  height: 100%;
}

.mir-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 991px) {
  .pml-link {
    padding: 30px 0;
  }

  .pml-title {
    font-size: 30px;
    letter-spacing: -1px;
  }

  .magnetic-image-reveal {
    display: none;
  }
}

.alturaitz-modern-tech-section {
  padding: 120px 0;
  background: #121212;
  position: relative;
  z-index: 1;
}

.alturaitz-tab-nav {
  display: flex;
  gap: 20px;
  margin-bottom: 40px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding-bottom: 20px;
}

.alturaitz-modern-tab-btn {
  background: transparent;
  border: none;
  color: #7a7a7a;
  font-size: 24px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  cursor: pointer;
  position: relative;
  transition: color 0.3s ease;
  padding: 0;
}

.alturaitz-modern-tab-btn.active {
  color: #fff;
}

.alturaitz-modern-tab-btn::after {
  content: '';
  position: absolute;
  bottom: -21px;
  left: 0;
  width: 0%;
  height: 2px;
  background: #e5ff4e;
  transition: width 0.3s ease;
}

.alturaitz-modern-tab-btn.active::after {
  width: 100%;
}

.alturaitz-tab-content {
  display: none;
  animation: fadeIn 0.5s ease forwards;
}

.alturaitz-tab-content.active {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.alturaitz-tech-image {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
}

.alturaitz-tech-image::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at top right, rgba(229, 255, 78, 0.2), transparent 50%);
  pointer-events: none;
}

.alturaitz-minimal-card {
  background: #1a1a1c;
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  padding: 50px 40px;
  height: 100%;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.alturaitz-minimal-card:hover {
  background: #1e1e20;
  border-color: rgba(229, 255, 78, 0.3);
  transform: translateY(-5px);
}

.alturaitz-glow-dot {
  position: absolute;
  top: 30px;
  right: 30px;
  width: 8px;
  height: 8px;
  background: #333;
  border-radius: 50%;
  transition: all 0.4s ease;
}

.alturaitz-minimal-card:hover .alturaitz-glow-dot {
  background: #e5ff4e;
  box-shadow: 0 0 15px 5px rgba(229, 255, 78, 0.4);
}


.alturaitz-accordion-section {
  padding: 120px 0;
  background: #000;
}

.alturaitz-flex-accordion {
  display: flex;
  width: 100%;
  height: 600px;
  gap: 20px;
}

.alturaitz-accordion-item {
  flex: 1;
  position: relative;
  background: #1a1a1c;
  border-radius: 20px;
  overflow: hidden;
  transition: flex 0.6s cubic-bezier(0.25, 1, 0.5, 1);
  cursor: pointer;
  border: 1px solid rgba(255, 255, 255, 0.05);
  display: flex;
  align-items: flex-end;
}

.alturaitz-accordion-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0) 100%);
  z-index: 1;
}

.alturaitz-accordion-item:hover {
  flex: 5;
  border-color: rgba(229, 255, 78, 0.5);
}

.alturaitz-accordion-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  filter: grayscale(100%) brightness(0.5);
  transition: filter 0.6s ease, transform 1s ease;
}

.alturaitz-accordion-item:hover .alturaitz-accordion-bg {
  filter: grayscale(0%) brightness(0.8);
  transform: scale(1.05);
}

.alturaitz-accordion-content {
  position: relative;
  z-index: 2;
  padding: 40px;
  width: 100%;
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1);
  transition-delay: 0s;
  pointer-events: none;
}

.alturaitz-accordion-item:hover .alturaitz-accordion-content {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.2s;
}

.alturaitz-accordion-title-vert {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%) rotate(-90deg);
  transform-origin: left bottom;
  color: #fff;
  font-size: 40px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: 2px;
  transition: opacity 0.3s ease;
  z-index: 3;
}

.alturaitz-accordion-item:hover .alturaitz-accordion-title-vert {
  opacity: 0;
}

@media (max-width: 991px) {
  .alturaitz-flex-accordion {
    flex-direction: column;
    height: 800px;
  }

  .alturaitz-accordion-title-vert {
    transform: none;
    left: 40px;
    bottom: 20px;
  }
}

/* --- Distinct Career Page Styles (Raw Typography & Timeline) --- */
.alturaitz-career-raw-list {
  display: flex;
  flex-direction: column;
}

.alturaitz-career-row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding: 40px 20px;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.alturaitz-career-row:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.alturaitz-career-row-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 0%;
  height: 100%;
  background: var(--primary);
  z-index: 1;
  transition: width 0.6s cubic-bezier(0.85, 0, 0.15, 1);
}

.alturaitz-career-row:hover .alturaitz-career-row-bg {
  width: 100%;
}

.alturaitz-career-row-content {
  position: relative;
  z-index: 2;
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}

.transition-color {
  transition: color 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}

.alturaitz-career-row:hover .transition-color {
  color: #121212 !important;
}

.alturaitz-career-row-arrow svg {
  transition: transform 0.4s ease;
}

.alturaitz-career-row:hover .alturaitz-career-row-arrow svg {
  transform: translateX(10px);
  stroke: #121212;
}

/* Timeline Process */
.alturaitz-career-timeline {
  display: flex;
  justify-content: space-between;
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
}

.alturaitz-timeline-line {
  position: absolute;
  top: 40px;
  left: 5%;
  width: 90%;
  height: 2px;
  background: repeating-linear-gradient(to right, rgba(255, 255, 255, 0.1) 0, rgba(255, 255, 255, 0.1) 10px, transparent 10px, transparent 20px);
  z-index: 1;
}

.alturaitz-timeline-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 2;
  cursor: pointer;
  flex: 1;
}

.alturaitz-timeline-node {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: #111;
  border: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: 700;
  color: #fff;
  transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}

.alturaitz-timeline-step:hover .alturaitz-timeline-node {
  background: var(--primary);
  color: #121212;
  border-color: var(--primary);
  box-shadow: 0 0 30px #3fe0f775;
  transform: scale(1.15) translateY(-5px);
}

@media (max-width: 768px) {
  .alturaitz-career-timeline {
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }

  .alturaitz-timeline-line {
    width: 2px;
    height: 90%;
    top: 5%;
    left: 50%;
    background: repeating-linear-gradient(to bottom, rgba(255, 255, 255, 0.1) 0, rgba(255, 255, 255, 0.1) 10px, transparent 10px, transparent 20px);
  }

  .alturaitz-career-row-content h3 {
    font-size: 24px !important;
  }

  .alturaitz-career-row-content span {
    font-size: 24px !important;
    margin-right: 20px !important;
  }
}

/* Infinite Marquee */
.alturaitz-career-stack-section {
  background: #121212;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.alturaitz-stack-marquee-wrap {
  display: flex;
  flex-direction: column;
  white-space: nowrap;
}

.alturaitz-stack-marquee {
  display: flex;
  width: max-content;
  animation: stackScroll 40s linear infinite;
}

.alturaitz-stack-marquee.reverse {
  animation-direction: reverse;
  animation-duration: 35s;
}

@keyframes stackScroll {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

/* About Page - The Titanium Monolith Ethos (Executive Model) */
.alturaitz-monolith-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  width: 100%;
  margin-top: 60px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

@media (max-width: 1300px) {
  .alturaitz-monolith-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .alturaitz-monolith-row {
    grid-template-columns: repeat(1, 1fr);
  }
}

.alturaitz-monolith-item {
  flex: 1;
  padding: 40px 35px;
  position: relative;
  border-right: 1px solid rgba(255, 255, 255, 0.05);
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  min-width: 250px;
  background: #080808;
}

.alturaitz-monolith-item:last-child {
  border-right: none;
}

@media (max-width: 767px) {
  .alturaitz-monolith-item {
    flex: 0 0 100%;
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding: 20px;
  }

  .alturaitz-monolith-row {
    margin-top: 30px;
  }

  .alturaitz-matrix-section .mb-60 {
    margin-bottom: 30px;
  }
}

.monolith-identity {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 30px;
}

.monolith-dot {
  width: 8px;
  height: 8px;
  background: var(--primary);
  border-radius: 50%;
  position: relative;
  display: inline-block;
}

.monolith-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border: 1px solid var(--primary);
  border-radius: 50%;
  animation: pulseDot 2s infinite;
}

@keyframes pulseDot {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  100% {
    transform: scale(2.5);
    opacity: 0;
  }
}

.monolith-title {
  font-size: 32px;
  font-weight: 800;
  color: transparent;
  -webkit-text-stroke: 1px rgb(255 255 255 / 73%);
  text-transform: uppercase;
  letter-spacing: 2px;
  transition: all 0.4s ease;
  position: relative;
}

.monolith-body {
  position: relative;
  z-index: 2;
  transition: all 0.4s ease;
}

.monolith-desc {
  font-size: 18px;
  color: #fff;
  line-height: 1.6;
  transition: all 0.4s ease;
}

/* --- TECHNICAL BRACKET REVEAL --- */
.alturaitz-monolith-item::before,
.alturaitz-monolith-item::after {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  border-color: var(--primary);
  border-style: solid;
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 10;
}

/* Top-Left and Bottom-Right Brackets */
.alturaitz-monolith-item::before {
  top: 10px;
  left: 10px;
  border-width: 2px 0 0 2px;
  transform: translate(-10px, -10px);
}

.alturaitz-monolith-item::after {
  bottom: 10px;
  right: 10px;
  border-width: 0 2px 2px 0;
  transform: translate(10px, 10px);
}

/* Hover States */
.alturaitz-monolith-item:hover {
  background: #0c0c0c;
}

.alturaitz-monolith-item:hover::before,
.alturaitz-monolith-item:hover::after {
  opacity: 1;
  transform: translate(0, 0);
}

.alturaitz-monolith-item:hover .monolith-title {
  -webkit-text-stroke: 1px var(--primary);
  text-shadow: 0 0 15px rgba(63, 224, 247, 0.3);
}

.alturaitz-monolith-item:hover .monolith-desc {
  color: rgba(255, 255, 255, 0.8);
  transform: translateX(10px);
}

.alturaitz-monolith-item:hover .monolith-dot {
  background: #fff;
  box-shadow: 0 0 10px #fff;
}

/* --- Glass Orb Visual (Extreme Modern Aesthetic) --- */
.glass-orb-wrap {
  width: 200px;
  height: 200px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.glass-orb {
  width: 140px;
  height: 140px;
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.1) 0%, rgba(138, 79, 255, 0.05) 50%, rgba(0, 0, 0, 0.2) 100%);
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
  z-index: 2;
  box-shadow:
    inset 0 10px 30px rgba(255, 255, 255, 0.1),
    inset 0 -10px 30px rgba(0, 0, 0, 0.4),
    0 20px 40px rgba(0, 0, 0, 0.5);
  animation: orbFloat 6s infinite ease-in-out;
}

.orb-shine {
  position: absolute;
  top: 15%;
  left: 15%;
  width: 30%;
  height: 30%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.2) 0%, transparent 80%);
  border-radius: 50%;
  transform: rotate(-15deg);
}

.orb-glow {
  position: absolute;
  width: 120%;
  height: 120%;
  background: radial-gradient(circle, rgba(138, 79, 255, 0.2) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(20px);
  z-index: 1;
  animation: orbPulse 4s infinite ease-in-out;
}

@keyframes orbFloat {

  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  50% {
    transform: translateY(-15px) scale(1.05);
  }
}

@keyframes orbPulse {

  0%,
  100% {
    transform: scale(0.8);
    opacity: 0.5;
  }

  50% {
    transform: scale(1.1);
    opacity: 0.8;
  }
}

@keyframes rotateLine {
  0% {
    transform: translateX(-50%) rotate(0deg);
  }

  100% {
    transform: translateX(-50%) rotate(360deg);
  }
}

.alturaitz-matrix-cell:hover::before {
  width: 200%;
  height: 200%;
}

.alturaitz-matrix-cell .matrix-num {
  display: block;
  font-size: 80px;
  font-family: 'Teko', sans-serif;
  font-weight: 700;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.1);
  line-height: 1;
  margin-bottom: 20px;
  transition: all 0.4s ease;
}

.alturaitz-matrix-cell:hover .matrix-num {
  color: var(--primary);
  -webkit-text-stroke: 0;
}

/* About Page - Epic Accordion */
.epic-accordion-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.epic-accordion-item:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.epic-accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 30px 0;
  cursor: pointer;
  transition: color 0.3s ease;
}

.epic-accordion-header:hover h3 {
  color: var(--primary) !important;
}

.epic-accordion-header h3 {
  transition: color 0.3s ease;
}

.epic-icon {
  font-size: 30px;
  color: #fff;
  font-weight: 300;
  transition: transform 0.4s ease;
}

.epic-accordion-item.active .epic-icon {
  transform: rotate(45deg);
  color: var(--primary);
}

.epic-accordion-body {
  display: none;
}

.alturaitz-footer-bg-image {
  position: absolute;
  max-width: 830px;
  width: 100%;
  bottom: -100px;
  right: -200px;
  opacity: 0.5;
}

.alturaitz-footer-bg-image svg {
  width: 100%;
  height: auto;
}

footer {
  overflow: hidden;
}

/* Hide cursor on mobile */
@media (max-width: 991px) {

  #magic-cursor,
  #ball {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
  }
}

.alturaitz-commitment-section {
  overflow-x: hidden;
}

.alturaitz-hero-bottom {
  overflow: hidden;
}

.why-choose-us-title span,
.alturaitz-text-revel-anim span {
  color: transparent;
  -webkit-text-stroke: 1px rgb(255 255 255 / 53%);
}

.alturaitz-monumental-title span {
  color: transparent;
  -webkit-text-stroke: 1px rgb(255 255 255 / 53%);
}

/* --- Exclusive Counter Hover Signature --- */
.alturaitz-counter-item {
  position: relative;
  overflow: hidden;
  transition: all 0.6s cubic-bezier(0.2, 1, 0.3, 1);
  padding: 45px 35px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  z-index: 1;
}

.alturaitz-counter-item:hover {
  transform: translateY(-15px);
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(63, 224, 247, 0.5);
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.6), 0 0 20px rgba(63, 224, 247, 0.1);
}

/* Cosmic Inner Glow */
.alturaitz-counter-item::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0%;
  height: 0%;
  background: radial-gradient(circle, rgba(63, 224, 247, 0.15) 0%, transparent 75%);
  transform: translate(-50%, -50%);
  transition: width 0.7s ease, height 0.7s ease;
  z-index: -1;
  border-radius: 50%;
}

.alturaitz-counter-item:hover::after {
  width: 280%;
  height: 280%;
}

.alturaitz-counter-item h2 {
  transition: all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.alturaitz-counter-item:hover h2 {
  color: #3fe0f7 !important;
  transform: scale(1.15) translateY(-5px);
  text-shadow: 0 0 25px rgba(63, 224, 247, 0.4);
}

.alturaitz-counter-item p {
  transition: all 0.5s ease;
  opacity: 0.6;
}

.alturaitz-counter-item:hover p {
  opacity: 1;
  color: #fff;
  transform: translateY(-3px);
}

/* --- The Cinematic Promise Highlight --- */
.alturaitz-promise-highlight {
  margin-top: 80px;
}

.promise-wrap {
  padding: 30px 60px;
  background: rgba(63, 224, 247, 0.03);
  border: 1px solid rgba(63, 224, 247, 0.15);
  border-radius: 100px;
  backdrop-filter: blur(10px);
  box-shadow: 0 0 40px rgba(63, 224, 247, 0.05);
  transition: all 0.5s ease;
}

.promise-wrap:hover {
  background: rgba(63, 224, 247, 0.06);
  border-color: rgba(63, 224, 247, 0.3);
  transform: translateY(-5px);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.3), 0 0 30px rgba(63, 224, 247, 0.1);
}

.promise-seal {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  background: #030303;
  padding: 8px;
  border-radius: 50%;
  border: 1px solid rgba(63, 224, 247, 0.3);
  box-shadow: 0 0 20px rgba(63, 224, 247, 0.2);
}

.promise-text {
  margin: 0;
  letter-spacing: 1px;
}

.text-cyan {
  color: #3fe0f7 !important;
  text-transform: uppercase;
  font-weight: 800;
  text-shadow: 0 0 10px rgba(63, 224, 247, 0.3);
}

.promise-line-left,
.promise-line-right {
  position: absolute;
  top: 50%;
  width: 100px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(63, 224, 247, 0.4));
}

.promise-line-left {
  right: 100%;
  margin-right: 30px;
  background: linear-gradient(90deg, transparent, rgba(63, 224, 247, 0.4));
}

.promise-line-right {
  left: 100%;
  margin-left: 30px;
  background: linear-gradient(-90deg, transparent, rgba(63, 224, 247, 0.4));
}

@media (max-width: 991px) {
  .promise-wrap {
    padding: 20px 30px;
    border-radius: 20px;
  }

  .promise-line-left,
  .promise-line-right {
    display: none;
  }
}

/* --- Premium Header Menu Animations --- */
.alturaitz-main-menu nav ul li {
  position: relative;
  overflow: hidden;
}

.alturaitz-main-menu nav ul li a {
  position: relative;
  transition: color 0.4s ease;
  z-index: 1;
}

/* Hover: The Digital Pulse Underline */
.alturaitz-main-menu nav ul li a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: -100%;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, #3fe0f7, transparent);
  transition: left 0.6s cubic-bezier(0.65, 0, 0.35, 1);
}

.alturaitz-main-menu nav ul li a:hover {
  color: #3fe0f7 !important;
}

.alturaitz-main-menu nav ul li a:hover::after {
  left: 100%;
}

/* Click: The 'Run' Effect */
.menu-item-clicked a {
  animation: menuPulse 0.5s ease;
}

.menu-item-clicked a::before {
  content: '';
  position: absolute;
  top: 0;
  left: -50%;
  width: 150%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(63, 224, 247, 0.2), transparent);
  animation: menuRun 0.4s ease forwards;
  pointer-events: none;
  z-index: -1;
}

@keyframes menuPulse {
  0% {
    transform: scale(1);
    filter: brightness(1);
  }

  50% {
    transform: scale(1.05);
    filter: brightness(1.5);
    color: #fff;
  }

  100% {
    transform: scale(1);
    filter: brightness(1);
  }
}

@keyframes menuRun {
  0% {
    left: -150%;
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    left: 150%;
    opacity: 0;
  }
}

/* --- Smoking Cursor Canvas Overlay --- */
#smoke-cursor-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 9999998;
  /* Just below the physical cursor ball */
  background: transparent;
}

#magic-cursor {
  z-index: 9999999;
}

/* --- Interlocking Nexus About (Modern Circle Model) --- */
.alturaitz-about-nexus {
  background: #080a0c;
  position: relative;
}

.nexus-bg-scroll {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 1;
  opacity: 0.03;
  white-space: nowrap;
}

.nexus-bg-text {
  font-size: 20vw;
  font-weight: 800;
  color: #fff;
  letter-spacing: -10px;
}

.nexus-matrix-wrap {
  perspective: 1000px;
}

.nexus-matrix {
  gap: -40px;
  /* Overlap effect */
}

.nexus-orb {
  width: 380px;
  height: 380px;
  border-radius: 50%;
  position: relative;
  margin: 0 -40px;
  /* Force overlap */
  transition: transform 0.6s cubic-bezier(0.23, 1, 0.32, 1);
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.orb-glass {
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 40px;
  z-index: 2;
}

.nexus-orb:hover {
  transform: translateY(-20px) scale(1.05);
  z-index: 10 !important;
}

.nexus-orb:hover .orb-glass {
  background: rgba(255, 255, 255, 0.08);
  border-color: #3fe0f7;
  box-shadow: 0 0 50px rgba(63, 224, 247, 0.2);
}

.orb-number {
  font-size: 80px;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: 10px;
  letter-spacing: -2px;
}

.orb-label {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.5);
  max-width: 120px;
}

.orb-glow {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 120%;
  height: 120%;
  background: radial-gradient(circle, rgba(63, 224, 247, 0.05) 0%, transparent 70%);
  transform: translate(-50%, -50%);
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s ease;
}

.nexus-orb:hover .orb-glow {
  opacity: 1;
}

/* Specific Z-indexing to ensure overlap pattern */
.orb-1 {
  z-index: 1;
}

.orb-2 {
  z-index: 2;
}

.orb-3 {
  z-index: 3;
}

.orb-4 {
  z-index: 2;
}

/* Strategic Content */
.nexus-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.badge-line {
  width: 80px;
  height: 1px;
  background: linear-gradient(90deg, transparent, #3fe0f7, transparent);
}

.badge-text {
  color: #3fe0f7;
  font-size: 14px;
}

@media (max-width: 1199px) {
  .nexus-matrix {
    flex-wrap: wrap;
    gap: 20px;
  }

  .nexus-orb {
    margin: 0;
    width: 250px;
    height: 250px;
  }
}

/* --- Orbital Counter System --- */
.alturaitz-orbital-counter-container {
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 500px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 5;
}

.orbital-grid-bg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  height: 80%;
  background-image: radial-gradient(rgba(63, 224, 247, 0.1) 1px, transparent 1px);
  background-size: 30px 30px;
  mask-image: radial-gradient(circle, black 40%, transparent 70%);
  z-index: -1;
  pointer-events: none;
}

/* Central Core */
.orbital-core {
  width: 200px;
  height: 200px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(15px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  z-index: 10;
  box-shadow: 0 0 50px rgba(63, 224, 247, 0.1);
}

.core-inner {
  z-index: 2;
}

.core-number {
  font-size: 84px;
  font-weight: 800;
  color: var(--primary);
  line-height: 1;
  margin: 0;
}

.core-number .plus {
  font-size: 0.6em;
  vertical-align: top;
  margin-left: 2px;
}

.core-label {
  display: block;
  font-size: 11px;
  line-height: 18px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.6);
  margin-top: 5px;
  text-transform: uppercase;
}

.core-pulse {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: var(--primary);
  opacity: 0.1;
  z-index: 1;
  animation: corePulse 3s infinite ease-out;
}

.core-orbit-ring {
  position: absolute;
  top: -20px;
  left: -20px;
  right: -20px;
  bottom: -20px;
  border: 1px dashed rgba(63, 224, 247, 0.2);
  border-radius: 50%;
  animation: rotate-orbit 20s linear infinite;
}

/* Satellites */
.orbital-satellite {
  position: absolute;
  z-index: 15;
  transition: transform 0.3s ease;
}

.sat-inner {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  padding: 15px 20px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 160px;
  max-width: 250px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.social-icon {
  width: 30px;
  height: 30px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.8);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.2));
}

.social-icon svg {
  width: 14px;
  height: 14px;
  display: block;
}

/* Specific Icon Animations */
.icon-heart svg {
  animation: heartPulse 2s infinite ease-in-out;
}

.icon-chat svg {
  animation: floatBounce 3s infinite ease-in-out;
}

@keyframes heartPulse {

  0%,
  100% {
    transform: scale(1);
    opacity: 0.8;
  }

  50% {
    transform: scale(1.15);
    opacity: 1;
    filter: drop-shadow(0 0 8px #3fe0f7);
  }
}

@keyframes floatBounce {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-3px);
  }
}

/* Hover States - Ignition */
.social-icon:hover {
  background: rgba(63, 224, 247, 0.15);
  border-color: #3fe0f7;
  color: #3fe0f7;
  transform: scale(1.2) translateY(-5px);
  filter: drop-shadow(0 0 15px #3fe0f7);
}

.sat-icon {
  width: 35px;
  height: 35px;
  min-width: 35px;
  background: rgba(63, 224, 247, 0.1);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
}

.sat-content {
  display: flex;
  font-size: 12px;
  color: #fff;
  margin-top: 2px;
  gap: 3px;
  flex-wrap: wrap;
  line-height: 10px;
}

.sat-num.purecounter,
.sat-content .plus {
  font-size: 40px !important;
  font-weight: 700;
  color: var(--primary);
  line-height: 16px;
  position: relative;
  left: auto;
  right: auto;
  top: auto;
  bottom: auto;
}

.sat-label {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
  margin-top: 2px;
}

/* Positioning Satellites */
.sat-1 {
  top: 5%;
  right: 0;
  animation: satFloat1 6s infinite ease-in-out;
}

.sat-2 {
  top: 15%;
  left: -5%;
  animation: satFloat2 8s infinite ease-in-out;
  animation-delay: -2s;
}

.sat-3 {
  bottom: 10%;
  right: -5%;
  animation: satFloat1 7s infinite ease-in-out;
  animation-delay: -1s;
}

.sat-4 {
  bottom: 5%;
  left: 5%;
  animation: satFloat2 9s infinite ease-in-out;
  animation-delay: -3s;
}

/* Animations */
@keyframes corePulse {
  0% {
    transform: scale(1);
    opacity: 0.3;
  }

  100% {
    transform: scale(1.5);
    opacity: 0;
  }
}

@keyframes rotate-orbit {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes satFloat1 {

  0%,
  100% {
    transform: translate(0, 0);
  }

  50% {
    transform: translate(10px, -15px);
  }
}

@keyframes satFloat2 {

  0%,
  100% {
    transform: translate(0, 0);
  }

  50% {
    transform: translate(-10px, 15px);
  }
}

/* Responsive */
@media (max-width: 991px) {
  .alturaitz-orbital-counter-container {
    max-width: 400px;
    margin-bottom: 60px;
  }

  .orbital-core {
    width: 160px;
    height: 160px;
  }

  .core-number {
    font-size: 48px;
  }

  .sat-inner {
    padding: 10px 15px;
    min-width: 140px;
  }
}

@media (max-width: 575px) {
  .alturaitz-orbital-counter-container {
    max-width: 100%;
    height: 450px;
    aspect-ratio: auto;
  }

  .sat-inner {
    min-width: 130px;
    transform: scale(0.9);
  }

  .sat-1 {
    right: -10px;
  }

  .sat-2 {
    left: -10px;
  }

  .sat-3 {
    right: -10px;
  }

  .sat-4 {
    left: -10px;
  }
}

/* --- Premium Service Navigator Redesign --- */
.service-navigator {
  padding-left: 20px;
  position: relative;
}

.service-navigator::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50px;
  bottom: 50px;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(63, 224, 247, 0.2), transparent);
}

.nav-item {
  cursor: pointer;
  padding: 40px 30px;
  position: relative;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.nav-item:last-child {
  border-bottom: none;
}

.nav-item-header {
  display: flex;
  align-items: flex-start;
  gap: 30px;
}

.nav-num {
  font-size: 16px;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.3);
  padding-top: 12px;
  transition: all 0.4s ease;
}

.nav-title {
  font-size: 42px;
  font-weight: 900;
  color: rgba(255, 255, 255, 0.4);
  text-transform: uppercase;
  letter-spacing: -2px;
  line-height: 1.1;
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

/* Active State Enhancements */
.nav-item.active {
  background: rgba(63, 224, 247, 0.03);
}

.nav-item.active .nav-num {
  color: var(--primary);
  transform: scale(1.2);
}

.nav-item.active .nav-title {
  color: #fff;
  transform: translateX(10px);
}

.nav-item.active .nav-active-line {
  width: 60px;
  background: var(--primary);
  box-shadow: 0 0 15px var(--primary);
}

.nav-active-line {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 2px;
  background: transparent;
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

/* Hover Polish */
.nav-item:hover .nav-title {
  color: rgba(255, 255, 255, 0.8);
}

/* Visual Stage Overrides for smoother cinematic feel */
.service-visual-stage {
  padding: 60px;
  border-radius: 40px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(20px);
  overflow: hidden;
  /* Override main.css offsets */
  top: 0 !important;
  height: auto !important;
  min-height: 500px;
}

.stage-num-bg {
  font-size: 200px;
  font-weight: 900;
  opacity: 0.03;
  position: absolute;
  top: -50px;
  right: -20px;
  line-height: 1;
}


/* --- Showcase Tags Styling --- */
.stage-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 35px;
}

.stage-tag {
  padding: 8px 18px;
  background: rgba(63, 224, 247, 0.05);
  border: 1px solid rgba(63, 224, 247, 0.1);
  color: var(--primary);
  border-radius: 50px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: all 0.4s ease;
  backdrop-filter: blur(5px);
}

.stage-tag:hover {
  background: rgba(63, 224, 247, 0.2);
  border-color: var(--primary);
  transform: translateY(-3px);
  box-shadow: 0 5px 15px rgba(63, 224, 247, 0.2);
}

.alturaitz-blog-details-content hr {
  border-top: 1px solid rgb(255 255 255);
}

.alturaitz-footer-widget a,
.alturaitz-footer-top-social-wrap a {
  width: fit-content;
  display: block;
}

.alturaitz-footer-widget a:focus,
.alturaitz-footer-widget a:hover {
  color: #fff;
}

.forminator-ui#forminator-module-93.forminator-design--default .forminator-button-submit {
  padding: 10px 25px !important;
}

.forminator-button {
  border-radius: 40px !important;
}

.cf7-inline-wrap {
  max-width: 800px;
  font-size: 20px;
  line-height: 1.8;
  color: #fff;
}

/* Inline field wrapper */
.field-inline {
  display: inline-block;
  min-width: 180px;
}

/* Inputs */
.cf7-inline-wrap input {
  border: none;
  border-bottom: 2px solid #555;
  background: transparent;
  font-size: 18px;
  color: #fff;
  padding: 4px 6px;
  width: 100%;
}

/* Remove CF7 weird spacing */
.cf7-inline-wrap p {
  margin: 12px 0;
}

/* Textarea full width */
.full-width textarea {
  width: 100%;
  border: 2px solid #555;
  background: transparent;
  color: #fff;
  padding: 10px;
  font-size: 18px;
  min-height: 120px;
}

/* Focus effect */
.cf7-inline-wrap input:focus,
.full-width textarea:focus {
  outline: none;
  border-color: #0a66c2;
}

/* Button */
.submit-btn input {
  background: #fff;
  color: #000;
  padding: 10px 20px;
  border-radius: 6px;
  cursor: pointer;
  border: none;
  margin-top: 10px;
}

.max-w-500 {
  max-width: 500px;
}


/* --- Kinetic Nexus Service Showcase --- */
.alturaitz-kinetic-services {
  background: #080a0c;
  z-index: 1;
}

.kinetic-particles {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  opacity: 0.3;
}

.kinetic-mesh-bg {
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background-image:
    linear-gradient(rgba(63, 224, 247, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(63, 224, 247, 0.05) 1px, transparent 1px);
  background-size: 60px 60px;
  transform: rotateX(60deg) translateZ(-200px);
  z-index: -2;
  pointer-events: none;
}


@keyframes meshMove {
  0% {
    transform: scale(1) translate(0, 0);
  }

  100% {
    transform: scale(1.2) translate(50px, 50px);
  }
}

.text-outline {
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.3);
}

.kinetic-hero-title {
  letter-spacing: -5px;
}

.alturaitz-kinetic-services {
  perspective: 2000px;
}

.alturaitz-kinetic-services {
  background: #050709;
  overflow-x: hidden;
  padding: 150px 0;
  position: relative;
}

/* BACKGROUND LAYERS */
#kinetic-bg-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  opacity: 0.4;
}

.aurora-glow {
  position: fixed;
  width: 100vw;
  height: 100vw;
  border-radius: 50%;
  filter: blur(180px);
  z-index: 0;
  opacity: 0.15;
  pointer-events: none;
  will-change: transform;
}

.aurora-1 {
  top: -30%;
  left: -30%;
  background: radial-gradient(circle, #3fe0f7 0%, transparent 70%);
}

.aurora-2 {
  bottom: -30%;
  right: -30%;
  background: radial-gradient(circle, #9b51e0 0%, transparent 70%);
}

.nexus-path-svg {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

.nexus-line {
  stroke: rgba(63, 224, 247, 0.2);
  stroke-dasharray: 10, 10;
  fill: none;
}

.nexus-line-progress {
  stroke: #3fe0f7;
  stroke-dasharray: 10, 10;
  fill: none;
  filter: drop-shadow(0 0 5px #3fe0f7);
}

.kinetic-list {
  position: relative;
  z-index: 2;
}

.kinetic-item {
  position: relative;
  width: 100%;
  margin-bottom: 100px;
  display: flex;
  justify-content: center;
}

.nexus-card {
  position: relative;
  width: 450px;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 30px;
  padding: 50px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
  transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.nexus-card:hover {
  transform: scale(1.05);
  border-color: rgba(63, 224, 247, 0.5);
}

.nexus-pin {
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  width: 30px;
  height: 30px;
  background: #3fe0f7;
  border-radius: 50%;
  box-shadow: 0 0 20px #3fe0f7;
  z-index: 3;
}

.nexus-num {
  font-size: 18px;
  font-weight: 800;
  color: #3fe0f7;
  margin-bottom: 20px;
  display: block;
}

/* Winding Layout */
.kinetic-item:nth-child(odd) {
  justify-content: flex-start;
  padding-left: 10%;
}

.kinetic-item:nth-child(even) {
  justify-content: flex-end;
  padding-right: 10%;
}

#kinetic-particles {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

.hud-scanner-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}

.hud-scanner-line {
  position: absolute;
  top: -100%;
  left: 0;
  width: 100%;
  height: 40%;
  background: linear-gradient(to bottom, transparent, rgba(63, 224, 247, 0.05), rgba(63, 224, 247, 0.2), rgba(63, 224, 247, 0.05), transparent);
  animation: hudScan 4s infinite linear;
}

.hud-svg-interface {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 120%;
  height: 120%;
  transform: translate(-50%, -50%);
  opacity: 0.3;
}

.hud-circle-rotating {
  transform-origin: center;
  animation: hudRotate 20s infinite linear;
}

@keyframes hudScan {
  0% {
    top: -100%;
  }

  100% {
    top: 100%;
  }
}

@keyframes hudRotate {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

.kinetic-ghost-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 25vw;
  font-weight: 900;
  color: #fff;
  /* Solid color, opacity handled by GSAP */
  white-space: nowrap;
  pointer-events: none;
  z-index: 0;
  text-transform: uppercase;
  transition: transform 1.5s cubic-bezier(0.16, 1, 0.3, 1);
}



.kinetic-num {
  font-size: 20px;
  font-weight: 800;
  color: var(--primary);
}

.kinetic-line {
  display: inline-block;
  width: 60px;
  height: 1px;
  background: rgba(255, 255, 255, 0.2);
  margin: 0 20px;
  vertical-align: middle;
}

.kinetic-tag {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.4);
}

.kinetic-btn {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 3px;
  transition: all 0.4s ease;
}

.btn-icon {
  width: 60px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.kinetic-btn:hover {
  color: var(--primary);
}

.kinetic-btn:hover .btn-icon {
  background: var(--primary);
  border-color: var(--primary);
  color: #000;
  transform: translateX(10px) rotate(-45deg);
}

/* Kinetic Visual HUD */
.kinetic-visual {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  max-width: 400px;
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

.visual-circle {
  width: 80%;
  height: 80%;
  border: 1px dashed rgba(63, 224, 247, 0.2);
  border-radius: 50%;
  animation: rotateClockwise 30s linear infinite;
}

.visual-scanner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent, rgba(63, 224, 247, 0.05), transparent);
  animation: scannerMove 4s infinite ease-in-out;
}

@keyframes rotateClockwise {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes scannerMove {

  0%,
  100% {
    transform: translateY(-50%);
    opacity: 0;
  }

  50% {
    transform: translateY(50%);
    opacity: 1;
  }
}

.visual-data {
  position: absolute;
  bottom: 40px;
  right: 40px;
  display: grid;
  gap: 8px;
}

.data-line {
  height: 2px;
  background: var(--primary);
  width: 40px;
  opacity: 0.3;
}

.data-line:nth-child(2) {
  width: 60px;
  opacity: 0.5;
}

.data-line:nth-child(3) {
  width: 30px;
  opacity: 0.2;
}

@media (max-width: 991px) {
  .kinetic-ghost-text {
    font-size: 40vw;
  }

  .kinetic-visual {
    margin: 50px auto 0;
  }
}

/* Kinetic Workflow Glassmorphism */
.alturaitz-bg-dark-core {
  background: #080a0c;
}

.kinetic-step {
  padding: 50px 30px;
  position: relative;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(10px);
  border-radius: 30px;
  transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1);
  height: 100%;
}

.kinetic-step:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--primary);
  transform: translateY(-15px) scale(1.02);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5);
}

.step-header {
  position: relative;
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.step-num {
  font-size: 32px;
  font-weight: 900;
  color: #fff;
  z-index: 2;
}

.step-scanner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid rgba(63, 224, 247, 0.2);
  border-radius: 12px;
  overflow: hidden;
}

.step-scanner::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--primary);
  box-shadow: 0 0 15px var(--primary);
  animation: scannerLine 3s infinite ease-in-out;
}

@keyframes scannerLine {

  0%,
  100% {
    transform: translateY(0);
    opacity: 0;
  }

  50% {
    transform: translateY(78px);
    opacity: 1;
  }
}

.kinetic-step:hover .step-scanner {
  border-color: var(--primary);
  background: rgba(63, 224, 247, 0.05);
  box-shadow: 0 0 30px rgba(63, 224, 247, 0.1);
}

/* ==========================================================================
   PREMIUM SERVICE SHOWCASE GRID
   ========================================================================== */
.alturaitz-premium-services {
  background: #050709;
  position: relative;
  z-index: 5;
}

.service-premium-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  max-width: 1400px;
  margin: 0 auto;
}

.service-premium-card-wrap {
  height: 100%;
}

.service-premium-card {
  position: relative;
  background: rgba(255, 255, 255, 0.02);
  backdrop-filter: blur(40px);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 40px;
  padding: 50px 40px;
  height: 100%;
  transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  overflow: hidden;
}

.service-premium-card:hover {
  transform: translateY(-15px) scale(1.02);
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(63, 224, 247, 0.4);
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.6), 0 0 30px rgba(63, 224, 247, 0.15);
}

/* Internal Visual Engines */
.service-card-visual {
  width: 100%;
  height: 220px;
  margin-bottom: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.visual-engine {
  position: relative;
  width: 140px;
  height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 1. Dev Window */
.v-dev-window {
  width: 120px;
  height: 80px;
  border: 2px solid #3fe0f7;
  border-radius: 12px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 20px rgba(63, 224, 247, 0.2);
}

/* 2. AI Core */
.v-ai-core .v-node {
  width: 50px;
  height: 50px;
  background: #3fe0f7;
  border-radius: 50%;
  box-shadow: 0 0 40px #3fe0f7;
  animation: corePulse 2s infinite;
}

/* 3. Social Marketing */
.v-mkt-social {
  display: flex;
  gap: 15px;
}

.v-mkt-social .v-icon {
  font-size: 24px;
  color: #3fe0f7;
  animation: floatBubble 3s infinite alternate;
}

/* 4. Strategy Map */
.v-str-map .v-target {
  width: 40px;
  height: 40px;
  border: 2px solid #3fe0f7;
  border-radius: 50%;
  animation: radarRotate 4s linear infinite;
}

/* 5. Analytics Bars */
.v-ana-bars {
  display: flex;
  gap: 6px;
  align-items: flex-end;
}

.v-ana-bars .v-bar {
  width: 10px;
  height: 40px;
  background: #3fe0f7;
  border-radius: 2px;
  animation: barRise 2s infinite alternate;
}

/* 6. Security Shield */
.v-sec-shield .v-ring {
  width: 60px;
  height: 60px;
  border: 2px solid #3fe0f7;
  border-radius: 50%;
  box-shadow: 0 0 20px #3fe0f7;
}

/* 7. Cloud Node */
.v-cld-node .v-sync {
  width: 40px;
  height: 40px;
  border: 2px dashed #3fe0f7;
  border-radius: 50%;
  animation: rotateClockwise 10s linear infinite;
}

/* Typography */
.service-card-title {
  font-size: 26px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 20px;
  line-height: 1.2;
}

.service-card-desc {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.7;
  margin-bottom: 30px;
}

.service-card-link {
  font-size: 14px;
  font-weight: 700;
  color: #3fe0f7;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s ease;
}

@media (max-width: 1200px) {
  .service-premium-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .service-premium-grid {
    grid-template-columns: 1fr;
  }
}

.nexus-vertical-path {
  height: 100%;
  background: linear-gradient(to bottom, transparent, rgba(63, 224, 247, 0.2) 10%, rgba(63, 224, 247, 0.2) 90%, transparent);
  z-index: 1;
}

.nexus-showcase-item {
  position: relative;
  margin-bottom: 250px;
  z-index: 2;
}

.nexus-showcase-item:last-child {
  margin-bottom: 0;
}

/* Node Styling */
.nexus-node-wrap {
  position: absolute;
  left: 50%;
  top: -20px;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 10;
}

.node-num {
  font-size: 14px;
  font-weight: 700;
  color: #3fe0f7;
  margin-bottom: 10px;
  position: relative;
}

.node-num::before {
  content: "";
  position: absolute;
  left: -40px;
  top: 50%;
  width: 30px;
  height: 1px;
  background: rgba(63, 224, 247, 0.3);
}

.node-dot {
  width: 12px;
  height: 12px;
  background: #050709;
  border: 2px solid #3fe0f7;
  border-radius: 50%;
  box-shadow: 0 0 15px #3fe0f7;
}

/* Text Content */
.nexus-title {
  font-size: clamp(40px, 5vw, 80px);
  font-weight: 900;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: -2px;
}

.nexus-desc {
  max-width: 500px;
  line-height: 1.6;
}

.item-reversed .nexus-desc {
  margin-left: auto;
}

/* Discover Button */
.nexus-discover-btn {
  display: inline-flex;
  align-items: center;
  gap: 15px;
  padding: 15px 30px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.nexus-discover-btn:hover {
  background: #3fe0f7;
  color: #050709;
  border-color: #3fe0f7;
}

.btn-arrow {
  font-size: 18px;
}

/* Visual Engines */
.nexus-visual-engine {
  width: 100%;
  height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 01. Devices Wireframe */
.v-nexus-devices {
  position: relative;
  width: 400px;
  height: 300px;
}

.v-device-browser {
  width: 300px;
  height: 200px;
  border: 1px solid rgba(63, 224, 247, 0.4);
  border-radius: 10px;
  position: absolute;
  right: 0;
  top: 0;
}

.v-device-phone {
  width: 80px;
  height: 160px;
  border: 1px solid rgba(63, 224, 247, 0.6);
  border-radius: 15px;
  position: absolute;
  left: 20px;
  bottom: 0;
  z-index: 2;
  background: #050709;
}

/* 02. AI Particle Sphere */
.v-nexus-ai-sphere {
  position: relative;
  width: 400px;
  height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ai-sphere-mesh {
  position: absolute;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle, transparent 40%, rgba(63, 224, 247, 0.05) 100%);
  border: 1px dashed rgba(63, 224, 247, 0.2);
  border-radius: 50%;
  animation: rotateClockwise 20s linear infinite;
}

.ai-sphere-core {
  font-size: 100px;
  font-weight: 900;
  color: rgba(255, 255, 255, 0.1);
  text-shadow: 0 0 30px rgba(63, 224, 247, 0.5);
}

/* 05. Isometric Cubes */
.v-nexus-iso-cubes {
  display: grid;
  grid-template-columns: repeat(2, 100px);
  gap: 20px;
  transform: rotateX(45deg) rotateZ(45deg);
}

.iso-cube {
  width: 100px;
  height: 100px;
  background: rgba(63, 224, 247, 0.1);
  border: 1px solid #3fe0f7;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cube-icon {
  transform: rotateZ(-45deg) rotateX(-45deg);
  font-size: 30px;
}

@media (max-width: 991px) {
  .nexus-vertical-path {
    left: 20px;
    transform: none;
  }

  .nexus-node-wrap {
    left: 20px;
    transform: none;
  }

  .nexus-text-col {
    padding-left: 60px;
    margin-bottom: 50px;
  }

  .item-reversed .row {
    flex-direction: column;
  }

  .nexus-title {
    font-size: 40px;
  }
}


/* ==========================================================================
   ADVANCED SERVICE VISUAL ENGINES (7 ORDERS)
   ========================================================================== */
.advanced-visual-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 1. Dev Mesh */
.v-mesh-dev {
  position: relative;
  width: 300px;
  height: 300px;
  transform: rotateX(20deg) rotateY(-20deg);
}

.v-mesh-dev .v-pane {
  position: absolute;
  width: 200px;
  height: 120px;
  border: 2px solid #3fe0f7;
  border-radius: 10px;
  background: rgba(63, 224, 247, 0.05);
  backdrop-filter: blur(5px);
  animation: floatPane 4s infinite alternate ease-in-out;
}

.v-mesh-dev .p1 {
  top: 0;
  left: 0;
  z-index: 3;
}

.v-mesh-dev .p2 {
  top: 40px;
  left: 40px;
  opacity: 0.6;
  animation-delay: 0.5s;
  z-index: 2;
}

.v-mesh-dev .p3 {
  top: 80px;
  left: 80px;
  opacity: 0.3;
  animation-delay: 1s;
  z-index: 1;
}

/* 2. AI Mesh */
.v-mesh-ai {
  position: relative;
  width: 400px;
  height: 400px;
}

.v-mesh-ai .v-core {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60px;
  height: 60px;
  background: #3fe0f7;
  border-radius: 50%;
  box-shadow: 0 0 50px #3fe0f7;
  animation: corePulse 2s infinite;
}

.v-mesh-ai .v-sphere {
  width: 100%;
  height: 100%;
  border: 1px dashed rgba(63, 224, 247, 0.3);
  border-radius: 50%;
  animation: rotateClockwise 20s linear infinite;
}

/* 3. Marketing Mesh */
.v-mesh-mkt .v-center {
  width: 80px;
  height: 80px;
  border: 2px solid #3fe0f7;
  border-radius: 50%;
}

.v-mesh-mkt .v-satellite {
  position: absolute;
  width: 40px;
  height: 40px;
  background: rgba(63, 224, 247, 0.1);
  border: 1px solid #3fe0f7;
  border-radius: 8px;
  animation: orbit 8s linear infinite;
}

.v-mesh-mkt .s1 {
  offset-path: path('M 0,0 m -100, 0 a 100,100 0 1,0 200,0 a 100,100 0 1,0 -200,0');
}

.v-mesh-mkt .s2 {
  offset-path: path('M 0,0 m -100, 0 a 100,100 0 1,0 200,0 a 100,100 0 1,0 -200,0');
  animation-delay: -4s;
}

/* 4. Strategy Mesh */
.v-mesh-str {
  width: 300px;
  height: 300px;
  background: repeating-linear-gradient(rgba(63, 224, 247, 0.05) 0 1px, transparent 1px 30px);
  border: 1px solid rgba(63, 224, 247, 0.1);
}

/* 5. Analytics Helix */
.v-mesh-ana .v-helix {
  width: 150px;
  height: 300px;
  border-left: 2px solid #3fe0f7;
  border-right: 2px solid #3fe0f7;
  border-radius: 50%;
  animation: rotateY 4s linear infinite;
}

/* 6. Security Mesh */
.v-mesh-sec .v-shield {
  width: 120px;
  height: 140px;
  background: rgba(63, 224, 247, 0.1);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  border: 3px solid #3fe0f7;
  animation: shieldGlow 3s infinite;
}

/* 7. Cloud Mesh */
.v-mesh-cld .v-cloud {
  width: 100px;
  height: 60px;
  background: #3fe0f7;
  border-radius: 50px;
  position: relative;
}

.v-mesh-cld .v-sync {
  position: absolute;
  width: 150px;
  height: 150px;
  border: 2px dashed rgba(63, 224, 247, 0.5);
  border-radius: 50%;
  animation: rotateClockwise 10s linear infinite;
}

@keyframes floatPane {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-20px);
  }
}

@keyframes shieldGlow {

  0%,
  100% {
    box-shadow: 0 0 20px #3fe0f7;
  }

  50% {
    box-shadow: 0 0 60px #3fe0f7;
  }
}

@keyframes rotateY {
  from {
    transform: rotateY(0deg);
  }

  to {
    transform: rotateY(360deg);
  }
}


/* ==========================================================================
   ADVANCED SVG ANIMATIONS (7 SERVICES)
   ========================================================================== */
.svg-advanced-main {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 0 10px rgba(63, 224, 247, 0.2));
}

/* 1. Dev Window Code Typing */
.v-path-code {
  stroke-dasharray: 100;
  stroke-dashoffset: 100;
  animation: typeCode 3s infinite alternate ease-in-out;
}

/* 2. AI Core Intense Pulse */
.v-ai-core {
  animation: corePulseIntense 2s infinite ease-in-out;
}

.v-ai-paths {
  stroke-dasharray: 50;
  stroke-dashoffset: 50;
  animation: flowData 4s infinite linear;
}

/* 3. Marketing Wave Ripple */
.v-mkt-wave {
  transform-origin: 250px 200px;
  animation: rippleWave 3s infinite;
}

.v-mkt-wave:nth-child(2) {
  animation-delay: 1.5s;
}

/* 4. Strategy Compass Rotation */
.v-str-needle {
  transform-origin: 200px 200px;
  animation: compassRotate 6s infinite ease-in-out;
}

/* 5. Analytics Lens Scan */
.v-ana-lens {
  animation: lensScan 4s infinite alternate ease-in-out;
}

/* 6. Security Shield Shimmer */
.v-sec-shield {
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  animation: shieldDraw 5s infinite alternate;
}

/* KEYFRAMES */
@keyframes typeCode {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes corePulseIntense {

  0%,
  100% {
    stroke-width: 3;
    opacity: 1;
  }

  50% {
    stroke-width: 8;
    opacity: 0.5;
  }
}

@keyframes flowData {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes rippleWave {
  0% {
    transform: scale(0.5);
    opacity: 0;
  }

  50% {
    opacity: 0.5;
  }

  100% {
    transform: scale(2);
    opacity: 0;
  }
}

@keyframes compassRotate {
  0% {
    transform: rotate(0deg);
  }

  25% {
    transform: rotate(30deg);
  }

  75% {
    transform: rotate(-30deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

@keyframes lensScan {
  from {
    transform: translateX(-40px);
  }

  to {
    transform: translateX(40px);
  }
}

@keyframes shieldDraw {
  to {
    stroke-dashoffset: 0;
  }
}


/* ==========================================================================
   PRECISION MODEL ANIMATIONS (INCH-BY-INCH)
   ========================================================================== */
/* AI Sphere Rotation */
.v-ai-mesh-lines {
  transform-origin: 250px 250px;
  animation: rotateDual 15s linear infinite;
}

.v-ai-glow-core {
  animation: breathingGlow 4s infinite ease-in-out;
}

/* Strategy Needle Model */
.v-str-needle-model {
  transform-origin: 250px 250px;
  animation: magneticSearch 5s infinite ease-in-out;
}

/* Helix Draw */
.v-ana-helix-path {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: drawHelix 8s linear infinite;
}

/* Engine Colors - Pure White Blueprint Style */
.v-engine-path {
  stroke: #ffffff !important;
  /* Changed to White */
  stroke-width: 2;
  fill: none;
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: drawEngine 4s linear infinite forwards;
  filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.4));
  /* White Glow */
  transition: all 0.4s ease;
}

@keyframes drawEngine {
  0% {
    stroke-dashoffset: 1000;
    opacity: 0;
  }

  20% {
    opacity: 1;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

.replit-glass-card:hover .v-engine-path {
  animation-duration: 4s;
  stroke-width: 3;
  filter: drop-shadow(0 0 10px #3fe0f7);
}

/* Security Shimmer */
.v-sec-hex-inner {
  filter: drop-shadow(0 0 5px #3fe0f7);
  animation: hexPulse 3s infinite alternate;
}

@keyframes rotateDual {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes breathingGlow {

  0%,
  100% {
    opacity: 0.3;
    stroke-width: 0.5;
  }

  50% {
    opacity: 1;
    stroke-width: 2;
  }
}

@keyframes magneticSearch {

  0%,
  100% {
    transform: rotate(0deg);
  }

  30% {
    transform: rotate(45deg);
  }

  70% {
    transform: rotate(-45deg);
  }
}

@keyframes drawHelix {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes hexPulse {
  from {
    opacity: 0.5;
  }

  to {
    opacity: 1;
  }
}


/* ==========================================================================
   ULTRA-FIDELITY FILL-SECTION VISUALS
   ========================================================================== */
.nexus-visual-engine {
  height: 650px !important;
  /* Increased for Fill-Section look */
  perspective: 1000px;
  overflow: visible;
}

.advanced-visual-wrap {
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
}

.svg-advanced-main {
  width: 110% !important;
  /* Slightly larger than container for bleed effect */
  height: 110% !important;
  filter: drop-shadow(0 0 30px rgba(63, 224, 247, 0.3));
}

/* Background Environment Grid for all visuals */
.advanced-visual-wrap::before {
  content: '';
  position: absolute;
  width: 150%;
  height: 150%;
  background-image:
    radial-gradient(circle at 50% 50%, rgba(63, 224, 247, 0.05) 0%, transparent 70%),
    linear-gradient(rgba(63, 224, 247, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(63, 224, 247, 0.05) 1px, transparent 1px);
  background-size: 100% 100%, 40px 40px, 40px 40px;
  top: -25%;
  left: -25%;
  transform: rotateX(60deg);
  z-index: -1;
  opacity: 0.5;
}

/* Floating Data Particles in environment */
@keyframes dataDust {
  0% {
    transform: translateY(0) translateX(0);
    opacity: 0;
  }

  50% {
    opacity: 0.5;
  }

  100% {
    transform: translateY(-100px) translateX(20px);
    opacity: 0;
  }
}

.advanced-visual-wrap::after {
  content: '? ? ?';
  position: absolute;
  font-size: 10px;
  color: #3fe0f7;
  animation: dataDust 5s infinite linear;
  top: 80%;
  left: 20%;
  filter: blur(1px);
}


/* ==========================================================================
   EXACT MODEL BACKGROUND & ATMOSPHERE
   ========================================================================== */
.alturaitz-nexus-showcase {
  position: relative;
  overflow: hidden;
}

/* Subtle Film Grain Texture */
.alturaitz-nexus-showcase::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('https://www.transparenttextures.com/patterns/stardust.png');
  opacity: 0.05;
  pointer-events: none;
  z-index: 1;
}

/* Atmospheric Auroras matching the image */
.nexus-aurora {
  position: absolute;
  width: 60vw;
  height: 60vw;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.15;
  z-index: 0;
}

.aurora-purple {
  background: radial-gradient(circle, #8a2be2, transparent);
  top: -10%;
  left: -10%;
}

.aurora-blue {
  background: radial-gradient(circle, #3fe0f7, transparent);
  bottom: -10%;
  right: -10%;
}

/* High-End Line Art Visuals */
.nexus-visual-engine {
  height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 5;
}

.svg-model-engine {
  width: 100%;
  height: 100%;
}

/* The Exact Wireframe Look */
.v-line-art {
  stroke: rgba(63, 224, 247, 0.4);
  stroke-width: 0.8;
  fill: none;
  filter: drop-shadow(0 0 5px rgba(63, 224, 247, 0.3));
}

.v-line-art-bold {
  stroke: #3fe0f7;
  stroke-width: 1.5;
}

/* Typography matching the image */
.nexus-title {
  font-size: clamp(40px, 6vw, 90px);
  font-weight: 900;
  letter-spacing: -3px;
  line-height: 0.95;
  text-transform: uppercase;
}

.nexus-discover-btn {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(10px);
  padding: 18px 35px;
  font-size: 13px;
  letter-spacing: 2px;
}


/* ==========================================================================
   NEXUS RHYTHM GRID (STAGGERED WATERFALL)
   ========================================================================== */
.replit-grid-section {
  background: #050709;
  padding: 150px 0;
}

.replit-card-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px 40px;
  /* Increased vertical gap for waterfall effect */
  max-width: 1300px;
  margin: 0 auto;
}

/* Waterfall Offset: Shift every even card */
.replit-glass-card:nth-child(even) {
  margin-top: 60px;
}

/* Featured Pulse Rhythm */
.replit-glass-card:nth-child(1),
.replit-glass-card:nth-child(4),
.replit-glass-card:nth-child(7) {
  grid-column: span 2;
  /* Full width feature cards at 1st, 4th, and 7th position */
  margin-top: 0 !important;
  flex-direction: row;
  text-align: left;
  align-items: center;
  gap: 60px;
}

.replit-glass-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgb(63 224 247 / 26%);
  border-radius: 50px;
  padding: 60px 50px;
  position: relative;
  backdrop-filter: blur(40px);
  transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Digital Connector Line (Pseudo) */
.replit-glass-card::before {
  content: '';
  position: absolute;
  left: -20px;
  top: 50%;
  width: 20px;
  height: 1px;
  background: linear-gradient(90deg, transparent, #3fe0f74d);
  opacity: 0.3;
}

/* ... (connector styles) ... */

.replit-card-visual {
  width: 100%;
  min-height: 250px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 991px) {
  .replit-card-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .replit-glass-card:nth-child(even),
  .replit-glass-card:nth-child(1),
  .replit-glass-card:nth-child(4),
  .replit-glass-card:nth-child(7) {
    grid-column: span 1 !important;
    margin-top: 0 !important;
    flex-direction: column !important;
    text-align: center;
    padding: 40px 30px;
  }

  .replit-card-visual {
    min-height: 200px;
  }
}

/* The Signature Page Curl */
.replit-glass-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, transparent 50%, rgba(255, 255, 255, 0.1) 50%, rgba(255, 255, 255, 0.05) 100%);
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
  border-radius: 0 0 30px 0;
}

/* Purple Nebula Glow inside card */
.replit-card-glow {
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, #3fe0f72b 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.replit-card-content {
  position: relative;
  z-index: 2;
}

.replit-card-title {
  font-size: 32px;
  font-weight: 900;
  margin-bottom: 20px;
  color: #3fe0f7 !important;
  /* Unified Site Blue */
  text-shadow: 0 0 10px rgba(63, 224, 247, 0.2);
}

.replit-card-desc {
  font-size: 17px;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.6;
  margin-bottom: 30px;
}

/* THE PROTOCOL BUTTON */
.replit-card-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 28px;
  border: 1px solid #3fe0f7;
  border-radius: 100px;
  color: #3fe0f7 !important;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  background: transparent;
  width: fit-content;
}

.replit-card-btn .btn-arrow {
  transition: transform 0.4s ease;
}

.replit-card-btn:hover {
  background: #3fe0f7;
  color: #050709 !important;
  box-shadow: 0 10px 30px rgba(63, 224, 247, 0.3);
  transform: translateX(5px);
}

.replit-card-btn:hover .btn-arrow {
  transform: translateX(5px);
}

/* Card Visual Containers */
.replit-card-visual {
  height: 250px;
  position: relative;
  margin-top: 30px;
  opacity: 0.8;
}

/* ========================================================================== 
   ABOUT HERO V4 - DATAPLACE STYLE 
   ========================================================================== */
.about-hero-v4 {
  background: #050709;
  min-height: 90vh;
  display: flex;
  align-items: center;
  z-index: 1;
  padding: 150px 0 250px !important;
}

.hero-v4-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at 50% 120%, rgba(63, 224, 247, 0.15), transparent 70%);
  z-index: -1;
}

.hero-arc-separator {
  position: absolute;
  bottom: -300px;
  left: 50%;
  transform: translateX(-50%);
  width: 150vw;
  height: 600px;
  background: #0a0c10;
  border-radius: 100%;
  border-top: 1px solid rgba(63, 224, 247, 0.2);
  box-shadow: 0 -50px 100px rgba(63, 224, 247, 0.05);
}

.trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 15px;
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 100px;
}

.avatar-group {
  display: flex;
}

.avatar-group img {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid #050709;
  margin-left: -10px;
}

.avatar-group img:first-child {
  margin-left: 0;
}

.review-count {
  font-size: 14px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
}

.hero-v4-title {
  font-size: 70px;
  line-height: 1.1;
  font-weight: 800;
  color: #fff;
}

.text-cyan {
  color: #3fe0f7;
}

.hero-v4-desc {
  font-size: 20px;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.6;
}

.about-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 18px 40px;
  background: #3fe0f7;
  color: #050709 !important;
  font-weight: 700;
  border-radius: 100px;
  font-size: 16px;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 10px 40px rgba(63, 224, 247, 0.3);
}

.about-cta-btn:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 50px rgba(63, 224, 247, 0.5);
}

.hero-feature-grid {
  position: relative;
  z-index: 10;
}

.feature-v4-item {
  padding: 40px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 30px;
  backdrop-filter: blur(10px);
  transition: all 0.4s ease;
  height: 100%;
}

.feature-v4-item:hover {
  background: rgba(63, 224, 247, 0.03);
  border-color: rgba(63, 224, 247, 0.2);
  transform: translateY(-10px);
}

.feature-icon {
  font-size: 32px;
  margin-bottom: 25px;
  display: block;
}

.feature-title {
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 15px;
}

.feature-text {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.5;
  margin-bottom: 0;
}

@media (max-width: 991px) {
  .hero-v4-title {
    font-size: 40px;
  }

  .hero-arc-separator {
    width: 300vw;
  }
}

.hero-monumental-text {
  font-family: "TrajanPro-Regular" !important;
  font-weight: 400 !important;
  letter-spacing: -10px !important;
}

.hero-monumental-text span.accent-text {
  font-family: "TrajanPro-Bold";
  letter-spacing: -5px !important;
}

/*----------------------------------------
    39. OUR TEAM SECTION
----------------------------------------*/
.alturaitz-team-list-section {
  background: transparent;
  z-index: 1;
  position: relative;
}

.alturaitz-team-item {
  text-align: center;
}

.alturaitz-team-thumb-wrap {
  height: 420px;
  border-radius: 40px;
  margin-bottom: 20px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 0;
}

.purple-theme .alturaitz-team-bg {
  background: linear-gradient(180deg, rgb(113 101 199 / 0%) 0%, #155b65 100%);
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 85%;
  z-index: -1;
  border-radius: 40px;
  backdrop-filter: blur(10px);
}

.orange-theme .alturaitz-team-bg {
  background: linear-gradient(180deg, rgb(248 164 91 / 0%) 0%, #d4b56085 100%);
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 85%;
  z-index: -1;
  border-radius: 40px;
  backdrop-filter: blur(10px);
}

.alturaitz-team-thumb-wrap img {
  height: 105%;
  width: auto;
  object-fit: contain;
  transform: translateY(10px);
  z-index: 1;
}

.alturaitz-team-item .vertical-name {
  position: absolute;
  top: 30px;
  right: 15px;
  writing-mode: vertical-rl;
  font-size: 55px;
  font-weight: 800;
  text-transform: capitalize;
  color: rgba(255, 255, 255, 0.4);
  font-family: 'DM Sans', sans-serif;
  line-height: 1;
  letter-spacing: -2px;
}

.alturaitz-team-btn {
  display: inline-block;
  padding: 12px 35px;
  border-radius: 15px;
  font-weight: 700;
  font-size: 16px;
  color: #fff;
  transition: all 0.3s;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.purple-theme .alturaitz-team-btn {
  background: #155B65;
}

.orange-theme .alturaitz-team-btn {
  background: #D4B560;
}

.alturaitz-team-section-title {
  font-size: 110px;
  font-weight: 800;
  background: linear-gradient(to right, #155b65, #d4b560);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: 'DM Sans', sans-serif;
  margin: 0;
}

.alturaitz-team-section-desc {
  font-size: 18px;
  line-height: 1.6;
  color: #a0a0a0;
  margin: 0;
  padding-left: 20px;
}

.team-members-list .alturaitz-team-member-col:nth-child(2),
.team-members-list .alturaitz-team-member-col:nth-child(3) {
  margin-top: 70px;
}

@media (max-width: 1200px) {
  .alturaitz-team-section-title {
    font-size: 80px;
  }
}

@media (max-width: 991px) {
  .alturaitz-team-section-title {
    font-size: 60px;
    margin-bottom: 20px;
  }

  .alturaitz-team-section-desc {
    padding-left: 0;
  }

  .alturaitz-team-thumb-wrap {
    height: 350px;
  }

  .alturaitz-team-item .vertical-name {
    font-size: 40px;
  }
}

/*----------------------------------------
    40. PARAGRAPH CONTACT FORM (BOTTOM)
----------------------------------------*/
.alturaitz-contact-area-bottom {
  position: relative;
}

.paragraph-form p {
  font-size: clamp(32px, 4.5vw, 55px);
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.95);
  font-weight: 600;
  letter-spacing: -1px;
  margin-bottom: 45px;
}

.paragraph-form input {
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid rgba(255, 255, 255, 0.3) !important;
  border-radius: 0 !important;
  color: #3fe0f7 !important;
  font-size: inherit;
  font-family: inherit;
  padding: 0 10px !important;
  width: auto;
  min-width: 250px;
  outline: none !important;
  transition: all 0.3s ease;
  display: inline-block;
  vertical-align: baseline;
  box-shadow: none !important;
}

.paragraph-form input:focus {
  border-bottom-color: #f8a45b !important;
  color: #fff !important;
}

.paragraph-form input::placeholder {
  color: rgba(255, 255, 255, 0.1) !important;
}

.paragraph-submit-btn {
  background: linear-gradient(90deg, #a44c21 0%, #421b1b 100%);
  color: #fff;
  border: none;
  padding: 22px 55px;
  border-radius: 100px;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 2px;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 10px 40px rgba(164, 76, 33, 0.4);
  cursor: pointer;
  margin-top: 40px;
}

.paragraph-submit-btn:hover {
  transform: translateY(-5px) scale(1.05);
  box-shadow: 0 20px 60px rgba(164, 76, 33, 0.6);
  background: linear-gradient(90deg, #f8a45b 0%, #a44c21 100%);
}

@media (max-width: 1200px) {
  .paragraph-form .form-text {
    font-size: 40px;
  }
}

@media (max-width: 768px) {
  .paragraph-form .form-text {
    font-size: 28px;
  }

  .paragraph-form input {
    width: 100%;
    margin: 15px 0;
    display: block;
    min-width: auto;
  }
}

.alturaitz-paragraph-contact-form input[type=text],
.alturaitz-paragraph-contact-form input[type=email],
.alturaitz-paragraph-contact-form input[type=tel],
.alturaitz-paragraph-contact-form input[type=number],
.alturaitz-paragraph-contact-form input[type=password],
.alturaitz-paragraph-contact-form input[type=url] {
  font-size: clamp(24px, 4.5vw, 55px);
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.95) !important;
  font-weight: 600;
  letter-spacing: -1px;
  max-width: 400px;
  height: 70px;
}

.alturaitz-paragraph-contact-form input[type=email],
.alturaitz-paragraph-contact-form input[type=tel] {
  max-width: 550px;
}

.alturaitz-paragraph-contact-form input::placeholder {
  font-size: clamp(24px, 4.5vw, 52px);
  line-height: 1.4;
  color: rgb(177 177 177 / 95%) !important;
  font-weight: 600;
  letter-spacing: -1px;
}

.alturaitz-paragraph-contact-form aside p {
  display: flex;
  align-items: flex-end;
  gap: 10px;
}

.alturaitz-paragraph-contact-form svg {
  width: 60px;
  height: 60px;
  color: #3fe0f7;
}

.wpcf7-not-valid-tip {
  position: absolute;
  font-size: 14px !important;
  left: 0;
}

/*----------------------------------------
    41. CONTACT PAGE HERO REDESIGN
----------------------------------------*/
.alturaitz-contact-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 40px;
  border-radius: 20px;
  height: 100%;
  transition: all 0.4s ease;
  backdrop-filter: blur(10px);
}

.alturaitz-contact-card:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(63, 224, 247, 0.3);
  transform: translateY(-5px);
}

.alturaitz-contact-card .card-label {
  font-size: 14px;
  text-uppercase: uppercase;
  letter-spacing: 2px;
  color: #3fe0f7;
  margin-bottom: 15px;
  font-weight: 600;
}

.alturaitz-contact-card .card-value {
  font-size: 24px;
  color: #fff;
  font-weight: 500;
  word-break: break-all;
  transition: color 0.3s ease;
}

.alturaitz-contact-card .card-value:hover {
  color: #3fe0f7;
}


/* --- High-Performance Dark Tech Service Slider --- */
.alturaitz-cinematic-slider {
  background: #000;
  position: relative;
  overflow: hidden;
}

/* Static Glow for better performance */
.alturaitz-cinematic-slider::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at center, rgba(63, 224, 247, 0.05) 0%, rgba(255, 0, 0, 0.05) 50%, transparent 80%);
  z-index: 0;
  pointer-events: none;
}

/* --- Owl Carousel Service Slider (High-Performance) --- */
.alturaitz-service-owl {
  z-index: 5;
}

.alturaitz-service-owl .owl-item {
  opacity: 0.6;
  transform: scale(0.9);
  transition: all 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.alturaitz-service-owl .owl-item.center {
  opacity: 1;
  transform: scale(1.08);
  z-index: 10;
  filter: drop-shadow(0 0 30px rgba(63, 224, 247, 0.15));
}

.alturaitz-service-owl .owl-item.center .cinematic-service-card {
  transform: translateY(-15px);
  border-color: rgba(63, 224, 247, 0.8);
  background: rgba(10, 10, 10, 0.8);
  box-shadow: 0 50px 100px rgba(0, 0, 0, 0.7), 0 0 40px rgba(63, 224, 247, 0.1);
}

.alturaitz-service-owl .owl-stage-outer {
  padding: 80px 0;
  margin: -40px 0;
}

/* Premium Owl Dots Styling */
.alturaitz-service-owl .owl-dots {
  text-align: center;
  margin-top: 40px;
  display: flex;
  justify-content: center;
  gap: 12px;
}

.alturaitz-service-owl .owl-dot {
  width: 40px;
  height: 4px;
  background: rgba(255, 255, 255, 0.1) !important;
  border-radius: 4px;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  border: none !important;
  outline: none !important;
}

.alturaitz-service-owl .owl-dot.active {
  width: 80px;
  background: #3fe0f7 !important;
  box-shadow: 0 0 15px rgba(63, 224, 247, 0.6);
}

/* --- Futuristic Glass Console Service Card --- */
.cinematic-service-card {
  position: relative;
  width: 100%;
  background: radial-gradient(circle at top right, #3fe0f742, transparent 100%);
  backdrop-filter: blur(20px);
  border-radius: 30px;
  border: 1px solid;
  border-color: rgba(63, 224, 247, 0.5);
  padding: 50px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: all 0.5s ease;
  will-change: transform, border-color, background;
}

/* Bottom Accent Glow */
.cinematic-service-card::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60%;
  height: 2px;
  background: #3fe0f7;
  box-shadow: 0 0 30px #3fe0f7;
  opacity: 0.3;
  transition: opacity 0.5s ease;
}

.cinematic-service-card:hover {
  transform: scale(1.03);
}

.cinematic-service-card:hover::before {
  opacity: 1;
}

/* Visual Container */
.card-hero-visual {
  width: 100%;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 30px;
}

/* Floating Meta Badge */
.card-meta-floating {
  position: absolute;
  top: 30px;
  right: 30px;
  background: rgba(63, 224, 247, 0.1);
  border: 1px solid rgba(63, 224, 247, 0.2);
  padding: 5px 12px;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 800;
  color: #3fe0f7;
  letter-spacing: 1px;
}

/* Typography */
.cinematic-title {
  font-size: 32px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 15px;
  line-height: 1.2;
}

.cinematic-meta {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin-top: 20px;
}

.meta-tag {
  background: rgba(255, 255, 255, 0.05);
  padding: 5px 15px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 1px;
}

@media (max-width: 991px) {
  .cinematic-title {
    font-size: 26px;
  }
}

/* --- Advanced SVG Animations --- */

/* Code Brackets & Slash */
.svg-code-bracket {
  animation: bracketMove 3s infinite alternate ease-in-out;
}

@keyframes bracketMove {
  from {
    transform: translateX(-5px);
  }

  to {
    transform: translateX(5px);
  }
}

.svg-code-slash {
  animation: slashPulse 2s infinite alternate ease-in-out;
}

@keyframes slashPulse {
  from {
    opacity: 0.2;
    transform: scaleY(0.9);
  }

  to {
    opacity: 0.6;
    transform: scaleY(1.1);
  }
}

/* AI Core & Circuitry */
.svg-ai-core {
  animation: aiPulse 4s infinite alternate ease-in-out;
}

@keyframes aiPulse {
  0% {
    filter: drop-shadow(0 0 5px #3fe0f7);
  }

  100% {
    filter: drop-shadow(0 0 20px #3fe0f7);
  }
}

.svg-ai-pulse {
  animation: coreExpand 3s infinite ease-out;
}

@keyframes coreExpand {
  0% {
    transform: scale(0.8);
    opacity: 0.4;
  }

  100% {
    transform: scale(1.5);
    opacity: 0;
  }
}

.svg-ai-circuit {
  stroke-dasharray: 100;
  stroke-dashoffset: 100;
  animation: dash 4s infinite linear;
}

@keyframes dash {
  to {
    stroke-dashoffset: 0;
  }
}

.svg-ai-node {
  animation: nodeBlink 2s infinite alternate ease-in-out;
}

@keyframes nodeBlink {
  from {
    opacity: 0.3;
    transform: scale(0.8);
  }

  to {
    opacity: 1;
    transform: scale(1.2);
  }
}

/* Marketing & Growth */
.svg-marketing-rocket {
  animation: rocketFloat 4s infinite ease-in-out;
}

@keyframes rocketFloat {

  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  50% {
    transform: translateY(-10px) rotate(5deg);
  }
}

.svg-radar-ring {
  transform-origin: center;
  animation: ringRotate 10s infinite linear;
}

@keyframes ringRotate {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

.svg-growth-line {
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
  animation: growthDraw 5s infinite linear;
}

@keyframes growthDraw {
  to {
    stroke-dashoffset: 0;
  }
}

/* UI & Analytics */
.svg-ui-bar {
  animation: barShimmer 2s infinite linear;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  background-size: 200% 100%;
}

@keyframes barShimmer {
  0% {
    fill: rgba(255, 255, 255, 0.03);
  }

  50% {
    fill: rgba(255, 255, 255, 0.08);
  }

  100% {
    fill: rgba(255, 255, 255, 0.03);
  }
}

/* Waves & Radar */
.svg-wave {
  animation: waveFlow 6s infinite linear;
}

@keyframes waveFlow {
  from {
    stroke-dasharray: 50 150;
    stroke-dashoffset: 200;
  }

  to {
    stroke-dasharray: 150 50;
    stroke-dashoffset: 0;
  }
}

.svg-radar-point {
  animation: pointPulse 2s infinite ease-in-out;
}

@keyframes pointPulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.5);
    opacity: 0.5;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

/* --- Precision Grid Sticky Note Section --- */
.alturaitz-workflow-nexus {
  position: relative;
  overflow: hidden;
}

.workflow-nexus-wrapper {
  position: relative;
  width: 100%;
}

/* --- Local Step Connectors (Universal Stability) --- */
.step-line-container {
  position: absolute;
  top: 50%;
  left: 27%;
  width: 55%;
  height: 200px;
  z-index: 1;
  pointer-events: none;
}

.step-line-container-rev {
  position: absolute;
  top: 50%;
  right: -15%;
  width: 70%;
  height: 200px;
  z-index: 1;
  pointer-events: none;
}

.step-line-svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}

.wave-path-animated {
  stroke: #3fe0f7 !important;
  stroke-width: 6 !important;
  stroke-dasharray: 15 20;
  stroke-linecap: round;
  fill: none;
  filter: drop-shadow(0 0 12px rgba(63, 224, 247, 0.7));
  animation: marchingDots 20s linear infinite;
}

@keyframes marchingDots {
  from {
    stroke-dashoffset: 1000;
  }

  to {
    stroke-dashoffset: 0;
  }
}

.sticky-node {
  position: relative;
  /* Fixed: No longer absolute */
  z-index: 10;
  width: 100%;
  max-width: 380px;
  margin: 0 auto;
}

.mb-120 {
  margin-bottom: 120px;
}

.sticky-card {
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(25px);
  padding: 45px 35px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.6);
  position: relative;
  transform: rotate(-2deg);
  transition: all 0.4s ease;
}

.node-1 .sticky-card {
  transform: rotate(-3deg);
}

.node-2 .sticky-card {
  transform: rotate(3deg);
}

.node-3 .sticky-card {
  transform: rotate(-2deg);
}

.node-4 .sticky-card {
  transform: rotate(2deg);
}

.sticky-node:hover .sticky-card {
  transform: rotate(0deg) translateY(-15px);
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(63, 224, 247, 0.5);
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.8);
}

/* Glowing Neon Pins */
.node-pin {
  position: absolute;
  top: -24px;
  left: 50%;
  transform: translateX(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  z-index: 20;
}

.node-pin::after {
  content: '';
  position: absolute;
  inset: -12px;
  background: inherit;
  filter: blur(15px);
  opacity: 0.6;
  z-index: -1;
}

.pin-orange {
  background: radial-gradient(circle at 35% 35%, #ff8c42, #ff5e00);
  box-shadow: 0 0 20px rgba(255, 94, 0, 0.5);
}

.pin-blue {
  background: radial-gradient(circle at 35% 35%, #3fe0f7, #00a8cc);
  box-shadow: 0 0 20px rgba(63, 224, 247, 0.5);
}

.pin-purple {
  background: radial-gradient(circle at 35% 35%, #a29bfe, #6c5ce7);
  box-shadow: 0 0 20px rgba(108, 92, 231, 0.5);
}

/* Typography (Crisp for Dark Theme) */
.sticky-num {
  font-size: 18px;
  font-weight: 800;
  display: block;
  margin-bottom: 12px;
  letter-spacing: 1px;
}

.sticky-title {
  font-family: 'Outfit', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 15px;
}

.sticky-text {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.7;
}

.color-orange {
  color: #ff8c42;
}

.color-blue {
  color: #3fe0f7;
}

.color-purple {
  color: #a29bfe;
}

/* Interactive Final Step */
.blurred-sticky-step .sticky-card {
  filter: blur(3px);
  /* opacity: 0.6; */
}

.sticky-node:hover.blurred-sticky-step .sticky-card {
  /* filter: none; */
  /* opacity: 1; */
}

.sticky-cursor {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #3fe0f7;
  color: #000;
  padding: 12px 24px;
  border-radius: 100px;
  font-weight: 800;
  font-size: 14px;
  box-shadow: 0 0 30px rgba(63, 224, 247, 0.6);
  z-index: 25;
}

/* --- Career Hero Nexus & Neural Canvas --- */
.career-hero-nexus {
  background: #050505;
  min-height: 80vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}

#career-neural-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  opacity: 0.8;
}

.career-hero-overlay {
  top: 0;
  left: 0;
  position: fixed;
  font-size: 0;
  background: radial-gradient(circle at 50% 50%, transparent 20%, #3fe0f72e 100%);
  z-index: 1;
  pointer-events: none;
  height: 100%;
  width: 100%;
}

.popup-open-btn {
  cursor: pointer;
}

.career-bg-mesh {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(63, 224, 247, 0.12) 0%, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(162, 155, 254, 0.12) 0%, transparent 40%);
  filter: blur(100px);
  z-index: 0;
}

.alturaitz-career-quote-section {
  width: 100%;
  z-index: 10;
}

.text-glow-cyan {
  color: #3fe0f7;
  text-shadow: 0 0 20px rgba(63, 224, 247, 0.6);
  font-weight: 500;
}

.alturaitz-quote-mark {
  font-size: 400px;
  color: rgba(255, 255, 255, 0.03);
  top: -80px;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'DM Sans', sans-serif;
  line-height: 1;
  z-index: -1;
  pointer-events: none;
}

.career-hero-quote {
  letter-spacing: -1.5px;
  text-shadow: 0 10px 40px rgba(0, 0, 0, 0.8);
}

.career-hero-divider {
  width: 100px;
  height: 2px;
  background: linear-gradient(90deg, transparent, #3fe0f7, transparent);
  margin-top: 30px;
}

@media (max-width: 767px) {
  .career-hero-nexus {
    min-height: 60vh;
  }

  .alturaitz-quote-mark {
    font-size: 200px;
    top: 20px;
  }
}

/* --- Service Nebula Experience --- */
.service-nebula-experience {
  background: #050505;
}

#service-fluid-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 0.6;
}

.service-stellar-title {
  font-size: 120px;
  background: linear-gradient(135deg, #fff 0%, #3fe0f7 50%, #a29bfe 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 0.9;
  letter-spacing: -2px;
}

.nebula-tag {
  color: #3fe0f7;
  letter-spacing: 4px;
}

.nebula-scroll-indicator {
  position: absolute;
  bottom: 50px;
  left: 50%;
  transform: translateX(-50%);
}

.scroll-line {
  width: 2px;
  height: 60px;
  background: linear-gradient(to bottom, #3fe0f7, transparent);
  display: block;
  margin: 0 auto 10px;
  animation: scrollAnim 2s infinite;
}

@keyframes scrollAnim {
  0% {
    transform: scaleY(0);
    transform-origin: top;
  }

  50% {
    transform: scaleY(1);
    transform-origin: top;
  }

  51% {
    transform: scaleY(1);
    transform-origin: bottom;
  }

  100% {
    transform: scaleY(0);
    transform-origin: bottom;
  }
}

.floating-shards .shard {
  position: absolute;
  background: radial-gradient(circle, rgba(63, 224, 247, 0.1) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(50px);
  pointer-events: none;
}

.shard-1 {
  width: 400px;
  height: 400px;
  top: 10%;
  left: -10%;
}

.shard-2 {
  width: 600px;
  height: 600px;
  bottom: 10%;
  right: -10%;
}

.shard-3 {
  width: 300px;
  height: 300px;
  top: 50%;
  left: 40%;
}

.glass-definition-card {
  background: rgba(255, 255, 255, 0.02);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 40px;
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.5);
}

.definition-line {
  width: 100px;
  height: 4px;
  background: #3fe0f7;
  border-radius: 2px;
  margin-top: 20px;
}

.stellar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
  gap: 30px;
}

.stellar-card {
  position: relative;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 30px;
  overflow: hidden;
  transition: all 0.5s ease;
}

.stellar-card:hover {
  border-color: #3fe0f7;
  transform: translateY(-15px) scale(1.02);
  background: rgba(255, 255, 255, 0.04);
}

.stellar-glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--x, 50%) var(--y, 50%), rgba(63, 224, 247, 0.15) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.3s;
}

.stellar-card:hover .stellar-glow {
  opacity: 1;
}

.stellar-icon-wrap {
  width: 80px;
  height: 80px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.nebula-btn {
  position: relative;
  display: inline-block;
  padding: 25px 60px;
  background: #3fe0f7;
  color: #050505;
  font-family: 'Teko', sans-serif;
  font-size: 24px;
  font-weight: 600;
  text-transform: uppercase;
  border-radius: 100px;
  overflow: hidden;
  transition: all 0.4s ease;
  text-decoration: none;
}

.nebula-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 0 50px rgba(63, 224, 247, 0.5);
}

.btn-flare {
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  transform: skewX(-25deg);
  transition: 0.5s;
}

.nebula-btn:hover .btn-flare {
  left: 150%;
}

@media (max-width: 991px) {
  .service-stellar-title {
    font-size: 70px;
  }

  .stellar-grid {
    grid-template-columns: 1fr;
  }
}

/* --- Service Orai Engine (Split Panels) --- */
.service-orai-engine {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.orai-container {
  min-height: 500px;
}

.orai-panel {
  flex: 1;
  min-width: 33.333%;
  position: relative;
  border-right: 1px solid rgba(255, 255, 255, 0.05);
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  background: #050505;
}

.orai-panel:last-child {
  border-right: none;
}

.orai-panel:hover {
  flex: 1.2;
  background: rgba(63, 224, 247, 0.02);
}

.panel-content {
  position: relative;
  z-index: 5;
  height: 100%;
}

.panel-num {
  font-size: 18px;
  color: #3fe0f7;
  letter-spacing: 2px;
  margin-bottom: 20px;
  opacity: 0.6;
}

.orai-dot {
  width: 8px;
  height: 8px;
  background: #3fe0f7;
  border-radius: 50%;
  display: inline-block;
  margin-right: 15px;
  box-shadow: 0 0 10px rgba(63, 224, 247, 0.5);
}

.orai-url {
  font-size: 32px;
  color: #fff;
  text-decoration: none;
  border-bottom: 2px solid #3fe0f7;
  transition: all 0.3s;
}

.orai-url:hover {
  text-shadow: 0 0 20px #3fe0f7;
  letter-spacing: 2px;
}

.orai-btn {
  display: inline-block;
  padding: 15px 40px;
  background: #3fe0f7;
  color: #000;
  font-family: 'Teko', sans-serif;
  font-size: 20px;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  border-radius: 4px;
  transition: all 0.4s;
}

.orai-btn:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(63, 224, 247, 0.4);
}

@media (max-width: 991px) {
  .orai-panel {
    flex: none;
    width: 100%;
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  }

  .orai-panel:hover {
    flex: none;
  }
}

/* --- Service Nexus Hub --- */
.service-nexus-hub {
  position: relative;
  min-height: 800px;
  display: flex;
  align-items: center;
}

.hub-layout {
  position: relative;
  width: 100%;
  height: 600px;
}

/* Central Core */
.nexus-core {
  position: absolute;
  top: 25%;
  left: 25%;
  transform: translate(-50%, -50%);
  width: 200px;
  height: 200px;
  z-index: 10;
}

.alturaitz-orbital-counter-container .core-inner {
  flex-direction: column;
}

.core-inner {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.core-rings span {
  position: absolute;
  border: 1px solid #3fe0f7;
  border-radius: 50%;
  animation: rotateRing 10s linear infinite;
}

.core-rings span:nth-child(1) {
  width: 100%;
  height: 100%;
  border-color: rgba(63, 224, 247, 0.4);
  animation-duration: 15s;
}

.core-rings span:nth-child(2) {
  width: 80%;
  height: 80%;
  border-color: rgba(162, 155, 254, 0.4);
  animation-duration: 10s;
  animation-direction: reverse;
}

.core-rings span:nth-child(3) {
  width: 60%;
  height: 60%;
  border-color: #3fe0f7;
  animation-duration: 5s;
}

@keyframes rotateRing {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

.core-text {
  font-size: 24px;
  color: #3fe0f7;
  text-align: center;
  letter-spacing: 2px;
  z-index: 2;
}

/* Satellites */
.nexus-satellite {
  position: absolute;
  width: 320px;
  transition: all 0.5s ease;
}

.identity-sat {
  top: 0;
  left: 0;
}

.action-sat {
  top: 0;
  right: 0;
}

.portal-sat {
  bottom: -50px;
  left: 50%;
  transform: translateX(-50%);
}

.glass-sat {
  background: rgba(255, 255, 255, 0.02);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 30px;
  position: relative;
  z-index: 5;
}

.sat-num {
  font-size: 60px;
  font-family: 'Teko', sans-serif;
  color: rgba(63, 224, 247, 0.2);
  position: absolute;
  top: 10px;
  right: 20px;
}

.nexus-satellite:hover .glass-sat {
  background: rgba(255, 255, 255, 0.05);
  border-color: #3fe0f7;
  transform: translateY(-10px);
  box-shadow: 0 20px 50px rgba(63, 224, 247, 0.2);
}

.sat-portal-link {
  color: #3fe0f7;
  text-decoration: none;
  border-bottom: 1px solid rgba(63, 224, 247, 0.3);
  transition: all 0.3s;
}

.sat-portal-link:hover {
  border-color: #3fe0f7;
  text-shadow: 0 0 10px #3fe0f7;
}

.nebula-btn-sm {
  padding: 10px 30px;
  background: #3fe0f7;
  color: #000;
  border-radius: 50px;
  font-family: 'Teko', sans-serif;
  font-size: 18px;
  text-transform: uppercase;
  text-decoration: none;
  font-weight: 600;
  display: inline-block;
}

.action-dot {
  width: 6px;
  height: 6px;
  background: #3fe0f7;
  border-radius: 50%;
  display: inline-block;
  margin-right: 10px;
  box-shadow: 0 0 10px #3fe0f7;
}

/* Mobile Adjustments */
@media (max-width: 991px) {
  .service-nexus-hub {
    min-height: auto;
    padding: 100px 0;
  }

  .hub-layout {
    height: auto;
    display: flex;
    flex-direction: column;
    gap: 40px;
  }


  .nexus-satellite {
    position: static;
    width: 100%;
    transform: none !important;
  }
}

@media (max-width: 991px) {
  .alturaitz-workflow-nexus {
    min-height: auto;
    padding: 80px 0;
  }

  .sticky-wave-svg {
    display: none;
  }

  .sticky-node {
    position: static !important;
    margin: 0 auto 50px;
    transform: none !important;
  }

  .sticky-card {
    transform: none !important;
  }
}

/* ==========================================================================
   NEW BLOG BANNER V2 - Premium Design
   ========================================================================== */

.alt-blog-v2-hero {
  background-color: #08080a;
  padding-top: 180px;
  padding-bottom: 80px;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.alt-blog-v2-hero::before {
  content: "";
  position: absolute;
  top: -10%;
  right: -5%;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(63, 224, 247, 0.15) 0%, transparent 70%);
  filter: blur(80px);
  z-index: -1;
  animation: altFloat 20s infinite alternate ease-in-out;
}

@keyframes altFloat {
  0% {
    transform: translate(0, 0) scale(1);
  }

  100% {
    transform: translate(-50px, 50px) scale(1.2);
  }
}

.alt-blog-v2-title {
  font-size: clamp(48px, 6vw, 90px);
  font-weight: 800;
  color: #fff;
  line-height: 1;
  letter-spacing: -3px;
  margin-bottom: 30px;
  text-transform: uppercase;
}

.alt-blog-v2-title span {
  display: block;
  background: linear-gradient(90deg, #fff, rgba(255, 255, 255, 0.4));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.alt-blog-v2-desc {
  font-size: 18px;
  color: #a1a1aa;
  line-height: 1.6;
  max-width: 500px;
  border-left: 2px solid var(--primary);
  padding-left: 25px;
  margin-top: 20px;
}

.alt-blog-v2-breadcrumb {
  margin-top: 60px;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.05);
  display: inline-flex;
  padding: 12px 25px;
  border-radius: 100px;
}

.alt-blog-v2-breadcrumb ul {
  display: flex;
  align-items: center;
  gap: 15px;
  list-style: none;
}

.alt-blog-v2-breadcrumb li {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.alt-blog-v2-breadcrumb li a {
  color: rgba(255, 255, 255, 0.5);
  transition: 0.3s;
}

.alt-blog-v2-breadcrumb li a:hover {
  color: var(--primary);
}

.alt-blog-v2-breadcrumb li span {
  width: 6px;
  height: 6px;
  background: var(--primary);
  border-radius: 50%;
  display: block;
}

.alt-blog-v2-img-container {
  margin-top: -60px;
  position: relative;
  z-index: 10;
  padding: 0 15px;
}

.alt-blog-v2-img-wrap {
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.5);
  position: relative;
}

.alt-blog-v2-img-wrap img {
  width: 100%;
  height: 600px;
  object-fit: cover;
  transition: transform 1.5s cubic-bezier(0.19, 1, 0.22, 1);
}

.alt-blog-v2-img-wrap:hover img {
  transform: scale(1.1);
}

.alt-blog-v2-img-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, transparent 50%, rgba(8, 8, 10, 0.8));
  pointer-events: none;
}

@media (max-width: 991px) {
  .alt-blog-v2-hero {
    padding-top: 140px;
    text-align: center;
  }

  .alt-blog-v2-desc {
    margin: 30px auto 0;
    text-align: left;
  }

  .alt-blog-v2-img-wrap img {
    height: 400px;
  }

  .alt-blog-v2-title {
    letter-spacing: -1px;
  }
}

/* Animation Helpers */
.alt-blog-v2-title .line {
  overflow: hidden;
  padding-bottom: 5px;
}

.alt-blog-v2-img-wrap {
  clip-path: inset(0% 0% 0% 0%);
}

/* Centered Layout Refinements */
.alt-blog-v2-divider {
  width: 80px;
  height: 3px;
  background: var(--primary);
  margin: 30px 0;
  border-radius: 10px;
}

.alt-blog-v2-desc.mx-auto {
  border-left: none;
  padding-left: 0;
  text-align: center;
}

.alt-blog-v2-title {
  text-align: center;
}

/* ==========================================================================
   NEW BLOG BANNER V3 - Asymmetric Premium
   ========================================================================== */

.alt-blog-v3-hero {
  background-color: #050505;
  padding: 160px 0 100px;
  position: relative;
  overflow: hidden;
}

.alt-blog-v3-bg-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 20vw;
  font-weight: 900;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.03);
  white-space: nowrap;
  pointer-events: none;
  z-index: 0;
  text-transform: uppercase;
}

.alt-blog-v3-title-wrap {
  position: relative;
  z-index: 2;
}

.alt-blog-v3-label {
  color: var(--primary);
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 4px;
  margin-bottom: 20px;
  display: block;
}

.alt-blog-v3-title {
  font-size: clamp(60px, 8vw, 120px);
  font-weight: 900;
  color: #fff;
  line-height: 0.9;
  text-transform: uppercase;
  letter-spacing: -4px;
}

.alt-blog-v3-title .outline {
  color: transparent;
  -webkit-text-stroke: 1.5px #fff;
}

.alt-blog-v3-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 40px;
  border-radius: 24px;
  backdrop-filter: blur(20px);
  position: relative;
  margin-top: 40px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.alt-blog-v3-card::after {
  content: "";
  position: absolute;
  top: -1px;
  left: 20%;
  width: 30%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--primary), transparent);
}

.alt-blog-v3-desc {
  font-size: 18px;
  color: #a1a1aa;
  line-height: 1.6;
  margin: 0;
}

@media (max-width: 991px) {
  .alt-blog-v3-hero {
    padding: 120px 0 60px;
    text-align: center;
  }

  .alt-blog-v3-title {
    letter-spacing: -2px;
  }

  .alt-blog-v3-card {
    margin-top: 30px;
    padding: 30px;
  }
}

/* ==========================================================================
   NEW BLOG BANNER V4 - Glass Mesh Design
   ========================================================================== */

.alt-blog-v4-hero {
  background-color: #07070a;
  padding: 180px 0 120px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.alt-blog-v4-mesh {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 0.4;
}

.alt-blog-v4-mesh::before,
.alt-blog-v4-mesh::after {
  content: "";
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  filter: blur(120px);
  animation: v4Float 20s infinite alternate ease-in-out;
}

.alt-blog-v4-mesh::before {
  background: var(--primary);
  top: -20%;
  left: -10%;
}

.alt-blog-v4-mesh::after {
  background: #3f5efb;
  bottom: -20%;
  right: -10%;
  animation-delay: -10s;
}

@keyframes v4Float {
  0% {
    transform: translate(0, 0) scale(1);
  }

  100% {
    transform: translate(100px, 100px) scale(1.3);
  }
}

.alt-blog-v4-glass {
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(40px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 40px;
  padding: 80px 60px;
  position: relative;
  z-index: 1;
  max-width: 900px;
  text-align: center;
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.5);
}

.alt-blog-v4-title {
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 30px;
  text-transform: uppercase;
  letter-spacing: -2px;
}

.alt-blog-v4-title span {
  color: var(--primary);
}

.alt-blog-v4-desc {
  font-size: 20px;
  color: #d1d1d1;
  line-height: 1.6;
  max-width: 700px;
  margin: 0 auto;
}

.alt-blog-v4-ornament {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: -1;
}

.alt-blog-v4-glass::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent);
  border-radius: 40px;
  pointer-events: none;
}

@media (max-width: 767px) {
  .alt-blog-v4-glass {
    padding: 40px 20px;
    border-radius: 20px;
  }
}

/* ==========================================================================
   NEW BLOG BANNER V5 - Split Panel Pro
   ========================================================================== */

.alt-blog-v5-hero {
  background-color: #000;
  min-height: 70vh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.alt-blog-v5-left {
  flex: 0 0 50%;
  display: flex;
  align-items: center;
  padding: 100px 80px;
  position: relative;
  z-index: 2;
  background: #000;
}

.alt-blog-v5-right {
  flex: 0 0 50%;
  position: relative;
  overflow: hidden;
}

.alt-blog-v5-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 2s ease;
}

.alt-blog-v5-hero:hover .alt-blog-v5-img {
  transform: scale(1.1);
}

.alt-blog-v5-content {
  max-width: 500px;
}

.alt-blog-v5-tag {
  display: inline-block;
  padding: 6px 15px;
  background: var(--primary);
  color: #000;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 30px;
  border-radius: 4px;
}

.alt-blog-v5-title {
  font-size: clamp(40px, 5vw, 70px);
  font-weight: 900;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 25px;
  text-transform: uppercase;
}

.alt-blog-v5-desc {
  font-size: 18px;
  color: #888;
  line-height: 1.6;
}

.alt-blog-v5-accent {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 150px;
  height: 150px;
  background: var(--primary);
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  z-index: 3;
}

@media (max-width: 991px) {
  .alt-blog-v5-hero {
    flex-direction: column;
    min-height: auto;
  }

  .alt-blog-v5-left,
  .alt-blog-v5-right {
    flex: 0 0 100%;
    width: 100%;
  }

  .alt-blog-v5-left {
    padding: 150px 30px 0;
    order: 2;
  }

  .alt-blog-v5-right {
    height: 400px;
    order: 1;
  }
}

/* ==========================================================================
   NEW SERVICE DETAIL V2 - Sovereign Design
   ========================================================================== */

.alt-service-v2-main {
  background-color: #050505;
  color: #fff;
}

/* 1. PARALLAX HERO */
.alt-service-v2-hero {
  height: 100vh;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.alt-service-v2-hero-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 120%;
  /* For parallax */
  z-index: 0;
}

.alt-service-v2-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.4) saturate(0.8);
}

.alt-service-v2-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
}

.alt-service-v2-subtitle {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 6px;
  color: var(--primary);
  margin-bottom: 20px;
  display: block;
}

.alt-service-v2-title {
  font-size: clamp(60px, 10vw, 150px);
  font-weight: 900;
  line-height: 0.9;
  text-transform: uppercase;
  letter-spacing: -6px;
  margin: 0;
}

/* 2. CORE LAYOUT */
.alt-service-v2-core {
  padding: 120px 0;
}

.alt-service-v2-sticky-wrap {
  position: sticky;
  top: 120px;
}

.alt-service-v2-num {
  font-size: 120px;
  font-weight: 900;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.1);
  line-height: 1;
  margin-bottom: 20px;
}

.alt-service-v2-core-title {
  font-size: 40px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 30px;
}

.alt-service-v2-desc {
  font-size: 20px;
  color: #a1a1aa;
  line-height: 1.6;
}

/* 3. BENTO GRID FEATURES */
.alt-service-v2-features {
  padding-bottom: 120px;
}

.alt-service-v2-bento {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 200px;
  gap: 24px;
}

.alt-service-v2-bento-item {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 30px;
  padding: 40px;
  position: relative;
  overflow: hidden;
  transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.alt-service-v2-bento-item:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--primary);
  transform: translateY(-10px);
}

.bento-icon {
  font-size: 40px;
  color: var(--primary);
  margin-bottom: 20px;
}

.bento-title {
  font-size: 24px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 15px;
}

.bento-desc {
  font-size: 16px;
  color: #888;
}

/* Specific Bento Sizes */
.bento-lg {
  grid-column: span 8;
  grid-row: span 2;
}

.bento-md {
  grid-column: span 4;
  grid-row: span 2;
}

.bento-sm {
  grid-column: span 4;
  grid-row: span 1;
}

.bento-wide {
  grid-column: span 6;
  grid-row: span 1;
}

/* 4. CTA SECTION */
.alt-service-v2-cta {
  background: linear-gradient(to right, #000, #111);
  padding: 100px 0;
  text-align: center;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.alt-service-v2-cta-title {
  font-size: 60px;
  font-weight: 800;
  margin-bottom: 40px;
}

.alt-service-v2-btn {
  display: inline-flex;
  padding: 20px 50px;
  background: var(--primary);
  color: #000;
  font-weight: 800;
  text-transform: uppercase;
  border-radius: 100px;
  transition: 0.3s;
}

.alt-service-v2-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 0 30px var(--primary);
  color: #000;
}

@media (max-width: 991px) {
  .alt-service-v2-bento {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .bento-lg,
  .bento-md,
  .bento-sm,
  .bento-wide {
    grid-column: span 1;
    grid-row: span 1;
  }

  .alt-service-v2-sticky-wrap {
    position: static;
    margin-bottom: 50px;
  }
}

/* ==========================================================================
   NEW SERVICE DETAIL V3 - Modern Agency Clean
   ========================================================================== */

.alt-service-v3-main {
  background-color: #08080a;
}

/* 1. CLEAN SPLIT HERO */
.alt-service-v3-hero {
  padding: 200px 0 100px;
  position: relative;
}

.alt-service-v3-hero-tag {
  color: var(--primary);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 3px;
  margin-bottom: 20px;
  display: block;
}

.alt-service-v3-title {
  font-size: clamp(40px, 8vw, 100px);
  font-weight: 900;
  color: #fff;
  line-height: 1;
  margin-bottom: 30px;
}

.alt-service-v3-hero-img-wrap {
  position: relative;
  border-radius: 40px;
  overflow: hidden;
  box-shadow: 0 50px 100px rgba(0, 0, 0, 0.4);
}

.alt-service-v3-hero-img-wrap img {
  width: 100%;
  height: 600px;
  object-fit: cover;
}

/* 2. STATS BAR */
.alt-service-v3-stats {
  padding: 60px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 100px;
}

.stat-item h4 {
  font-size: 50px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 5px;
}

.stat-item p {
  color: #666;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 700;
}

/* 3. CONTENT AREA */
.alt-service-v3-content-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 80px;
  margin-bottom: 120px;
}

.alt-service-v3-sticky-label {
  position: sticky;
  top: 120px;
  font-size: 24px;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
}

.alt-service-v3-text {
  font-size: 22px;
  line-height: 1.7;
  color: #a1a1aa;
}

/* 4. PROCESS CARDS */
.alt-service-v3-step {
  background: #111;
  padding: 50px;
  border-radius: 30px;
  margin-bottom: 30px;
  transition: 0.3s;
}

.alt-service-v3-step:hover {
  background: #161618;
  transform: scale(1.02);
}

.step-num {
  font-size: 14px;
  color: var(--primary);
  font-weight: 800;
  margin-bottom: 20px;
  display: block;
}

.step-title {
  font-size: 30px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 15px;
}

@media (max-width: 991px) {
  .alt-service-v3-content-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .alt-service-v3-hero {
    padding: 140px 0 60px;
  }

  .alt-service-v3-hero-img-wrap img {
    height: 350px;
  }
}

/* ==========================================================================
   NEW SERVICE DETAIL V4 - Technical Monolith
   ========================================================================== */

.alt-service-v4-main {
  background-color: #030303;
  color: #fff;
}

/* 1. MONOLITH HERO */
.alt-service-v4-hero {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  background: radial-gradient(circle at center, #111 0%, #000 100%);
}

.alt-service-v4-glow {
  position: absolute;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(63, 224, 247, 0.1) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(50px);
  z-index: 0;
  animation: v4Pulse 10s infinite alternate;
}

@keyframes v4Pulse {
  0% {
    transform: scale(1);
    opacity: 0.5;
  }

  100% {
    transform: scale(1.2);
    opacity: 0.8;
  }
}

.alt-service-v4-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
}

.alt-service-v4-title {
  font-size: clamp(50px, 12vw, 180px);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -8px;
  line-height: 0.85;
  margin: 0;
  background: linear-gradient(180deg, #fff 30%, rgba(255, 255, 255, 0.1) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* 2. THE DATA SHEET */
.alt-service-v4-data {
  padding: 150px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.alt-service-v4-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 40px;
}

.alt-service-v4-info-box {
  grid-column: span 5;
}

.alt-service-v4-img-box {
  grid-column: span 7;
  position: relative;
  border-radius: 20px;
  overflow: hidden;
}

.alt-service-v4-img-box img {
  width: 100%;
  height: 700px;
  object-fit: cover;
  filter: grayscale(1) brightness(0.8);
  transition: 0.8s;
}

.alt-service-v4-img-box:hover img {
  filter: grayscale(0) brightness(1);
  transform: scale(1.05);
}

.alt-service-v4-label {
  font-size: 12px;
  font-weight: 900;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 5px;
  margin-bottom: 30px;
  display: block;
}

.alt-service-v4-text {
  font-size: 24px;
  line-height: 1.5;
  color: #fff;
  font-weight: 300;
}

/* 3. TECHNICAL SPECS (PROCESS) */
.alt-service-v4-specs {
  padding-bottom: 150px;
}

.spec-row {
  display: flex;
  justify-content: space-between;
  padding: 40px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  align-items: center;
}

.spec-name {
  font-size: 14px;
  color: #555;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.spec-val {
  font-size: 40px;
  font-weight: 700;
  color: #fff;
  text-align: right;
}

@media (max-width: 991px) {

  .alt-service-v4-info-box,
  .alt-service-v4-img-box {
    grid-column: span 12;
  }

  .alt-service-v4-title {
    letter-spacing: -2px;
  }

  .spec-val {
    font-size: 24px;
  }
}

/* ==========================================================================
   NEW SERVICE DETAIL V5 - Kinetic Typography (No Images)
   ========================================================================== */

.alt-service-v5-main {
  background-color: #000;
  color: #fff;
}

/* 1. TYPOGRAPHIC HERO */
.alt-service-v5-hero {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.alt-service-v5-hero-bg-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 30vw;
  font-weight: 900;
  color: rgba(255, 255, 255, 0.02);
  white-space: nowrap;
  pointer-events: none;
  text-transform: uppercase;
  z-index: 0;
}

.alt-service-v5-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
}

.alt-service-v5-hero-label {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 10px;
  color: var(--primary);
  margin-bottom: 40px;
  display: block;
}

.alt-service-v5-title {
  font-size: clamp(50px, 12vw, 160px);
  font-weight: 900;
  line-height: 0.8;
  text-transform: uppercase;
  letter-spacing: -6px;
  margin: 0;
}

.alt-service-v5-title span {
  display: block;
  color: transparent;
  -webkit-text-stroke: 1px #fff;
}

/* 2. MINIMALIST OVERVIEW */
.alt-service-v5-overview {
  padding: 200px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.alt-service-v5-section-title {
  font-size: 80px;
  font-weight: 800;
  margin-bottom: 60px;
  text-transform: uppercase;
  line-height: 1;
}

.alt-service-v5-desc-text {
  font-size: 32px;
  line-height: 1.4;
  color: #fff;
  font-weight: 400;
  max-width: 900px;
}

.alt-service-v5-desc-text p {
  margin-bottom: 0;
}

/* 3. STEP GRID (Typographic) */
.alt-service-v5-steps {
  padding-bottom: 200px;
}

.alt-service-v5-step-item {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 60px 0;
  display: flex;
  align-items: flex-start;
  transition: 0.4s;
}

.alt-service-v5-step-item:hover {
  background: rgba(255, 255, 255, 0.02);
  padding-left: 30px;
}

.alt-service-v5-step-num {
  font-size: 20px;
  font-weight: 800;
  color: var(--primary);
  margin-right: 100px;
  min-width: 50px;
}

.alt-service-v5-step-content {
  flex: 1;
}

.alt-service-v5-step-title {
  font-size: 50px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 20px;
}

.alt-service-v5-step-desc {
  font-size: 18px;
  color: #888;
  max-width: 600px;
}

/* 4. CTA (TYPOGRAPHIC) */
.alt-service-v5-cta {
  padding: 200px 0;
  text-align: center;
  background: #fff;
  color: #000;
}

.alt-service-v5-cta-title {
  font-size: clamp(40px, 8vw, 100px);
  font-weight: 900;
  text-transform: uppercase;
  line-height: 0.9;
  margin-bottom: 60px;
}

.alt-service-v5-cta-btn {
  font-size: 24px;
  font-weight: 800;
  text-transform: uppercase;
  color: #000;
  text-decoration: underline;
  text-underline-offset: 10px;
  transition: 0.3s;
}

.alt-service-v5-cta-btn:hover {
  color: var(--primary);
  text-underline-offset: 15px;
}

@media (max-width: 991px) {
  .alt-service-v5-step-item {
    flex-direction: column;
  }

  .alt-service-v5-step-num {
    margin-bottom: 20px;
  }

  .alt-service-v5-step-title {
    font-size: 30px;
  }

  .alt-service-v5-section-title {
    font-size: 40px;
  }

  .alt-service-v5-desc-text {
    font-size: 22px;
  }
}

/* ==========================================================================
   NEW SERVICE DETAIL V6 - Swiss Dark Minimal
   ========================================================================== */

.alt-service-v6-main {
  background-color: #0a0a0a;
  color: #fff;
  padding: 100px 0;
}

.alt-service-v6-section {
  padding: 120px 0;
  border-top: 1px solid #1a1a1a;
}

.alt-service-v6-num {
  font-size: 14px;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 20px;
  display: block;
}

.alt-service-v6-title {
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -2px;
  margin-bottom: 40px;
  line-height: 1;
  color: var(--white);
}

.alt-service-v6-content {
  font-size: 24px;
  line-height: 1.5;
  color: #a1a1aa;
}

.alt-service-v6-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
}

.alt-service-v6-feature {
  padding: 40px;
  background: #111;
  border-radius: 20px;
}

.alt-service-v6-feature h3 {
  font-size: 30px;
  font-weight: 700;
  margin-bottom: 20px;
}

.alt-service-v6-feature p {
  font-size: 16px;
  color: #666;
  margin: 0;
}

.alt-service-v6-cta {
  background: var(--primary);
  color: #000;
  padding: 100px 0;
  text-align: center;
}

.alt-service-v6-cta h2 {
  font-size: 60px;
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 40px;
}

.alt-service-v6-btn {
  display: inline-block;
  padding: 20px 60px;
  background: #000;
  color: #fff;
  font-weight: 800;
  text-transform: uppercase;
  border-radius: 100px;
  transition: 0.3s;
}

.alt-service-v6-btn:hover {
  background: #222;
  transform: translateY(-5px);
}

@media (max-width: 991px) {
  .alt-service-v6-grid {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   NEW SERVICE DETAIL V7 - Quantum Node (Dark + Canvas)
   ========================================================================== */

.alt-service-v7-main {
  background-color: #050507;
  color: #fff;
  position: relative;
  min-height: 100vh;
}

#alt-v7-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
  opacity: 0.6;
}

.alt-service-v7-hero {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 2;
}

.alt-service-v7-glass-card {
  background: rgba(255, 255, 255, 0.02);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 40px;
  padding: 80px 60px;
  text-align: center;
  max-width: 1000px;
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.5);
}

.alt-service-v7-label {
  font-size: 14px;
  font-weight: 700;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 5px;
  margin-bottom: 30px;
  display: block;
}

.alt-service-v7-title {
  font-size: clamp(50px, 8vw, 120px);
  font-weight: 900;
  text-transform: uppercase;
  line-height: 0.9;
  margin-bottom: 40px;
  letter-spacing: -4px;
}

.alt-service-v7-desc {
  font-size: 22px;
  color: #a1a1aa;
  line-height: 1.6;
  max-width: 800px;
  margin: 0 auto;
}

.alt-service-v7-nodes {
  padding: 150px 0;
  position: relative;
  z-index: 2;
}

.alt-service-v7-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
}

.alt-service-v7-node-item {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 50px;
  border-radius: 30px;
  transition: 0.5s;
  position: relative;
  overflow: hidden;
}

.alt-service-v7-node-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--primary), transparent);
  transform: translateX(-100%);
  transition: 0.5s;
}

.alt-service-v7-node-item:hover {
  background: rgba(255, 255, 255, 0.06);
  transform: translateY(-10px);
}

.alt-service-v7-node-item:hover::before {
  transform: translateX(100%);
}

.node-num {
  font-size: 12px;
  color: var(--primary);
  font-weight: 800;
  margin-bottom: 20px;
  display: block;
}

.node-title {
  font-size: 32px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 20px;
}

.node-text {
  font-size: 16px;
  color: #888;
  line-height: 1.6;
}

.alt-service-v7-cta {
  padding: 150px 0;
  text-align: center;
  position: relative;
  z-index: 2;
}

.alt-service-v7-btn {
  display: inline-flex;
  padding: 25px 60px;
  background: var(--primary);
  color: #000;
  font-weight: 900;
  text-transform: uppercase;
  border-radius: 100px;
  font-size: 18px;
  letter-spacing: 2px;
  transition: 0.4s;
  box-shadow: 0 10px 40px rgba(63, 224, 247, 0.3);
}

.alt-service-v7-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 20px 60px rgba(63, 224, 247, 0.5);
  color: #000;
}

/* ==========================================================================
   NEW SERVICE DETAIL V8 - Liquid Wave (Dark + Canvas)
   ========================================================================== */

.alt-service-v8-main {
  background-color: #000;
  color: #fff;
  position: relative;
}

#alt-v8-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

.alt-service-v8-hero {
  height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
  z-index: 2;
  padding-left: 10%;
}

.alt-service-v8-title {
  font-size: clamp(60px, 10vw, 150px);
  font-weight: 900;
  text-transform: uppercase;
  line-height: 0.85;
  letter-spacing: -6px;
  background: linear-gradient(180deg, #fff 50%, rgba(255, 255, 255, 0.1) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.alt-service-v8-content-box {
  padding: 150px 0;
  position: relative;
  z-index: 2;
  background: linear-gradient(to bottom, transparent, #000 20%, #000 80%, transparent);
}

.alt-service-v8-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 20px;
  padding: 60px;
  backdrop-filter: blur(20px);
  transition: 0.5s;
}

.alt-service-v8-card:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--primary);
  transform: scale(1.02);
}

.alt-service-v8-label {
  font-size: 14px;
  font-weight: 800;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 4px;
  margin-bottom: 20px;
  display: block;
}

.alt-service-v8-text {
  font-size: 26px;
  line-height: 1.5;
  font-weight: 300;
  color: #ccc;
}

.alt-service-v8-step-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-top: 100px;
}

.alt-service-v8-step {
  padding: 40px;
  border-left: 2px solid rgba(255, 255, 255, 0.1);
  transition: 0.3s;
}

.alt-service-v8-step:hover {
  border-left-color: var(--primary);
  background: rgba(255, 255, 255, 0.02);
}

.step-title {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 15px;
  text-transform: uppercase;
}

.step-desc {
  font-size: 16px;
  color: #666;
}

/* ==========================================================================
   NEW SERVICE DETAIL V9 - Executive Monolith (Professional Dark)
   ========================================================================== */

.alt-service-v9-main {
  background-color: #080808;
  color: #fff;
}

.alt-service-v9-hero {
  padding: 220px 0 60px;
  background: linear-gradient(180deg, #0f0f0f 0%, #080808 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.alt-service-v9-tag {
  color: var(--primary);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 5px;
  margin-bottom: 25px;
  display: block;
}

.alt-service-v9-title {
  font-size: clamp(48px, 7vw, 110px);
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: -3px;
  margin: 0;
  color: var(--white);
  max-width: 800px;
}

.alt-service-v9-overview {
  padding: 50px 0;
}

.alt-service-v9-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 60px;
}

.alt-service-v9-label {
  grid-column: span 3;
  font-size: 18px;
  font-weight: 700;
  color: #b0b0b0;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.alt-service-v9-text {
  grid-column: span 9;
  font-size: 24px;
  line-height: 1.6;
  color: #a1a1aa;
}

.alt-service-v9-text h2,
.alt-service-v9-text h3,
.alt-service-v9-text h4,
.alt-service-v9-text h5,
.alt-service-v9-text h6 {
  font-size: 30px;
  color: #fff;
  margin: 40px 0 20px;
}

.alt-service-v9-text p,
.alt-service-v9-text li,
.alt-service-v9-text span {
  color: #ececec;
  font-size: 16px;
  line-height: 26px;
}

.alt-service-v9-text ul {
  margin: 20px 0;
  padding-left: 30px;
}

.alt-service-v9-features {
  padding-bottom: 150px;
}

.alt-service-v9-feature-item {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding: 60px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: 0.3s;
}

.alt-service-v9-feature-item:hover {
  background: rgba(255, 255, 255, 0.02);
  padding-left: 20px;
  padding-right: 20px;
}

.feature-num {
  font-size: 14px;
  color: #444;
  font-weight: 700;
}

.feature-title {
  font-size: 40px;
  font-weight: 700;
  color: #fff;
  flex: 1;
  margin-left: 80px;
}

.feature-arrow {
  font-size: 30px;
  color: var(--primary);
  opacity: 0;
  transform: translateX(-20px);
  transition: 0.3s;
}

.alt-service-v9-feature-item:hover .feature-arrow {
  opacity: 1;
  transform: translateX(0);
}

.alt-service-v9-cta {
  padding: 150px 0;
  background: #000;
  text-align: center;
}

.alt-service-v9-cta-btn {
  font-size: 60px;
  font-weight: 900;
  color: #fff;
  text-transform: uppercase;
  text-decoration: none;
  transition: 0.3s;
  display: inline-block;
}

.alt-service-v9-cta-btn span {
  color: var(--primary);
}

.alt-service-v9-cta-btn:hover {
  transform: scale(1.05);
  letter-spacing: 2px;
}

/* ==========================================================================
   NEW SERVICE DETAIL V10 - Visual Flow Capability List (Image Inspired)
   ========================================================================== */

.alt-service-v10-capabilities {
  padding: 50px 0;
  background-color: #050505;
  overflow: hidden;
}

.alt-v10-flow-container {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
}

.alt-v10-step {
  display: flex;
  align-items: center;
  margin-bottom: 150px;
  position: relative;
}

.alt-v10-step:last-child {
  margin-bottom: 0;
}

/* Card Styling */
.alt-v10-card {
  flex: 0 0 45%;
  background: rgba(255, 255, 255, 0.03);
  padding: 50px;
  border-radius: 20px;
  position: relative;
  border-left: 4px solid var(--primary);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
}

.alt-v10-num {
  font-size: 60px;
  font-weight: 900;
  color: var(--primary);
  line-height: 1;
  margin-bottom: 20px;
}

.alt-v10-title {
  font-size: 28px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 20px;
  color: #fff;
}

.alt-v10-desc {
  font-size: 16px;
  color: #a1a1aa;
  line-height: 1.6;
}

/* Illustration Space */
.alt-v10-illu {
  flex: 0 0 55%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 50px;
}

.alt-v10-illu-box {
  width: 100%;
  max-width: 350px;
  height: 250px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px dashed rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
  font-size: 100px;
}

.card-inner {
  background: rgba(10, 20, 20, 0.85);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(63, 224, 247, 0.15);
  padding: 8px 45px 8px 8px;
  /* Extra padding on right for arrow */
  border-radius: 100px;
  display: flex;
  align-items: center;
  gap: 15px;
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.6);
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  min-width: 240px;
  position: relative;
}

.card-icon-wrap {
  width: 42px;
  height: 42px;
  flex-shrink: 0;
}

.card-icon-inner {
  width: 100%;
  height: 100%;
  background: rgba(63, 224, 247, 0.05);
  border: 1px solid rgba(63, 224, 247, 0.2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
  box-shadow: inset 0 0 10px rgba(63, 224, 247, 0.1);
}

.card-text-content {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
}

.card-title {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.8);
  letter-spacing: 0.5px;
  text-transform: none;
}

.card-counter {
  font-size: 18px;
  font-weight: 800;
  color: #fff;
}

.card-counter .plus {
  color: var(--primary);
  margin-left: 2px;
}

.card-arrow {
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--primary);
  opacity: 0.8;
}

.metric-card:hover .card-inner {
  border-color: var(--primary);
  background: rgba(10, 20, 20, 0.95);
  transform: scale(1.05);
}

/* Alternating Logic */
.alt-v10-step:nth-child(even) {
  flex-direction: row-reverse;
}

/* Connecting Curves (Simplified with SVG background or pseudo elements) */
.alt-v10-connector {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 100px;
  height: 150px;
  z-index: 1;
}

.alt-v10-connector svg {
  width: 100%;
  height: 100%;
  stroke: rgba(63, 224, 247, 0.2);
  stroke-width: 2;
  fill: none;
  stroke-dasharray: 10;
}

@media (max-width: 991px) {

  .alt-v10-step,
  .alt-v10-step:nth-child(even) {
    flex-direction: column;
    margin-bottom: 80px;
  }

  .alt-v10-card,
  .alt-v10-illu {
    flex: 0 0 100%;
    width: 100%;
  }

  .alt-v10-illu {
    margin-top: 40px;
    padding: 0;
  }

  .alt-v10-connector {
    display: none;
  }
}

/* REFINING V10 - The Notebook Grid + Hand-drawn Curves */

.alt-service-v10-capabilities {
  background-image:
    linear-gradient(rgba(63, 224, 247, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(63, 224, 247, 0.03) 1px, transparent 1px);
  background-size: 40px 40px;
  /* Notebook Grid */
}

.alt-v10-card {
  border: 1px solid rgba(255, 255, 255, 0.1);
  /* Torn edge effect */
  /* clip-path: polygon(0% 2%, 5% 0%, 10% 2%, 15% 0%, 20% 2%, 25% 0%, 30% 2%, 35% 0%, 40% 2%, 45% 0%, 50% 2%, 55% 0%, 60% 2%, 65% 0%, 70% 2%, 75% 0%, 80% 2%, 85% 0%, 90% 2%, 95% 0%, 100% 2%,
      100% 98%, 95% 100%, 90% 98%, 85% 100%, 80% 98%, 75% 100%, 70% 98%, 65% 100%, 60% 98%, 55% 100%, 50% 98%, 45% 100%, 40% 98%, 35% 100%, 30% 98%, 25% 100%, 20% 98%, 15% 100%, 10% 98%, 5% 100%, 0% 98%); */
}

.alt-v10-connector {
  width: 200px;
  height: 200px;
  opacity: 0.4;
}

.alt-v10-step:nth-child(odd) .alt-v10-connector {
  left: 55%;
}

.alt-v10-step:nth-child(even) .alt-v10-connector {
  left: 45%;
}

.alt-v10-illu-box {
  transform: rotate(-3deg);
  border-width: 2px;
}

.alt-v10-step:nth-child(even) .alt-v10-illu-box {
  transform: rotate(3deg);
}

/* SUSPENSE CARD STYLING */
.alt-v10-card.suspense {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(0, 0, 0, 0.8) 100%);
  /* border: 1px solid var(--primary); */
  overflow: hidden;
}

.suspense-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  z-index: 10;
  transition: 0.5s;
}

.suspense-btn {
  background: var(--primary);
  color: #000;
  padding: 12px 25px;
  border-radius: 100px;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 14px;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(63, 224, 247, 0.4);
}

.suspense-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 15px 40px rgba(63, 224, 247, 0.6);
}

.alt-v10-card.suspense .alt-v10-desc {
  filter: blur(4px);
  user-select: none;
}

/* THEME SUITABLE GRADIENT BACKGROUND */

.alt-service-v9-main {
  background: radial-gradient(circle at 0% 0%, rgba(63, 224, 247, 0.05) 0%, transparent 50%),
    radial-gradient(circle at 100% 100%, rgba(63, 224, 247, 0.05) 0%, transparent 50%),
    #050505;
  position: relative;
  min-height: 100vh;
}

.alt-service-v9-main::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(5, 5, 5, 0) 0%, #000 100%);
  pointer-events: none;
  z-index: 1;
}

/* Adjusting sections to be transparent to show background */
.alt-service-v9-hero,
.alt-service-v9-overview,
.alt-service-v10-capabilities {
  background: transparent !important;
  position: relative;
  z-index: 2;
}

/* Subtle moving glow for extra premium feel */
.bg-mesh-glow {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at 50% 50%, rgba(63, 224, 247, 0.03) 0%, transparent 70%);
  z-index: 0;
  pointer-events: none;
  animation: meshMove 15s infinite alternate ease-in-out;
}

@keyframes meshMove {
  0% {
    transform: translate(-10%, -10%) scale(1);
  }

  100% {
    transform: translate(10%, 10%) scale(1.2);
  }
}


/* FINAL PREMIUM BACKGROUND REFINEMENT */

.alt-service-v9-main {
  background-color: #000000;
  background-image:
    radial-gradient(at 0% 0%, rgba(63, 224, 247, 0.08) 0, transparent 50%),
    radial-gradient(at 50% 0%, rgba(63, 224, 247, 0.03) 0, transparent 50%),
    radial-gradient(at 100% 0%, rgba(63, 224, 247, 0.08) 0, transparent 50%),
    radial-gradient(at 50% 50%, rgba(5, 5, 5, 1) 0, transparent 100%);
  background-attachment: fixed;
  position: relative;
  overflow: hidden;
}

/* Add a subtle scanline or noise texture for that "Digital" feel */
.alt-service-v9-main::after {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.1) 50%),
    linear-gradient(90deg, rgba(255, 0, 0, 0.01), rgba(0, 255, 0, 0.005), rgba(0, 0, 255, 0.01));
  background-size: 100% 2px, 3px 100%;
  pointer-events: none;
  z-index: 1;
  opacity: 0.3;
}

.alt-v10-card.suspense {
  background: rgba(10, 10, 10, 0.8) !important;
  border: 1px solid rgba(63, 224, 247, 0.2) !important;
  backdrop-filter: blur(15px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
}

/* --- PROFESSIONAL EXECUTIVE DESCRIPTION --- */
.executive-desc-wrap {
  position: relative;
}

.executive-paragraph {
  font-size: 24px;
  line-height: 1.5;
  color: #fff;
  font-weight: 300;
  margin: 0;
}

.executive-paragraph span.surface-text {
  display: block;
  font-size: 18px;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 15px;
  font-style: italic;
}

.executive-paragraph span.process-text {
  display: block;
  font-weight: 600;
  background: linear-gradient(90deg, #fff 0%, var(--primary) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.executive-paragraph b {
  color: var(--primary);
  font-weight: 800;
}

/* --- PREMIUM CONTACT HERO DESCRIPTION --- */
.contact-hero-desc-wrap {
  position: relative;
  padding-left: 40px;
  max-width: 750px;
}

.contact-hero-desc-wrap::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 1px;
  height: 100%;
  background: linear-gradient(to bottom, var(--primary), transparent);
}

.contact-hero-desc-wrap::after {
  content: '';
  position: absolute;
  left: -4px;
  top: 10%;
  width: 9px;
  height: 9px;
  background: var(--primary);
  border-radius: 50%;
  box-shadow: 0 0 15px var(--primary);
  animation: contactPulse 2s infinite;
}

@keyframes contactPulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  100% {
    transform: scale(2.5);
    opacity: 0;
  }
}

.contact-hero-paragraph {
  font-size: 21px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 300;
  margin: 0;
}

.contact-hero-paragraph b {
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.5px;
}

.contact-hero-paragraph .contact-accent {
  color: var(--primary);
  font-weight: 600;
  position: relative;
  display: inline-block;
}

.contact-hero-paragraph .contact-accent::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--primary);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.contact-hero-desc-wrap:hover .contact-accent::after {
  transform: scaleX(1);
  transform-origin: left;
}

.alt-input-group input {
  border: 1px solid rgb(255 255 255 / 17%) !important;
}

/* --- Social Media Custom Tooltips --- */
.social-tooltip {
  position: relative;
  display: inline-block;
}

.social-tooltip::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%) translateY(15px) scale(0.9);
  background: linear-gradient(135deg, rgba(20, 20, 22, 0.95), rgba(5, 5, 5, 0.98));
  backdrop-filter: blur(10px);
  color: #fff;
  padding: 2px 10px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  pointer-events: none;
  z-index: 100;
  font-family: 'Kanit', sans-serif;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.5), inset 0 0 0 1px rgba(63, 224, 247, 0.15);
}

.social-tooltip::before {
  content: '';
  position: absolute;
  bottom: calc(100% + 4px);
  left: 50%;
  width: 2px;
  height: 10px;
  background: var(--primary, #3fe0f7);
  transform: translateX(-50%) scaleY(0);
  transform-origin: bottom;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  pointer-events: none;
  z-index: 99;
  box-shadow: 0 0 8px var(--primary, #3fe0f7);
}

.social-tooltip:hover::after {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0) scale(1);
  border-color: rgba(63, 224, 247, 0.4);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.5), 0 0 15px rgba(63, 224, 247, 0.25);
}

.social-tooltip:hover::before {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) scaleY(1);
}

/* --- Footer Contact Icons --- */
.contact-info-link {
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.contact-info-link .contact-icon {
  margin-right: 5px;
  flex-shrink: 0;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.contact-info-link:hover {
  transform: translateX(5px);
  color: #fff !important;
}

.contact-info-link:hover .contact-icon {
  transform: scale(1.15) rotate(-5deg);
}

/* --- Text Truncation Utilities --- */
.text-line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ==========================================================================
   PROFESSIONAL BLOG HERO - Clean & Corporate
   ========================================================================== */

/* --- Total Page Background Design --- */
.alturaitz-blog-page-wrapper {
  background-color: #030303;
  background-image:
    radial-gradient(ellipse at 15% 10%, rgba(63, 224, 247, 0.08) 0%, transparent 40%),
    radial-gradient(ellipse at 85% 70%, rgba(63, 224, 247, 0.04) 0%, transparent 50%),
    linear-gradient(180deg, #051416 0%, #030303 30%, #050507 100%);
  position: relative;
  min-height: 100vh;
}

.alturaitz-blog-hero-pro {
  position: relative;
  padding: 80px 0 80px;
  background-color: transparent;
  min-height: 100vh;
  display: flex;
  align-items: center;
}

.ai-grid-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image:
    linear-gradient(rgba(63, 224, 247, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(63, 224, 247, 0.03) 1px, transparent 1px);
  background-size: 50px 50px;
  z-index: 1;
  mask-image: radial-gradient(ellipse at center, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 0%, transparent 80%);
  pointer-events: none;
}

.ai-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.6;
  animation: orbMotion 15s infinite alternate ease-in-out;
  z-index: 1;
  pointer-events: none;
}

.ai-orb-primary {
  top: -10%;
  left: 10%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(63, 224, 247, 0.5) 0%, transparent 70%);
  animation-delay: 0s;
}

.ai-orb-secondary {
  bottom: -20%;
  right: 5%;
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(0, 168, 196, 0.4) 0%, transparent 70%);
  animation-delay: -5s;
}

.ai-orb-tertiary {
  top: 30%;
  left: 40%;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.08) 0%, transparent 70%);
  animation-delay: -10s;
}

@keyframes orbMotion {
  0% {
    transform: translate(0, 0) scale(1);
  }

  33% {
    transform: translate(100px, -50px) scale(1.1);
  }

  66% {
    transform: translate(-50px, 100px) scale(0.9);
  }

  100% {
    transform: translate(0, 0) scale(1);
  }
}

.alturaitz-blog-hero-pro .container {
  position: relative;
  z-index: 10;
}

.blog-pro-meta {
  margin-bottom: 40px;
}

.glass-badge {
  display: inline-flex;
  align-items: center;
  padding: 8px 24px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 50px;
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 4px;
  color: #fff;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.02), 0 10px 30px rgba(0, 0, 0, 0.5);
}

.blog-pro-title {
  font-size: 110px;
  font-weight: 300;
  color: #ffffff;
  line-height: 1.05;
  margin-bottom: 0;
  letter-spacing: -3px;
  text-shadow: 0 20px 40px rgba(0, 0, 0, 0.5);
}

.blog-pro-title .text-gradient {
  font-weight: 800;
  background: linear-gradient(135deg, #ffffff 0%, var(--primary, #3fe0f7) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
  filter: drop-shadow(0 0 20px rgba(63, 224, 247, 0.3));
}

.blog-pro-desc {
  font-size: 22px;
  color: #aeb4c6;
  line-height: 1.7;
  max-width: 650px;
  margin: 40px auto 0;
  font-weight: 300;
}

.blog-cta-area {
  margin-top: 40px;
}

.ai-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 36px;
  background: linear-gradient(135deg, rgba(63, 224, 247, 0.15), rgba(255, 255, 255, 0.05));
  border: 1px solid rgba(63, 224, 247, 0.3);
  border-radius: 50px;
  color: #fff;
  font-weight: 600;
  font-size: 16px;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  backdrop-filter: blur(10px);
  text-decoration: none;
}

.ai-cta-btn:hover {
  background: var(--primary, #3fe0f7);
  color: #000 !important;
  transform: translateY(-5px);
  box-shadow: 0 15px 30px rgba(63, 224, 247, 0.3);
  border-color: transparent;
}

@media (max-width: 991px) {
  .blog-pro-title {
    font-size: 55px;
    letter-spacing: -1.5px;
  }

  .alturaitz-blog-hero-pro {
    padding: 120px 0 30px;
    min-height: auto;
  }

  .blog-pro-desc {
    font-size: 18px;
    margin-top: 30px;
  }

  .ai-orb {
    filter: blur(60px);
  }
}

/* --- Premium Circular UI (Reference Match) --- */
.premium-about-section {
  position: relative;
  background-color: #05050A;
  /* Deep dark background */
  overflow: hidden;
  color: #fff;
  min-height: 80vh;
  display: flex;
  align-items: center;
}

/* Floating 3D Cubes/Elements */
.premium-bg-cube {
  position: absolute;
  background: linear-gradient(135deg, #3fe0f75c, #3fe0f71c);
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.2), 0 10px 30px rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(10px);
  border-radius: 10px;
  z-index: 1;
  animation: premiumFloat 8s infinite alternate ease-in-out;
}

.cube-1 {
  width: 100px;
  height: 100px;
  top: 10%;
  right: 15%;
  transform: rotate(15deg);
}

.cube-2 {
  width: 140px;
  height: 140px;
  bottom: 5%;
  left: 10%;
  transform: rotate(-25deg);
  animation-delay: -4s;
}

@keyframes premiumFloat {
  0% {
    transform: translateY(0) rotate(15deg);
  }

  100% {
    transform: translateY(-30px) rotate(25deg);
  }
}

/* The Massive Gradient Circle */
.premium-massive-circle {
  position: absolute;
  top: 50%;
  left: -15%;
  transform: translateY(-50%);
  width: 900px;
  height: 900px;
  border-radius: 50%;
  opacity: 0.6;
  z-index: 2;
  filter: blur(2px);
}

/* Main Content Container inside Circle area */
.premium-circle-content {
  position: relative;
  z-index: 10;
  padding-left: 5%;
}

.premium-title-monumental {
  font-size: clamp(40px, 4vw, 65px);
  font-weight: 800;
  line-height: 1.1;
  text-transform: uppercase;
  margin-bottom: 30px;
  letter-spacing: 0px;
  color: #fff;
}

.premium-title-monumental .title-light {
  font-weight: 300;
}

.premium-core-years {
  position: absolute;
  right: 0%;
  top: 50%;
  transform: translateY(-50%);
  text-align: right;
  z-index: 1;
  /* Behind the list wrapper (which is z-index 10) */
  pointer-events: none;
  opacity: 0.25;
  /* Watermark effect */
}

.premium-core-years .core-number {
  font-size: 350px;
  font-weight: 900;
  line-height: 1;
  margin: 0;
  font-family: var(--alturaitz-ff-inter, sans-serif);
  color: #fff;
  letter-spacing: -5px;
}

.premium-core-years .core-label {
  font-size: 24px;
  text-transform: uppercase;
  letter-spacing: 5px;
  color: #fff;
  white-space: nowrap;
}

/* The List on the Right */
.premium-list-wrapper {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 40px;
  padding-left: 10%;
  /* Push away from center */
}

.premium-list-item {
  display: flex;
  align-items: center;
  gap: 30px;
  transition: transform 0.3s ease;
}

.premium-list-item:hover {
  transform: translateX(10px);
}

/* The Icons on the Circle Edge */
.premium-list-item .item-icon {
  width: 80px;
  height: 80px;
  background: #0c1112;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), inset 0 0 20px #3fe0f73b;
  backdrop-filter: blur(10px);
  transition: all 0.3s ease;
}

.premium-list-item:hover .item-icon {
  border-color: #3fe0f7;
  box-shadow: 0 10px 30px #3fe0f752, inset 0 0 20px #3fe0f76b;
  transform: scale(1.05);
}

.premium-list-item .item-content {
  flex-grow: 1;
}

.premium-list-item .item-title {
  font-size: 24px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
  display: flex;
  align-items: baseline;
  gap: 5px;
}

.premium-list-item .sat-num {
  font-size: 28px;
}

.premium-list-item .item-desc {
  font-size: 20px;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
  margin: 0;
}

/* Adjust layout for curves */
.premium-list-item:nth-child(1) {
  margin-left: 40px;
}

.premium-list-item:nth-child(2) {
  margin-left: -20px;
}

.premium-list-item:nth-child(3) {
  margin-left: -20px;
}

.premium-list-item:nth-child(4) {
  margin-left: 40px;
}

@media (max-width: 991px) {
  .premium-massive-circle {
    left: 50%;
    top: 20%;
    transform: translate(-50%, -50%);
    width: 600px;
    height: 600px;
  }

  .premium-core-years {
    position: relative;
    right: auto;
    top: auto;
    transform: none;
    text-align: left;
    opacity: 1;
    margin-top: 40px;
  }

  .premium-core-years .core-number {
    font-size: 130px;
    letter-spacing: 0;
  }

  .premium-core-years {
    text-align: center;
  }

  .premium-core-years .core-label {
    font-size: 16px;
    letter-spacing: 2px;
  }

  .premium-list-wrapper {
    padding-left: 0;
    margin-top: 60px;
  }

  .premium-list-item {
    margin-left: 0 !important;
  }
}

/* ==========================================================================
   Single.php Redesign (Immersive Hero & Glassmorphic Sidebar)
   ========================================================================== */

.alturaitz-immersive-hero {
  position: relative;
  width: 100%;
  padding: 200px 0 100px;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 70vh;
}

.immersive-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 102%;
  background: linear-gradient(180deg, rgba(7, 7, 10, 0.6) 0%, rgba(7, 7, 10, 0.9) 100%);
  backdrop-filter: blur(8px);
  z-index: 1;
}

.alturaitz-immersive-breadcrumb ul {
  display: flex;
  align-items: center;
  justify-content: center;
  list-style: none;
  gap: 10px;
  padding: 0;
  margin: 0;
}

.alturaitz-immersive-breadcrumb ul li,
.alturaitz-immersive-breadcrumb ul li a {
  color: rgba(255, 255, 255, 0.6);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.alturaitz-immersive-breadcrumb ul li a:hover {
  color: var(--primary, #3fe0f7);
}

.alturaitz-immersive-breadcrumb ul li span {
  display: inline-block;
  width: 6px;
  height: 6px;
  background: var(--primary, #3fe0f7);
  border-radius: 50%;
}

.immersive-title {
  text-transform: capitalize;
  letter-spacing: -1px;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.alturaitz-immersive-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  color: #fff;
}

.meta-cat {
  background: rgba(63, 224, 247, 0.1);
  border: 1px solid rgba(63, 224, 247, 0.3);
  color: var(--primary, #3fe0f7);
  padding: 6px 16px;
  border-radius: 50px;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.meta-dot {
  width: 4px;
  height: 4px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 50%;
}

.meta-date {
  color: rgba(255, 255, 255, 0.7);
  font-size: 15px;
}

/* Content Area */
.alturaitz-premium-content {
  font-size: 18px;
  line-height: 1.8;
  color: #c9c9c9;
}

.alturaitz-premium-content h2,
.alturaitz-premium-content h3 {
  color: #fff;
  margin-top: 40px;
  margin-bottom: 20px;
  font-size: 36px;
}

.alturaitz-premium-content h4,
.alturaitz-premium-content h5 {
  color: #fff;
  margin-top: 30px;
  margin-bottom: 20px;
  font-size: 24px;
}

.alturaitz-premium-content p {
  color: #c9c9c9;
  margin-bottom: 25px;
}

.alturaitz-premium-content blockquote {
  border-left: 4px solid var(--primary, #3fe0f7);
  padding-left: 25px;
  margin: 27px 0;
  font-size: 22px;
  font-style: italic;
  color: #fff;
  background: rgba(255, 255, 255, 0.02);
  padding: 0px 30px;
  border-radius: 0 15px 15px 0;
}

/* Post Navigation V2 */
.alturaitz-post-navigation-v2 {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  gap: 30px;
}

.alturaitz-nav-v2-item {
  flex: 1;
}

.nav-v2-link {
  display: flex;
  flex-direction: column;
  color: #fff;
  transition: all 0.3s ease;
  padding: 20px 0;
  position: relative;
}

.nav-v2-link::before {
  content: '';
  position: absolute;
  top: 0;
  width: 0;
  height: 2px;
  background: var(--primary, #3fe0f7);
  transition: 0.4s ease;
}

.alturaitz-nav-v2-item.prev .nav-v2-link::before {
  left: 0;
}

.alturaitz-nav-v2-item.next .nav-v2-link::before {
  right: 0;
}

.nav-v2-link:hover::before {
  width: 50%;
}

.nav-v2-link:hover {
  color: var(--primary, #3fe0f7);
}

.nav-v2-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 15px;
  transition: 0.3s ease;
}

.nav-v2-link:hover .nav-v2-label {
  color: var(--primary, #3fe0f7);
}

.nav-v2-label svg {
  transition: 0.3s ease;
}

.alturaitz-nav-v2-item.prev .nav-v2-link:hover .nav-v2-label svg {
  transform: translateX(-5px);
}

.alturaitz-nav-v2-item.next .nav-v2-link:hover .nav-v2-label svg {
  transform: translateX(5px);
}

.nav-v2-title {
  font-size: 24px;
  line-height: 1.4;
  color: inherit;
  font-weight: 600;
  margin: 0;
  transition: 0.3s;
}

/* Sidebar */
.sticky-sidebar {
  position: sticky;
  top: 100px;
}

.alturaitz-glass-widget {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgb(255 255 255 / 17%);
  backdrop-filter: blur(10px);
  border-radius: 20px;
  padding: 35px 30px;
  margin-bottom: 30px;
}

.widget-title {
  font-size: 24px;
  color: #fff;
  margin-bottom: 25px;
  position: relative;
  padding-bottom: 15px;
}

.widget-title::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 40px;
  height: 2px;
  background: var(--primary, #3fe0f7);
}

.category-list ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.category-list ul li {
  margin-bottom: 15px;
}

.category-list ul li a {
  color: rgba(255, 255, 255, 0.7);
  font-size: 16px;
  transition: 0.3s;
  display: flex;
  justify-content: space-between;
}

.category-list ul li a:hover {
  color: var(--primary, #3fe0f7);
  padding-left: 5px;
}

.rc-post-item {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding-bottom: 20px;
}

.rc-post-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

.rc-post-tag,
.rc-post-tag:hover {
  font-size: 12px;
  color: var(--primary, #3fe0f7);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.rc-post-title a {
  font-size: 18px;
  color: #fff;
  line-height: 1.5;
  transition: 0.3s;
}

.rc-post-title a:hover {
  color: var(--primary, #3fe0f7);
}

.toc {
  position: sticky;
  top: 120px;
}

.toc a {
  display: block;
  padding: 5px 15px;
  text-decoration: none;
  transition: all 0.4s ease;
}

.toc a:hover {
  color: var(--primary);
  padding-left: 10px;
}

.toc a.active {
  font-weight: 700;
}

.toc div {
  padding: 30px 20px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgb(255 255 255 / 17%);
  backdrop-filter: blur(10px);
  border-radius: 20px;
}

.alturaitz-premium-content ul {
  list-style: circle;
  margin-left: 30px;
  margin-bottom: 20px;
}

.alturaitz-premium-content a {
  font-weight: 500;
  color: #3fe0f7;
}