@charset "UTF-8";
/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */
/* calligraffitti-latin-400-normal */
@font-face {
  font-family: "Calligraffitti";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/calligraffitti-latin-400-normal.woff2") format("woff2"), url("./files/calligraffitti-latin-400-normal.woff") format("woff");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* roboto-cyrillic-ext-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-cyrillic-ext-400-normal.woff2") format("woff2"), url("./files/roboto-cyrillic-ext-400-normal.woff") format("woff");
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* roboto-cyrillic-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-cyrillic-400-normal.woff2") format("woff2"), url("./files/roboto-cyrillic-400-normal.woff") format("woff");
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* roboto-greek-ext-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-greek-ext-400-normal.woff2") format("woff2"), url("./files/roboto-greek-ext-400-normal.woff") format("woff");
  unicode-range: U+1F00-1FFF;
}
/* roboto-greek-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-greek-400-normal.woff2") format("woff2"), url("./files/roboto-greek-400-normal.woff") format("woff");
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* roboto-math-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-math-400-normal.woff2") format("woff2"), url("./files/roboto-math-400-normal.woff") format("woff");
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* roboto-symbols-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-symbols-400-normal.woff2") format("woff2"), url("./files/roboto-symbols-400-normal.woff") format("woff");
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* roboto-vietnamese-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-vietnamese-400-normal.woff2") format("woff2"), url("./files/roboto-vietnamese-400-normal.woff") format("woff");
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* roboto-latin-ext-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-latin-ext-400-normal.woff2") format("woff2"), url("./files/roboto-latin-ext-400-normal.woff") format("woff");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* roboto-latin-400-normal */
@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-latin-400-normal.woff2") format("woff2"), url("./files/roboto-latin-400-normal.woff") format("woff");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* roboto-slab-cyrillic-ext-400-normal */
@font-face {
  font-family: "Roboto Slab";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-slab-cyrillic-ext-400-normal.woff2") format("woff2"), url("./files/roboto-slab-cyrillic-ext-400-normal.woff") format("woff");
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* roboto-slab-cyrillic-400-normal */
@font-face {
  font-family: "Roboto Slab";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-slab-cyrillic-400-normal.woff2") format("woff2"), url("./files/roboto-slab-cyrillic-400-normal.woff") format("woff");
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* roboto-slab-greek-ext-400-normal */
@font-face {
  font-family: "Roboto Slab";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-slab-greek-ext-400-normal.woff2") format("woff2"), url("./files/roboto-slab-greek-ext-400-normal.woff") format("woff");
  unicode-range: U+1F00-1FFF;
}
/* roboto-slab-greek-400-normal */
@font-face {
  font-family: "Roboto Slab";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-slab-greek-400-normal.woff2") format("woff2"), url("./files/roboto-slab-greek-400-normal.woff") format("woff");
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* roboto-slab-vietnamese-400-normal */
@font-face {
  font-family: "Roboto Slab";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-slab-vietnamese-400-normal.woff2") format("woff2"), url("./files/roboto-slab-vietnamese-400-normal.woff") format("woff");
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* roboto-slab-latin-ext-400-normal */
@font-face {
  font-family: "Roboto Slab";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-slab-latin-ext-400-normal.woff2") format("woff2"), url("./files/roboto-slab-latin-ext-400-normal.woff") format("woff");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* roboto-slab-latin-400-normal */
@font-face {
  font-family: "Roboto Slab";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./files/roboto-slab-latin-400-normal.woff2") format("woff2"), url("./files/roboto-slab-latin-400-normal.woff") format("woff");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

input, textarea {
  outline: none;
}

body.pages {
  padding: 1em;
  font-size: large;
  font-family: sans-serif;
}
body.pages header {
  text-align: center;
}
body.pages header h1 {
  padding: 1em;
}
body.pages header a {
  font-family: monospace;
}
body.pages main {
  width: 100%;
  overflow: hidden;
}
body.pages footer {
  position: relative;
  width: 100%;
  overflow: hidden;
}
body.pages a {
  text-decoration: none;
  font-weight: 600;
  color: #666;
}
body.pages abbr {
  border-bottom: dotted 1px;
}
body.pages p {
  margin: 18px;
}
body.pages li {
  margin-bottom: 3px;
  margin-right: 6px;
}
body.pages h3 {
  text-align: center;
}
body.pages .tabs-slider {
  width: 100%;
  text-align: center;
}
body.pages .tabs-slider h3 {
  display: inline;
  margin: 6px;
  padding: 6px;
  border-radius: 3px;
  transition: color, background-color 0.4s;
  cursor: pointer;
  color: #333;
  background-color: #CCC;
}
body.pages .tabs-slider h3.active {
  cursor: default;
  color: #CCC;
  background-color: #333;
}
body.pages .tabs-slider .slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  text-align: left;
}
body.pages .tabs-slider .slider .slide {
  white-space: nowrap;
}
body.pages .tabs-slider .slider .slide .tab {
  white-space: normal;
  display: inline-block;
  width: 100%;
}
body.pages .tabs-slider .slider .slide .tab > * {
  margin: 21px;
}
body.pages .short-logo-desc {
  display: inline-block;
  max-width: 25%;
  vertical-align: middle;
}
body.pages .long-logo-desc {
  display: inline-block;
  max-width: 50%;
  margin-left: 18px;
  vertical-align: middle;
}
body.pages .tech-specs {
  font-family: monospace;
}
body.pages .social {
  margin: 18px;
  line-height: 200%;
}
body.pages .qr-code {
  width: 180px;
  height: 180px;
}
body.pages .uservoice-hint {
  text-align: right;
  margin-right: 64px;
}
body.pages .logo {
  vertical-align: middle;
  border: 0;
}
body.pages .mines {
  font: 48px monospace;
  color: #ccc;
  background: #333;
  padding: 6px;
  border-radius: 3px;
}

body.works {
  background-color: rgb(255, 255, 255);
  font-family: Roboto;
  cursor: pointer;
}
body.works h1 {
  padding: 1ex;
  text-align: center;
  font-size: xx-large;
  font-weight: normal;
}
body.works h1 .announcement {
  display: inline-block;
  position: relative;
}
body.works h1 .announcement .notification {
  position: absolute;
  font-size: 12pt;
  width: 15pt;
  height: 15pt;
  top: -22pt;
  left: -8pt;
  border-radius: 15pt;
  line-height: 17pt;
  background-color: red;
  color: white;
}
body.works li {
  margin: 2ex 2ex 0.5ex 0;
  font-size: x-large;
}
body.works li li {
  margin: 0.5ex 2ex;
  font-size: large;
}
body.works .tenses {
  max-width: 640px;
  width: 100%;
  margin: auto;
  overflow: scroll hidden;
  white-space: nowrap;
  scroll-padding: 12.5%;
}
body.works .tenses.scroll-snap {
  scroll-snap-type: x mandatory;
}
body.works .tenses .tense + .tense:before {
  position: absolute;
  left: -12.5%;
}
@media (max-width: 640px) {
  body.works .tenses .tense:first-child + .tense:before {
    font-size: 200%;
  }
  body.works .tenses .tense:nth-child(3):before {
    font-size: 230%;
  }
}
body.works .tenses .tense:first-child + .tense:before {
  content: "☽";
  font-size: 300%;
  font-weight: bold;
  transform: rotate(45deg);
}
body.works .tenses .tense:nth-child(3):before {
  content: "☉";
  font-size: 350%;
}
body.works .tenses .tense {
  display: inline-block;
  position: relative;
  width: 75%;
  padding: 1ex 0;
  margin: 0 6.25%;
  scroll-snap-align: start;
  white-space: normal;
  vertical-align: top;
}
body.works .tenses .tense:first-child {
  padding-left: 6.25%;
}
body.works .tenses .tense:nth-child(3) {
  padding-right: 6.25%;
}
body.works .tenses .tense h2 {
  padding: 0.5ex;
  font-weight: bold;
  text-align: center;
  opacity: 0.5;
}
body.works .tenses .tense h3 {
  padding: 0.25ex 0;
  text-align: left;
  font-size: x-large;
  font-weight: normal;
  font-style: italic;
  margin-left: -0.5ex;
}
body.works .tenses .tense a {
  color: inherit;
}
body.works .tenses .tense .work {
  margin: 3ex 0;
}
body.works .tenses .tense .work p {
  font-size: larger;
}
body.works .tenses .tense .work ul + p {
  padding-left: 1em;
  font-size: x-large;
  font-style: italic;
}
body.works .tenses .tense .work ul {
  padding-left: 1em;
}
body.works .tenses .buzz {
  width: 277%;
  padding: 100px 0;
  overflow: hidden;
}
body.works .tenses .buzz .words {
  position: relative;
  margin-left: -5%;
  transform: rotate(-3deg);
  font-size: larger;
  font-weight: bold;
  opacity: 0.5;
}
body.works .tenses .buzz .words:before {
  position: absolute;
  content: "〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜";
  bottom: 0.5ex;
  font-size: 50px;
  letter-spacing: -23px;
}
body.works .videos {
  width: 320px;
  height: 200px;
  margin: auto;
}
body.works #contact {
  height: 0;
  width: 100%;
  overflow: hidden;
  transition-property: height;
  transition-duration: 0.5s;
  font-size: large;
}
body.works #contact.open {
  height: 17ex;
}
body.works #contact .form {
  position: relative;
  width: 100%;
  height: 100%;
}
body.works #contact .form .message {
  position: absolute;
  top: 1ex;
  left: 4.5%;
  width: 90%;
  height: 10ex;
  resize: none;
  font-size: large;
}
body.works #contact .form button {
  position: absolute;
  height: 5ex;
  margin: 0;
  bottom: 1ex;
  color: rgb(255, 255, 255);
  font-size: small;
  font-weight: bold;
}
body.works #contact .form button.close {
  left: 4.5%;
  background-color: rgb(48, 24, 96);
}
body.works #contact .form button.email {
  right: 4.5%;
  background-color: rgb(96, 24, 48);
  z-index: 1;
}
@media (max-width: 640px) {
  body.works #contact .form button {
    font-size: x-small;
  }
}

