:root {
  --csm-bg: #ffffff;
  --csm-alt-bg: #fafafa;
  --csm-card: #f4f6f8;
  --csm-surface: #ffffff;
  --csm-ink: #0f172a;
  --csm-muted: #5f6786;
  --csm-primary: #2b2f6b;
  --csm-primary-2: #23265a;
  --csm-accent: #5aa6a6;
  --csm-accent-2: #a8e0c8;
  --csm-accent-soft: #eef9f3;
  --csm-eng-blue: #6f86a8;
  --csm-divider: rgba(26, 143, 158, 0.18);
  --csm-border: #ebebeb;
  --csm-radius-md: 18px;
  --csm-radius-lg: 24px;
  --csm-shadow: 0 28px 52px rgba(18, 28, 74, 0.12);
  --csm-max: 1344px;
  --csm-font-heading: "Inter", "Segoe UI", sans-serif;
  --csm-font-body: "Inter", "Segoe UI", sans-serif;
  --csm-h1-size: clamp(38px, 6vw, 72px);
  --csm-h2-size: clamp(28px, 3.6vw, 44px);
  --csm-h3-size: clamp(20px, 2.2vw, 30px);
  --csm-body-size: clamp(16px, 1.25vw, 18px);
  --csm-small-size: 14px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--csm-font-body);
  color: var(--csm-ink);
  font-size: var(--csm-body-size);
  line-height: 1.7;
  background: var(--csm-bg);
}
a { color: inherit; text-decoration: none; }

.csm-site h1,
.csm-site h2,
.csm-site h3 {
  font-family: var(--csm-font-heading);
}

.csm-site h1 {
  font-size: var(--csm-h1-size);
  letter-spacing: -0.02em;
  line-height: 1.08;
}

.csm-site h2 {
  font-size: var(--csm-h2-size);
  letter-spacing: -0.02em;
  line-height: 1.14;
}

