.alphakat_generator {
  background: var(--primary) var(--module_background);
  font-family: var(--font_main);
  padding: 50px 20px;
  position: relative;
  width: 100vw; }
  .alphakat_generator.empty #design {
    display: none; }
  .alphakat_generator form {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 auto;
    width: 100%;
    max-width: 1000px; }
  .alphakat_generator legend {
    font-family: var(--font_feature);
    font-size: 4em;
    line-height: 1.2;
    margin-bottom: 50px;
    text-align: center;
    width: 100%; }
  .alphakat_generator .subtitle {
    font-size: 20px;
    margin-bottom: 30px;
    text-align: center;
    width: 100%; }
  .alphakat_generator button {
    background: transparent;
    border: none;
    padding: 0; }
  .alphakat_generator input[type="radio"] {
    display: none; }
    .alphakat_generator input[type="radio"] + label.radio {
      display: flex;
      cursor: pointer;
      font-size: 18px;
      line-height: 1;
      margin: 10px;
      padding: 0;
      position: relative; }
      .alphakat_generator input[type="radio"] + label.radio:before, .alphakat_generator input[type="radio"] + label.radio:after {
        border-radius: 50%;
        display: inline-block; }
      .alphakat_generator input[type="radio"] + label.radio:before {
        background: #fff;
        border: 1px solid black;
        content: '';
        height: 1em;
        margin-right: 1ch;
        width: 1em; }
      .alphakat_generator input[type="radio"] + label.radio:after {
        background: var(--primary);
        top: calc((0.1 * 1em) + 1px);
        left: calc((0.1 * 1em) + 1px);
        height: 0.8em;
        position: absolute;
        width: 0.8em; }
    .alphakat_generator input[type="radio"]:checked + label.radio:after {
      content: ''; }
  .alphakat_generator .fieldset.letters {
    background: #fff;
    box-shadow: 11px 11px 0px 0px rgba(35, 31, 32, 0.3);
    padding: 30px;
    display: flex;
    justify-content: center;
    position: relative;
    width: auto;
    max-width: 100%;
    overflow-x: hidden; }
    .alphakat_generator .fieldset.letters button {
      cursor: pointer;
      flex-shrink: 0; }
      .alphakat_generator .fieldset.letters button[data-index] {
        box-shadow: inset 2px 2px 2px rgba(255, 255, 255, 0.4), inset -2px -2px 2px rgba(0, 0, 0, 0.4);
        margin: 5px;
        line-height: 1; }
      .alphakat_generator .fieldset.letters button img {
        height: auto;
        width: 50px;
        min-width: 50px; }
    .alphakat_generator .fieldset.letters.navy {
      background: #1C3073; }
    .alphakat_generator .fieldset.letters.black {
      background: #000; }
    .alphakat_generator .fieldset.letters.bw img {
      filter: grayscale(100); }
  .alphakat_generator .fieldset.boards, .alphakat_generator .fieldset.colour {
    padding: 40px 10px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%; }
  .alphakat_generator #create input[type="text"] {
    border: 1px solid #fff;
    flex-grow: 1;
    font-size: 1.2em;
    letter-spacing: 0.2em;
    line-height: 1.5;
    padding: 20px;
    text-transform: uppercase;
    width: calc(100% - 80px); }
  .alphakat_generator #create input[type="submit"] {
    background: var(--secondary);
    border: none;
    color: #fff;
    cursor: pointer;
    font-size: 18px;
    font-weight: bold;
    padding: 20px;
    width: 80px; }
    .alphakat_generator #create input[type="submit"]:active, .alphakat_generator #create input[type="submit"]:hover, .alphakat_generator #create input[type="submit"]:focus {
      background: #fff;
      color: var(--secondary); }
  .alphakat_generator #design {
    margin-top: 50px; }
    .alphakat_generator #design label[for="navy"] {
      background: #1C3073;
      color: #fff; }
    .alphakat_generator #design label[for="black"] {
      background: #000;
      color: #fff; }
    .alphakat_generator #design label[for="white"] {
      background: #fff; }
    .alphakat_generator #design .instruct {
      font-size: 2em;
      font-weight: bold;
      margin-top: 100px;
      text-align: center;
      text-transform: uppercase;
      width: 100%; }
    .alphakat_generator #design input[type="submit"] {
      background: var(--secondary);
      border: none;
      box-shadow: 2px 2px 0px 0px #fff;
      color: #fff;
      cursor: pointer;
      font-size: 20px;
      padding: 20px 35px;
      text-transform: uppercase;
      transition: all 300ms ease 0ms; }
      .alphakat_generator #design input[type="submit"]:hover {
        letter-spacing: 2px; }
  .alphakat_generator .boards input[type="radio"], .alphakat_generator .boards input input[type="checkbox"] {
    display: none; }
    .alphakat_generator .boards input[type="radio"] + label, .alphakat_generator .boards input input[type="checkbox"] + label {
      box-shadow: 2px 2px 0px 0px rgba(35, 31, 32, 0.3);
      cursor: pointer;
      font-size: 18px;
      margin: 10px;
      padding: 17px 32px;
      text-transform: uppercase;
      transition: all 300ms ease 0ms; }
      .alphakat_generator .boards input[type="radio"] + label:hover, .alphakat_generator .boards input input[type="checkbox"] + label:hover {
        letter-spacing: 1px; }
  .alphakat_generator .lightbox {
    background: white;
    display: none;
    padding: 20px;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 50; }
    .alphakat_generator .lightbox.open {
      display: block; }
    .alphakat_generator .lightbox .tags {
      display: flex;
      flex-wrap: wrap;
      font-size: 18px;
      margin-bottom: 30px;
      text-transform: uppercase; }
      .alphakat_generator .lightbox .tags legend {
        font-family: var(--font_main);
        font-size: 1em;
        font-weight: bold;
        margin: 0;
        width: auto; }
      .alphakat_generator .lightbox .tags ul {
        display: flex; }
      .alphakat_generator .lightbox .tags ul, .alphakat_generator .lightbox .tags li {
        list-style: none;
        padding: 0;
        margin: 0; }
      .alphakat_generator .lightbox .tags label.radio {
        font-size: 1em; }
    .alphakat_generator .lightbox h2 {
      color: var(--primary);
      font-weight: bold;
      padding-bottom: 30px;
      text-transform: uppercase;
      text-align: center; }
    .alphakat_generator .lightbox .close {
      background: none;
      border: 2px solid transparent;
      position: absolute;
      top: 20px;
      right: 20px; }
      .alphakat_generator .lightbox .close:before {
        background: url("../img/close.svg");
        background-size: contain;
        content: '';
        display: block;
        height: 20px;
        width: 20px; }
      .alphakat_generator .lightbox .close:hover, .alphakat_generator .lightbox .close:focus {
        border-color: var(--secondary); }
      .alphakat_generator .lightbox .close span {
        opacity: 0;
        position: absolute;
        right: -200vw; }
    .alphakat_generator .lightbox .options {
      display: grid;
      grid-template-columns: repeat(auto-fill, 70px);
      grid-gap: 10px;
      overflow-y: auto;
      max-height: 70vh; }
      .alphakat_generator .lightbox .options button {
        display: inline;
        line-height: 1; }
        .alphakat_generator .lightbox .options button img {
          width: 100%; }
      .alphakat_generator .lightbox .options.filtered button {
        display: none; }
        .alphakat_generator .lightbox .options.filtered button.visible {
          display: block; }
  .alphakat_generator .mobile-warning {
    background: #fff;
    font-size: 1.2em;
    font-weight: bold;
    padding: 20px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }

