/* =====================================================
   StackOrbit — Redesign v2
   Dark Editorial · Mesh Gradients · Lime Accent
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Karla:ital,wght@0,300;0,400;0,500;0,700;1,400&display=swap');

:root {
  --bg-void:   #07090C;
  --bg-deep:   #0C0F14;
  --bg-mid:    #111620;
  --bg-glass:  rgba(255,255,255,.04);
  --bg-glass2: rgba(255,255,255,.07);

  --g-teal:    #00C9A7;
  --g-blue:    #1D6FFF;
  --g-lime:    #C9FF3A;
  --g-amber:   #FF9B3A;

  --grad-main:   linear-gradient(135deg, #00C9A7 0%, #1D6FFF 100%);
  --grad-warm:   linear-gradient(135deg, #FF9B3A 0%, #FF4E8A 100%);
  --grad-lime:   linear-gradient(135deg, #C9FF3A 0%, #00C9A7 100%);
  --grad-text:   linear-gradient(90deg,  #00C9A7 0%, #1D6FFF 60%, #C9FF3A 100%);
  --grad-subtle: linear-gradient(135deg, rgba(0,201,167,.12) 0%, rgba(29,111,255,.12) 100%);

  --txt-hi:   #F0F4FF;
  --txt-mid:  #8B94A8;
  --txt-low:  #4A5262;

  --font-head: 'Syne', sans-serif;
  --font-body: 'Karla', sans-serif;

  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 24px;
  --transition: .38s cubic-bezier(.23,.46,.36,1);
  --glow:      0 0 40px rgba(0,201,167,.22), 0 0 80px rgba(29,111,255,.12);
  --glow-lime: 0 0 28px rgba(201,255,58,.35);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 17px; }
body {
  font-family: var(--font-body);
  background: var(--bg-void);
  color: var(--txt-hi);
  line-height: 1.75;
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 { font-family: var(--font-head); line-height: 1.15; color: var(--txt-hi); }
h1 { font-size: clamp(2.6rem, 6vw, 5rem); font-weight: 800; }
h2 { font-size: clamp(2rem, 4vw, 3.4rem); font-weight: 700; }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.8rem); font-weight: 600; }
h4 { font-size: 1.2rem; font-weight: 600; }
p  { color: var(--txt-mid); line-height: 1.8; font-size: 1rem; }
a  { text-decoration: none; color: inherit; }
img{ max-width: 100%; height: auto; display: block; }

/* noise grain overlay */
body::before {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none; z-index: 0; opacity: .032;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}

/* ── UTILITY ── */
.section-pad    { padding: 100px 0; }
.section-pad-sm { padding: 64px 0; }

.tag-label {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-head); font-size: .7rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--g-lime);
  background: rgba(201,255,58,.08);
  border: 1px solid rgba(201,255,58,.18);
  border-radius: 40px; padding: 6px 16px; margin-bottom: 18px;
}
.gradient-text {
  background: var(--grad-text);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.section-intro { font-size: 1.05rem; color: var(--txt-mid); max-width: 560px; line-height: 1.8; }
.gline { display: block; width: 64px; height: 3px; background: var(--grad-main); border-radius: 4px; margin-bottom: 20px; }

/* ── BUTTONS ── */
.btn-glow {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--grad-main); color: #fff;
  font-family: var(--font-head); font-size: .82rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 15px 34px; border-radius: 50px; border: none; cursor: pointer;
  position: relative; transition: var(--transition);
  box-shadow: 0 4px 28px rgba(0,201,167,.3);
}
.btn-glow::after {
  content: ''; position: absolute; inset: -1px; border-radius: 50px;
  background: var(--grad-main); filter: blur(12px); opacity: 0; z-index: -1; transition: opacity .3s;
}
.btn-glow:hover { transform: translateY(-2px); color:#fff; }
.btn-glow:hover::after { opacity: .6; }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 10px;
  background: transparent; color: var(--txt-hi);
  font-family: var(--font-head); font-size: .82rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 14px 34px; border-radius: 50px;
  border: 1px solid rgba(255,255,255,.15); cursor: pointer; transition: var(--transition);
}
.btn-ghost:hover { border-color: var(--g-teal); color: var(--g-teal); box-shadow: 0 0 20px rgba(0,201,167,.15); }

