/* spark-landing — layout: container, header, footer, sections, grids, responsive. */

.spk-container {
  width: 100%;
  max-width: var(--spk-container);
  margin: 0 auto;
  padding: 0 24px;
}
.spk-main { display: block; }

/* ============ Section base + dark/light variants ============ */
.spk-section { position: relative; padding: var(--spk-s-80) 0; }
.spk-section--light { background: var(--spk-bg-light); color: var(--spk-ink); }
.spk-section--dark  { background: var(--spk-bg-dark);  color: var(--spk-ink-on-dark); }

/* ============ Header (logo left · nav+login right · floating panel on scroll) ============ */
.spk-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: var(--spk-z-header);
  display: flex;
  justify-content: center;
  padding: 0 24px;
  pointer-events: none;
}
.spk-header__inner {
  width: 100%;
  max-width: var(--spk-container);
  height: var(--spk-header-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 0 16px;
  pointer-events: auto;
  border-radius: 0 0 var(--spk-r-panel) var(--spk-r-panel);
  transition: background var(--spk-dur-base) var(--spk-ease),
              height var(--spk-dur-base) var(--spk-ease),
              box-shadow var(--spk-dur-base) var(--spk-ease);
}
.spk-header.is-scrolled .spk-header__inner {
  height: var(--spk-header-h-sticky);
  background: #fff;
  box-shadow: 0 14px 34px -18px rgba(17, 33, 111, 0.28);
}

.spk-header__brand { display: inline-flex; align-items: center; }
.spk-header__brand img { height: 30px; width: auto; display: block; }
/* logo swap: white on hero, color when panel is white */
.spk-header__brand .spk-logo--color { display: none; }
.spk-header.is-scrolled .spk-header__brand .spk-logo--white { display: none; }
.spk-header.is-scrolled .spk-header__brand .spk-logo--color { display: block; }

.spk-header__right { display: flex; align-items: center; gap: 34px; }
.spk-header__nav { display: flex; align-items: center; gap: 34px; }
.spk-header__nav a {
  color: #fff;
  font-size: 16px;
  font-weight: 400;
  transition: color var(--spk-dur-quick) var(--spk-ease);
}
.spk-header.is-scrolled .spk-header__nav a { color: var(--spk-ink); }
.spk-header__nav a:hover,
.spk-header.is-scrolled .spk-header__nav a:hover { color: var(--spk-blue); }

.spk-header__lang { display: inline-flex; gap: 2px; align-items: center; }
.spk-header__lang-link {
  color: rgba(255, 255, 255, 0.62);
  font-size: 13px; font-weight: 600; letter-spacing: 0.5px;
  padding: 4px 5px;
  transition: color var(--spk-dur-quick) var(--spk-ease);
}
.spk-header__lang-link.is-active, .spk-header__lang-link:hover { color: #fff; }
.spk-header.is-scrolled .spk-header__lang-link { color: var(--spk-ink-dim); }
.spk-header.is-scrolled .spk-header__lang-link.is-active,
.spk-header.is-scrolled .spk-header__lang-link:hover { color: var(--spk-ink); }

.spk-header__burger {
  display: none; color: #fff;
  width: 44px; height: 44px;
  align-items: center; justify-content: center;
}
.spk-header.is-scrolled .spk-header__burger { color: var(--spk-ink); }

/* ============ Mobile nav ============ */
.spk-mobile-nav {
  position: fixed; inset: 0; z-index: var(--spk-z-overlay);
  background: rgba(8, 14, 46, 0.6);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.spk-mobile-nav[hidden] { display: none; }
.spk-mobile-nav__panel {
  position: absolute; inset: 0 0 0 auto;
  width: min(86vw, 380px);
  background: var(--spk-gradient-dark);
  background-color: var(--spk-navy);
  padding: 84px 28px 32px;
  display: flex; flex-direction: column; gap: 28px;
  box-shadow: -20px 0 60px -20px rgba(0,0,0,0.5);
}
.spk-mobile-nav__close {
  position: absolute; top: 22px; right: 22px;
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center; color: #fff;
}
.spk-mobile-nav__nav { display: flex; flex-direction: column; gap: 6px; }
.spk-mobile-nav__nav a {
  color: #fff; font-family: var(--spk-font-display);
  font-size: 26px; font-weight: 500; padding: 12px 0;
  border-bottom: 1px solid var(--spk-line-on-dark);
}
.spk-mobile-nav__bottom { margin-top: auto; display: flex; flex-direction: column; gap: 18px; }
.spk-mobile-nav__lang { display: flex; gap: 14px; }
.spk-mobile-nav__lang-link { color: rgba(255,255,255,0.65); font-weight: 600; letter-spacing: 0.5px; }
.spk-mobile-nav__lang-link.is-active { color: #fff; }

/* ============ Hero (rounded bottom panel) ============ */
.spk-hero {
  padding: calc(var(--spk-header-h) + 70px) 0 96px;
  overflow: hidden;
  color: #fff;
  text-align: center;
  border-radius: 0 0 var(--spk-r-panel) var(--spk-r-panel);
}
.spk-hero__inner { position: relative; z-index: 2; }
.spk-hero__title { max-width: none; margin: 0 auto; }
/* white headline stays on one line; orange accent drops to its own line.
   fit-content + auto margins so the clipped gradient maps to the TEXT box
   (full-width block would sample only the gradient's middle → looks flat). */
.spk-hero__title .spk-accent { display: block; width: fit-content; margin: 0 auto; }
.spk-hero__sub {
  max-width: 760px; margin: 22px auto 0;
  font-size: var(--spk-fs-lead); line-height: var(--spk-lh-lead);
  color: rgba(255, 255, 255, 0.9);
}
.spk-hero__cta { margin-top: 34px; display: flex; justify-content: center; }
.spk-hero__clients { margin-top: 70px; }
.spk-hero__built { font-size: var(--spk-fs-small); color: rgba(255, 255, 255, 0.8); margin-bottom: 24px; }
.spk-hero__client-row {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 46px;
}
.spk-hero__client { display: inline-flex; align-items: center; opacity: 0.92; }
.spk-hero__client img { height: 26px; width: auto; }

/* ============ Statement ============ */
.spk-statement { text-align: center; padding-top: 110px; padding-bottom: 0; }
.spk-statement__text {
  max-width: 820px; margin: 0 auto;
  font-family: var(--spk-font-display);
  font-size: var(--spk-fs-h2md); line-height: var(--spk-lh-h2md);
  letter-spacing: var(--spk-ls-h2md);
  font-weight: 500; color: var(--spk-ink);
}
/* media floats DOWN over the dark How It Works (negative bottom margin + z-index);
   the white statement bg ends above, so navy wraps the card sides/bottom. */
.spk-statement__media {
  margin: 56px auto -150px; max-width: 1040px;
  border-radius: var(--spk-r-panel); overflow: hidden;
  position: relative; z-index: 3;
}
.spk-statement__media img { width: 100%; height: auto; display: block; }

/* ============ How It Works ============ */
.spk-howitworks__heading { text-align: center; margin-bottom: 56px; }
.spk-howitworks__grid { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
/* gradient connector — only in the gaps BETWEEN panels (not behind them).
   col width = (100% - 2*24px gap)/3; two short segments bridge the two gaps. */
.spk-howitworks__grid::before,
.spk-howitworks__grid::after {
  content: ""; position: absolute; top: calc(36px + 28px); /* card pad-top + half 56px circle */
  width: 28px; height: 2px; z-index: 2;
  background: linear-gradient(90deg, var(--spk-orange), var(--spk-magenta));
}
.spk-howitworks__grid::before { left: calc((100% - 48px) / 3 - 2px); }
.spk-howitworks__grid::after  { left: calc((100% - 48px) / 3 * 2 + 24px - 2px); }
@media (max-width: 1023px) {
  .spk-howitworks__grid::before, .spk-howitworks__grid::after { display: none; }
}

/* ============ Competitive Edge ============ */
.spk-competitive__heading { margin-bottom: 18px; }
.spk-competitive__sub { margin-bottom: 56px; }
.spk-competitive__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }

/* ============ Outcomes carousel (3 columns, center active) ============ */
.spk-outcomes__heading { margin-bottom: 48px; }
.spk-outcomes__carousel { position: relative; }
.spk-outcomes__track {
  display: flex; gap: 0;
  overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 8px 0 28px;
  -ms-overflow-style: none; scrollbar-width: none;
}
.spk-outcomes__track::-webkit-scrollbar { display: none; }
.spk-outcome-card { scroll-snap-align: center; flex: 0 0 33.333%; padding: 0 28px; }
.spk-outcomes__nav { display: flex; justify-content: center; gap: 16px; margin-top: 8px; }

/* ============ Use Cases (two opposite marquee rows) ============ */
.spk-usecases { overflow: hidden; }
.spk-usecases__heading { margin-bottom: 18px; }
.spk-usecases__sub { margin-bottom: 48px; }
.spk-usecases__rows { display: flex; flex-direction: column; gap: 16px; width: 100vw; margin-left: calc(50% - 50vw); }
.spk-uc-row { overflow: hidden; }
.spk-uc-track { display: flex; gap: 16px; width: max-content; will-change: transform; }
.spk-uc-track--l { animation: spk-marquee-l 46s linear infinite; }
.spk-uc-track--r { animation: spk-marquee-r 46s linear infinite; }
.spk-uc-row:hover .spk-uc-track { animation-play-state: paused; }
@keyframes spk-marquee-l { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes spk-marquee-r { from { transform: translateX(-50%); } to { transform: translateX(0); } }
@media (prefers-reduced-motion: reduce) {
  .spk-uc-track--l, .spk-uc-track--r { animation: none; }
}
.spk-usecases__cta { margin-top: 48px; display: flex; justify-content: center; }

/* ============ Solution (white cards) ============ */
.spk-solution { background: var(--spk-gradient-dark); background-color: var(--spk-navy); }
.spk-solution__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 64px; align-items: start; }
.spk-solution__intro { position: sticky; top: 120px; }
.spk-solution__heading { margin-bottom: 20px; }
.spk-solution__sub { color: var(--spk-ink-on-dark-muted); font-size: var(--spk-fs-lead); line-height: var(--spk-lh-lead); max-width: 380px; }
.spk-solution__cards { display: flex; flex-direction: column; gap: 18px; }

/* ============ Code ============ */
.spk-code { background: var(--spk-bg-dark); }
.spk-code__inner { max-width: var(--spk-container-narrow); }
.spk-code__heading { margin-bottom: 16px; }
.spk-code__sub { margin-bottom: 44px; }
.spk-code__cta { margin-top: 36px; }

/* ============ One Home (text left in container · art bleeds to screen edge) ============ */
.spk-onehome__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  padding-left: max(24px, calc((100vw - var(--spk-container)) / 2 + 24px));
}
.spk-onehome__copy { max-width: 520px; }
.spk-onehome__heading { margin-bottom: 24px; }
.spk-onehome__text { font-size: var(--spk-fs-lead); line-height: 1.7; color: var(--spk-ink-muted); }
.spk-onehome__art {
  border-radius: 24px 0 0 24px; overflow: hidden;     /* round left only — right runs off-screen */
  background: var(--spk-bg-soft); box-shadow: var(--spk-shadow-card);
  aspect-ratio: 3 / 2;
}
.spk-onehome__art img { width: 100%; height: 100%; object-fit: cover; display: block; }
.spk-onehome__art .spk-wf-block { height: 100%; border: 0; border-radius: 0; }
@media (max-width: 1023px) {
  .spk-onehome__grid { grid-template-columns: 1fr; gap: 36px; padding-left: 24px; padding-right: 24px; }
  .spk-onehome__art { border-radius: 18px; aspect-ratio: 16/10; }
}

/* ============ Resources (clean: art + bold title, single CTA) ============ */
.spk-resources__heading { margin-bottom: 14px; }
.spk-resources__sub { margin-bottom: 56px; }
.spk-resources__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.spk-resources__cta { margin-top: 56px; display: flex; justify-content: center; }

/* ============ Mission ============ */
.spk-mission-wrap { padding: 40px 0 120px; }
.spk-mission { position: relative; border-radius: var(--spk-r-code); overflow: hidden; padding: 88px 32px; text-align: center; color: #fff; }
.spk-mission__inner { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; }
.spk-mission__heading { margin-bottom: 22px; }
.spk-mission__text { font-size: var(--spk-fs-lead); line-height: 1.7; color: rgba(255,255,255,0.92); }

/* ============ Final CTA (two lines: black + gradient) ============ */
.spk-final-cta { padding: 110px 0; }
.spk-final-cta__heading .spk-accent { display: block; width: fit-content; margin: 0 auto; }
.spk-final-cta__cta { margin-top: 36px; display: flex; justify-content: center; }

/* ============ Footer (3 columns, full presence) ============ */
.spk-footer { background: var(--spk-bg-light); border-top: 1px solid var(--spk-line); padding: 80px 0 36px; }
.spk-footer__inner { max-width: var(--spk-container); margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: 1.6fr 3fr; gap: 64px; align-items: start; }
.spk-footer__brand img { height: 34px; width: auto; margin-bottom: 20px; }
.spk-footer__tagline { color: var(--spk-ink-muted); font-size: 16px; line-height: 26px; max-width: 320px; }
.spk-footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.spk-footer__col-title { font-weight: 700; font-size: 16px; color: var(--spk-ink); margin-bottom: 20px; }
.spk-footer__col ul { display: flex; flex-direction: column; gap: 14px; }
.spk-footer__col a { color: var(--spk-ink-muted); font-size: 16px; transition: color var(--spk-dur-quick) var(--spk-ease); }
.spk-footer__col a:hover { color: var(--spk-blue); }
.spk-footer__bottom {
  max-width: var(--spk-container); margin: 56px auto 0; padding: 28px 24px 0;
  border-top: 1px solid var(--spk-line);
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.spk-footer__copy { color: var(--spk-ink-muted); font-size: 14px; }
.spk-footer__legal { display: flex; gap: 24px; }
.spk-footer__legal a { color: var(--spk-ink-muted); font-size: 14px; }
.spk-footer__legal a:hover { color: var(--spk-blue); }
@media (max-width: 1023px) {
  .spk-footer__inner { grid-template-columns: 1fr; gap: 40px; }
  .spk-footer__cols { grid-template-columns: repeat(3, 1fr); gap: 20px; }
}
@media (max-width: 600px) {
  .spk-footer__cols { grid-template-columns: 1fr; gap: 28px; }
  .spk-footer__bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
}

/* ====================== Responsive ====================== */
@media (max-width: 1023px) {
  .spk-section { padding: 80px 0; }
  .spk-header__nav, .spk-header__lang { display: none; }
  .spk-header__burger { display: inline-flex; }
  .spk-howitworks__grid { grid-template-columns: 1fr; gap: 18px; }
  .spk-solution__grid { grid-template-columns: 1fr; gap: 36px; }
  .spk-solution__intro { position: static; }
  .spk-usecases__mosaic { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
  .spk-uc-tile--0, .spk-uc-tile--5 { grid-column: span 2; }
  .spk-uc-tile--2, .spk-uc-tile--7 { grid-row: span 1; }
  .spk-resources__grid { grid-template-columns: 1fr; gap: 24px; }
  .spk-footer__inner { grid-template-columns: 1fr; gap: 36px; }
  .spk-outcome-card { flex-basis: 80%; }
}

@media (max-width: 600px) {
  .spk-section { padding: 64px 0; }
  .spk-container { padding: 0 18px; }
  .spk-hero { padding-top: calc(var(--spk-header-h) + 40px); }
  .spk-hero__client-row { gap: 28px; }
  .spk-statement { padding-top: 72px; margin-bottom: -90px; }
  .spk-competitive__grid { grid-template-columns: 1fr; }
  .spk-usecases__mosaic { grid-template-columns: 1fr; grid-auto-rows: 170px; }
  .spk-uc-tile--0, .spk-uc-tile--5 { grid-column: span 1; }
  .spk-footer__cols { grid-template-columns: repeat(2, 1fr); gap: 28px 18px; }
  .spk-outcome-card { flex-basis: 90%; }
}

/* ============================================================
   SUBPAGES (use-cases / blog)
   ============================================================ */

/* Header forced into its solid (scrolled) look from the top — subpage heroes
   sit on white, not the dark gradient. Mirrors the .is-scrolled treatment. */
.spk-header--solid .spk-header__inner {
  height: var(--spk-header-h-sticky);
  background: #fff;
  box-shadow: 0 14px 34px -18px rgba(17, 33, 111, 0.28);
}
.spk-header--solid .spk-header__brand .spk-logo--white { display: none; }
.spk-header--solid .spk-header__brand .spk-logo--color { display: block; }
.spk-header--solid .spk-header__nav a { color: var(--spk-ink); }
.spk-header--solid .spk-header__nav a:hover { color: var(--spk-blue); }
.spk-header--solid .spk-header__lang-link { color: var(--spk-ink-dim); }
.spk-header--solid .spk-header__lang-link.is-active,
.spk-header--solid .spk-header__lang-link:hover { color: var(--spk-ink); }
.spk-header--solid .spk-header__burger { color: var(--spk-ink); }
.spk-header--solid .spk-pill--header { border-color: rgba(245, 114, 76, 0.55); color: var(--spk-ink); }
.spk-header--solid .spk-pill--header:hover { background: var(--spk-blue); color: #fff; border-color: var(--spk-blue); }

/* ---- Page hero (white, centered) ---- */
.spk-page-hero {
  background: #fff;
  padding: calc(var(--spk-header-h-sticky) + 86px) 0 16px;
  text-align: center;
}
.spk-page-hero__title { color: var(--spk-ink); }
.spk-page-hero__sub { margin-top: 20px; }

/* ---- Use Cases page: 2-col card grid ---- */
.spk-uc-page { padding-top: 40px; }
.spk-uc-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.spk-uc-card {
  display: flex; flex-direction: column;
  background: #fff; border-radius: var(--spk-r-card);
  box-shadow: var(--spk-shadow-card); overflow: hidden;
}
.spk-uc-card__media { aspect-ratio: 16 / 9; overflow: hidden; background: var(--spk-bg-soft); }
.spk-uc-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--spk-dur-slow) var(--spk-ease); }
.spk-uc-card:hover .spk-uc-card__media img { transform: scale(1.05); }
.spk-uc-card__body { padding: 28px 30px 32px; }
.spk-uc-card__title { font-family: var(--spk-font-display); font-size: 24px; font-weight: 600; letter-spacing: -0.3px; color: var(--spk-ink); margin-bottom: 12px; }
.spk-uc-card__desc { color: var(--spk-ink-muted); font-size: 15px; line-height: 24px; }

/* ---- Case studies (dark photo cards) ---- */
.spk-cs__heading { margin-bottom: 48px; }
.spk-cs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.spk-cs-card {
  position: relative; display: flex; align-items: flex-end;
  min-height: 440px; border-radius: var(--spk-r-code); overflow: hidden;
  background: var(--spk-navy); color: #fff;
}
.spk-cs-card__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.spk-cs-card::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(11,20,60,0) 28%, rgba(11,20,60,0.55) 62%, rgba(11,20,60,0.92) 100%);
}
.spk-cs-card__body { position: relative; z-index: 2; padding: 40px; }
.spk-cs-card__title { font-family: var(--spk-font-display); font-size: 30px; font-weight: 600; line-height: 1.2; letter-spacing: -0.4px; margin-bottom: 24px; max-width: 360px; }

/* ---- Blog featured (gradient panel) ---- */
.spk-blog-featured-wrap { background: #fff; padding: 24px 0 0; }
/* gradient panel acts as a frame: 48px padding all round, art is an inset
   rounded rectangle (not edge-to-edge) — matches spark.ai featured block. */
.spk-blog-featured {
  display: grid; grid-template-columns: minmax(0, 0.82fr) 1fr; align-items: center;
  gap: 48px; padding: 48px;
  background: var(--spk-gradient); background-color: var(--spk-navy);
  border-radius: var(--spk-r-code); color: #fff;
}
.spk-blog-featured__media { position: relative; overflow: hidden; border-radius: 16px; aspect-ratio: 7 / 5; }
.spk-blog-featured__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform var(--spk-dur-slow) var(--spk-ease); }
.spk-blog-featured:hover .spk-blog-featured__media img { transform: scale(1.04); }
.spk-blog-featured__body { display: flex; flex-direction: column; justify-content: center; }
.spk-blog-featured__tag { display: inline-block; width: fit-content; font-size: 13px; font-weight: 600; letter-spacing: 0.6px; text-transform: uppercase; color: rgba(255,255,255,0.8); margin-bottom: 16px; }
.spk-blog-featured__title { color: #fff; }
.spk-blog-featured__excerpt { color: rgba(255,255,255,0.88); font-size: 16px; line-height: 26px; margin: 18px 0 28px; max-width: 460px; }
.spk-blog-featured__more { display: inline-flex; align-items: center; gap: 10px; color: #fff; font-weight: 600; }

/* ---- Blog grid (3-col cards + stat overlay + pagination) ---- */
.spk-blog { padding-top: 64px; }
.spk-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.spk-blog-card { display: flex; flex-direction: column; background: #fff; border-radius: var(--spk-r-card); box-shadow: var(--spk-shadow-soft); overflow: hidden; }
.spk-blog-card__media { position: relative; display: block; aspect-ratio: 16 / 10; overflow: hidden; background: var(--spk-bg-soft); }
.spk-blog-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--spk-dur-slow) var(--spk-ease); }
.spk-blog-card:hover .spk-blog-card__media img { transform: scale(1.05); }
.spk-blog-card__media--stat {
  background: var(--spk-gradient-dark); background-color: var(--spk-navy);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 24px; gap: 10px;
}
.spk-blog-card__stat-num { font-family: var(--spk-font-display); font-size: 56px; font-weight: 700; line-height: 1; }
.spk-blog-card__stat-cap { color: rgba(255,255,255,0.82); font-size: 13px; line-height: 18px; max-width: 220px; }
.spk-blog-card__body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 8px; }
.spk-blog-card__title { font-family: var(--spk-font-display); font-size: 19px; font-weight: 600; line-height: 1.35; letter-spacing: -0.2px; color: var(--spk-ink); }
.spk-blog-card__title a:hover { color: var(--spk-blue); }
.spk-blog-card__excerpt { color: var(--spk-ink-muted); font-size: 14px; line-height: 22px; }

.spk-pagination { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 56px; }
.spk-pagination__edge { display: inline-flex; align-items: center; gap: 6px; color: var(--spk-ink-muted); font-size: 14px; font-weight: 500; padding: 0 10px; }
.spk-pagination__num { width: 40px; height: 40px; display: inline-grid; place-items: center; border-radius: 10px; color: var(--spk-ink-muted); font-weight: 600; font-size: 15px; }
.spk-pagination__num.is-active { background: var(--spk-blue); color: #fff; }

/* ---- Subpage responsive ---- */
@media (max-width: 1023px) {
  .spk-uc-cards { gap: 22px; }
  .spk-cs-grid { gap: 22px; }
  .spk-blog-grid { grid-template-columns: repeat(2, 1fr); }
  .spk-blog-featured { grid-template-columns: 1fr; gap: 32px; padding: 32px; }
  .spk-blog-featured__media { aspect-ratio: 16 / 10; }
}
@media (max-width: 600px) {
  .spk-uc-cards { grid-template-columns: 1fr; }
  .spk-cs-grid { grid-template-columns: 1fr; }
  .spk-cs-card { min-height: 340px; }
  .spk-blog-grid { grid-template-columns: 1fr; }
  .spk-page-hero { padding-top: calc(var(--spk-header-h-sticky) + 48px); }
  .spk-blog-featured { padding: 22px; gap: 22px; }
  .spk-blog-card__stat-num { font-size: 46px; }
}