@media (min-width: 480px) {
  .alphakat_generator {
    padding: 50px; }
    .alphakat_generator legend {
      font-size: 5em; }
    .alphakat_generator input[type="radio"] + label.radio {
      font-size: 20px; }
    .alphakat_generator #create input[type="text"] {
      font-size: 1.5em;
      width: calc(100% - 100px); }
    .alphakat_generator #create input[type="submit"] {
      font-size: 20px;
      padding: 20px;
      width: 100px; }
    .alphakat_generator .boards input[type="radio"] + label, .alphakat_generator .boards input input[type="checkbox"] + label {
      font-size: 20px;
      padding: 17px 32px; }
      .alphakat_generator .boards input[type="radio"] + label:hover, .alphakat_generator .boards input input[type="checkbox"] + label:hover {
        letter-spacing: 2px; } }

@media (min-width: 650px) {
  .alphakat_generator {
    padding: 100px 20px; }
    .alphakat_generator input[type="radio"] + label.radio {
      margin: 0 10px; }
    .alphakat_generator #create input[type="text"] {
      font-size: 2em;
      padding: 20px 50px;
      width: calc(100% - 125px); }
    .alphakat_generator #create input[type="submit"] {
      padding: 20px 50px;
      width: 125px; }
    .alphakat_generator .fieldset.letters {
      position: static;
      overflow-x: auto; }
    .alphakat_generator .mobile-warning {
      display: none; } }

@media (min-width: 1000px) {
  .alphakat_generator #create input[type="text"] {
    width: auto; }
  .alphakat_generator #create input[type="submit"] {
    width: auto; }
  .alphakat_generator .fieldset.letters button img {
    width: 80px; }
  .alphakat_generator .fieldset.boards, .alphakat_generator .fieldset.colour {
    padding: 50px; }
  .alphakat_generator .boards input[type="radio"] + label, .alphakat_generator .boards input input[type="checkbox"] + label {
    margin: 0 10px; }
  .alphakat_generator .lightbox {
    background: rgba(255, 255, 255, 0.9);
    padding: 50px;
    top: 10vh;
    left: 15vw;
    right: 15vw;
    bottom: auto; }
    .alphakat_generator .lightbox .tags {
      flex-wrap: nowrap; }
    .alphakat_generator .lightbox .options {
      grid-template-columns: repeat(auto-fill, 100px);
      max-height: 60vh; } }

@media (min-width: 1200px) {
  .alphakat_generator .fieldset.letters button img {
    width: 100px; }
  .alphakat_generator #design {
    max-width: 1200px; }
  .alphakat_generator .lightbox {
    left: 20vw;
    right: 20vw; } }
