body {
  background: var(--background-main);
  color: var(--text-main);
  font-family: Inter, Manrope, "Segoe UI", Arial, sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
body.menu-open, body.modal-open { overflow: hidden; }
::selection { background: var(--accent-blue); color: white; }
:focus-visible { outline: 2px solid var(--accent-blue-bright); outline-offset: 4px; }
.container { width: var(--container); margin-inline: auto; }
.section { padding: clamp(76px, 9vw, 132px) 0; position: relative; }
.section--soft { background: var(--background-soft); }
.section--compact { padding: clamp(56px, 7vw, 92px) 0; }
.eyebrow {
  color: var(--accent-blue-bright);
  font-size: 0.73rem;
  font-weight: 750;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.display {
  max-width: 950px;
  margin-top: 14px;
  font-size: clamp(2.25rem, 5.8vw, 5.2rem);
  line-height: 0.99;
  letter-spacing: -0.055em;
  font-weight: 620;
}
.display--medium { font-size: clamp(2.1rem, 4.6vw, 4.15rem); }
.display--small { font-size: clamp(1.85rem, 3.4vw, 3.2rem); }
.accent {
  color: #9cc1ff;
  font-family: Georgia, "Times New Roman", serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.035em;
}
.lead {
  max-width: 720px;
  color: var(--text-muted);
  font-size: clamp(1rem, 1.4vw, 1.18rem);
}
.section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 36px;
  margin-bottom: 44px;
}
.section-heading .lead { max-width: 500px; }
.muted { color: var(--text-muted); }
.blue { color: var(--accent-blue-bright); }
.divider { height: 1px; background: var(--border-soft); }
.skip-link {
  position: fixed;
  top: 10px;
  left: 10px;
  z-index: 9999;
  padding: 10px 14px;
  background: white;
  color: black;
  transform: translateY(-150%);
}
.skip-link:focus { transform: none; }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
.underline-animate { position: relative; display: inline-block; }
.underline-animate::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 2px;
  background: linear-gradient(90deg, var(--accent-blue), #8bb7ff);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 1.15s var(--ease) 1.35s;
}
.is-visible .underline-animate::after { transform: scaleX(1); }