.btn-lime {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--g-lime); color: #07090C;
  font-family: var(--font-head); font-size: .82rem; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 15px 34px; border-radius: 50px; border: none; cursor: pointer;
  transition: var(--transition); box-shadow: var(--glow-lime);
}
.btn-lime:hover { transform: translateY(-2px); background: #d4ff50; color:#07090C; }

/* ══ NAVBAR ══ */
.navbar-main {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  transition: background .4s, border-color .4s;
  border-bottom: 1px solid transparent;
}
.navbar-main.scrolled {
  background: rgba(7,9,12,.88);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom-color: rgba(255,255,255,.06);
}
.navbar-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 48px; max-width: 1320px; margin: 0 auto;
}
.brand-logo { display: flex; flex-direction: column; gap: 2px; }
.brand-logo .logo-name {
  font-family: var(--font-head); font-size: 1.5rem; font-weight: 800;
  background: var(--grad-main);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.brand-logo .logo-sub {
  font-size: .6rem; font-weight: 500; letter-spacing: .2em;
  text-transform: uppercase; color: var(--txt-low);
}
.nav-links { display: flex; align-items: center; gap: 36px; list-style: none; }
.nav-links a {
  font-family: var(--font-head); font-size: .75rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase; color: var(--txt-mid);
  transition: color .25s; position: relative;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -4px; left: 0;
  width: 0; height: 2px; border-radius: 2px;
  background: var(--grad-main); transition: width .3s;
}
.nav-links a:hover, .nav-links a.active { color: var(--txt-hi); }
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }
.nav-cta-pill {
  background: var(--grad-main) !important; color: #fff !important;
  padding: 9px 22px !important; border-radius: 50px !important;
  box-shadow: 0 4px 18px rgba(0,201,167,.25);
}
.nav-cta-pill::after { display: none !important; }
.nav-cta-pill:hover { opacity: .88; transform: translateY(-1px); }

.hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; padding: 4px; cursor: pointer;
}
.hamburger span { display: block; width: 24px; height: 2px; background: var(--txt-hi); border-radius: 2px; transition: var(--transition); }

