/* public/normalize.css */
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
  -webkit-text-size-adjust: 100%;
  line-height: 1.15;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  margin: .67em 0;
  font-size: 2em;
}

hr {
  box-sizing: content-box;
  overflow: visible;
  height: 0;
}

pre {
  font-family: monospace;
  font-size: 1em;
}

a {
  background-color: #0000;
}

abbr[title] {
  text-decoration: underline;
  text-decoration: underline dotted;
  border-bottom: none;
}

b, strong {
  font-weight: bolder;
}

code, kbd, samp {
  font-family: monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub, sup {
  position: relative;
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
}

sub {
  bottom: -.25em;
}

sup {
  top: -.5em;
}

img {
  border-style: none;
}

button, input, optgroup, select, textarea {
  margin: 0;
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
}

button, input {
  overflow: visible;
}

button, select {
  text-transform: none;
}

button, [type="button"], [type="reset"], [type="submit"] {
  -webkit-appearance: button;
}

button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type="button"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type="reset"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring {
  outline: 1px dotted buttontext;
}

[type="button"]:-moz-focusring {
  outline: 1px dotted buttontext;
}

[type="reset"]:-moz-focusring {
  outline: 1px dotted buttontext;
}

[type="submit"]:-moz-focusring {
  outline: 1px dotted buttontext;
}

fieldset {
  padding: .35em .75em .625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  white-space: normal;
  max-width: 100%;
  padding: 0;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type="checkbox"], [type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

[type="number"]::-webkit-inner-spin-button {
  height: auto;
}

[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template, [hidden] {
  display: none;
}

/* public/base.css */
*, *:before, *:after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  min-height: 100dvh;
  font-size: 20px;
}

body {
  color: #222;
  display: flex;
  background-color: #fafafa;
  flex-direction: column;
  min-height: 100dvh;
  margin: 0;
  padding: 0;
  font-family: Helvetica, Arial, sans-serif;
  line-height: 1.6;
}

#main {
  flex: 1;
}

#main a {
  color: #1d70b8;
  text-decoration: underline;
  text-underline-position: under;
  text-decoration-thickness: max(1px);
}

#main a:hover {
  color: #003078;
  text-decoration: underline;
  text-decoration-thickness: 3px;
}

#main a:active {
  color: #003078;
  text-decoration: underline;
  text-decoration-thickness: 3px;
}

#main a:active {
  background-color: #d9edff;
}

#top-bar {
  background-color: #06302d;
  min-height: 2em;
}

.vh {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
}

.amended {
  background-color: #f8e5fb;
  font-style: italic;
}

.amended:before {
  content: "[Amended by " attr(data-amendments) "] ";
}

.omitted {
  opacity: .7;
  text-decoration: line-through;
  text-decoration-color: #ff0000b3;
}

:root {
  --main-column-width: 40rem;
}

.under-construction {
  background: repeating-linear-gradient(45deg, #fed053, #fed053 10px, #e3ba4c 10px 20px);
  margin-top: 1rem;
  padding: .5rem 1rem;
}

.under-construction .text-box {
  color: #323437;
  max-width: var(--main-column-width);
  background-color: #fff;
  border-radius: .25rem;
  margin: 0 auto;
  padding: .5rem 1rem;
  font-size: .8rem;
}

.under-construction .title {
  text-transform: uppercase;
  font-weight: bold;
}

.callout {
  max-width: var(--main-column-width);
  background-color: #f0f0f0;
  border-radius: .2rem;
  margin: 1rem auto;
  padding: 1rem;
}

/* public/nav.css */
nav {
  text-align: left;
  background-color: #0f6c66;
}

nav .nav-wrapper {
  background-color: #0a4d49;
}

nav .nav-links-wrapper {
  display: flex;
  max-width: var(--main-column-width);
  justify-content: flex-end;
  align-items:  center;
  min-height: 2rem;
  margin: 0 auto;
  padding: 0 1rem;
}

nav .nav-links {
  color: #fff;
  font-size: .8rem;
}

nav .nav-links a {
  color: #fff;
  text-decoration: none;
}

nav .nav-links a:hover {
  text-decoration: underline;
}

nav .nav-links a:active {
  text-decoration: underline;
}

nav .title-wrapper {
  display: flex;
  max-width: var(--main-column-width);
  justify-content: flex-start;
  align-items:  center;
  min-height: 3rem;
  margin: 0 auto;
  padding: 0 1rem;
}

nav h1 {
  color: #fff;
  text-transform: uppercase;
  max-width: var(--main-column-width);
  margin: 0;
  padding: 0;
  font-family: Georgia, serif;
  font-size: 1rem;
  font-weight: normal;
}

nav h1 a {
  color: #fff;
  text-decoration: none;
}

nav h1 a:hover {
  color: #d09c49;
}

nav h1 a:active {
  color: #d09c49;
}

nav h1 a:active {
  color: #fff;
  text-decoration: none;
}

nav h1 a:focus {
  color: #fff;
  text-decoration: none;
}

nav h1 span.of {
  text-transform: lowercase;
  margin-right: .15em;
  font-style: italic;
}

footer {
  color: #fff;
  text-align: center;
  background-color: #0a4d49;
  margin-top: 0;
  padding: 1.5rem 0;
  font-size: .8rem;
}

footer a {
  color: #fff;
  text-decoration: none;
  padding: 0 .5rem;
}

footer a:hover {
  color: #d09c49;
  text-decoration: underline;
}

footer a:active {
  color: #d09c49;
  text-decoration: underline;
}

#back-to-top {
  position: fixed;
  bottom: 1rem;
  right: 1rem;
}

