/* ============================================================
   WIXNIT — SHARED DESIGN SYSTEM
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,300;12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300&display=swap');

/* ── DARK MODE (default) ── */
:root {
  --bg:         #03060F;
  --surface:    #080E1C;
  --surface2:   #0E1526;
  --surface3:   #141D30;
  --blue:       #2563EB;
  --blue-mid:   #3B82F6;
  --blue-light: #93C5FD;
  --green:      #059669;
  --green-mid:  #10B981;
  --green-light:#6EE7B7;
  --amber:      #D97706;
  --amber-mid:  #F59E0B;
  --amber-light:#FCD34D;
  --violet:     #7C3AED;
  --violet-mid: #8B5CF6;
  --violet-light:#C4B5FD;
  --white:      #F8FAFC;
  --text:       #CBD5E1;
  --muted:      #64748B;
  --border:     rgba(255,255,255,0.07);
  --radius:     10px;
  --radius-lg:  16px;
  --shadow-sm:  0 1px 3px rgba(0,0,0,.4);
  --shadow-md:  0 4px 16px rgba(0,0,0,.5);
  --hero-grid-color: rgba(59,130,246,.025);
}

/* ── LIGHT MODE ── */
html.light {
  --bg:         #F1F5F9;
  --surface:    #FFFFFF;
  --surface2:   #F8FAFC;
  --surface3:   #EFF3F7;
  --blue:       #1D4ED8;
  --blue-mid:   #2563EB;
  --blue-light: #1D4ED8;
  --green:      #047857;
  --green-mid:  #059669;
  --green-light:#047857;
  --amber:      #B45309;
  --amber-mid:  #D97706;
  --amber-light:#92400E;
  --violet:     #6D28D9;
  --violet-mid: #7C3AED;
  --violet-light:#5B21B6;
  --white:      #0F172A;
  --text:       #334155;
  --muted:      #64748B;
  --border:     rgba(0,0,0,0.08);
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08);
  --shadow-md:  0 4px 16px rgba(0,0,0,.1);
  --hero-grid-color: rgba(37,99,235,.04);
}

/* Light mode body overrides */
html.light body { cursor: none; }
html.light body::after { opacity: 0; }

/* Light headings */
html.light h1, html.light h2, html.light h3,
html.light .h1, html.light .h2, html.light .h3,
html.light .nav-logo, html.light .stat-num,
html.light .hero-h1, html.light .sh-num,
html.light .fp-stat-num, html.light .prog-num,
html.light .testi-name, html.light .team-name,
html.light .div-card-title, html.light .division-name,
html.light .val-title, html.light .feat-item-text h4,
html.light .tech-step-title, html.light .tl-title,
html.light .office-name, html.light .form-title,
html.light .ci-value, html.light .faq-q,
html.light .footer-col h4, html.light .cta-title,
html.light .pillar-text h4, html.light .prod-name,
html.light .prog-title, html.light .region-name {
  color: #0F172A;
}

