*, *::before, *::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-family-sans);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-primary);
  background: var(--color-surface-muted);
  line-height: var(--line-height-normal);
  min-height: 100vh;
}

img {
  max-width: 100%;
  display: block;
}

a {
  color: var(--color-accent-blue);
  text-decoration: none;
  transition: color var(--transition-base);
}

a:hover {
  color: var(--color-primary);
}

.site-header {
  position: sticky;
  top: 0;
  background: var(--color-surface);
  box-shadow: 0 12px 32px rgba(17, 20, 45, 0.15);
  z-index: 1000;
}

.header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-4);
  padding: var(--spacing-3) var(--spacing-5);
  max-width: var(--content-max-width);
  margin: 0 auto;
  flex-wrap: wrap;
}

.logo {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.02em;
  color: var(--color-secondary);
}

.nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.nav-btn {
  color: var(--color-text-inverse);
  padding: var(--spacing-3) var(--spacing-4);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  transition: opacity var(--transition-base);
}

.nav-btn:hover {
  opacity: 0.82;
}

.nav-btn + .nav-btn {
  border-left: 1px solid rgba(255, 255, 255, 0.28);
}

.nav-btn.home { background: linear-gradient(135deg, #e63946, #ff6b6b); }
.nav-btn.about { background: linear-gradient(135deg, #ff8c42, #ffa600); }
.nav-btn.people { background: linear-gradient(135deg, #0077b6, #00b4d8); }
.nav-btn.careers { background: linear-gradient(135deg, #5a189a, #9d4edd); }
.nav-btn.news { background: linear-gradient(135deg, #8338ec, #3a0ca3); }

main {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
}

.section-shell {
  width: min(calc(100% - 2 * var(--spacing-5)), var(--content-max-width));
  margin: 0 auto;
}

.section-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  margin-bottom: var(--spacing-5);
}

.section-eyebrow {
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-xs);
  letter-spacing: 0.18em;
  color: var(--color-accent-gold);
}

.section-title {
  font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl));
  font-weight: var(--font-weight-bold);
  margin: 0;
  color: var(--color-secondary);
}

.section-description {
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  max-width: var(--content-narrow-width);
  margin: 0;
}

.hero-section {
  position: relative;
  min-height: clamp(28rem, 80vh, 38rem);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-inverse);
  background: var(--gradient-hero-overlay), radial-gradient(circle at 20% 20%, rgba(255, 196, 0, 0.25), transparent 45%), var(--gradient-brand);
  overflow: hidden;
}

.hero-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 20%, rgba(255, 255, 255, 0.18), transparent 45%);
  pointer-events: none;
}

.hero-content {
  position: relative;
  padding: var(--spacing-8) 0;
  text-align: center;
  width: min(calc(100% - 2 * var(--spacing-5)), var(--content-narrow-width));
}

.hero-eyebrow {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  margin-bottom: var(--spacing-3);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
}

.hero-eyebrow::before {
  content: "";
  width: 3rem;
  height: 1px;
  background: rgba(255, 255, 255, 0.55);
}

.hero-title {
  font-family: var(--font-family-serif);
  font-size: clamp(var(--font-size-3xl), 6vw, 3.5rem);
  line-height: var(--line-height-tight);
  margin: 0 0 var(--spacing-3) 0;
}

.hero-description {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  margin: 0 auto var(--spacing-5);
  color: rgba(255, 255, 255, 0.9);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-3);
  justify-content: center;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3) var(--spacing-5);
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.02em;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.btn-primary {
  background: var(--gradient-button);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-soft);
}

.btn-secondary {
  background: rgba(255, 255, 255, 0.15);
  color: var(--color-text-inverse);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255, 255, 255, 0.25);
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card);
}

.news-section {
  padding: calc(var(--spacing-8) * 0.8) 0 calc(var(--spacing-9) * 0.8);
  background: var(--color-surface);
  position: relative;
}

.news-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(234, 239, 255, 0.65), transparent 35%);
  pointer-events: none;
}

.news-page-intro {
  background: var(--color-surface-muted);
  padding: var(--spacing-8) 0 var(--spacing-6);
}

.news-page-intro .section-shell {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
}

.news-page-intro .intro-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-3);
}

.news-grid {
  position: relative;
  display: grid;
  gap: var(--spacing-5);
  grid-template-columns: 1fr;
  align-items: stretch;
}