#back-to-top a {
  color: #fff;
  text-decoration: none;
  opacity: .5;
  background-color: #0a4d49;
  border-radius: .5rem;
  padding: .5rem;
  font-size: 1.5rem;
  font-weight: bold;
}

#back-to-top a:hover {
  opacity: 1;
}

#back-to-top a:active {
  opacity: 1;
}

/* public/pages.css */
.page-main-column, .pages-article-index {
  max-width: var(--main-column-width);
  margin: 0 auto;
  padding: 1rem;
}

.pages-article-view .previous-next-wrapper {
  max-width: var(--main-column-width);
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  padding: 1rem;
}

.pages-article-view .amendment-history-table {
  border-collapse: collapse;
  overflow: hidden;
  background: #fff;
  border-radius: 6px;
  width: 100%;
  box-shadow: 0 2px 4px #0000001a;
}

.pages-article-view .amendment-history-table th {
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .5px;
  background: #495057;
  padding: .75rem;
  font-size: .8rem;
  font-weight: 600;
}

.pages-article-view .amendment-history-table td {
  border-bottom: 1px solid #e9ecef;
  padding: .75rem;
}

.pages-article-view .amendment-history-table tr:last-child td {
  border-bottom: none;
}

.pages-article-view .amendment-history-table tr:hover {
  background: #f8f9fa;
}

.pages-article-view .amendment-history-table a {
  color: #007bff;
  text-decoration: none;
}

.pages-article-view .amendment-history-table a:hover {
  text-decoration: underline;
}

.pages-amendment-index {
  max-width: var(--main-column-width);
  margin: 0 auto;
  padding: 1rem;
}

/* public/content.css */
.constitution-wrapper {
  background-color: #f5f5f5;
  border-top: 1px solid #ccc;
  margin-top: 1rem;
}

.constitution-context {
  background-color: #eee;
  border-bottom: 1px dashed #ccc;
}

.constitution-context-inner {
  color: #454545;
  max-width: var(--main-column-width);
  text-align: center;
  margin: 0 auto;
  padding: .5rem 1rem;
  font-family: Helvetica, Arial, sans-serif;
  font-size: .8rem;
}

.constitution-content {
  max-width: var(--main-column-width);
  margin: 0 auto;
  padding: 1rem;
  font-family: Georgia, serif;
}

@keyframes highlight-fade {
  0% {
    background-color: #fed053;
  }

  100% {
    background-color: #f8eccb;
    border-color: #fddd85;
  }
}

.constitution-content a.location-reference {
  text-decoration: underline dashed;
}

.constitution-content h2 {
  color: #333;
}

.constitution-content h3 {
  color: #333;
}

.constitution-content h2 {
  text-align: center;
  border-bottom: 3px double #2c3e50;
  padding-bottom: 1rem;
  font-size: 1.5rem;
}

.constitution-content .heading {
  display: flex;
  justify-content: space-between;
}

.constitution-content .article-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.constitution-content .article-wrapper a {
  color: #666;
  font-style: italic;
}

.constitution-content section {
  margin: 1.5rem 0;
}

.constitution-content blockquote {
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  margin: .8rem;
  padding: 1rem;
}

.constitution-content p {
  text-indent: 1em;
  margin: 0 0 .4rem;
}

.constitution-content p + p {
  text-indent: 1em;
  margin-top: 1rem;
}

.constitution-content .toc {
  padding: 0;
  font-size: .8rem;
}

.constitution-content .toc ol {
  list-style-type: none;
  padding: 0;
}

.constitution-content .toc li + li a {
  padding-top: .5em;
}

.constitution-content .toc li > a {
  color: #222;
  text-decoration: none;
  display: grid;
  grid-template-columns: auto max-content;
  align-items:  end;
}

.constitution-content .toc li > a > .title {
  position: relative;
  overflow: hidden;
  text-transform: uppercase;
}

