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

* {
  margin: 0;
  padding: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

html:focus-within {
  scroll-behavior: smooth;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

img, picture, svg, video, canvas {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
}

input, button, textarea, select {
  font: inherit;
}

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
    transition: none;
  }
}
body, html {
  height: 100%;
  scroll-behavior: smooth;
}

:root {
  --col-bg: #fff;
  --col-text: #3b3a48;
  --col-usa-banner-bg: #f0f0f0;
  --col-state-yellow: #fcb713;
  --col-state-blue: #035d85;
  --col-text-dark-blue: #002742;
  --col-outline: #2ea3f2;
}

html {
  font-size: 10px;
}

body {
  font-family: "Source Sans 3", Helvetica Neue, Helvetica, Roboto, Arial, sans-serif;
  font-feature-settings: "kern";
  font-kerning: normal;
  font-weight: 400;
  font-optical-sizing: auto;
  unicode-bidi: isolate;
  -webkit-text-size-adjust: 100%;
  line-height: 1.5;
  background: var(--col-bg);
  color: var(--col-text);
  font-size: 1.5rem;
}

.std-container {
  position: relative;
  width: 100%;
  max-width: 1188px;
  padding: 0 32px;
  margin: 0 auto;
}

.std-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: auto;
  border-radius: 8px;
  cursor: pointer;
  text-decoration: none;
  appearance: none;
  outline: none;
  background: transparent;
  border: 1px solid transparent;
  transition: all 0.14s ease-out;
  position: relative;
  overflow: hidden;
}
.std-btn:focus {
  outline: solid 2px var(--col-outline);
}
.std-btn::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  transform: scaleX(0) translateZ(0);
  backface-visibility: hidden;
  z-index: 0;
  transition: all 0.14s ease-out;
}
.std-btn:hover {
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}
.std-btn:hover::before {
  background: rgba(0, 0, 0, 0.2);
  transform: scaleX(1);
}
.std-btn > img:first-child, .std-btn > svg:first-child {
  margin-right: 8px;
}
.std-btn.-md {
  height: 4rem;
  font-size: 1.6rem;
  padding: 0 12px;
}
.std-btn.-lg {
  height: 4.8rem;
  font-size: 1.8rem;
  padding: 0 16px;
}
.std-btn.-fill.-dark-blue {
  border: 1px solid var(--col-text-dark-blue);
  background: var(--col-text-dark-blue);
  color: #fff;
}
.std-btn.-fill.-dark-blue svg {
  fill: #fff;
}
.std-btn.-fill.-dark-blue::before {
  background: rgba(255, 255, 255, 0.1);
}
.std-btn.-outline {
  border: 1px solid #fff;
  color: #fff;
}
.std-btn.-outline svg {
  fill: #fff;
}
.std-btn.-outline > * {
  z-index: 1;
}
.std-btn.-outline-dark-blue, .std-btn.-outline.-dark-blue {
  border: 1px solid var(--col-text-dark-blue);
  color: var(--col-text-dark-blue);
}

