@import url("https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400..800;1,6..72,400..800&family=Public+Sans:wght@300;400;500;600;700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,300..700,0..1,0");

:root {
  --background: #f8f9fa;
  --surface-lowest: #ffffff;
  --surface-low: #f3f4f5;
  --surface: #edeeef;
  --surface-high: #e1e3e4;
  --ink: #191c1d;
  --ink-soft: #424751;
  --blue: #00346f;
  --blue-bright: #004a99;
  --blue-soft: #d7e2ff;
  --steel: #526070;
  --steel-soft: #d5e4f7;
  --warm: #5f2200;
  --warm-soft: #ffdbcc;
  --danger: #93000a;
  --danger-soft: #ffdad6;
  --line-ghost: rgba(115, 119, 131, 0.18);
  --shadow-soft: 0 20px 50px -28px rgba(25, 28, 29, 0.12);
  --shadow-float: 0 28px 60px -38px rgba(0, 52, 111, 0.26);
  --radius-lg: 18px;
  --radius-xl: 28px;
  --shell: min(1220px, calc(100% - 48px));
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "Public Sans", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at top left, rgba(171, 199, 255, 0.28), transparent 28%),
    linear-gradient(180deg, #fcfcfd 0%, var(--background) 32%, #f3f5f7 100%);
}

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

a {
  color: inherit;
  text-decoration: none;
}

p,
li {
  line-height: 1.65;
}

h1,
h2,
h3,
h4 {
  margin: 0;
  color: var(--blue);
  font-family: "Newsreader", serif;
  letter-spacing: -0.03em;
}

button,
input {
  font: inherit;
}

.material-symbols-outlined {
  font-family: "Material Symbols Outlined", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  direction: ltr;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(14px);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 14px 36px -32px rgba(0, 52, 111, 0.4);
}

.site-header__inner {
  width: var(--shell);
  margin: 0 auto;
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  font-family: "Public Sans", sans-serif;
  font-size: clamp(1.05rem, 1.8vw, 1.3rem);
  font-style: normal;
  font-weight: 800;
  line-height: 1.05;
  color: var(--blue);
  letter-spacing: -0.03em;
}

.site-nav {
  display: flex;
  align-items: center;
  gap: 28px;
}

.site-nav a {
  color: var(--ink-soft);
  font-size: 1rem;
  font-weight: 600;
  padding-bottom: 4px;
}

.site-nav a.active {
  color: var(--blue);
  border-bottom: 2px solid var(--blue);
}

.site-avatar {
  color: var(--blue);
}

.page-shell,
.shell {
  width: var(--shell);
  margin: 0 auto;
  padding-bottom: 88px;
}

.page-shell {
  padding-top: 32px;
}

.hero-band {
  padding: 28px 0 32px;
}

.kicker,
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  color: var(--blue);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--steel-soft);
  color: var(--blue);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.status-pill.danger {
  background: var(--danger-soft);
  color: var(--danger);
}

.status-pill.warm {
  background: var(--warm-soft);
  color: var(--warm);
}

.hero-grid {
  display: grid;
  gap: 52px;
  align-items: center;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.86fr);
}

.hero-grid.hero-grid--dark {
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, 0.75fr);
}

.hero-copy h1,
.hero h1 {
  max-width: 10ch;
  font-size: clamp(3rem, 6vw, 5.6rem);
  line-height: 0.96;
}

.hero-copy p,
.hero > p,
.lede {
  max-width: 44rem;
  margin-top: 18px;
  color: var(--ink-soft);
  font-size: clamp(1.03rem, 1.8vw, 1.3rem);
}

.hero-grid--dark .hero-copy h1,
.hero-band--dark h1 {
  color: #ffffff;
}

.hero-grid--dark .hero-copy p,
.hero-band--dark .lede {
  color: rgba(215, 226, 255, 0.88);
}

.hero-band--dark {
  margin: 0 calc(50% - 50vw);
  padding: 104px 0 92px;
  background:
    linear-gradient(135deg, rgba(0, 52, 111, 0.96) 0%, rgba(0, 74, 153, 0.94) 100%);
  overflow: hidden;
}

.hero-band--dark .page-shell {
  position: relative;
}

