body{
  font-family: proxima-nova, sans-serif;
  font-size: 1.675rem;
  line-height: 1.4;
  margin: 0;
  padding: 0;
  -webkit-text-size-adjust: 100%;
}
body,
html{
  overflow-x: hidden;
  position: relative;
}
html{
  font-size: 62.5%;
}
*{
  box-sizing: border-box;
}

h2,
.h2{
  letter-spacing: .1rem;
  font-family: espiritu, sans-serif;
  font-weight: normal;
}
img{
  max-width: 100%;
}

.animation-paused{
  animation-play-state: paused !important;
}
.animation-running{
  animation-play-state: running !important;
}
.disabled{
  opacity: .5;
}
.display-block{
  display: block;
}
.margin-auto{
  margin: auto;
}
.margin-bottom-0{
  margin-bottom: 0;
}
.margin-top-0{
  margin-top: 0;
}
.margin-top-1_5{
  margin-top: 1.5rem;
}
.margin-0{
  margin: 0;
}
.position-relative{
  position: relative;
}
.sr-only{
  border: 0;
  clip: rect(0, 0, 0, 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.text-center{
  text-align: center;
}
.text-lg{
  line-height: 1.3;
}

.container-lg{
  width: min(1130px, 100vw - 5rem);
}
.container-lg-extended{
  width: min((1130px + 20rem), 100vw - 5rem);
}
.container-md{
  width: min(960px, 100vw - 5rem)
}

.badge{
  border-radius: .25rem;
  display: inline-block;
  line-height: 1.5;
  padding: .25rem .75rem;
}
.badge-secondary{
  background-color: #ccc;
}
.badge-tertiary{
  background-color: #754c29;
}
.bg-dark{
  color: #fff;
}
.bg-1{
  background-color: #f26722;
}
.bg-2{
  background-color: #7db642;
}
.bg-3{
  background-color: #43a147;
}
.bg-4{
  background-color: #fdf0e0;
}
.bg-5{
  background-color: #fff;
}
.btn{
  border-radius: 2.5rem;
  display: inline-block;
  overflow: hidden;
  transition: .375s all;
}
.btn a{
  border-bottom: 5px solid transparent;
  border-top: 5px solid transparent;
  display: block;
  font-weight: bold;
  text-decoration: none;
}
.btn-lg a{
  padding: 1.25rem 5rem;
}
.btn-lg i{
  margin-left: .5rem;
}
.btn-1{
  background-color: #f26722;
}
.btn-1:active a{
  border-bottom: 5px solid;
}
.btn-1:hover{
  background-color: #fff;
}
.btn-1:hover a{
  color: #f26722;
}
.btn-1 a{
  color: #fff;
}
.color-1{
  color: #7db642;
}
.content a:hover{
  text-decoration: none;
}
.card{
  border-radius: .5rem;
}
.pause-play{
  aspect-ratio: 1;
  border: none;
  border-radius: 100%;
  cursor: pointer;
  font-size: 1.8rem;
  opacity: .75;
  padding: .5rem;
  text-align: center;  
}
.pause-play:focus,
.pause-play:hover{
  opacity: 1;
}

#header{
  background: #fdf0e0 url('images/bg-pattern-1-1.svg') no-repeat;
  background-position: center;
  background-size: 2200px;
  box-shadow: 0px 6px 18px rgba(0, 0, 0, .25);
  position: relative;
}
#header .pause-play{
  background-color: #fff;
  box-shadow: 0 0 2px rgba(0,0,0,.75);
  color: #222;
  position: absolute;
  right: 2.5rem;
  width: 52px;
  z-index: 99999;
}

