/*
Theme Name: Agnito Corporate
Theme URI: https://agnitotechnologies.com/
Author: Agnito Technologies
Author URI: https://agnitotechnologies.com/
Description: Modern corporate WordPress theme for Agnito Technologies - Custom Software Development Company specializing in Fantasy Sports, Lottery, and Scalable Software Solutions.
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: corporate, technology, dark, modern, responsive, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready
Text Domain: agnito
*/

/* ============================================
   CSS CUSTOM PROPERTIES
   ============================================ */
:root {
  --color-navy:        #060d1f;
  --color-navy-mid:    #0d1b38;
  --color-navy-light:  #152244;
  --color-blue:        #1565d8;
  --color-blue-bright: #2979ff;
  --color-cyan:        #00c2ff;
  --color-gold:        #f7c542;
  --color-gold-dark:   #e0a800;
  --color-white:       #ffffff;
  --color-off-white:   #e8edf5;
  --color-muted:       #8a9bbf;
  --color-border:      rgba(255,255,255,0.08);
  --color-card-bg:     rgba(255,255,255,0.04);
  --color-card-hover:  rgba(255,255,255,0.07);

  --font-display: 'Outfit', sans-serif;
  --font-body:    'Inter', sans-serif;

  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --radius-pill: 999px;

  --shadow-card:  0 4px 24px rgba(0,0,0,0.35);
  --shadow-glow:  0 0 40px rgba(21,101,216,0.25);
  --shadow-gold:  0 0 30px rgba(247,197,66,0.2);

  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --header-h: 80px;
}

/* ============================================
   RESET & BASE
   ============================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-body);
  background-color: var(--color-navy);
  color: var(--color-off-white);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--color-cyan); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-gold); }

img { max-width: 100%; height: auto; display: block; }

ul { list-style: none; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-white);
}

p { color: var(--color-muted); margin-bottom: 1rem; }

section { position: relative; }

/* ============================================
   UTILITY CLASSES
   ============================================ */
.text-gold    { color: var(--color-gold) !important; }
.text-cyan    { color: var(--color-cyan) !important; }
.text-white   { color: var(--color-white) !important; }
.text-muted   { color: var(--color-muted) !important; }
.bg-navy      { background: var(--color-navy); }
.bg-navy-mid  { background: var(--color-navy-mid); }

.section-pad  { padding: 90px 0; }
.section-pad-sm { padding: 60px 0; }

.section-label {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-cyan);
  background: rgba(0,194,255,0.1);
  border: 1px solid rgba(0,194,255,0.25);
  padding: 5px 14px;
  border-radius: var(--radius-pill);
  margin-bottom: 16px;
}

.section-title {
  font-size: clamp(2rem, 4vw, 2.8rem);
  margin-bottom: 16px;
}

.section-title span { color: var(--color-gold); }

.section-sub {
  font-size: 1rem;
  color: var(--color-muted);
  max-width: 560px;
  line-height: 1.8;
}

/* Grid decorative line */
.divider-line {
  width: 60px; height: 3px;
  background: linear-gradient(90deg, var(--color-blue), var(--color-cyan));
  border-radius: 2px;
  margin: 16px 0 24px;
}

/* ============================================
   BUTTONS
   ============================================ */
.btn-primary-ag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 30px;
  background: linear-gradient(135deg, var(--color-blue), var(--color-blue-bright));
  color: var(--color-white);
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  border-radius: var(--radius-pill);
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  box-shadow: 0 4px 20px rgba(41,121,255,0.35);
  text-transform: uppercase;
}
.btn-primary-ag:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(41,121,255,0.5);
  color: var(--color-white);
  background: linear-gradient(135deg, var(--color-blue-bright), #5b9bff);
}

.btn-outline-ag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  background: transparent;
  color: var(--color-white);
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  border-radius: var(--radius-pill);
  border: 1.5px solid rgba(255,255,255,0.25);
  cursor: pointer;
  transition: all var(--transition);
  text-transform: uppercase;
}
.btn-outline-ag:hover {
  border-color: var(--color-cyan);
  color: var(--color-cyan);
  background: rgba(0,194,255,0.06);
}

.btn-gold-ag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 30px;
  background: linear-gradient(135deg, var(--color-gold), var(--color-gold-dark));
  color: var(--color-navy);
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: var(--radius-pill);
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  box-shadow: var(--shadow-gold);
  text-transform: uppercase;
}
.btn-gold-ag:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(247,197,66,0.45);
  color: var(--color-navy);
}

/* ============================================
   CARD STYLES
   ============================================ */
.card-ag {
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 32px;
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
}
.card-ag::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  background: linear-gradient(135deg, rgba(0,194,255,0.15), transparent) border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity var(--transition);
}
.card-ag:hover { 
  background: var(--color-card-hover);
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
}
.card-ag:hover::before { opacity: 1; }

/* ============================================
   HEADER / NAVIGATION
   ============================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--header-h);
  transition: all var(--transition);
}
.site-header.scrolled {
  background: rgba(6,13,31,0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--color-border);
  box-shadow: 0 4px 30px rgba(0,0,0,0.3);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
  padding: 0 40px;
  max-width: 1400px;
  margin: 0 auto;
}

.site-logo img { height: 48px; width: auto; object-fit: contain; }
.site-logo .logo-text {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--color-white);
  letter-spacing: -0.02em;
}
.site-logo .logo-text span { color: var(--color-gold); }

/* Main nav */
.main-nav-wrap {
  display: flex;
  align-items: center;
  flex: 1;
  justify-content: flex-end;
  gap: 0;
}

.main-nav { display: flex; align-items: center; gap: 4px; }

.main-nav > li { position: relative; }
.main-nav > li > a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 7px 11px;
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-off-white);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  white-space: nowrap;
}
.main-nav > li > a:hover,
.main-nav > li.current-menu-item > a,
.main-nav > li.current-menu-ancestor > a {
  color: var(--color-cyan);
  background: rgba(0,194,255,0.08);
}

/* Dropdown arrow */
.main-nav > li.menu-item-has-children > a::after {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  margin-top: -2px;
  transition: transform var(--transition);
}
.main-nav > li.menu-item-has-children:hover > a::after { transform: rotate(-135deg); margin-top: 2px; }

/* Dropdown */
.main-nav .sub-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 220px;
  background: var(--color-navy-mid);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 8px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.5);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--transition);
  z-index: 100;
}
.main-nav li:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.main-nav .sub-menu li a {
  display: block;
  padding: 9px 14px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-muted);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
}
.main-nav .sub-menu li a:hover {
  color: var(--color-white);
  background: rgba(255,255,255,0.06);
  padding-left: 20px;
}

/* Third level */
.main-nav .sub-menu .sub-menu {
  left: 100%;
  top: 0;
}

/* CTA in nav */
.nav-cta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: 16px;
}

/* Mobile toggle */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 42px; height: 42px;
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  gap: 5px;
  transition: all var(--transition);
}
.nav-toggle span {
  display: block;
  width: 22px; height: 2px;
  background: var(--color-white);
  border-radius: 2px;
  transition: all var(--transition);
}
.nav-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.nav-toggle.active span:nth-child(2) { opacity: 0; }
.nav-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ============================================
   HERO / BANNER
   ============================================ */
.hero-section {
  min-height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding-top: 0;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-navy) 0%, #0a1535 60%, #081020 100%);
  z-index: 0;
}
.hero-bg::before {
  content: '';
  position: absolute;
  top: -20%; right: -10%;
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(21,101,216,0.2) 0%, transparent 60%);
  animation: pulse-glow 6s ease-in-out infinite alternate;
}
.hero-bg::after {
  content: '';
  position: absolute;
  bottom: -10%; left: -5%;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(247,197,66,0.08) 0%, transparent 60%);
  animation: pulse-glow 8s ease-in-out infinite alternate-reverse;
}

@keyframes pulse-glow {
  from { transform: scale(1); opacity: 0.6; }
  to   { transform: scale(1.15); opacity: 1; }
}

/* Grid bg pattern */
.hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  z-index: 0;
}

.hero-content { position: relative; z-index: 1; }

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 18px;
  background: rgba(247,197,66,0.1);
  border: 1px solid rgba(247,197,66,0.3);
  border-radius: var(--radius-pill);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-gold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.hero-badge .dot {
  width: 6px; height: 6px;
  background: var(--color-gold);
  border-radius: 50%;
  animation: blink 1.5s ease-in-out infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

.hero-headline {
  font-size: clamp(1.9rem, 3.8vw, 3rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
  color: var(--color-white);
}
.hero-headline .highlight {
  background: linear-gradient(135deg, var(--color-cyan), var(--color-blue-bright));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-headline .gold-text { color: var(--color-gold); -webkit-text-fill-color: var(--color-gold); }

.hero-sub {
  font-size: 1.1rem;
  color: var(--color-muted);
  max-width: 520px;
  line-height: 1.8;
  margin-bottom: 36px;
}

.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 52px; }

.hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  padding-top: 32px;
  border-top: 1px solid var(--color-border);
}
.hero-stat-item .num {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-white);
  line-height: 1;
  display: block;
}
.hero-stat-item .num span { color: var(--color-gold); }
.hero-stat-item .lbl {
  font-size: 0.8rem;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 4px;
  display: block;
}

/* Hero image side */
.hero-visual {
  position: relative;
  z-index: 1;
}
.hero-image-wrap {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.hero-image-wrap::before {
  content: '';
  position: absolute;
  inset: -2px;
  background: linear-gradient(135deg, var(--color-blue), var(--color-cyan), var(--color-gold));
  border-radius: calc(var(--radius-lg) + 2px);
  z-index: -1;
  opacity: 0.5;
}
.hero-image-wrap img {
  width: 100%;
  border-radius: var(--radius-lg);
  position: relative;
}

/* Floating badges */
.float-badge {
  position: absolute;
  background: var(--color-navy-mid);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 12px 18px;
  backdrop-filter: blur(12px);
  animation: float 4s ease-in-out infinite;
  box-shadow: var(--shadow-card);
}
.float-badge.badge-1 { top: 15%; right: -30px; }
.float-badge.badge-2 { bottom: 20%; left: -30px; animation-delay: 2s; }

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

/* ============================================
   SERVICES / TECHNOLOGY
   ============================================ */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}

.service-card {
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 32px 28px;
  transition: all var(--transition);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.service-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 100%; height: 3px;
  background: linear-gradient(90deg, var(--color-blue), var(--color-cyan));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}
.service-card:hover {
  background: var(--color-card-hover);
  transform: translateY(-5px);
  border-color: rgba(0,194,255,0.2);
  box-shadow: var(--shadow-glow);
}
.service-card:hover::after { transform: scaleX(1); }

.service-icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(21,101,216,0.2), rgba(0,194,255,0.1));
  border: 1px solid rgba(0,194,255,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 20px;
  transition: all var(--transition);
}
.service-card:hover .service-icon {
  background: linear-gradient(135deg, var(--color-blue), var(--color-cyan));
  border-color: transparent;
  box-shadow: 0 0 20px rgba(0,194,255,0.35);
}

.service-card h4 {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 10px;
  color: var(--color-white);
}
.service-card p { font-size: 0.875rem; color: var(--color-muted); margin: 0; line-height: 1.7; }

.service-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-cyan);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  transition: gap var(--transition);
}
.service-link:hover { gap: 10px; color: var(--color-cyan); }

/* ============================================
   INDUSTRIES / PORTFOLIO
   ============================================ */
.portfolio-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 36px;
}

.filter-btn {
  padding: 9px 22px;
  border-radius: var(--radius-pill);
  border: 1.5px solid var(--color-border);
  background: transparent;
  color: var(--color-muted);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition);
}
.filter-btn:hover, .filter-btn.active {
  background: var(--color-blue);
  border-color: var(--color-blue);
  color: var(--color-white);
  box-shadow: 0 4px 16px rgba(21,101,216,0.35);
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 24px;
}

.portfolio-item {
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
  aspect-ratio: 4/3;
  cursor: pointer;
}
.portfolio-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.portfolio-item:hover img { transform: scale(1.08); }

.portfolio-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(6,13,31,0.95) 0%, rgba(6,13,31,0.4) 60%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
  opacity: 0;
  transition: opacity var(--transition);
}
.portfolio-item:hover .portfolio-overlay { opacity: 1; }
.portfolio-overlay h4 { font-size: 1.1rem; color: var(--color-white); margin-bottom: 4px; }
.portfolio-overlay span { font-size: 0.8rem; color: var(--color-cyan); text-transform: uppercase; letter-spacing: 0.1em; }

/* ============================================
   STATS COUNTER
   ============================================ */
.stats-section {
  background: linear-gradient(135deg, var(--color-navy-mid), var(--color-navy-light));
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

.stat-block {
  text-align: center;
  padding: 40px 20px;
  border-right: 1px solid var(--color-border);
}
.stat-block:last-child { border-right: 0; }

.stat-block .count {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--color-white), var(--color-cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  display: block;
}
.stat-block .count .plus { -webkit-text-fill-color: var(--color-gold); color: var(--color-gold); }
.stat-block .label {
  font-size: 0.85rem;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 8px;
  display: block;
}

/* ============================================
   TECHNOLOGY STACK TABS
   ============================================ */
.tech-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 32px; }

.tech-tab {
  padding: 8px 20px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  background: var(--color-card-bg);
  color: var(--color-muted);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--transition);
}
.tech-tab.active, .tech-tab:hover {
  background: rgba(21,101,216,0.15);
  border-color: var(--color-blue);
  color: var(--color-cyan);
}