.hero-band--dark::after {
  content: "";
  position: absolute;
  inset: 0 0 0 auto;
  width: 34vw;
  min-width: 260px;
  background: linear-gradient(90deg, rgba(0, 52, 111, 0) 0%, rgba(0, 52, 111, 0.25) 28%, rgba(0, 52, 111, 0.6) 100%);
}

.hero-actions,
.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 24px;
  border-radius: 999px;
  border: 0;
  background: var(--blue);
  color: #ffffff;
  font-weight: 700;
  box-shadow: var(--shadow-float);
}

.button:hover {
  background: var(--blue-bright);
}

.button.secondary {
  background: var(--steel-soft);
  color: var(--blue);
  box-shadow: none;
}

.button.ghost {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.28);
  color: #ffffff;
  box-shadow: none;
}

.button.line {
  background: transparent;
  color: var(--blue);
  border: 1px solid rgba(0, 52, 111, 0.18);
  box-shadow: none;
}

.hero-media {
  position: relative;
}

.hero-media__frame {
  min-height: 420px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--surface-low);
  box-shadow: var(--shadow-float);
}

.hero-media__frame img,
.hero-media__frame .cover-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.floating-note {
  position: absolute;
  left: -26px;
  bottom: -24px;
  width: min(250px, 74%);
  padding: 18px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 30px 50px -36px rgba(25, 28, 29, 0.32);
}

.floating-note strong {
  display: block;
  color: var(--blue);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.floating-note p {
  margin: 8px 0 0;
  color: var(--ink-soft);
  font-size: 0.88rem;
  line-height: 1.55;
}

.section-block {
  margin-top: 30px;
  padding: 42px;
  border-radius: var(--radius-xl);
  background: var(--surface-lowest);
  box-shadow: var(--shadow-soft);
}

.section-soft {
  background: var(--surface-low);
}

.section-grid {
  display: grid;
  gap: 28px;
}

.section-grid > *,
.hero-grid > *,
.split-card > *,
.resource-grid > * {
  min-width: 0;
}

.section-grid.two,
.grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.section-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.section-grid.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.utility-nav,
.nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.utility-nav a,
.nav a {
  padding: 11px 16px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink-soft);
  font-size: 0.95rem;
  font-weight: 600;
  box-shadow: inset 0 0 0 1px rgba(0, 52, 111, 0.08);
}

.utility-nav a.active,
.nav a.active {
  background: var(--blue);
  color: #ffffff;
  box-shadow: var(--shadow-float);
}

.stats-grid,
.stat-row {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 28px;
}

.stat-card,
.stat {
  min-height: 148px;
  padding: 22px;
  border-radius: 20px;
  background: var(--surface-lowest);
  box-shadow: var(--shadow-soft);
}

.stat-card.soft {
  background: var(--steel-soft);
}

.stat-card.warm {
  background: var(--warm-soft);
}

.stat-card.danger {
  background: var(--danger-soft);
}

.stat-card strong,
.stat strong {
  display: block;
  margin-top: 12px;
  color: var(--blue);
  font-family: "Newsreader", serif;
  font-size: clamp(2rem, 3.4vw, 3.2rem);
  line-height: 1;
}

.stat-card p,
.stat {
  color: var(--ink-soft);
  font-size: 0.94rem;
}

.stat-card small {
  display: block;
  color: var(--ink-soft);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.split-card {
  display: grid;
  gap: 24px;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.9fr);
  align-items: stretch;
}

.content-stack,
.list {
  display: grid;
  gap: 18px;
}

.list.compact {
  gap: 12px;
}

.content-card,
.card {
  padding: 24px;
  border-radius: 18px;
  background: var(--surface-lowest);
  box-shadow: var(--shadow-soft);
}

.card.nested {
  background: var(--surface-low);
  box-shadow: none;
}

.content-card h3,
.card h3 {
  margin-bottom: 10px;
  font-size: 1.45rem;
}

.content-card p,
.card p {
  margin: 0;
  color: var(--ink-soft);
}