/* ══ HERO ══ */
.hero-section {
  position: relative; min-height: 100vh;
  display: flex; align-items: center;
  overflow: hidden; background: var(--bg-void);
}
.hero-section::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 10% 20%,  rgba(0,201,167,.18) 0%, transparent 55%),
    radial-gradient(ellipse 55% 70% at 85% 10%,  rgba(29,111,255,.16) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 90% 80%,  rgba(201,255,58,.1)  0%, transparent 50%),
    radial-gradient(ellipse 45% 55% at 20% 90%,  rgba(255,155,58,.08) 0%, transparent 50%);
  pointer-events: none;
  animation: meshPulse 14s ease-in-out infinite alternate;
}
@keyframes meshPulse {
  0%   { opacity:1;   transform:scale(1); }
  50%  { opacity:.75; transform:scale(1.04) rotate(2deg); }
  100% { opacity:1;   transform:scale(1.02) rotate(-1deg); }
}
.hero-blob {
  position: absolute; border-radius: 50%;
  filter: blur(80px); pointer-events: none;
}
.hero-blob-1 {
  width:480px; height:480px;
  background: radial-gradient(circle, rgba(0,201,167,.22) 0%, transparent 70%);
  top:-120px; left:-80px; animation: blobFloat1 18s ease-in-out infinite;
}
.hero-blob-2 {
  width:560px; height:560px;
  background: radial-gradient(circle, rgba(29,111,255,.18) 0%, transparent 70%);
  bottom:-160px; right:-100px; animation: blobFloat2 22s ease-in-out infinite;
}
.hero-blob-3 {
  width:300px; height:300px;
  background: radial-gradient(circle, rgba(201,255,58,.14) 0%, transparent 70%);
  top:40%; left:55%; animation: blobFloat3 16s ease-in-out infinite;
}
@keyframes blobFloat1 {
  0%,100% { transform:translate(0,0) scale(1); }
  33%     { transform:translate(60px,40px) scale(1.1); }
  66%     { transform:translate(-30px,80px) scale(.95); }
}
@keyframes blobFloat2 {
  0%,100% { transform:translate(0,0) scale(1); }
  40%     { transform:translate(-80px,-60px) scale(1.08); }
  70%     { transform:translate(40px,-40px) scale(.92); }
}
@keyframes blobFloat3 {
  0%,100% { transform:translate(0,0) scale(1); }
  50%     { transform:translate(-50px,60px) scale(1.15); }
}
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 72px 72px; pointer-events: none;
}
.hero-content {
  position: relative; z-index: 2;
  padding: 120px 48px 60px;
  max-width: 1320px; margin: 0 auto; width: 100%;
}
.hero-eyebrow { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.hero-eyebrow-dot {
  width:8px; height:8px; border-radius:50%;
  background: var(--grad-main); box-shadow: 0 0 14px var(--g-teal);
  animation: dotPulse 2.5s ease-in-out infinite;
}
@keyframes dotPulse {
  0%,100% { box-shadow: 0 0 8px var(--g-teal); }
  50%     { box-shadow: 0 0 22px var(--g-teal), 0 0 40px rgba(0,201,167,.4); }
}
.hero-eyebrow-text {
  font-family: var(--font-head); font-size:.72rem; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase; color: var(--txt-mid);
}
.hero-title { max-width:860px; margin-bottom:26px; }
.hero-title .line-hi {
  display:block;
  background: var(--grad-text);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-subtitle { font-size:1.12rem; color:var(--txt-mid); max-width:560px; margin-bottom:48px; line-height:1.8; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:80px; }
.hero-metrics {
  display:flex; gap:0;
  border-top:1px solid rgba(255,255,255,.07); padding-top:44px; flex-wrap:wrap;
}
.hero-metric { flex:1; min-width:140px; padding:0 36px 0 0; border-right:1px solid rgba(255,255,255,.07); }
.hero-metric:last-child  { border-right:none; padding-right:0; padding-left:36px; }
.hero-metric:first-child { padding-left:0; }
.metric-num {
  font-family:var(--font-head); font-size:2.8rem; font-weight:800;
  background: var(--grad-main);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1; display:block;
}
.metric-lbl {
  font-size:.75rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  color:var(--txt-low); margin-top:8px; display:block;
}

/* ══ ABOUT ══ */
.about-section { background:var(--bg-deep); position:relative; overflow:hidden; }
.about-section::before {
  content:''; position:absolute;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, rgba(0,201,167,.07) 0%, transparent 65%);
  right:-200px; top:-100px; pointer-events:none;
}
.about-img-wrap { position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.about-img-wrap img {
  width:100%; height:500px; object-fit:cover; border-radius:var(--radius-lg);
  filter:brightness(.85) saturate(.9); transition:filter .5s;
}
.about-img-wrap:hover img { filter:brightness(.95) saturate(1.05); }
.about-img-wrap::after {
  content:''; position:absolute; inset:0; border-radius:var(--radius-lg);
  background:linear-gradient(135deg, rgba(0,201,167,.15) 0%, rgba(29,111,255,.1) 100%);
  pointer-events:none;
}
.about-img-wrap::before {
  content:''; position:absolute; inset:-1px; border-radius:var(--radius-lg);
  background:var(--grad-main); z-index:-1; opacity:.4;
}
.about-stat-chip {
  position:absolute; bottom:28px; left:-20px;
  background:var(--bg-mid);
  border:1px solid rgba(255,255,255,.08); border-radius:var(--radius);
  padding:18px 24px; backdrop-filter:blur(12px);
  box-shadow:0 20px 60px rgba(0,0,0,.5); z-index:2;
}
.chip-num {
  font-family:var(--font-head); font-size:2.2rem; font-weight:800;
  background:var(--grad-lime);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1; display:block;
}
.chip-lbl {
  font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--txt-low); display:block; margin-top:5px;
}
.about-features { margin-top:32px; display:flex; flex-direction:column; gap:14px; }
.about-feat {
  display:flex; gap:16px; align-items:flex-start; padding:18px 20px;
  background:var(--bg-glass); border:1px solid rgba(255,255,255,.06); border-radius:var(--radius);
  transition:var(--transition);
}
.about-feat:hover {
  background:var(--bg-glass2); border-color:rgba(0,201,167,.25);
  transform:translateX(6px); box-shadow:0 0 30px rgba(0,201,167,.07);
}
.feat-icon {
  width:40px; height:40px; min-width:40px;
  display:flex; align-items:center; justify-content:center;
  background:var(--grad-main); border-radius:var(--radius-sm);
  font-size:1rem; color:#fff; flex-shrink:0;
}
.feat-text h5 { font-size:1rem; color:var(--txt-hi); margin-bottom:4px; }
.feat-text p  { font-size:.88rem; color:var(--txt-low); margin:0; line-height:1.5; }

/* ══ SERVICES ══ */
.services-section { background:var(--bg-void); position:relative; overflow:hidden; }
.services-section::before {
  content:''; position:absolute;
  width:700px; height:400px; bottom:-100px; left:50%; transform:translateX(-50%);
  background:radial-gradient(ellipse, rgba(29,111,255,.08) 0%, transparent 70%);
  pointer-events:none;
}
/* service cards — no images, gradient top bar per color */
.service-card {
  background:var(--bg-deep); border:1px solid rgba(255,255,255,.07); border-radius:var(--radius-lg);
  overflow:hidden; height:100%; transition:var(--transition); position:relative;
}
.service-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  opacity:.6; transition:opacity .35s, height .35s;
}
.service-card:hover {
  transform:translateY(-8px); border-color:transparent;
  box-shadow:0 30px 60px rgba(0,0,0,.4);
}
.service-card:hover::before { opacity:1; height:4px; }

