/* KCIT — minimal & light redesign */

:root{
  --ink:#163a66;
  --ink-soft:#4d6584;
  --muted:#92a0b3;
  --line:#e3e9f1;
  --bg:#ffffff;
  --bg-alt:#eaf1fa;
  --accent:#1d4f91;
  --accent-soft:#e8eff9;
  --accent-2:#2f6fb0;
  --radius:14px;
  --maxw:1140px;
  --font:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }

section{ padding:60px 0; }

h1,h2,h3,h4{ font-weight:600; letter-spacing:-0.01em; }

h1{ font-size:clamp(34px,5vw,56px); line-height:1.1; }
h2{ font-size:clamp(26px,3vw,38px); line-height:1.2; }
h3{ font-size:19px; }

.eyebrow{
  font-size:13px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
}
.eyebrow::before{
  content:"";
  width:6px; height:6px;
  border-radius:50%;
  background:var(--accent);
}

.lead{
  font-size:18px;
  color:var(--ink-soft);
  max-width:620px;
}

/* HEADER */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 28px;
  max-width:var(--maxw); margin:0 auto;
}
.logo{ display:inline-flex; flex-direction:column; align-items:flex-start; gap:3px; }
.logo img{ height:34px; width:auto; display:block; }
.logo-name{
  font-size:10.5px; font-weight:600; letter-spacing:.01em;
  color:var(--ink-soft); white-space:nowrap;
}
.footer .logo img{ height:30px; }
.footer .logo-name{ color:#aec2dc; }

.nav-links{
  display:flex; gap:34px;
  font-size:15px; font-weight:500;
}
.nav-links a{ color:var(--ink-soft); position:relative; padding:6px 0; }
.nav-links a:hover, .nav-links a.active{ color:var(--ink); }

.nav-cta{
  display:inline-flex; align-items:center;
  background:var(--ink); color:#fff;
  padding:10px 20px; border-radius:999px;
  font-size:14px; font-weight:600;
}
.nav-cta:hover{ background:var(--accent); }

.nav-right{ display:flex; align-items:center; gap:28px; }

.burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; }
.burger span{ width:22px; height:2px; background:var(--ink); display:block; }

.mobile-menu{
  display:none; flex-direction:column;
  padding:20px 28px 28px;
  border-top:1px solid var(--line);
}
.mobile-menu a{ padding:12px 0; font-size:15px; border-bottom:1px solid var(--line); }
.mobile-menu.open{ display:flex; }

