html {
  background: #111;
  margin: 0;
}

body {
  margin: 0;
}

.layout {
  width: 100%;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  align-content: center;
}

.header {
  width: 100%;
}

.middle {
  flex: 1;
}
.middle h2 {
  padding: 0 5px 0 10px;
}
.middle p {
  padding: 0 5px 0 20px;
}

.middle .content {
  background-clip: border-box !important;
}

.left, .right {
  container-type: size;
  container-name: baner;
  flex: 0 1 clamp(70px, 15vw, 300px);
  z-index: -1;
}

.left {
  display: flex;
  flex-direction: column;
  align-content: flex-end;
  flex-wrap: wrap;
}

.right {
  display: flex;
  flex-direction: column;
  align-content: flex-start;
  flex-wrap: wrap;
}

.center {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: flex-start;
  align-content: flex-start;
  width: 100%;
}

.footer {
  width: 100%;
}

@media screen and (max-width: 320px) {
  .middle {
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 80%;
  }
  .left, .right {
    flex-grow: 0;
    flex-shrink: 1;
    flex-basis: 10%;
  }
}
@media screen and (max-width: 500px) {
  .left {
    display: none;
    order: 1;
  }
  .middle {
    order: 3;
  }
  .right {
    order: 2;
  }
}
form {
  display: flex;
  flex-direction: column;
  width: 100%;
  z-index: 3;
  position: relative;
}

fieldset {
  display: flex;
  flex-direction: column;
  min-height: 520px;
}

.wraper {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  flex-wrap: wrap;
}

.grid-el {
  display: inline-flex;
  align-content: center;
  justify-content: center;
  flex-wrap: wrap;
  flex-direction: row;
  align-items: center;
}

.wraper-col {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 1fr;
}
.wraper-col div {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  align-items: stretch;
}

input[type=text], input[type=email], input[type=number], select, textarea {
  display: inline;
  height: 2rem;
  padding: 0.3rem 0.4rem;
  outline: 0;
  border: 1px solid #e31e24;
  margin-top: 0.4rem;
  box-sizing: border-box;
}

textarea {
  resize: vertical;
}

input[type=checkbox] {
  -webkit-appearance: none;
  display: inline-flex;
  justify-content: center;
  border: 1px solid #e31e24;
  background-color: white;
  width: 3ch;
  height: 3ch;
}

input:checked, input[type=checkbox i]:checked {
  -webkit-appearance: none;
  color: #ffffff;
  background-color: #e31e24;
  border: 1px solid white;
}

input:checked:after, input[type=checkbox i]:checked:after {
  pointer-events: none;
  content: "X";
}

input.invalid {
  background-color: white;
  color: black;
  text-decoration: underline;
}

label {
  padding: 12px 12px 12px 0;
  display: inline;
}

.wraper-steps {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  align-items: stretch;
}

.step {
  padding: 10px;
  background-color: #e31e24;
  border: none;
  display: inline-block;
  opacity: 0.5;
  flex: 1;
  text-align: center;
}
.step.active {
  background-color: #e31e24;
  color: #221f20;
  color: white;
  opacity: 1;
}
.step.finish {
  background-color: #221f20;
  color: rgba(255, 255, 255, 0.5019607843);
  opacity: 1;
}

.form-grid-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-content: stretch;
  grid-auto-flow: column;
  align-items: center;
  justify-items: stretch;
  justify-content: center;
}
.form-grid-col label {
  display: flex;
  flex-direction: row;
  justify-content: space-around;
}
.form-grid-col.nosplit {
  display: flex;
  flex-direction: column;
  align-content: center;
  justify-content: flex-start;
  align-items: center;
}

#prevBtn, #nextBtn {
  min-width: 20%;
  padding: 10px;
  background-color: #e31e24;
  border-radius: 0px;
  color: white;
  border: 0px;
}

#nextBtn {
  margin-left: 0.5ch;
}

.panel {
  border-image: url("p.webp") 22 22 22 22/22px 22px 22px/0px 0px 0px 0px;
  border-image-repeat: round;
  padding: 22px;
  background-color: #221f20;
  color: white;
  background-clip: content-box;
  box-sizing: border-box;
  z-index: 1;
  position: relative;
}

.panelnb {
  height: 130px;
  color: white;
  background-clip: content-box;
  box-sizing: border-box;
}

.invite {
  z-index: 1;
  position: relative;
}
.invite h1 {
  float: right;
  padding-right: 20px;
  font-size: 45px;
}

hr {
  border-image: url(p.webp) 22 22 22 22/22px 0px 0px/0px 8px 0px 8px;
  border-image-repeat: round;
  padding: 22px 0px 0px 0px;
}

.bastion {
  border-image: url("bastion.png") 128 128 128 128/128px 104px 0px 104px/0px 0px 0px 0px;
  border-image-repeat: round;
  border-left: 0;
  border-bottom: 0;
  border-right: 0;
  color: white;
  background-clip: content-box;
  box-sizing: border-box;
  display: flex;
  flex-grow: 2;
  border-top: 128px;
  height: 68px;
}