main.std-container {
  display: flex;
  color: rgb(59, 58, 72);
  padding-top: 3.6rem;
  padding-bottom: 3.6rem;
  gap: 4.8rem;
}
main.std-container.-column {
  flex-direction: column;
}
main.std-container .row {
  position: relative;
  display: flex;
  width: 100%;
  gap: 4.8rem;
}
main.std-container .row:last-child {
  margin-bottom: 0;
}
main.std-container .row.-centered {
  align-items: center;
}
main.std-container hr {
  position: relative;
  display: block;
  width: 100%;
  height: 1px;
  border: none;
  background: #eaeaea;
}
main.std-container .wizard {
  padding-top: 2.4rem;
  padding-bottom: 2.4rem;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
main.std-container .left-page, main.std-container .right-page {
  font-size: 1.6rem;
  max-width: 594px;
  flex-basis: 50%;
  flex-grow: 1;
}
main.std-container .left-page.-wide, main.std-container .right-page.-wide {
  max-width: 1188px;
  flex-basis: 100%;
}
main.std-container .left-page h2, main.std-container .right-page h2 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
}
main.std-container .left-page p, main.std-container .right-page p {
  margin-bottom: 2rem;
}
main.std-container .left-page ul, main.std-container .right-page ul {
  list-style: disc;
  margin: 0 0 20px 20px;
  padding: 0;
}
main.std-container .left-page ul li, main.std-container .right-page ul li {
  list-style: disc;
  margin: 0 0 10px;
  padding: 0;
}
main.std-container .left-page .buttons, main.std-container .right-page .buttons {
  display: flex;
  align-items: center;
}
main.std-container .left-page .buttons .std-btn, main.std-container .right-page .buttons .std-btn {
  margin-right: 1.2rem;
}
main.std-container .left-page .buttons .std-btn:last-child, main.std-container .right-page .buttons .std-btn:last-child {
  margin-right: 0;
}
main.std-container .left-page > *:last-child, main.std-container .right-page > *:last-child {
  margin-bottom: 0;
}
main.std-container .tiles {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 2.4rem;
  margin-bottom: 1.2rem;
}
main.std-container .tiles.-per-3 {
  grid-template-columns: repeat(3, 1fr);
}
main.std-container .tiles.-per-4 {
  grid-template-columns: repeat(4, 1fr);
}
main.std-container .box {
  background: rgb(243, 243, 244);
  border: 1px solid rgb(212, 212, 215);
  padding: 2.4rem;
  border-radius: 10px;
  margin-bottom: 2.4rem;
  flex-grow: 0;
  flex-shrink: 0;
  position: relative;
}
main.std-container .box.-card {
  display: flex;
}
main.std-container .box.-card img {
  margin-right: 2.4rem;
  object-fit: contain;
}
main.std-container .box.-card .text {
  display: flex;
  flex-direction: column;
}
main.std-container .box.-card .text > *:last-child {
  margin-bottom: 0;
}
main.std-container .box.-status {
  display: flex;
  align-items: center;
}
main.std-container .box.-status .emoji {
  font-size: 2rem;
  margin-right: 1.2rem;
}
main.std-container .box.-status .lamp {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
  background: #2ecc71;
  margin: 0.6rem 1.2rem 0 0;
}
main.std-container .box.-status .text {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-grow: 1;
}
main.std-container .box.-status .text h3 {
  margin: 0;
  flex-grow: 1;
}
main.std-container .box.-status .text .details {
  font-size: 1.4rem;
  color: #293a55;
  opacity: 0.333;
  cursor: help;
}
main.std-container .box.-status .text .details:hover {
  opacity: 0.666;
}
main.std-container .box.-status.-green {
  border-color: #2ecc71;
  background: #e8f8f5;
  color: #024727;
}
main.std-container .box.-status.-green .lamp {
  background: #2ecc71;
}
main.std-container .box.-status.-green .text p {
  color: #2ecc71;
}
main.std-container .box.-status.-red {
  border-color: #e74c3c;
  background: #f8e8e8;
  color: #721c24;
}
main.std-container .box.-status.-red .lamp {
  background: #e74c3c;
}
main.std-container .box.-status.-red .text p {
  color: #e74c3c;
}
main.std-container .box.-radio {
  align-items: center;
  border-width: 2px;
  border-color: #000;
  background: #fff;
  padding: 0;
}
main.std-container .box.-radio .text {
  cursor: pointer;
  width: 100%;
  padding: 1.5rem 1.5rem 1.5rem 6rem;
  border-radius: 10px;
  outline-offset: 2px;
}
main.std-container .box.-radio .text h4 {
  display: flex;
  align-items: center;
}
main.std-container .box.-radio .text h4 svg {
  margin-right: 0.4rem;
  width: 22px;
  height: 22px;
  flex-grow: 0;
  flex-shrink: 0;
}
main.std-container .box.-radio .text p {
  margin-top: 0.5rem;
  font-size: 1.5rem;
}
main.std-container .box.-radio input {
  position: absolute;
  display: inline-flex;
  width: 20px;
  height: 20px;
  flex-grow: 0;
  flex-shrink: 0;
  margin-right: 2.4rem;
  left: 2rem;
}
main.std-container .box.-radio input:checked + label {
  outline: solid 2px var(--col-outline);
}
main.std-container .tiled-page {
  display: flex;
  flex-wrap: wrap;
  max-width: 800px;
}
main.std-container .tiled-page > div {
  flex-basis: 360px;
  margin-right: 2.4rem;
}