.csm-site h3 {
  font-size: var(--csm-h3-size);
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.csm-site p,
.csm-site li,
.csm-site input,
.csm-site textarea,
.csm-site label,
.csm-site button,
.csm-site .csm-nav-link,
.csm-site .csm-btn,
.csm-site .csm-footer .csm-footer-col a,
.csm-site .csm-footer .csm-footer-col p {
  font-family: var(--csm-font-body);
}

.csm-site small,
.csm-site .csm-small,
.csm-site .csm-kicker,
.csm-site .csm-text-link,
.csm-site .csm-header .csm-nav .csm-mega .csm-mega-link-group a small {
  font-size: var(--csm-small-size);
}

.csm-site { min-height: 100vh; display: flex; flex-direction: column; }
.csm-main { flex: 1; }
.csm-shell { width: min(var(--csm-max), calc(100% - 40px)); margin: 0 auto; }

.csm-skip {
  position: absolute; left: -999px; top: 10px; z-index: 999;
  background: #fff; color: var(--csm-primary); padding: 8px 12px; border-radius: 8px;
}
.csm-skip:focus { left: 10px; }

.csm-btn {
  min-height: 46px; display: inline-flex; align-items: center; justify-content: center;
  padding: 0 20px; border-radius: 12px; border: 1px solid transparent; font-weight: 700;
  font-size: 15px; letter-spacing: 0.005em; transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.csm-btn:hover { transform: translateY(-1px); }
.csm-btn-primary {
  color: #fff;
  background: var(--csm-primary);
  box-shadow: 0 8px 18px rgba(28, 35, 58, 0.18);
}
.csm-btn-primary:hover { background: var(--csm-primary-2); }
.csm-btn-ghost { border-color: #d4d9e1; background: transparent; color: #1f243f; }
.csm-btn-ghost:hover { background: #f4f6f8; }
.csm-cta .csm-btn-ghost { border-color: rgba(255, 255, 255, 0.45); color: #f8fafc; }
.csm-cta .csm-btn-ghost:hover { background: rgba(255, 255, 255, 0.12); }

.csm-kicker {
  display: inline-flex; align-items: center; border-radius: 999px;
  background: var(--csm-accent-soft);
  border: 1px solid rgba(26, 143, 158, 0.24);
  color: #0f5f6b;
  font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  padding: 7px 11px; margin-bottom: 12px;
}

.csm-header {
  width: 100vw; position: sticky; top: 0; z-index: 210;
  border-bottom: 1px solid rgba(36, 33, 108, 0.1);
  backdrop-filter: blur(10px);
  background: rgba(255, 255, 255, 0.92);
}
.csm-header .csm-nav-inner {
  width: min(var(--csm-max), calc(100% - 40px));
  margin: 0 auto;
  min-height: 86px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 18px;
  align-items: center;
}
.csm-header .csm-brand .csm-brand-logo { height: 52px; width: auto; display: block; }

.csm-header .csm-nav {
  display: flex; align-items: center; justify-content: center; gap: 2px;
}
.csm-header .csm-nav .csm-nav-link,
.csm-header .csm-nav .csm-nav-item .csm-nav-link {
  border: 0; background: transparent; cursor: pointer;
  padding: 10px 12px; border-radius: 10px;
  font-size: 15px; font-weight: 600; color: #262c58;
  display: inline-flex; align-items: center; gap: 8px;
}
.csm-header .csm-nav .csm-nav-link:hover { background: rgba(43, 47, 107, 0.08); }

.csm-header .csm-nav .csm-nav-item-mega {
  position: relative; padding-bottom: 12px; margin-bottom: -12px;
}
.csm-header .csm-nav .csm-mega {
  position: absolute; top: calc(100% + 12px); left: 50%; transform: translateX(-50%) translateY(6px);
  border: 1px solid #d9dfeb; border-radius: 16px;
  box-shadow: 0 24px 44px rgba(18, 30, 72, 0.12);
  background: #fff; padding: 14px; opacity: 0; pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
  overflow: hidden;
}
.csm-header .csm-nav .csm-nav-item-mega.is-open .csm-mega,
.csm-header .csm-nav .csm-nav-item-mega:hover .csm-mega {
  opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0);
}
.csm-header .csm-nav .csm-nav-item-mega.is-open > .csm-nav-link,
.csm-header .csm-nav .csm-nav-item-mega:hover > .csm-nav-link {
  background: rgba(43, 47, 107, 0.1); color: var(--csm-primary-2);
}

.csm-header .csm-nav .csm-mega-services {
  width: min(1200px, 96vw);
  display: grid; grid-template-columns: 240px 1fr 280px; gap: 14px;
}
.csm-header .csm-nav .csm-mega-solutions {
  width: min(1080px, 96vw);
  display: grid; grid-template-columns: 220px 1fr 280px; gap: 14px;
}

.csm-header .csm-nav .csm-mega .csm-mega-anchors,
.csm-header .csm-nav .csm-mega .csm-mega-links,
.csm-header .csm-nav .csm-mega .csm-mega-feature {
  border: 1px solid #e1e7f1; border-radius: 14px; background: #fff; padding: 14px;
}
.csm-header .csm-nav .csm-mega .csm-mega-anchors h3,
.csm-header .csm-nav .csm-mega .csm-mega-feature h3 {
  margin: 0 0 10px; font-size: 16px; font-weight: 700; color: #20295a;
}
.csm-header .csm-nav .csm-mega .csm-mega-anchors span {
  display: block; border-radius: 10px; padding: 9px 10px;
  font-size: 14px; font-weight: 600; color: #3e4870;
  background: #f4f6f8; margin-bottom: 7px;
}
.csm-header .csm-nav .csm-mega .csm-mega-anchors span:last-child { margin-bottom: 0; }

.csm-header .csm-nav .csm-mega .csm-mega-links {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.csm-header .csm-nav .csm-mega .csm-mega-link-group h4 {
  margin: 0 0 8px; font-size: 13px; text-transform: uppercase; letter-spacing: .07em;
  color: #596285;
}
.csm-header .csm-nav .csm-mega .csm-mega-link-group a {
  display: grid; grid-template-columns: 20px 1fr; gap: 8px; align-items: start;
  border-radius: 10px; padding: 8px; transition: background .15s ease;
}
.csm-header .csm-nav .csm-mega .csm-mega-link-group a i {
  color: var(--csm-accent); font-size: 14px; margin-top: 4px;
}
.csm-header .csm-nav .csm-mega .csm-mega-link-group a:hover { background: #f4f6f8; }
.csm-header .csm-nav .csm-mega .csm-mega-link-group a strong {
  display: block; font-size: 14px; color: #1f2858; line-height: 1.35;
}
.csm-header .csm-nav .csm-mega .csm-mega-link-group a small {
  display: block; margin-top: 2px; font-size: 13px; line-height: 1.45; color: #5f6786;
}

.csm-header .csm-nav .csm-mega .csm-mega-feature {
  background: linear-gradient(165deg, #ffffff 0%, #eef9f3 100%);
}
.csm-header .csm-nav .csm-mega .csm-mega-feature p {
  margin: 0 0 12px; font-size: 14px; line-height: 1.55; color: #4b547a;
}
.csm-header .csm-nav .csm-mega .csm-mega-feature .csm-mega-feature-points {
  display: grid; gap: 6px; margin-bottom: 12px;
}
.csm-header .csm-nav .csm-mega .csm-mega-feature .csm-mega-feature-points span {
  display: flex; align-items: center; gap: 8px; font-size: 13px; color: #214e56; font-weight: 700;
  background: var(--csm-accent-2);
  border: 1px solid rgba(90, 166, 166, 0.32);
  border-radius: 999px;
  padding: 6px 10px;
}
.csm-header .csm-nav .csm-mega .csm-mega-feature .csm-mega-feature-points i {
  color: var(--csm-accent);
}

@media (max-width: 1360px) {
  .csm-header .csm-nav .csm-mega-services {
    width: min(1080px, 96vw);
    grid-template-columns: 210px 1fr 250px;
  }
  .csm-header .csm-nav .csm-mega-solutions {
    width: min(980px, 96vw);
    grid-template-columns: 190px 1fr 240px;
  }
}

.csm-header .csm-menu-toggle { display: none; }
.csm-header .csm-mobile-nav { display: none; }

.csm-interior-hero,
.csm-hero,
.csm-section,
.csm-cta { width: 100%; }

.csm-hero h1 {
  margin: 0;
}
.csm-hero p { margin: 16px 0 0; color: var(--csm-muted); font-size: var(--csm-body-size); line-height: 1.7; }

.csm-interior-hero {
  width: 100%;
  padding: clamp(30px, 5.6vw, 68px) 0 clamp(20px, 3.6vw, 42px);
  background:
    radial-gradient(720px 280px at 100% 0%, rgba(36, 33, 108, 0.05), transparent 74%),
    radial-gradient(540px 220px at 0% 100%, rgba(154, 224, 196, 0.12), transparent 70%),
    #fff;
}
.csm-interior-hero .csm-shell .csm-interior-hero-grid {
  display: grid; grid-template-columns: 1.02fr .98fr; gap: clamp(16px, 3.5vw, 34px); align-items: center;
}
.csm-interior-hero .csm-shell .csm-interior-hero-copy h1 { margin: 0; }
.csm-interior-hero .csm-shell .csm-interior-hero-copy p {
  margin: 14px 0 0; max-width: 760px; color: var(--csm-muted);
}
.csm-interior-hero .csm-shell .csm-interior-hero-meta {
  list-style: none; margin: 14px 0 0; padding: 0; display: grid; gap: 8px;
}
.csm-interior-hero .csm-shell .csm-interior-hero-meta li {
  display: flex; align-items: center; gap: 10px;
  font-size: 16px; color: #2e365f; font-weight: 600;
}
.csm-interior-hero .csm-shell .csm-interior-hero-meta li i { color: var(--csm-accent); }
.csm-interior-hero .csm-shell .csm-interior-hero-cta {
  margin-top: 16px; display: flex; flex-wrap: wrap; gap: 10px;
}
.csm-interior-hero.text-only .csm-shell .csm-interior-hero-grid {
  grid-template-columns: 1fr;
}
.csm-interior-hero .csm-shell .csm-interior-hero-media img {
  padding: 20%;
  box-sizing: border-box;
  object-fit: contain;
}

.csm-hero { padding: clamp(36px, 7vw, 78px) 0 20px; }
.csm-hero .csm-shell .csm-hero-grid {
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(20px, 4vw, 42px); align-items: center;
}
.csm-hero .csm-shell .csm-hero-cta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.csm-hero .csm-shell .csm-hero-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}
.csm-hero .csm-shell .csm-hero-stats .csm-hero-stat {
  border: 1px solid var(--csm-border);
  border-radius: 14px;
  background: #fff;
  padding: 12px 12px 11px;
  min-height: 108px;
}
.csm-hero .csm-shell .csm-hero-stats .csm-stat-value {
  display: block;
  margin: 0;
  font-size: clamp(28px, 3.2vw, 36px);
  line-height: 1;
  letter-spacing: -0.02em;
  font-weight: 800;
}
.csm-hero .csm-shell .csm-hero-stats .csm-hero-stat span {
  display: block;
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.35;
  color: #616980;
  font-weight: 600;
}
.csm-hero .csm-shell .csm-hero-stats .csm-stat-indigo .csm-stat-value { color: var(--csm-primary); }
.csm-hero .csm-shell .csm-hero-stats .csm-stat-teal .csm-stat-value { color: var(--csm-accent); }
.csm-hero .csm-shell .csm-hero-stats .csm-stat-mint .csm-stat-value { color: #2d8b74; }
.csm-hero .csm-shell .csm-hero-stats .csm-stat-engblue .csm-stat-value { color: var(--csm-eng-blue); }
.csm-hero .csm-shell .csm-hero-trust {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border: 1px solid var(--csm-border);
  border-radius: 999px;
  background: #fff;
  color: #57607b;
  font-size: 14px;
  font-weight: 600;
}
.csm-hero .csm-shell .csm-hero-trust .csm-hero-stars {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  color: #e0a824;
  font-size: 13px;
}
.csm-hero .csm-shell .csm-hero-visual {
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-lg); background: #fff;
  padding: 18px; box-shadow: var(--csm-shadow); position: relative;
}
.csm-hero .csm-shell .csm-hero-visual.csm-hero-ui-composition {
  min-height: clamp(320px, 34vw, 460px);
  overflow: hidden;
  background:
    radial-gradient(180px 140px at 8% 10%, rgba(95, 134, 217, 0.12), transparent 78%),
    radial-gradient(220px 140px at 92% 92%, rgba(154, 224, 196, 0.16), transparent 76%),
    #fff;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-main-card {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: min(88%, 430px);
  border: 1px solid var(--csm-border);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 20px 42px rgba(28, 36, 77, 0.16);
  padding: 14px;
  z-index: 2;
  animation: csm-float-main 7s ease-in-out infinite;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-main-card header,
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card header,
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-arch-card header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-main-card header strong {
  color: #1f2858;
  font-size: 15px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-main-card header span {
  font-size: 12px;
  color: #5f6786;
  background: #f4f6f8;
  border-radius: 999px;
  padding: 4px 9px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-kpis div {
  border: 1px solid var(--csm-border);
  border-radius: 12px;
  background: #f4f6f8;
  padding: 8px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-kpis div small {
  display: block;
  font-size: 11px;
  line-height: 1.3;
  color: #646d89;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-kpis div strong {
  display: block;
  margin-top: 4px;
  color: var(--csm-primary);
  font-size: 14px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-chart {
  margin-top: 10px;
  height: 122px;
  border: 1px solid var(--csm-border);
  border-radius: 12px;
  background: linear-gradient(180deg, #fafafa 0%, #ffffff 100%);
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
  align-items: end;
  padding: 10px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-chart span {
  border-radius: 8px 8px 4px 4px;
  background: linear-gradient(180deg, var(--csm-eng-blue) 0%, var(--csm-primary) 100%);
  min-height: 20px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-float {
  position: absolute;
  border: 1px solid var(--csm-border);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 14px 28px rgba(24, 32, 70, 0.14);
  padding: 10px 12px;
  z-index: 3;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card {
  top: 18px;
  left: 10px;
  width: min(52%, 210px);
  animation: csm-float-soft 6.6s ease-in-out infinite;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card header,
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-arch-card header {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 700;
  color: #2a3568;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 11px;
  color: #3f496f;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card li strong {
  color: var(--csm-accent);
  font-size: 11px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-arch-card {
  right: 10px;
  bottom: 16px;
  width: min(52%, 220px);
  animation: csm-float-soft 7.2s ease-in-out infinite reverse;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-arch-nodes {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-arch-nodes span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  border: 1px solid var(--csm-border);
  background: #f4f6f8;
  min-height: 34px;
  font-size: 11px;
  color: #334069;
  font-weight: 700;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-cloud-badges {
  position: absolute;
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  display: flex;
  gap: 7px;
  z-index: 4;
}
.csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-cloud-badges span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 6px 9px;
  border-radius: 999px;
  border: 1px solid #dde3ef;
  background: #fff;
  color: #2f3964;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
}
@keyframes csm-float-main {
  0%, 100% { transform: translate(-50%, -50%) translateY(0); }
  50% { transform: translate(-50%, -50%) translateY(-8px); }
}
@keyframes csm-float-soft {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}
.csm-hero .csm-shell .csm-hero-visual .csm-hero-main-media img {
  width: 100%; height: auto; display: block; border-radius: 12px;
}
.csm-hero .csm-shell .csm-hero-visual .csm-hero-float {
  position: absolute; border: 1px solid var(--csm-border); background: #fff;
  border-radius: 14px; padding: 8px; width: min(220px, 42%);
  box-shadow: 0 14px 24px rgba(25, 35, 91, 0.15);
}
.csm-hero .csm-shell .csm-hero-visual .csm-hero-float img {
  width: 100%; height: auto; display: block; border-radius: 10px;
}
.csm-hero .csm-shell .csm-hero-visual .csm-hero-float strong {
  display: block; margin-top: 8px; font-size: 14px; line-height: 1.4;
}
.csm-hero .csm-shell .csm-hero-visual .csm-hero-float-top { top: -14px; right: -8px; }
.csm-hero .csm-shell .csm-hero-visual .csm-hero-float-bottom { bottom: -14px; left: -8px; }

.csm-home .csm-hero h1 { font-size: clamp(40px, 5.5vw, 64px); }
.csm-home .csm-hero p,
.csm-home .csm-section p,
.csm-home .csm-section li { font-size: 16px; }
.csm-home .csm-section .csm-section-head h2,
.csm-home .csm-spotlight h2 { font-size: clamp(28px, 3.1vw, 38px); }
.csm-home .csm-spotlight h3,
.csm-home .csm-card-grid .csm-service-card h3,
.csm-home .csm-card-grid .csm-compact-card h3,
.csm-home .csm-bullet-grid article h3,
.csm-home .csm-solution-card h3,
.csm-home .csm-highlight-card h3,
.csm-home .csm-process article h3,
.csm-home .csm-bento-grid .csm-bento-card h3 { font-size: clamp(18px, 1.8vw, 20px); }
.csm-home .csm-hero .csm-shell .csm-hero-visual {
  max-width: 540px; justify-self: end; width: 100%;
}
.csm-home .csm-hero .csm-shell .csm-hero-visual .csm-hero-float {
  width: min(170px, 36%);
}
.csm-home .csm-home-capability-cluster { padding-top: 16px; padding-bottom: clamp(26px, 4.4vw, 54px); }
.csm-home .csm-home-capability-cluster {
  background:
    linear-gradient(180deg, #ffffff 0%, #fafafa 45%, var(--csm-accent-soft) 100%);
  border-top: 1px solid var(--csm-divider);
  border-bottom: 1px solid var(--csm-divider);
}
.csm-home .csm-home-capability-cluster .csm-capability-grid {
  display: grid; gap: 14px; grid-template-columns: repeat(4, minmax(0, 1fr));
}
.csm-home .csm-home-capability-cluster .csm-capability-card {
  display: block; border-radius: 18px; padding: clamp(18px, 2.6vw, 28px);
  min-height: 220px; text-decoration: none; color: #fff;
  box-shadow: 0 16px 30px rgba(21, 33, 78, 0.2);
  filter: saturate(1.08);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.csm-home .csm-home-capability-cluster .csm-capability-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 36px rgba(21, 33, 78, 0.25);
  filter: saturate(1.14);
}
.csm-home .csm-home-capability-cluster .csm-capability-card .csm-capability-icon {
  width: 46px; height: 46px; border-radius: 14px; display: inline-grid; place-items: center;
  background: rgba(255, 255, 255, 0.22); margin-bottom: 14px; font-size: 18px;
}
.csm-home .csm-home-capability-cluster .csm-capability-card h3 {
  margin: 0 0 8px; font-size: 20px;
}
.csm-home .csm-home-capability-cluster .csm-capability-card p {
  margin: 0; color: rgba(244, 248, 255, 0.94); font-size: 16px; line-height: 1.6;
}

.csm-gradient-blue {
  background: linear-gradient(145deg, #2b2f6b 0%, #323a86 55%, #3d47a2 100%);
}
.csm-gradient-teal {
  background: linear-gradient(145deg, #3f8f95 0%, #4ea2a2 52%, #60b5b0 100%);
}
.csm-gradient-mint {
  background: linear-gradient(145deg, #68b79b 0%, #86cdb0 52%, #9edbc1 100%);
}
.csm-gradient-indigo {
  background: linear-gradient(145deg, #2b2f6b 0%, #384294 52%, #4a57aa 100%);
}
.csm-gradient-softviolet {
  background: linear-gradient(145deg, #6f799b 0%, #8290af 52%, #99a7bf 100%);
}

.csm-home .csm-home-stack-strip {
  padding-top: 12px;
  padding-bottom: 8px;
}
.csm-home .csm-home-stack-strip .csm-stack-groups {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.csm-home .csm-home-stack-strip .csm-stack-group {
  border: 1px solid var(--csm-border);
  border-radius: 16px;
  background: #fff;
  padding: 12px 14px;
}
.csm-home .csm-home-stack-strip .csm-stack-group span {
  display: block;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #4a547f;
  margin-bottom: 10px;
  font-weight: 700;
}
.csm-home .csm-home-stack-strip .csm-stack-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
}
.csm-home .csm-home-stack-strip .csm-stack-logos img {
  height: clamp(28px, 2.2vw, 36px);
  width: auto;
  display: block;
}

.csm-section { padding: clamp(30px, 6vw, 74px) 0; }
.csm-section.csm-section-alt { background: var(--csm-alt-bg); }
.csm-section.csm-section-soft { background: linear-gradient(140deg, rgba(43, 47, 107, 0.08), rgba(168, 224, 200, 0.2)); }
.csm-home .csm-section + .csm-section {
  border-top: 1px solid rgba(235, 235, 235, 0.9);
}
.csm-section .csm-section-head { margin-bottom: 20px; }
.csm-section .csm-section-head h2 {
  margin: 0;
}
.csm-section .csm-section-head p { margin: 10px 0 0; color: var(--csm-muted); line-height: 1.7; }

.csm-card-grid { display: grid; gap: 14px; }
.csm-card-grid.csm-card-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.csm-card-grid.csm-card-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.csm-card-grid.csm-card-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.csm-bento-grid {
  display: grid; gap: 14px; grid-template-columns: repeat(12, minmax(0, 1fr));
}
.csm-bento-grid .csm-bento-card {
  grid-column: span 3;
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md); background: var(--csm-card);
  padding: 16px; transition: transform .2s ease, box-shadow .2s ease;
}
.csm-bento-grid .csm-bento-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(24, 34, 92, .12);
}
.csm-bento-grid .csm-bento-card.csm-bento-spotlight {
  grid-column: span 6;
  background: #fff;
}
.csm-bento-grid .csm-bento-card img {
  width: 100%; height: auto; border-radius: 10px; display: block;
}
.csm-bento-grid .csm-bento-card h3 { margin: 10px 0 8px; }
.csm-bento-grid .csm-bento-card p { margin: 0; }

.csm-spotlight,
.csm-spotlight-section {
  display: grid; gap: 16px; grid-template-columns: 1.02fr .98fr; align-items: center;
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-lg);
  background: #fff;
  padding: clamp(18px, 3vw, 30px);
}
.csm-spotlight .csm-checklist,
.csm-spotlight-section .csm-checklist { margin-top: 12px; }

.csm-spotlight-copy {
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md);
  background: var(--csm-card); padding: 16px; display: grid; gap: 12px;
}
.csm-spotlight-copy p { margin: 0; }

.csm-card-grid .csm-service-card,
.csm-card-grid .csm-compact-card,
.csm-bullet-grid article,
.csm-process article,
.csm-solution-card,
.csm-cap-chip,
.csm-highlight-card {
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md); background: var(--csm-card); padding: 18px;
}

.csm-card-grid .csm-service-card i,
.csm-bullet-grid article i,
.csm-process article i,
.csm-highlight-card i,
.csm-cap-chip i,
.csm-solution-card i { color: var(--csm-accent); font-size: 20px; }

.csm-card-grid .csm-service-card h3,
.csm-card-grid .csm-compact-card h3,
.csm-bullet-grid article h3,
.csm-solution-card h3,
.csm-highlight-card h3,
.csm-process article h3 {
  margin: 10px 0 8px;
}

.csm-card-grid .csm-service-card p,
.csm-card-grid .csm-compact-card p,
.csm-bullet-grid article p,
.csm-solution-card p,
.csm-highlight-card p,
.csm-process article p,
.csm-split p,
.csm-timeline article p {
  margin: 0; color: var(--csm-muted); line-height: 1.65; font-size: 16px;
}

.csm-text-link { margin-top: 10px; display: inline-flex; align-items: center; gap: 8px; color: var(--csm-primary); font-weight: 700; }
.csm-text-link::after { content: "\f061"; font-family: "Font Awesome 6 Pro"; font-weight: 400; }

.csm-capability-strip .csm-shell .csm-capability-row { display: grid; gap: 10px; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.csm-capability-strip .csm-shell .csm-cap-chip { display: flex; align-items: center; gap: 10px; }
.csm-home .csm-home-positioning { padding-top: 22px; }
.csm-home .csm-home-services,
.csm-home .csm-home-spotlights { background: var(--csm-alt-bg); }
.csm-home .csm-home-portfolio-cta { margin-top: 18px; }
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card img {
  width: auto;
  height: clamp(64px, 7vw, 96px);
  max-height: 96px;
  max-width: 100%;
  justify-self: start;
  align-self: center;
  grid-column: 1;
  grid-row: 1 / span 4;
}
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card.csm-bento-spotlight {
  min-height: 0;
}
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card {
  display: grid;
  grid-template-columns: minmax(72px, 96px) 1fr;
  column-gap: 14px;
  row-gap: 4px;
  align-items: center;
  align-content: center;
  min-height: 188px;
}
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card h3,
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card p,
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card .csm-text-link {
  grid-column: 2;
}
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card h3 { grid-row: 1; }
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card p { grid-row: 2; }
.csm-home .csm-home-services .csm-bento-grid .csm-bento-card .csm-text-link { grid-row: 3; }

.csm-split { display: grid; gap: 16px; grid-template-columns: 1.04fr .96fr; align-items: start; }
.csm-checklist { display: grid; gap: 10px; }
.csm-checklist > div {
  border: 1px solid var(--csm-border); border-radius: 14px; background: var(--csm-card);
  padding: 12px; font-size: 16px; font-weight: 600; color: #323b63;
  display: flex; align-items: center; gap: 10px;
}
.csm-checklist > div i { color: var(--csm-accent); }

.csm-bullet-grid { display: grid; gap: 14px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.csm-cms-crm-block {
  display: grid; gap: 16px; grid-template-columns: 1.08fr .92fr; align-items: start;
}

.csm-problem-list {
  list-style: none; margin: 0; padding: 0; display: grid; gap: 10px;
}
.csm-problem-list li {
  border: 1px solid var(--csm-border); border-radius: 14px; background: #fff;
  padding: 12px; display: flex; align-items: flex-start; gap: 10px;
}
.csm-problem-list li i { color: var(--csm-accent); margin-top: 3px; }
.csm-problem-list li strong { display: block; font-size: 16px; color: #222a55; margin-bottom: 4px; }
.csm-problem-list li p { margin: 0; color: var(--csm-muted); font-size: 16px; line-height: 1.6; }

.csm-tech-list {
  list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; grid-template-columns: repeat(2, minmax(0, 1fr));
}
.csm-tech-list li {
  border: 1px solid var(--csm-border); border-radius: 14px; background: var(--csm-card); padding: 12px;
}
.csm-tech-list li span { display: block; font-size: 16px; font-weight: 700; color: #202759; }
.csm-tech-list li small { display: block; margin-top: 4px; color: var(--csm-muted); font-size: 14px; line-height: 1.5; }

.csm-timeline { display: grid; gap: 14px; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.csm-timeline article { border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md); background: var(--csm-card); padding: 16px; }
.csm-timeline article span {
  width: 34px; height: 34px; border-radius: 12px; display: grid; place-items: center;
  background: #edf4f0; color: var(--csm-primary); font-weight: 800; font-size: 12px;
}
.csm-timeline article h3 { margin: 10px 0 6px; font-size: clamp(20px, 2vw, 24px); }

.csm-process-steps {
  display: grid; gap: 14px; grid-template-columns: repeat(4, minmax(0, 1fr));
}
.csm-process-step {
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md); background: var(--csm-card); padding: 16px;
}
.csm-process-step span {
  width: 34px; height: 34px; border-radius: 12px; display: grid; place-items: center;
  background: #edf4f0; color: var(--csm-eng-blue); font-weight: 800; font-size: 12px;
}
.csm-process-step h3 { margin: 10px 0 6px; font-size: 20px; }
.csm-process-step p { margin: 0; color: var(--csm-muted); font-size: 16px; line-height: 1.6; }

.csm-related-links {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.csm-related-links a {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid var(--csm-border); border-radius: 12px;
  background: var(--csm-card); color: #28315e; font-size: 14px; font-weight: 700;
  padding: 10px 12px;
}
.csm-related-links a i { color: var(--csm-accent); }

.csm-404-page .csm-shell { display: grid; place-items: center; }
.csm-404-page .csm-404-card {
  width: min(760px, 100%);
  border: 1px solid var(--csm-border);
  border-radius: var(--csm-radius-lg);
  background: #fff;
  padding: clamp(24px, 4vw, 44px);
  text-align: center;
}
.csm-404-page .csm-404-card .csm-kicker {
  margin-bottom: 12px;
  gap: 8px;
}
.csm-404-page .csm-404-card .csm-404-code {
  font-size: clamp(56px, 10vw, 100px);
  line-height: 1;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--csm-primary);
}
.csm-404-page .csm-404-card h1 {
  margin: 10px 0 10px;
}
.csm-404-page .csm-404-card p {
  margin: 0 auto;
  max-width: 620px;
  color: var(--csm-muted);
}
.csm-404-page .csm-404-actions {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.csm-404-page .csm-404-actions .csm-btn i { margin-right: 8px; }
.csm-404-page .csm-404-note {
  margin-top: 14px;
  border-top: 1px solid var(--csm-border);
  padding-top: 14px;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--csm-muted);
}
.csm-404-page .csm-404-note i { color: var(--csm-accent); }

.mt-blog,
.mt-article {
  padding: clamp(36px, 5.5vw, 78px) 0;
  background: #fff;
}

.mt-blog .mt-blog-kicker {
  border: 1px solid rgba(90, 166, 166, 0.3);
  background: var(--csm-accent-soft);
  color: #1f5d63;
}

.mt-blog .mt-blog-title,
.mt-article .mt-article-title,
.mt-article .mt-related .mt-related-title {
  color: var(--csm-ink);
  letter-spacing: -0.02em;
}

.mt-blog .mt-blog-subtitle,
.mt-article .mt-article-card .mt-article-content,
.mt-article .mt-article-card .mt-article-cta .mt-article-cta-sub {
  color: var(--csm-muted);
}

.mt-blog .mt-blog-search .mt-blog-search-inner {
  border: 1px solid var(--csm-border);
  background: #fff;
  box-shadow: none;
}

.mt-blog .mt-blog-search .mt-blog-search-btn,
.mt-blog .mt-blog-side .mt-blog-side-cta .mt-btn,
.mt-blog .mt-cat-card .mt-cat-btn,
.mt-article .mt-article-card .mt-article-cta .mt-btn {
  border-radius: 12px;
  border: 1px solid transparent;
  background: var(--csm-primary);
  color: #fff;
  font-weight: 700;
}

.mt-blog .mt-blog-search .mt-blog-search-btn:hover,
.mt-blog .mt-blog-side .mt-blog-side-cta .mt-btn:hover,
.mt-blog .mt-cat-card .mt-cat-btn:hover,
.mt-article .mt-article-card .mt-article-cta .mt-btn:hover {
  background: var(--csm-primary-2);
}

.mt-blog .mt-blog-side .mt-blog-side-card,
.mt-blog .mt-cat-card,
.mt-post-card,
.mt-article .mt-article-card,
.mt-article .mt-article-side .mt-article-side-card,
.mt-article .mt-article-cover {
  border: 1px solid var(--csm-border);
  background: #fff;
  box-shadow: none;
}

.mt-blog .mt-blog-side .mt-blog-side-link,
.mt-article .mt-article-side .mt-article-side-link,
.mt-post-card .mt-post-link {
  color: var(--csm-primary);
}

.mt-blog .mt-blog-side .mt-blog-side-link:hover,
.mt-article .mt-article-side .mt-article-side-link:hover {
  background: #f4f6f8;
  color: var(--csm-ink);
}

.mt-blog .mt-blog-side .mt-blog-side-link i,
.mt-article .mt-article-meta .mt-article-date i {
  color: var(--csm-accent);
}

.mt-article .mt-article-meta .mt-article-tag {
  border: 1px solid rgba(90, 166, 166, 0.26);
  background: var(--csm-accent-soft);
  color: #1f5d63;
}

.mt-article .mt-article-card .mt-article-content a {
  color: var(--csm-primary);
}

.mt-article .mt-article-card .mt-article-cta {
  border: 1px solid rgba(90, 166, 166, 0.24);
  background: linear-gradient(180deg, #ffffff 0%, #f5fbf8 100%);
}

.mt-article .mt-article-card .mt-article-divider {
  background: var(--csm-border);
}

.csm-contact-grid {
  display: grid; grid-template-columns: 1.2fr .8fr; gap: 14px; align-items: start;
}
.csm-contact-card,
.csm-contact-side .csm-contact-block,
.csm-faq-grid article {
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md); background: var(--csm-card); padding: 18px;
}
.csm-contact-card h2,
.csm-contact-side h3,
.csm-faq-grid article h3 {
  margin: 0 0 8px; font-family: var(--csm-font-heading);
}
.csm-contact-card p,
.csm-contact-side p,
.csm-faq-grid article p {
  margin: 0; color: var(--csm-muted); line-height: 1.6;
}
.csm-contact-form {
  margin-top: 14px; display: grid; gap: 8px;
}
.csm-contact-form label {
  font-size: 14px; font-weight: 600; color: #2b3463;
}
.csm-contact-form input,
.csm-contact-form textarea {
  width: 100%; border: 1px solid var(--csm-border); border-radius: 12px;
  background: #fff; color: #1d2247; min-height: 44px; padding: 10px 12px;
}
.csm-contact-form textarea { min-height: 140px; resize: vertical; }
.csm-contact-form input:focus,
.csm-contact-form textarea:focus {
  outline: 0; border-color: var(--csm-accent); box-shadow: 0 0 0 3px rgba(90, 166, 166, 0.18);
}
.csm-contact-form .csm-contact-captcha { margin: 6px 0 4px; overflow: auto; }
.csm-contact-side {
  display: grid; gap: 12px;
}
.csm-contact-side .csm-contact-block {
  display: grid; gap: 8px;
}
.csm-contact-side .csm-contact-block a,
.csm-contact-side .csm-contact-block div {
  display: inline-flex; align-items: center; gap: 8px; color: #2f3968;
}
.csm-contact-side .csm-contact-block ul {
  margin: 0; padding-left: 18px; color: var(--csm-muted); display: grid; gap: 6px;
}

.csm-discovery-box { text-align: left; }
.csm-discovery-box p { max-width: 760px; margin-left: 0; }

.csm-case-study-grid {
  display: grid; gap: 14px; grid-template-columns: repeat(3, minmax(0, 1fr));
}
.csm-case-study-card {
  border: 1px solid #d9deea; border-radius: var(--csm-radius-md); background: #fff;
  padding: 18px; box-shadow: 0 10px 24px rgba(18, 28, 74, 0.06);
}
.csm-case-study-card span {
  display: inline-flex; font-size: 12px; text-transform: uppercase; letter-spacing: .08em;
  color: #1e4f56; background: var(--csm-accent-2); border-radius: 999px; padding: 5px 9px; font-weight: 700;
}
.csm-case-study-card h3 { margin: 10px 0 8px; font-size: 20px; }
.csm-case-study-card p { margin: 0 0 8px; color: var(--csm-muted); font-size: 16px; line-height: 1.6; }
.csm-case-study-card p:last-child { margin-bottom: 0; }

.csm-faq-grid {
  display: grid; gap: 14px; grid-template-columns: repeat(3, minmax(0, 1fr));
}

.csm-service-category-media {
  margin: 0 0 14px; display: grid; gap: 12px; grid-template-columns: repeat(4, minmax(0, 1fr));
}
.csm-service-category-media article {
  border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md); background: var(--csm-card); padding: 12px;
}
.csm-service-category-media article img {
  width: 100%; height: auto; display: block; border-radius: 10px;
}
.csm-service-category-media article h3 {
  margin: 10px 0 0; font-size: 18px;
}

.csm-section-figure,
.csm-two-media figure {
  margin: 0; border: 1px solid var(--csm-border); border-radius: var(--csm-radius-md); background: var(--csm-card); padding: 12px;
}
.csm-section-figure img,
.csm-two-media figure img {
  width: 100%; height: auto; display: block; border-radius: 10px;
}
.csm-section-figure:has(img[src$=".svg"]),
.csm-two-media figure:has(img[src$=".svg"]) {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}
.csm-section-figure:has(img[src$=".svg"]) img,
.csm-two-media figure:has(img[src$=".svg"]) img {
  border-radius: 0;
}
.csm-home .csm-home-spotlight-row .csm-section-figure {
  width: min(100%, 520px);
  justify-self: end;
}
.csm-home .csm-home-spotlights .csm-spotlight,
.csm-home .csm-home-spotlights .csm-spotlight-section {
  margin-bottom: 14px;
}
.csm-home .csm-home-spotlights .csm-spotlight:last-child,
.csm-home .csm-home-spotlights .csm-spotlight-section:last-child {
  margin-bottom: 0;
}
.csm-home .csm-home-proof .csm-two-media figure {
  width: min(100%, 520px);
}

.csm-wide-spotlight {
  width: 100%;
  display: grid;
  grid-template-columns: 50vw 50vw;
  align-items: stretch;
  background: #fff;
  overflow-x: hidden;
}
.csm-wide-spotlight .csm-wide-media {
  min-height: clamp(300px, 34vw, 480px);
  background:
    linear-gradient(145deg, #fafafa 0%, #fafafa 55%, rgba(168, 224, 200, 0.28) 100%);
  overflow-x: hidden;
}
.csm-wide-spotlight .csm-wide-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.csm-wide-spotlight .csm-wide-media img[src$=".svg"] {
  padding: 20%;
  box-sizing: border-box;
  object-fit: contain;
}
.csm-wide-spotlight .csm-wide-content-wrap {
  display: flex;
  align-items: center;
  padding: clamp(26px, 5vw, 62px) 0;
}
.csm-wide-spotlight .csm-wide-content-card {
  border: 0;
  border-radius: 20px;
  background: transparent;
  box-shadow: none;
  padding: clamp(18px, 3.3vw, 34px);
  max-width: 620px;
}
.csm-wide-spotlight .csm-wide-content-card h2 {
  margin: 0 0 10px;
}
.csm-wide-spotlight .csm-wide-content-card p {
  margin: 0 0 16px;
  color: var(--csm-muted);
  font-size: 16px;
}
.csm-wide-spotlight.csm-wide-image-left .csm-wide-content-wrap .csm-shell {
  display: flex;
  justify-content: flex-start;
}
.csm-wide-spotlight.csm-wide-image-right .csm-wide-content-wrap .csm-shell {
  display: flex;
  justify-content: flex-end;
}
.csm-section-figure.csm-section-figure-wide { margin-bottom: 14px; }
.csm-two-media {
  margin-bottom: 14px; display: grid; gap: 12px; grid-template-columns: repeat(2, minmax(0, 1fr));
}

.csm-cta { padding: clamp(30px, 6vw, 70px) 0; }
.csm-cta .csm-cta-box,
.csm-cta .csm-cta-banner {
  border: 1px solid rgba(255, 255, 255, 0.16); border-radius: var(--csm-radius-lg); background: var(--csm-primary-2);
  text-align: center; padding: clamp(22px, 4vw, 40px);
}
.csm-cta .csm-cta-box h2,
.csm-cta .csm-cta-banner h2 { margin: 0; }
.csm-cta .csm-cta-box h2,
.csm-cta .csm-cta-box p,
.csm-cta .csm-cta-banner h2,
.csm-cta .csm-cta-banner p { color: #f8fafc; }
.csm-cta .csm-cta-box p,
.csm-cta .csm-cta-banner p { margin: 10px auto 16px; max-width: 820px; color: #f8fafc; }

.csm-footer {
  width: 100%;
  background: linear-gradient(175deg, #23265a 0%, #2b2f6b 58%, #343a7a 100%);
  color: #eef3ff;
  margin-top: 36px;
}
.csm-footer .csm-footer-inner {
  width: min(var(--csm-max), calc(100% - 40px));
  margin: 0 auto;
  padding: 40px 0 0;
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr 1fr;
  row-gap: 14px;
  column-gap: 40px;
}
.csm-footer .csm-footer-col h3 {
  margin: 0 0 10px; font-size: 20px; letter-spacing: -0.01em; color: #fff;
}
.csm-footer .csm-footer-col p { margin: 12px 0 0; color: rgba(236, 242, 255, 0.78); line-height: 1.7; font-size: 16px; }
.csm-footer .csm-footer-col .csm-footer-text { margin: 0 0 8px; }
.csm-footer .csm-footer-col a { display: block; color: rgba(235, 241, 255, 0.9); margin-bottom: 8px; font-size: 16px; }
.csm-footer .csm-footer-col a:hover { color: #fff; }
.csm-footer .csm-footer-bottom {
  width: min(var(--csm-max), calc(100% - 40px));
  margin: 48px auto 0;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.6);
  font-size: 14px;
  padding-top: 24px;
  padding-bottom: 40px;
}

.csm-reveal { opacity: 0; transform: translateY(16px); transition: opacity .55s ease, transform .55s ease; }
.csm-reveal.is-visible { opacity: 1; transform: translateY(0); }
.csm-enter { opacity: 0; transform: translateY(14px); }
body.csm-ready .csm-enter { opacity: 1; transform: translateY(0); transition: opacity .5s ease, transform .5s ease; }

.csm-card-grid .csm-service-card:hover,
.csm-card-grid .csm-compact-card:hover,
.csm-bullet-grid article:hover,
.csm-solution-card:hover,
.csm-process article:hover,
.csm-spotlight:hover { transform: translateY(-3px); box-shadow: 0 12px 24px rgba(24, 34, 92, .11); }

@media (max-width: 1150px) {
  .csm-header .csm-nav-inner { grid-template-columns: auto auto; }
  .csm-header .csm-nav,
  .csm-header .csm-nav-cta { display: none; }
  .csm-header .csm-menu-toggle {
    display: inline-grid; place-items: center; margin-left: auto;
    width: 44px; height: 44px; border: 1px solid var(--csm-border); border-radius: 12px;
    background: #fff; color: var(--csm-primary);
  }
  body.csm-nav-open { overflow: hidden; }
  .csm-header .csm-mobile-nav {
    position: fixed; inset: 0; z-index: 280; display: none; background: rgba(8, 12, 32, 0.38);
  }
  .csm-header .csm-mobile-nav.is-open { display: block; }
  .csm-header .csm-mobile-nav .csm-mobile-panel {
    width: min(560px, 100vw); margin-left: auto; height: 100vh; overflow: auto;
    background: #fafafa; border-left: 1px solid #e2e8ef; padding: 18px;
  }
  .csm-header .csm-mobile-nav .csm-mobile-top {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px;
  }
  .csm-header .csm-mobile-nav .csm-mobile-top strong {
    font-size: 16px; color: #20295a; letter-spacing: -0.01em;
  }
  .csm-header .csm-mobile-nav .csm-mobile-close {
    width: 42px; height: 42px; border: 1px solid var(--csm-border); border-radius: 12px;
    background: #fff; color: #222a54; display: inline-grid; place-items: center;
  }
  .csm-header .csm-mobile-nav .csm-mobile-wrap { display: grid; gap: 10px; }
  .csm-header .csm-mobile-nav .csm-mobile-link,
  .csm-header .csm-mobile-nav .csm-mobile-acc summary,
  .csm-header .csm-mobile-nav .csm-mobile-acc > a,
  .csm-header .csm-mobile-nav .csm-mobile-acc details summary,
  .csm-header .csm-mobile-nav .csm-mobile-acc details a {
    display: block; border: 1px solid #dfe5f0; background: #fff; color: #20295a;
    border-radius: 12px; padding: 12px 14px; font-size: 15px; font-weight: 700;
  }
  .csm-header .csm-mobile-nav .csm-mobile-acc summary { list-style: none; cursor: pointer; }
  .csm-header .csm-mobile-nav .csm-mobile-acc summary::-webkit-details-marker { display: none; }
  .csm-header .csm-mobile-nav .csm-mobile-acc details { margin-top: 8px; display: grid; gap: 8px; }
  .csm-header .csm-mobile-nav .csm-mobile-acc details a small {
    display: block; margin-top: 2px; font-size: 13px; line-height: 1.45; color: #5c6588; font-weight: 500;
  }
  .csm-header .csm-mobile-nav .csm-btn { margin-top: 8px; min-height: 48px; }

  .csm-hero .csm-shell .csm-hero-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }

  .csm-hero .csm-shell .csm-hero-grid,
  .csm-interior-hero .csm-shell .csm-interior-hero-grid,
  .csm-spotlight,
  .csm-spotlight-section,
  .csm-home .csm-home-stack-strip .csm-stack-groups,
  .csm-capability-strip .csm-shell .csm-capability-row,
  .csm-home .csm-home-capability-cluster .csm-capability-grid,
  .csm-split,
  .csm-cms-crm-block,
  .csm-service-category-media,
  .csm-two-media,
  .csm-contact-grid,
  .csm-card-grid.csm-card-grid-4,
  .csm-card-grid.csm-card-grid-3,
  .csm-case-study-grid,
  .csm-bullet-grid,
  .csm-tech-list,
  .csm-faq-grid,
  .csm-timeline,
  .csm-process-steps,
  .csm-footer .csm-footer-inner { grid-template-columns: 1fr; }

  .csm-bento-grid .csm-bento-card,
  .csm-bento-grid .csm-bento-card.csm-bento-spotlight { grid-column: span 12; }

  .csm-hero .csm-shell .csm-hero-visual .csm-hero-float {
    position: static; width: 100%; margin-top: 10px;
  }
  .csm-hero .csm-shell .csm-hero-visual.csm-hero-ui-composition {
    min-height: 360px;
    padding: 12px;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-main-card {
    width: calc(100% - 24px);
    max-width: none;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card,
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-arch-card {
    width: min(46%, 185px);
  }
  .csm-home .csm-hero .csm-shell .csm-hero-visual,
  .csm-home .csm-home-spotlight-row .csm-section-figure,
  .csm-home .csm-home-proof .csm-two-media figure { width: 100%; max-width: none; justify-self: stretch; }
  .csm-home .csm-hero .csm-shell .csm-hero-visual {
    margin-top: 10px;
    padding: 12px;
    border-radius: 18px;
    box-shadow: 0 12px 24px rgba(22, 30, 58, 0.12);
  }

  .csm-wide-spotlight {
    grid-template-columns: 1fr;
  }
  .csm-wide-spotlight .csm-wide-media {
    min-height: 220px;
    order: 1;
  }
  .csm-wide-spotlight .csm-wide-content-wrap {
    order: 2;
    padding: 20px 0;
  }
  .csm-wide-spotlight .csm-wide-content-wrap .csm-shell {
    justify-content: stretch !important;
  }
  .csm-wide-spotlight .csm-wide-content-card {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .csm-hero .csm-shell .csm-hero-stats { grid-template-columns: 1fr; }
  .csm-home .csm-hero .csm-shell .csm-hero-visual {
    margin-top: 8px;
    padding: 10px;
    border-radius: 16px;
    box-shadow: 0 8px 18px rgba(22, 30, 58, 0.1);
  }
  .csm-hero .csm-shell .csm-hero-trust {
    width: 100%;
    justify-content: center;
    text-align: center;
    border-radius: 14px;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition {
    min-height: 304px;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-main-card {
    inset: 16px 10px auto 10px;
    transform: none;
    width: auto;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-main-card .csm-ui-kpis {
    grid-template-columns: 1fr;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-chart {
    height: 92px;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-admin-card {
    top: auto;
    left: 10px;
    bottom: 62px;
    width: calc(50% - 14px);
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-arch-card {
    right: 10px;
    bottom: 62px;
    width: calc(50% - 14px);
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-cloud-badges {
    left: 10px;
    right: 10px;
    bottom: 10px;
    transform: none;
    justify-content: space-between;
  }
  .csm-hero .csm-shell .csm-hero-ui-composition .csm-ui-cloud-badges span {
    min-width: 0;
    flex: 1;
    font-size: 10px;
  }
}