.tech-icons-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 16px;
}

.tech-icon-item {
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 20px;
  text-align: center;
  transition: all var(--transition);
}
.tech-icon-item:hover {
  border-color: rgba(0,194,255,0.3);
  background: var(--color-card-hover);
  transform: translateY(-3px);
}
.tech-icon-item span {
  display: block;
  font-size: 2rem;
  margin-bottom: 8px;
}
.tech-icon-item p {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-muted);
  margin: 0;
}

/* ============================================
   BLOG / NEWS
   ============================================ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 28px;
}

.blog-card {
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all var(--transition);
}
.blog-card:hover {
  transform: translateY(-5px);
  border-color: rgba(0,194,255,0.2);
  box-shadow: var(--shadow-card);
}

.blog-card-thumb {
  width: 100%; aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--color-navy-light);
}
.blog-card-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.blog-card:hover .blog-card-thumb img { transform: scale(1.06); }

.blog-card-body { padding: 24px; }
.blog-card-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 12px;
  font-size: 0.78rem;
  color: var(--color-muted);
}
.blog-card-meta .cat {
  background: rgba(21,101,216,0.2);
  color: var(--color-cyan);
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.blog-card-body h3 {
  font-size: 1.05rem;
  margin-bottom: 10px;
  line-height: 1.4;
  transition: color var(--transition);
}
.blog-card:hover h3 { color: var(--color-cyan); }
.blog-card-body p { font-size: 0.875rem; color: var(--color-muted); line-height: 1.7; margin-bottom: 16px; }

.blog-read-more {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-cyan);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap var(--transition);
}
.blog-read-more:hover { gap: 10px; color: var(--color-gold); }

/* ============================================
   SINGLE / DETAIL PAGE
   ============================================ */
.blog-detail-wrap { max-width: 800px; }
.blog-detail-wrap h1, .blog-detail-wrap h2 { margin-bottom: 16px; }
.blog-detail-wrap h3 { margin: 28px 0 14px; color: var(--color-cyan); }
.blog-detail-wrap p { color: var(--color-muted); line-height: 1.9; margin-bottom: 20px; }
.blog-detail-wrap ul, .blog-detail-wrap ol { padding-left: 24px; margin-bottom: 20px; }
.blog-detail-wrap li { color: var(--color-muted); margin-bottom: 8px; }
.blog-detail-wrap a { color: var(--color-cyan); }
.blog-detail-wrap img { border-radius: var(--radius-md); margin-bottom: 24px; }
.blog-detail-wrap blockquote {
  border-left: 3px solid var(--color-blue);
  padding: 16px 24px;
  background: var(--color-card-bg);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin: 24px 0;
  font-style: italic;
  color: var(--color-off-white);
}

/* Post meta bar */
.post-meta-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
  padding: 16px 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 32px;
  font-size: 0.85rem;
  color: var(--color-muted);
}
.post-meta-bar .meta-item { display: flex; align-items: center; gap: 6px; }
.post-meta-bar .meta-item svg, .post-meta-bar .meta-item i { color: var(--color-cyan); font-size: 0.9rem; }

/* Sidebar */
.blog-sidebar { position: sticky; top: calc(var(--header-h) + 24px); }

.widget-block {
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 28px;
  margin-bottom: 28px;
}
.widget-block h4 {
  font-size: 1rem;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-white);
}

/* ============================================
   CONTACT FORM
   ============================================ */
.contact-form-wrap .form-group { margin-bottom: 20px; }

.contact-form-wrap input,
.contact-form-wrap textarea,
.contact-form-wrap select {
  width: 100%;
  background: var(--color-card-bg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.9rem;
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
.contact-form-wrap input::placeholder,
.contact-form-wrap textarea::placeholder { color: var(--color-muted); }
.contact-form-wrap input:focus,
.contact-form-wrap textarea:focus {
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(21,101,216,0.15);
}
.contact-form-wrap textarea { min-height: 130px; resize: vertical; }

.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 28px;
}
.contact-info-item .icon-box {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(21,101,216,0.2), rgba(0,194,255,0.1));
  border: 1px solid rgba(0,194,255,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.contact-info-item h5 { font-size: 0.85rem; color: var(--color-muted); font-weight: 500; margin-bottom: 4px; }
.contact-info-item p { font-size: 0.95rem; color: var(--color-white); margin: 0; }

/* ============================================
   FOOTER
   ============================================ */
.site-footer {
  background: var(--color-navy-mid);
  border-top: 1px solid var(--color-border);
}

.footer-top { padding: 70px 0 50px; }

.footer-brand .footer-logo img { height: 44px; margin-bottom: 20px; }
.footer-brand .footer-logo-text {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--color-white);
  margin-bottom: 16px;
}
.footer-brand .footer-logo-text span { color: var(--color-gold); }

.footer-desc { font-size: 0.875rem; color: var(--color-muted); line-height: 1.8; margin-bottom: 24px; max-width: 280px; }

.footer-social { display: flex; gap: 10px; }
.footer-social a {
  width: 38px; height: 38px;
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-muted);
  font-size: 0.9rem;
  transition: all var(--transition);
}
.footer-social a:hover {
  background: var(--color-blue);
  border-color: var(--color-blue);
  color: var(--color-white);
  transform: translateY(-2px);
}

.footer-col h5 {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: 20px;
}
.footer-col ul li { margin-bottom: 10px; }
.footer-col ul li a {
  font-size: 0.875rem;
  color: var(--color-muted);
  transition: all var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.footer-col ul li a::before {
  content: '';
  width: 0;
  height: 1px;
  background: var(--color-cyan);
  transition: width var(--transition);
  display: inline-block;
}
.footer-col ul li a:hover { color: var(--color-white); padding-left: 4px; }
.footer-col ul li a:hover::before { width: 8px; }

.footer-bottom {
  border-top: 1px solid var(--color-border);
  padding: 22px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-bottom p { font-size: 0.82rem; color: var(--color-muted); margin: 0; }
.footer-bottom .rating-badge {
  font-size: 0.82rem;
  color: var(--color-muted);
}
.footer-bottom .rating-badge .stars { color: var(--color-gold); letter-spacing: 2px; }

/* ============================================
   PAGE BANNERS
   ============================================ */
.page-banner {
  position: relative;
  min-height: 420px;
  display: flex;
  align-items: center;
  padding-top: 0;
  overflow: hidden;
}
.page-banner-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 100%);
  z-index: 0;
}
.page-banner-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.15;
}
.page-banner-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(6,13,31,0.9) 0%, rgba(6,13,31,0.5) 100%);
}

.page-banner-content {
  position: relative;
  z-index: 1;
  padding: 60px 0;
}
.page-banner-content h1 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 16px; }
.page-banner-content p { max-width: 500px; }

.breadcrumb-ag {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--color-muted);
  margin-bottom: 16px;
}
.breadcrumb-ag a { color: var(--color-cyan); }
.breadcrumb-ag .sep { color: var(--color-border); }

/* ============================================
   404 PAGE
   ============================================ */
.page-404 {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 80px 20px;
}
.page-404 .err-code {
  font-family: var(--font-display);
  font-size: clamp(6rem, 20vw, 12rem);
  font-weight: 900;
  line-height: 1;
  background: linear-gradient(135deg, var(--color-blue), var(--color-cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0.15;
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.page-404-content { position: relative; z-index: 1; }
.page-404-content h2 { font-size: clamp(1.5rem, 3vw, 2.5rem); margin-bottom: 16px; }

/* ============================================
   PRIVACY / STATIC PAGES
   ============================================ */
.content-page { padding: 80px 0; }
.content-page .prose h2 { font-size: 1.6rem; margin: 32px 0 14px; color: var(--color-white); }
.content-page .prose h3 { font-size: 1.2rem; margin: 24px 0 12px; color: var(--color-cyan); }
.content-page .prose p { color: var(--color-muted); line-height: 1.9; }
.content-page .prose ul { padding-left: 24px; }
.content-page .prose ul li { color: var(--color-muted); margin-bottom: 8px; }
.content-page .prose ul li::marker { color: var(--color-cyan); }

/* ============================================
   SITEMAP
   ============================================ */
.sitemap-wrap ul { padding: 0; }
.sitemap-wrap > ul > li {
  margin-bottom: 28px;
}
.sitemap-wrap > ul > li > a {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-white);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 12px;
}
.sitemap-wrap .sub-list {
  padding-left: 20px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px 20px;
}
.sitemap-wrap .sub-list a {
  font-size: 0.875rem;
  color: var(--color-muted);
  transition: color var(--transition);
}
.sitemap-wrap .sub-list a:hover { color: var(--color-cyan); }
.sitemap-wrap .sub-sub-list {
  padding-left: 16px;
  margin-top: 6px;
}
.sitemap-wrap .sub-sub-list a { font-size: 0.82rem; }

/* ============================================
   PAGINATION
   ============================================ */
.pagination-ag {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  padding: 40px 0;
}
.pagination-ag a,
.pagination-ag span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-card-bg);
  color: var(--color-muted);
  font-size: 0.875rem;
  font-weight: 600;
  transition: all var(--transition);
}
.pagination-ag a:hover,
.pagination-ag .current {
  background: var(--color-blue);
  border-color: var(--color-blue);
  color: var(--color-white);
  box-shadow: 0 4px 12px rgba(21,101,216,0.35);
}

/* ============================================
   SCROLL TO TOP
   ============================================ */
.scroll-top-btn {
  position: fixed;
  bottom: 32px; right: 32px;
  width: 46px; height: 46px;
  background: var(--color-blue);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  font-size: 1rem;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition);
  box-shadow: 0 4px 20px rgba(21,101,216,0.4);
  cursor: pointer;
}
.scroll-top-btn.visible { opacity: 1; visibility: visible; }
.scroll-top-btn:hover { background: var(--color-blue-bright); transform: translateY(-3px); }

/* ============================================
   WP-SPECIFIC OVERRIDES
   ============================================ */
.wp-block-image img,
.wp-block-gallery img {
  border-radius: var(--radius-md);
}

/* Contact Form 7 */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea,
.wpcf7-form select {
  width: 100%;
  background: var(--color-card-bg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.9rem;
  outline: none;
  transition: border-color var(--transition);
  margin-bottom: 4px;
}
.wpcf7-form input:focus, .wpcf7-form textarea:focus {
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(21,101,216,0.15);
}
.wpcf7-form input[type="submit"] {
  background: linear-gradient(135deg, var(--color-blue), var(--color-blue-bright));
  color: var(--color-white);
  border: none;
  padding: 13px 36px;
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--transition);
  width: auto !important;
}
.wpcf7-form input[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(41,121,255,0.4);
}

/* ============================================
   ANIMATIONS
   ============================================ */
.fade-in-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in-up.visible {
  opacity: 1;
  transform: translateY(0);
}
.fade-in-up:nth-child(1) { transition-delay: 0s; }
.fade-in-up:nth-child(2) { transition-delay: 0.1s; }
.fade-in-up:nth-child(3) { transition-delay: 0.2s; }
.fade-in-up:nth-child(4) { transition-delay: 0.3s; }
.fade-in-up:nth-child(5) { transition-delay: 0.4s; }
.fade-in-up:nth-child(6) { transition-delay: 0.5s; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1199px) {
  .header-inner { padding: 0 24px; }
  .main-nav > li > a { padding: 8px 10px; font-size: 0.76rem; }
}

@media (max-width: 991px) {
  .nav-toggle { display: flex; }
  
  .main-nav-wrap {
    position: fixed;
    top: var(--header-h); left: 0; right: 0;
    bottom: 0;
    background: rgba(6,13,31,0.98);
    backdrop-filter: blur(20px);
    overflow-y: auto;
    padding: 24px;
    transform: translateX(-100%);
    transition: transform var(--transition);
    z-index: 999;
  }
  .main-nav-wrap.open { transform: translateX(0); }

  .main-nav { flex-direction: column; gap: 0; }
  .main-nav > li > a {
    padding: 14px 16px;
    font-size: 1rem;
    border-bottom: 1px solid var(--color-border);
    border-radius: 0;
  }
  .main-nav .sub-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: 0;
    border-radius: 0;
    background: rgba(255,255,255,0.03);
    padding: 0;
    display: none;
    border-left: 2px solid var(--color-blue);
    margin-left: 16px;
  }
  .main-nav li.open > .sub-menu { display: block; }
  .main-nav > li.menu-item-has-children > a::after { margin-left: auto; }
  
  .nav-cta { flex-direction: column; margin: 16px 0 0; }
  .nav-cta .btn-primary-ag,
  .nav-cta .btn-gold-ag { width: 100%; justify-content: center; }

  .hero-section { padding-top: calc(var(--header-h) + 20px); }
  .hero-visual { margin-top: 48px; }
  .float-badge { display: none; }
  
  .stat-block { border-right: 0; border-bottom: 1px solid var(--color-border); }
  .stat-block:last-child { border-bottom: 0; }

  .footer-bottom { justify-content: center; text-align: center; }
}