#header-overlay{
  background: radial-gradient(circle,rgba(255, 255, 255, 0) 100%, rgba(255, 255, 255, 0) 0%);
  margin: auto;
  max-width: 2400px;
  overflow: hidden;
  position: relative;
}
#header-overlay-icn-1,
#header-overlay-icn-6,
#header-overlay-icn-11{
  background-image: url('images/icn-apple.svg');
}
#header-overlay-icn-1{
  left: -20px;
  top: -80px;
  width: 80px;
}
#header-overlay-icn-2,
#header-overlay-icn-7,
#header-overlay-icn-18,
#header-overlay-icn-25{
  background-image: url('images/icn-acorn.svg');
}
#header-overlay-icn-2{
  left: 220px;
  top: -60px;
  width: 60px;
}
#header-overlay-icn-3,
#header-overlay-icn-8,
#header-overlay-icn-12,
#header-overlay-icn-15,
#header-overlay-icn-17,
#header-overlay-icn-19,
#header-overlay-icn-23,
#header-overlay-icn-26{
  background-image: url('images/icn-leaf-1.svg');
}
#header-overlay-icn-3{
  left: 360px;
  top: -45px;
  width: 45px;
}
#header-overlay-icn-4,
#header-overlay-icn-9,
#header-overlay-icn-13,
#header-overlay-icn-16,
#header-overlay-icn-21,
#header-overlay-icn-23{
  background-image: url('images/icn-leaf-2.svg');
}
#header-overlay-icn-4{
  left: 500px;
  top: -205px;
  width: 55px;
}
#header-overlay-icn-5,
#header-overlay-icn-10,
#header-overlay-icn-14,
#header-overlay-icn-20,
#header-overlay-icn-22{
  background-image: url('images/icn-leaf-3.svg');
}
#header-overlay-icn-5{
  left: 760px;
  top: -555px;
  width: 75px;
}
#header-overlay-icn-6{
  left: 1000px;
  top: -485px;
  width: 90px;
}
#header-overlay-icn-7{
  left: 1375px;
  top: -125px;
  width: 65px;
}
#header-overlay-icn-8{
  left: 1550px;
  top: -130px;
  width: 62.5px;
}
#header-overlay-icn-9{
  left: 1775px;
  top: -127.5px;
  width: 42.5px;
}
#header-overlay-icn-10{
  left: 1950px;
  top: -140px;
  width: 70px;
}
#header-overlay-icn-11{
  left: 2150px;
  top: -180px;
  width: 90px;
}
#header-overlay-icn-12{
  left: 2440px;
  top: -75px;
  width: 35px;
}
#header-overlay-icn-13{
  left: 15px;
  top: -160px;
  width: 80px;
}
#header-overlay-icn-14{
  left: 40px;
  top: -450px;
  width: 100px;
}
#header-overlay-icn-15{
  left: 100px;
  top: -525px;
  width: 120px;
}
#header-overlay-icn-16{
  left: 255px;
  top: -195px;
  width: 150px;
}
#header-overlay-icn-17{
  left: 420px;
  top: -325px;
  width: 110px;
}
#header-overlay-icn-18{
  left: 575px;
  top: -304px;
  width: 72px;
}
#header-overlay-icn-19{
  left: 800px;
  top: -422px;
  width: 88px;
}
#header-overlay-icn-20{
  left: 1200px;
  top: -132px;
  width: 102px;
}
#header-overlay-icn-21{
  left: 1300px;
  top: -166px;
  width: 123px;
}
#header-overlay-icn-22{
  left: 1500px;
  top: -108px;
  width: 154px;
}
#header-overlay-icn-23{
  left: 1700px;
  top: -100px;
  width: 112px;
}
#header-overlay-icn-24{
  left: 1920px;
  top: -116px;
  width: 88px;
}
#header-overlay-icn-25{
  left: 2012px;
  top: -144px;
  width: 76px;
}
#header-overlay-icn-26{
  left: -89px;
  top: 44px;
  width: 76px;
}
.header-overlay-icn{
  aspect-ratio: 1;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  z-index: 2;
}
.header-overlay-icn-set-1{
  animation: spin-and-fall 7s linear infinite;
}
.header-overlay-icn-set-2{
  animation: spin-and-fall 8s linear infinite;
  animation-delay: 1s;
}
.header-overlay-icn-set-3{
  animation: spin-and-fall 13s linear infinite;
}
.header-overlay-icn-set-4{
  animation: spin-and-fall 11s linear infinite;
}
.header-overlay-icn-set-5{
  animation: spin-and-fall 9s linear infinite;
}
.header-overlay-icn-set-6{
  animation: spin-and-fall 6s linear infinite;
}
.header-overlay-icn-set-7{
  animation: spin-and-fall 5.25s linear infinite;
}
.header-overlay-icn-set-8{
  animation: spin-and-fall 6.5s linear infinite;
}