.svc-color-1::before { background:linear-gradient(90deg,#00C9A7,#1D6FFF); }
.svc-color-2::before { background:linear-gradient(90deg,#1D6FFF,#C9FF3A); }
.svc-color-3::before { background:linear-gradient(90deg,#C9FF3A,#00C9A7); }
.svc-color-4::before { background:linear-gradient(90deg,#FF9B3A,#FF4E8A); }
.svc-color-5::before { background:linear-gradient(90deg,#00C9A7,#C9FF3A); }
.svc-color-6::before { background:linear-gradient(90deg,#1D6FFF,#FF9B3A); }

.svc-color-1:hover { box-shadow:0 30px 60px rgba(0,0,0,.4), 0 0 40px rgba(0,201,167,.1); }
.svc-color-2:hover { box-shadow:0 30px 60px rgba(0,0,0,.4), 0 0 40px rgba(29,111,255,.1); }
.svc-color-3:hover { box-shadow:0 30px 60px rgba(0,0,0,.4), 0 0 40px rgba(201,255,58,.08); }
.svc-color-4:hover { box-shadow:0 30px 60px rgba(0,0,0,.4), 0 0 40px rgba(255,155,58,.1); }
.svc-color-5:hover { box-shadow:0 30px 60px rgba(0,0,0,.4), 0 0 40px rgba(0,201,167,.1); }
.svc-color-6:hover { box-shadow:0 30px 60px rgba(0,0,0,.4), 0 0 40px rgba(29,111,255,.1); }

.svc-body { padding:30px 28px 32px; position:relative; z-index:1; }
.svc-icon {
  width:52px; height:52px;
  background:var(--bg-mid); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center; font-size:1.3rem;
  margin-bottom:20px; transition:var(--transition);
}
.svc-icon i {
  background:var(--grad-main);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.service-card:hover .svc-icon { background:var(--grad-main); border-color:transparent; }
.service-card:hover .svc-icon i { -webkit-text-fill-color:#fff; }
.svc-body h3 { font-size:1.25rem; margin-bottom:12px; }
.svc-body p  { font-size:.9rem; color:var(--txt-mid); line-height:1.7; }
.svc-tags { margin-top:18px; display:flex; flex-wrap:wrap; gap:7px; }
.svc-tag {
  font-size:.68rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(0,201,167,.07); color:var(--g-teal); padding:5px 12px;
  border-radius:20px; border:1px solid rgba(0,201,167,.15);
}

/* ══ METHODOLOGY ══ */
.method-section {
  position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 0% 50%,   rgba(0,201,167,.1)  0%, transparent 50%),
    radial-gradient(ellipse 60% 80% at 100% 50%,  rgba(29,111,255,.1) 0%, transparent 50%),
    var(--bg-mid);
}
.method-section::after {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:var(--grad-main); opacity:.4;
}
.method-step-card {
  display:flex; flex-direction:column; gap:12px; padding:28px 28px 30px;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius); height:100%; transition:var(--transition); position:relative; overflow:hidden;
}
.method-step-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad-main); opacity:0; transition:opacity .35s;
}
.method-step-card:hover {
  background:rgba(255,255,255,.055); border-color:rgba(0,201,167,.2);
  box-shadow:0 8px 40px rgba(0,0,0,.3), 0 0 30px rgba(0,201,167,.05);
}
.method-step-card:hover::before { opacity:1; }
.step-number {
  font-family:var(--font-head); font-size:3.5rem; font-weight:800;
  background:var(--grad-main);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  opacity:.25; line-height:1; transition:opacity .35s;
}
.method-step-card:hover .step-number { opacity:.5; }
.step-title { font-size:1.1rem; color:var(--txt-hi); font-family:var(--font-head); }
.step-desc  { font-size:.9rem; color:var(--txt-mid); line-height:1.7; }
.method-img-col img {
  width:100%; height:100%; min-height:420px; object-fit:cover;
  border-radius:var(--radius-lg); filter:brightness(.75) saturate(.85);
}
.method-img-col { position:relative; }
.method-img-col::after {
  content:''; position:absolute; inset:-1px; border-radius:var(--radius-lg);
  background:var(--grad-main); z-index:-1; opacity:.35; filter:blur(1px);
}

/* ══ STATS ══ */
.stats-section {
  position:relative; padding:80px 0; overflow:hidden; background:var(--bg-deep);
}
.stats-section::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg,
    rgba(0,201,167,.06) 0%, rgba(29,111,255,.08) 25%,
    rgba(201,255,58,.05) 50%, rgba(255,155,58,.06) 75%,
    rgba(0,201,167,.06) 100%);
  pointer-events:none;
}
.stats-section::after {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--g-teal), var(--g-blue), transparent);
  opacity:.4;
}
.stat-block { text-align:center; }
.s-num {
  font-family:var(--font-head); font-size:3.6rem; font-weight:800;
  background:var(--grad-text);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1; display:block;
}
.s-label {
  font-size:.72rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--txt-low); display:block; margin-top:10px;
}
.stat-sep {
  width:1px; height:60px;
  background:linear-gradient(to bottom, transparent, rgba(255,255,255,.1), transparent);
  align-self:center;
}

/* ══ INDUSTRIES — CSS-only tiles ══ */
.industries-section { background:var(--bg-void); position:relative; overflow:hidden; }
.industries-section::before {
  content:''; position:absolute;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle, rgba(201,255,58,.06) 0%, transparent 65%);
  top:-100px; right:-100px; pointer-events:none;
}
.industry-tile-css {
  padding:26px 22px 28px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius);
  background:var(--bg-deep);
  transition:var(--transition);
  height:100%;
  position:relative;
  overflow:hidden;
}
.industry-tile-css::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  transform:scaleX(0); transform-origin:left; transition:transform .4s;
}
.industry-tile-css:hover { transform:translateY(-5px); border-color:rgba(0,201,167,.2); }
.industry-tile-css:hover::after { transform:scaleX(1); }

/* individual bottom-line gradient per tile */
.ind-c1::after { background:linear-gradient(90deg,#00C9A7,#1D6FFF); }
.ind-c2::after { background:linear-gradient(90deg,#1D6FFF,#C9FF3A); }
.ind-c3::after { background:linear-gradient(90deg,#C9FF3A,#00C9A7); }
.ind-c4::after { background:linear-gradient(90deg,#FF9B3A,#FF4E8A); }
.ind-c5::after { background:linear-gradient(90deg,#00C9A7,#C9FF3A); }
.ind-c6::after { background:linear-gradient(90deg,#FF9B3A,#1D6FFF); }
.ind-c7::after { background:linear-gradient(90deg,#C9FF3A,#00C9A7); }
.ind-c8::after { background:linear-gradient(90deg,#1D6FFF,#00C9A7); }

.ind-tile-icon {
  width:48px; height:48px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,201,167,.08);
  border:1px solid rgba(0,201,167,.15);
  border-radius:var(--radius-sm);
  font-size:1.15rem; margin-bottom:16px;
  transition:var(--transition);
}
.ind-tile-icon i {
  background:var(--grad-main);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.industry-tile-css:hover .ind-tile-icon {
  background:var(--grad-main); border-color:transparent;
}
.industry-tile-css:hover .ind-tile-icon i { -webkit-text-fill-color:#fff; }
.industry-tile-css h4 { font-size:1rem; color:var(--txt-hi); margin-bottom:8px; font-family:var(--font-head); }
.industry-tile-css p  { font-size:.85rem; color:var(--txt-mid); margin:0; line-height:1.6; }

/* ══ TEAM — avatar cards ══ */
.team-section { background:var(--bg-deep); position:relative; overflow:hidden; }
.team-section::before {
  content:''; position:absolute; width:600px; height:400px;
  background:radial-gradient(ellipse, rgba(29,111,255,.08) 0%, transparent 70%);
  bottom:-50px; left:50%; transform:translateX(-50%); pointer-events:none;
}
.team-card {
  background:var(--bg-mid); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-lg); overflow:hidden; transition:var(--transition);
}
.team-card:hover {
  transform:translateY(-6px); border-color:rgba(0,201,167,.25);
  box-shadow:var(--glow), 0 20px 50px rgba(0,0,0,.4);
}
/* avatar without photo */
.team-avatar-wrap {
  position:relative; height:180px;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.av-1 { background:linear-gradient(135deg,rgba(0,201,167,.18) 0%,rgba(29,111,255,.12) 100%); }
.av-2 { background:linear-gradient(135deg,rgba(29,111,255,.18) 0%,rgba(201,255,58,.12) 100%); }
.av-3 { background:linear-gradient(135deg,rgba(255,155,58,.14) 0%,rgba(255,78,138,.12) 100%); }
.team-avatar-initials {
  font-family:var(--font-head); font-size:3rem; font-weight:800;
  background:var(--grad-main);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  position:relative; z-index:1; line-height:1;
}
.team-avatar-glow {
  position:absolute; width:120px; height:120px; border-radius:50%;
  background:radial-gradient(circle, rgba(0,201,167,.18) 0%, transparent 65%);
  top:50%; left:50%; transform:translate(-50%,-50%);
}
.team-info { padding:22px 24px 28px; }
.team-info h4 { font-size:1.2rem; margin-bottom:4px; }
.team-role {
  font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  background:var(--grad-main);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  display:block; margin-bottom:12px;
}
.team-info p { font-size:.88rem; color:var(--txt-mid); line-height:1.6; }
.team-socials { margin-top:16px; display:flex; gap:8px; }
.t-soc {
  width:34px; height:34px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-sm); color:var(--txt-mid); font-size:.85rem; transition:var(--transition);
}
.t-soc:hover { background:var(--grad-main); border-color:transparent; color:#fff; box-shadow:0 4px 16px rgba(0,201,167,.3); }

/* ══ WORKSHOPS ══ */
.workshops-section { background:var(--bg-void); position:relative; overflow:hidden; }
.workshops-section::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 55% 70% at 100% 50%, rgba(201,255,58,.05) 0%, transparent 55%),
    radial-gradient(ellipse 45% 55% at 0% 50%,   rgba(0,201,167,.06) 0%, transparent 50%);
  pointer-events:none;
}
.ws-card {
  display:flex; gap:20px; align-items:flex-start; padding:26px 28px;
  background:var(--bg-glass); border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius); transition:var(--transition);
}
.ws-card:hover {
  background:var(--bg-glass2); border-color:rgba(0,201,167,.2);
  box-shadow:0 0 40px rgba(0,201,167,.06);
}
.ws-icon {
  width:54px; height:54px; min-width:54px; background:var(--grad-main);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; color:#fff; box-shadow:0 4px 20px rgba(0,201,167,.25); transition:var(--transition);
}
.ws-card:hover .ws-icon { box-shadow:0 4px 30px rgba(0,201,167,.5); transform:scale(1.05); }
.ws-body h4 { font-size:1.1rem; color:var(--txt-hi); margin-bottom:8px; }
.ws-body p  { font-size:.9rem; color:var(--txt-mid); line-height:1.6; margin:0; }
.ws-pills { margin-top:12px; display:flex; flex-wrap:wrap; gap:7px; }
.ws-pill {
  font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(201,255,58,.07); color:var(--g-lime); padding:4px 12px;
  border-radius:20px; border:1px solid rgba(201,255,58,.15);
}
.workshops-img-wrap { position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.workshops-img { width:100%; height:100%; min-height:440px; object-fit:cover; border-radius:var(--radius-lg); filter:brightness(.7) saturate(.85); }
.workshops-img-wrap::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(0,201,167,.1) 0%, rgba(201,255,58,.08) 100%);
  pointer-events:none;
}
.workshops-img-wrap::before {
  content:''; position:absolute; inset:-1px; border-radius:var(--radius-lg);
  background:var(--grad-main); z-index:-1; opacity:.3;
}

/* ══ CTA SECTION ══ */
.cta-section {
  position:relative; overflow:hidden; padding:100px 0;
}
.cta-section::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 80% at 0% 50%,   rgba(0,201,167,.14) 0%, transparent 55%),
    radial-gradient(ellipse 60% 70% at 100% 50%,  rgba(29,111,255,.12) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 50% 100%,  rgba(201,255,58,.07) 0%, transparent 50%),
    var(--bg-mid);
  pointer-events:none;
}
.cta-section::after {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--g-teal), var(--g-blue), transparent);
  opacity:.5;
}
.cta-form-wrap {
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg); padding:40px;
  backdrop-filter:blur(10px); position:relative; z-index:1;
}
.cta-form-wrap::before {
  content:''; position:absolute; inset:-1px; border-radius:var(--radius-lg);
  background:var(--grad-main); z-index:-1; opacity:.15; filter:blur(1px);
}
.cta-form label {
  font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--txt-mid); margin-bottom:7px; display:block;
}
.cta-form .form-control, .cta-form .form-select {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-sm); color:var(--txt-hi);
  padding:13px 16px; font-family:var(--font-body); font-size:.95rem; transition:var(--transition);
}
.cta-form .form-control::placeholder { color:var(--txt-low); }
.cta-form .form-control:focus, .cta-form .form-select:focus {
  outline:none; border-color:var(--g-teal);
  box-shadow:0 0 0 3px rgba(0,201,167,.12);
  background:rgba(255,255,255,.08); color:var(--txt-hi);
}
.cta-form .form-select option { background:var(--bg-mid); color:var(--txt-hi); }
.cta-form textarea.form-control { min-height:120px; resize:vertical; }
.cta-form .form-check-label { font-size:.85rem; color:var(--txt-mid); text-transform:none !important; letter-spacing:0 !important; font-weight:400; }

/* ══ CONTACT PAGE ══ */
.contact-hero {
  padding:160px 0 80px; background:var(--bg-void);
  position:relative; overflow:hidden;
}
.contact-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 20% 50%, rgba(0,201,167,.1) 0%, transparent 55%),
    radial-gradient(ellipse 50% 60% at 80% 50%, rgba(29,111,255,.1) 0%, transparent 55%);
  pointer-events:none;
}
.c-card {
  background:var(--bg-deep); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-lg); padding:38px 36px; height:100%;
}
.c-info-item {
  display:flex; gap:16px; align-items:flex-start;
  padding:18px 0; border-bottom:1px solid rgba(255,255,255,.06);
}
.c-info-item:last-child { border-bottom:none; }
.c-icon {
  width:44px; height:44px; min-width:44px; background:var(--grad-main);
  border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center;
  font-size:1rem; color:#fff; box-shadow:0 4px 16px rgba(0,201,167,.2);
}
.c-body strong {
  font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--g-teal); display:block; margin-bottom:4px;
}
.c-body p  { font-size:.92rem; color:var(--txt-mid); margin:0; }
.c-body a  { color:var(--txt-hi); transition:color .2s; }
.c-body a:hover { color:var(--g-teal); }
.contact-form-wrap label {
  font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--txt-mid); margin-bottom:7px; display:block;
}
.contact-form-wrap .form-control, .contact-form-wrap .form-select {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius-sm); color:var(--txt-hi);
  padding:13px 16px; font-family:var(--font-body); font-size:.95rem; transition:var(--transition);
}
.contact-form-wrap .form-control::placeholder { color:var(--txt-low); }
.contact-form-wrap .form-control:focus, .contact-form-wrap .form-select:focus {
  outline:none; border-color:var(--g-teal);
  box-shadow:0 0 0 3px rgba(0,201,167,.12);
  background:rgba(255,255,255,.07); color:var(--txt-hi);
}
.contact-form-wrap .form-select option { background:var(--bg-mid); }
.contact-form-wrap textarea.form-control { min-height:130px; resize:vertical; }
.contact-form-wrap .form-check-label { font-size:.88rem; color:var(--txt-mid); text-transform:none !important; letter-spacing:0 !important; font-weight:400; }

/* ══ POLICY ══ */
.policy-hero {
  padding:160px 0 70px; background:var(--bg-void);
  position:relative; overflow:hidden;
}
.policy-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 50% 70% at 10% 50%, rgba(0,201,167,.09) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 90% 50%, rgba(29,111,255,.08) 0%, transparent 55%);
  pointer-events:none;
}
.policy-hero::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--g-teal), var(--g-blue), transparent);
  opacity:.3;
}
.policy-body { max-width:820px; margin:0 auto; padding:70px 20px 100px; }
.policy-body h2 {
  font-size:1.5rem; color:var(--txt-hi); margin:44px 0 14px;
  padding-bottom:12px; border-bottom:1px solid rgba(255,255,255,.07);
}
.policy-body h3 { font-size:1.15rem; color:var(--g-teal); margin:28px 0 10px; }
.policy-body p  { font-size:.97rem; color:var(--txt-mid); margin-bottom:16px; line-height:1.8; }
.policy-body ul { padding-left:22px; margin-bottom:16px; }
.policy-body li { font-size:.97rem; color:var(--txt-mid); line-height:1.8; margin-bottom:8px; }
.policy-body a  { color:var(--g-teal); }
.policy-body a:hover { color:var(--g-lime); }
.policy-date {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  background:rgba(0,201,167,.07); color:var(--g-teal);
  padding:7px 18px; border-radius:40px; border:1px solid rgba(0,201,167,.18); margin-bottom:44px;
}

