*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;

  --clr-primary-bg: hsl(218, 100%, 96%);
  --clr-secondary-bg: hsl(232, 43%, 13%);
  --clr-tertiary-bg: hsl(217, 100%, 93%);
  --clr-pink-bg: hsl(275, 63%, 90%);
  --clr-white-bg: hsl(218, 100%, 96%);
  --clr-brightwhite-bg: hsl(218, 100%, 100%);
  --clr-button-bg: hsl(218, 37%, 63%);
  --clr-button-clk-bg: hsla(204, 29%, 97%, 0.95);
  --clr-button-hover-bg: hsl(0, 0%, 100%);
  --clr-button-active-bg: hsl(210, 74%, 13%);
  --clr-chkbox-active-bg: hsl(213, 100%, 32%);
  --clr-tblrow-light-bg: hsl(225, 100%, 99%);
  --clr-header-bg: hsl(232, 65%, 11%);
  --clr-list-text: hsl(0, 0%, 50%);
  --clr-boxshadow-grey: hsla(0, 0%, 0%, 0.24);
  --clr-link-text: hsla(0, 0%, 100%, 0.75);
  --clr-link-text-hover: hsla(0, 2%, 26%, 0.5);
  --clr-link-card-bg: hsl(210, 90%, 40%);
  --clr-link-card-hover: hsl(214, 70%, 29%);
  --clr-select-opt: hsl(0, 0%, 83%);
  --clr-textarea-bg: hsl(0, 0%, 100%);
  --clr-link-text: hsl(210, 90%, 40%);
  --clr-link-hover: hsl(214, 70%, 29%);

  --clr-text-light: hsla(0, 0%, 100%, 0.75);
  --clr-text-dark: hsla(213, 8%, 73%, 0);
  --clr-text-blue: hsl(213, 100%, 32%);
  --clr-text-white: hsl(220, 0%, 100%);
  --clr-text-pink: hsl(309, 68%, 54%);
  --clr-text-grey: hsl(220, 6%, 40%);

  --fontsize--2: clamp(0.7813rem, 0.7747rem + 0.0326vw, 0.8rem);
  --fontsize--1: clamp(0.9375rem, 0.9158rem + 0.1087vw, 1rem);
  --fontsize-0: clamp(1.125rem, 1.0815rem + 0.2174vw, 1.25rem);
  --fontsize-1: clamp(1.35rem, 1.2761rem + 0.3696vw, 1.5625rem);
  --fontsize-2: clamp(1.62rem, 1.5041rem + 0.5793vw, 1.9531rem);
  --fontsize-3: clamp(1.9438rem, 1.7707rem + 0.8652vw, 2.4413rem);
  --fontsize-4: clamp(2.3325rem, 2.0823rem + 1.2511vw, 3.0519rem);
  --fontsize-5: clamp(2.7994rem, 2.4461rem + 1.7663vw, 3.815rem);
}

input,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: transparent;
  border: none;
  padding: 0;
  margin: 0;
  box-sizing: border-box;

  border: 2px solid var(--clr-select-opt);
  background-color: var(--clr-textarea-bg);
  border-radius: 0.25rem;
  box-shadow: var(--clr-boxshadow-grey) 0px 3px 8px;
}

ul {
  margin-left: 0.75rem;
  text-align: left;
}

body {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
  font-size: var(--fontsize-0);
  background-color: var(--clr-primary-bg);
}

/* ***************************************************
WRAPPER - This is the main envelope inside the body 
We will use this with the media queries to control the
appearance on different devices 
***************************************************** */
.wrapper {
  margin: 0 auto !important;
  float: none !important;
}
/* ***************************************************
END WRAPPER
***************************************************** */

a:link {
  text-decoration: none;
}
a:visited {
  text-decoration: none;
}
a:hover {
  text-decoration: none;
}
a:active {
  text-decoration: none;
}

.nav-bar {
  background-color: var(--clr-secondary-bg);
  color: var(--clr-text-light);
  display: flex;
  justify-content: space-between;
}

.nav-link {
  padding: 1rem 2rem 1rem 1rem;
}

.nav-link a:link {
  color: var(--clr-text-light);
}

.nav-link a:visited,
.nav-link a:hover,
.nav-link a:focus {
  color: var(--clr-text-white);
}

