:root {
  --blue: #0064ff;
  --blue-deep: #003b97;
  --cyan: #7ae5ff;
  --ink: #101827;
  --graphite: #2b2b2b;
  --mist: #f5f7fa;
  --line: #d7e0ee;
  --white: #fff;
  --shadow: 0 24px 70px rgba(0, 71, 194, .18);
  --shell: min(1180px, calc(100vw - 48px));
}

* { box-sizing: border-box; }
html { scroll-behavior: auto; }
body {
  margin: 0;
  background: var(--white);
  color: var(--graphite);
  font-family: "Finlandica", Arial, sans-serif;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0;
}
body.menu-open { overflow: hidden; }
a { color: inherit; }
img { display: block; max-width: 100%; }
h1, h2, h3, .brand, .button, .eyebrow { color: var(--ink); font-family: "KoHo", "Segoe UI", sans-serif; letter-spacing: 0; line-height: 1.08; }
h1, h2, h3, p { margin-top: 0; }
h1 { font-size: clamp(2.7rem, 5.5vw, 6.65rem); margin-bottom: 24px; }
h2 { font-size: clamp(2rem, 3vw, 3.6rem); margin-bottom: 18px; }
h3 { font-size: clamp(1.24rem, 1.5vw, 1.65rem); margin-bottom: 12px; }
p { margin-bottom: 18px; }
.shell { margin-inline: auto; width: var(--shell); }
.section { padding-block: clamp(76px, 10vw, 136px); }
.sr-only { clip: rect(0 0 0 0); clip-path: inset(50%); height: 1px; overflow: hidden; position: absolute; white-space: nowrap; width: 1px; }
.skip-link { background: var(--white); color: var(--ink); left: 16px; padding: 12px 16px; position: fixed; top: -80px; z-index: 30; }
.skip-link:focus { top: 16px; }
.eyebrow {
  align-items: center;
  color: var(--blue);
  display: inline-flex;
  font-size: .88rem;
  font-weight: 700;
  gap: 10px;
  margin-bottom: 18px;
  text-transform: uppercase;
}
.eyebrow::before { background: currentColor; content: ""; height: 2px; width: 28px; }
.button {
  align-items: center;
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  font-size: 1rem;
  font-weight: 700;
  justify-content: center;
  min-height: 54px;
  padding: 14px 22px;
  text-decoration: none;
  transition: background .7s cubic-bezier(.2,.8,.2,1), border .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1);
}
.button:hover { transform: translateY(-3px); }
.button-primary, .button-light { background: var(--blue); color: var(--white); }
.button-light { background: var(--white); color: var(--blue-deep); }
.button-dark { background: var(--ink); color: var(--white); }
.button-ghost { border-color: rgba(255,255,255,.42); color: var(--white); }
.text-link { color: var(--blue); font-family: "KoHo", sans-serif; font-weight: 700; text-decoration: none; }
.page-loader {
  background: var(--blue);
  color: var(--white);
  display: grid;
  inset: 0;
  place-items: center;
  pointer-events: none;
  position: fixed;
  z-index: 40;
}
.page-loader[hidden] { display: none; }
.loader-mark { font-family: "KoHo", sans-serif; font-size: clamp(3rem, 10vw, 8rem); font-weight: 700; }
.site-header {
  align-items: center;
  display: flex;
  gap: 22px;
  justify-content: space-between;
  left: 50%;
  max-width: calc(100vw - 32px);
  backdrop-filter: blur(20px);
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.34);
  border-radius: 999px;
  min-height: 72px;
  padding: 14px 18px;
  position: fixed;
  top: 18px;
  transform: translateX(-50%);
  transition: background .8s ease, box-shadow .8s ease, top .8s ease;
  width: 1240px;
  z-index: 20;
}
.site-header.is-scrolled, .site-header.compact {
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(215,224,238,.82);
  border-radius: 999px;
  box-shadow: 0 12px 42px rgba(16,24,39,.11);
}
.site-header.is-scrolled { top: 10px; }
.brand { align-items: center; color: var(--ink); display: inline-flex; flex: 0 0 auto; font-size: 1.03rem; gap: 12px; text-decoration: none; }
.home-hero .brand { color: var(--white); }
.brand b { display: block; font-size: .83rem; font-weight: 500; opacity: .72; }
.brand-mark {
  align-items: center;
  background: var(--blue);
  border-radius: 14px;
  color: var(--white);
  display: inline-grid;
  font-weight: 700;
  height: 50px;
  justify-items: center;
  width: 62px;
}
.site-nav { align-items: center; display: flex; font-size: .92rem; font-weight: 600; gap: clamp(10px, 1.4vw, 22px); }
.site-nav a { color: var(--ink); text-decoration: none; white-space: nowrap; }
.site-nav a[aria-current="page"] { color: var(--blue); }
.site-nav .nav-cta { background: var(--ink); border-radius: 999px; color: var(--white); padding: 12px 18px; }
.site-header:not(.compact):not(.is-scrolled) .brand,
.site-header:not(.compact):not(.is-scrolled) .site-nav a { color: var(--white); }
.site-header:not(.compact):not(.is-scrolled) .site-nav .nav-cta { background: var(--white); color: var(--blue-deep); }
.menu-toggle { background: transparent; border: 0; display: none; height: 44px; padding: 8px; width: 48px; }
.menu-toggle span:not(.sr-only) { background: var(--ink); display: block; height: 2px; margin: 7px auto; transition: transform .7s ease, opacity .7s ease; width: 28px; }
.site-header:not(.compact):not(.is-scrolled) .menu-toggle span:not(.sr-only) { background: var(--white); }

