html {
  font-family: sans-serif;
  font-size: 16px;
  --blueprint-blue: hsl(218, 63%, 32%);
  --blueprint-white: white;
  --blueprint-light-blue: hsl(218, 43%, 40%);

  --prism-green: green;
  --prism-violet: rgb(172, 55, 181);
  --prism-yellow: yellow;
  --prism-red: red;
  --prism-blue: rgb(0, 157, 255);
  --prism-orange: orange;

  --mora-jai-box-red: red;
  --mora-jai-box-orange: orange;
  --mora-jai-box-yellow: yellow;
  --mora-jai-box-green: green;
  --mora-jai-box-blue: rgb(0, 157, 255);
  --mora-jai-box-pink: pink;
  --mora-jai-box-violet: rgb(172, 55, 181);
  --mora-jai-box-white: white;
  --mora-jai-box-black: black;

  --room-size: 65px;
  --lantern-size: calc(var(--room-size) / 6);
  --mora-jai-box-size: calc(var(--room-size) / 4);

  input {
    font-size: inherit;
  }

  input:focus {
    font-size: inherit;
  }

  body {
    background-color: var(--blueprint-blue);
    color: var(--blueprint-white);
    font-weight: bold;
    box-sizing: border-box;
    margin: 0;

    &:has(dialog[open]) {
      overflow: hidden;
    }

    main {
      margin-block-start: 20px;
      margin-block-end: calc(2em + 20px);

      #grid-wrapper {
        width: min-content;
        margin: 0px auto;
        padding: 4px;
        border: 3px solid var(--blueprint-white);

        #house-grid {
          margin: 0 auto;
          width: min-content;
          display: grid;
          gap: 0px;
          grid-template-rows: repeat(19, var(--room-size));
          grid-template-columns: repeat(11, var(--room-size));
          place-items: center;

          bp-room,
          bp-room-46,
          bp-junction,
          .nothing {
            width: var(--room-size);
            aspect-ratio: 1 / 1;
          }

          bp-room {
            display: grid;
            place-items: center;
            background-size: cover;
            text-align: center;
            overflow-wrap: anywhere;
            z-index: 2;

            .room-exits {
              display: none;
            }

            .room-name {
              text-transform: capitalize;
              font-size: 0.75em;
            }

            .mora-jai-contents {
              text-transform: uppercase;
              font-size: 0.75em;
            }

            .painting-solution-letter {
              text-transform: uppercase;
              font-size: 2.5em;
            }

            .mora-jai-color {
              width: var(--mora-jai-box-size);
              aspect-ratio: 1 / 1;
              border: 3px solid var(--blueprint-light-blue);

              &[box-color="black"] {
                background-color: var(--mora-jai-box-black);
              }

              &[box-color="blue"] {
                background-color: var(--mora-jai-box-blue);
              }

              &[box-color="green"] {
                background-color: var(--mora-jai-box-green);
              }

              &[box-color="orange"] {
                background-color: var(--mora-jai-box-orange);
              }

              &[box-color="pink"] {
                background-color: var(--mora-jai-box-pink);
              }

              &[box-color="red"] {
                background-color: var(--mora-jai-box-red);
              }

              &[box-color="violet"] {
                background-color: var(--mora-jai-box-violet);
              }

              &[box-color="white"] {
                background-color: var(--mora-jai-box-white);
              }

              &[box-color="yellow"] {
                background-color: var(--mora-jai-box-yellow);
              }
            }
          }

          bp-room-46 {
            background-image: url(/img/diagonal.svg);
            background-size: cover;
            background-repeat: repeat;
          }

          bp-junction {
            border: 4px dashed var(--blueprint-light-blue);
            z-index: 0;
          }

          bp-lantern {
            width: var(--lantern-size);
            height: var(--lantern-size);
            background-color: inherit;
            border: 2px solid var(--blueprint-light-blue);
            transform: rotate(45deg);
          }

          bp-lantern[prism-color="green"] {
            background-color: var(--prism-green);
            border-color: var(--prism-green);
          }

          bp-lantern[prism-color="violet"] {
            background-color: var(--prism-violet);
            border-color: var(--prism-violet);
          }

          bp-lantern[prism-color="yellow"] {
            background-color: var(--prism-yellow);
            border-color: var(--prism-yellow);
          }

          bp-lantern[prism-color="red"] {
            background-color: var(--prism-red);
            border-color: var(--prism-red);
          }

          bp-lantern[prism-color="blue"] {
            background-color: var(--prism-blue);
            border-color: var(--prism-blue);
          }

          bp-lantern[prism-color="orange"] {
            background-color: var(--prism-orange);
            border-color: var(--prism-orange);
          }

          bp-junction[top-wall] {
            border-top: 4px solid var(--blueprint-white);
          }

          bp-junction[right-wall] {
            border-right: 4px solid var(--blueprint-white);
          }

          bp-junction[bottom-wall] {
            border-bottom: 4px solid var(--blueprint-white);
          }

          bp-junction[left-wall] {
            border-left: 4px solid var(--blueprint-white);
          }
        }
      }
    }
  }

  footer#room-display {
    background-color: var(--blueprint-blue);
    position: fixed;
    overflow: hidden;
    z-index: 10;
    bottom: 0;
    width: 100%;
    margin: 0 auto;

    fieldset {
      margin: 0;
      border: 3px solid var(--blueprint-light-blue);

      display: flex;
      flex-direction: row;
      justify-content: space-evenly;

      label {
        display: flex;
        flex-direction: row;
        align-items: center;
      }
    }
  }

  bp-room-editor {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    background-color: rgb(0, 0, 0, 0);
    transition: background-color 0.1s;

    &:has(dialog[open]) {
      background-color: rgb(0, 0, 0, 0.4);
      z-index: 5;
    }

    dialog {
      background-color: var(--blueprint-blue);
      border-color: var(--blueprint-white);
      color: var(--blueprint-white);
      font-weight: bold;
      width: 80%;
      max-width: 720px;
      height: min-content;
    }

    .exits-editor {
      background-size: cover;
      height: calc(var(--room-size) * 4);
      aspect-ratio: 1 / 1;
      margin: 20px auto;
    }

    .fake-form {
      display: flex;
      width: calc(75vw + 30px);
      max-width: inherit;
      height: min-content;
      place-items: center;
      flex-wrap: wrap;
      justify-content: center;
      margin: 0 auto;

      .form-item {
        width: 200px;
        padding: 20px;

        label {
          display: block;
          margin-bottom: 8px;
        }

        select {
          font-size: inherit;
        }

        textarea {
          width: 175px;
          font-family: inherit;
        }

        input {
          width: 175px;
          text-align: center;
          min-height: 1.5em;
        }

        #painting-solution-letter {
          justify-self: center;
          font-size: 2em;
          text-transform: uppercase;
        }
      }

      button#close-editor {
        position: absolute;
        top: 1em;
        right: 1em;
        border: none;
        background-color: unset;
        color: var(--blueprint-white);

        &::after {
          content: "✕";
          font-size: 2em;
        }
      }
    }
  }

  .exits-editor,
  bp-room {
    &[room-exits="0"],
    &:not([room-exits]),
    &[room-exits=""] {
      background-image: url(img/doors-0.svg);
    }

    &[room-exits="1"] {
      background-image: url(img/doors-1.svg);
    }

    &[room-exits="2"] {
      background-image: url(img/doors-2.svg);
    }

    &[room-exits="3"] {
      background-image: url(img/doors-3.svg);
    }

    &[room-exits="4"] {
      background-image: url(img/doors-4.svg);
    }

    &[room-exits="5"] {
      background-image: url(img/doors-5.svg);
    }

    &[room-exits="6"] {
      background-image: url(img/doors-6.svg);
    }

    &[room-exits="7"] {
      background-image: url(img/doors-7.svg);
    }

    &[room-exits="8"] {
      background-image: url(img/doors-8.svg);
    }

    &[room-exits="9"] {
      background-image: url(img/doors-9.svg);
    }

    &[room-exits="10"] {
      background-image: url(img/doors-10.svg);
    }

    &[room-exits="11"] {
      background-image: url(img/doors-11.svg);
    }

    &[room-exits="12"] {
      background-image: url(img/doors-12.svg);
    }

    &[room-exits="13"] {
      background-image: url(img/doors-13.svg);
    }

    &[room-exits="14"] {
      background-image: url(img/doors-14.svg);
    }

    &[room-exits="15"] {
      background-image: url(img/doors-15.svg);
    }
  }
}
