:root {
  --colorBlack: #15171a;
  --colorWhite: #fefeff;
  --colorTomato: #dd3b40;
  --colorChocolate: #c05b2c;
  --colorGold: #9f7e00;
  --colorOlive: #688200;
  --colorForest: #008c22;
  --colorTeal: #008780;
  --colorCerulean: #0081b1;
  --colorDenim: #477f9b;
  --colorDanube: #5d79aa;
  --colorLavender: #a156d2;
  --colorAzalea: #d43892;
  --colorCoral: #a36969;
  --colorBlackRGB: 21, 23, 26;
  --colorWhiteRGB: 254, 254, 255;
  --colorTomatoRGB: 240, 59, 64;
  --colorChocolateRGB: 192, 91, 44;
  --colorGoldRGB: 159, 126, 0;
  --colorOliveRGB: 104, 130, 0;
  --colorForestRGB: 0, 140, 34;
  --colorTealRGB: 0, 135, 128;
  --colorCeruleanRGB: 0, 129, 177;
  --colorDenimRGB: 71, 127, 155;
  --colorDanubeRGB: 93, 121, 170;
  --colorLavenderRGB: 161, 86, 210;
  --colorAzaleaRGB: 212, 56, 146;
  --colorCoralRGB: 163, 105, 105;
  --colorBase: var(--colorBlack);
  --colorBaseInvert: var(--colorWhite);
  --colorLink: var(--colorBlack);
  --colorLinkInvert: var(--colorWhite);
  --bgBase: var(--colorWhite);
  --bgBand: var(--colorBlack);
  --borderInput: var(--colorBlackRGB);
  --contentPadding: .75rem;
  --contentWidth: 40rem;
}

.-Tomato {
  --colorAccent: var(--colorTomato);
  --colorLink: var(--colorTomato);
  --bgBand: var(--colorTomato);
}

.-Chocolate {
  --colorAccent: var(--colorChocolate);
  --colorLink: var(--colorChocolate);
  --bgBand: var(--colorChocolate);
}

.-Gold {
  --colorAccent: var(--colorGold);
  --colorLink: var(--colorGold);
  --bgBand: var(--colorGold);
}

.-Olive {
  --colorAccent: var(--colorOlive);
  --colorLink: var(--colorOlive);
  --bgBand: var(--colorOlive);
}

.-Forest {
  --colorAccent: var(--colorForest);
  --colorLink: var(--colorForest);
  --bgBand: var(--colorForest);
}

.-Teal {
  --colorAccent: var(--colorTeal);
  --colorLink: var(--colorTeal);
  --bgBand: var(--colorTeal);
}

.-Cerulean {
  --colorAccent: var(--colorCerulean);
  --colorLink: var(--colorCerulean);
  --bgBand: var(--colorCerulean);
}

.-Denim {
  --colorAccent: var(--colorDenim);
  --colorLink: var(--colorDenim);
  --bgBand: var(--colorDenim);
}

.-Danube {
  --colorAccent: var(--colorDanube);
  --colorLink: var(--colorDanube);
  --bgBand: var(--colorDanube);
}

.-Lavender {
  --colorAccent: var(--colorLavender);
  --colorLink: var(--colorLavender);
  --bgBand: var(--colorLavender);
}

.-Azalea {
  --colorAccent: var(--colorAzalea);
  --colorLink: var(--colorAzalea);
  --bgBand: var(--colorAzalea);
}

.-Coral {
  --colorAccent: var(--colorCoral);
  --colorLink: var(--colorCoral);
  --bgBand: var(--colorCoral);
}

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

html {
  margin: 0;
  padding: 0;
}

body {
  color: var(--colorBlack);
  accent-color: var(--colorAccent);
  background-color: var(--bgBase);
  grid-template-rows: auto 1fr auto;
  gap: 1rem;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 1.125rem;
  display: grid;
}

main {
  display: block;
}

a:link, a:visited, a:hover, a:focus, a:active {
  color: var(--colorLink);
}

a.-invert:link, a.-invert:visited, a.-invert:hover, a.-invert:focus, a.-invert:active {
  color: var(--colorLinkInvert);
}

:focus {
  outline-color: var(--colorAccent);
}

.Header {
  color: var(--colorBaseInvert);
  background-color: var(--bgBand);
}

.Header__inner {
  padding: var(--contentPadding);
  max-width: var(--contentWidth);
  align-items: center;
  margin: auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.Header__inner > * + * {
  margin-left: 1rem;
}

.Header__title {
  margin-top: 0;
  margin-bottom: 0;
}

.Header__link {
  border-radius: 999rem;
  -webkit-box-flex: 0;
  -webkit-flex: none;
  -ms-flex: none;
  flex: none;
  width: 2.625rem;
  height: 2.625rem;
  display: block;
  overflow: hidden;
}

.Header__logo {
  display: block;
}

.Header__desc {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1rem;
}

.Footer {
  color: var(--colorBaseInvert);
  background-color: var(--bgBand);
}

.Footer__inner {
  padding: var(--contentPadding);
  max-width: var(--contentWidth);
  justify-content: space-between;
  margin: auto;
  font-size: 1rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.Footer__inner > * + * {
  margin-left: 1rem;
}

.Footer__credit, .Footer__license {
  margin-top: 0;
  margin-bottom: 0;
}

.Main {
  padding: 0 var(--contentPadding);
  max-width: var(--contentWidth);
  grid-template: "t t t t"
                 "w cw cw cw"
                 "r cr cr cr"
                 "ch ch ch ch"
                 "gc gc gr gr"
                 "dc dc dr dr" 1fr
                 / 1fr 1fr 1fr 1fr;
  gap: 1rem;
  width: 100%;
  margin: 0 auto;
  display: grid;
}

.Type {
  -webkit-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  grid-area: t;
  align-items: baseline;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.Type__label {
  width: 100%;
  margin: 0;
  font-size: .875rem;
}

.Type__item + .Type__item {
  margin-left: 1rem;
}

.Word {
  grid-area: w;
}

.Reading {
  grid-area: r;
}

.ConjugateWords {
  grid-area: cw;
}

.ConjugateReadings {
  grid-area: cr;
}

.DuplicationChecker {
  grid-area: ch;
}

.GeneratedContents {
  grid-area: gc;
}

.GeneratedReadings {
  grid-area: gr;
}

.DuplicatedContents {
  grid-area: dc;
}

.DuplicatedReadings {
  grid-area: dr;
}

.Label {
  font-size: .875rem;
  display: block;
}

.Label.-inline {
  display: inline;
}

.Input {
  border: 1px solid rgba(var(--borderInput), .25);
  color: inherit;
  vertical-align: top;
  border-radius: .125rem;
  width: 100%;
  padding: .375rem;
  font-size: 1.0625rem;
  line-height: 1.4;
}

.Input.-selection {
  border: initial;
  vertical-align: middle;
  width: auto;
}

.Input.-textarea {
  resize: vertical;
  max-width: 18.75rem;
}

.Input.-textarea.-high, .Input.-textarea.-low {
  min-height: 300px;
}

.VisuallyHidden {
  opacity: 0 !important;
  visibility: visible !important;
  border: none !important;
  width: 4px !important;
  height: 4px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  overflow: hidden !important;
}