.hero { align-items: center; background: var(--blue); display: flex; min-height: 100svh; overflow: hidden; position: relative; }
.hero-media, .hero-wash, .hero-grid { inset: 0; position: absolute; }
.hero-media img { filter: saturate(1.15) contrast(1.06); height: 100%; object-fit: cover; object-position: center; opacity: .24; width: 100%; }
.hero-wash { background: radial-gradient(circle at 70% 20%, rgba(255,255,255,.24), transparent 32%), linear-gradient(120deg, rgba(0,100,255,.98), rgba(0,63,170,.9)); }
.hero-grid {
  background-image: linear-gradient(rgba(255,255,255,.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.1) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.76), transparent 90%);
}
.hero-layout { display: block; padding-block: clamp(148px, 18vh, 210px) 112px; position: relative; z-index: 1; }
.hero-copy { max-width: 1100px; }
.home-hero h1, .home-hero .eyebrow, .home-hero p { color: var(--white); }
.hero-title { font-size: clamp(3.4rem, 9.5vw, 9rem); line-height: .89; margin-bottom: 26px; overflow-wrap: anywhere; }
.hero-title span { display: block; overflow: hidden; }
.hero-lead { color: rgba(255,255,255,.9); font-size: clamp(1.12rem, 1.8vw, 1.45rem); max-width: 740px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.scroll-cue { bottom: 34px; color: var(--white); display: grid; font-family: "KoHo", sans-serif; font-size: .84rem; gap: 10px; justify-items: center; left: 50%; position: absolute; text-decoration: none; transform: translateX(-50%); transition: opacity .8s ease, transform .8s ease; z-index: 2; }
.scroll-cue i { background: rgba(255,255,255,.42); display: block; height: 42px; overflow: hidden; position: relative; width: 1px; }
.scroll-cue i::after { animation: cue 1.8s ease infinite; background: var(--white); content: ""; inset: 0; position: absolute; }
.scroll-cue.is-hidden { opacity: 0; transform: translate(-50%, 18px); }
@keyframes cue { 0% { transform: translateY(-100%); } 100% { transform: translateY(100%); } }

.section-intro { max-width: 820px; margin-bottom: clamp(34px, 5vw, 64px); }
.split-intro { align-items: end; display: flex; justify-content: space-between; max-width: none; gap: 28px; }
.split-intro > p { max-width: 390px; }
.text-block { color: var(--graphite); font-size: clamp(1.1rem, 1.7vw, 1.35rem); line-height: 1.62; }
.text-block p + p { margin-top: 22px; }
.pain-layout { align-items: start; display: grid; gap: clamp(34px, 6vw, 80px); grid-template-columns: 1fr .86fr; }
.problem-grid, .service-grid, .post-grid, .value-grid, .deliverable-grid, .use-grid, .why-grid { display: grid; gap: 18px; }
.problem-grid { grid-template-columns: repeat(3, 1fr); }
.problem-grid article { border-top: 2px solid var(--blue); padding: 28px 22px 0 0; }
.services-band, .values-band { background: var(--mist); }
.service-grid { grid-template-columns: repeat(4, 1fr); }
.service-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 20px 50px rgba(0,100,255,.08);
  display: flex;
  flex-direction: column;
  min-height: 360px;
  padding: clamp(22px, 2vw, 32px);
  position: relative;
  text-decoration: none;
  transition: border .7s ease, box-shadow .7s ease, transform .7s cubic-bezier(.2,.8,.2,1);
}
.service-card:hover { border-color: var(--blue); box-shadow: var(--shadow); transform: translateY(-7px); }
.service-card span, .process-step span { color: var(--blue); display: block; font-family: "KoHo", sans-serif; font-weight: 700; margin-bottom: 72px; }
.service-card p { margin-bottom: 0; }
.process-stage { background: var(--blue); color: var(--white); min-height: 300vh; position: relative; }
.process-sticky { align-items: center; display: flex; min-height: 100vh; overflow: hidden; position: sticky; top: 0; }
.process-frame { align-items: center; display: grid; gap: clamp(36px, 6vw, 90px); grid-template-columns: .9fr 1.1fr; min-height: 100vh; padding-block: 92px; }
.process-copy h2, .process-copy .eyebrow, .process-step h3 { color: var(--white); }
.process-copy p { color: rgba(255,255,255,.78); }
.process-copy h2 { font-size: clamp(2.7rem, 6vw, 6rem); line-height: .92; }
.process-reel { display: grid; gap: 16px; }
.process-step {
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 8px;
  opacity: .26;
  padding: 22px clamp(20px, 2.4vw, 32px);
  transform: translateY(36px);
}
.process-step span { color: rgba(255,255,255,.74); margin-bottom: 8px; }
.process-step h3 { margin-bottom: 8px; }
.process-step p { color: rgba(255,255,255,.82); margin-bottom: 0; }
.local-section, .contact-layout, .feature-columns, .story-grid, .audience-grid { display: grid; gap: clamp(28px, 5vw, 74px); grid-template-columns: repeat(2, minmax(0, 1fr)); }
.local-map { background: var(--blue); border-radius: 8px; color: var(--white); padding: clamp(28px, 4vw, 62px); }
.local-map h2, .local-map .eyebrow { color: var(--white); }
.tag-row, .filter-row, .contact-notes { display: flex; flex-wrap: wrap; gap: 10px; }
.tag-row span, .filter-row span, .contact-notes span {
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.32);
  border-radius: 8px;
  display: inline-flex;
  padding: 9px 13px;
}
.filter-row { margin-bottom: 34px; }
.filter-row span, .contact-notes span { background: var(--mist); border-color: var(--line); color: var(--ink); }
.proof-list { display: grid; gap: 10px; }
.proof-list article { border-bottom: 1px solid var(--line); padding: 22px 0; }
.journal-band { background: #ebf3ff; }
.why-band { background: #eaf2ff; }
.why-grid { grid-template-columns: repeat(4, 1fr); }
.why-card { background: var(--white); border: 1px solid var(--line); border-radius: 8px; padding: clamp(22px, 2vw, 30px); }
.why-card h3 { color: var(--blue); }
.post-grid { grid-template-columns: repeat(3, 1fr); }
.post-card, .article-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  min-height: 290px;
  padding: clamp(22px, 2.5vw, 36px);
}
.post-card > p, .article-card > p:first-child { color: var(--blue); font-family: "KoHo", sans-serif; font-size: .9rem; font-weight: 700; text-transform: uppercase; }
.post-card a { color: var(--ink); font-family: "KoHo", sans-serif; font-weight: 700; }
.cta-band {
  background: var(--blue);
  border-radius: 8px;
  color: var(--white);
  margin-block: clamp(72px, 10vw, 132px);
  overflow: hidden;
  padding: clamp(34px, 6vw, 84px);
  position: relative;
}
.cta-band::after { border: 1px solid rgba(255,255,255,.24); border-radius: 50%; content: ""; height: min(52vw, 620px); position: absolute; right: -22%; top: -60%; width: min(52vw, 620px); }
.cta-band h2, .cta-band .eyebrow { color: var(--white); max-width: 840px; position: relative; z-index: 1; }
.cta-band .button { position: relative; z-index: 1; }
.site-footer { background: var(--ink); color: rgba(255,255,255,.74); padding-block: 54px; }
.site-footer .brand { color: var(--white); margin-bottom: 20px; }
.footer-grid { display: grid; gap: 32px; grid-template-columns: minmax(250px, 1.5fr) 1fr 1fr; }
.footer-grid p { max-width: 390px; }
.footer-links { display: grid; gap: 12px; align-content: start; }
.footer-links a { color: var(--white); text-decoration: none; }

.page-hero, .service-hero { padding-top: clamp(170px, 21vw, 260px); }
.page-hero { max-width: 1060px; padding-bottom: clamp(48px, 7vw, 90px); }
.page-hero > p:last-child { font-size: clamp(1.12rem, 1.6vw, 1.4rem); max-width: 760px; }
.service-hero {
  align-items: end;
  display: grid;
  gap: clamp(28px, 5vw, 72px);
  grid-template-columns: minmax(0, 1.2fr) 390px;
  padding-bottom: clamp(62px, 8vw, 106px);
}
.service-hero h1 { font-size: clamp(2.6rem, 4.7vw, 5.4rem); }
.service-hero > div > p { font-size: clamp(1.1rem, 1.5vw, 1.34rem); max-width: 720px; }
.brief-card, .story-panel, .flow-card, .contact-aside {
  background: var(--ink);
  border-radius: 8px;
  box-shadow: var(--shadow);
  color: var(--white);
  padding: clamp(26px, 4vw, 48px);
}
.brief-card h2, .story-panel strong, .contact-aside h2 { color: var(--white); font-family: "KoHo", sans-serif; font-size: clamp(1.55rem, 2vw, 2.2rem); }
.brief-card ul { margin: 24px 0 0; padding-left: 18px; }
.brief-card li { border-top: 1px solid rgba(255,255,255,.18); padding: 14px 0; }
.rich-copy p { font-size: clamp(1.05rem, 1.35vw, 1.23rem); }
.story-panel { background: linear-gradient(145deg, var(--blue), var(--blue-deep)); min-height: 380px; }
.story-panel strong { display: block; font-size: clamp(3rem, 7vw, 7rem); margin-bottom: 86px; }
.value-grid { grid-template-columns: repeat(4, 1fr); }
.value-grid article { border-left: 2px solid var(--blue); padding-left: 20px; }
.check-list { display: grid; gap: 16px; list-style: none; margin: 0; padding: 0; }
.check-list li {
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  font-size: clamp(1.08rem, 1.45vw, 1.32rem);
  padding: 0 0 16px 38px;
  position: relative;
}
.check-list li::before { border: 2px solid var(--blue); content: ""; height: 14px; left: 0; position: absolute; top: 7px; transform: rotate(45deg); width: 14px; }
.deliverable-grid { grid-template-columns: repeat(4, 1fr); }
.deliverable-grid article { background: var(--white); border: 1px solid var(--line); border-radius: 8px; min-height: 220px; padding: 28px; }
.use-grid { grid-template-columns: repeat(3, 1fr); }
.use-grid article { background: var(--blue); border-radius: 8px; color: var(--white); padding: clamp(26px, 3vw, 42px); }
.use-grid h2 { color: var(--white); font-size: clamp(1.45rem, 2vw, 2.2rem); }
.flow-card { align-items: center; background: var(--blue); display: grid; gap: 12px; grid-template-columns: 1fr auto 1fr auto; }
.flow-card span { background: var(--white); border-radius: 8px; color: var(--ink); font-family: "KoHo", sans-serif; font-weight: 700; min-height: 72px; padding: 22px 12px; text-align: center; }
.flow-card i { background: var(--cyan); display: block; height: 2px; position: relative; width: 24px; }
.flow-card i::after { border-right: 2px solid var(--cyan); border-top: 2px solid var(--cyan); content: ""; height: 8px; position: absolute; right: 0; top: -4px; transform: rotate(45deg); width: 8px; }
.faq-list { display: grid; gap: 12px; }
details { background: var(--mist); border: 1px solid var(--line); border-radius: 8px; padding: 22px clamp(18px, 2.5vw, 30px); }
summary { color: var(--ink); cursor: pointer; font-family: "KoHo", sans-serif; font-size: clamp(1.08rem, 1.4vw, 1.28rem); font-weight: 700; }
details p { margin: 16px 0 0; max-width: 860px; }
.article-grid { display: grid; gap: 18px; grid-template-columns: repeat(3, 1fr); }
.article-card { min-height: 324px; }
.article-card-media {
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  display: block;
  margin-bottom: 24px;
  overflow: hidden;
}
.article-card-media img {
  height: 100%;
  object-fit: cover;
  transition: transform .9s cubic-bezier(.2,.8,.2,1);
  width: 100%;
}
.article-card:hover .article-card-media img { transform: scale(1.045); }
.article-card h2 { font-size: clamp(1.35rem, 1.8vw, 2rem); }
.article-card div { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 18px; }
.article-card div span { background: #dceaff; border-radius: 8px; color: var(--blue-deep); font-size: .9rem; padding: 8px 10px; }
.article-card.featured { background: var(--blue); color: var(--white); grid-column: span 2; }
.article-card.featured h2, .article-card.featured > p:first-child { color: var(--white); }
.article-card.featured div span { background: rgba(255,255,255,.2); color: var(--white); }
.article-card.featured .text-link { color: var(--white); }
.article-card .text-link { display: inline-block; margin-top: 12px; }
.article-page { max-width: 900px; padding-bottom: clamp(54px, 8vw, 100px); padding-top: clamp(170px, 21vw, 250px); }
.article-page h1 { font-size: clamp(2.55rem, 5.2vw, 5.7rem); }
.article-deck { color: var(--graphite); font-size: clamp(1.16rem, 1.8vw, 1.48rem); max-width: 760px; }
.article-cover {
  aspect-ratio: 16 / 8;
  border-radius: 8px;
  box-shadow: var(--shadow);
  margin: clamp(30px, 5vw, 58px) 0 0;
  overflow: hidden;
}
.article-cover img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}
.article-body { color: var(--ink); font-size: clamp(1.06rem, 1.35vw, 1.24rem); max-width: 760px; padding-top: 34px; }
.article-body h2 { color: var(--blue); font-size: clamp(1.65rem, 2.6vw, 2.8rem); margin-top: 46px; }
.article-body h3 { color: var(--blue-deep); font-size: clamp(1.35rem, 2vw, 2rem); margin-top: 36px; }
.article-body p { line-height: 1.7; }
.nav-article-link {
  background: var(--blue);
  border-radius: 999px;
  color: var(--white);
  font: 700 1rem "KoHo", sans-serif;
  padding: 12px 18px;
  text-decoration: none;
}
.contact-aside a { color: var(--cyan); display: inline-block; font-weight: 700; margin-bottom: 28px; }
.contact-form { border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); padding: clamp(22px, 4vw, 48px); }
.field-pair { display: grid; gap: 16px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
label { color: var(--ink); display: grid; font-weight: 600; gap: 8px; margin-bottom: 18px; }
input, textarea, select {
  background: var(--mist);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--ink);
  font: inherit;
  letter-spacing: 0;
  min-height: 54px;
  padding: 13px 15px;
  width: 100%;
}
textarea { resize: vertical; }
input:focus, textarea:focus, select:focus { border-color: var(--blue); outline: 3px solid rgba(0,100,255,.18); }
.form-actions { align-items: center; display: flex; flex-wrap: wrap; gap: 18px; }
.form-actions p { color: var(--blue-deep); margin: 0; }