@media (max-width: 767px) {
  :root { --header-h: 68px; }
  .section-pad { padding: 60px 0; }
  .hero-headline { font-size: 1.75rem; }
  .hero-stats { gap: 20px; }
  .services-grid { grid-template-columns: 1fr; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .tech-icons-grid { grid-template-columns: repeat(3, 1fr); }
  .scroll-top-btn { bottom: 20px; right: 20px; }
  .footer-top { padding: 50px 0 30px; }
}

@media (max-width: 480px) {
  .header-inner { padding: 0 16px; }
  .hero-actions { flex-direction: column; }
  .btn-primary-ag, .btn-outline-ag, .btn-gold-ag { width: 100%; justify-content: center; }
  .tech-icons-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================
   INNER PAGE — Full Width Fix
   Appended to style.css (loads before Bootstrap
   override can affect things)
   ============================================ */

/* Force dark background everywhere */
body,
.main-content-wrapper {
  background-color: #060d1f !important;
  color: #e8edf5;
  width: 100%;
  max-width: 100%;
  display: block;
}

/* ── Inner page hero — full viewport width ── */
.ip-hero {
  position: relative;
  width: 100vw;
  max-width: 100%;
  min-height: 85vh;
  display: flex;
  align-items: center;
  background-color: #060d1f;
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  padding-top: var(--header-h, 80px);
  overflow: hidden;
  box-sizing: border-box;
}
.ip-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(6,13,31,0.97) 0%, rgba(6,13,31,0.80) 60%, rgba(6,13,31,0.55) 100%);
  z-index: 0;
}
/* Pure CSS Grid layout — zero Bootstrap dependency */
.ip-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 72px 40px 80px;
  box-sizing: border-box;
}
.ip-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.ip-hero__text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.ip-hero__image {
  display: flex;
  justify-content: center;
  align-items: center;
}
.ip-hero__overlay { display: none; }
.ip-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: .82rem; color: rgba(255,255,255,0.5);
  margin-bottom: 20px; flex-wrap: wrap;
}
.ip-breadcrumb a { color: #00c2ff; text-decoration: none; }
.ip-hero__title {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  font-weight: 800;
  color: #ffffff !important;
  line-height: 1.15;
  margin-bottom: 20px;
}
.ip-hero__sub {
  font-size: 1rem;
  color: rgba(255,255,255,0.72) !important;
  line-height: 1.8;
  max-width: 520px;
  margin-bottom: 28px;
}
.ip-hero__btns { display: flex; flex-wrap: wrap; gap: 14px; }
.ip-hero__img-wrap {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5);
}
.ip-hero__img { width: 100%; display: block; border-radius: 16px; }

/* ── Experience cloud strip ── */
.ip-cloud {
  width: 100%;
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.ip-cloud__inner {
  max-width: 1400px; margin: 0 auto;
  padding: 24px 40px;
}
.ip-cloud__list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap;
  justify-content: center; gap: 36px;
}
.ip-cloud__list li {
  display: flex; align-items: center; gap: 10px;
  color: rgba(255,255,255,0.8); font-size: .9rem; font-weight: 600;
}
.ip-cloud__list img { height: 40px; object-fit: contain; filter: brightness(0) invert(1); }

/* ── Tech grid strip ── */
.ip-tech {
  width: 100%;
  padding: 44px 0;
  background: #0d1b38;
}
.ip-tech__grid {
  display: flex; flex-wrap: wrap;
  gap: 24px; justify-content: center; padding: 0 40px;
}
.ip-tech__item {
  display: flex; flex-direction: column;
  align-items: center; gap: 8px; text-align: center;
}
.ip-tech__item img { height: 50px; object-fit: contain; }
.ip-tech__item span { font-size: .78rem; color: rgba(255,255,255,0.7); font-weight: 600; }

/* ── Section heading ── */
.ip-section-title { padding: 56px 0 0; width: 100%; }
.ip-section-title__h {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 700; color: #ffffff !important;
  padding-bottom: 14px; margin-bottom: 0;
  position: relative;
}
.ip-section-title__h::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 56px; height: 3px;
  background: linear-gradient(90deg, #1565d8, #00c2ff);
  border-radius: 2px;
}