.content-card a,
.card a,
.checklist-item a,
.ops-entry a,
.evidence-item a,
.support-banner a,
.aside-panel a,
.footer__links a {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.content-card p,
.card p,
.checklist-item p,
.ops-entry p,
.evidence-item p,
.support-banner p,
.note-panel p {
  overflow-wrap: anywhere;
}

.content-card p + p,
.card p + p {
  margin-top: 10px;
}

.content-card.tint-blue {
  background: rgba(213, 228, 247, 0.52);
}

.content-card.tint-soft {
  background: rgba(0, 52, 111, 0.05);
}

.content-card.tint-warm {
  background: rgba(255, 219, 204, 0.62);
}

.content-card.tint-danger {
  background: rgba(255, 218, 214, 0.72);
}

.content-card .label,
.meta-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.content-card .meta-value,
.meta-value {
  display: block;
  color: var(--blue);
  font-family: "Newsreader", serif;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  line-height: 1.08;
}

.resource-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.resource-grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.checklist-list {
  display: grid;
  gap: 14px;
}

.checklist-item {
  padding: 18px 20px;
  border-radius: 16px;
  background: var(--surface-lowest);
  box-shadow: var(--shadow-soft);
}

.checklist-item strong {
  display: block;
  margin-bottom: 8px;
  color: var(--blue);
  font-size: 0.84rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.support-banner {
  padding: 20px 22px;
  border-radius: 18px;
  background: rgba(0, 52, 111, 0.08);
  color: var(--ink-soft);
}

.support-banner strong {
  display: block;
  margin-bottom: 8px;
  color: var(--blue);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.ops-grid {
  display: grid;
  gap: 18px;
}

.ops-entry {
  padding: 20px 22px;
  border-radius: 16px;
  background: var(--surface-low);
}

.ops-entry h4 {
  margin-bottom: 10px;
  font-size: 1.2rem;
}

.ops-entry p {
  margin: 0;
  color: var(--ink-soft);
}

.ops-entry p + p {
  margin-top: 10px;
}

.fact-rail {
  display: grid;
  gap: 14px;
}

.fact-row {
  display: grid;
  gap: 16px;
  grid-template-columns: 54px minmax(0, 1fr);
  align-items: start;
}

.fact-icon {
  width: 54px;
  height: 54px;
  border-radius: 14px;
  background: var(--steel-soft);
  color: var(--blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.aside-panel {
  padding: 30px;
  border-radius: 18px;
  background: var(--blue);
  color: #ffffff;
  box-shadow: var(--shadow-float);
}

.aside-panel h2,
.aside-panel h3 {
  color: #ffffff;
}

.aside-panel p {
  color: rgba(215, 226, 255, 0.88);
}

.aside-panel .button {
  width: 100%;
  justify-content: center;
  background: #ffffff;
  color: var(--blue);
  box-shadow: none;
}

.aside-panel .button.line,
.aside-panel .button.ghost {
  background: transparent;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.24);
}

.note-panel {
  padding: 24px;
  border-radius: 18px;
  background: var(--surface-low);
}

.note-panel strong {
  display: block;
  color: var(--ink-soft);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.note-panel .price {
  display: block;
  margin-top: 10px;
  color: var(--ink);
  font-family: "Newsreader", serif;
  font-size: clamp(2.3rem, 4vw, 3.4rem);
  line-height: 1;
}

.editorial-line {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
}

.editorial-line::before {
  content: "";
  width: 4px;
  height: 28px;
  border-radius: 999px;
  background: var(--blue);
}

.lookup-panel {
  margin-top: 28px;
  padding: 42px;
  border-radius: var(--radius-xl);
  background: var(--surface-low);
}

.lookup-form {
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1.4fr) repeat(2, minmax(0, 0.7fr)) auto;
  margin-top: 26px;
}

.lookup-form label {
  display: grid;
  gap: 8px;
  color: var(--ink-soft);
  font-size: 0.93rem;
  font-weight: 600;
}

.lookup-form input {
  min-height: 56px;
  padding: 0 18px;
  border: 0;
  border-bottom: 2px solid rgba(115, 119, 131, 0.16);
  border-radius: 14px 14px 0 0;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink);
  outline: none;
}

.lookup-form input:focus {
  border-bottom-color: var(--blue);
  box-shadow: inset 0 -1px 0 var(--blue);
}

.lookup-form button {
  align-self: end;
  min-height: 56px;
  padding: 0 24px;
  border: 0;
  border-radius: 999px;
  background: var(--blue);
  color: #ffffff;
  font-weight: 700;
  box-shadow: var(--shadow-float);
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 18px;
}

.chip-row span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink-soft);
  font-size: 0.82rem;
  font-weight: 600;
}

.dot {
  width: 11px;
  height: 11px;
  border-radius: 999px;
}

.dot.blue { background: var(--blue); }
.dot.warm { background: var(--warm); }
.dot.soft { background: var(--warm-soft); }
.dot.danger { background: var(--danger); }

.evidence-list {
  display: grid;
  gap: 18px;
}

.evidence-item {
  padding: 22px 24px;
  border-radius: 18px;
  background: var(--surface-lowest);
  box-shadow: var(--shadow-soft);
}

.evidence-item strong {
  display: block;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 1rem;
  font-weight: 700;
}

.evidence-item a {
  color: var(--blue);
  word-break: break-word;
}

.muted {
  color: var(--ink-soft);
}

.warning {
  color: var(--danger);
}

.support-note {
  padding: 22px 24px;
  border-radius: 18px;
  background: rgba(213, 228, 247, 0.46);
  color: var(--ink-soft);
}

.footer {
  margin-top: 52px;
  padding: 28px 0 36px;
  color: var(--ink-soft);
}

.footer__inner {
  width: var(--shell);
  margin: 0 auto;
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  justify-content: flex-end;
  font-size: 1rem;
}

.hero,
.panel {
  background: var(--surface-lowest);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-soft);
}