/* HERO */
.hero{
  position:relative;
  overflow:hidden;
  padding:56px 0 64px;
  background:
    radial-gradient(ellipse 900px 650px at 82% 45%, rgba(16,185,129,.10) 0%, rgba(16,185,129,0) 60%),
    radial-gradient(ellipse 1100px 800px at 78% 40%, #0c2a4a 0%, #07182f 55%, #040b17 100%);
  color:#fff;
}
.hero-canvas{
  position:absolute; inset:0;
  width:100%; height:100%;
  display:block;
}
.hero-bokeh{ position:absolute; inset:0; pointer-events:none; }
.hero-bokeh::before, .hero-bokeh::after{
  content:""; position:absolute; border-radius:50%; filter:blur(34px);
}
.hero-bokeh::before{
  width:220px; height:220px; left:-60px; bottom:-70px;
  background:radial-gradient(circle, rgba(59,130,246,.3), transparent 70%);
}
.hero-bokeh::after{
  width:160px; height:160px; right:8%; top:-40px;
  background:radial-gradient(circle, rgba(16,185,129,.25), transparent 70%);
}
.hero-inner{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center;
}
.hero .eyebrow{ color:#bcd2ee; }
.hero .eyebrow::before{ background:#bcd2ee; }
.hero h1{ margin-bottom:16px; color:#fff; }
.hero h1 em{ font-style:normal; color:#8fc1ff; }
.hero .lead{ color:#cfdcef; }
.hero-actions{ display:flex; gap:14px; margin-top:24px; flex-wrap:wrap; }

.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 24px; border-radius:999px;
  font-size:15px; font-weight:600;
  border:1px solid var(--line);
  transition:all .15s ease;
}
.btn-primary{ background:var(--ink); color:#fff; border-color:var(--ink); }
.btn-primary:hover{ background:var(--accent); border-color:var(--accent); }
.btn-secondary{ background:#fff; color:var(--ink); }
.btn-secondary:hover{ border-color:var(--ink); }

.hero .btn-primary{ background:#fff; color:var(--ink); border-color:#fff; }
.hero .btn-primary:hover{ background:#8fc1ff; border-color:#8fc1ff; color:var(--ink); }
.hero .btn-secondary{ background:transparent; color:#fff; border-color:rgba(255,255,255,.4); }
.hero .btn-secondary:hover{ border-color:#fff; }

.hero-stats{
  display:flex; gap:36px; margin-top:28px; padding-top:20px; border-top:1px solid rgba(255,255,255,.18);
}
.stat-num{ font-size:28px; font-weight:700; color:#fff; }
.stat-label{ font-size:13px; color:#9fb4cf; }

.hero-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);
  padding:36px;
  display:flex; flex-direction:column; gap:20px;
}
.hero-card .row{
  display:flex; align-items:center; gap:14px;
  background:#fff; border:1px solid var(--line);
  border-radius:10px; padding:14px 16px;
  font-size:14px; font-weight:500;
  color:var(--ink);
}
.icon-dot{
  width:34px; height:34px; border-radius:9px;
  background:var(--accent-soft); color:var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; flex-shrink:0;
}

/* SECTION HEADERS */
.section-head{ max-width:640px; margin-bottom:32px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

/* SERVICES GRID */
.grid-5{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.service-card{
  border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; background:#fff;
  transition:border-color .15s ease, transform .15s ease;
}
.service-card:hover{ border-color:var(--accent); transform:translateY(-3px); }
.service-card .icon-dot{ margin-bottom:18px; }
.service-card h3{ margin-bottom:10px; }
.service-card p{ color:var(--ink-soft); font-size:14.5px; }
.service-card a.more{ display:inline-block; margin-top:16px; font-size:13.5px; font-weight:600; color:var(--accent); }

.bg-alt{ background:var(--bg-alt); }

/* INDUSTRIES */
.pill-row{ display:flex; flex-wrap:wrap; gap:14px; }
.pill{
  border:1px solid var(--line); border-radius:999px;
  padding:10px 20px; font-size:14px; font-weight:500;
  background:#fff;
}

/* ABOUT SPLIT */
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center;
}
.checklist{ display:flex; flex-direction:column; gap:14px; margin-top:24px; }
.checklist li{ display:flex; gap:12px; align-items:flex-start; font-size:15px; color:var(--ink-soft); }
.checklist .tick{
  width:22px; height:22px; border-radius:50%;
  background:var(--accent-soft); color:var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; flex-shrink:0; margin-top:2px;
}
.media-block{
  background:var(--bg-alt); border:1px solid var(--line); border-radius:var(--radius);
  aspect-ratio:4/2.4; display:flex; align-items:center; justify-content:center;
  color:var(--muted); font-size:14px;
  overflow:hidden;
}
.media-icon{ width:46%; height:auto; max-width:160px; }

/* PARTNERS */
.partner-row{
  display:flex; flex-wrap:wrap; gap:14px; justify-content:center;
}
.partner-chip{
  border:1px solid var(--line); border-radius:10px;
  padding:16px 26px; font-size:14px; font-weight:600;
  color:var(--ink-soft); background:#fff;
}

/* CTA BAND */
.cta-band{
  background:var(--ink); color:#fff;
  border-radius:24px;
  padding:40px 44px;
  display:flex; align-items:center; justify-content:space-between; gap:30px;
  flex-wrap:wrap;
}
.cta-band h2{ color:#fff; margin-bottom:8px; }
.cta-band p{ color:#c4cdd6; }
.cta-band .btn-primary{ background:var(--accent); border-color:var(--accent); }
.cta-band .btn-primary:hover{ background:var(--accent-2); }

/* FOOTER */
.footer{ background:var(--ink); color:#fff; padding:44px 0 24px; }
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:32px;
}
.footer .logo img{ height:30px; background:#fff; border-radius:6px; padding:4px 8px; }
.footer h4{ font-size:14px; margin-bottom:18px; color:#fff; }
.footer ul li{ margin-bottom:10px; }
.footer ul a{ color:#aec2dc; font-size:14px; }
.footer ul a:hover{ color:#fff; }
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.18); padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  font-size:13px; color:#9fb4cf; flex-wrap:wrap; gap:12px;
}
.social-row{ display:flex; gap:12px; }
.social-row a{
  width:34px; height:34px; border-radius:50%; border:1px solid rgba(255,255,255,.25);
  color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:13px;
}
.social-row a:hover{ border-color:var(--accent); color:var(--accent); }

/* CONTACT PAGE */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:50px; }
.info-card{
  border:1px solid var(--line); border-radius:var(--radius); padding:24px;
  display:flex; gap:16px; align-items:flex-start; margin-bottom:16px;
}
.info-card h4{ margin-bottom:4px; }
.info-card p{ color:var(--ink-soft); font-size:14.5px; }

form{ display:flex; flex-direction:column; gap:16px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
label{ font-size:13px; font-weight:600; color:var(--ink-soft); display:block; margin-bottom:6px; }
input, textarea, select{
  width:100%; border:1px solid var(--line); border-radius:10px;
  padding:13px 14px; font-size:14.5px; font-family:var(--font); color:var(--ink);
  background:#fff;
}
input:focus, textarea:focus, select:focus{ outline:none; border-color:var(--accent); }
textarea{ resize:vertical; min-height:130px; }

/* PAGE HERO (sub pages) */
.page-hero{
  padding:44px 0 36px; background:var(--bg-alt); border-bottom:1px solid var(--line);
}
.breadcrumb{ font-size:13px; color:var(--muted); margin-bottom:14px; }
.breadcrumb a{ color:var(--accent); }

.map-block{
  margin-top:40px; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
}
.map-block iframe{ width:100%; height:320px; border:0; display:block; }

@media (max-width: 900px){
  .hero-inner, .split, .contact-grid{ grid-template-columns:1fr; }
  .grid-5{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .nav-links{ display:none; }
  .nav-cta{ display:none; }
  .burger{ display:flex; }
  .form-row{ grid-template-columns:1fr; }
}

@media (max-width: 560px){
  section{ padding:64px 0; }
  .grid-5{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .cta-band{ padding:40px 28px; }
  .hero-stats{ gap:24px; flex-wrap:wrap; }
}