@media (min-width: 64rem) {
  .news-grid {
    grid-template-columns: minmax(320px, 2fr) minmax(260px, 1fr);
  }
}

.news-feature {
  background: var(--color-surface);
  border-radius: 0;
  padding: calc(var(--spacing-5) * 0.7) calc(var(--spacing-5) * 0.85);
  box-shadow: var(--shadow-soft);
  display: grid;
  grid-auto-flow: row;
  grid-template-rows: auto auto auto 1fr auto;
  gap: calc(var(--spacing-3) * 0.7);
  align-content: stretch;
  height: var(--news-feature-height, auto);
  min-height: var(--news-feature-height, var(--news-feature-min-height));
  max-height: var(--news-feature-height, none);
  overflow: visible;
}

@media (min-width: 64rem) {
  .news-feature {
    min-height: var(
      --news-feature-height,
      var(--news-feature-min-height-desktop, var(--news-feature-min-height))
    );
  }
}

.news-feature--locked {
  overflow: hidden;
}

.news-feature time {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-text-secondary);
}

.news-feature-meta {
  margin: 0;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-accent-blue);
}

.news-feature h3 {
  font-size: clamp(var(--font-size-lg), 3.4vw, var(--font-size-2xl));
  margin: 0;
  font-family: var(--font-family-serif);
  color: var(--color-secondary);
}

.news-feature p {
  margin: 0;
  color: var(--color-text-secondary);
  line-height: var(--line-height-normal);
}

.news-feature-body {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing-3) * 0.7);
  overflow: visible;
}

.news-feature--locked .news-feature-body {
  overflow-y: auto;
  scrollbar-gutter: stable;
  padding-right: calc(var(--spacing-2) * 0.85);
}

.news-feature-link {
  align-self: flex-start;
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.02em;
  color: var(--color-accent-blue);
}

.news-feature-link:hover,
.news-feature-link:focus {
  color: var(--color-primary);
  text-decoration: underline;
}

.news-list {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing-3) * 0.7);
}

.news-item {
  padding: calc(var(--spacing-4) * 0.7) calc(var(--spacing-4) * 0.9);
  border-radius: 0;
  background: var(--color-surface-subtle);
  border: 1px solid var(--color-border);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing-2) * 0.7);
  min-height: var(--news-side-card-min-height);
}

.news-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(19, 31, 53, 0.18);
}

.news-item h4 {
  margin: 0 0 calc(var(--spacing-2) * 0.7) 0;
  font-size: clamp(var(--font-size-md), 2.8vw, var(--font-size-lg));
  color: var(--color-secondary);
}

.news-item h4 a {
  color: inherit;
}

.news-item h4 a:hover {
  color: var(--color-primary);
}

.news-item p {
  margin: 0;
  color: var(--color-text-secondary);
  line-height: var(--line-height-normal);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-item-meta {
  margin-top: calc(var(--spacing-2) * 0.7);
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-tertiary, rgba(30, 41, 59, 0.6));
}

.news-loading {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.news-empty {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  font-style: italic;
}

.news-archive {
  background: var(--color-surface);
  padding: var(--spacing-8) 0 var(--spacing-9);
}

.news-articles {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-6);
}

.news-article {
  background: var(--color-surface-subtle);
  border-radius: 0;
  border: 1px solid var(--color-border);
  box-shadow: none;
  padding: calc(var(--spacing-5) * 0.7) calc(var(--spacing-5) * 0.85);
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing-3) * 0.75);
  scroll-margin-top: 6.5rem;
}

.news-article-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  position: relative;
  padding-right: var(--spacing-5);
}

.news-article-header h2 {
  margin: 0;
  font-size: clamp(var(--font-size-xl), 4vw, var(--font-size-3xl));
  font-family: var(--font-family-serif);
  color: var(--color-secondary);
}

.news-article-meta {
  margin: 0;
  font-size: var(--font-size-sm);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
}

.news-article-anchor {
  position: absolute;
  top: 0;
  right: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.15rem 0.35rem;
  border-radius: var(--border-radius-sm);
  opacity: 0.65;
  transition: opacity var(--transition-base), color var(--transition-base),
    background var(--transition-base);
}

.news-article-anchor:hover,
.news-article-anchor:focus {
  color: var(--color-primary);
  opacity: 1;
  background: rgba(218, 41, 28, 0.08);
}

.news-article-meta time {
  font-style: normal;
}