.banner {
  display: flex;
  flex-direction: column;
}

.banner-item {
  font-size: 2rem;
  vertical-align: center;
  padding-top: 1rem;
  justify-content: center;
}

.banner-item img:first-child {
  border-radius: 50%;
  width: 80%;
  max-width: 350px;
  margin-top: 1rem;
  margin-bottom: 1rem;
  margin-left: 5%;
}

.banner-text {
  display: grid;
  grid-template-columns: auto;
}

.site-name,
.site-strapline {
  width: 80%;
  margin-left: 5%;
}
.site-name {
  font-size: 4rem;
  margin-bottom: 16px;
  font-weight: 400;
  color: var(--clr-text-pink);
}

.site-strapline {
  font-size: 3rem;
  font-weight: 100;
  line-height: 1.2;
  color: var(--clr-text-blue);
}

.events {
  background-color: var(--clr-secondary-bg);
  padding-bottom: 2rem;
}

.events-text {
  width: 100%;
  padding-top: 1rem;
  padding-bottom: 1rem;
  text-align: center;
  font-size: var(--fontsize-2);
  color: var(--clr-text-light);
}

.event {
  background-color: var(--clr-secondary-bg);
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.event-text-box {
  display: flex;
  flex-direction: column;
  margin: auto;
  width: clamp(15rem, 45rem, 55rem);
}
.event-text-title,
.event-text-info,
.event-date-info {
  color: var(--clr-text-light);
  font-weight: 100;
  text-wrap: wrap;
}

.event-text-title {
  font-size: var(--fontsize-3);
}

.event-text-info,
.event-date-info {
  font-size: var(--fontsize-1);
  padding-top: 0.75rem;
  line-height: 1.35rem;
}

.event-bar {
  width: 100%;
  height: 1px;
  background-color: var(--clr-white-bg);
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

.event-text-double {
  display: flex;
  justify-content: space-between;
}

.button-box {
  display: flex;
  width: 100%;
  justify-content: space-between;
  padding-left: 5rem;
  padding-right: 5rem;
}

.cards {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  padding-left: 2rem;
  padding-right: 2rem;
}

.card {
  display: grid;
  grid-template-rows: 1fr;
  max-width: 15rem;
  max-height: 18rem;
  border-radius: 1rem;
  padding: 0.5rem;
  background-color: #3c4e5d;
}

.card-text {
  padding-top: 0.3rem;
  padding-bottom: 0.3rem;
  margin-left: 1rem;

  font-size: var(--fontsize--1);
  font-weight: 100;
  color: var(--clr-text-white);
}

.card-text:last-of-type {
  padding-bottom: 1rem;
}

.card-link {
  text-decoration: none;
  align-items: center;
  background-color: var(--clr-link-card-bg);
  border: 0;
  border-radius: 2rem;
  color: var(--clr-text-white);
  cursor: pointer;
  display: flex;
  font-size: 1rem;
  font-weight: 100;
  justify-content: center;
  line-height: 1rem;
  max-width: 8rem;
  min-height: 2rem;
  min-width: 0px;
  overflow: hidden;
  padding: 0px;
  padding-left: 1rem;
  padding-right: 1rem;
  text-align: center;
  touch-action: manipulation;
  transition: background-color 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s,
    box-shadow 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s,
    color 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s;
  user-select: none;
  -webkit-user-select: none;
  vertical-align: middle;
  margin-left: 1rem;
  margin-bottom: 1rem;
}

.card-link:hover,
.card-link:focus,
.card-link:active {
  background-color: var(--clr-link-card-hover);
  color: var(--clr-text-white);
}

.card-link:disabled {
  cursor: not-allowed;
  background: rgba(0, 0, 0, 0.08);
  color: rgba(0, 0, 0, 0.3);
}

select option {
  color: hsl(0, 0%, 83%);
}

.form-input {
  display: flex;
  flex-direction: column;
  align-items: start;
  margin: auto;
  max-width: 50%;
  padding-top: 3rem;
  margin-bottom: 3rem;
}
.form-input-comps {
  /* display: flex;
  flex-direction: column;
  align-items: start;
  margin: auto;
  max-width: 50%; */
  padding-top: 3rem;
  /* margin-bottom: 3rem; */
}

.form-header {
  font-size: var(--fontsize-2);
  font-weight: 100;
  padding-bottom: 1rem;
}

.input-text,
.input-select-short,
.input-select-long {
  height: 2rem;
  font-size: var(--fontsize-0);
  padding-left: 1rem;
  background-color: var(--clr-brightwhite-bg);
}

.input-text {
  width: 30rem;
}

.input-select-short {
  width: 15rem;
}
.input-select-long {
  width: 30rem;
}

.icon-up:before {
  content: "\25B2";
}

.icon-down:before {
  content: "\25BC";
}

.input-text:hover,
.input-text:focus {
  border: 2px solid darkgray;
}

.input-double {
  display: grid;
  grid-gap: 1rem;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 3rem 3rem;
  grid-auto-flow: column;
}

label {
  font-size: 1.5rem;
  font-weight: 300;
  padding-bottom: 1rem;
  padding-top: 1.5rem;
}

select option {
  margin: 2rem;

  background: rgba(0, 0, 0, 0.3);
  color: #fff;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.4);
}

.input-button,
.input-button-outline {
  text-decoration: none;
  align-items: center;
  background-color: #0a66c2;
  border: 0;
  border-radius: 2rem;
  color: #ffffff;
  cursor: pointer;
  display: flex;
  font-size: 1rem;
  font-weight: 100;
  justify-content: center;
  line-height: 1rem;

  min-height: 2rem;
  min-width: 0px;
  overflow: hidden;
  margin-top: 3rem;
  margin-bottom: 3rem;
  padding: 0px;
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 2rem;
  padding-right: 2rem;
  text-align: center;
  touch-action: manipulation;
  transition: background-color 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s,
    box-shadow 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s,
    color 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s;
  user-select: none;
  -webkit-user-select: none;
  vertical-align: middle;
}

.input-button-outline {
  background-color: var(--clr-primary-bg);
  color: var(--clr-text-blue);
  border: 1px solid var(--clr-text-blue);
}

.input-button:hover,
.input-button:focus {
  background-color: var(--clr-button-bg);
  color: #ffffff;
}

.input-button:active {
  background: var(--clr-button-active-bg);
  color: rgb(255, 255, 255, 0.7);
}

.input-button:disabled {
  cursor: not-allowed;
  background: rgba(0, 0, 0, 0.08);
  color: rgba(0, 0, 0, 0.3);
}

.input-privacy {
  position: relative;
  border: 2px solid #000;
  border-radius: 2px;
  background: none;
  cursor: pointer;
  line-height: 0;
  margin: 0 1rem 0 0;
  outline: 0;
  padding: 0 !important;
  vertical-align: text-top;
  height: 1.5rem;
  width: 1.5rem;
  opacity: 0.5;
}

.input-privacy:hover {
  opacity: 1;
}

.input-privacy:checked {
  background-color: var(--clr-chkbox-active-bg);

  opacity: 1;
}

.input-privacy:before {
  content: "";
  position: absolute;
  right: 50%;
  top: 50%;
  width: 4px;
  height: 10px;
  border: solid var(--clr-tertiary-bg);
  border-width: 0 2px 2px 0;
  margin: -1px -1px 0 -1px;
  transform: rotate(45deg) translate(-50%, -50%);
  z-index: 2;
}

.dancer-info-sidebar {
  grid-area: dancer-info-sidebar;
  background-color: var(--clr-text-blue);
  width: 0.1rem;
}

.dancer-info-name {
  grid-area: dancer-info-name;
}

.dancer-info-yob {
  grid-area: dancer-info-yob;
}
.dancer-info-school {
  grid-area: dancer-info-school;
}
.dancer-info-edit {
   grid-area: dancer-info-edit;
}
.dancer-info-remove {
   grid-area: dancer-info-remove;
}
.dancer-info-addcomps {
   grid-area: dancer-info-addcomps;
}

.dancer-info-edit > a {
  color: var(--clr-link-text);
}

.dancer-info-edit > a:hover {
  color: var(--clr-link-hover);
}

.dancer-info-ct {
  grid-area: dancer-info-ct;
  padding-top: 1rem;
  font-weight: bold;
}

.dancer-info-basket > .dancer-info-school,
.dancer-info-basket > .dancer-info-yob,
.dancer-info-basket > .dancer-info-edit {
  font-size: var(--fontsize--1);
}

.dancer-info {
  margin-top: 1rem;
  margin-bottom: 1rem;
  display: grid;
  grid-gap: 10px;
  grid-template-columns: 4rem auto;
  grid-template-areas:
    "dancer-info-sidebar dancer-info-name"
    "dancer-info-sidebar dancer-info-yob"
    "dancer-info-sidebar  dancer-info-school"
    "dancer-info-sidebar  dancer-info-edit";
}

.bold-txt {
  font-weight: bold;
}



input[type="checkbox"].toggle {
  opacity: 0;
  position: absolute;
  left: -9000px;
  top: -9000px;
  cursor: pointer;
}

input[type="checkbox"].toggle + label {
  display: flex;
}

input[type="checkbox"].toggle + label::before {
  width: 6rem;
  height: 2rem;
  background-color: var(--clr-button-bg);
  border-radius: 1rem;
  margin-right: 0.5rem;
  content: "Enter";
  transition: 500ms;
  text-align: center;
  color: var(--clr-white-bg);
}

input[type="checkbox"].toggle:checked + label::before {
  background-color: transparent;
  content: "Remove";
  transition: 500ms;
  color: black;
  font-weight: 300;
}

table {
  width: 100%;
  border-collapse: collapse;
}

caption,
th,
td {
  padding: 0.5rem;
  font-weight: 300;
  background-color: transparent;
}

caption,
th {
  text-align: left;
  color: var(--clr-text-blue);
  text-transform: uppercase;
}

/* *****************************************
Make TRs alternate row colours
Make included tbls on these rows match in colour */
.altrows > * > tr:nth-of-type(odd)  {
    background-color:var(--clr-tblrow-light-bg);
}

.subtbl > * > tr  {
  background-color: transparent;
}
/* ***************************************** */


/* START basket */
.basket-header {
  color: var(--clr-text-pink);
  font-weight: 400;
  font-size: var(--fontsize-4);
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.basket {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.basket-col .event {
  border-radius: 1rem;
  padding: 1rem;
}

.basket-col .event .event-text-box {
  padding-left: 2rem;
}

.dancer-info-basket {
  margin-top: 1rem;
  margin-bottom: 1rem;
}
.dancer-info-row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
}
.dancer-info-col {
  display: flex;
  flex-direction: column;
  flex-basis: 100%;
  font-size: var(--fontsize--1);
}

.dancer-info-col > a {
  color: var(--clr-link-text);
}

.dancer-info-col > a:hover {
  color: var(--clr-link-hover);
}

.dancer-info-dbl-col {
  display: flex;
  flex-direction: column;
  flex-basis: 100%;
  font-size: var(--fontsize--1);
}

.payment-box {
  top: 0;
  position: sticky;
}

.payment-info {
  display: grid;
  grid-template-columns: [col] 1fr [col] 1fr [col] 1fr [col] 1fr;
  grid-template-rows: [row] auto [row] auto [row] auto [row] auto [row] auto [row] auto;
  background-color: var(--clr-tertiary-bg);
  padding: 0.75rem 1rem 0.75rem 1rem;
  color: var(--clr-text-grey);
  border: var(--clr-text-blue) 1px solid;
  border-radius: 1rem;
}

.tbl-basket {
  font-size: var(--fontsize--2);
}

.td-basket-comp {
  width: 50%;
}

.td-basket-grade,
.td-basket-age,
.td-basket-price {
  width: 14%;
}

.input-privacy + label {
  font-size: var(--fontsize-0);
  color: var(--clr-text-grey);
}

.payment-info-item {
  padding-top: 1rem;
}

.item-a {
  grid-column: col / span 3;
  grid-row: row;
}
.item-b {
  grid-column: col 4 / span 1;
  grid-row: row;
}
.item-c {
  grid-column: col / span 3;
  grid-row: row 2;
}
.item-d {
  grid-column: col 4 / span 1;
  grid-row: row 2;
}
.item-e {
  grid-column: col / span 3;
  grid-row: row 3;
}
.item-f {
  grid-column: col 4 / span 1;
  grid-row: row 3;
}
.item-g {
  grid-column: col / span 4;
  grid-row: row 4;
}
.item-h {
  grid-column: col / span 4;
  grid-row: row 4;
}

.payment-notes {
  padding: 1rem 0 1rem 0;
  color: var(--clr-text-grey);
}

.payment-inst {
  background-color: var(--clr-pink-bg);
  border: var(--clr-text-pink) 1px solid;
  border-radius: 1rem;
  padding: 2rem;
  color: var(--clr-text-grey);
}

.contact-details {
  width: 100%;
  padding-top: 2rem;
}

.contact-details .input-text {
  width: 23rem;
  font-size: var(--fontsize--3);
}

.contact-details-title {
  padding-bottom: 1rem;
}

.contact-details-info {
  font-size: var(--fontsize-0);
  color: var(--clr-text-grey);
}

.contact-details-item {
  display: flex;
  flex-direction: column;
  width: fit-content;
  padding-top: 1rem;
}
.contact-details-label {
  font-size: var(--fontsize--3);
  padding: 0;
}

/* END basket */

/* START footer */
.footer {
  width: 100%;
  display: flex;
  gap: 5rem;
  justify-content: center;
  background-color: var(--clr-secondary-bg);
  color: var(--clr-text-light);
  font-size: var(--fontsize--3);
  font-weight: 200;
  line-height: 2rem;
}

.footer_link a:link {
  color: var(--clr-text-light);
}

.footer_link a:visited,
.footer_link a:hover,
.footer_link a:focus {
  color: var(--clr-text-white);
}

/* END footer */

.pad-t1 {
  padding-top: 1rem;
}

/*
********************************************
MEDIA QUERIES BREAKPOINTS
******************************************** 
320px — 480px: Mobile devices
481px — 768px: iPads, Tablets
769px — 1024px: Small screens, laptops
1025px — 1200px: Desktops, large screens
1201px and more —  Extra large screens, TV

********************************************
*/

/* Large devices such as laptops, computers (greater than 1024px) */
@media screen and (min-width: 1025px) {
  .wrapper {
    max-width: 1200px;
  }
  .banner {
    display: flex;
    flex-direction: row;
  }
  .banner-item {
    width: 70%;
    font-size: var(--fontsize-3);
    vertical-align: center;
  }
  .site-name,
  .site-strapline {
    margin-left: 5%;
    vertical-align: center;
  }
  .site-name {
    margin-top: 15%;
  }
  .site-strapline {
    margin-bottom: 15%;
  }

  .event {
    padding: 0 0 1rem 0;
  }

label {
  font-size: 1.5rem;
  font-weight: 300;
  padding-bottom: 0.5rem;
  padding-top: 0.5rem;
}

  .form-input {
  max-width: 80%;
  margin-left: 25%;
  margin-bottom: 1rem;
  padding-top: 1.5rem;
}

.input-select-short {
  width: 15rem;
}

.input-select-smltxt {
  width: 18rem;
  font-size: var(--fontsize--1);
  margin: 0;
  padding: 0;
}

.setdancebox {
  display: flex;
  flex-direction: column;
}

.input-double {
  display: grid;
  grid-gap: 1rem;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 2rem 2rem;
  grid-auto-flow: column;
}

.input-button {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;

}

.dancer-info-col {
    flex: 1
  }

  .dancer-info-dbl-col {
    flex: 2
  }
}

/* Medium devices such as tablets (1024px or lesser) */
@media screen and (max-width: 1024px) {
  .wrapper {
    max-width: 992px;
  }
  th {
    display: none;
  }

  td {
    display: grid;
    grid-template-columns: 15ch auto;
    padding: 0.5rem 1rem;
  }

  td::before {
    content: attr(data-cell) ": ";
    font-weight: 700;
    text-transform: capitalize;
  }
  .event-text-box {
  width: clamp(15rem, 35rem, 55rem);
}
  .basket {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.25rem;
}
}

/* Small devices such as phones (768px or lesser) */
@media screen and (max-width: 768px) {
  .wrapper {
    max-width: 768px;
  }
  th {
    display: none;
  }

  td {
    display: grid;
    grid-template-columns: 15ch auto;
    padding: 0.5rem 1rem;
  }

  td::before {
    content: attr(data-cell) ": ";
    font-weight: 700;
    text-transform: capitalize;
  }
  .basket {
  display: flex;
  flex-direction: column;
  flex-basis: 100%;
  flex: 2;
}
}
