:root {
  --c0: #FFF;
  --c1: #735871;
  --c2: #BF9BBD;
  --c3: #A686A4;
  --c4: #F2E9D8;
  --c5: #958878;
  --c6: #fff2db;
  --c7: #BFAF9B;
}

body {
  height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--c4);
}

.header {
  border-bottom: 4px solid var(--c1);
  padding: 4px 8px;
  display: flex;
  flex-direction: row;
  align-items: center;
  background: var(--c0);
}

.logo {
  display: inline-block;
  width: 116px;
  height: 26px;
  margin: 12px 0;
  margin-left: 4px;
  fill: var(--c1);
}

.logo:hover {
  fill: var(--c2);
}

.tagline {
  color: var(--c1);
  margin-left: 16px;
  padding-top: 4px;
}

section {
  margin: 16px 8px;
  max-width: 640px;
  border-bottom: 2px solid var(--c4);
}

.paragraph {
  background: var(--c6);
  border-radius: 16px;
  padding: 16px;
  border: 1px solid var(--c5);
}

h2 {
  font-weight: bold;
  font-size: 24px;
  color: var(--c1);
}

.field {
  color: var(--c1);
  display: block;
  margin-top: 8px;
  font-weight: bold;
}

.note {
  font-weight: normal;
  color: var(--c5);
}

.row {
  margin-top: 16px;
}

input[type=text], textarea {
  width: 100%;
  border: 2px solid var(--c5);
  padding: 4px 8px;
  border-radius: 4px;
  outline-color: var(--c1);
}

.mh-s {
  min-height: 90px;
}

.mh-m {
  min-height: 180px;
}

button, .button {
  background: var(--c1);
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  padding: 0 16px;
  line-height: 28px;
  border-radius: 16px;
  display: inline-block;
  margin-right: 8px;
  height: 32px;
  border: 1px solid var(--c3);
  box-shadow: 0 2px 4px var(--c3);
}

button:hover, .button:hover {
  background: var(--c3);
}

footer {
  background: var(--c1);
  margin-top: auto;
  padding: 16px 8px;
  color: var(--c4);
}

.err {
  font-size: 20px;
}

input[type=checkbox], input[type=radio] {
  display: none;
}

input[type=checkbox] + b {
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 2px solid var(--c1);
  border-radius: 8px;
  position: absolute;
}

input[type=radio] + b {
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 2px solid var(--c1);
  border-radius: 12px;
  position: absolute;
}

input[type=checkbox]:checked + b, input[type=radio]:checked + b {
  background: var(--c1);
}

input[type=checkbox]:checked + b::before, input[type=radio]:checked + b::before {
  content: "\2713";
  position: absolute;
  left: 2px;
  top: -4px;
  font-size: 18px;
  color: var(--c0);
}

input[readonly] {
  background: var(--c4);
}

.setting-row {
  position: relative;
  padding-left: 32px;
  cursor: pointer;
}

.tl {
  top: 0;
  left: 0;
}

.option {
  top: 16px;
  left: 16px;
}

.option-row {
  margin-top: 8px;
  position: relative;
  padding: 16px 16px 16px 48px;
  background: var(--c0);
  border-radius: 16px;
  box-shadow: 0px 2px 4px var(--c5);
  border: 1px solid var(--c5);
  cursor: pointer;
}

.option-row.selected {
  background: var(--c6);
}

.tally-row {
  margin-top: 8px;
  font-weight: bold;
  font-size: 24px;
  color: var(--c2);
}

.tally {
  height: 8px;
  border-radius: 4px;
  background: var(--c2);
}

.description {
  white-space: pre-wrap;
}

.link {
  border-bottom: 2px dotted var(--c5);
}

.link:hover {
  border-bottom-style: solid;
}