/* ── Project alternating sections ── */
.ip-project {
  width: 100%;
  padding: 64px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.ip-project--alt { background: #0d1b38; }
.ip-project__img img {
  width: 100%; border-radius: 14px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.4);
}
.ip-project__content h3 {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(1.3rem, 2.8vw, 2rem);
  font-weight: 700; color: #ffffff !important;
  margin-bottom: 14px;
}
.ip-project__content > p {
  color: rgba(255,255,255,0.65) !important;
  line-height: 1.85; margin-bottom: 22px;
}
.ip-services-list {
  list-style: none; padding: 0; margin: 0 0 18px;
  display: flex; flex-direction: column; gap: 14px;
}
.ip-services-list li { display: flex; gap: 12px; align-items: flex-start; }
.ip-services-list__icon {
  flex-shrink: 0; width: 40px; height: 40px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px; display: flex;
  align-items: center; justify-content: center; padding: 7px;
}
.ip-services-list__icon img { width: 100%; height: 100%; object-fit: contain; }
.ip-services-list strong { display: block; color: #ffffff !important; font-size: .9rem; margin-bottom: 3px; }
.ip-services-list p { color: rgba(255,255,255,0.55) !important; font-size: .82rem; margin: 0; line-height: 1.6; }
.ip-bullet-list { list-style: none; padding: 0; margin: 0 0 18px; }
.ip-bullet-list li {
  padding: 7px 0 7px 20px; position: relative;
  color: rgba(255,255,255,0.7) !important; font-size: .88rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.ip-bullet-list li::before { content: '▸'; position: absolute; left: 0; color: #00c2ff; }

/* ── Service offers ── */
.ip-offers { width: 100%; padding: 64px 0; background: #0d1b38; }
.ip-section-h {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 700; color: #ffffff !important;
}
.ip-offers__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
  gap: 18px;
}
.ip-offers__item {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 14px; padding: 26px 18px;
  display: flex; flex-direction: column;
  align-items: center; gap: 12px; text-align: center;
  font-size: .875rem; font-weight: 600;
  color: rgba(255,255,255,0.8) !important;
  transition: border-color 0.2s;
}
.ip-offers__item:hover { border-color: #00c2ff; }
.ip-offers__item img { height: 44px; object-fit: contain; }

/* ── Portfolio ── */
.ip-portfolio { width: 100%; padding: 64px 0; }
.ip-watermark {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(3rem, 7vw, 6rem);
  font-weight: 900; color: rgba(255,255,255,0.025);
  text-transform: uppercase; letter-spacing: 5px;
  margin-bottom: -24px; pointer-events: none;
}
.ip-portfolio__grid { display: flex; flex-direction: column; gap: 40px; }
.ip-portfolio__item { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.ip-portfolio__text h4 { color: #ffffff !important; margin-bottom: 10px; }
.ip-portfolio__text p  { color: rgba(255,255,255,0.6) !important; line-height: 1.8; }
.ip-portfolio__img img { width: 100%; border-radius: 12px; }

/* ── Trusted By ── */
.comn_sec { padding: 60px 0; background: #152244; }
.static_box { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 14px; padding: 24px; height: 100%; }
.static_img img { height: 44px; object-fit: contain; margin-bottom: 12px; }
.static_contant p  { color: rgba(255,255,255,0.7) !important; font-size: .875rem; }
.static_contant a  { color: #00c2ff; font-size: .875rem; font-style: italic; }
.statistic_second p { color: rgba(255,255,255,0.55) !important; font-size: .82rem; line-height: 1.7; margin-top: 10px; }

/* ── Achievement ── */
.achivementSec { padding: 60px 0; background: #0d1b38; position: relative; overflow: hidden; }
.globeBox { display: flex; align-items: center; justify-content: center; gap: 40px; flex-wrap: wrap; }
.globeBox > img { max-width: 260px; opacity: .8; }
.globeBox > ul { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.globeBox li { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 18px; text-align: center; }
.globeBox li .inner-achievement-num {
  display: block; font-size: 1.8rem; font-weight: 800;
  background: linear-gradient(135deg,#1565d8,#00c2ff);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; margin-bottom: 4px;
}
.inner-achievement-lbl { font-size: .82rem; color: rgba(255,255,255,0.6); }

/* ── Blog section ── */
.blogSec { padding: 60px 0; background: #152244; }
.blogList h4 { color: #ffffff !important; font-size: 1.3rem; line-height: 1.4; margin-bottom: 14px; }
.blogList p  { color: rgba(255,255,255,0.6) !important; font-size: .875rem; line-height: 1.8; }
.blogSlider { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.blogBox { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 14px; overflow: hidden; }
.blogImg { aspect-ratio: 16/9; overflow: hidden; }
.blogImg img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.blogBox:hover .blogImg img { transform: scale(1.05); }
.blogCont { padding: 16px; }
.blogCont h4 { font-size: .92rem; color: #ffffff !important; margin-bottom: 8px; line-height: 1.4; }
.blogCont h4 a { color: #ffffff !important; text-decoration: none; }
.blogCont p  { font-size: .8rem; color: rgba(255,255,255,0.55) !important; line-height: 1.6; }
.blogCont a  { display: inline-block; font-size: .72rem; background: rgba(0,194,255,0.1); color: #00c2ff; border: 1px solid rgba(0,194,255,0.25); border-radius: 30px; padding: 3px 10px; margin: 2px 3px 0 0; }

/* ── Get In Touch ── */
.getinTouchSec { padding: 64px 0; background: #0d1b38; }
.touchHead h4  { color: #ffffff !important; font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 700; }
.touchHead p   { color: rgba(255,255,255,0.6) !important; margin-bottom: 28px; }
.touchList h4  { color: #ffffff !important; font-size: 1rem; font-weight: 700; margin-bottom: 12px; }
.touchList ul  { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.touchList li a { display: flex; gap: 10px; align-items: flex-start; color: rgba(255,255,255,0.8) !important; text-decoration: none; font-size: .875rem; }
.touchList li a:hover { color: #00c2ff !important; }
.touchForm { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.09); border-radius: 14px; padding: 28px; }

/* ── About intro ── */
.ip-about-intro { padding: 60px 0; background: #060d1f; }
.ip-about-content { color: rgba(255,255,255,0.7) !important; line-height: 1.85; }

/* ── Cloud static strip ── */
.cloudeSec { padding: 24px 0; border-bottom: 1px solid rgba(255,255,255,0.07); }
.cloudeSec ul { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: 36px; }
.cloudeSec li { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,0.8) !important; font-size: .9rem; font-weight: 600; }
.cloudeSec li img { height: 40px; object-fit: contain; filter: brightness(0) invert(1); }
.cloudeSec li p { margin: 0; color: inherit !important; }

/* ── Responsive ── */
@media (max-width: 991px) {
  .ip-hero { min-height: auto; padding-bottom: 48px; }
  .ip-hero__title { font-size: 2rem; }
  .ip-project { padding: 44px 0; }
  .blogSlider { grid-template-columns: repeat(2, 1fr); }
  .ip-portfolio__item { grid-template-columns: 1fr; }
  .globeBox { flex-direction: column; }
  .ip-hero__inner { padding: 56px 20px 40px; }
}
@media (max-width: 767px) {
  .ip-hero__inner { padding: 48px 16px 36px; }
  .blogSlider { grid-template-columns: 1fr; }
  .ip-offers__grid { grid-template-columns: repeat(2, 1fr); }
  .globeBox > ul { grid-template-columns: 1fr; }
}
@media (max-width: 575px) {
  .ip-offers__grid { grid-template-columns: 1fr; }
  .ip-hero__btns { flex-direction: column; gap: 10px; }
}

/* ── Final layout fixes ── */

/* Bootstrap container-fluid with max-width for hero */
./* removed Bootstrap container override */ .ip-hero__inner {
  max-width: 1400px !important;
}

/* Ensure all ip-* sections are full-width blocks */
.ip-cloud, .ip-tech, .ip-section-title,
.ip-project, .ip-offers, .ip-portfolio,
.blogSec, .getinTouchSec, .comn_sec, .achivementSec {
  display: block;
  width: 100%;
  clear: both;
}

/* Fix Bootstrap row overflow in project sections */
.ip-project .container-fluid,
.ip-project .container-fluid.px-lg-5 {
  overflow: visible;
}

/* Mobile responsive fix */
@media (max-width: 991px) {
  .ip-hero__inner { padding-left: 20px; padding-right: 20px; padding-top: 32px; }
  .ip-hero__title { font-size: 1.9rem !important; }
}
@media (max-width: 575px) {
  .ip-hero__inner { padding-left: 16px; padding-right: 16px; }
  .ip-hero__btns { flex-direction: column; }
  .ip-hero__btns a { text-align: center; justify-content: center; }
}

/* ── Hero Grid Responsive ── */
@media (max-width: 1199px) {
  .ip-hero__inner { padding: 64px 32px 72px; }
}
@media (max-width: 991px) {
  .ip-hero { min-height: auto; }
  .ip-hero__inner { padding: 56px 24px 56px; }
  .ip-hero__grid { grid-template-columns: 1fr; gap: 32px; }
  .ip-hero__image { display: none; }
  .ip-hero__title { font-size: 2rem !important; }
}
@media (max-width: 767px) {
  .ip-hero__inner { padding: 48px 16px 48px; }
  .ip-hero__title { font-size: 1.75rem !important; }
}
@media (max-width: 575px) {
  .ip-hero__btns { flex-direction: column; gap: 10px; }
  .ip-hero__btns a { text-align: center; }
}

/* ── Force full-width on all sections ── */
.ip-hero, .ip-cloud, .ip-tech, .ip-section-title,
.ip-project, .ip-offers, .ip-portfolio,
.blogSec, .getinTouchSec, .comn_sec, .achivementSec,
.main-content-wrapper {/* full-width */
  box-sizing: border-box;
  max-width: 100% !important;
}

/* ── Responsive ── */
@media (max-width: 991px) {
  .ip-hero { min-height: auto; padding-bottom: 48px; }
  .ip-hero__title { font-size: 2rem; }
  .ip-project { padding: 44px 0; }
  .blogSlider { grid-template-columns: repeat(2, 1fr); }
  .ip-portfolio__item { grid-template-columns: 1fr; }
  .globeBox { flex-direction: column; }
  .ip-hero__inner { padding: 56px 20px 40px; }
}
@media (max-width: 767px) {
  .ip-hero__inner { padding: 48px 16px 36px; }
  .blogSlider { grid-template-columns: 1fr; }
  .ip-offers__grid { grid-template-columns: repeat(2, 1fr); }
  .globeBox > ul { grid-template-columns: 1fr; }
}
@media (max-width: 575px) {
  .ip-offers__grid { grid-template-columns: 1fr; }
  .ip-hero__btns { flex-direction: column; gap: 10px; }
}

/* ── Final layout fixes ── */

/* Bootstrap container-fluid with max-width for hero */
./* removed Bootstrap container override */ .ip-hero__inner {
  max-width: 1400px !important;
}

/* Ensure all ip-* sections are full-width blocks */
.ip-cloud, .ip-tech, .ip-section-title,
.ip-project, .ip-offers, .ip-portfolio,
.blogSec, .getinTouchSec, .comn_sec, .achivementSec {
  display: block;
  width: 100%;
  clear: both;
}

/* Fix Bootstrap row overflow in project sections */
.ip-project .container-fluid,
.ip-project .container-fluid.px-lg-5 {
  overflow: visible;
}

/* Mobile responsive fix */
@media (max-width: 991px) {
  .ip-hero__inner { padding-left: 20px; padding-right: 20px; padding-top: 32px; }
  .ip-hero__title { font-size: 1.9rem !important; }
}
@media (max-width: 575px) {
  .ip-hero__inner { padding-left: 16px; padding-right: 16px; }
  .ip-hero__btns { flex-direction: column; }
  .ip-hero__btns a { text-align: center; justify-content: center; }
}

/* ── Hero Grid Responsive ── */
@media (max-width: 1199px) {
  .ip-hero__inner { padding: 64px 32px 72px; }
}
@media (max-width: 991px) {
  .ip-hero { min-height: auto; }
  .ip-hero__inner { padding: 56px 24px 56px; }
  .ip-hero__grid { grid-template-columns: 1fr; gap: 32px; }
  .ip-hero__image { display: none; }
  .ip-hero__title { font-size: 2rem !important; }
}
@media (max-width: 767px) {
  .ip-hero__inner { padding: 48px 16px 48px; }
  .ip-hero__title { font-size: 1.75rem !important; }
}
@media (max-width: 575px) {
  .ip-hero__btns { flex-direction: column; gap: 10px; }
  .ip-hero__btns a { text-align: center; }
}

/* ── Force full-width on all sections ── */
.ip-hero, .ip-cloud, .ip-tech, .ip-section-title,
.ip-project, .ip-offers, .ip-portfolio,
.blogSec, .getinTouchSec, .comn_sec, .achivementSec,
.main-content-wrapper {/* full-width */
  box-sizing: border-box;
  max-width: 100% !important;
}

/* ╔══════════════════════════════════════════════════════════════════════
   INNER PAGE — PREMIUM UI  (agnip-* namespace)
   Mobile-first, dark navy, glassmorphism cards
   ══════════════════════════════════════════════════════════════════════╗ */

/* ── Shared container ── */
.agnip-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: border-box;
}

/* ── Buttons ── */
.agnip-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  border-radius: 50px;
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: all .25s cubic-bezier(.4,0,.2,1);
  cursor: pointer;
  white-space: nowrap;
}
.agnip-btn--gold {
  background: linear-gradient(135deg, #f7c542, #e0a800);
  color: #000;
  box-shadow: 0 4px 20px rgba(247,197,66,.3);
}
.agnip-btn--gold:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(247,197,66,.45);
  color: #000;
}
.agnip-btn--outline {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.35);
}
.agnip-btn--outline:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.6);
  color: #fff;
}
.agnip-btn--sm { padding: 10px 22px; font-size: .85rem; }

/* ── Section heading ── */
.agnip-section-head { text-align: center; margin-bottom: 52px; }
.agnip-section-head h2 {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight: 800;
  color: #fff;
  margin-bottom: 14px;
}
.agnip-section-head--light h2 { color: #fff; }
.agnip-section-head__bar {
  width: 56px;
  height: 3px;
  background: linear-gradient(90deg, #1565d8, #00c2ff);
  border-radius: 2px;
  margin: 0 auto;
}

/* ══════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════ */
.agnip-hero {
  position: relative;
  width: 100%;
  min-height: 92vh;
  display: flex;
  align-items: center;
  background: #060d1f;
  background-size: cover;
  background-position: center top;
  padding-top: var(--header-h, 80px);
  overflow: hidden;
}
.agnip-hero--no-bg { background: linear-gradient(135deg, #060d1f 0%, #0d1b38 100%); }

.agnip-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(6,13,31,.96) 0%,
    rgba(6,13,31,.82) 55%,
    rgba(6,13,31,.45) 100%
  );
  z-index: 0;
}

/* Animated decorative orbs */
.agnip-hero__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  z-index: 0;
  pointer-events: none;
  animation: agnipOrb 8s ease-in-out infinite alternate;
}
.agnip-hero__orb--1 {
  width: 500px; height: 500px;
  background: rgba(21,101,216,.18);
  top: -100px; right: -100px;
}
.agnip-hero__orb--2 {
  width: 350px; height: 350px;
  background: rgba(0,194,255,.1);
  bottom: -80px; left: -80px;
  animation-delay: -4s;
}
@keyframes agnipOrb {
  from { transform: scale(1) translate(0,0); }
  to   { transform: scale(1.2) translate(20px,-20px); }
}

.agnip-hero .agnip-container { position: relative; z-index: 2; padding-top: 60px; padding-bottom: 80px; }
.agnip-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.agnip-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  color: rgba(255,255,255,.45);
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.agnip-breadcrumb a { color: #00c2ff; text-decoration: none; }
.agnip-breadcrumb svg { opacity: .4; }

.agnip-hero__title {
  font-size: clamp(2rem, 4.8vw, 3.6rem);
  font-weight: 800;
  color: #fff !important;
  line-height: 1.12;
  margin-bottom: 20px;
}
.agnip-hero__desc {
  color: rgba(255,255,255,.72);
  font-size: 1rem;
  line-height: 1.82;
  max-width: 500px;
  margin-bottom: 32px;
}
.agnip-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 40px; }

/* Trust badges in hero */
.agnip-hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.agnip-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 50px;
  padding: 7px 16px 7px 10px;
  font-size: .8rem;
  font-weight: 600;
  color: rgba(255,255,255,.8);
}
.agnip-hero__trust-item img { height: 26px; object-fit: contain; filter: brightness(0) invert(1); }

/* Hero image frame */
.agnip-hero__img-frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
}
.agnip-hero__img-frame::before {
  content: '';
  position: absolute;
  inset: -2px;
  background: linear-gradient(135deg, #1565d8, #00c2ff, #f7c542);
  border-radius: 26px;
  z-index: -1;
  opacity: .5;
}
.agnip-hero__img-frame img {
  width: 100%;
  display: block;
  border-radius: 22px;
  max-height: 500px;
  object-fit: cover;
}

/* ══════════════════════════════════════════════
   TECH STRIP (auto-scroll marquee)
   ══════════════════════════════════════════════ */
.agnip-tech-strip {
  background: rgba(255,255,255,.025);
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 20px 0;
  overflow: hidden;
  width: 100%;
}
.agnip-tech-strip__track {
  display: flex;
  gap: 40px;
  width: max-content;
  animation: agnipScroll 30s linear infinite;
}
.agnip-tech-strip:hover .agnip-tech-strip__track { animation-play-state: paused; }
@keyframes agnipScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.agnip-tech-strip__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 80px;
  text-align: center;
}
.agnip-tech-strip__item img { height: 44px; object-fit: contain; filter: grayscale(.3) brightness(1.1); }
.agnip-tech-strip__item span { font-size: .72rem; color: rgba(255,255,255,.55); font-weight: 600; }

/* ══════════════════════════════════════════════
   SECTION LABEL
   ══════════════════════════════════════════════ */
.agnip-section-label { padding: 56px 0 0; }
.agnip-section-label__inner {
  display: flex;
  align-items: center;
  gap: 16px;
}
.agnip-section-label__line {
  flex: 0 0 56px;
  height: 3px;
  background: linear-gradient(90deg, #1565d8, #00c2ff);
  border-radius: 2px;
}
.agnip-section-label__text {
  font-size: clamp(1.3rem, 2.8vw, 2rem);
  font-weight: 700;
  color: #fff !important;
}

/* ══════════════════════════════════════════════
   SPLIT SECTIONS (alternating image/text)
   ══════════════════════════════════════════════ */
.agnip-split { padding: 72px 0; width: 100%; }
.agnip-split--alt { background: #0d1b38; }

.agnip-split__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.agnip-split__grid--rev { direction: rtl; }
.agnip-split__grid--rev > * { direction: ltr; }

.agnip-split__img-wrap {
  position: relative;
  border-radius: 20px;
  overflow: visible;
}
.agnip-split__img-wrap img {
  width: 100%;
  border-radius: 20px;
  display: block;
  box-shadow: 0 24px 64px rgba(0,0,0,.45);
}
.agnip-split__img-glow {
  position: absolute;
  inset: -40px;
  background: radial-gradient(ellipse, rgba(21,101,216,.2) 0%, transparent 70%);
  pointer-events: none;
  z-index: -1;
}

.agnip-split__title {
  font-size: clamp(1.3rem, 2.8vw, 2.1rem);
  font-weight: 700;
  color: #fff !important;
  margin-bottom: 16px;
  line-height: 1.25;
}
.agnip-split__desc {
  color: rgba(255,255,255,.65);
  line-height: 1.85;
  font-size: .97rem;
  margin-bottom: 24px;
}

/* Feature list (with icons) */
.agnip-feature-list { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 16px; }
.agnip-feature-list__item { display: flex; gap: 14px; align-items: flex-start; }
.agnip-feature-list__icon {
  flex-shrink: 0;
  width: 44px; height: 44px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  padding: 9px;
  transition: background .2s;
}
.agnip-feature-list__item:hover .agnip-feature-list__icon { background: rgba(21,101,216,.2); }
.agnip-feature-list__icon img { width: 100%; height: 100%; object-fit: contain; }
.agnip-feature-list__item strong { display: block; color: #fff; font-size: .9rem; font-weight: 600; margin-bottom: 3px; }
.agnip-feature-list__item p { color: rgba(255,255,255,.55); font-size: .82rem; margin: 0; line-height: 1.65; }

/* Checklist */
.agnip-check-list { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 2px; }
.agnip-check-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 9px 0;
  color: rgba(255,255,255,.72);
  font-size: .9rem;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.agnip-check-list__icon {
  flex-shrink: 0;
  width: 20px; height: 20px;
  background: rgba(0,194,255,.12);
  border: 1px solid rgba(0,194,255,.25);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin-top: 1px;
}

/* ══════════════════════════════════════════════
   SERVICES ICON GRID
   ══════════════════════════════════════════════ */
.agnip-services-grid { padding: 80px 0; background: #060d1f; }
.agnip-services-grid__items {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
  gap: 20px;
}
.agnip-services-grid__card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 28px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  transition: all .25s;
  cursor: default;
}
.agnip-services-grid__card:hover {
  background: rgba(21,101,216,.12);
  border-color: rgba(0,194,255,.35);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(21,101,216,.2);
}
.agnip-services-grid__icon {
  width: 60px; height: 60px;
  background: rgba(255,255,255,.06);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  padding: 12px;
}
.agnip-services-grid__icon img { width: 100%; height: 100%; object-fit: contain; }
.agnip-services-grid__card p { color: rgba(255,255,255,.8); font-size: .875rem; font-weight: 600; margin: 0; line-height: 1.5; }

/* ══════════════════════════════════════════════
   STATS / ACHIEVEMENT
   ══════════════════════════════════════════════ */
.agnip-stats { padding: 80px 0; background: #0d1b38; position: relative; overflow: hidden; }
.agnip-stats__bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(21,101,216,.15), transparent);
  pointer-events: none;
}
.agnip-stats__grid {
  display: flex;
  align-items: center;
  gap: 60px;
  flex-wrap: wrap;
  justify-content: center;
}
.agnip-stats__globe { flex: 0 0 260px; }
.agnip-stats__globe img { width: 100%; opacity: .85; }
.agnip-stats__numbers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  flex: 1;
  min-width: 280px;
}
.agnip-stats__item {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 24px;
  text-align: center;
  transition: border-color .2s;
}
.agnip-stats__item:hover { border-color: rgba(0,194,255,.3); }
.agnip-stats__num {
  display: block;
  font-size: 2.2rem;
  font-weight: 800;
  background: linear-gradient(135deg, #1565d8, #00c2ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 6px;
  line-height: 1;
}
.agnip-stats__lbl { font-size: .82rem; color: rgba(255,255,255,.6); font-weight: 600; }

/* ══════════════════════════════════════════════
   TRUSTED BY
   ══════════════════════════════════════════════ */
.agnip-trusted { padding: 72px 0; background: #060d1f; }
.agnip-trusted__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px;
}
.agnip-trusted__card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 28px;
  transition: all .2s;
}
.agnip-trusted__card:hover {
  border-color: rgba(0,194,255,.25);
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(0,0,0,.3);
}
.agnip-trusted__logo { margin-bottom: 14px; }
.agnip-trusted__logo img { height: 44px; object-fit: contain; }
.agnip-trusted__name { color: rgba(255,255,255,.8); font-weight: 600; font-size: .9rem; margin-bottom: 8px; }
.agnip-trusted__link { color: #00c2ff; font-size: .85rem; font-style: italic; text-decoration: none; display: block; margin-bottom: 8px; }
.agnip-trusted__desc { color: rgba(255,255,255,.5); font-size: .82rem; line-height: 1.7; margin: 8px 0 0; }

/* ══════════════════════════════════════════════
   BLOG SECTION
   ══════════════════════════════════════════════ */
.agnip-blog { padding: 80px 0; background: #0d1b38; }
.agnip-blog__head {
  margin-bottom: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.agnip-blog__eyebrow {
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #00c2ff;
  margin-bottom: 8px;
}
.agnip-blog__title { font-size: clamp(1.8rem, 3.5vw, 2.6rem); font-weight: 800; color: #fff; margin-bottom: 12px; }
.agnip-blog__sub { color: rgba(255,255,255,.6); font-size: .95rem; line-height: 1.7; max-width: 480px; margin-bottom: 24px; }

.agnip-blog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.agnip-blog__card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  overflow: hidden;
  transition: all .25s;
}
.agnip-blog__card:hover {
  border-color: rgba(0,194,255,.25);
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
.agnip-blog__img-wrap {
  display: block;
  overflow: hidden;
  position: relative;
  aspect-ratio: 16/9;
}
.agnip-blog__img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.agnip-blog__card:hover .agnip-blog__img-wrap img { transform: scale(1.06); }
.agnip-blog__img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(6,13,31,.4), transparent);
}
.agnip-blog__body { padding: 20px; }
.agnip-blog__meta { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.agnip-blog__meta time { font-size: .75rem; color: rgba(255,255,255,.4); }
.agnip-blog__cat {
  font-size: .72rem;
  font-weight: 700;
  background: rgba(0,194,255,.12);
  color: #00c2ff;
  border: 1px solid rgba(0,194,255,.2);
  border-radius: 50px;
  padding: 2px 10px;
}
.agnip-blog__body h3 { font-size: .95rem; margin-bottom: 8px; line-height: 1.4; }
.agnip-blog__body h3 a { color: #fff; text-decoration: none; }
.agnip-blog__body h3 a:hover { color: #00c2ff; }
.agnip-blog__body p { font-size: .82rem; color: rgba(255,255,255,.55); line-height: 1.6; margin-bottom: 12px; }
.agnip-blog__more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  font-weight: 700;
  color: #00c2ff;
  text-decoration: none;
}
.agnip-blog__more:hover { gap: 10px; }

/* ══════════════════════════════════════════════
   GET IN TOUCH / CTA
   ══════════════════════════════════════════════ */
.agnip-cta { padding: 80px 0; background: #060d1f; position: relative; overflow: hidden; }
.agnip-cta__bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 80% at 30% 50%, rgba(21,101,216,.12), transparent);
  pointer-events: none;
}
.agnip-cta .agnip-container { position: relative; z-index: 1; }
.agnip-cta__grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 60px;
  align-items: center;
}
.agnip-cta__eyebrow {
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #00c2ff;
  margin-bottom: 8px;
}
.agnip-cta__title { font-size: clamp(1.8rem, 3.5vw, 2.6rem); font-weight: 800; color: #fff; margin-bottom: 14px; }
.agnip-cta__sub { color: rgba(255,255,255,.6); font-size: .95rem; line-height: 1.7; margin-bottom: 32px; }

.agnip-cta__contacts { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.agnip-cta__contacts a {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  transition: opacity .2s;
}
.agnip-cta__contacts a:hover { opacity: .8; }
.agnip-cta__contact-icon {
  flex-shrink: 0;
  width: 44px; height: 44px;
  background: linear-gradient(135deg, #1565d8, #00c2ff);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
}
.agnip-cta__contacts strong { display: block; font-size: .8rem; color: rgba(255,255,255,.5); font-weight: 600; margin-bottom: 2px; }
.agnip-cta__contacts span { font-size: .9rem; color: #fff; font-weight: 600; }

.agnip-cta__form-inner {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px;
  padding: 36px;
  backdrop-filter: blur(10px);
}

/* ══════════════════════════════════════════════
   RESPONSIVE — TABLET & MOBILE
   ══════════════════════════════════════════════ */
@media (max-width: 1199px) {
  .agnip-container { padding: 0 32px; }
  .agnip-hero__grid { gap: 40px; }
  .agnip-split__grid { gap: 40px; }
}

@media (max-width: 991px) {
  /* Hero */
  .agnip-hero { min-height: auto; padding-bottom: 0; }
  .agnip-hero .agnip-container { padding-top: 48px; padding-bottom: 56px; }
  .agnip-hero__grid { grid-template-columns: 1fr; gap: 36px; }
  .agnip-hero__image { order: -1; max-width: 480px; margin: 0 auto; }
  .agnip-hero__text { text-align: center; }
  .agnip-hero__desc { margin: 0 auto 28px; }
  .agnip-hero__actions { justify-content: center; }
  .agnip-hero__trust { justify-content: center; }
  /* Split */
  .agnip-split__grid { grid-template-columns: 1fr; gap: 32px; }
  .agnip-split__grid--rev { direction: ltr; }
  .agnip-split__visual { max-width: 480px; margin: 0 auto; }
  /* Blog */
  .agnip-blog__grid { grid-template-columns: repeat(2, 1fr); }
  /* CTA */
  .agnip-cta__grid { grid-template-columns: 1fr; gap: 40px; }
  /* Stats */
  .agnip-stats__grid { flex-direction: column; gap: 32px; }
  .agnip-stats__numbers { grid-template-columns: repeat(2, 1fr); min-width: 0; width: 100%; }
}

@media (max-width: 767px) {
  .agnip-container { padding: 0 20px; }
  .agnip-hero .agnip-container { padding-top: 36px; padding-bottom: 44px; }
  .agnip-hero__title { font-size: 2rem !important; }
  .agnip-hero__actions { flex-direction: column; align-items: center; }
  .agnip-hero__trust { gap: 8px; }
  .agnip-split { padding: 48px 0; }
  .agnip-services-grid__items { grid-template-columns: repeat(2, 1fr); }
  .agnip-blog__grid { grid-template-columns: 1fr; }
  .agnip-trusted__grid { grid-template-columns: 1fr; }
  .agnip-cta__form-inner { padding: 24px 20px; }
  .agnip-section-head { margin-bottom: 36px; }
  .agnip-stats__numbers { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 480px) {
  .agnip-hero__title { font-size: 1.75rem !important; }
  .agnip-services-grid__items { grid-template-columns: 1fr; }
  .agnip-stats__numbers { grid-template-columns: 1fr; }
  .agnip-hero__trust-item { font-size: .72rem; }
  .agnip-blog__grid { gap: 16px; }
}

/* ╔══════════════════════════════════════════════════════════════════════
   ABOUT US, WORK AT, CONTACT, BLOG — Premium UI Extensions
   ══════════════════════════════════════════════════════════════════════╗ */

/* ── ABOUT INTRO ─────────────────────────────────────────────────────── */
.agnip-about-intro { padding: 80px 0; background: #0d1b38; }
.agnip-about-intro__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.agnip-about-intro__text h2 {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight: 800;
  color: #fff;
  margin-bottom: 20px;
  line-height: 1.25;
}
.agnip-about-intro__body { color: rgba(255,255,255,.65); line-height: 1.9; font-size: .97rem; }
.agnip-about-intro__body p { margin-bottom: 14px; color: rgba(255,255,255,.65); }

.agnip-about-intro__value-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 20px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  margin-bottom: 12px;
  transition: border-color .2s;
}
.agnip-about-intro__value-card:hover { border-color: rgba(0,194,255,.25); }
.agnip-about-intro__value-icon { font-size: 1.5rem; flex-shrink: 0; }
.agnip-about-intro__value-card strong { display: block; color: #fff; font-size: .9rem; margin-bottom: 3px; }
.agnip-about-intro__value-card p { color: rgba(255,255,255,.55); font-size: .82rem; margin: 0; line-height: 1.5; }

/* About image stacking */
.agnip-about__imgs { position: relative; }
.agnip-about__img-main img { width: 100%; border-radius: 16px; box-shadow: 0 20px 60px rgba(0,0,0,.45); }
.agnip-about__img-secondary {
  margin-top: 16px;
  margin-left: 32px;
  border-radius: 14px;
  overflow: hidden;
  border: 2px solid rgba(0,194,255,.25);
}
.agnip-about__img-secondary img { width: 100%; display: block; border-radius: 12px; }

/* Watermark text */
.agnip-watermark {
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  font-weight: 900;
  color: rgba(255,255,255,.025);
  text-transform: uppercase;
  letter-spacing: 6px;
  margin-top: 24px;
  pointer-events: none;
  user-select: none;
  overflow: hidden;
}

/* ── WHY CHOOSE US GRID ───────────────────────────────────────────────── */
.agnip-why { padding: 80px 0; background: #060d1f; }
.agnip-why__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
  gap: 20px;
}
.agnip-why__card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 28px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: all .25s;
}
.agnip-why__card:hover {
  border-color: rgba(247,197,66,.4);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(247,197,66,.1);
}
.agnip-why__emoji { font-size: 2rem; }
.agnip-why__num {
  font-size: 2rem;
  font-weight: 800;
  background: linear-gradient(135deg, #f7c542, #e0a800);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}
.agnip-why__lbl { font-size: .82rem; color: rgba(255,255,255,.6); font-weight: 600; }

/* ── CTA BANNER ───────────────────────────────────────────────────────── */
.agnip-cta-banner {
  padding: 72px 0;
  background: linear-gradient(135deg, #0d1b38 0%, #152244 50%, #1565d8 100%);
  position: relative;
  overflow: hidden;
}
.agnip-cta-banner::before {
  content: '';
  position: absolute;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(0,194,255,.15), transparent 70%);
  top: -150px; right: -100px;
  pointer-events: none;
}
.agnip-cta-banner__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
.agnip-cta-banner__inner h2 { font-size: clamp(1.4rem, 3vw, 2rem); color: #fff; font-weight: 800; margin-bottom: 8px; }
.agnip-cta-banner__inner p  { color: rgba(255,255,255,.7); font-size: .95rem; }
.agnip-cta-banner__btns { display: flex; gap: 14px; flex-wrap: wrap; flex-shrink: 0; }

/* ── PERKS (Work At Agnito) ──────────────────────────────────────────── */
.agnip-perks {
  background: #0d1b38;
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: 56px 0;
}
.agnip-perks__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
  gap: 18px;
}
.agnip-perks__item {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 24px 18px;
  text-align: center;
  transition: all .2s;
}
.agnip-perks__item:hover {
  border-color: rgba(0,194,255,.3);
  transform: translateY(-3px);
}
.agnip-perks__icon { font-size: 2rem; display: block; margin-bottom: 10px; }
.agnip-perks__item strong { display: block; color: #fff; font-size: .9rem; font-weight: 700; margin-bottom: 6px; }
.agnip-perks__item p { color: rgba(255,255,255,.55); font-size: .8rem; margin: 0; line-height: 1.5; }

/* ── CONTACT PAGE ────────────────────────────────────────────────────── */
.agnip-contact { padding: 80px 0; background: #060d1f; }
.agnip-contact__grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 56px;
  align-items: start;
}
/* Quick contact cards */
.agnip-contact__quick { display: flex; flex-direction: column; gap: 12px; margin-bottom: 36px; }
.agnip-contact__quick-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  text-decoration: none;
  transition: all .2s;
}
.agnip-contact__quick-item:hover {
  border-color: rgba(0,194,255,.3);
  background: rgba(0,194,255,.06);
  transform: translateX(4px);
}
.agnip-contact__quick-icon {
  width: 44px; height: 44px;
  background: linear-gradient(135deg, #1565d8, #00c2ff);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.agnip-contact__quick-item strong { display: block; color: rgba(255,255,255,.5); font-size: .75rem; font-weight: 600; margin-bottom: 2px; }
.agnip-contact__quick-item span { color: #fff; font-size: .88rem; font-weight: 600; }
.agnip-contact__quick-arrow { margin-left: auto; opacity: .3; flex-shrink: 0; color: #fff; }
.agnip-contact__quick-item:hover .agnip-contact__quick-arrow { opacity: 1; color: #00c2ff; }

/* Offices */
.agnip-contact__offices { margin-bottom: 32px; }
.agnip-contact__offices h3 { font-size: 1rem; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: 1.5px; font-weight: 700; margin-bottom: 16px; font-size: .8rem; }
.agnip-contact__office {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.agnip-contact__office > span { font-size: 1.2rem; flex-shrink: 0; margin-top: 2px; }
.agnip-contact__office strong { display: block; color: #fff; font-size: .88rem; margin-bottom: 3px; }
.agnip-contact__office p { color: rgba(255,255,255,.5); font-size: .8rem; margin: 0; line-height: 1.5; }

/* Social links */
.agnip-contact__social h3 { font-size: .8rem; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: 1.5px; font-weight: 700; margin-bottom: 12px; }
.agnip-contact__social-links { display: flex; gap: 10px; flex-wrap: wrap; }
.agnip-contact__social-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 50px;
  font-size: .82rem; font-weight: 600; color: #fff;
  text-decoration: none;
  transition: all .2s;
}
.agnip-contact__social-btn:hover { transform: translateY(-2px); color: #fff; opacity: .9; }

/* Contact form card */
.agnip-contact__form-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 24px;
  overflow: hidden;
}
.agnip-contact__form-header {
  padding: 32px 36px 24px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.agnip-contact__form-header h2 { font-size: 1.4rem; color: #fff; margin-bottom: 8px; }
.agnip-contact__form-header p  { color: rgba(255,255,255,.55); font-size: .88rem; margin: 0; }
.agnip-contact__form-body { padding: 28px 36px 36px; }

/* CF7 override inside contact form */
.agnip-contact__form-body .wpcf7-form input,
.agnip-contact__form-body .wpcf7-form textarea,
.agnip-contact__form-body .wpcf7-form select {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: 10px !important;
  color: #fff !important;
  padding: 12px 16px !important;
  width: 100% !important;
  font-size: .9rem !important;
  transition: border-color .2s !important;
}
.agnip-contact__form-body .wpcf7-form input:focus,
.agnip-contact__form-body .wpcf7-form textarea:focus {
  border-color: rgba(0,194,255,.5) !important;
  outline: none !important;
}
.agnip-contact__form-body .wpcf7-form input[type="submit"],
.agnip-contact__form-body .wpcf7-form .wpcf7-submit {
  background: linear-gradient(135deg, #f7c542, #e0a800) !important;
  color: #000 !important;
  font-weight: 700 !important;
  border: none !important;
  padding: 14px 32px !important;
  border-radius: 50px !important;
  cursor: pointer !important;
  transition: all .25s !important;
}
.agnip-contact__form-body .wpcf7-form input[type="submit"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(247,197,66,.35) !important;
}

/* ── BLOG LISTING PAGE ───────────────────────────────────────────────── */
.agnip-blog-listing {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}
.agnip-blog-listing__card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  overflow: hidden;
  transition: all .25s;
  display: flex;
  flex-direction: column;
}
.agnip-blog-listing__card:hover {
  border-color: rgba(0,194,255,.25);
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
.agnip-blog-listing__thumb {
  display: block;
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
}
.agnip-blog-listing__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.agnip-blog-listing__card:hover .agnip-blog-listing__thumb img { transform: scale(1.06); }
.agnip-blog-listing__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(6,13,31,.5), transparent 50%);
}
.agnip-blog-listing__cat {
  position: absolute;
  bottom: 14px; left: 14px;
  font-size: .72rem; font-weight: 700;
  background: rgba(0,194,255,.9);
  color: #000;
  border-radius: 50px;
  padding: 3px 12px;
}
.agnip-blog-listing__body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.agnip-blog-listing__title {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 10px;
  line-height: 1.4;
  flex: 1;
}
.agnip-blog-listing__title a { color: #fff; text-decoration: none; }
.agnip-blog-listing__title a:hover { color: #00c2ff; }
.agnip-blog-listing__excerpt { color: rgba(255,255,255,.55); font-size: .875rem; line-height: 1.7; margin-bottom: 16px; }

/* Pagination */
.agnip-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 56px;
  flex-wrap: wrap;
}
.agnip-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.7);
  text-decoration: none;
  font-size: .85rem;
  font-weight: 600;
  transition: all .2s;
}
.agnip-pagination .page-numbers:hover,
.agnip-pagination .page-numbers.current {
  background: linear-gradient(135deg, #1565d8, #00c2ff);
  border-color: transparent;
  color: #fff;
}
.agnip-pagination .prev, .agnip-pagination .next {
  width: auto;
  padding: 0 18px;
  border-radius: 50px;
}

/* ── RESPONSIVE EXTRAS ───────────────────────────────────────────────── */
@media (max-width: 991px) {
  .agnip-about-intro__grid { grid-template-columns: 1fr; gap: 40px; }
  .agnip-contact__grid { grid-template-columns: 1fr; gap: 40px; }
  .agnip-cta-banner__inner { flex-direction: column; text-align: center; }
  .agnip-cta-banner__btns { justify-content: center; }
  .agnip-blog-listing { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .agnip-why__grid { grid-template-columns: repeat(2, 1fr); }
  .agnip-perks__grid { grid-template-columns: repeat(2, 1fr); }
  .agnip-contact__form-header, .agnip-contact__form-body { padding-left: 20px; padding-right: 20px; }
  .agnip-blog-listing { gap: 18px; }
}
@media (max-width: 480px) {
  .agnip-why__grid { grid-template-columns: 1fr 1fr; }
  .agnip-perks__grid { grid-template-columns: 1fr 1fr; }
  .agnip-contact__social-links { flex-direction: column; }
}

/* ╔══════════════════════════════════════════════════════════════════════
   INNER PAGE v2 — Premium Full-Width UI  (ip2-* namespace)
   Matches homepage quality. Mobile-first responsive.
   ══════════════════════════════════════════════════════════════════════╗ */

/* ── Container ── */
.ip2-container { width:100%; max-width:1280px; margin:0 auto; padding:0 40px; box-sizing:border-box; }

/* ── Buttons ── */
.ip2-btn { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; border-radius:50px; font-weight:700; font-size:.9rem; text-decoration:none; transition:all .25s; cursor:pointer; white-space:nowrap; }
.ip2-btn--gold { background:linear-gradient(135deg,#f7c542,#e0a800); color:#000!important; box-shadow:0 4px 20px rgba(247,197,66,.3); }
.ip2-btn--gold:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(247,197,66,.45); color:#000!important; }
.ip2-btn--outline { background:transparent; color:#fff!important; border:1.5px solid rgba(255,255,255,.35); }
.ip2-btn--outline:hover { background:rgba(255,255,255,.08); color:#fff!important; }
.ip2-btn--sm { padding:10px 22px; font-size:.85rem; }

/* ── Section heads ── */
.ip2-section-head { text-align:center; margin-bottom:52px; }
.ip2-section-head h2 { font-size:clamp(1.6rem,3.5vw,2.4rem); font-weight:800; color:#fff; margin-bottom:14px; }
.ip2-section-head__bar { width:56px; height:3px; background:linear-gradient(90deg,#1565d8,#00c2ff); border-radius:2px; margin:0 auto; }
.ip2-eyebrow { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:#00c2ff; margin-bottom:8px; }

/* ── HERO ── */
.ip2-hero { position:relative; width:100%; min-height:88vh; display:flex; align-items:center; background:#060d1f; background-size:cover; background-position:center top; padding-top:76px; overflow:hidden; box-sizing:border-box; }
.ip2-hero__overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(6,13,31,.97) 0%,rgba(6,13,31,.84) 55%,rgba(6,13,31,.5) 100%); z-index:0; }
.ip2-hero__orb { position:absolute; border-radius:50%; filter:blur(80px); z-index:0; pointer-events:none; animation:ip2Orb 8s ease-in-out infinite alternate; }
.ip2-hero__orb--1 { width:500px; height:500px; background:rgba(21,101,216,.18); top:-100px; right:-80px; }
.ip2-hero__orb--2 { width:350px; height:350px; background:rgba(0,194,255,.1); bottom:-80px; left:-60px; animation-delay:-4s; }
@keyframes ip2Orb { from{transform:scale(1)} to{transform:scale(1.25) translate(20px,-20px)} }
.ip2-hero .ip2-container { position:relative; z-index:2; padding-top:52px; padding-bottom:72px; }
.ip2-hero__grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.ip2-breadcrumb { display:flex; align-items:center; gap:6px; font-size:.8rem; color:rgba(255,255,255,.45); margin-bottom:20px; flex-wrap:wrap; }
.ip2-breadcrumb a { color:#00c2ff; text-decoration:none; }
.ip2-hero__title { font-size:clamp(2rem,4.5vw,3.5rem); font-weight:800; color:#fff!important; line-height:1.12; margin-bottom:20px; }
.ip2-hero__desc { color:rgba(255,255,255,.72); font-size:1rem; line-height:1.82; max-width:520px; margin-bottom:24px; }
.ip2-hero__trust { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:24px; }
.ip2-hero__trust-badge { display:flex; align-items:center; gap:8px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:50px; padding:7px 14px 7px 10px; font-size:.8rem; font-weight:600; color:rgba(255,255,255,.85); }
.ip2-hero__trust-badge img { height:26px; object-fit:contain; filter:brightness(0) invert(1); }
.ip2-hero__btns { display:flex; flex-wrap:wrap; gap:14px; }
.ip2-hero__img-frame { position:relative; border-radius:20px; }
.ip2-hero__img-frame::before { content:''; position:absolute; inset:-2px; background:linear-gradient(135deg,#1565d8,#00c2ff,#f7c542); border-radius:22px; z-index:-1; opacity:.45; }
.ip2-hero__img { width:100%; border-radius:20px; display:block; max-height:520px; object-fit:cover; }
.ip2-hero__img-glow { position:absolute; inset:-40px; background:radial-gradient(ellipse,rgba(21,101,216,.2),transparent 70%); z-index:-1; pointer-events:none; }

/* ── Tech strip ── */
.ip2-tech-strip { background:rgba(255,255,255,.025); border-top:1px solid rgba(255,255,255,.06); border-bottom:1px solid rgba(255,255,255,.06); padding:18px 0; overflow:hidden; width:100%; }
.ip2-tech-strip__track { display:flex; gap:40px; width:max-content; animation:ip2Scroll 30s linear infinite; }
.ip2-tech-strip:hover .ip2-tech-strip__track { animation-play-state:paused; }
@keyframes ip2Scroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ip2-tech-strip__item { display:flex; flex-direction:column; align-items:center; gap:6px; min-width:80px; text-align:center; }
.ip2-tech-strip__item img { height:44px; object-fit:contain; filter:grayscale(.3) brightness(1.1); }
.ip2-tech-strip__item span { font-size:.72rem; color:rgba(255,255,255,.55); font-weight:600; }

/* ── Section label ── */
.ip2-section-label { padding:52px 0 0; width:100%; }
.ip2-section-label__inner { display:flex; align-items:center; gap:16px; }
.ip2-section-label__line { flex:0 0 56px; height:3px; background:linear-gradient(90deg,#1565d8,#00c2ff); border-radius:2px; }
.ip2-section-label__text { font-size:clamp(1.3rem,2.8vw,2rem); font-weight:700; color:#fff!important; }

/* ── Split sections ── */
.ip2-split { padding:72px 0; width:100%; border-bottom:1px solid rgba(255,255,255,.06); }
.ip2-split--alt { background:#0d1b38; }
.ip2-split__grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.ip2-split__grid--rev { direction:rtl; }
.ip2-split__grid--rev > * { direction:ltr; }
.ip2-split__img-wrap { position:relative; border-radius:20px; overflow:visible; }
.ip2-split__img-wrap img { width:100%; border-radius:20px; display:block; box-shadow:0 24px 64px rgba(0,0,0,.45); }
.ip2-split__img-glow { position:absolute; inset:-40px; background:radial-gradient(ellipse,rgba(21,101,216,.18),transparent 70%); z-index:-1; pointer-events:none; }
.ip2-split__title { font-size:clamp(1.3rem,2.8vw,2.1rem); font-weight:700; color:#fff!important; margin-bottom:16px; line-height:1.25; }
.ip2-split__desc { color:rgba(255,255,255,.65); line-height:1.85; font-size:.97rem; margin-bottom:24px; }

/* Feature list */
.ip2-feature-list { list-style:none; padding:0; margin:0 0 24px; display:flex; flex-direction:column; gap:16px; }
.ip2-feature-list li { display:flex; gap:14px; align-items:flex-start; }
.ip2-feature-list__icon { flex-shrink:0; width:44px; height:44px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:12px; display:flex; align-items:center; justify-content:center; padding:9px; transition:background .2s; }
.ip2-feature-list li:hover .ip2-feature-list__icon { background:rgba(21,101,216,.2); }
.ip2-feature-list__icon img { width:100%; height:100%; object-fit:contain; }
.ip2-feature-list strong { display:block; color:#fff; font-size:.9rem; font-weight:600; margin-bottom:3px; }
.ip2-feature-list p { color:rgba(255,255,255,.55); font-size:.82rem; margin:0; line-height:1.6; }

/* Check list */
.ip2-check-list { list-style:none; padding:0; margin:0 0 24px; display:flex; flex-direction:column; }
.ip2-check-list li { display:flex; align-items:flex-start; gap:10px; padding:8px 0; color:rgba(255,255,255,.72); font-size:.9rem; border-bottom:1px solid rgba(255,255,255,.05); }
.ip2-check-list__dot { flex-shrink:0; width:20px; height:20px; background:rgba(0,194,255,.12); border:1px solid rgba(0,194,255,.25); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-top:1px; }
.ip2-check-list__dot::after { content:'▸'; font-size:.6rem; color:#00c2ff; }

/* ── Offers grid ── */
.ip2-offers { padding:72px 0; background:#0d1b38; width:100%; }
.ip2-offers__grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(185px,1fr)); gap:18px; }
.ip2-offers__card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:28px 18px; display:flex; flex-direction:column; align-items:center; gap:14px; text-align:center; font-size:.875rem; font-weight:600; color:rgba(255,255,255,.8); transition:all .25s; }
.ip2-offers__card:hover { border-color:rgba(0,194,255,.35); transform:translateY(-4px); box-shadow:0 12px 40px rgba(21,101,216,.2); }
.ip2-offers__icon { width:60px; height:60px; background:rgba(255,255,255,.06); border-radius:50%; display:flex; align-items:center; justify-content:center; padding:12px; }
.ip2-offers__icon img { width:100%; height:100%; object-fit:contain; }

/* ── Achievement ── */
.ip2-achievement { padding:72px 0; background:#060d1f; position:relative; overflow:hidden; }
.ip2-achievement__bg { position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(21,101,216,.13),transparent); pointer-events:none; }
.ip2-achievement .ip2-container { position:relative; z-index:1; }
.ip2-achievement__wrap { display:flex; align-items:center; gap:56px; flex-wrap:wrap; justify-content:center; }
.ip2-achievement__globe img { max-width:260px; opacity:.85; }
.ip2-achievement__numbers { display:grid; grid-template-columns:1fr 1fr; gap:18px; min-width:280px; }
.ip2-achievement__item { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:22px; text-align:center; transition:border-color .2s; }
.ip2-achievement__item:hover { border-color:rgba(0,194,255,.3); }
.ip2-achievement__num { display:block; font-size:2rem; font-weight:800; background:linear-gradient(135deg,#1565d8,#00c2ff); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:6px; line-height:1; }
.ip2-achievement__lbl { font-size:.82rem; color:rgba(255,255,255,.6); font-weight:600; }

/* ── Trusted By ── */
.ip2-trusted { padding:64px 0; background:#0d1b38; width:100%; }
.ip2-trusted__grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:20px; }
.ip2-trusted__card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:28px; transition:all .2s; }
.ip2-trusted__card:hover { border-color:rgba(0,194,255,.25); transform:translateY(-3px); }
.ip2-trusted__logo { margin-bottom:14px; }
.ip2-trusted__logo img { height:44px; object-fit:contain; }
.ip2-trusted__name { color:rgba(255,255,255,.8); font-weight:600; font-size:.9rem; margin-bottom:8px; }
.ip2-trusted__link { color:#00c2ff; font-size:.85rem; font-style:italic; display:block; margin-bottom:8px; text-decoration:none; }
.ip2-trusted__desc { color:rgba(255,255,255,.5); font-size:.82rem; line-height:1.7; margin:8px 0 0; }

/* ── Blog ── */
.ip2-blog { padding:72px 0; background:#152244; width:100%; }
.ip2-blog__head { margin-bottom:48px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.07); }
.ip2-blog__title { font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:800; color:#fff; margin-bottom:12px; }
.ip2-blog__sub { color:rgba(255,255,255,.6); font-size:.95rem; line-height:1.8; max-width:480px; margin-bottom:20px; }
.ip2-blog__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.ip2-blog__card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:18px; overflow:hidden; transition:all .25s; }
.ip2-blog__card:hover { border-color:rgba(0,194,255,.25); transform:translateY(-5px); box-shadow:0 16px 48px rgba(0,0,0,.4); }
.ip2-blog__thumb { display:block; overflow:hidden; position:relative; aspect-ratio:16/9; }
.ip2-blog__thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s; display:block; }
.ip2-blog__card:hover .ip2-blog__thumb img { transform:scale(1.06); }
.ip2-blog__thumb-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(6,13,31,.4),transparent); }
.ip2-blog__body { padding:20px; }
.ip2-blog__meta { display:flex; align-items:center; gap:8px; margin-bottom:8px; flex-wrap:wrap; }
.ip2-blog__meta time { font-size:.75rem; color:rgba(255,255,255,.4); }
.ip2-blog__cat { font-size:.72rem; font-weight:700; background:rgba(0,194,255,.1); color:#00c2ff; border:1px solid rgba(0,194,255,.2); border-radius:50px; padding:2px 10px; }
.ip2-blog__body h3 { font-size:.95rem; color:#fff; margin-bottom:8px; line-height:1.4; }
.ip2-blog__body h3 a { color:#fff; text-decoration:none; }
.ip2-blog__body h3 a:hover { color:#00c2ff; }
.ip2-blog__body p { font-size:.82rem; color:rgba(255,255,255,.55); line-height:1.6; margin-bottom:10px; }
.ip2-blog__more { font-size:.8rem; font-weight:700; color:#00c2ff; text-decoration:none; display:inline-flex; align-items:center; gap:4px; }

/* ── CTA section ── */
.ip2-cta { padding:80px 0; background:#060d1f; position:relative; overflow:hidden; }
.ip2-cta__bg { position:absolute; inset:0; background:radial-gradient(ellipse 70% 80% at 30% 50%,rgba(21,101,216,.12),transparent); pointer-events:none; }
.ip2-cta .ip2-container { position:relative; z-index:1; }
.ip2-cta__grid { display:grid; grid-template-columns:1fr 1.4fr; gap:60px; align-items:center; }
.ip2-cta__title { font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:800; color:#fff; margin-bottom:14px; }
.ip2-cta__sub { color:rgba(255,255,255,.6); line-height:1.8; margin-bottom:28px; }
.ip2-cta__contacts { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:16px; }
.ip2-cta__contacts a { display:flex; align-items:center; gap:14px; text-decoration:none; transition:opacity .2s; }
.ip2-cta__contacts a:hover { opacity:.8; }
.ip2-cta__icon { flex-shrink:0; width:44px; height:44px; background:linear-gradient(135deg,#1565d8,#00c2ff); border-radius:12px; display:flex; align-items:center; justify-content:center; color:#fff; }
.ip2-cta__contacts strong { display:block; color:rgba(255,255,255,.5); font-size:.8rem; font-weight:600; margin-bottom:2px; }
.ip2-cta__contacts span { color:#fff; font-size:.9rem; font-weight:600; }
.ip2-cta__form-card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09); border-radius:20px; padding:36px; }
.ip2-cta__form-card h3 { font-size:1.3rem; color:#fff; margin-bottom:8px; }
.ip2-cta__form-card > p { color:rgba(255,255,255,.5); font-size:.88rem; margin-bottom:20px; }
.ip2-cta__form-card .wpcf7-form input:not([type=submit]),
.ip2-cta__form-card .wpcf7-form textarea { background:rgba(255,255,255,.06)!important; border:1px solid rgba(255,255,255,.15)!important; border-radius:10px!important; color:#fff!important; padding:12px 16px!important; width:100%!important; font-size:.9rem!important; box-sizing:border-box!important; margin-bottom:12px; }
.ip2-cta__form-card .wpcf7-form input[type=submit] { background:linear-gradient(135deg,#f7c542,#e0a800)!important; color:#000!important; font-weight:700!important; border:none!important; border-radius:50px!important; padding:13px 28px!important; cursor:pointer!important; width:auto!important; }

/* ══════════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — Inner Page v2
   ══════════════════════════════════════════════════════════════════ */
@media (max-width:1199px) {
  .ip2-container { padding:0 32px; }
  .ip2-split__grid { gap:40px; }
  .ip2-hero__grid { gap:40px; }
}
@media (max-width:991px) {
  .ip2-hero { min-height:auto; }
  .ip2-hero .ip2-container { padding-top:40px; padding-bottom:56px; }
  .ip2-hero__grid { grid-template-columns:1fr; gap:36px; }
  .ip2-hero__image { order:-1; max-width:480px; margin:0 auto; }
  .ip2-hero__title { font-size:2.2rem!important; }
  .ip2-split { padding:48px 0; }
  .ip2-split__grid { grid-template-columns:1fr; gap:32px; }
  .ip2-split__grid--rev { direction:ltr; }
  .ip2-blog__grid { grid-template-columns:repeat(2,1fr); }
  .ip2-cta__grid { grid-template-columns:1fr; gap:40px; }
  .ip2-achievement__wrap { flex-direction:column; gap:32px; }
  .ip2-achievement__numbers { min-width:0; width:100%; }
}
@media (max-width:767px) {
  .ip2-container { padding:0 20px; }
  .ip2-hero .ip2-container { padding-top:36px; padding-bottom:44px; }
  .ip2-hero__title { font-size:1.85rem!important; }
  .ip2-hero__btns { flex-direction:column; align-items:flex-start; }
  .ip2-hero__trust { gap:8px; }
  .ip2-blog__grid { grid-template-columns:1fr; }
  .ip2-offers__grid { grid-template-columns:repeat(2,1fr); }
  .ip2-trusted__grid { grid-template-columns:1fr; }
  .ip2-cta__form-card { padding:22px 18px; }
  .ip2-achievement__numbers { grid-template-columns:1fr 1fr; }
}
@media (max-width:480px) {
  .ip2-hero__title { font-size:1.65rem!important; }
  .ip2-offers__grid { grid-template-columns:1fr; }
  .ip2-achievement__numbers { grid-template-columns:1fr; }
  .ip2-hero__trust { flex-direction:column; }
  .ip2-hero__btns a { text-align:center; justify-content:center; }
}

/* ════════════════════════════════════════════════════════════
   GLOBAL: Hide CF7 built-in headings + style all CF7 forms
   ════════════════════════════════════════════════════════════ */

/* CF7 built-in headings — style nicely, don't hide */
.wpcf7 > div > h2, .wpcf7 > form > h2 {
  font-size:clamp(1.2rem,2.5vw,1.7rem) !important;
  font-weight:800 !important; color:#fff !important;
  margin-bottom:6px !important; line-height:1.3 !important;
}
.wpcf7 > div > h3, .wpcf7 > form > h3 {
  font-size:1rem !important; font-weight:700 !important;
  color:rgba(255,255,255,.65) !important; margin-bottom:16px !important;
}
.wpcf7 h4 {
  font-size:.82rem !important; font-weight:700 !important;
  text-transform:uppercase !important; letter-spacing:1.5px !important;
  color:#00c2ff !important; margin:20px 0 10px !important;
  padding-top:16px !important; border-top:1px solid rgba(255,255,255,.07) !important;
}
/* Contact links inside CF7 */
.wpcf7 ul { list-style:none !important; padding:0 !important; margin:0 0 16px !important; }
.wpcf7 ul li { margin-bottom:6px !important; }
.wpcf7 ul li a {
  display:flex !important; align-items:center !important; gap:8px !important;
  color:rgba(255,255,255,.75) !important; font-size:.88rem !important;
  text-decoration:none !important; padding:8px 12px !important;
  background:rgba(255,255,255,.04) !important;
  border:1px solid rgba(255,255,255,.07) !important;
  border-radius:10px !important; transition:all .2s !important;
}
.wpcf7 ul li a:hover { border-color:rgba(0,194,255,.3) !important; color:#fff !important; }
.wpcf7 > div > p { color:rgba(255,255,255,.6) !important; font-size:.88rem !important; }
.wpcf7 > div > p a { color:#00c2ff !important; }
/* Old sections we replaced - hide those */
.inner-contact-section, .getinTouchSec { display:none !important; }

/* Global dark CF7 field styling */
.wpcf7-form input:not([type=submit]):not([type=checkbox]):not([type=radio]),
.wpcf7-form textarea,
.wpcf7-form select {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 12px !important;
  color: #fff !important;
  padding: 13px 16px !important;
  width: 100% !important;
  font-size: .9rem !important;
  box-sizing: border-box !important;
  margin-bottom: 12px !important;
  font-family: 'Outfit','Inter',sans-serif !important;
  transition: border-color .2s, background .2s !important;
}
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder { color: rgba(255,255,255,.32) !important; }
.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
  border-color: rgba(0,194,255,.5) !important;
  background: rgba(0,194,255,.05) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(0,194,255,.12) !important;
}
.wpcf7-form input[type=submit],
.wpcf7-form .wpcf7-submit {
  background: linear-gradient(135deg,#f7c542,#e0a800) !important;
  color: #000 !important;
  font-weight: 800 !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 14px 40px !important;
  cursor: pointer !important;
  width: auto !important;
  font-size: .95rem !important;
  letter-spacing: .3px !important;
  transition: all .25s !important;
  margin-top: 8px !important;
  display: inline-flex !important;
  align-items: center !important;
}
.wpcf7-form input[type=submit]:hover,
.wpcf7-form .wpcf7-submit:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(247,197,66,.4) !important;
}
.wpcf7-response-output {
  border-radius: 12px !important;
  margin: 12px 0 0 !important;
  padding: 12px 16px !important;
  font-size: .88rem !important;
  border: none !important;
  background: rgba(0,194,255,.1) !important;
  color: #fff !important;
}
.wpcf7-not-valid-tip { color: #ff6b6b !important; font-size: .8rem !important; }

/* Textarea min height */
.wpcf7-form textarea { min-height: 130px !important; resize: vertical !important; }

/* Label */
.wpcf7-form label {
  color: rgba(255,255,255,.55) !important;
  font-size: .8rem !important;
  font-weight: 600 !important;
  letter-spacing: .4px !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
  display: block !important;
}

/* ╔══════════════════════════════════════════════════════════════
   OCEAN BLUE THEME — Global Overrides
   All dark navy → ocean blue gradient palette
   ══════════════════════════════════════════════════════════════╗ */

/* Re-map all dark navy colors to ocean blue */
:root {
  --n:   #0a1628; /* was #060d1f */
  --nm:  #0f2040; /* was #0d1b38 */
  --nl:  #162a52; /* was #152244 */
  --b:   #0066cc; /* was #1565d8 */
  --c:   #00b4d8; /* was #00c2ff */
  --g:   #f4a825; /* was #f7c542 */
  --ob-bg:#0a1628; --ob-bg2:#0f2040; --ob-bg3:#162a52;
  --ob-blue:#0066cc; --ob-blue2:#0080ff;
  --ob-cyan:#00b4d8; --ob-cyan2:#48cae4;
  --ob-gold:#f4a825; --ob-gold2:#e09420;
  --ob-text:#d0e8ff; --ob-muted:rgba(180,215,255,.65);
  --ob-border:rgba(0,180,216,.15); --ob-card:rgba(0,102,204,.08);
  --color-cyan:#00b4d8; --color-gold:#f4a825;
}
html, body { background:#0a1628 !important; color:#d0e8ff !important; }
.main-content-wrapper, .ip-page-wrap, .au-wrap, .wa-wrap, .cp-wrap { background:#0a1628; }

/* Update all hero/section backgrounds */
.iph, section.hp-hero, .au-hero, .wa-hero, .cp-hero { background:#0a1628 !important; }
.iph.has-bg, .au-hero.has-bg, section.hp-hero.has-bg { background-color:#0a1628 !important; }

/* Section alternating backgrounds */
.sp.alt, .au-split.alt, .wa-split.alt { background:#0f2040 !important; }

/* Tech strip */
.ts, .ip2-tech-strip { background:rgba(0,102,204,.06) !important; border-color:rgba(0,180,216,.1) !important; }

/* Cards */
.iph__badge, .sp__img-w, .og__card, .ach__item, .tr__card,
.bl__card, .au-val, .wa-perk, .wa-job, .nct__card,
.hp-services__card, .hp-stats__item, .hp-portfolio__item,
.hp-blog__card, .hp-trusted__card, .hp-achievement__item {
  background:rgba(0,102,204,.08) !important;
  border-color:rgba(0,180,216,.15) !important;
}
.og__card:hover, .tr__card:hover, .wa-perk:hover, .wa-job:hover,
.hp-services__card:hover, .hp-stats__item:hover, .hp-blog__card:hover {
  border-color:rgba(0,180,216,.4) !important;
  box-shadow:0 12px 40px rgba(0,102,204,.25) !important;
}

/* Gradient text updates */
.ach__num, .hp-stats__num, .hp-achievement__num, .au-why__num {
  background:linear-gradient(135deg,#0066cc,#00b4d8) !important;
  -webkit-background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
  background-clip:text !important;
}

/* Section head bar */
.ach__bar, .au-why__bar, .wa-bar { background:linear-gradient(90deg,#0066cc,#00b4d8) !important; }

/* Buttons */
.btn-gd, .btn-gold-ag, .ip2-btn--gold, .requestBtn, .hp-btn--gold {
  background:linear-gradient(135deg,#f4a825,#e09420) !important;
}
.btn-ol, .ip2-btn--outline, .hp-btn--outline {
  border-color:rgba(0,180,216,.3) !important; color:#d0e8ff !important;
}

/* Eyebrow text + links */
.nct__ey, .bl__ey, .hp-eyebrow, .wa-bc a, .iph__bc a, .au-hero__bc a, .cp-hero__ey { color:#00b4d8 !important; }

/* Form inputs — ocean blue tint */
.wpcf7-form input:not([type=submit]),
.wpcf7-form textarea {
  background:rgba(0,102,204,.08) !important;
  border-color:rgba(0,180,216,.2) !important;
}
.wpcf7-form input:focus, .wpcf7-form textarea:focus {
  border-color:rgba(0,180,216,.6) !important;
  background:rgba(0,180,216,.06) !important;
  box-shadow:0 0 0 3px rgba(0,180,216,.12) !important;
}

/* Contact cards */
.nct__card { background:rgba(0,102,204,.08) !important; border-color:rgba(0,180,216,.15) !important; }
.nct__card:hover { border-color:rgba(0,180,216,.4) !important; background:rgba(0,180,216,.1) !important; }
.nct__card-ico-email { background:linear-gradient(135deg,#0066cc,#00b4d8) !important; }
.nct__card-ico-phone { background:linear-gradient(135deg,#047857,#10b981) !important; }
.nct__card-ico-wa    { background:linear-gradient(135deg,#15803d,#22c55e) !important; }

/* Scroll top */
.scroll-top-btn { background:linear-gradient(135deg,#0066cc,#00b4d8) !important; }

/* Hero orbs - ocean blue */
.wa-orb1, .iph__orb1, .au-hero__orb1 { background:rgba(0,102,204,.2) !important; }
.wa-orb2, .iph__orb2, .au-hero__orb2 { background:rgba(0,180,216,.12) !important; }

/* Split glow */
.sp__glow, .wa-split__glow, .iph__glow { background:radial-gradient(ellipse,rgba(0,102,204,.18),transparent 70%) !important; }

/* Blog category pills */
.bl__cat, .hp-blog__cat { background:rgba(0,180,216,.12) !important; color:#00b4d8 !important; border-color:rgba(0,180,216,.25) !important; }

/* Check dots */
.chk-dot { background:rgba(0,180,216,.12) !important; border-color:rgba(0,180,216,.3) !important; color:#00b4d8 !important; }

/* Hero image frame gradient */
.iph__img-frame::before, .wa-img-frame::before, .au-hero__img-frame::before {
  background:linear-gradient(135deg,#0066cc,#00b4d8,#f4a825) !important;
}

/* CTA banner */
.wa-cta, .au-cta { background:linear-gradient(135deg,#0f2040,#162a52,#0066cc) !important; }

/* Section labels */
.sl__line { background:linear-gradient(90deg,#0066cc,#00b4d8) !important; }

/* Trusted link */
.tr__link { color:#00b4d8 !important; }

/* Quick contact arrow */
.nct__card-arr { color:rgba(180,215,255,.3) !important; }
.nct__card:hover .nct__card-arr { color:#00b4d8 !important; }

/* Perk card hover */
.wa-perk:hover { border-color:rgba(0,180,216,.4) !important; }

/* Job cards */
.wa-job__icon { background:linear-gradient(135deg,#0066cc,#00b4d8) !important; }
.wa-job__badge { background:rgba(0,180,216,.1) !important; color:#00b4d8 !important; border-color:rgba(0,180,216,.2) !important; }
.wa-job__tag  { background:rgba(0,102,204,.1) !important; border-color:rgba(0,180,216,.15) !important; }

/* Stats items */
.nct__stat { background:rgba(0,102,204,.08) !important; border-color:rgba(0,180,216,.12) !important; }
.nct__stat strong { background:linear-gradient(135deg,#f4a825,#e09420) !important; -webkit-background-clip:text !important; -webkit-text-fill-color:transparent !important; background-clip:text !important; }


/* ══════════════════════════════════════════════════════════════
   CRITICAL FIXES — Applied last, maximum specificity
   ══════════════════════════════════════════════════════════════ */

/* 1. HIDE CF7 HEADINGS site-wide */
.wpcf7 h1, .wpcf7 h2, .wpcf7 h3, .wpcf7 h4,
.wpcf7 > form > h2, .wpcf7 > form > h3,
.wpcf7 > div > h2, .wpcf7 > div > h3,
.wpcf7 > div > h4 { display:none; }

/* 2. NO WHITE FLASH */
html, body { background:#0a1628 !important; }

/* 3. HERO SPACING — remove ALL double padding */
body { padding-top:76px !important; }
.page-banner,
.hero-section,
.iph,
.bl-hero,
.sp-hero,
.au-hero,
.wa-hero,
.cp-hero,
section[class*="hero"],
div[class*="hero"] { padding-top:0 !important; }

/* Inner content padding for hero text */
.page-banner-content { padding-top:40px !important; padding-bottom:48px !important; }
.bl-hero { padding-bottom:48px !important; }
.sp-hero { padding-bottom:40px !important; }
.iph .iph__wrap { padding-top:44px !important; padding-bottom:56px !important; }

/* 4. DROPDOWN MENU SPACING */
.ob-nav .sub-menu {
  padding:10px !important;
  min-width:240px !important;
}
.ob-nav .sub-menu li { margin:2px 0 !important; }
.ob-nav .sub-menu li > a,
.ob-nav .sub-menu li > .dropdown-link {
  display:block !important;
  padding:11px 18px !important;
  border-radius:8px !important;
  line-height:1.5 !important;
  font-size:.83rem !important;
  color:rgba(180,215,255,.75) !important;
  transition:all .2s !important;
  white-space:normal !important;
  word-wrap:break-word !important;
}
.ob-nav .sub-menu li:hover > a,
.ob-nav .sub-menu li:hover > .dropdown-link {
  color:#00b4d8 !important;
  background:rgba(0,180,216,.09) !important;
  padding-left:22px !important;
}

/* 5. CF7 FORM DARK PREMIUM STYLING */
.wpcf7-form input:not([type=submit]):not([type=checkbox]):not([type=radio]),
.wpcf7-form textarea,
.wpcf7-form select {
  background:rgba(0,102,204,.08) !important;
  border:1.5px solid rgba(0,180,216,.2) !important;
  border-radius:12px !important;
  color:#fff !important;
  padding:13px 18px !important;
  width:100% !important;
  font-size:.9rem !important;
  box-sizing:border-box !important;
  margin-bottom:12px !important;
  font-family:'Outfit','Inter',sans-serif !important;
  transition:border-color .25s, background .25s, box-shadow .25s !important;
}
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder { color:rgba(180,215,255,.32) !important; }
.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
  border-color:rgba(0,180,216,.6) !important;
  background:rgba(0,180,216,.07) !important;
  outline:none !important;
  box-shadow:0 0 0 4px rgba(0,180,216,.1) !important;
}
.wpcf7-form textarea { min-height:130px !important; resize:vertical !important; }
.wpcf7-form input[type=submit],
.wpcf7-form .wpcf7-submit {
  background:linear-gradient(135deg,#f4a825,#e09420) !important;
  color:#000 !important;
  font-weight:800 !important;
  border:none !important;
  border-radius:50px !important;
  padding:14px 40px !important;
  cursor:pointer !important;
  width:auto !important;
  font-size:.95rem !important;
  letter-spacing:.3px !important;
  transition:all .25s !important;
  margin-top:4px !important;
  box-shadow:0 4px 16px rgba(244,168,37,.25) !important;
}
.wpcf7-form input[type=submit]:hover,
.wpcf7-form .wpcf7-submit:hover {
  transform:translateY(-2px) !important;
  box-shadow:0 8px 28px rgba(244,168,37,.45) !important;
}
.wpcf7-response-output {
  border-radius:12px !important;
  margin:14px 0 0 !important;
  padding:12px 18px !important;
  font-size:.88rem !important;
  border:1px solid rgba(0,180,216,.25) !important;
  background:rgba(0,180,216,.08) !important;
  color:#0d6efd !important;
}
.wpcf7-not-valid-tip { color:#f87171 !important; font-size:.8rem !important; margin-top:4px !important; }
.wpcf7-form label {
  color:rgba(180,215,255,.6) !important;
  font-size:.78rem !important;
  font-weight:700 !important;
  letter-spacing:.5px !important;
  text-transform:uppercase !important;
  margin-bottom:6px !important;
  display:block !important;
}

/* 6. MOBILE HERO FIX */
@media(max-width:991px){
  .page-banner { min-height:280px !important; }
  .bl-hero, .sp-hero { padding-bottom:36px !important; }
  .iph .iph__wrap { padding-top:36px !important; padding-bottom:44px !important; }
}
@media(max-width:767px){
  .page-banner { min-height:240px !important; }
  .page-banner-content { padding-top:28px !important; padding-bottom:36px !important; }
  .bl-hero { padding-bottom:32px !important; }
  .ob-nav .sub-menu li > a,
  .ob-nav .sub-menu li > .dropdown-link { white-space:normal !important; }
}

/* ═══ FAQ ACCORDION — Global Styles ═══════════════════════════════════ */
.ip-faq{padding:64px 0;background:var(--ob-bg2,#0f2040);width:100%;}
.ip-faq__w{max-width:860px;margin:0 auto;padding:0 40px;box-sizing:border-box;}
.ip-faq__sh{text-align:center;margin-bottom:44px;}
.ip-faq__sh h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;color:#fff;margin-bottom:10px;}
.ip-faq__bar{width:56px;height:3px;background:linear-gradient(90deg,var(--ob-blue,#0066cc),var(--ob-cyan,#00b4d8));border-radius:2px;margin:0 auto;}
.ip-faq__sub{color:rgba(208,232,255,.6);font-size:.9rem;margin-top:12px;}
.faq-item{border:1px solid rgba(0,180,216,.15);border-radius:14px;overflow:hidden;margin-bottom:10px;transition:border-color .2s,box-shadow .2s;}
.faq-item.open{border-color:rgba(0,180,216,.45);box-shadow:0 4px 24px rgba(0,180,216,.1);}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;cursor:pointer;background:rgba(0,102,204,.06);transition:background .2s;-webkit-user-select:none;user-select:none;list-style:none;}
.faq-q:hover{background:rgba(0,102,204,.12);}
.faq-item.open .faq-q{background:rgba(0,180,216,.08);}
.faq-q__text{font-size:.95rem;font-weight:700;color:#fff;line-height:1.45;flex:1;}
.faq-q__icon{width:28px;height:28px;flex-shrink:0;background:rgba(0,180,216,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#00b4d8;font-weight:700;line-height:1;transition:transform .3s,background .2s;}
.faq-item.open .faq-q__icon{transform:rotate(45deg);background:rgba(0,180,216,.2);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.faq-item.open .faq-a{max-height:800px;}
.faq-a__inner{padding:0 22px 22px;color:rgba(208,232,255,.72);font-size:.9rem;line-height:1.85;}
@media(max-width:767px){
  .ip-faq__w{padding:0 20px;}
  .ip-faq{padding:48px 0;}
  .faq-q{padding:14px 16px;}
  .faq-q__text{font-size:.88rem;}
  .faq-a__inner{padding:0 16px 16px;}
}