@container baner (width > 1px) and (width < 99px) {
  .baner {
    border-image: url("b_(0).webp") 28 28 48 28/28px 28px 48px 28px/0px 0px 0px 0px;
    width: 70px;
    padding: 28px 28px 48px 28px;
  }
}
@container baner (width > 99px) and (width < 149px) {
  .baner {
    border-image: url("b_(1).webp") 28 28 65 28/28px 28px 65px 28px/0px 0px 0px 0px;
    width: 99px;
    padding: 28px 28px 65px 28px;
  }
}
@container baner (width > 150px) and (width < 199px) {
  .baner {
    border-image: url("b_(2).webp") 28 28 81 28/28px 28px 81px 28px/0px 0px 0px 0px;
    width: 150px;
    padding: 28px 28px 81px 28px;
  }
}
@container baner (width > 200px) and (width < 249px) {
  .baner {
    border-image: url("b_(3).webp") 28 28 98 28/28px 28px 98px 28px/0px 0px 0px 0px;
    width: 200px;
    padding: 28px 28px 98px 28px;
  }
}
@container baner (width > 250px) and (width < 272px) {
  .baner {
    border-image: url("b_(4).webp") 28 28 105 28/28px 28px 105px 28px/0px 0px 0px 0px;
    width: 250px;
    padding: 28px 28px 105px 28px;
  }
}
@container baner (width > 273px) and (width < 300px) {
  .baner {
    border-image: url("b_(5).webp") 28 28 114 28/28px 28px 114px 28px/0px 0px 0px 0px;
    width: 273px;
    padding: 28px 28px 114px 28px;
  }
}
@container baner (width >= 300px) {
  .baner {
    border-image: url("b_(6).webp") 28 28 114 28/28px 28px 114px 28px/0px 0px 0px 0px;
    width: 300px;
    padding: 28px 28px 114px 28px;
  }
}
.baner {
  height: 600px;
  background-color: #e31e24;
  background-clip: content-box;
  box-sizing: border-box;
}

.tablink:focus, .tablink:focus-visible {
  outline: 1px dashed gold;
  outline-offset: -5px;
}
.tablink a {
  color: white;
  text-decoration: none;
  letter-spacing: 0.5px;
  transition: color 0.25s ease, text-shadow 0.25s ease;
  border-bottom: 1px dashed silver;
}
.tablink a:visited {
  color: #e6e6e6;
}
.tablink a:hover {
  color: #ffd700; /* gold pairs beautifully with blackletter fonts */
  text-shadow: 0 0 6px rgba(255, 215, 0, 0.6);
  border-bottom: 1px dashed gold;
}
.tablink a:active {
  color: #ffb300;
  text-shadow: 0 0 4px rgba(255, 179, 0, 0.8);
  border-bottom: 1px dashed gold;
}
.tablink a:focus, .tablink a:focus-visible {
  outline: 1px dashed gold;
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.9);
}
.tablink a:disabled, .tablink a a[aria-disabled=true] {
  color: #777;
  pointer-events: none;
}
.tabcontent {
  color: white;
  display: none;
  padding: 50px;
  text-align: center;
}
.tabcontent p {
  line-height: 1em;
  min-height: 2em;
}

#participant, #recon, #food, #merch, #group, #wolo {
  background-color: #e31e24;
}

.break {
  width: 100%;
}

.btn-wraper {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: space-between;
  justify-content: space-between;
  align-items: flex-start;
}
.btn-wraper a.tablink {
  flex: auto;
  background-color: rgb(67, 66, 66);
  color: white;
  letter-spacing: 0.5px;
  transition: color 0.25s ease, text-shadow 0.25s ease;
  border: none;
  border-bottom-width: 1px;
  border-bottom-style: dashed;
  border-bottom-color: black;
  outline: none;
  padding: 0.5em;
  cursor: pointer;
  font-size: 1em;
  line-height: 5em;
  min-height: 5em;
  text-align: center;
}
.btn-wraper a.tablink:focus, .btn-wraper a.tablink:focus-visible {
  outline: 1px dashed gold;
  outline-offset: -5px;
}
.btn-wraper a.tablink:link {
  border-bottom-color: black;
  border-bottom-style: solid;
}
.btn-wraper a.tablink:visited {
  color: #e6e6e6;
}
.btn-wraper a.tablink:hover {
  color: #ffd700;
  text-shadow: 0 0 6px rgba(255, 215, 0, 0.6);
  border-bottom: 1px dashed gold;
  background-color: #777;
}
.btn-wraper a.tablink:active {
  color: #ffb300;
  text-shadow: 0 0 4px rgba(255, 179, 0, 0.8);
  border-bottom: 1px dashed gold;
}
.btn-wraper a.tablink:focus, .btn-wraper a.tablink:focus-visible {
  outline: 1px dashed gold;
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.9);
}
.btn-wraper a.tablink:disabled, .btn-wraper a.tablink a[aria-disabled=true] {
  color: #777;
  pointer-events: none;
}

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