/* =========================================================
   ABHINOVA — pages.css
   ========================================================= */

/* ---- Nav active link ---- */
.nav-links a.is-active {
  color: var(--brand);
  background: rgba(124, 92, 255, .08);
  border-radius: 10px;
}

/* Sub-pages: offset for fixed site-header (ann-bar + nav) */
body > main > section:first-child,
.page-hero {
  scroll-margin-top: var(--header-h, 110px);
}

.page-hero {
  padding-top: var(--header-h, 110px);
  min-height: calc(70vh + var(--header-h, 110px));
}

/* ---- Zoom-in-view reveal ---- */
.zoom-in-view {
  opacity: 0;
  transform: scale(.94) translateY(22px);
  transition: opacity .75s cubic-bezier(.2, .7, .2, 1), transform .75s cubic-bezier(.2, .7, .2, 1);
  transition-delay: var(--d, 0s);
}

.zoom-in-view.in-view {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/* ---- Service bubbles flow ---- */
.bubbles-sec {
  padding: 2.2rem 0;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(124, 92, 255, .05), rgba(0, 194, 255, .04));
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.bubbles-label {
  text-align: center;
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 700;
  margin-bottom: 1.2rem;
}

.bubbles-track {
  display: flex;
  gap: .7rem;
  width: max-content;
  animation: bubbleScroll 30s linear infinite;
  padding: .3rem 0;
}

.bubbles-track:hover {
  animation-play-state: paused;
}

@keyframes bubbleScroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

.bubble-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .52rem 1.1rem;
  border-radius: 999px;
  background: #fff;
  border: 1.5px solid var(--line);
  font-size: .88rem;
  font-weight: 600;
  color: var(--ink-2);
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(11, 16, 32, .06);
  transition: transform .25s, box-shadow .25s, border-color .25s, color .25s;
  cursor: default;
}

.bubble-pill:hover {
  transform: translateY(-3px) scale(1.04);
  box-shadow: 0 10px 28px rgba(124, 92, 255, .2);
  border-color: var(--brand);
  color: var(--brand);
}

.bubble-pill .bpico {
  font-size: 1rem;
  line-height: 1;
}

/* ---- Image showcase grid ---- */
.showcase {
  max-width: var(--maxw);
  margin: 5rem auto;
  padding: 0 clamp(1rem, 4vw, 2rem);
}

.showcase-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  grid-template-rows: 260px 260px;
  gap: .9rem;
}

.sc-item {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
}

.sc-item.sc-big {
  grid-row: span 2;
}

.sc-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .7s cubic-bezier(.2, .7, .2, 1);
}

.sc-item:hover img {
  transform: scale(1.08);
}

.sc-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(11, 16, 32, .75) 0%, transparent 55%);
  display: flex;
  align-items: flex-end;
  padding: 1.2rem 1.4rem;
  opacity: 0;
  transition: opacity .35s;
}

.sc-item:hover .sc-overlay {
  opacity: 1;
}

.sc-overlay span {
  color: #fff;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
}

/* ---- CTA Banner ---- */
.cta-banner {
  margin: 5rem 0;
  position: relative;
  overflow: hidden;
  min-height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cta-banner-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: bannerZoom 18s ease-in-out infinite alternate;
}

@keyframes bannerZoom {
  from {
    transform: scale(1);
  }

  to {
    transform: scale(1.07);
  }
}

.cta-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(124, 92, 255, .85), rgba(0, 194, 255, .78));
}

.cta-banner-content {
  position: relative;
  z-index: 1;
  text-align: center;
  color: #fff;
  padding: 3rem clamp(1rem, 4vw, 2rem);
  max-width: 680px;
}

.cta-banner-content h2 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 700;
  margin: 0 0 .75rem;
  color: #fff;
  line-height: 1.1;
}

.cta-banner-content p {
  font-size: 1.1rem;
  color: rgba(255, 255, 255, .9);
  margin: 0 0 1.8rem;
}

/* ---- Page hero ---- */
.page-hero {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}

.page-hero-bg {
  position: absolute;
  inset: 0;
}

.page-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: bannerZoom 20s ease-in-out infinite alternate;
}