.constitution-content .toc li > a .leaders:after {
  color: #aaa;
  position: absolute;
  content: " . . . . . . . . . . . . . . . . . . . " ". . . . . . . . . . . . . . . . . . . . . . . " ". . . . . . . . . . . . . . . . . . . . . . . " ". . . . . . . . . . . . . . . . . . . . . . . " ". . . . . . . . . . . . . . . . . . . . . . . " ". . . . . . . . . . . . . . . . . . . . . . . " ". . . . . . . . . . . . . . . . . . . . . . . ";
  text-align: right;
  padding-inline-start: .25ch;
  padding-inline-end: .5ch;
}

.constitution-content .toc li > a > .page {
  font-variant-numeric: tabular-nums;
  text-align: right;
  min-width: 2ch;
}

.constitution-content .number {
  color: #0a4d49;
}

.constitution-content h2 {
  color: #0a4d49;
}

.constitution-content h3 {
  color: #0a4d49;
}

.constitution-content .article {
  margin-top: 2rem;
}

.constitution-content .article h3 {
  margin: 0;
  font-size: 1.25rem;
}

.constitution-content .article .heading {
  display: flex;
  justify-content: space-between;
}

.constitution-content .article .links a {
  color: #007bff;
  cursor: pointer;
  display: inline-block;
  text-decoration: none;
  background-color: #0000;
  border: none;
  border-radius: .2rem;
  padding: .1rem .5rem;
  transition: background-color .3s, color .3s;
  font-size: 1rem;
}

.constitution-content .article .links a:hover {
  color: #0056b3;
  background-color: #e7f1ff;
}

.constitution-content .article ol {
  margin: 0;
}

.constitution-content .article > ol {
  list-style-position: inside;
  padding-left: 0;
}

.constitution-content .article > ol li {
  counter-increment: level1;
  position: relative;
  display: flex;
  align-items:  flex-start;
  margin-bottom: .5em;
  padding-left: 1.5em;
}

.constitution-content .article > ol li:before {
  content: counters(level1, ".") ".";
  position: absolute;
  text-align: right;
  flex-shrink: 0;
  left: 0;
}

.constitution-content ol.list-type-decimal-degree {
  list-style: none;
  counter-reset: subsection;
  padding-left: 0;
}

.constitution-content ol.list-type-decimal-degree > li {
  counter-increment: subsection;
  position: relative;
  margin-bottom: .5em;
  padding-left: 2em;
}

.constitution-content ol.list-type-decimal-degree > li:before {
  content: counters(subsection, ".") "°";
  position: absolute;
  text-align: right;
  width: 1.5em;
  left: 0;
}

.constitution-content ol.list-type-lower-roman {
  list-style: none;
  counter-reset: paragraphs;
  padding-left: 0;
}

.constitution-content ol.list-type-lower-roman > li {
  counter-increment: paragraphs;
  position: relative;
  margin-bottom: .5em;
  padding-left: 2em;
}

.constitution-content ol.list-type-lower-roman > li:before {
  content: counters(paragraphs, ".", lower-roman) ".";
  position: absolute;
  text-align: right;
  width: 1.5em;
  left: 0;
}

.constitution-content .section:target {
  animation: highlight-fade 1s .25s forwards ease-in-out;
  background-color: #fed053;
  border: 2px dashed #fb0;
  border-radius: .2rem;
  scroll-margin-top: 2rem;
}

.constitution-content .subsection:target {
  animation: highlight-fade 1s .25s forwards ease-in-out;
  background-color: #fed053;
  border: 2px dashed #fb0;
  border-radius: .2rem;
  scroll-margin-top: 2rem;
}

.constitution-content .numbered-paragraph:target {
  animation: highlight-fade 1s .25s forwards ease-in-out;
  background-color: #fed053;
  border: 2px dashed #fb0;
  border-radius: .2rem;
  scroll-margin-top: 2rem;
}

/* public/part.css */
.part.preamble p {
  font-style: italic;
}

/* public/print.css */
@media print {
  body {
    color: #000;
    background: #fff;
    margin: 1in;
    padding: 0;
  }

  article {
    box-shadow: none;
    break-inside: avoid;
  }
}

/* public/table.css */
table {
  border-collapse: collapse;
  width: 100%;
  font-size: .9rem;
}

thead {
  position: sticky;
  z-index: 1;
  background: #fff;
  top: 0;
}

th, td {
  text-align: left;
  vertical-align: top;
}

tr.article-row {
  border-top: 1px solid #d0d0d0;
}

tr.article-row td {
  padding: .2em .1em;
}

.right-aligned {
  text-align: right;
}

.amendments-header {
  display: flex;
  text-transform: uppercase;
  justify-content: center;
  align-items:  center;
}

.amendments-header:after, .amendments-header:before {
  content: "";
  background: #d0d0d0;
  width: 100%;
  height: 2px;
  margin: 0 10px;
}

/* public/style.css */