/* ══ PAGE HEADER ══ */
.page-header { padding:155px 0 70px; background:var(--bg-void); position:relative; overflow:hidden; }
.page-header::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 55% 70% at 15% 50%, rgba(0,201,167,.1) 0%, transparent 55%),
    radial-gradient(ellipse 45% 60% at 85% 50%, rgba(29,111,255,.1) 0%, transparent 55%);
  pointer-events:none;
}
.page-header::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--g-teal), var(--g-blue), transparent);
  opacity:.35;
}
.breadcrumb { background:none; padding:0; margin-bottom:14px; }
.breadcrumb-item a { color:var(--txt-low); font-size:.8rem; transition:color .2s; }
.breadcrumb-item a:hover { color:var(--g-teal); }
.breadcrumb-item.active { color:var(--g-lime); font-size:.8rem; }
.breadcrumb-item + .breadcrumb-item::before { color:var(--txt-low); }

/* ══ FOOTER ══ */
.site-footer { background:var(--bg-deep); padding:70px 0 0; position:relative; overflow:hidden; }
.site-footer::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--g-teal), var(--g-blue), transparent);
  opacity:.3;
}
.footer-brand p { font-size:.9rem; color:var(--txt-low); line-height:1.7; margin:14px 0 18px; }
.footer-heading {
  font-family:var(--font-head); font-size:.68rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase; color:var(--g-teal); margin-bottom:18px;
}
.footer-links { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-links a { font-size:.9rem; color:var(--txt-low); transition:color .25s; }
.footer-links a:hover { color:var(--g-teal); }
.footer-socials { display:flex; gap:8px; margin-top:4px; }
.f-soc {
  width:34px; height:34px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-sm); color:var(--txt-mid); font-size:.85rem; transition:var(--transition);
}
.f-soc:hover { background:var(--grad-main); border-color:transparent; color:#fff; }
.footer-bottom {
  margin-top:56px; padding:22px 0; border-top:1px solid rgba(255,255,255,.06);
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;
}
.footer-bottom p { font-size:.8rem; color:var(--txt-low); margin:0; }
.footer-bottom-links { display:flex; gap:22px; }
.footer-bottom-links a { font-size:.8rem; color:var(--txt-low); transition:color .25s; }
.footer-bottom-links a:hover { color:var(--g-teal); }

/* ══ COOKIE BANNER ══ */
#cookie-banner {
  position:fixed; bottom:24px; left:24px; max-width:420px;
  background:var(--bg-mid); border:1px solid rgba(0,201,167,.25);
  border-radius:var(--radius); padding:24px 26px;
  box-shadow:var(--glow), 0 20px 60px rgba(0,0,0,.5); z-index:9999; display:none;
}
#cookie-banner.show { display:block; animation:slideUpCookie .4s ease; }
@keyframes slideUpCookie {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
#cookie-banner h5 { color:var(--txt-hi); font-size:1rem; margin-bottom:10px; }
#cookie-banner p  { font-size:.85rem; color:var(--txt-mid); margin-bottom:18px; line-height:1.6; }
#cookie-banner a  { color:var(--g-teal); }
.cookie-actions { display:flex; gap:10px; }
.cookie-accept {
  flex:1; background:var(--grad-main); color:#fff; border:none;
  padding:10px; border-radius:var(--radius-sm);
  font-family:var(--font-head); font-weight:700; font-size:.82rem; cursor:pointer;
  transition:var(--transition); box-shadow:0 4px 16px rgba(0,201,167,.25);
}
.cookie-accept:hover { opacity:.88; }
.cookie-decline {
  flex:1; background:transparent; color:var(--txt-mid);
  border:1px solid rgba(255,255,255,.1); padding:10px;
  border-radius:var(--radius-sm); font-family:var(--font-head); font-size:.82rem;
  cursor:pointer; transition:var(--transition);
}
.cookie-decline:hover { border-color:rgba(255,255,255,.3); color:var(--txt-hi); }

/* ══ SUCCESS MODAL ══ */
#success-modal .modal-content {
  background:var(--bg-mid); border:1px solid rgba(0,201,167,.25);
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--glow);
}
.success-inner { padding:52px 40px; text-align:center; }
.success-icon {
  width:80px; height:80px; background:var(--grad-main); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 24px; font-size:2rem; color:#fff;
  box-shadow:0 0 40px rgba(0,201,167,.4);
  animation:iconPop .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes iconPop {
  from { transform:scale(0); opacity:0; }
  to   { transform:scale(1); opacity:1; }
}
.success-inner h3 { color:var(--txt-hi); margin-bottom:12px; }
.success-inner p  { color:var(--txt-mid); font-size:.95rem; margin-bottom:28px; }

/* ══ SCROLL REVEAL ══ */
.fade-up { opacity:0; transform:translateY(30px); transition:opacity .7s ease, transform .7s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.delay-1 { transition-delay:.12s; }
.delay-2 { transition-delay:.24s; }
.delay-3 { transition-delay:.36s; }
.delay-4 { transition-delay:.48s; }

/* ══ RESPONSIVE ══ */
@media (max-width:991px) {
  .nav-links {
    display:none; flex-direction:column; position:absolute;
    top:100%; left:0; right:0;
    background:rgba(7,9,12,.96); backdrop-filter:blur(20px);
    padding:24px 40px; gap:18px; border-top:1px solid rgba(255,255,255,.07);
  }
  .nav-links.open { display:flex; }
  .hamburger { display:flex; }
  .navbar-inner { padding:16px 24px; }
  .hero-content { padding:120px 24px 50px; }
  .about-stat-chip { left:8px; }
  .stat-sep { display:none; }
  .cta-form-wrap { padding:28px 24px; }
}
@media (max-width:767px) {
  .hero-metrics { flex-wrap:wrap; }
  .hero-metric {
    flex:0 0 50%; border-right:none !important;
    padding:16px 0 !important; border-bottom:1px solid rgba(255,255,255,.07);
  }
  .hero-metric:nth-child(3),.hero-metric:nth-child(4) { border-bottom:none; }
  .hero-actions { flex-direction:column; align-items:flex-start; }
}
@media (max-width:575px) {
  h1 { font-size:2.2rem; }
  h2 { font-size:1.7rem; }
  .section-pad { padding:64px 0; }
  #cookie-banner { left:12px; right:12px; max-width:none; bottom:12px; }
  .c-card { padding:24px 20px; }
}

/* ══ CONTACT VISUAL IMAGE ══ */
.contact-visual-img {
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  height:220px;
}
.contact-visual-img img {
  width:100%; height:100%; object-fit:cover;
  filter:brightness(.6) saturate(.8);
}
.contact-visual-img::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(0,201,167,.15) 0%, rgba(29,111,255,.1) 100%);
  pointer-events:none;
}
.contact-visual-img::before {
  content:''; position:absolute; inset:-1px; border-radius:var(--radius-lg);
  background:var(--grad-main); z-index:-1; opacity:.35;
}