@keyframes spin-and-fall{
  0%{
    transform: translateY(0) rotate(0deg);
    opacity: 1;
  }
  95%{
    transform: translate3d(225px, 650px, 0) rotate(180deg); /* Final fall and spin */
    opacity: 0; /* Fades out at the end */
  }
  100%{
    transform: translate3d(300px, 650px, 0) rotate(0deg); /* Final fall and spin */
    opacity: 0; /* Fades out at the end */
  }
}

#header-badge{
  background-color: #7db642;
  max-width: 120px;
  padding: 1.75rem 1rem;
  padding-bottom: 1rem;
  position: relative;
  z-index: 99;
}
#header-badge::after,
#header-badge::before{
  background-color: #7db642;
  bottom: -29px;
  content: "";
  display: block;
  height: 30px;
  position: absolute;
  width: 55%;
}
#header-badge::after{
  clip-path: polygon(0 0, 100% 0, 100% 100%);
  right: -.4px;
}
#header-badge::before{
  clip-path: polygon(0 0, 100% 0, 0 100%);
  left: 0;
}

#header-logo{
  text-align: center;
}
#header-logo h1{
  margin-bottom: -.5rem;
}
#header-logo img{
  margin: 4rem auto;
  margin-bottom: 0;
  animation-fill-mode: both;
  animation-direction: alternate;
  width: min(525px, 65vw);
  z-index: 99;
}
#header-logo-bg{
  background: radial-gradient(ellipse, rgba(252,240,224,.75), transparent 75%);
  margin: auto;
  max-width: 550px;
  position: relative;
  z-index: 98;
}

#header-content{
  padding-bottom: 2rem;
}
#header-content p{
  color: #f26722;
}
#header-content small{
  color: #7db642;
  font-size: 2.3rem;
  font-weight: bold;
}
#header-content .lead{
  font-weight: bold;
  margin-top: 0;
}
#header-content .lead span{
  background: url('images/badge-1.svg') no-repeat;
  background-position: center;
  color: #fff;
  padding: 0 2rem;
}

main>section{
  margin: 6rem auto;
}

#intro{
  font-weight: bold;
  line-height: 1.4;
  padding: 3rem 2rem;
}

#main,
#cta-1,
#schedule{
  z-index: 2;
}

#main img{
  border-radius: .5rem;
}
#main-bg{
  background: url('images/bg-pattern-2.svg') no-repeat;
  background-size: cover;
  background-position: center -12rem;
  height: 100%;
  filter: opacity(.045);
  margin-top: -6rem;
  position: absolute;
  width: 100%;
  z-index: 1;
}

#schedule .ampm{
  font-size: .5em;
  position: relative;
  top: -.3rem;
}
#schedule-events{
  align-items: flex-start;
  margin-bottom: 2rem;
}
#schedule-events>div{
  padding: .5rem;
}
#schedule-events .border-top-1-1{
  border-top: 1px solid rgba(255,255,255,.25);
}

#sponsorship{
  padding-bottom: 4rem;
  padding-top: 4rem;
  z-index: 3;
}
#sponsorship .sponsor{
  filter: grayscale(1) opacity(.5);
  max-width: 200px;
  mix-blend-mode: multiply;
}
#sponsorship-tiers{
  margin: 2rem auto;
  margin-bottom: 4rem;
}
#sponsorship-tiers .card h3,
#sponsorship-tiers .card h3 a{
  color: #222;
}
#sponsorship-tiers .card h3{
  line-height: 1.1;
}
#sponsorship-tiers .card h3 a{
  display: block;
  text-decoration: none;
}
#sponsorship-tiers .card h3 a>i{
  font-size: 1.2em;
  line-height: 1;
  margin: 0 .325rem;
  position: relative;
  right: 0;
  top: .2rem;
  transition: .25s all;
}
#sponsorship-tiers .card h3 a:focus .larger,
#sponsorship-tiers .card h3 a:hover .larger{
  text-decoration: underline;
}
#sponsorship-tiers .card h3 a:hover>i{
  right: -.25rem;
}
#sponsorship-tiers .card h3 .badge{
  font-size: .75em;
  position: relative;
  top: -.1rem;
}