.news-article p {
  margin: 0;
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}

.news-article p + p {
  margin-top: var(--spacing-2);
}

.about-section {
  padding: var(--spacing-9) 0;
  background: var(--color-surface-subtle);
}

.about-grid {
  display: grid;
  gap: var(--spacing-6);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.about-card {
  background: var(--color-surface);
  border-radius: 0;
  padding: var(--spacing-5);
  box-shadow: var(--shadow-soft);
  border: 1px solid rgba(255, 255, 255, 0.4);
}

.about-card h3 {
  margin: 0 0 var(--spacing-3) 0;
  font-size: var(--font-size-xl);
  color: var(--color-secondary);
}

.about-card p {
  margin: 0;
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}

.people-section {
  padding: var(--spacing-9) 0 var(--spacing-8);
  background: var(--color-surface);
}

.people-grid {
  display: grid;
  gap: var(--spacing-5);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.person-card {
  background: var(--color-surface);
  border-radius: 0;
  padding: var(--spacing-5) var(--spacing-4);
  border: 1px solid var(--color-border);
  box-shadow: 0 16px 36px rgba(17, 23, 33, 0.12);
  display: grid;
  gap: var(--spacing-3);
  text-align: center;
}

.person-portrait {
  width: 112px;
  height: 112px;
  border-radius: 50%;
  margin: 0 auto;
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(17, 23, 33, 0.16);
  background: linear-gradient(135deg, rgba(218, 41, 28, 0.35), rgba(93, 46, 140, 0.4));
}

.person-portrait--photo {
  background: none;
}

.person-photo {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  background-size: cover;
  background-position: center;
}

.person-photo--gradient {
  background-image: radial-gradient(120% 140% at 80% 10%, rgba(255, 198, 120, 0.8) 0%, rgba(255, 198, 120, 0) 55%),
    radial-gradient(140% 160% at 0% 120%, rgba(108, 211, 236, 0.6) 0%, rgba(108, 211, 236, 0) 60%),
    linear-gradient(135deg, #1c1f4f 0%, #442b78 48%, #e85520 100%);
}

.person-monogram {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  letter-spacing: 0.12em;
  background: linear-gradient(135deg, rgba(218, 41, 28, 0.25), rgba(93, 46, 140, 0.35));
}

.person-name {
  margin: 0;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-secondary);
}

.person-name a {
  color: inherit;
}

.person-name a:hover,
.person-name a:focus {
  color: var(--color-primary);
}

.person-role {
  margin: 0;
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-text-secondary);
}

.person-bio {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}

.site-footer {
  background: var(--color-secondary);
  color: var(--color-text-inverse);
  padding: var(--spacing-8) 0 var(--spacing-6);
  margin-top: var(--spacing-7);
}

.footer-grid {
  display: grid;
  gap: var(--spacing-6);
  align-items: start;
}

@media (min-width: 48rem) {
  .footer-grid {
    grid-template-columns: minmax(0, 2fr) repeat(2, minmax(0, 1fr));
  }
}

.footer-brand {
  max-width: 26rem;
  display: grid;
  gap: var(--spacing-2);
}

.footer-title {
  margin: 0;
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
}

.footer-tagline {
  margin: 0;
  color: rgba(255, 255, 255, 0.75);
  line-height: var(--line-height-relaxed);
}

.footer-column {
  display: grid;
  gap: var(--spacing-2);
  align-content: start;
}

.footer-contact {
  gap: var(--spacing-2);
}

.footer-heading {
  margin: 0 0 var(--spacing-2) 0;
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.6);
}

.footer-links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: var(--spacing-2);
}

.footer-links a {
  color: rgba(255, 255, 255, 0.88);
}

.footer-links a:hover,
.footer-links a:focus {
  color: var(--color-accent-gold);
}

.footer-meta {
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  margin-top: var(--spacing-6);
  padding-top: var(--spacing-3);
  text-align: center;
  color: rgba(255, 255, 255, 0.6);
  font-size: var(--font-size-sm);
}

@media (max-width: 768px) {
  .header-content {
    justify-content: center;
    text-align: center;
  }

  .logo {
    width: 100%;
  }

  .nav-links {
    width: 100%;
    justify-content: center;
  }

  .hero-content {
    padding: var(--spacing-7) var(--spacing-4);
  }

  main {
    gap: var(--spacing-7);
  }
}
