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

:root {
  --blue: #1d74f5;
  --blue-2: #4ca5ff;
  --navy: #12325a;
  --deep: #0c2547;
  --text: #45698e;
  --muted: #5f7fa3;
  --pale: #f5f9ff;
  --pale-2: #eef6ff;
  --line: #d9e8fb;
  --white: #ffffff;
  --shadow: 0 16px 38px rgba(18, 50, 90, 0.09);
  --shadow-strong: 0 24px 60px rgba(18, 50, 90, 0.14);
}

html { scroll-behavior: smooth; }
body { font-family: Arial, Helvetica, sans-serif; background: var(--pale); color: var(--navy); line-height: 1.6; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.skip-link { position: absolute; left: -999px; top: 12px; background: var(--deep); color: white; padding: 10px 14px; z-index: 999; }
.skip-link:focus { left: 12px; }

.topbar { background: #e8f2ff; border-bottom: 1px solid #d2e5ff; font-size: 13px; color: #35608f; }
.topbar-inner, .nav-inner, .container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.topbar-inner { display: flex; justify-content: space-between; gap: 20px; padding: 10px 0; flex-wrap: wrap; }

.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,0.95); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 18px 0; gap: 20px; }
.logo { display: flex; align-items: center; gap: 12px; min-width: fit-content; }
.logo-mark { width: 48px; height: 48px; background: linear-gradient(135deg, var(--blue), var(--blue-2)); border-radius: 14px; display: grid; place-items: center; font-weight: 900; font-size: 18px; color: #fff; box-shadow: 0 10px 25px rgba(29,116,245,0.22); }
.logo-title { font-weight: 900; font-size: 21px; text-transform: uppercase; line-height: 1; color: var(--navy); }
.logo-subtitle { margin-top: 5px; color: #5d7ea4; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; }

.main-nav { display: flex; gap: 22px; color: var(--text); font-size: 13px; text-transform: uppercase; font-weight: 800; letter-spacing: 0.04em; flex-wrap: wrap; }
.main-nav a:hover { color: var(--blue); }
.menu-button { display: none; width: 46px; height: 42px; border: 1px solid var(--line); background: var(--white); border-radius: 10px; align-items: center; justify-content: center; flex-direction: column; gap: 5px; cursor: pointer; }
.menu-button span { width: 20px; height: 2px; background: var(--navy); display: block; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; background: linear-gradient(135deg, var(--blue), var(--blue-2)); color: #fff; padding: 14px 22px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.04em; border-radius: 12px; border: 0; cursor: pointer; transition: 0.2s ease; box-shadow: 0 10px 24px rgba(29,116,245,0.22); }
.btn:hover { transform: translateY(-2px); box-shadow: 0 16px 34px rgba(29,116,245,0.28); }
.btn-outline { background: white; color: var(--blue); border: 1px solid #b8d6ff; box-shadow: none; }
.btn-outline:hover { background: var(--pale-2); }

.hero { position: relative; min-height: 790px; display: grid; align-items: center; overflow: hidden; border-bottom: 1px solid var(--line); background: linear-gradient(110deg, rgba(245,249,255,0.96) 0%, rgba(245,249,255,0.84) 46%, rgba(245,249,255,0.56) 100%), url('https://images.unsplash.com/photo-1473445361085-b9a07f55608b?q=80&w=2070&auto=format&fit=crop') center/cover; }
.hero::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 20% 20%, rgba(72,163,255,0.18), transparent 32%), radial-gradient(circle at 85% 15%, rgba(29,116,245,0.12), transparent 28%); pointer-events: none; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 54px; align-items: center; padding: 80px 0; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; padding: 10px 15px; border: 1px solid #b9d8ff; background: #edf6ff; color: var(--blue); font-size: 13px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.16em; margin-bottom: 24px; border-radius: 999px; }
h1 { max-width: 930px; font-size: clamp(34px, 5.2vw, 62px); line-height: 0.96; text-transform: uppercase; font-weight: 950; letter-spacing: -0.055em; color: var(--navy); }
.hero p { margin-top: 28px; max-width: 675px; color: #4e6d90; font-size: 18px; line-height: 1.7; }
.hero-actions { margin-top: 38px; display: flex; gap: 16px; flex-wrap: wrap; }
.hero-card { background: rgba(255,255,255,0.93); border: 1px solid var(--line); padding: 28px; border-radius: 24px; box-shadow: var(--shadow-strong); }
.hero-card img { border-radius: 18px; margin-bottom: 18px; height: 220px; width: 100%; object-fit: cover; }
.hero-card small { color: var(--blue); text-transform: uppercase; letter-spacing: 0.2em; font-weight: 900; }
.hero-card h2 { margin-top: 8px; font-size: 25px; line-height: 1.05; text-transform: uppercase; font-weight: 950; color: var(--navy); }
.hero-card p { font-size: 16px; margin-top: 18px; color: #58779b; }

.check-list { margin-top: 22px; display: grid; gap: 12px; }
.check-item { display: flex; gap: 12px; padding: 14px; background: #f4f9ff; border: 1px solid var(--line); color: #4f6f93; font-size: 14px; border-radius: 12px; }
.check { color: var(--blue); font-weight: 900; }

.stat-strip { background: white; border-bottom: 1px solid var(--line); padding: 26px 0; }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.stat { background: #f7fbff; border: 1px solid #dbeafb; border-radius: 18px; padding: 26px; }
.stat strong { color: var(--blue); font-size: 28px; font-weight: 950; text-transform: uppercase; display: block; }
.stat span { display: block; margin-top: 6px; color: var(--muted); text-transform: uppercase; font-size: 13px; letter-spacing: 0.05em; }

.section { padding: 96px 0; }
.section-header { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: 50px; align-items: end; margin-bottom: 50px; }
.section-label { color: var(--blue); text-transform: uppercase; letter-spacing: 0.22em; font-size: 13px; font-weight: 900; margin-bottom: 12px; }
.section-title { font-size: clamp(28px, 4vw, 42px); line-height: 1; text-transform: uppercase; font-weight: 950; letter-spacing: -0.04em; color: var(--navy); }
.section-intro { color: #58779b; font-size: 18px; line-height: 1.75; }

.welcome-section { background: linear-gradient(180deg, #ffffff 0%, #f6fbff 100%); }
.welcome-grid { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 52px; align-items: center; }
.welcome-image { position: relative; }
.welcome-image::before { content: ""; position: absolute; inset: 28px -18px -18px 28px; background: linear-gradient(135deg, rgba(29,116,245,0.16), rgba(76,165,255,0.12)); border-radius: 28px; }
.welcome-image img { position: relative; z-index: 1; height: 560px; width: 100%; object-fit: cover; border-radius: 28px; box-shadow: var(--shadow-strong); border: 1px solid var(--line); }
.welcome-points { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 30px 0; }
.welcome-points div { background: white; border: 1px solid var(--line); border-radius: 18px; padding: 20px; box-shadow: 0 10px 24px rgba(18,50,90,0.04); }
.welcome-points span { color: var(--blue); font-weight: 950; letter-spacing: 0.15em; font-size: 13px; }
.welcome-points h3 { margin: 8px 0; color: var(--navy); text-transform: uppercase; font-size: 17px; line-height: 1.1; }
.welcome-points p { color: #58779b; font-size: 14px; }

.profile-section { background: linear-gradient(135deg, rgba(29,116,245,0.08), transparent 40%), #ffffff; border-top: 1px solid var(--line); }
.profile-hero { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 48px; align-items: end; margin-bottom: 34px; }
.profile-grid { display: grid; grid-template-columns: 1.2fr 0.9fr 0.9fr; gap: 20px; }
.profile-card { background: #f8fbff; border: 1px solid var(--line); border-radius: 24px; padding: 28px; box-shadow: 0 10px 28px rgba(18,50,90,0.04); }
.profile-card.large { grid-row: span 2; background: linear-gradient(135deg, #f2f8ff, #ffffff); }
.profile-icon { width: 54px; height: 54px; display: grid; place-items: center; border-radius: 16px; background: linear-gradient(135deg, var(--blue), var(--blue-2)); color: white; font-weight: 900; margin-bottom: 22px; }
.profile-card h3 { text-transform: uppercase; color: var(--navy); font-size: 18px; line-height: 1.05; margin-bottom: 12px; font-weight: 950; }
.profile-card p { color: #58779b; }
.values-strip { margin-top: 24px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.values-strip div { background: var(--navy); color: white; border-radius: 22px; padding: 26px; }
.values-strip span { color: #8fc7ff; font-weight: 950; letter-spacing: 0.16em; }
.values-strip h3 { margin: 10px 0; text-transform: uppercase; font-size: 18px; }
.values-strip p { color: rgba(255,255,255,0.72); font-size: 14px; }

.products-section { background: radial-gradient(circle at top right, rgba(29,116,245,0.08), transparent 30%), var(--white); border-top: 1px solid var(--line); }
.product-feature { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 32px; align-items: center; background: linear-gradient(135deg, #f2f8ff, #ffffff); border: 1px solid var(--line); border-radius: 28px; padding: 24px; margin-bottom: 30px; box-shadow: var(--shadow); }
.product-feature-image img { height: 370px; width: 100%; object-fit: cover; border-radius: 22px; }
.product-feature-copy { padding: 20px; }
.product-feature-copy h3 { font-size: clamp(26px, 3.4vw, 36px); line-height: 1; text-transform: uppercase; font-weight: 950; letter-spacing: -0.04em; color: var(--navy); }
.product-feature-copy p { margin: 18px 0 26px; color: #58779b; font-size: 18px; line-height: 1.75; }

.product-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.product-card { background: white; border: 1px solid var(--line); border-radius: 24px; overflow: hidden; box-shadow: 0 10px 30px rgba(18,50,90,0.05); transition: 0.2s ease; }
.product-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: #9ecaff; }
.product-card img { width: 100%; height: 190px; object-fit: cover; }
.product-body { padding: 24px; }
.product-body span { color: var(--blue); font-size: 13px; font-weight: 950; letter-spacing: 0.2em; }
.product-body h3 { margin: 10px 0 12px; color: var(--navy); font-size: 18px; line-height: 1.05; text-transform: uppercase; font-weight: 950; }
.product-body p { color: #58779b; font-size: 15px; }
.product-body ul { list-style: none; margin-top: 18px; display: grid; gap: 9px; }
.product-body li { color: #517398; font-size: 14px; padding-left: 22px; position: relative; }
.product-body li::before { content: "✓"; position: absolute; left: 0; color: var(--blue); font-weight: 900; }

.services-section { background: var(--pale); }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.service-card { background: white; border: 1px solid var(--line); padding: 22px; transition: 0.2s ease; min-height: 430px; border-radius: 22px; box-shadow: 0 10px 30px rgba(18,50,90,0.05); }
.service-card:hover { border-color: #9ecaff; transform: translateY(-4px); box-shadow: 0 16px 40px rgba(18,50,90,0.10); }
.service-card img { width: 100%; height: 185px; object-fit: cover; border-radius: 16px; margin-bottom: 18px; }
.service-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.icon-box { width: 56px; height: 56px; background: linear-gradient(135deg, var(--blue), var(--blue-2)); border-radius: 14px; display: grid; place-items: center; font-size: 21px; color: white; }
.number { font-size: 48px; color: #d7e7fb; font-weight: 950; }
.service-card h3 { font-size: 21px; text-transform: uppercase; line-height: 1.05; font-weight: 950; margin-bottom: 14px; color: var(--navy); }
.service-card p { color: #58779b; min-height: 118px; }
.learn { display: inline-flex; margin-top: 20px; color: var(--blue); font-size: 13px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.06em; }

.capabilities { background: linear-gradient(180deg, var(--pale-2) 0%, #f9fcff 100%); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.cap-grid { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 56px; align-items: center; }
.cap-image { min-height: 500px; background: linear-gradient(rgba(255,255,255,0.12), rgba(17,54,98,0.15)), url('https://images.unsplash.com/photo-1516937941344-00b4e0337589?q=80&w=2070&auto=format&fit=crop') center/cover; border: 1px solid var(--line); border-radius: 22px; display: flex; align-items: flex-end; padding: 34px; box-shadow: 0 20px 50px rgba(18,50,90,0.08); }
.cap-image-box { background: rgba(255,255,255,0.88); padding: 18px 20px; border-radius: 16px; max-width: 480px; }
.cap-image h3 { font-size: 25px; line-height: 1.08; text-transform: uppercase; font-weight: 950; color: var(--navy); }
.cap-list { margin-top: 34px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.cap-item { display: flex; gap: 12px; padding: 16px; background: white; border: 1px solid var(--line); color: #56779b; font-size: 14px; border-radius: 14px; }

.project-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.project-card { background: white; border: 1px solid var(--line); padding: 26px; min-height: 190px; transition: 0.2s ease; border-radius: 18px; box-shadow: 0 10px 28px rgba(18,50,90,0.04); }
.project-card:hover { background: #f8fbff; transform: translateY(-2px); }
.blue-line { width: 52px; height: 4px; background: var(--blue); border-radius: 999px; margin-bottom: 24px; }
.project-card h3 { font-size: 18px; line-height: 1.1; text-transform: uppercase; font-weight: 950; margin-bottom: 12px; color: var(--navy); }
.project-card p { color: #5d7ea4; font-size: 14px; }

.cta { background: linear-gradient(135deg, var(--blue), #60b3ff); color: white; padding: 64px 0; }
.cta-inner { display: grid; grid-template-columns: 1fr auto; gap: 30px; align-items: center; }
.cta .section-label { color: rgba(255,255,255,0.8); }
.cta h2 { font-size: clamp(34px, 5vw, 50px); line-height: 1; text-transform: uppercase; font-weight: 950; letter-spacing: -0.04em; }
.btn-white { background: white; color: var(--blue); box-shadow: none; }
.btn-white:hover { background: var(--pale-2); }

.contact-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 50px; }
.contact-list { margin-top: 34px; }
.contact-card { display: flex; gap: 16px; align-items: center; padding: 18px; border: 1px solid var(--line); background: white; margin-top: 14px; color: #507095; border-radius: 14px; }
.contact-form { background: white; border: 1px solid var(--line); padding: 32px; border-radius: 22px; box-shadow: 0 12px 32px rgba(18,50,90,0.06); }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
label { display: grid; gap: 8px; color: #54759a; font-size: 13px; text-transform: uppercase; font-weight: 900; letter-spacing: 0.06em; }
input, textarea { width: 100%; background: #f7fbff; border: 1px solid #d8e8fb; color: var(--navy); padding: 14px; font-size: 16px; outline: none; font-family: inherit; border-radius: 12px; }
input:focus, textarea:focus { border-color: var(--blue); background: white; }
textarea { min-height: 150px; resize: vertical; }
.full { grid-column: 1 / -1; margin-top: 18px; }
.contact-form .btn { width: 100%; margin-top: 22px; }
.form-note { color: #6e8cac; font-size: 13px; margin-top: 12px; text-align: center; }

footer { background: white; border-top: 1px solid var(--line); padding: 30px 0; color: #6b88aa; font-size: 14px; }
.footer-inner { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.footer-links { display: flex; gap: 22px; text-transform: uppercase; font-weight: 700; font-size: 13px; flex-wrap: wrap; }
.footer-links a:hover { color: var(--blue); }

@media (max-width: 1100px) {
  .main-nav { gap: 15px; }
  .nav-cta { display: none; }
}

@media (max-width: 980px) {
  .topbar { display: none; }
  .menu-button { display: flex; }
  .main-nav { position: absolute; top: 85px; left: 20px; right: 20px; display: none; flex-direction: column; gap: 0; background: white; border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow); overflow: hidden; }
  .main-nav.is-open { display: flex; }
  .main-nav a { padding: 16px 20px; border-bottom: 1px solid var(--line); }
  .main-nav a:last-child { border-bottom: 0; }
  .hero-grid, .section-header, .welcome-grid, .profile-hero, .product-feature, .cap-grid, .contact-grid, .cta-inner { grid-template-columns: 1fr; }
  .service-grid, .stats, .project-grid, .product-grid, .cap-list, .values-strip { grid-template-columns: repeat(2, 1fr); }
  .profile-grid { grid-template-columns: 1fr 1fr; }
  .profile-card.large { grid-row: auto; grid-column: span 2; }
  .hero { min-height: auto; }
  .welcome-image img { height: 420px; }
}

@media (max-width: 640px) {
  .topbar-inner, .nav-inner, .container { width: min(100% - 28px, 1180px); }
  .logo-subtitle { display: none; }
  .hero-grid { padding: 58px 0; }
  .hero-card, .contact-form, .product-feature { padding: 20px; }
  .hero-card img, .product-feature-image img, .welcome-image img { height: 220px; }
  .service-grid, .stats, .project-grid, .product-grid, .cap-list, .form-grid, .welcome-points, .profile-grid, .values-strip { grid-template-columns: 1fr; }
  .profile-card.large { grid-column: auto; }
  .section { padding: 70px 0; }
  .footer-inner { flex-direction: column; }
}


/* Version 6 capability additions */
.capability-showcase {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 32px;
  align-items: center;
  background: linear-gradient(135deg, #f2f8ff, #ffffff);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 24px;
  box-shadow: var(--shadow);
  margin-bottom: 28px;
}

.capability-image img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  border-radius: 22px;
}

.capability-content {
  padding: 18px;
}

.capability-content h3 {
  font-size: clamp(26px, 3.4vw, 36px);
  line-height: 1.05;
  text-transform: uppercase;
  font-weight: 950;
  letter-spacing: -0.035em;
  color: var(--navy);
  margin-bottom: 16px;
}

.capability-content p {
  color: #58779b;
  font-size: 17px;
  line-height: 1.75;
  margin-bottom: 22px;
}

.capability-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.capability-list div {
  display: flex;
  gap: 10px;
  background: white;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
  color: #56779b;
  font-size: 14px;
}

.capability-list span {
  color: var(--blue);
  font-weight: 900;
  flex: none;
}

.materials-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.materials-grid article {
  background: white;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 24px;
  box-shadow: 0 10px 28px rgba(18,50,90,0.04);
}

.materials-grid h3 {
  color: var(--navy);
  font-size: 18px;
  line-height: 1.1;
  text-transform: uppercase;
  font-weight: 950;
  margin-bottom: 12px;
}

.materials-grid p {
  color: #5d7ea4;
  font-size: 14px;
}

@media (max-width: 980px) {
  .capability-showcase {
    grid-template-columns: 1fr;
  }

  .materials-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .capability-list,
  .materials-grid {
    grid-template-columns: 1fr;
  }

  .capability-image img {
    height: 240px;
  }
}


/* Version 7 typography refinement: smaller and less heavy */
h1 {
  font-size: clamp(30px, 4.8vw, 52px) !important;
  line-height: 1.08 !important;
  font-weight: 800 !important;
  letter-spacing: -0.035em !important;
}

.section-title {
  font-size: clamp(24px, 3.2vw, 34px) !important;
  line-height: 1.12 !important;
  font-weight: 800 !important;
  letter-spacing: -0.025em !important;
}

.hero-card h2,
.product-feature-copy h3,
.capability-content h3,
.cap-image h3 {
  font-size: clamp(22px, 2.7vw, 30px) !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
}

.logo-title {
  font-size: 19px !important;
  font-weight: 800 !important;
}

.logo-subtitle {
  font-size: 10px !important;
  letter-spacing: 0.13em !important;
}

.section-label,
.eyebrow,
.main-nav,
.btn,
.learn,
label {
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
}

.hero p {
  font-size: 17px !important;
  line-height: 1.7 !important;
}

.section-intro,
.product-feature-copy p,
.capability-content p {
  font-size: 16px !important;
  line-height: 1.7 !important;
}

.hero-card p,
.profile-card p,
.service-card p,
.product-body p,
.project-card p,
.materials-grid p,
.values-strip p,
.capability-list div,
.cap-item,
.check-item {
  font-size: 13.5px !important;
  line-height: 1.6 !important;
}

.stat strong {
  font-size: 24px !important;
  font-weight: 800 !important;
}

.stat span {
  font-size: 12px !important;
  letter-spacing: 0.04em !important;
}

.product-body h3,
.service-card h3,
.profile-card h3,
.project-card h3,
.materials-grid h3,
.values-strip h3 {
  font-size: 17px !important;
  line-height: 1.18 !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
}

.number {
  font-size: 34px !important;
  font-weight: 800 !important;
}

.product-body span,
.welcome-points span,
.values-strip span {
  font-size: 11px !important;
  letter-spacing: 0.1em !important;
}

.welcome-points h3 {
  font-size: 15px !important;
  font-weight: 800 !important;
}

.profile-icon,
.icon-box {
  width: 48px !important;
  height: 48px !important;
  font-size: 20px !important;
}

.section {
  padding: 78px 0 !important;
}

.section-header {
  margin-bottom: 36px !important;
}

.product-feature-copy,
.capability-content {
  padding: 10px !important;
}

@media (max-width: 640px) {
  h1 {
    font-size: 30px !important;
  }

  .section-title {
    font-size: 24px !important;
  }

  .hero-card h2,
  .product-feature-copy h3,
  .capability-content h3,
  .cap-image h3 {
    font-size: 21px !important;
  }

  .section {
    padding: 56px 0 !important;
  }
}


/* Version 7 compact CTA */
.cta {
  padding: 44px 0 !important;
}

.cta h2 {
  font-size: clamp(24px, 3vw, 34px) !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
}


/* Version 8 image refinements */
.hero-card img,
.welcome-image img,
.product-feature-image img,
.service-card img,
.product-card img,
.capability-image img,
.cap-image {
  box-shadow: 0 14px 34px rgba(18,50,90,0.10);
}

.product-card img,
.service-card img {
  object-position: center;
}

.hero-card,
.product-card,
.service-card,
.profile-card,
.materials-grid article,
.project-card,
.capability-showcase,
.product-feature {
  transition: 0.24s ease;
}

.hero-card:hover,
.product-card:hover,
.service-card:hover,
.profile-card:hover,
.materials-grid article:hover,
.project-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(18,50,90,0.10);
}

.capability-list div,
.check-item,
.cap-item {
  align-items: flex-start;
}


/* Version 9 branding update with provided StarCentro logo */
.logo {
  display: flex !important;
  align-items: center !important;
  min-width: fit-content;
}

.logo-image {
  display: block;
  height: 58px;
  width: auto;
  object-fit: contain;
}

.footer-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.footer-logo {
  display: block;
  height: 34px;
  width: auto;
  object-fit: contain;
}

/* retain compatibility if old logo classes remain in markup */
.logo-mark,
.logo-title,
.logo-subtitle {
  display: none !important;
}

@media (max-width: 640px) {
  .logo-image {
    height: 42px;
    max-width: min(76vw, 290px);
  }

  .footer-logo {
    height: 28px;
  }

  .footer-brand {
    gap: 10px;
  }
}
