/* rpm-landing.css — public pages (index, pricing). Federal-instrument look. */
* { box-sizing: border-box; margin: 0; }
body { font-family: "Source Sans Pro", "Segoe UI", system-ui, -apple-system, sans-serif;
  color: #1b1b1b; background: #ffffff; line-height: 1.55; }
a { color: #205493; }

.gov-band { background: #112e51; color: #fff; padding: 8px 0; font-size: 0.78rem; }
.gov-band .wrap { display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.gov-band span { color: rgba(255,255,255,0.75); }

.wrap { max-width: 1000px; margin: 0 auto; padding: 0 20px; }

.site-head { border-bottom: 1px solid #d6d7d9; padding: 18px 0; }
.site-head .wrap { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.brandmark { display: flex; align-items: center; gap: 12px; text-decoration: none; color: #1b1b1b; }
.brandmark .seal { width: 44px; height: 44px; border-radius: 50%; background: #112e51; color: #fff;
  display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 0.8rem; letter-spacing: 0.02em; }
.brandmark .t1 { font-size: 1.18rem; font-weight: 800; line-height: 1.2; }
.brandmark .t2 { font-size: 0.78rem; color: #5b616b; }
.head-actions { display: flex; gap: 10px; align-items: center; }
.btn { display: inline-block; text-decoration: none; font-weight: 700; font-size: 0.92rem;
  padding: 11px 22px; border-radius: 4px; border: 2px solid #205493; }
.btn.solid { background: #205493; color: #fff; }
.btn.solid:hover { background: #112e51; border-color: #112e51; }
.btn.line { color: #205493; background: #fff; }
.btn.line:hover { background: rgba(32,84,147,0.08); }

.hero { background: #f0f0f0; border-bottom: 1px solid #d6d7d9; padding: 56px 0; }
.hero h1 { font-size: 2.1rem; line-height: 1.2; max-width: 700px; }
.hero p.lead { font-size: 1.08rem; color: #3d4551; max-width: 660px; margin: 14px 0 24px; }
.hero .acts { display: flex; gap: 12px; flex-wrap: wrap; }
.hero .fine { font-size: 0.82rem; color: #5b616b; margin-top: 14px; }

.sec { padding: 44px 0; }
.sec.alt { background: #f0f0f0; border-top: 1px solid #d6d7d9; border-bottom: 1px solid #d6d7d9; }
.sec h2 { font-size: 1.4rem; margin-bottom: 8px; }
.sec p.sub { color: #5b616b; margin-bottom: 22px; max-width: 640px; }

.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 16px; }
.card { border: 1px solid #d6d7d9; border-radius: 4px; background: #fff; padding: 20px; }
.card h3 { font-size: 1rem; margin-bottom: 6px; }
.card p { font-size: 0.9rem; color: #3d4551; }
.card .k { display: inline-block; background: rgba(32,84,147,0.1); color: #205493; font-weight: 800;
  font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; border-radius: 3px; padding: 3px 8px; margin-bottom: 10px; }

.steps { counter-reset: st; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.step { border-left: 4px solid #205493; background: #fff; border-top: 1px solid #d6d7d9; border-right: 1px solid #d6d7d9;
  border-bottom: 1px solid #d6d7d9; padding: 16px 18px; }
.step::before { counter-increment: st; content: counter(st); display: inline-flex; width: 26px; height: 26px;
  align-items: center; justify-content: center; background: #112e51; color: #fff; font-weight: 800;
  border-radius: 50%; font-size: 0.82rem; margin-bottom: 10px; }
.step b { display: block; margin-bottom: 4px; }
.step span { font-size: 0.88rem; color: #3d4551; }

.price-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.price { border: 1px solid #d6d7d9; border-radius: 4px; background: #fff; padding: 22px; text-align: center; }
.price.feat { border: 2px solid #205493; }
.price .n { font-size: 1rem; font-weight: 800; }
.price .amt { font-size: 2.1rem; font-weight: 800; margin: 6px 0 2px; }
.price .per { font-size: 0.8rem; color: #5b616b; margin-bottom: 12px; }

table.costs { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid #d6d7d9; }
table.costs th, table.costs td { text-align: left; padding: 11px 16px; border-bottom: 1px solid #d6d7d9; font-size: 0.92rem; }
table.costs th { background: #112e51; color: #fff; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; }
table.costs td.r { text-align: right; font-weight: 700; white-space: nowrap; }

.foot { border-top: 1px solid #d6d7d9; padding: 26px 0 34px; margin-top: 30px; font-size: 0.8rem; color: #5b616b; }
.foot .links { display: flex; gap: 18px; flex-wrap: wrap; margin-bottom: 12px; }
.foot a { color: #205493; }
.disclaim { background: #f0f0f0; border: 1px solid #d6d7d9; border-radius: 4px; padding: 12px 16px; margin-bottom: 14px; }

@media (max-width: 640px) {
  .hero h1 { font-size: 1.6rem; }
  .gov-band .wrap { justify-content: center; }
}
