/*============================================
Gernal Styles
============================================*/
body {
  background-color: #f5f7f8;
  overflow-x: hidden;
}

.center {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.left {
  text-align: left;
}

.right {
  text-align: right;
}

.bold {
  font-weight: bold;
}

.clear {
  clear: both;
}

.caps {
  text-transform: capitalize;
}

.error {
  border: solid 1px red;
}

.required,
.error-text {
  color: red;
}

#logo {
  max-height: 120px;
  padding-top: 10px;
  padding-bottom: 10px;
 
}

img.sponsor,
#council img,
.card-body img {
  border-radius: 50%;
  border: solid 3px #2b5528;
}

#council img.selected {
  border: solid 3px #b0542e;
}

#homepromo {
  height: 100%;
  background-image: url(https://www.acbci.com/hike/images/background2.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  padding-left: 0px;
}

/*============================================
Buttons
============================================*/
.btn-main {
  background-color: #b0542e;
  color: #fff;
}

.btn-main:hover,
.btn-main:focus {
  background-color: #c45b2e;
  color: #fff;
}

.btn-min {
  background-color: #1e3e1c;
  color: #fff;
}

.btn-min:hover,
.btn-min:focus {
  background-color: #193017;
  color: #fff;
}

/*============================================
Navbar
============================================*/
header {
  background-color: #422d1e;
  color: #fff;
}

#logoutform button,
form.nav-link button {
  background: none;
  border: none;
  color: #fff;
  padding: 0px;
}

#logoutform {
  border: solid 2px #b0542e;
  background-color: #422d1e;
}

form.nav-link button:focus {
  outline: none;
}

nav div {
  display: block;
}

.none {
  display: none;
}

.header .row {
  padding-top: 15px;
}

.navbar {
  background-color: #816c5b;
  /* background-color: #404F24; */
  border-bottom: solid 2px #1e3e1c;
  color: #fff;
}

.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.active,
.navbar-dark .navbar-nav .nav-link.show,
.navbar-dark .navbar-nav .show > .nav-link,
.navbar-dark .navbar-nav .nav-link,
.navbar-dark .navbar-nav .nav-link:hover {
  color: #fff;
}

.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.active {
  text-decoration: underline;
}

#eventdate {
  margin-top: 15px;
}

/*============================================
Table
============================================*/
.table-striped tbody tr.header {
  background-color: #017aa9;
  color: #fff;
}

#hiketimes {
  margin-bottom: 15px;
}

th {
  background-color: #2b5528;
  color: #fff;
}

.table-bordered td,
.table-bordered th {
  border: 1px solid #110c08;
}

.table-striped tbody tr:nth-of-type(odd) {
  background-color: #ece4d5;
}

#purhcase-summary {
  margin-bottom: 30px;
}

/*============================================
Layout and Spacing
============================================*/
.space-bottom {
  margin-bottom: 10px;
}

.space-top {
  margin-top: 10px;
}

.space-both {
  margin-top: 10px;
  margin-bottom: 10px;
}

.alert p {
  margin: 0px;
}

.section {
  padding-top: 20px;
  padding-bottom: 50px;
}

.alt-section {
  background-color: #d7c7b9;
}

.lead-section {
  margin-top: 40px;
}

.hike {
  margin-bottom: 20px;
}

#feature {
  width: 100%;
  margin-top: 15px;
}

#promo {
  background: rgba(247, 247, 247, 0.7);
  padding: 30px;
}

#ACRM {
  width: 75%;
  border: solid 2px rgb(43, 42, 42);
  box-shadow: 0px 0px gray;
}

.confirm #ACRM {
  width: 50%;
}

#map {
  width: 80%;
}

.progress {
  height: 30px;
}

.progress .bg-main {
  background-color: #2b5528;
}

footer {
  padding-top: 20px;
}

#copyright {
  margin-top: 30px;
}

img.council {
  width: 80%;
}

hr.special {
  width: 400px;
  height: 3px;
  margin-bottom: 40px;
  background-color: #356a9f;
}

#sponsor img.sponsor {
  width: 100px;
}

#spsonsor-levels {
  margin-bottom: 30px;
}

.level {
  display: inline-block;
  margin-right: 15px;
  margin-top: 10px;
}

.level p {
  margin-bottom: 0px;
}

#council p {
  margin-bottom: 0px;
}

#council .bio p,
#council #councilbio {
  margin-bottom: 10px;
}

#council .bio div {
  display: none;
}

#ticket-prices img {
  max-width: 150px;
  margin-bottom: 20px;
}

.btn-holder {
  margin-top: 20px;
}

#headshot {
  border-radius: 50%;
  border: solid 3px #2b5528;
  margin-bottom: 20px;
}

h2.title {
  margin-top: 40px;
}

footer p {
  padding-bottom: 20px;
  margin-bottom: 0px;
}

.feature-icon {
  margin-top: 20px;
}

.feature-content {
  margin-left: 20px;
}

#ucla-tabs {
  margin-top: 50px;
}