.hero {
  padding: 34px;
  margin-bottom: 26px;
}

.panel {
  padding: 30px;
}

.badge {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--steel-soft);
  color: var(--blue);
  font-size: 0.84rem;
  font-weight: 700;
}

.badge.severity-critical {
  background: var(--danger-soft);
  color: var(--danger);
}

.badge.severity-warning {
  background: var(--warm-soft);
  color: var(--warm);
}

.badge.severity-info {
  background: var(--steel-soft);
  color: var(--blue);
}

code {
  padding: 2px 6px;
  border-radius: 8px;
  background: rgba(0, 52, 111, 0.08);
  color: var(--blue);
}

@media (max-width: 1080px) {
  .hero-grid,
  .hero-grid.hero-grid--dark,
  .split-card,
  .section-grid.two,
  .section-grid.three,
  .section-grid.four,
  .grid.two,
  .resource-grid,
  .stats-grid,
  .stat-row {
    grid-template-columns: 1fr;
  }

  .lookup-form {
    grid-template-columns: 1fr 1fr;
  }

  .lookup-form label:first-child {
    grid-column: 1 / -1;
  }

  .lookup-form button {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  :root {
    --shell: min(100% - 24px, 1220px);
  }

  .site-header__inner {
    min-height: auto;
    padding: 14px 0 10px;
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .site-nav {
    display: flex;
    order: 3;
    width: 100%;
    gap: 16px;
    margin-top: 8px;
    padding-bottom: 2px;
    overflow-x: auto;
    scrollbar-width: none;
    white-space: nowrap;
  }

  .site-nav::-webkit-scrollbar {
    display: none;
  }

  .site-nav a {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    min-height: 44px;
  }

  .utility-nav a,
  .nav a {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    font-size: 16px;
  }

  .floating-note p,
  .stat-card p,
  .stat,
  .content-card p,
  .card p,
  .checklist-item p,
  .ops-entry p,
  .evidence-item p,
  .support-banner p,
  .note-panel p,
  .muted,
  .footer__links,
  .site-nav a,
  label,
  .lookup-form label,
  input,
  button {
    font-size: 16px;
  }

  .page-shell,
  .shell {
    padding-bottom: 56px;
  }

  .hero-band {
    padding-top: 18px;
  }

  .hero-band--dark {
    padding: 86px 0 74px;
  }

  .section-block,
  .panel,
  .hero,
  .lookup-panel {
    padding: 24px;
  }

  .hero-copy h1,
  .hero h1 {
    max-width: none;
  }

  .hero-media__frame {
    min-height: 320px;
  }

  .floating-note {
    position: static;
    width: 100%;
    margin-top: 16px;
  }

  .lookup-form {
    grid-template-columns: 1fr;
  }

  .footer__inner {
    grid-template-columns: 1fr;
  }

  .footer__links {
    justify-content: flex-start;
  }
}