.page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(11, 16, 32, .8), rgba(124, 92, 255, .65));
}

.page-hero-content {
  position: relative;
  z-index: 1;
  padding: 2rem clamp(1rem, 4vw, 2rem);
  max-width: 760px;
}

/* ---- Page section ---- */
.pg-section {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 5rem clamp(1rem, 4vw, 2rem);
}

.pg-section-wide {
  padding: 5rem clamp(1rem, 4vw, 2rem);
}

/* ---- Stats row ---- */
.pg-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--grad);
}

.pg-stat {
  text-align: center;
  color: #fff;
  border-right: 1px solid rgba(255, 255, 255, .2);
  padding: 2.2rem 1rem;
  transition: background .25s;
}

.pg-stat:last-child {
  border-right: none;
}

.pg-stat:hover {
  background: rgba(255, 255, 255, .1);
}

.pg-stat strong {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 800;
  letter-spacing: -.03em;
}

.pg-stat span {
  font-size: .9rem;
  opacity: .88;
  font-weight: 600;
}

/* ---- Deep service grid ---- */
.svc-deep-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.4rem;
}

.svc-deep-card {
  position: relative;
  padding: 2rem 1.6rem;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
  isolation: isolate;
}

.svc-deep-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--grad);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s var(--ease);
}

.svc-deep-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-2);
}

.svc-deep-card:hover::before {
  transform: scaleX(1);
}

.sdc-num {
  font-family: var(--font-mono);
  font-size: .72rem;
  color: var(--brand);
  background: rgba(124, 92, 255, .08);
  padding: .2rem .5rem;
  border-radius: 7px;
  display: inline-block;
  margin-bottom: .8rem;
}

.sdc-ico {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: var(--grad);
  color: #fff;
  margin-bottom: 1rem;
  box-shadow: 0 10px 24px -10px rgba(124, 92, 255, .6);
  transition: transform .35s var(--ease);
}

.svc-deep-card:hover .sdc-ico {
  transform: rotate(-6deg) scale(1.07);
}

.sdc-title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0 0 .5rem;
  color: var(--ink);
}

.sdc-desc {
  font-size: .97rem;
  color: var(--muted);
  line-height: 1.65;
  margin: 0 0 1rem;
}

.sdc-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}

.sdc-tag {
  font-size: .72rem;
  padding: .22rem .52rem;
  border-radius: 7px;
  background: rgba(124, 92, 255, .08);
  color: var(--brand);
  font-weight: 600;
  border: 1px solid rgba(124, 92, 255, .15);
}

/* ---- Process timeline ---- */
.process-timeline {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
  position: relative;
}

.process-timeline::before {
  content: "";
  position: absolute;
  top: 22px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: var(--grad);
  opacity: .3;
}

.ptl-step {
  position: relative;
  text-align: center;
  padding: 1.4rem 1rem 1.6rem;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}

.ptl-step:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-2);
}

.ptl-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--grad);
  color: #fff;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 800;
  margin: 0 auto 1rem;
  box-shadow: 0 8px 20px -8px rgba(124, 92, 255, .6);
}

.ptl-step h3 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  margin: 0 0 .4rem;
  color: var(--ink);
}

.ptl-step p {
  font-size: .9rem;
  color: var(--muted);
  margin: 0;
  line-height: 1.6;
}

/* ---- Founder feature (team page) ---- */
.founder-feature {
  display: grid;
  grid-template-columns: .42fr 1fr;
  gap: 3rem;
  align-items: start;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 2.8rem;
  box-shadow: var(--shadow-2);
}

.ff-image {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4/5;
}

.ff-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s;
  display: block;
}

.ff-image:hover img {
  transform: scale(1.04);
}

.ff-badge {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  background: var(--grad);
  color: #fff;
  padding: .4rem .8rem;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  box-shadow: 0 6px 14px rgba(124, 92, 255, .5);
}

/* ---- Culture cards ---- */
.culture-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.3rem;
}

.culture-card {
  padding: 2rem 1.4rem;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  text-align: center;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}

.culture-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-2);
}

