/* Marketing pages (home/services/cases/blog) */

:root {
  --mk-max: 1180px;
  --mk-ring: rgba(37, 99, 235, 0.22);
  --mk-radius-lg: 28px;
  --mk-radius-md: 18px;
}

.mk-main {
  max-width: var(--mk-max);
  margin: 0 auto;
  padding: var(--space-12) var(--space-6);
}

@media (max-width: 768px) {
  .mk-main { padding: var(--space-8) var(--space-4); }
}

/* Headings */
.mk-title {
  text-align: center;
  margin-bottom: var(--space-3);
}

.mk-lead {
  text-align: center;
  max-width: 72ch;
  margin-left: auto;
  margin-right: auto;
}

/* Light polish (keep minimal) */
.mk-main a { text-underline-offset: 2px; text-decoration-thickness: 2px; }
.mk-main a:focus-visible,
.mk-main button:focus-visible,
.mk-main .button:focus-visible,
.mk-main input:focus-visible,
.mk-main select:focus-visible,
.mk-main textarea:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--mk-ring);
}

.hero-title { letter-spacing: -0.02em; line-height: 1.05; }
.hero-description { line-height: 1.65; max-width: 60ch; }

/* Section rhythm (consistent across marketing pages) */
.mk-main .section {
  padding: clamp(var(--space-12), 6vw, var(--space-24)) 0;
}
.mk-main .section-sm {
  padding: clamp(var(--space-8), 4.5vw, var(--space-12)) 0;
}
.mk-main .section-lg {
  padding: clamp(var(--space-16), 7vw, var(--space-32)) 0;
}

/* Used by templates (keep simple + consistent) */
.mk-main .section-badge { margin-bottom: var(--space-3); }
.mk-main .section-intro { max-width: 70ch; margin-left: auto; margin-right: auto; }
.mk-main .mb-xl { margin-bottom: var(--space-8) !important; }
.mk-main .mb-2xl { margin-bottom: var(--space-12) !important; }

/* Alternate surface used on home */
.mk-main .surface-alt {
  background: linear-gradient(180deg, rgba(255,255,255,0.028), rgba(255,255,255,0.018));
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* Hero */
.mk-hero {
  padding: var(--space-24) 0 var(--space-16);
}

.mk-hero-panel {
  border-radius: var(--mk-radius-lg);
  border: 1px solid rgba(124, 58, 237, 0.16);
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(22px);
  overflow: hidden;
}

.mk-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.9fr);
  gap: var(--space-8);
  padding: clamp(1.25rem, 2.6vw, 2.1rem);
  align-items: start;
}

.mk-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .45rem .85rem;
  border-radius: 999px;
  border: 1px solid rgba(124,58,237,0.26);
  background: rgba(124,58,237,0.12);
  color: var(--text);
  font-weight: 700;
  font-size: .9rem;
  width: fit-content;
}

.mk-hero-copy p {
  margin-bottom: var(--space-6);
}

.mk-hero-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.mk-hero-actions .button {
  min-height: 48px;
  transition: transform var(--t-base), box-shadow var(--t-base), filter var(--t-base);
}
.mk-hero-actions .button:hover { transform: translateY(-1px); }
.mk-hero-actions .button:active { transform: translateY(0); }

.mk-hero-bullets {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin: var(--space-6) 0 var(--space-6);
}

.mk-hero-bullet {
  border-radius: var(--mk-radius-md);
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  padding: .95rem 1rem;
  transition: transform var(--t-base), border-color var(--t-base), background var(--t-base);
}
.mk-hero-bullet:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.055);
}

.mk-hero-bullet strong { display: block; color: #fff; margin-bottom: .25rem; }
.mk-hero-bullet span { display: block; color: var(--muted); font-size: .93rem; line-height: 1.55; }

.mk-hero-aside {
  display: grid;
  gap: var(--space-4);
}

.mk-aside-card {
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.03));
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-sm);
  padding: 1.2rem;
}

.mk-aside-card h3 {
  margin: .6rem 0 .75rem;
  font-size: 1.15rem;
  color: #fff;
}

.mk-aside-list {
  display: grid;
  gap: .75rem;
  margin-top: 1rem;
}

.mk-aside-item {
  padding: .9rem 1rem;
  border-radius: var(--mk-radius-md);
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  transition: border-color var(--t-base), background var(--t-base);
}
.mk-aside-item:hover { border-color: rgba(255,255,255,0.18); background: rgba(255,255,255,0.055); }

.mk-aside-item strong { display: block; color: #fff; margin-bottom: .25rem; }
.mk-aside-item span { display: block; color: var(--muted); font-size: .93rem; line-height: 1.6; }

.mk-signal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
}

