body {
  margin: 0;
  padding: 0 15px;
  font-family: Verdana, sans-serif;
  font-size: 18px;
  color: #140235;
  background: white; }

a {
  color: #660066;
  text-decoration: underline; }
  a:hover {
    color: #990099;
    cursor: pointer; }

div.page {
  max-width: 900px;
  margin: 40px auto; }

header {
  display: flex;
  align-items: center;
  justify-content: center; }
  header div.logobox {
    width: 96px;
    height: 96px;
    font-size: 22px;
    font-weight: bold;
    flex: 96px 1 auto; }
    header div.logobox a {
      background: #660066;
      border-radius: 13px;
      height: 100%;
      width: 100%;
      color: white;
      display: flex;
      align-items: center;
      justify-content: flex-end;
      text-decoration: none; }
      header div.logobox a:hover {
        background: #593559; }
      header div.logobox a span {
        padding: 10px;
        align-self: flex-end;
        text-align: right; }
  header div.membershipareabox {
    margin-top: 52px;
    margin-left: 10px;
    font-weight: 600; }
  header nav {
    flex: 1 1 auto;
    width: auto;
    padding-left: 20px;
    text-align: right; }

h1 {
  margin: 20px 0;
  font-size: 32px;
  font-weight: normal; }

section.body {
  padding: 20px 0; }
  section.body > :first-child {
    margin-top: 0; }

section.body__embed {
  margin: 0 -15px;
  padding: 0; }

.pagination {
  margin: 15px 0;
  text-align: center; }

.message {
  margin: 15px 0;
  padding: 10px 15px;
  font-weight: bold;
  background: #d6d0e0;
  color: #660066; }

footer {
  margin-top: 25px;
  text-align: right;
  font-size: 16px;
  color: #140235; }
  footer a {
    color: #888; }

video {
  margin: 15px 0;
  width: 100%; }

.box-80 {
  width: 80%;
  margin: 0 auto; }

.right {
  text-align: right; }

.table {
  width: 100%;
  border: 1px solid #ddd;
  border-collapse: collapse; }

.table th {
  background: #ddd;
  text-align: left;
  padding: 5px 10px; }

.table td {
  text-align: left;
  padding: 5px 10px;
  border: 1px solid #ddd; }

dl {
  margin: 15px 0; }

dt {
  font-weight: bold;
  margin: 10px 0;
  padding: 0; }

dt small {
  font-weight: normal; }

dd {
  font-weight: normal;
  margin: 10px 0 10px 40px;
  padding: 0; }

input[type="text"], input[type="number"], input[type="tel"], select {
  font-family: Verdana, sans-serif;
  font-size: 18px; }

input:disabled, button:disabled {
  cursor: default !important;
  background: #eee;
  border-color: #ccc;
  color: #666; }

.btn {
  font-family: Verdana, sans-serif;
  font-size: 18px;
  padding: 10px 15px;
  border: 1px solid #ccc;
  background: white;
  border: 2px solid #ccc;
  color: #140235;
  cursor: pointer;
  text-decoration: none; }

.btn:hover {
  color: inherit; }

.btn--small {
  font-size: 13px;
  font-weight: 600;
  padding: 5px 7px; }

.btn__primary {
  background: #660066;
  color: white;
  border-color: #660066; }
  .btn__primary:hover {
    background: #990099;
    color: white; }
  .btn__primary:disabled {
    background: #eee;
    border-color: #ccc;
    color: #666; }

.btn__delete {
  background: #dd0000;
  color: white;
  border-color: #dd0000; }
  .btn__delete:hover {
    background: #ff1111;
    color: white; }
  .btn__delete:disabled {
    background: #eee;
    border-color: #ccc;
    color: #666; }

.field {
  border: 2px solid #ccc;
  padding: 3px 5px;
  border-radius: 3px; }
  .field:focus {
    outline: none;
    border-color: #999999; }

.field--error {
  border-color: #962607; }

.error {
  margin: 5px 0;
  color: #962607; }

.actionbar {
  font-size: 0;
  margin-top: 30px; }

.actionbar > * + * {
  margin-left: 8px; }

.creditcardinput {
  margin: 25px 0; }

.qrcode {
  border-collapse: collapse; }

.donationflow {
  margin: 25px 0;
  background: #eee; }
  .donationflow ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex; }

.donationplan p.actionbar {
  margin-top: 25px; }

.flowitem {
  background: #660066;
  color: white;
  font-size: 15px;
  font-weight: 400; }

.flowitem > * {
  display: block;
  background: transparent;
  color: inherit;
  text-decoration: inherit;
  padding: 5px 10px; }
  .flowitem > *:hover {
    color: inherit; }

.flowitem__done {
  background: #660066; }

@keyframes flowitem-current-color {
  0% {
    background: #610061; }
  50% {
    background: #850085; }
  100% {
    background: #610061; } }

.flowitem__current {
  background: #660066;
  font-weight: 600;
  animation: flowitem-current-color 3s infinite; }

.flowitem__pending {
  background: #eee;
  color: #660066; }

.donationhint {
  background: #d6d0e0;
  border: 2px solid #660066;
  padding: 10px;
  margin: 25px 0;
  border-radius: 5px;
  overflow: hidden; }
  .donationhint > p {
    margin: 0; }
  .donationhint video {
    width: 350px;
    margin: 0 0 0 15px;
    float: right; }
  .donationhint small {
    display: block;
    margin-top: 25px; }
    .donationhint small p {
      margin: 5px 0; }

.sharebuttons {
  display: flex; }
  .sharebuttons .social-icon {
    border-radius: 2px; }
  .sharebuttons > span + span {
    margin-left: 6px; }
  .sharebuttons > span:hover {
    cursor: pointer;
    filter: drop-shadow(0 0 5px #aaa);
    opacity: 0.7; }

.fundraising .bar {
  margin-bottom: 40px;
  height: 50px;
  display: flex;
  background: #d6d0e0;
  position: relative; }

.fundraising .goal {
  position: absolute;
  top: 100%;
  margin-top: 4px;
  bottom: 0; }

.fundraising .goal-name, .fundraising .goal-amount {
  display: block;
  font-size: 14px;
  font-weight: bold; }

.fundraising .goal-name {
  color: #888; }

.fundraising .mark {
  position: absolute;
  top: 0;
  bottom: 0;
  margin-left: -1px;
  border-right: 2px solid #660066; }

.fundraising .progress {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  background: #660066;
  animation: flowitem-current-color 3s infinite; }

.perks {
  margin: 0;
  display: flex;
  align-items: center; }

@keyframes perk-shine {
  0% {
    background: #610061; }
  50% {
    background: #850085; }
  100% {
    background: #610061; } }

.perk {
  display: inline-block;
  border: 3px solid gray;
  border-radius: 50%;
  width: 70px;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 10px 5px 0;
  color: #888;
  filter: drop-shadow(0 0 5px #aaa);
  cursor: pointer; }

.perk span.perk-name {
  font-weight: bold;
  color: inherit; }

.no-perk {
  color: #660066;
  border-color: #660066;
  background: rgba(102, 0, 102, 0.42); }

.silver-perk {
  color: #9dacb7;
  border-color: #9dacb7;
  background: #edf0f2; }

.gold-perk {
  color: #D4AF37;
  border-color: #D4AF37;
  background: #f2eee1; }

@keyframes silver-perk-shine {
  0% {
    background: #dee4e7;
    color: #9dacb7; }
  50% {
    background: white;
    color: #bac5cd; }
  100% {
    background: #dee4e7;
    color: #9dacb7; } }

@keyframes gold-perk-shine {
  0% {
    background: #eae4cf;
    color: #D4AF37; }
  50% {
    background: white;
    color: #ddc061; }
  100% {
    background: #eae4cf;
    color: #D4AF37; } }

.silver-perk__active {
  animation: silver-perk-shine 4s infinite; }

.gold-perk__active {
  animation: gold-perk-shine 4s infinite; }

.no-perk__inactive, .silver-perk__inactive, .gold-perk__inactive {
  color: #ccc;
  border-color: #ccc;
  background: #fafafa;
  filter: none; }

.inactive {
  color: #888; }

div.admin-page {
  margin: 40px auto;
  padding: 0 40px; }

.auditlog {
  font-size: 15px;
  border: 2px solid #ccc;
  border-collapse: collapse;
  width: 100%;
  margin: 10px 0; }
  .auditlog th {
    font-weight: normal;
    text-align: left;
    width: 240px;
    padding: 5px;
    background: #eee;
    border: 2px solid #ccc;
    vertical-align: top; }
  .auditlog td {
    vertical-align: top;
    border: 2px solid #ccc;
    padding: 5px; }
    .auditlog td pre {
      padding: 0;
      margin: 0; }

table tr.admin {
  background: #d6d0e0; }

/*# sourceMappingURL=style.css.map*/