/* Nav links light */
html.light .nav-links a { color: #475569; }
html.light .nav-links a:hover, html.light .nav-links a.active { color: #0F172A; background: rgba(0,0,0,.04); }
html.light .nav-cta { background: var(--blue-mid); }
html.light .nav-drawer { background: rgba(248,250,252,.97); }
html.light .nav-drawer a { color: #0F172A; }
html.light .drawer-close { color: #64748B; }

/* Card surfaces light */
html.light .card,
html.light .testi-card,
html.light .tech-step,
html.light .val-card,
html.light .prog-card,
html.light .office-card,
html.light .team-card,
html.light .contact-form-wrap,
html.light .contact-item,
html.light .faq-item,
html.light .partner-card,
html.light .pillar,
html.light .feat-item,
html.light .stat-item,
html.light .sh-item,
html.light .region-item,
html.light .div-section,
html.light .featured-program { box-shadow: var(--shadow-sm); }

/* Scrollbar */
html.light ::-webkit-scrollbar-track { background: var(--bg); }
html.light ::-webkit-scrollbar-thumb { background: #CBD5E1; }

/* Marquee */
html.light .marquee-wrap { background: var(--surface); }
html.light .mi { color: #94A3B8; }

/* Hero grid */
html.light .hero-grid {
  background-image:
    linear-gradient(var(--hero-grid-color) 1px, transparent 1px),
    linear-gradient(90deg, var(--hero-grid-color) 1px, transparent 1px);
}

/* Pill light tweaks */
html.light .pill-blue { background: rgba(37,99,235,.07); }
html.light .pill-green { background: rgba(5,150,105,.07); }
html.light .pill-amber { background: rgba(217,119,6,.07); }
html.light .pill-violet { background: rgba(109,40,217,.07); }

/* Footer */
html.light footer { background: var(--surface); }
html.light .footer-copy { color: #94A3B8; }
html.light .soc { color: #94A3B8; }
html.light .soc:hover { color: var(--blue-mid); }

/* ── THEME TOGGLE BUTTON ── */
.theme-toggle {
  width: 40px; height: 40px;
  border-radius: 10px;
  border: 1.5px solid var(--border);
  background: var(--surface2);
  display: flex; align-items: center; justify-content: center;
  cursor: none;
  margin-left: .75rem;
  transition: border-color .25s, background .25s, transform .2s;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.theme-toggle:hover {
  border-color: var(--blue-mid);
  background: rgba(59,130,246,.08);
  transform: rotate(15deg);
}
.theme-toggle .icon-sun,
.theme-toggle .icon-moon {
  position: absolute;
  font-size: 1.05rem;
  transition: opacity .3s, transform .4s;
  line-height: 1;
}
.theme-toggle .icon-sun  { opacity: 0; transform: rotate(-90deg) scale(.6); }
.theme-toggle .icon-moon { opacity: 1; transform: rotate(0deg) scale(1); }

html.light .theme-toggle .icon-sun  { opacity: 1; transform: rotate(0deg) scale(1); }
html.light .theme-toggle .icon-moon { opacity: 0; transform: rotate(90deg) scale(.6); }

/* Smooth transitions for all theme changes */
body, nav, .nav-links a, .card, .stat-item, .val-card, .testi-card,
.tech-step, .feat-item, .pillar, .partner-card, .faq-item, .contact-item,
.contact-form-wrap, .office-card, .team-card, .prog-card, .sh-item,
footer, .marquee-wrap, .form-input, .form-select, .form-textarea {
  transition: background-color .35s ease, border-color .35s ease, color .25s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-weight: 400;
  line-height: 1.6;
  overflow-x: hidden;
  cursor: none;
}

/* ── CURSOR ── */
.cur {
  width: 10px; height: 10px;
  background: var(--blue-mid);
  border-radius: 50%;
  position: fixed; top:0; left:0;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  transition: transform .12s ease, background .2s;
}
.cur-ring {
  width: 38px; height: 38px;
  border: 1.5px solid rgba(59,130,246,.4);
  border-radius: 50%;
  position: fixed; top:0; left:0;
  pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: all .18s ease;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--surface3); border-radius: 4px; }

/* ── NOISE LAYER ── */
body::after {
  content:''; position:fixed; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
  pointer-events:none; z-index:9990;
}

/* ── NAV ── */
#nav {
  position: fixed; top:0; left:0; right:0;
  z-index: 1000;
  padding: 1.25rem 5vw;
  display: flex; align-items: center; justify-content: space-between;
  transition: background .4s, backdrop-filter .4s, border-color .4s;
  border-bottom: 1px solid transparent;
}
#nav.scrolled {
  background: rgba(3,6,15,.85);
  backdrop-filter: blur(20px);
  border-color: var(--border);
}
.nav-logo {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800;
  font-size: 1.55rem;
  letter-spacing: -.03em;
  color: #fff;
  text-decoration: none;
}
.nav-logo em { color: var(--blue-mid); font-style: normal; }
.nav-links {
  display: flex; align-items: center; gap: .25rem;
}
.nav-links a {
  font-size: .84rem;
  font-weight: 500;
  color: var(--muted);
  text-decoration: none;
  padding: .45rem .9rem;
  border-radius: 6px;
  transition: color .2s, background .2s;
  letter-spacing: .01em;
}
.nav-links a:hover, .nav-links a.active { color:#fff; background: rgba(255,255,255,.05); }
.nav-cta {
  font-size: .8rem;
  font-weight: 600;
  background: var(--blue-mid);
  color: #fff;
  padding: .55rem 1.4rem;
  border-radius: 8px;
  text-decoration: none;
  margin-left: .75rem;
  transition: background .2s, transform .2s, box-shadow .2s;
  letter-spacing: .02em;
}
.nav-cta:hover {
  background: #2563EB;
  transform: translateY(-1px);
  box-shadow: 0 4px 24px rgba(59,130,246,.35);
}

/* Hamburger */
.nav-ham {
  display: none;
  flex-direction: column; gap: 5px;
  cursor: none; padding: 6px;
}
.nav-ham span {
  display: block; width: 22px; height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all .3s;
}
.nav-drawer {
  display: none;
  position: fixed; inset:0; top:0;
  background: rgba(3,6,15,.97);
  backdrop-filter: blur(20px);
  z-index: 999;
  flex-direction: column;
  align-items: center; justify-content: center; gap: 2.5rem;
  padding: 2rem;
}
.nav-drawer.open { display: flex; }
.nav-drawer a {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  letter-spacing: -.02em;
  transition: color .2s;
}
.nav-drawer a:hover { color: var(--blue-mid); }
.drawer-close {
  position: absolute; top: 1.5rem; right: 1.5rem;
  font-size: 1.5rem; color: var(--muted); cursor: none;
  background: none; border: none;
  transition: color .2s;
}
.drawer-close:hover { color: #fff; }

/* ── SECTION BASE ── */
.section { padding: 7rem 5vw; max-width: 1360px; margin: 0 auto; }
.section-full { padding: 7rem 5vw; }

.eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--blue-mid);
  margin-bottom: 1.1rem;
}
.eyebrow::before {
  content:''; width: 20px; height: 1.5px;
  background: var(--blue-mid);
  display: inline-block;
}
.eyebrow.green { color: var(--green-mid); }
.eyebrow.green::before { background: var(--green-mid); }
.eyebrow.amber { color: var(--amber-mid); }
.eyebrow.amber::before { background: var(--amber-mid); }
.eyebrow.violet { color: var(--violet-mid); }
.eyebrow.violet::before { background: var(--violet-mid); }

.h1 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800;
  font-size: clamp(3rem, 7vw, 6.5rem);
  line-height: .96;
  letter-spacing: -.04em;
  color: #fff;
}
.h2 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 1.06;
  letter-spacing: -.03em;
  color: #fff;
}
.h3 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700;
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  letter-spacing: -.02em;
  color: #fff;
}
.lead {
  font-size: clamp(.95rem, 1.4vw, 1.1rem);
  color: var(--muted);
  line-height: 1.8;
  font-weight: 300;
}

.text-blue { color: var(--blue-mid); }
.text-green { color: var(--green-mid); }
.text-amber { color: var(--amber-mid); }
.text-violet { color: var(--violet-mid); }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-weight: 600;
  font-size: .88rem;
  padding: .85rem 2rem;
  border-radius: 8px;
  text-decoration: none;
  transition: all .25s;
  letter-spacing: .01em;
  border: none; cursor: none;
}
.btn-blue {
  background: var(--blue-mid);
  color: #fff;
}
.btn-blue:hover {
  background: var(--blue);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(59,130,246,.35);
}
.btn-outline {
  border: 1.5px solid var(--border);
  color: var(--text);
  background: transparent;
}
.btn-outline:hover {
  border-color: rgba(255,255,255,.25);
  color: #fff;
  background: rgba(255,255,255,.04);
}
.btn-green { background: var(--green-mid); color:#fff; }
.btn-green:hover { background: var(--green); transform:translateY(-2px); box-shadow:0 8px 32px rgba(16,185,129,.3); }

/* ── PILL TAGS ── */
.pill {
  display: inline-block;
  font-size: .7rem;
  font-weight: 500;
  padding: .28rem .75rem;
  border-radius: 20px;
  border: 1px solid;
  letter-spacing: .04em;
}
.pill-blue { color: var(--blue-light); border-color: rgba(59,130,246,.25); background: rgba(59,130,246,.06); }
.pill-green { color: var(--green-light); border-color: rgba(16,185,129,.25); background: rgba(16,185,129,.06); }
.pill-amber { color: var(--amber-light); border-color: rgba(245,158,11,.25); background: rgba(245,158,11,.06); }
.pill-violet { color: var(--violet-light); border-color: rgba(139,92,246,.25); background: rgba(139,92,246,.06); }

/* ── CARDS ── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color .3s, transform .3s;
}
.card:hover {
  border-color: rgba(59,130,246,.2);
  transform: translateY(-4px);
}

/* ── IMAGE UTILITIES ── */
.img-cover { width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.img-overlay {
  position: absolute; inset:0;
  background: linear-gradient(to bottom, rgba(3,6,15,.2) 0%, rgba(3,6,15,.85) 100%);
}
.img-overlay-right {
  position: absolute; inset:0;
  background: linear-gradient(to right, rgba(3,6,15,.95) 35%, rgba(3,6,15,.4) 100%);
}
.img-overlay-light {
  position: absolute; inset:0;
  background: rgba(3,6,15,.55);
}

/* ── DIVIDER ── */
.divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 0;
}

/* ── MARQUEE ── */
.marquee-wrap {
  overflow: hidden;
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: .9rem 0;
}
.marquee-track {
  display: flex; gap: 0;
  white-space: nowrap;
  animation: marquee 30s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
.mi {
  display: inline-flex; align-items: center; gap: .6rem;
  font-size: .74rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 0 2.5rem;
}
.mi span { color: var(--blue-mid); font-size: .6rem; }
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ── STATS STRIP ── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.stat-item {
  background: var(--surface);
  padding: 2.5rem 2rem;
  text-align: center;
  transition: background .3s;
}
.stat-item:hover { background: var(--surface2); }
.stat-num {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800;
  font-size: 2.8rem;
  color: #fff;
  line-height: 1;
  letter-spacing: -.03em;
}
.stat-num b { color: var(--blue-mid); }
.stat-label {
  font-size: .75rem;
  font-weight: 500;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-top: .4rem;
}

/* ── FOOTER ── */
footer {
  background: var(--surface);
  border-top: 1px solid var(--border);
  padding: 5rem 5vw 2.5rem;
}
.footer-inner { max-width: 1360px; margin: 0 auto; }
.footer-grid {
  display: grid;
  grid-template-columns: 2.2fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3.5rem;
}
.footer-about-text {
  font-size: .875rem;
  color: var(--muted);
  line-height: 1.8;
  margin-top: .9rem;
  max-width: 300px;
  font-weight: 300;
}
.footer-col h4 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 1.2rem;
}
.footer-col ul { list-style: none; display:flex; flex-direction:column; gap:.65rem; }
.footer-col ul a {
  font-size: .85rem;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.footer-col ul a:hover { color: #fff; }
.footer-bottom {
  border-top: 1px solid var(--border);
  padding-top: 1.8rem;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem;
}
.footer-copy {
  font-size: .78rem;
  color: var(--muted);
}
.footer-socials { display:flex; gap:.6rem; }
.soc {
  width: 36px; height: 36px;
  border: 1px solid var(--border);
  border-radius: 8px;
  display:flex; align-items:center; justify-content:center;
  font-size: .78rem; font-weight:700;
  color: var(--muted);
  text-decoration: none;
  transition: all .2s;
}
.soc:hover { border-color: var(--blue-mid); color: var(--blue-mid); background: rgba(59,130,246,.07); }

/* ── REVEAL ANIMATIONS ── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-left {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal-left.in { opacity: 1; transform: translateX(0); }
.reveal-right {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal-right.in { opacity: 1; transform: translateX(0); }

/* ── MOBILE RESPONSIVE ── */
@media (max-width: 1024px) {
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-ham { display: flex; }
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr; }
  .section { padding: 5rem 5vw; }
}
@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
}