.mk-signal {
  border-radius: var(--mk-radius-md);
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  padding: 1rem;
  transition: border-color var(--t-base), background var(--t-base);
}
.mk-signal:hover { border-color: rgba(255,255,255,0.18); background: rgba(255,255,255,0.055); }

.mk-signal strong { display: block; color: #fff; font-size: 1.02rem; margin-bottom: .35rem; }
.mk-signal span { display: block; color: var(--dim); font-size: .86rem; line-height: 1.55; }

.mk-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-6);
  padding: 0 clamp(1.25rem, 2.6vw, 2.1rem) clamp(1.25rem, 2.6vw, 2.1rem);
  margin-top: var(--space-6);
}

.mk-stat {
  text-align: center;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(135deg, rgba(255,255,255,0.09), rgba(255,255,255,0.04));
  padding: 1.35rem 1.1rem;
  box-shadow: 0 8px 28px rgba(0,0,0,0.10);
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}

.mk-stat:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 56px rgba(124, 58, 237, 0.22);
  border-color: rgba(255,255,255,0.22);
}

.mk-stat-value {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.15;
  background: var(--accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: .35rem;
}

.mk-stat-label {
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--dim);
}

@media (max-width: 960px) {
  .mk-hero-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .mk-hero { padding: var(--space-16) 0 var(--space-12); }
  .mk-hero-grid { gap: var(--space-6); }
  .mk-hero-actions { display: grid; }
  .mk-hero-actions .button { width: 100%; justify-content: center; }
  .mk-hero-bullets { grid-template-columns: 1fr; }
  .mk-signal-grid { grid-template-columns: 1fr; }
  .mk-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .mk-stat:hover { transform: none; }
  .mk-hero-bullet:hover { transform: none; }
}

@media (max-width: 480px) {
  .mk-hero-panel { border-radius: 20px; }
  .mk-stats { grid-template-columns: 1fr; }
}

/* Generic card grids used by services/cases/blog */
.mk-grid {
  display: grid;
  gap: var(--density-grid-gap);
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
}

@media (max-width: 1024px) {
  .mk-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 768px) {
  .mk-grid { grid-template-columns: 1fr; }
}

.mk-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  justify-content: flex-start;
  padding: var(--density-card-padding);
}

.mk-card .card-description {
  margin-bottom: 0;
}

.mk-card h3 a {
  color: #fff;
  text-decoration: none;
}
.mk-card h3 a:hover { text-decoration: underline; }

.mk-card .button {
  margin-top: auto;
  width: fit-content;
}

@media (max-width: 768px) {
  .mk-card .button { width: 100%; justify-content: center; }
}

/* CTA band */
.mk-cta-band {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  padding: var(--space-12) 0;
}

.mk-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--density-grid-gap);
  flex-wrap: wrap;
}

.mk-cta-copy h3 { margin: 0 0 .35rem; }
.mk-cta-copy p { margin: 0; }

/* Blog detail */
.mk-article {
  max-width: 80ch;
  margin: 0 auto;
}

.mk-article img {
  max-width: 100%;
  height: auto;
  border-radius: 14px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
}

/* ROI section: rely on global input styles, just layout */
.mk-roi {
  background: radial-gradient(900px 520px at 18% -10%, rgba(124,58,237,0.22) 0%, transparent 62%),
              radial-gradient(820px 520px at 110% 10%, rgba(37,99,235,0.18) 0%, transparent 60%),
              linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  color: var(--text);
}

.mk-roi .mk-title,
.mk-roi p { color: var(--muted); }

.mk-roi .panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.03));
  border-color: rgba(255,255,255,0.10);
  box-shadow: var(--shadow-md);
}

.mk-roi-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: calc(var(--space-6) + .25rem) !important;
  margin-top: var(--space-6);
}

.mk-roi-grid > div {
  display: grid;
  gap: .75rem !important;
  align-content: start;
  min-width: 0;
}

.mk-roi label {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.25;
  color: var(--text);
  font-weight: 700;
}

.mk-roi input,
.mk-roi select,
.mk-roi textarea {
  margin: 0 !important;
  width: 100%;
  min-height: 46px;
}

.mk-roi-results {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.mk-roi-result {
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
  padding: 1rem;
  text-align: center;
}

.mk-roi-result-label { color: var(--dim); font-weight: 800; font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; }
.mk-roi-result-value {
  font-size: clamp(1.25rem, 2.4vw, 1.6rem);
  font-weight: 900;
  line-height: 1.2;
  word-break: break-word;
  background: var(--accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

@media (max-width: 1024px) {
  .mk-roi-grid { grid-template-columns: 1fr; }
  .mk-roi-results { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .mk-roi-grid { grid-template-columns: 1fr; }
  .mk-roi-results { grid-template-columns: 1fr; }
}