.one .cut-mark {
  position: absolute;
  background-color: black;
  visibility: hidden;
}
.one .cut-mark.top-left {
  left: -0.25mm;
  top: -5mm;
  width: 0.5mm;
  height: 2.5mm;
}
.one .cut-mark.left-top {
  left: -5mm;
  top: -0.25mm;
  width: 2.5mm;
  height: 0.5mm;
}
.one .cut-mark.left-bottom {
  left: -5mm;
  bottom: -0.5mm;
  width: 2.5mm;
  height: 0.5mm;
}
.one .cut-mark.bottom-left {
  left: -0.25mm;
  bottom: -5mm;
  width: 0.5mm;
  height: 2.5mm;
}
.one .cut-mark.bottom-right {
  right: -0.5mm;
  bottom: -5mm;
  width: 0.5mm;
  height: 2.5mm;
}
.one .cut-mark.right-bottom {
  right: -5mm;
  bottom: -0.5mm;
  width: 2.5mm;
  height: 0.5mm;
}
.one .cut-mark.right-top {
  right: -5mm;
  top: -0.25mm;
  width: 2.5mm;
  height: 0.5mm;
}
.one .cut-mark.top-right {
  right: -0.5mm;
  top: -5mm;
  width: 0.5mm;
  height: 2.5mm;
}
.one.first-row .cut-mark.top-left {
  visibility: visible;
}
.one.first-row.last-col .cut-mark.top-right {
  visibility: visible;
}
.one.last-row .cut-mark.bottom-left {
  visibility: visible;
}
.one.last-row.last-col .cut-mark.bottom-right {
  visibility: visible;
}
.one.first-col .cut-mark.left-top {
  visibility: visible;
}
.one.first-col.last-row .cut-mark.left-bottom {
  visibility: visible;
}
.one.last-col .cut-mark.right-top {
  visibility: visible;
}
.one.last-col.last-row .cut-mark.right-bottom {
  visibility: visible;
}