.culture-ico {
  font-size: 2.2rem;
  margin-bottom: 1rem;
}

.culture-card h3 {
  font-family: var(--font-display);
  font-size: 1.15rem;
  margin: 0 0 .5rem;
  color: var(--ink);
}

.culture-card p {
  font-size: .95rem;
  color: var(--muted);
  margin: 0;
  line-height: 1.65;
}

/* ---- Page CTA strip ---- */
.pg-cta-strip {
  background: var(--grad);
  text-align: center;
  padding: 4.5rem clamp(1rem, 4vw, 2rem);
  color: #fff;
}

.pg-cta-strip h2 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  margin: 0 0 .6rem;
  color: #fff;
  font-weight: 700;
}

.pg-cta-strip p {
  font-size: 1.12rem;
  margin: 0 0 2rem;
  opacity: .92;
  color: #fff;
}

.pg-cta-strip .btn {
  margin: .35rem;
}

.pg-cta-strip .btn-primary {
  background: #fff;
  color: var(--brand);
  box-shadow: 0 10px 28px rgba(0, 0, 0, .2);
}

.pg-cta-strip .btn-primary:hover {
  background: #f0edff;
  transform: translateY(-2px);
}

/* ---- Responsive ---- */
@media (max-width: 1100px) {
  .showcase-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 240px 240px;
  }

  .sc-item.sc-big {
    grid-row: span 1;
  }

  .svc-deep-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .process-timeline {
    grid-template-columns: repeat(3, 1fr);
  }

  .process-timeline::before {
    display: none;
  }

  .founder-feature {
    grid-template-columns: 1fr;
    padding: 1.8rem;
  }

  .ff-image {
    aspect-ratio: 16/8;
  }

  .culture-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .pg-stats-row {
    grid-template-columns: repeat(2, 1fr);
  }

  .pg-stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, .2);
  }

  .pg-stat:nth-child(odd) {
    border-right: 1px solid rgba(255, 255, 255, .2);
  }
}

@media (max-width: 720px) {
  .showcase-grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .sc-item {
    height: 200px;
  }

  .svc-deep-grid {
    grid-template-columns: 1fr;
  }

  .process-timeline {
    grid-template-columns: 1fr 1fr;
  }

  .culture-grid {
    grid-template-columns: 1fr 1fr;
  }

  .pg-stats-row {
    grid-template-columns: 1fr 1fr;
  }

  .page-hero {
    min-height: 55vh;
  }

  .cta-banner {
    min-height: 300px;
  }
}

/* ---- Extra visibility overrides ---- */
.svc-deep-card,
.ptl-step,
.culture-card,
.founder-feature {
  background: #ffffff !important;
  border: 1.5px solid rgba(10, 15, 30, .1) !important;
}

.sdc-title,
.ptl-step h3,
.culture-card h3 {
  color: #0a0f1e !important;
}

.sdc-desc,
.ptl-step p,
.culture-card p {
  color: #2e3a55 !important;
}

.sdc-num,
.sdc-tag {
  color: #7c5cff !important;
}

/* ---- MODERN ENHANCEMENTS FOR SUB-PAGES ---- */

/* Service cards triple hover effect */
.svc-deep-card {
  position: relative;
  overflow: hidden;
  transition: all .4s cubic-bezier(.2, .7, .2, 1);
}

.svc-deep-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(124, 92, 255, .1) 0%, transparent 70%);
  opacity: 0;
  transition: opacity .4s var(--ease);
  pointer-events: none;
  z-index: 1;
}

.svc-deep-card:hover::after {
  opacity: 1;
}

/* Process timeline step animations */
.ptl-step {
  position: relative;
  transition: all .35s var(--ease);
}

.ptl-step:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 20px 50px -15px rgba(124, 92, 255, .35), inset 0 1px 0 rgba(255, 255, 255, .6);
}

.ptl-num {
  transition: all .35s var(--ease);
}

.ptl-step:hover .ptl-num {
  transform: scale(1.15) rotate(-5deg);
}

/* Page hero image improvements */
.page-hero-bg img {
  transition: transform .8s ease-in-out;
}

