:root{
  --kc-navy:#0B1220;
  --kc-ink:#0F172A;
  --kc-slate:#334155;
  --kc-muted:#64748B;
  --kc-border:rgba(15,23,42,.10);
  --kc-surface:#F6F8FB;
  --kc-primary:#1D4ED8;
  --kc-primary-2:#2563EB;
  --kc-accent:#14B8A6;
  --kc-gold:#D4AF37;
}

html,body{height:100%;}
body{color:var(--kc-ink); background:#fff;}

.kc-muted{color:var(--kc-muted) !important;}
.kc-section{padding:72px 0;}

.kc-page-hero {
  padding: 48px 0;
  border-bottom: 1px solid var(--kc-border);
}
.kc-page-hero .crumb a { color: rgba(255,255,255,.9); text-decoration: none; }
.kc-page-hero .crumb a:hover { text-decoration: underline; }
.kc-page-hero { background: linear-gradient(90deg, var(--kc-navy), var(--kc-azure)); color:#fff; }

.kc-hover { transition: transform .18s ease, box-shadow .18s ease; }
.kc-hover:hover { transform: translateY(-4px); box-shadow: 0 .8rem 2rem rgba(15,23,42,.10); }

.kc-pill{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.4rem .75rem; border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  color:#fff; font-weight:600; font-size:.85rem;
}

.kc-hero{
  position:relative;
  background: radial-gradient(1200px 600px at 15% 25%, rgba(29,78,216,.65), transparent 55%),
              radial-gradient(900px 500px at 80% 10%, rgba(20,184,166,.45), transparent 60%),
              linear-gradient(180deg, rgba(11,18,32,.92), rgba(11,18,32,.88));
  color:#fff;
  overflow:hidden;
}

.kc-hero::before{
  content:"";
  position:absolute; inset:0;
  background:url('./assets/img/hero-team.jpg') center/cover no-repeat;
  opacity:.18;
  transform:scale(1.02);
}

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

.kc-card{
  background:#fff;
  border:1px solid var(--kc-border);
  border-radius:18px;
  box-shadow:0 14px 40px rgba(2,8,23,.06);
}

.kc-hover{
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.kc-hover:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 55px rgba(2,8,23,.10);
  border-color:rgba(29,78,216,.20);
}

.kc-badge{background:rgba(29,78,216,.10); color:var(--kc-primary); border:1px solid rgba(29,78,216,.18);}

.kc-section-alt{background:var(--kc-surface); border-top:1px solid var(--kc-border); border-bottom:1px solid var(--kc-border);}

.kc-service-img{
  border-top-left-radius:18px;
  border-top-right-radius:18px;
  height:170px;
  width:100%;
  object-fit:cover;
}

.kc-icon{
  width:44px; height:44px; border-radius:14px;
  display:grid; place-items:center;
  background:rgba(29,78,216,.12);
  color:var(--kc-primary);
}

.kc-page-hero{
  padding:56px 0;
  background:linear-gradient(180deg, rgba(11,18,32,.98), rgba(11,18,32,.90));
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.kc-page-hero .crumb a{color:rgba(255,255,255,.8); text-decoration:none;}
.kc-page-hero .crumb a:hover{text-decoration:underline;}

footer{background:#0B1220; color:rgba(255,255,255,.8);}
footer a{color:rgba(255,255,255,.78); text-decoration:none;}
footer a:hover{color:#fff; text-decoration:underline;}

/* Performance helpers */
img{max-width:100%; height:auto;}