.fieldset {
  display: flex;
  flex-direction: column;
  margin-bottom: 1.2rem;
}
.fieldset label {
  font-weight: bold;
}
.fieldset input, .fieldset textarea {
  appearance: none;
  border: 2px solid #000;
  margin: 1rem 0;
}
.fieldset textarea {
  padding: 1.2rem;
}
.fieldset .help {
  color: #666;
  font-size: 14px;
  margin-bottom: 1rem;
}

.ChapterHeader {
  position: relative;
  background: #002742;
  color: #fff;
}
.ChapterHeader:after {
  content: "";
  height: 100%;
  width: 66.666%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: auto;
  background-image: url("/img/vitrailer5.webp");
  background-size: cover;
  background-position: center center;
  mask-image: linear-gradient(to left, rgb(0, 0, 0), rgba(0, 0, 0, 0));
}
.ChapterHeader.-art-beach:after {
  background-image: url("/img/vitrailer2.webp");
}
.ChapterHeader.-art-street:after {
  background-image: url("/img/vitrailer3.webp");
}
.ChapterHeader .std-container {
  display: flex;
  flex-direction: column;
  padding-top: 3.6rem;
  padding-bottom: 4.2rem;
}
.ChapterHeader .std-container .breadcrumbs {
  margin-bottom: 2.4rem;
  line-height: 30px;
  font-size: 1.6rem;
}
.ChapterHeader .std-container .breadcrumbs a {
  color: #fff;
  text-decoration: underline;
}
.ChapterHeader .std-container .breadcrumbs span {
  color: #fff;
}
.ChapterHeader .std-container .breadcrumbs .slash {
  margin: 0 1rem;
}
.ChapterHeader .std-container h1 {
  font-size: 3.6rem;
  text-transform: uppercase;
  font-weight: 600;
}
.ChapterHeader.-page {
  background: #eef8fb;
  color: rgb(59, 58, 72);
}
.ChapterHeader.-page h1 {
  color: rgb(3, 83, 118);
}
.ChapterHeader.-page span {
  color: rgb(59, 58, 72);
}

.CtaBox {
  display: flex;
  flex-direction: column;
  width: 100%;
  background: var(--col-state-yellow);
  color: var(--col-text-dark-blue);
  padding: 24px;
  text-shadow: none;
}
.CtaBox h2 {
  font-size: 2.4rem;
  margin-bottom: 0.75rem;
}
.CtaBox h2 svg {
  fill: var(--col-text-dark-blue);
}
.CtaBox p {
  font-size: 1.8rem;
  margin-bottom: 1.5rem;
}
.CtaBox .std-btn {
  margin: 0;
}

.DiscordButton {
  display: flex;
  align-items: center;
  border-radius: 4px;
  background: rgb(88, 101, 242);
  text-decoration: none;
  color: #fff;
  padding: 1rem 1.5rem;
  font-weight: 500;
  transition: all 0.17s ease-out;
  line-height: normal;
}
.DiscordButton img {
  height: 20px;
  width: 20px;
  margin-right: 10px;
}
.DiscordButton:hover {
  background: rgb(71, 82, 196);
}
.DiscordButton:active {
  background: rgb(60, 69, 165);
}

.Header {
  background: #004e71;
  background: radial-gradient(ellipse at center bottom, rgb(24, 107, 171) -50%, rgb(3, 39, 65) 70%);
  width: 100%;
  color: #fff;
  border-bottom: 4px solid var(--col-state-yellow);
}
.Header, .Header .std-container {
  height: 175px;
}
.Header .std-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 3px;
}
.Header .logo {
  display: flex;
  align-items: center;
  color: #fff;
  text-decoration: none;
}
.Header .logo img {
  height: 100px;
  width: auto;
  margin-right: 15px;
}
.Header .logo .text {
  display: flex;
  flex-direction: column;
}
.Header .logo .text .the-state {
  padding: 0;
  margin: 0 0 0.25rem 0;
}
.Header .logo .text .tagline {
  padding: 0;
  margin: 0 0 0.35rem 0;
  font-size: 2rem;
  font-weight: 600;
}
.Header #clock {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 0.5rem;
  text-align: right;
  color: #ccc;
}
.Header .statuses {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  font-size: 14px;
  color: #fff;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 2rem;
}
.Header .statuses .status {
  display: flex;
  align-items: center;
  margin-left: 1.5rem;
}
.Header .statuses .status img {
  display: inline;
  width: 41px;
  height: 36px;
  vertical-align: middle;
}
.Header .statuses .status img.spaced {
  margin-right: 4px;
  padding: 4px;
}
.Header .statuses .status .status-text {
  color: var(--col-state-yellow);
  font-weight: bold;
  margin-left: 5px;
}
.Header nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.Header nav a {
  display: flex;
  align-items: center;
  padding: 0.4rem 0.75rem;
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  transition: all 0.14s ease-in-out;
  line-height: 1;
  border-radius: 6px;
  font-size: 1.8rem;
  margin-left: 1rem;
}
.Header nav a:hover {
  color: var(--col-state-yellow);
}
.Header nav a:active, .Header nav a.-active {
  background: var(--col-state-yellow);
  color: #000;
}