#footer{
  background-color: #754c29;
  color: #fff;
  margin-top: -6rem;
  padding: 4rem 0;
  padding-bottom: 3rem;
}
#footer a{
  color: #fff;
}
#footer aside{
  font-size: 1.2rem;
}
#footer .content a{
  color: #fff;
  font-weight: bold;
}
#footer .content .logo{
  max-width: 200px;
}
#footer .social-media a{
  color: #fff;
  font-size: 2rem;
  margin: .5rem;
}
#footer-content{
  border-bottom: 1px solid rgba(255,255,255,.25);
  margin-bottom: 3rem;
  padding-bottom: 2rem;
}

@media screen and (min-width: 1380px){
  .container-extended{
    padding: 2.5rem 10rem;
  }
}

@media screen and (max-width: 1379px){
  .container-extended{
    padding: 2.5rem;
  }
}

@media screen and (min-width: 900px){
  #header-aside{
    left: 50%;
    margin-left: min(-425px, 100vw - 5rem);
    min-width: min(425px, 100vw - 5rem);
    position: absolute;
    top: 14rem;
    z-index: 99;
  }
  #header-aside img{
    width: 250px;
  }
  #header-aside img+svg{
    left: 2.25rem;
    position: absolute;
    top: 2.35rem;
  }
  #header-aside textPath{
    fill: #754c29;
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: .085rem;
  }
}

@media screen and (max-width: 899px){
  #header-aside{
    border: 0;
    clip: rect(0, 0, 0, 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
  #header-aside img{
    display: none;
  }
}

@media screen and (min-width: 871px){
  h2,
  .h2{
    font-size: 2.6rem;
  }
  h3,
  .h3{
    font-size: 1.8rem;
  }

  .text-center-md{
    text-align: center;
  }
  .text-lg{
    font-size: 2.6rem;
  }
  .text-md{
    font-size: 1.8rem;
  }
  .text-right-md{
    text-align: right;
  }
  .text-sm{
    font-size: 1.3rem;
  }

  .content-left-md{
    padding-right: 6rem;
  }

  .btn-lg a{
    font-size: 2.6rem;
  }
  .card{
    padding: 2.5rem;
  }

  #header-content{
    margin-top: -1rem;
  }
  #header-content p{
    font-size: 3.8rem;
  }

  #schedule-events>div:nth-child(even){
    padding-left: 1.25rem;
  }
  #schedule-events .badge,
  #schedule-events .text-md{
    margin-top: .5rem;
  }
  #schedule-events .border-top-1-1-md{
    border-top: 1px solid rgba(255,255,255,.25);
  }

  #sponsorship-tiers .card{
    margin-bottom: 1.5rem;
    margin-top: 1.5rem;
    max-width: 95%;
    height: min(100% - 3rem);
  }
  #sponsorship-tiers .card h3 .larger{
    font-size: 1.5em;
  }
  #sponsorship-tiers>div:nth-child(3n+2) .card{
    margin-left: auto;
    margin-right: auto;
  }
  #sponsorship-tiers>div:nth-child(3n) .card{
    margin-left: auto;
  }

  #footer-content p{
    margin-left: 4rem;
  }
}

@media screen and (max-width: 870px){
  h2, .h2{
    font-size: 1.5em;
  }

  .text-lg{
    font-size: 2rem;
  }
  .text-sm{
    font-size: 1.2rem;
  }

  .card{
    padding: .5rem 2.5rem;
  }

  #header-content{
    margin-top: -2rem;
  }
  #header-content p{
    font-size: 3.4rem;
  }
  #header-content .lead span{
    display: block;
  }

  #main img{
    margin-top: 4rem;
  }

  #cta-1 .btn{
    margin-top: 2rem;
  }

  #schedule-events .border-top-1-1{
    margin-top: 1rem;
    padding-top: 1.5rem;
  }

  #sponsorship-tiers .card{
    margin: .5rem auto;
  }
  #sponsorship-tiers .card h3 .larger{
    font-size: 1.25em;
  }

  #footer .content .logo{
    margin-bottom: 2rem;
  }
  #footer .social-media{
    margin-top: 2rem;
  }
}

@media screen and (max-width: 649px){
  .header-overlay-icn{
    max-width: 44px;
  }
}

@media screen and (min-width: 500px){
  #header .pause-play{
    bottom: 2.5rem;
  }
}

@media screen and (max-width: 499px){
  #header .pause-play{
    top: 2.5rem;
  }
}