@media (max-width: 1080px) {
  .site-header { width: calc(100vw - 24px); top: 12px; }
  .menu-toggle { display: block; z-index: 2; }
  .site-nav {
    background: rgba(255,255,255,.98);
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow);
    display: grid;
    gap: 4px;
    left: 0;
    opacity: 0;
    padding: 92px 18px 18px;
    pointer-events: none;
    position: absolute;
    top: -1px;
    transform: translateY(-16px);
    transition: opacity .7s ease, transform .7s ease;
    width: 100%;
    z-index: -1;
  }
  .site-nav a { border-radius: 8px; padding: 12px; }
  .site-nav .nav-cta { text-align: center; }
  .site-header:not(.compact):not(.is-scrolled) .site-nav a { color: var(--ink); }
  .site-header:not(.compact):not(.is-scrolled) .site-nav .nav-cta { background: var(--ink); color: var(--white); }
  .menu-open .site-header:not(.compact):not(.is-scrolled) .menu-toggle span:not(.sr-only) { background: var(--ink); }
  .menu-open .site-nav { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .menu-open .menu-toggle span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
  .menu-open .menu-toggle span:nth-child(2) { opacity: 0; }
  .menu-open .menu-toggle span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }
  .service-hero { grid-template-columns: 1fr; }
  .service-grid, .deliverable-grid, .value-grid { grid-template-columns: repeat(2, 1fr); }
  .process-frame { grid-template-columns: 1fr; min-height: auto; }
  .process-sticky { min-height: auto; position: relative; }
  .process-stage { min-height: auto; }
  .process-step { opacity: 1; transform: none; }
  .article-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  :root { --shell: min(100vw - 28px, 1180px); }
  body { font-size: 17px; }
  h1 { font-size: clamp(2.35rem, 10vw, 4rem); }
  .section { padding-block: 72px; }
  .site-header { max-width: calc(100vw - 16px); padding: 12px; top: 8px; }
  .brand { gap: 9px; font-size: .94rem; }
  .brand-mark { height: 44px; width: 54px; }
  .hero { min-height: 100svh; }
  .hero-layout { padding-bottom: 108px; padding-top: 130px; }
  .hero-media img { object-position: 62% center; }
  .hero-actions, .form-actions { align-items: stretch; flex-direction: column; }
  .button { width: 100%; }
  .problem-grid, .service-grid, .post-grid, .footer-grid, .local-section, .feature-columns, .story-grid, .audience-grid, .use-grid, .article-grid, .contact-layout, .field-pair, .deliverable-grid, .value-grid, .process-reel, .pain-layout, .why-grid { grid-template-columns: 1fr; }
  .split-intro { align-items: start; flex-direction: column; }
  .service-card { min-height: 250px; }
  .service-card span { margin-bottom: 40px; }
  .process-frame { min-height: auto; padding-block: 76px; }
  .local-map, .cta-band { padding: 28px; }
  .page-hero, .service-hero { padding-top: 140px; }
  .brief-card { order: -1; }
  .story-panel { min-height: 290px; }
  .story-panel strong { margin-bottom: 50px; }
  .flow-card { grid-template-columns: 1fr; }
  .flow-card i { height: 24px; justify-self: center; width: 2px; }
  .flow-card i::after { bottom: 0; left: -4px; right: auto; top: auto; transform: rotate(135deg); }
  .article-card.featured { grid-column: auto; }
  .scroll-cue { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .page-loader { display: none; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
}