.Masthead {
  position: relative;
  background: var(--col-state-blue);
  padding: 8rem 0;
  color: #fff;
  background-image: url("/img/masthead-diag-bg.svg");
  background-color: var(--color-p2, #046b99);
  background-position: center !important;
  background-size: cover !important;
  overflow: hidden;
}
.Masthead .std-container {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.Masthead .std-container > .content {
  display: flex;
  align-items: center;
  margin-bottom: 4rem;
}
.Masthead .std-container > .content .left, .Masthead .std-container > .content .right {
  width: 50%;
  flex-basis: 50%;
  flex-grow: 0;
  flex-shrink: 0;
  margin: 0;
}
.Masthead .std-container > .content .left {
  padding-right: 2rem;
}
.Masthead .std-container > .content .right {
  padding-left: 2rem;
  text-align: right;
}
.Masthead .std-container > .content .right img {
  border-radius: 50%;
  height: 280px;
  width: 280px;
  object-fit: cover;
}
.Masthead .search {
  background: #fff;
  border-radius: 8px;
  height: 50px;
  display: flex;
  margin-top: 2.4rem;
  flex-grow: 0;
  flex-shrink: 1;
}
.Masthead .search input, .Masthead .search button {
  appearance: none;
  border: none;
  outline: none;
  background: transparent;
  height: 50px;
}
.Masthead .search input:focus, .Masthead .search button:focus {
  outline: solid 2px var(--col-outline);
}
.Masthead .search input {
  padding-left: 1.6rem;
  padding-right: 2px;
  flex-grow: 1;
  font-size: 1.8rem;
  border-top-left-radius: 8px;
  border-bottom-left-radius: 8px;
}
.Masthead .search button {
  cursor: pointer;
  padding: 0 1.6rem;
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
}
.Masthead .search button:hover {
  background: var(--col-state-yellow);
}
.Masthead h1 {
  font-size: 3.2rem;
  max-width: 420px;
}
.Masthead .CtaBox {
  text-align: left;
  text-shadow: none;
}
.Masthead .circle-combo {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 542px;
}
.Masthead .circle-combo, .Masthead .circle-combo img {
  flex-grow: 0;
  flex-shrink: 0;
}
.Masthead .circle-combo img {
  border: 5px solid #035376;
}
.Masthead .circle-combo img:nth-child(2) {
  margin-left: -33.333%;
}
.Masthead .circle-combo img:nth-child(3) {
  margin-left: -33.333%;
}

.OocSiteNotice {
  display: block;
  width: 100%;
  background: var(--col-usa-banner-bg);
  padding: 4px 0;
  color: #1b1b1b;
  font-size: 12.8px;
  font-weight: 600;
}
.OocSiteNotice .std-container {
  display: flex;
  align-items: center;
}
.OocSiteNotice img.flag {
  height: 16px;
  width: 16px;
  margin-right: 8px;
}

.ProgressSteps {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.2rem;
  width: 100%;
}
.ProgressSteps .segments {
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  width: 100%;
}
.ProgressSteps .segment {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-bottom: 1rem;
  height: 1.2rem;
  margin-right: 0.5rem;
}
.ProgressSteps .segment.-complete {
  background-color: #27ae60;
}
.ProgressSteps .segment.-incomplete {
  background-color: #ccc;
}
.ProgressSteps .segment.-current {
  background-color: var(--col-state-yellow);
}

/*# sourceMappingURL=leaflinks.css.map */