.page-hero:hover .page-hero-bg img {
  transform: scale(1.05);
}

/* Showcase grid improvements */
.sc-item {
  transition: all .5s var(--ease);
  position: relative;
}

.sc-item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(124, 92, 255, .15) 0%, transparent 70%);
  opacity: 0;
  transition: opacity .4s var(--ease);
  z-index: 1;
}

.sc-item:hover::before {
  opacity: 1;
}

.sc-item img {
  will-change: transform;
}

/* CTA Banner improvements */
.cta-banner-content {
  animation: slideUp .7s var(--ease);
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Zoom-in-view reveal animation */
.zoom-in-view {
  animation: zoomReveal .6s var(--ease) forwards;
  opacity: 0;
  transform: scale(.92) translateY(20px);
}

.zoom-in-view.in-view {
  animation-play-state: running;
}

@keyframes zoomReveal {
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* Process timeline line animation */
.process-timeline::before {
  background: linear-gradient(90deg, transparent, #7c5cff, transparent);
  background-size: 200% 100%;
  animation: gradientMove 4s ease-in-out infinite;
}

@keyframes gradientMove {

  0%,
  100% {
    background-position: 200% 0;
  }

  50% {
    background-position: -200% 0;
  }
}

/* Bubble pill animation improvements */
.bubble-pill {
  transition: all .35s var(--ease);
  position: relative;
}

.bubble-pill::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--grad);
  opacity: 0;
  z-index: -1;
  transition: opacity .35s var(--ease);
  filter: blur(8px);
}

.bubble-pill:hover::after {
  opacity: .2;
}

.pg-section {
  background: transparent;
}

.pg-cta-strip h2,
.pg-cta-strip p {
  color: #fff !important;
}

.pg-stat strong {
  color: #fff !important;
  font-size: clamp(2rem, 4vw, 3.2rem) !important;
}

.pg-stat span {
  color: rgba(255, 255, 255, .92) !important;
}

.bubble-pill {
  color: #151d35 !important;
  font-weight: 700 !important;
  font-size: .9rem !important;
}

.page-hero-content h1,
.page-hero-content p {
  color: #fff !important;
}

/* =============================================================
   PROJECTS PAGE — proj-hero, trust strip, process, filters
   ============================================================= */

/* Hero orbs */
.proj-hero { overflow: hidden; }
.proj-hero-orbs { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.pho {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: .35; mix-blend-mode: screen;
}
.pho-a {
  width: 500px; height: 500px;
  background: radial-gradient(circle, #7c5cff, transparent 65%);
  top: -120px; right: -100px;
}
.pho-b {
  width: 400px; height: 400px;
  background: radial-gradient(circle, #00c2ff, transparent 65%);
  bottom: -80px; left: -60px;
}

/* Filters on projects page */
.proj-filters {
  max-width: 900px;
  margin-left: auto; margin-right: auto;
  margin-bottom: .6rem;
}

/* Trust strip */
.proj-trust-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  background: rgba(255,255,255,.75);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 1.6rem 1.4rem;
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-1);
}
.proj-trust-item {
  display: flex; align-items: center; gap: .9rem;
}
.proj-trust-ico {
  font-size: 1.8rem; line-height: 1; flex-shrink: 0;
}
.proj-trust-item strong {
  display: block; font-size: .96rem; font-weight: 700;
  color: var(--ink); margin-bottom: .1rem;
}
.proj-trust-item span {
  font-size: .82rem; color: var(--muted);
}

/* Process timeline on projects page */
.proj-process-strip .process-timeline {
  grid-template-columns: repeat(5, 1fr);
}

/* CTA strip buttons spacing */
.pg-cta-strip .btn { margin: .4rem; }

/* Responsive */
@media (max-width: 1100px) {
  .proj-trust-inner { grid-template-columns: repeat(2, 1fr); }
  .proj-process-strip .process-timeline { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .proj-trust-inner { grid-template-columns: 1fr; }
  .proj-process-strip .process-timeline { grid-template-columns: 1fr 1fr; }
  .proj-filters { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; padding-bottom: .4rem; }
  .proj-filters .chip { flex-shrink: 0; }
}