/* TODO?
 * The default css assets setup is to include (require) everything
 * in application.css, this means this file too.
 * This maybe excessive in the future when there's more CSS or performance
 * optimisation is required
 */
body.cards {
  zoom: 2;
  font-size: 0;
}
body.cards .smart-shrinking-frame {
  position: absolute;
  left: 0;
  top: 0;
}
body.cards .one {
  display: inline-block;
  position: relative;
}
body.cards .one.front .background {
  position: absolute;
  left: -2%;
  top: -5%;
  width: 104%;
  height: 110%;
  background-color: white;
}
body.cards .one.front .description {
  display: inline-block;
  position: relative;
  width: 56%;
  height: 100%;
  text-align: center;
}
body.cards .one.front .description .name {
  position: absolute;
  top: 10%;
  width: 100%;
  font-size: xx-large;
  font-family: Roboto Slab;
}
body.cards .one.front .description .email-address {
  position: absolute;
  top: 40%;
  width: 100%;
  font-size: medium;
  font-weight: bold;
  font-family: Roboto;
}
body.cards .one.front .description .formula {
  position: absolute;
  top: 60%;
  width: 100%;
  font-size: xx-large;
  font-family: Calligraffitti;
}
body.cards .one.back .background {
  position: absolute;
  left: -2%;
  top: -5%;
  width: 104%;
  height: 110%;
  background-color: white;
}
body.cards .one.back .re-cycle {
  position: absolute;
  ledt: 0;
  bottom: 0;
  padding: 2%;
  font-size: large;
}
body.cards .one.back .re-cycle:before {
  content: "♲";
}
body.cards .one.back .description {
  display: inline-block;
  position: relative;
  width: 60%;
  height: 100%;
  text-align: center;
}
body.cards .one.back .description .gag {
  position: absolute;
  top: 40%;
  width: 100%;
  font-size: xx-large;
  font-weight: bold;
  font-family: Calligraffitti;
}
body.cards .qr {
  display: inline-block;
  position: relative;
  width: 40%;
  height: 100%;
}
body.cards .code {
  position: absolute;
  left: 10%;
  top: 10%;
  width: 80%;
  height: 80%;
}