#ucla-tabs button {
  margin-bottom: 30px;
}

.ucla-detail h2 {
  margin-bottom: 20px;
}

.modal .d-flex {
  margin-bottom: 30px;
}

.modal button.close {
  text-align: right;
}

.card {
  margin-bottom: 20px;
}

.sponsor img {
  margin-bottom: 15px;
}

.sponsor {
  padding-left: 5px;
  padding-right: 5px;
}

hr.title {
  height: 4px;
  width: 25%;
}

.error-text {
  margin-bottom: 25px;
}

.accordion .card h2 button {
  padding-bottom: 15px;
  width: 100%;
}

.accordion .card h2 button .right {
  margin-top: 5px;
  float: right;
}

label.left {
  float: left;
  padding-left: 5px;
}

.items h2 {
  display: inline-block;
  vertical-align: middle;
  margin-bottom: 10px;
  margin-left: 5px;
  margin-right: 5px;
}

.spinner-border {
  vertical-align: middle;
  margin-bottom: 5px;
  margin-left: 5px;
}

#scrolltop {
  position: fixed;
  right: 15px;
  bottom: 20px;
  z-index: 1000;
}

table td .btn-link {
  padding: 0px;
}

#supporters img {
  margin: 10px;
}

@media print {
  .mobile {
    display: none;
  }
}

@media screen and (min-width: 1200px) {
  .sponsor .card {
    height: 525px;
  }

  #promo {
    margin-top: 125px;
  }
}

@media screen and (max-width: 1199px) and (min-width: 992px) {
  .sponsor .card {
    height: 540px;
  }

  #promo {
    margin-top: 65px;
  }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  .sponsor .card {
    height: 595px;
  }

  .card-header {
    height: 105px;
  }

  #feature img {
    position: relative;
    bottom: -63px;
  }
}

@media screen and (min-width: 768px) {
  .sponsor .card .cta {
    position: absolute;
    bottom: 15px;
    left: calc(50% - 45px);
  }

  .sponsor-center {
    margin-left: 17%;
  }

  .mobile {
    display: none;
  }

  #beneficiary {
    width: 50%;
  }
  
  .summary {
    width: 60%;
    text-align: left;
  }

  #medal {
    width: 50%;
    margin-left: 25%;
  }
}

@media screen and (max-width: 767px) {
  .desktop {
    display: none;
  }

  #promo {
    margin-bottom: 30px;
  }

  #beneficiary {
    width: 90%;
  }

  .confirm #ACRM {
    width: 100%;
  }

  #medal {
    width: 100%;
  }
}

@media screen and (max-width: 600px) {
  #logo {
    width: 45% !important;
    height: auto;
  }

  .btn {
    width: 90%;
  }

  #map {
    width: 100%;
  }

  hr.title {
    width: 80%;
  }

  #headshot {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    width: 100%;
  }

  body,
  main {
    overflow-x: hidden;
  }
}

/*============================================
Fonts and Colors
============================================*/
.none {
  list-style-type: none;
}

.lead-lg {
  font-size: 24px;
}

.alt-color {
  background-color: #fff;
}

label {
  font-weight: bold;
}

main {
  background-color: #ece4d5;
}

hr.title {
  background-color: #1e3e1c;
}

.icon {
  color: #b0542e;
}

.row div label {
  padding-left: 5px;
}

footer {
  background-color: #35312f;
  /* background-color: #816c5B; */
  color: #fff;
}

blockquote {
  font-family: Georgia, serif;
  font-size: 20px;
  font-style: italic;
  width: 80%;
  margin: 0.25em 0;
  padding: 0.35em 40px;
  line-height: 1.45;
  position: relative;
  color: #383838;
  border-right: solid 4px gray;
}

blockquote:before {
  display: block;
  padding-left: 10px;
  content: "\201C";
  font-size: 80px;
  position: absolute;
  left: -20px;
  top: -20px;
  color: #7a7a7a;
}

blockquote cite {
  color: #999999;
  font-size: 14px;
  display: block;
  margin-top: 5px;
}

blockquote cite:before {
  content: "\2014 \2009";
}

.accordion .card h2 button {
  font-weight: 600;
  font-size: 30px;
}

.progress {
  font-weight: bold;
  font-size: 16px;
}

.progress .dark {
  color: #000;
}

sup {
  font-size: 50%;
  top: -15px;
}

sup#paat {
  font-size: 100%;
  top: -5px;
}

@media screen and (min-width: 768px) {
  .summary tr:last-of-type {
    font-weight: bold;
  }
}

/*============================================
Login Page
============================================*/
@media screen and (min-width: 601px) {
  #loginform {
    width: 50%;
    margin-left: 25%;
  }
}

@media screen and (max-width: 600px) {
  #logo {
    width: 75%;
    height: auto;
  }

  #loginform {
    width: 100%;
  }

  #loginform button {
    width: 100%;
  }

  #loginform .form-control {
    height: 50px;
  }
}

#loginform input {
  margin-bottom: 20px;
}
