html {
  max-width: 1440px;
  margin: 0 auto; }

h1 {
  font-family: 'Montserrat', 'Arial', sans-serif;
  font-weight: 700;
  font-size: 36px;
  text-transform: uppercase;
  color: #FEFEFE; }
  @media (min-width: 700px) {
    h1 {
      font-size: 65px; } }
  @media (min-width: 1024px) {
    h1 {
      font-size: 72px; } }

h2 {
  font-family: 'Montserrat', 'Arial', sans-serif;
  font-weight: 700;
  font-size: 28px;
  text-transform: uppercase;
  color: #000; }
  @media (min-width: 700px) {
    h2 {
      font-size: 48px; } }
  @media (min-width: 1024px) {
    h2 {
      font-size: 55px; } }

h3 {
  font-family: 'Montserrat', 'Arial', sans-serif;
  font-weight: 300;
  font-size: 24px;
  text-transform: uppercase;
  color: #000; }
  @media (min-width: 700px) {
    h3 {
      font-size: 28px; } }
  @media (min-width: 1024px) {
    h3 {
      font-size: 32px; } }
  h3 span {
    font-weight: 700; }

h4 {
  font-family: 'Montserrat', 'Arial', sans-serif;
  font-weight: 700;
  font-size: 26px;
  text-transform: uppercase;
  color: #000; }
  @media (min-width: 700px) {
    h4 {
      font-size: 28px; } }
  @media (min-width: 1024px) {
    h4 {
      font-size: 36px; } }
  h4 span {
    font-weight: 700; }

p, li {
  font-family: 'Montserrat', 'Arial', sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 18px;
  color: #000; }
  @media (min-width: 700px) {
    p, li {
      font-size: 16px;
      line-height: 20px; } }
  @media (min-width: 1024px) {
    p, li {
      font-size: 18px;
      line-height: 24px; } }
  p span, li span {
    font-weight: 700; }

a {
  color: #000; }
  a:hover {
    font-style: italic; }

section {
  padding: 75px 0; }
  @media (min-width: 700px) {
    section {
      padding: 100px 0; } }
  @media (min-width: 1024px) {
    section {
      padding: 125px 0; } }

.rsvp-button {
  display: inline-block;
  border: solid 4px #FEFEFE;
  text-decoration: none; }
  .rsvp-button a {
    text-decoration: none;
    padding: 15px 10px;
    display: block; }

.gradient-sections {
  position: relative;
  padding: 0px 0 75px;
  overflow: hidden; }
  @media (min-width: 700px) {
    .gradient-sections {
      padding: 0;
      height: 600px; } }
  @media (min-width: 700px) {
    .gradient-sections {
      padding: 0;
      height: 720px; } }
  .gradient-sections .img-container {
    width: 100%;
    position: relative;
    background-image: none; }
    @media (min-width: 700px) {
      .gradient-sections .img-container {
        height: 100%;
        background-position: center;
        background-size: cover;
        background-repeat: no-repeat; } }
    .gradient-sections .img-container img {
      width: 100%; }
      @media (min-width: 700px) {
        .gradient-sections .img-container img {
          display: none; } }
    .gradient-sections .img-container .fadeout {
      position: absolute;
      bottom: -1px;
      width: 100%;
      height: 50%;
      background: -webkit-linear-gradient(rgba(255, 255, 255, 0) 0%, white 92%);
      background-image: -ms-linear-gradient(rgba(255, 255, 255, 0) 0%, white 92%);
      background-image: linear-gradient(rgba(255, 255, 255, 0) 0%, white 92%);
      background-image: -moz-linear-gradient(rgba(255, 255, 255, 0) 0%, white 92%);
      background-image: -o-linear-gradient(rgba(255, 255, 255, 0) 0%, white 92%);
      pointer-events: none; }
  .gradient-sections .gradient {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    opacity: .75; }
  .gradient-sections .space-overlay-mobile {
    position: absolute;
    z-index: 2;
    width: 700px;
    left: 50%;
    transform: translateX(-50%);
    bottom: 0; }
    @media (min-width: 700px) {
      .gradient-sections .space-overlay-mobile {
        display: none; } }
  .gradient-sections .space-overlay {
    display: none; }
    @media (min-width: 700px) {
      .gradient-sections .space-overlay {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 2;
        width: 1440px; } }
  .gradient-sections .content {
    z-index: 100;
    position: relative;
    width: 80%;
    margin: 0 auto;
    max-width: 500px; }
    @media (min-width: 700px) {
      .gradient-sections .content {
        position: absolute;
        bottom: 25px;
        left: 5%; } }
    @media (min-width: 1024px) {
      .gradient-sections .content {
        position: absolute;
        bottom: 45px; } }
    .gradient-sections .content .logo {
      max-width: 80px;
      margin-bottom: 15px; }
      @media (min-width: 700px) {
        .gradient-sections .content .logo {
          max-width: 100px; } }
    .gradient-sections .content p {
      margin-top: 15px;
      color: #FEFEFE;
      max-width: 275px; }
      @media (min-width: 700px) {
        .gradient-sections .content p {
          max-width: 400px; } }
      @media (min-width: 700px) {
        .gradient-sections .content p {
          max-width: 450px; } }
  .gradient-sections a {
    color: #FEFEFE; }

.this-is-us .img-container {
  background-image: url("../img/this-is-us-3.jpg"); }

.this-is-us .gradient {
  background: #9ad093;
  background: -moz-linear-gradient(45deg, #9ad093 0%, #8fd2f3 100%);
  background: -webkit-linear-gradient(45deg, #9ad093 0%, #8fd2f3 100%);
  background: linear-gradient(45deg, #9ad093 0%, #8fd2f3 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#9ad093', endColorstr='#8fd2f3',GradientType=1 );
  z-index: 1; }

.this-is-us .content .word-container {
  position: relative; }
  @media (min-width: 700px) {
    .this-is-us .content .word-container {
      height: 65px; } }
  .this-is-us .content .word-container h1 {
    -webkit-text-stroke: black 1.5px;
    color: rgba(0, 0, 0, 0); }
    @media (min-width: 700px) {
      .this-is-us .content .word-container h1 {
        position: absolute;
        top: 0;
        overflow: hidden;
        animation: animate 8s linear infinite;
        opacity: 0; } }
    .this-is-us .content .word-container h1:nth-child(1) {
      animation-delay: 0s; }
    .this-is-us .content .word-container h1:nth-child(2) {
      animation-delay: 2s; }
    .this-is-us .content .word-container h1:nth-child(3) {
      animation-delay: 4s; }
    .this-is-us .content .word-container h1:nth-child(4) {
      animation-delay: 6s; }

@keyframes animate {
  0% {
    opacity: 0;
    transform: translateY(-50px); }
  2% {
    opacity: 1;
    transform: translateY(0); }
  23% {
    opacity: 1;
    transform: translateY(0); }
  25% {
    opacity: 0;
    transform: translateY(50px); } }

.this-is-dan-goods .img-container {
  background-position: 0 40%;
  background-image: url("../img/dan-goods.jpg"); }

.this-is-dan-goods .gradient {
  background: #4ec4ce;
  background: -moz-linear-gradient(45deg, #4ec4ce 0%, #b74699 100%);
  background: -webkit-linear-gradient(45deg, #4ec4ce 0%, #b74699 100%);
  background: linear-gradient(45deg, #4ec4ce 0%, #b74699 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4ec4ce', endColorstr='#b74699',GradientType=1 ); }

.callout {
  position: relative;
  padding: 0; }
  @media (min-width: 700px) {
    .callout {
      height: 500px; } }
  @media (min-width: 1024px) {
    .callout {
      height: 650px; } }
  .callout .img-container {
    background-image: url("../img/this-is-us-1.jpg"); }
  .callout .gradient {
    background: #f16f99;
    background: -moz-linear-gradient(45deg, #f16f99 0%, #fde140 100%);
    background: -webkit-linear-gradient(45deg, #f16f99 0%, #fde140 100%);
    background: linear-gradient(45deg, #f16f99 0%, #fde140 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f16f99', endColorstr='#fde140',GradientType=1 ); }
  .callout .content {
    position: absolute;
    width: 100%;
    transform: translateX(-50%) translateY(-50%);
    top: 50%;
    left: 50%;
    text-align: center;
    max-width: unset;
    bottom: unset; }
    .callout .content p {
      max-width: 100%;
      margin-top: 15px; }
  .callout .contact {
    position: absolute;
    bottom: 15px;
    text-align: center;
    left: 50%;
    transform: translateX(-50%);
    z-index: 5; }
    .callout .contact p {
      color: #FEFEFE; }
  .callout .space-overlay-mobile {
    top: 50%;
    left: 50%;
    bottom: unset;
    transform: translateX(-50%) translateY(-50%); }
  .callout .space-overlay {
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%); }

.this-is-our-show {
  width: 80%;
  max-width: 450px;
  margin: 0 auto; }
  @media (min-width: 1024px) {
    .this-is-our-show {
      max-width: 650px; } }
  .this-is-our-show h2 {
    max-width: 175px;
    margin-bottom: 15px; }
    @media (min-width: 700px) {
      .this-is-our-show h2 {
        max-width: 300px; } }
    @media (min-width: 1024px) {
      .this-is-our-show h2 {
        max-width: 340px;
        margin-bottom: 30px; } }
  .this-is-our-show p {
    margin-bottom: 15px; }
    @media (min-width: 1024px) {
      .this-is-our-show p {
        margin-bottom: 30px; } }
    .this-is-our-show p.show-subtext span {
      text-transform: uppercase; }

.seniors {
  width: 80%;
  margin: 0 auto;
  max-width: 450px; }
  @media (min-width: 700px) {
    .seniors {
      max-width: 450px; } }
  @media (min-width: 1024px) {
    .seniors {
      width: 90%;
      max-width: unset; } }
  .seniors h2 {
    margin-bottom: 30px;
    text-align: center; }
    @media (min-width: 700px) {
      .seniors h2 {
        margin-bottom: 45px; } }
    @media (min-width: 1024px) {
      .seniors h2 {
        margin-bottom: 60px; } }
  @media (min-width: 1024px) {
    .seniors .student-group .student-images {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      margin-bottom: 30px; } }
  .seniors .student-group .student-images .individual-student {
    display: block;
    text-decoration: none;
    position: relative;
    color: #FEFEFE; }
    @media (min-width: 1024px) {
      .seniors .student-group .student-images .individual-student {
        width: 22%; } }
    .seniors .student-group .student-images .individual-student img {
      display: block;
      width: 100%;
      margin-bottom: 20px; }
      @media (min-width: 1024px) {
        .seniors .student-group .student-images .individual-student img {
          margin: 0; } }
      .seniors .student-group .student-images .individual-student img.silly {
        display: none; }
    .seniors .student-group .student-images .individual-student .portfolio-button {
      position: absolute;
      bottom: 0;
      width: 100%;
      padding: 20px 0; }
      .seniors .student-group .student-images .individual-student .portfolio-button p {
        text-align: center;
        color: #FEFEFE; }
        @media (min-width: 1024px) {
          .seniors .student-group .student-images .individual-student .portfolio-button p {
            font-size: 18px; } }
    .seniors .student-group .student-images .individual-student:hover .portfolio-button {
      text-decoration: underline; }
    .seniors .student-group .student-images .individual-student:hover .prof {
      display: none; }
    .seniors .student-group .student-images .individual-student:hover .silly {
      display: block; }
  .seniors .student-group .student-images .mobile-content {
    margin-bottom: 20px; }
    @media (min-width: 700px) {
      .seniors .student-group .student-images .mobile-content {
        margin-bottom: 45px; } }
    @media (min-width: 1024px) {
      .seniors .student-group .student-images .mobile-content {
        display: none; } }
  @media (min-width: 1024px) {
    .seniors .student-group:last-of-type .student-images {
      justify-content: start; } }
  @media (min-width: 1024px) {
    .seniors .student-group:last-of-type .student-images .individual-student {
      margin-right: 4%; } }
  .seniors .student-info {
    display: none; }
    @media (min-width: 1024px) {
      .seniors .student-info {
        margin-bottom: 30px;
        display: block;
        height: 150px; } }
    .seniors .student-info div {
      display: none; }
      .seniors .student-info div h3 {
        margin-bottom: 15px; }
      .seniors .student-info div.hovered {
        display: block; }

.sponsors {
  background: #F1F1F1; }
  .sponsors h2 {
    text-align: center;
    margin-bottom: 30px; }
    @media (min-width: 700px) {
      .sponsors h2 {
        margin-bottom: 45px; } }
    @media (min-width: 1024px) {
      .sponsors h2 {
        margin-bottom: 60px; } }
  .sponsors .sponsors-grid {
    width: 80%;
    margin: 0 auto;
    max-width: 450px; }
    @media (min-width: 700px) {
      .sponsors .sponsors-grid {
        display: flex;
        flex-wrap: wrap;
        max-width: unset;
        justify-content: flex-start;
        align-items: center; } }
    .sponsors .sponsors-grid div {
      display: block;
      margin: 0 auto 30px;
      width: 100%; }
      @media (min-width: 700px) {
        .sponsors .sponsors-grid div {
          width: 45%;
          margin: 0 2.5% 45px; } }
      @media (min-width: 1024px) {
        .sponsors .sponsors-grid div {
          width: 30%;
          margin: 0 1.66% 60px; } }
      .sponsors .sponsors-grid div img {
        display: block;
        max-height: 75px;
        max-width: 150px;
        margin: 0 auto; }
        @media (min-width: 700px) {
          .sponsors .sponsors-grid div img {
            max-height: 125px;
            max-width: 300px; }
            .sponsors .sponsors-grid div img.horiz {
              max-height: 75px; } }
    .sponsors .sponsors-grid.smaller-logos div {
      width: 45%; }
      @media (min-width: 700px) {
        .sponsors .sponsors-grid.smaller-logos div {
          width: 30%;
          margin: 0 1.66% 45px; } }
      @media (min-width: 1024px) {
        .sponsors .sponsors-grid.smaller-logos div {
          width: 18%;
          margin: 0 3.5% 60px; } }
      .sponsors .sponsors-grid.smaller-logos div img {
        max-height: 50px;
        max-width: 75px; }
        @media (min-width: 700px) {
          .sponsors .sponsors-grid.smaller-logos div img {
            max-height: 75px;
            max-width: 150px; } }
  .sponsors h4 {
    width: 80%;
    margin: 0 auto 25px;
    max-width: 450px; }
    @media (min-width: 700px) {
      .sponsors h4 {
        max-width: unset;
        margin-bottom: 30px; } }
    @media (min-width: 1024px) {
      .sponsors h4 {
        margin-bottom: 45px; } }
  .sponsors .contributers {
    width: 80%;
    margin: 0 auto;
    max-width: 450px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    @media (min-width: 700px) {
      .sponsors .contributers {
        max-width: unset; } }
    .sponsors .contributers ul {
      list-style: none;
      width: 45%;
      margin-bottom: 20px; }
      @media (min-width: 700px) {
        .sponsors .contributers ul {
          width: 30%;
          margin-bottom: 30px; } }
      @media (min-width: 1024px) {
        .sponsors .contributers ul {
          margin-bottom: 45px; } }