body.public_announcements {
  background-color: rgb(255, 255, 255);
  font-family: Roboto;
}
body.public_announcements h1 {
  padding: 1ex;
  text-align: center;
  font-size: xx-large;
  font-weight: normal;
}
body.public_announcements .public-announcements {
  margin: auto;
  max-width: 120ex;
}
body.public_announcements .public-announcements .public-announcement {
  padding: 2ex;
}
body.public_announcements .public-announcements .public-announcement h2 {
  padding: 2ex;
  font-weight: bold;
  text-align: center;
  opacity: 0.5;
}
body.public_announcements .public-announcements .public-announcement h3 {
  padding: 2ex 0 1ex 0;
  text-align: left;
  font-size: x-large;
  font-weight: normal;
  font-style: italic;
  margin-left: -0.5ex;
}
body.public_announcements .public-announcements .public-announcement h4 {
  padding: 2ex 0 1ex 0;
  text-align: left;
  font-weight: bold;
}
body.public_announcements .public-announcements .public-announcement .block {
  display: block;
}
body.public_announcements .public-announcements .public-announcement a {
  text-decoration: none;
}
body.public_announcements .public-announcements .public-announcement p {
  line-height: 150%;
  font-family: Roboto Slab;
}
body.public_announcements .public-announcements .public-announcement .date {
  font-size: large;
}
body.public_announcements .public-announcements .public-announcement .date:after {
  content: "🔗";
  font-size: small;
}
body.public_announcements .public-announcements .public-announcement li {
  margin: 2ex 2ex 0.5ex 0;
  line-height: 150%;
  font-family: Roboto Slab;
}
body.public_announcements .public-announcements .public-announcement li li {
  margin: 0.5ex 2ex;
}
body.public_announcements #contact {
  height: 17ex;
  width: 100%;
  overflow: hidden;
  transition-property: height;
  transition-duration: 0.5s;
  font-size: large;
}
body.public_announcements #contact .form {
  position: relative;
  width: 100%;
  height: 100%;
}
body.public_announcements #contact .form .message {
  position: absolute;
  top: 1ex;
  left: 4.5%;
  width: 90%;
  height: 10ex;
  resize: none;
  font-size: large;
}
body.public_announcements #contact .form button {
  position: absolute;
  height: 5ex;
  margin: 0;
  bottom: 1ex;
  color: rgb(255, 255, 255);
  font-size: small;
  font-weight: bold;
}
body.public_announcements #contact .form button.email {
  right: 4.5%;
  background-color: rgb(96, 24, 48);
  z-index: 1;
}
@media (max-width: 640px) {
  body.public_announcements #contact .form button {
    font-size: x-small;
  }
}
