html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  font-size: 16px;
}

* {
  box-sizing: border-box;
  transition: 0.3s ease;
  font-family: "sen";
  color: var(--light-text);
}

/* --Font-- */

@font-face {
  font-family: "sen";
  src: url(Fonts/Sen-VariableFont_wght.ttf);
  letter-spacing: -1px;
}

@font-face {
  font-family: "euphorigenic";
  src: url(Fonts/Euphorigenic.otf);
}

/* --Colors & Glass--*/

:root {
  --light-back: #4d8db0;
  --dark-back: #1f3d4d;
  --light-text: #f2fce8;
  --dark-text: #142c36;
  --dark-fade: #1f3d4d90;
  --emph-text: #ffd479;

  --glass-bg: rgba(58, 98, 118, 0.72);
  --glass-border: rgba(255, 255, 255, 0.2);
  --glass-glow: rgba(255, 255, 255, 0.05);
  --glass-shadow: rgba(0, 0, 0, 0.25);
  --glass-shine: rgba(255, 255, 255, 0.15);
}

/* --Glass-- */

.glass {
  background-color: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 1.5rem;
  padding: 0.75rem;
  font-weight: 500;
  backdrop-filter: blur(30px) saturate(150%);
  -webkit-backdrop-filter: blur(30px) saturate(150%);
  box-shadow: inset 0 0 1px var(--glass-glow), 0 6px 20px var(--glass-shadow);
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.glass::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    145deg,
    rgba(255, 255, 255, 0.04),
    rgba(255, 255, 255, 0)
  );
  z-index: 0;
  pointer-events: none;
}

.glass::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, var(--glass-shine), transparent);
  opacity: 0.3;
  pointer-events: none;
}

/* --Color-Settings-- */

body,
.about,
.spacer-slash-left,
.spacer-waves-2,
.crew-card-large,
.crew-card,
.cast-card,
.headshot img,
.filters button,
.scroll-btn,
.screening-head,
.screenings,
#gallery,
.gallery-heading,
.gallery-footer {
  background-color: var(--dark-back);
}

.laurels,
.spacer-slash-right,
.spacer-waves,
.cast-crew,
.key-team,
.filters button.selected,
.screening,
.fest-btn,
.contact,
#lightbox img {
  background-color: var(--light-back);
}

.laurels,
.key-team,
.cast-crew,
.contact,
nav a {
  text-shadow: 0 0 5px var(--dark-back);
}

/* --Background-Settings-- */

.landing,
.film-section,
.key-team-member,
.about {
  background-size: cover;
  background-repeat: no-repeat;
}

/* --Z-Index-- */
.cast-crew,
.scroller-wrap,
.crew-card,
.cast-card {
  z-index: 5;
}

.cast-crew,
.scroll-head,
.spacer-waves,
.spacer-waves-2,
.spacer-slash-left,
.spacer-slash-right,
.spacer-steps,
.spacer-drips,
.spacer-hills,
.wave-frame,
.screening-heading,
.gallery-screening,
.scroller-fade-left,
.scroller-fade-right,
.screening-head {
  z-index: 15;
}

header,
.socials,
.filters,
.scroll-btn,
.gallery-footer {
  z-index: 25;
}

nav,
.screening-wrap::-webkit-scrollbar {
  z-index: 100;
}

.modal,
#lightbox {
  z-index: 200;
}

/* --Floats-- */
.spacer-drips,
.editorial,
#contact-form {
  float: left;
}

.filters,
.foot-right,
.social-wrap {
  float: right;
}

/* --Positions-- */

header,
.scroller-wrap,
.crew-card,
.cast-card,
.screening-head,
.gallery-heading,
.screenings,
.editorial,
.spacer-waves,
.spacer-waves-2,
.spacer-slash-left,
.spacer-slash-right,
.spacer-steps,
.spacer-drips,
.spacer-slash-right,
.spacer-slash-left {
  position: relative;
}

.scroll-btn,
.scroller-fade-left,
.scroller-fade-right {
  position: absolute;
}

/* --Display-- */
main,
.landing,
header,
nav,
.about,
.socials,
.laurel-grid span,
.award-block,
.award-block p,
.films,
.film-section,
.our-team,
.key-team-member,
.sonia,
.pat,
.team-head,
.card-content,
.card-content-large,
.cast,
.crew,
.filters,
.scroller-wrap,
.scroller,
.scroll-btn,
.gallery,
.gallery-section,
.screening-list,
.contact,
.contact-heading a,
#lightbox.active {
  display: flex;
}

.laurel-grid,
.crew-page,
.screening,
.foot-right,
#contact-form {
  display: grid;
}

.key-team .subheading,
.logo,
.spacer-drips,
.subheading-small {
  display: block;
}

/* --Flex Flow-- */
.contact,
footer {
  flex-flow: wrap-reverse;
}

.landing,
.about,
.gallery,
.card-content-large {
  flex-flow: wrap;
}

main,
.contact-heading a,
.award-block,
.films,
.our-team,
.team-head,
.cast,
.crew,
.screening-list,
.gallery-section,
.contact-heading a,
#lightbox {
  flex-direction: column;
}

.socials,
nav,
.card-content,
.card-content-large,
.filters,
.scroller,
.gallery,
.contact,
.landing,
.about,
.film-section,
.gallery,
.sonia,
.key1 .card-content-large,
.key2 .card-content-large,
.key3 .card-content-large,
.film-2,
.pat {
  flex-direction: row;
}

/* --Margins-- */

.screening-head,
.screening-wrap,
.inside,
.landing,
.laurel-grid,
.and-count span,
.award-count span,
.film-section,
.sonia,
.pat,
.crew-page,
.cast-crew-menu,
.gallery,
.filters,
.gallery-wrap,
.contact {
  margin-inline: auto;
}

.inside,
.landing,
.laurel-grid,
.and-count span,
.award-count span,
.film-section,
.sonia,
.pat,
.crew-page,
.cast,
.crew,
.filters,
.gallery-wrap,
.contact,
.inner-large,
.contact-heading {
  margin-block: auto;
}

.inside,
.left,
.right,
.left-large,
.right-large,
.landing,
.laurel-grid,
.and-count span,
.film-section,
.sonia,
.pat,
.crew-page,
.cast,
.crew,
.filters,
.gallery-wrap,
.contact,
.crew-wrap,
.crew-page,
.crew-card,
.crew-card-large,
.cast-card {
  align-content: center;
  justify-content: space-around;
}

a:active, .awards-button:active,
.read-more:active, .filters button:active, .fest-btn:active, .crew-card,
.cast-card, #submit:active {
  transform: scale(0.8);
}

.blurb,
.subheading-small {
  font-size: 1.2rem;
}

body {
  margin: 0;
  width: 100vw;
}

/* --Components-- */

p {
  margin-block: 0.5rem;
}

h1 {
  margin-top: -7rem;
  padding-left: 1rem;
  font-size: 12rem;
  text-align: left;
  width: auto;
  height: 10px;
  font-weight: lighter;
}

h2 {
  font-size: 8rem;
}

/* --Headings-- */

.heading,
.heading-small,
.heading-large {
  margin-bottom: 1rem;
}

.heading-large {
  font-size: 4.2rem;
}

.heading {
  font-size: 2rem;
}

.heading-small {
  font-size: 1.5rem;
}

.subheading,
.subheading-small {
  font-weight: normal;
  opacity: 0.9;
}

/* --Blurbs-- */

.blurb-small {
  overflow: hidden;
  position: relative;
  font-size: 1.1rem;
}

.blurb-xs {
  font-size: 1rem;
}

/* --Logos and Socials-- */

.prod-logo {
  height: 8rem;
}

.prod-logo:hover {
  transform: scale(1.1);
}

.imdb {
  align-content: center;
}

.imdb a {
  float: right;
}

.logo {
  height: 2rem;
  max-width: 4rem;
  vertical-align: middle;
  fill: var(--light-text);
}

.logo:hover {
  fill: var(--emph-text);
  transform: scale(1.1);
}

.socials {
  width: 100%;
  justify-content: space-evenly;
  justify-self: center;
  max-width: 300px;
  padding-block: 10px;
}

.social-wrap {
  margin-right: 0;
}

/* --Sizzle and Stills-- */

.sizzle iframe {
  min-height: 280px;
  animation: fadeIn 1.5s ease-out forwards;
  border-radius: 10px;
}

.still img,
.sizzle iframe {
  width: clamp(1px, 99%, 100%);
}

.still img {
  width: 100%;
  height: auto;
  display: block;
}

.still-small img {
  width: 49%;
}

/* Headshots */

.headshot img {
  width: 100%;
  height: auto;
  border-radius: 1.5rem;
}

/* --Layout-- */

.inner-content {
  display: flex;
  max-width: 1000px;
  width: 90%;
  padding: 2rem;
  border-radius: 20px;
}

.grid-section {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  align-items: start;
  gap: 2rem;
}

.grid-section .grid-item:nth-child(2) {
  text-align: left;
}

.grid-section .grid-item .film-buttons {
  justify-content: center;
}

/* --Header-- */

header {
  width: 72%;
  justify-content: space-between;
  margin-top: 2rem;
  margin-right: 8rem;
}

/* --Nav-- */

nav {
  height: 2vh;
  width: clamp(400px, 450px, 550px);
  position: fixed;
  bottom: 2rem;
  right: 17.5%;
  justify-content: space-between;
  text-decoration: none;
}

nav a {
  text-decoration: none;
  height: 1.5rem;
  padding-inline: 4px;
  border-radius: 20px;
  align-content: center;
}

nav a:hover {
  color: var(--emph-text);
  transform: scale(1.1);
}

nav .glass {
  padding-block: 0;
}

.scroll-top {
  padding-inline: 0;
  margin-top: -5px;
}

/* --Landing-- */

.landing {
  width: 100%;
  background-image: url(Images/00_Background_LandingPic.png);
  background-position: 7% 80%;
  background-attachment: fixed;
  opacity: 0;
  animation: fadeIn 1s ease-in forwards;
}

.left-landing {
  width: 55vw;
  align-content: flex-end;
  padding-bottom: 10rem;
}

.right-landing {
  width: 43%;
}

.right-landing,
.left-landing {
  height: 80vh;
  margin-bottom: 4rem;
}

.right-landing .inside {
  margin-block: 5vh 12vh;
  bottom: 0;
  width: clamp(300px, 500px, 100%);
  float: left;
  padding: 1.25rem;
}

.title {
  font-size: 10vw;
  margin-left: 12vw;
  text-shadow: 0 0 10px var(--dark-text);
  line-height: 10rem;
  white-space: nowrap;
  font-family: "euphorigenic";
}

/* --About-- */

.about {
  background-attachment: fixed;
  margin-block: 8rem;
  display: flex;
  justify-content: center;
  padding: 1rem;
  background: none;
}

/* --Laurels-- */

.laurels {
  padding-bottom: 5rem;
}

.laurel-grid {
  grid-template-areas:
    "a b c d e"
    "f txt txt txt g"
    "h txt txt txt i"
    "j k l m n";
  grid-template-columns: 2fr 2fr 2fr 2fr 2fr;
  grid-template-rows: 1fr 1fr 1fr 1fr;
  padding-block: 5rem;
  padding-inline: 2rem;
  column-gap: 1rem;
  row-gap: 2rem;
  justify-items: center;
  align-items: center;
}

.laurel-grid span {
  align-items: center;
  height: 100%;
  width: 100%;
}

.laurel-grid span p {
  display: block;
}

.laurel-grid span img {
  max-height: 100%;
  max-width: 100%;
  height: 8vw;
  object-fit: contain;
}

/* --Award Block (text in middle of laurels section)-- */

.award-block {
  grid-area: txt;
}

.award-block p {
  margin: 0;
  height: auto;
}

.award-count {
  font-size: clamp(5rem, 6rem, 9rem);
  font-weight: bold;
  text-decoration: none;
  color: var(--emph-text);
  max-width: 12rem;
}

.award-text {
  font-size: clamp(1rem, 2.5rem, 5rem);
  text-decoration: none;
  max-width: 550px;
  margin-block: auto;
}

.and-count {
  font-size: 2rem;
  line-height: 4rem;
}

/* --Film Sections-- */

.films {
  height: clamp(300vh, 300vh, 300%);
  justify-content: space-between;
}

.film-section {
  width: 100%;
  padding-block: 10rem;
}

.film-1 {
  background-image: url(Images/00_Background_Ms-Rossi.jpg);
}

.film-2 {
  background-image: url(Images/00_Background_Ms-Rossi-2.jpg);
}

.film-3 {
  background-image: url(Images/00_Background_Ms-Rossi-3.jpg);
}

.film-buttons {
  padding: auto;
  height: 3.5rem;
  display: flex;
  gap: 1rem;
  align-items: center;
}

.film-buttons a .logo {
  width: 6rem;
  height: 2.5rem;
}

/* --Our Team (Pat & Sonia)-- */

.our-team {
  row-gap: 1rem;
  padding-top: 5rem;
}

.sonia .grid-section {
  grid-template-columns: 2fr 3fr;
}

.pat .grid-section {
  grid-template-columns: 3fr 2fr;
}

.sonia {
  background-image: url(Images/00_Background_Sonia.png);
  padding-block: 10rem 10rem;
  background-position: 90% 10%;
}

.pat {
  padding-block: 10rem;
  background-image: url(Images/00_Background_Pat.png);
  background-position: 10% 50%;
}

.sonia,
.pat {
  min-height: 80vh;
  width: 100%;
}

/* --Key Cards (3 Key Crew)-- */

.crew-page {
  justify-items: center;
  min-height: 60rem;
  width: clamp(75vw, 90vw, 95vw);
  padding-block: 10rem;
  gap: 1rem;
  justify-content: space-around;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  grid-template-areas:
    "head key1"
    "key2 key3";
}

.team-head {
  font-size: 8rem;
  grid-area: head;
  width: clamp(1px, 100%, 98vw);
}

.team-head span {
  text-align: right;
  padding-inline: 2rem;
}

.key1 {
  grid-area: key1;
}

.key2 {
  grid-area: key2;
}

.key3 {
  grid-area: key3;
}

/* --Cast & Crew-- */

.cast-crew {
  width: 100%;
  position: relative;
}

.cast-crew-menu {
  width: clamp(60vw, 100%, 100rem);
}

.cast,
.crew {
  scrollbar-width: none;
  width: clamp(1px, 100%, 1400px);
  margin-inline: auto;
}

/* --Filter Btns-- */

.filters {
  justify-content: space-between;
  width: 30rem;
  position: sticky;
  top: 20px;
  padding-right: 1rem;
}

.filters button {
  border: 2px solid var(--light-back);
  padding: 10px 15px;
  border-radius: 5px;
  font-size: 1.2rem;
  cursor: pointer;
}

.filters button:hover {
  background-color: var(--emph-text);
  color: var(--dark-text);
  border-color: var(--dark-back);
  transform: scale(1.1);
}

.filters button.selected {
  color: var(--dark-text);
  border: 2px solid var(--dark-back);
  font-weight: bold;
}

/* --Cast-Crew Scrollers-- */

.scroller-wrap {
  height: 30rem;
  margin-bottom: 3rem;
}

.scroller {
  height: 30rem;
  overflow-x: scroll;
  padding-inline: 15rem;
  scrollbar-width: none;
  scroll-behavior: smooth;
  align-items: center;
}

.scroll-head {
  letter-spacing: -5px;
}

.scroller-fade-left {
  left: 0;
  background: linear-gradient(to right, var(--light-back) 60%, transparent);
}

.scroller-fade-right {
  right: 0;
  background: linear-gradient(to left, var(--light-back) 60%, transparent);
}

.scroller-fade-left,
.scroller-fade-right {
  top: 0;
  width: 10%;
  height: 100%;
}

/* --Scroll-Btns-- */

.scroll-btn {
  border: 2px solid var(--light-back);
  border-radius: 0.5rem;
  font-size: 2rem;
  cursor: pointer;
  justify-content: center;
  align-items: center;
  padding: 0;
  width: 3rem;
  height: 3rem;
  top: 50%;
  transform: translateY(-50%);
}

.scroll-btn:hover {
  background-color: var(--emph-text);
  border-color: var(--dark-text);
  color: var(--dark-text)
}

#back-cast,
#back-crew {
  left: 1rem;
}

#next-cast,
#next-crew {
  right: 1rem;
}

/* --Cast & Crew Cards-- */

.crew-card,
.crew-card-large,
.cast-card {
  box-shadow: 0 0 20px var(--dark-text);
  margin-block: auto;
}

.crew-card-large {
  padding: 1rem;
}

.card-content,
.card-content-large {
  align-items: center;
  justify-content: center;
  gap: 1rem;
  height: 100%;
}

.crew-card,
.cast-card {
  width: clamp(500px, 550px, 1000px);
  margin: 2rem;
  padding: 1rem;
  transition: 1s ease;
  pointer-events: auto;
}

.crew-card-large,
.crew-card,
.cast-card {
  border-radius: 1.5rem;
}

.crew-desc {
  max-width: 450px;
  align-self: center;
}

.crew-desc-small {
  width: clamp(200px, 400px, 550px);
}

.crew-card-large .headshot img {
  width: 12rem;
  min-width: 150px;
}

.crew-card .headshot img,
.cast-card .headshot img {
  width: 12rem;
  max-width: 200px;
}

.card-content .headshot {
  width: clamp(1rem, 12rem, 15rem);
}

/* --Screenings Section-- */

.screenings {
  overflow-y: inherit;
  margin-top: 10rem;
}

.screening-head {
  text-align: left;
  width: 51rem;
  position: relative;
  padding-inline: 1rem;
  box-shadow: 0 0 20px 15px var(--dark-back);
}

.screening-wrap {
  width: 51rem;
  height: 85vh;
  overflow-y: auto;
  padding-bottom: 5vh;
  scrollbar-width: thin;
  scrollbar-color: var(--light-text) var(--dark-back);
}

.screening-wrap::-webkit-scrollbar {
  position: relative;
  background: var(--dark-back);
}

.screening-wrap .spacer {
  height: 10rem;
}

.screening-list {
  width: 100%;
  align-items: center;
  gap: 2rem;
  overflow-x: hidden;
}

/* --Screening Cards-- */

.screening {
  grid-template-columns: 1fr 6fr 1fr;
  grid-template-areas: "calendar text button";
  width: 50rem;
  margin-bottom: 2rem;
  border-radius: 1.5rem;
  padding: 1rem 1rem 1rem 1rem;
  column-gap: 1rem;
  position: relative;
}

.past-screening {
  filter: grayscale(100%);
  opacity: 0.5;
}

/* --Calendar-- */

.date_time {
  text-align: center;
  border-color: var(--light-text);
  grid-area: calendar;
  align-self: center;
}

.month,
.blurb-large,
nav,
.subheading,
.bio,
.contact p {
  font-size: 1.2rem;
}

.month{
  text-align: center;
  border-color: var(--light-text);
  padding: 0 0.5vw 0 0.5vw;
  color: var(--dark-text);
  background-color: var(--light-text);
  border-radius: 0.5rem 0.5rem 0 0;
}

.day {
  text-align: center;
  font-size: 3rem;
  border-radius: 0 0 0.5rem 0.5rem;
  background-color: var(--dark-fade);
}

.screening-info {
  text-align: left;
  margin-left: 1.5rem;
  height: auto;
  grid-area: text;
}

.screen-head {
  font-size: 2.5rem;
  margin-bottom: 1vh;
}

/* --Fest-Btn-- */

.fest-btn {
  height: 3.5rem;
  align-self: center;
  width: 100%;
  font-size: 1rem;
  border: 2px solid var(--light-text);
}

.fest-btn:hover {
  background-color: var(--emph-text);
  color: var(--dark-text);
  border-color: var(--dark-back);
  transform: scale(1.1);
}

/* --Gallery-- */

.gallery {
  justify-content: space-around;
  width: clamp(5rem, 100%, 90rem);
}

.gallery-wrap {
  width: 30%;
  height: 60rem;
}

.gallery-section {
  height: 90%;
  width: auto;
}

.images {
  overflow-y: scroll;
  width: 100%;
  scrollbar-width: thin;
  scrollbar-color: var(--light-text) var(--dark-back);
}

.images img {
  width: 100%;
  margin-bottom: 2vh;
}

.images .spacer {
  height: 10rem;
  width: 100%;
}

.gallery-heading {
  text-align: left;
  font-size: 9rem;
  height: 8rem;
  width: 100%;
  margin: 0;
  box-shadow: 0 0 20px 15px var(--dark-back);
}

.gallery-footer {
  height: 10vh;
  box-shadow: 0 0 100px 100px var(--dark-back);
  width: 100%;
}

/* --Contact Section-- */

.contact {
  padding-block: 20rem 15rem;
  box-sizing: border-box;
  width: 100%;
  overflow-x: hidden;
  position: relative;
}

.contact-heading {
  width: 50%;
  font-size: 4rem;
  font-weight: bolder;
}

.contact-heading a {
  width: 100%;
  font-size: 2rem;
}

/* --Contact Form-- */

#contact-form {
  height: 17rem;
  width: 100%;
  margin-inline: auto;
  column-gap: 1rem;
  row-gap: 0.25rem;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr 3fr 1fr;
  grid-template-areas:
    "first last"
    "phone email"
    "message message"
    "submit submit";
}

#first-name {
  grid-area: first;
}

#last-name {
  grid-area: last;
}

#email {
  grid-area: email;
}

#phone {
  grid-area: phone;
}

#message {
  grid-area: message;
}

#contact-form textarea,
#contact-form input,
#submit {
  border-width: 3px;
  border-color: var(--light-text);
  border-style: solid;
  border-radius: 3px;
  width: 7rem;
  font-family: "sen";
  background-color: var(--light-back);
}

#contact-form textarea,
#contact-form input {
  padding: 1rem;
}

#contact-form input::placeholder,
#contact-form textarea::placeholder {
  color: var(--light-text);
  opacity: 0.7;
  font-size: 1.25rem;
}

#contact-form textarea {
  width: 100%;
}

#contact-form input {
  width: 100%;
  height: 2.5rem;
}

#submit {
  width: 100% !important;
  height: 2.5rem;
  font-size: 1.5rem;
  grid-area: submit;
  margin-top: 0.25rem;
}

#submit:hover {
  background-color: var(--emph-text);
  color: var(--dark-text);
}

/* --Footer-- */

footer {
  height: 15rem;
  width: clamp(300px, 100%, 1500px);
  display: flex;
  justify-content: center;
  margin-inline: auto;
  padding-block: 1rem;
}

footer .foot-content {
  width: 100%;
  display: flex;
  justify-content: center;
}

.foot-right {
  width: clamp(25px, 60%, 65%);
  text-align: right;
  line-height: 2.5rem;
  font-size: 1rem;
  justify-content: end;
  max-height: 8rem;
}

/* -Spacers- */

.editorial {
  width: clamp(1px, 100%, 100vw);
  height: 6.5rem;
  top: 0;
}

.editorial svg {
  height: 7rem;
  width: 100%;
}

.spacer-drips {
  width: 100%;
  height: 100%;
  position: relative;
  margin-block: -5px -18rem;
  line-height: 0;
  overflow: hidden;
}

.spacer-drips svg {
  width: 100%;
  height: 100%;
  display: block;
  transform: rotate(180deg);
}

.spacer-slash-right,
.spacer-slash-left {
  height: 15rem;
  width: 100%;
  margin-block: -3.2rem;
}

.spacer-slash-right {
  transform: skew(0, -2deg);
}

.spacer-slash-left {
  transform: skew(0, 2deg);
}

.spacer-steps {
  fill: var(--light-back);
  margin-top: 3rem;
  transform: skew(0, -2deg);
}

.spacer-steps-2 {
  fill: var(--light-back);
  transform: rotate(180deg);
  height: 5rem;
  margin-top: 3rem;
}

.spacer-waves,
.spacer-waves-2 {
  height: 10rem;
  clip-path: polygon(
    0% 65%,
    1% 64.95%,
    2% 64.8%,
    3% 64.6%,
    4% 64.3%,
    5% 63.9%,
    6% 63.45%,
    7% 62.9%,
    8% 62.25%,
    9% 61.55%,
    10% 60.8%,
    11% 59.95%,
    12% 59.05%,
    13% 58.1%,
    14% 57.1%,
    15% 56.05%,
    16% 55%,
    17% 53.9%,
    18% 52.8%,
    19% 51.65%,
    20% 50.5%,
    21% 49.35%,
    22% 48.2%,
    23% 47.05%,
    24% 45.9%,
    25% 44.8%,
    26% 43.75%,
    27% 42.75%,
    28% 41.75%,
    29% 40.8%,
    30% 39.9%,
    31% 39.1%,
    32% 38.35%,
    33% 37.65%,
    34% 37.05%,
    35% 36.5%,
    36% 36.05%,
    37% 35.65%,
    38% 35.35%,
    39% 35.15%,
    40% 35.05%,
    41% 35%,
    42% 35.05%,
    43% 35.2%,
    44% 35.45%,
    45% 35.75%,
    46% 36.15%,
    47% 36.65%,
    48% 37.2%,
    49% 37.85%,
    50% 38.55%,
    51% 39.35%,
    52% 40.2%,
    53% 41.1%,
    54% 42.05%,
    55% 43.05%,
    56% 44.1%,
    57% 45.15%,
    58% 46.3%,
    59% 47.4%,
    60% 48.55%,
    61% 49.7%,
    62% 50.85%,
    63% 52%,
    64% 53.15%,
    65% 54.25%,
    66% 55.35%,
    67% 56.4%,
    68% 57.45%,
    69% 58.4%,
    70% 59.35%,
    71% 60.2%,
    72% 61.05%,
    73% 61.8%,
    74% 62.45%,
    75% 63.05%,
    76% 63.6%,
    77% 64.05%,
    78% 64.4%,
    79% 64.7%,
    80% 64.85%,
    81% 65%,
    82% 65%,
    83% 64.9%,
    84% 64.75%,
    85% 64.5%,
    86% 64.2%,
    87% 63.75%,
    88% 63.25%,
    89% 62.7%,
    90% 62.05%,
    91% 61.3%,
    92% 60.5%,
    93% 59.65%,
    94% 58.75%,
    95% 57.8%,
    96% 56.8%,
    97% 55.75%,
    98% 54.65%,
    99% 53.55%,
    100% 52.4%,
    100% 100%,
    0% 100%
  );
}

.spacer-waves {
  margin-bottom: -1rem;
}

.spacer-waves-2 {
  margin-top: -9rem;
}

.spacer-hills {
  transform: rotate(180deg);
  height: 12;
  margin-top: -5rem;
}

.wave-frame {
  height: 12vh;
  margin-bottom: 5vh;
}

/* --Buttons-- */

.awards-button,
.read-more {
  background-color: transparent;
  border: 2px solid var(--light-text);
  height: 2rem;
  font-size: 1.5rem;
  width: auto;
  padding: 0.25rem;
  line-height: 1rem;
}

.awards-button:hover,
.read-more:hover {
  background-color: var(--emph-text);
  color: var(--dark-text);
  border-color: var(--dark-back);
  transform: scale(1.1);
}

/* --Modals-- */

body.modal-open {
  position: fixed;
  width: 100%;
  overflow: hidden;
  touch-action: none;
}

body.modal-open html {
  scroll-behavior: auto !important;
}

.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 99vw;
  height: 100vh;
  backdrop-filter: blur(10px);
  background-color: rgba(0, 0, 0, 0.7);
  justify-content: center;
  align-items: center;
  overflow-y: auto;
  padding: 2rem;
}

.modal .close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  font-size: 2rem;
  cursor: pointer;
}

.modal-overlay {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
}

.modal-content {
  position: relative;
  padding: 1rem;
  max-width: 70vw;
  width: 100%;
  max-height: 100%;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
  justify-content: center;
}

/* --Crew Modals--*/

.modal .grid-section {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 2rem;
  padding: 1rem;
}

.bio {
  line-height: 1.5rem;
  overflow-y: auto;
  max-height: 50vh;
}

.modal .headshot {
  width: 100%;
  justify-content: center;
  display: flex;
}

.modal-info.no-image {
  grid-column: 1 / -1;
  text-align: center;
  align-items: center;
  justify-content: center;
  margin-inline: 5rem;
}

/* --Awards Modals-- */

.awards-modal .heading {
  padding: 1.5rem;
}

.awards-wrap {
  max-height: 50vh;
  overflow: auto;
}

.awards-grid {
  display: grid;
  gap: 1.5rem;
  margin-top: 1rem;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  width: 99%;
  height: clamp(10%, 90%, 100%);
  overflow-y: auto;
  padding: 0.5rem;
}

.award-entry {
  padding: 0.5rem;
  border-radius: 0.5rem;
  background: var(--dark-back);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}

.award-header {
  font-size: 1.2rem;
  font-weight: bold;
  margin-bottom: 0.2rem;
}

.award-subheader {
  font-size: 1rem;
  font-style: italic;
  opacity: 0.5;
  margin-bottom: 0.5rem;
}

.result-category {
  font-size: 0.95rem;
}

.modal .bio::-webkit-scrollbar {
  width: 8px;
}
.modal .bio::-webkit-scrollbar-thumb {
  background: var(--light-back);
  border-radius: 4px;
}

.awards-wrap::-webkit-scrollbar {
  width: 8px;
}
.awards-wrap::-webkit-scrollbar-thumb {
  background: var(--light-back);
  border-radius: 4px;
}

/* --Lightbox-- */

#lightbox {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none;
  justify-content: space-around;
  align-items: center;
  padding: 2rem;
  background-color: var(--dark-fade);
}

#lightbox img {
  max-width: 90%;
  max-height: 80%;
  padding: 4px;
  border-radius: 8px;
}

#lightbox-caption {
  margin-top: 1rem;
  text-align: center;
  font-size: 1.2rem;
  max-width: 90%;
  background-color: var(--dark-back);
}
/* --Animations-- */

/* Fade-in Animation */
@keyframes fadeIn {
  to {
    opacity: 1;
  }
}

/* Editorial */

.parallax1 > use {
  animation: move-forever1 10s linear infinite;
  &:nth-child(1) {
    animation-delay: -2s;
  }
}
.parallax2 > use {
  animation: move-forever2 8s linear infinite;
  &:nth-child(1) {
    animation-delay: -2s;
  }
}
.parallax3 > use {
  animation: move-forever3 6s linear infinite;
  &:nth-child(1) {
    animation-delay: -2s;
  }
}
.parallax4 > use {
  animation: move-forever4 4s linear infinite;
  &:nth-child(1) {
    animation-delay: -2s;
  }
}
@keyframes move-forever1 {
  0% {
    transform: translate(85px, 0%);
  }
  100% {
    transform: translate(-90px, 0%);
  }
}
@keyframes move-forever2 {
  0% {
    transform: translate(-90px, 0%);
  }
  100% {
    transform: translate(85px, 0%);
  }
}
@keyframes move-forever3 {
  0% {
    transform: translate(85px, 0%);
  }
  100% {
    transform: translate(-90px, 0%);
  }
}
@keyframes move-forever4 {
  0% {
    transform: translate(-90px, 0%);
  }
  100% {
    transform: translate(85px, 0%);
  }
}

/* --Responsiveness-- */

@media (max-width: 1023px) {
  /* --Layout-- */

  .inner-content {
    width: 90%;
    padding: 1.5rem;
    text-align: left;
  }

  .grid-section .grid-item:nth-child(1) {
    text-align: left;
  }

  nav {
    justify-content: space-around;
    width: clamp(200px, 100%, 100vw);
    justify-self: center;
    padding-inline: 0.5rem;
    right: 0;
  }

  .about,
  .film-section,
  .contact {
    flex-direction: column;
    align-items: center;
    row-gap: 4rem;
  }

  .blurb,
  .blurb-large,
  .blurb-small,
  .heading-large,
  .heading,
  .heading-small,
  .cast,
  .crew,
  .still {
    width: 100% !important;
    min-width: unset;
    height: auto;
  }

  .blurb-xs {
    display: none;
  }

  .inside {
    margin-top: 0;
    padding-top: 0;
    height: auto;
  }

  /* --Headers-- */

  header {
    width: 90%;
    margin: 1rem 0 0 0;
  }

  .heading {
    display: block;
    width: 100%;
  }

  .subheading,
  .subheading-small {
    font-size: 1.3rem;
    display: block;
  }

  .heading-large {
    font-size: 3rem;
  }

  h1 {
    margin-top: -20px;
    height: 10vh;
    font-size: 6rem;
  }

  h2 {
    font-size: 4rem;
  }

  /* --Landing-- */

  .landing {
    background-size: contain !important;
    background-position: center top;
    background-repeat: no-repeat;
    background-attachment: scroll !important;
    background-image: url(Images/00_Background_Landing-Pic_Mobile.png);
    width: 100%;
    height: auto;
  }

  .left-landing,
  .right-landing {
    height: auto;
    width: 90%;
  }

  .left-landing {
    height: 80vh;
  }

  .right-landing {
    height: 100%;
    justify-content: center;
    margin-bottom: 5rem;
  }

  .right-landing .inside {
    margin-inline: auto;
    text-align: center;
    align-items: center;
    justify-content: center;
    float: none;
    margin-block: 0 0;
  }

  .title {
    font-size: 5rem;
    margin-left: auto;
    justify-content: center;
  }

  .sizzle iframe {
    height: 100%;
  }

  /* --About-- */

  .about {
    margin-block: 5rem;
  }

  .about .inner-content {
    width: 95%;
  }

  /* --Laurels-- */

  .laurel-grid {
    width: 90%;
    row-gap: 0;
    padding-block: 0;
    padding-inline: 0;
    height: auto;
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: 1.5fr 1fr 1fr 1fr 1fr 0.75fr 0.75fr;
    grid-template-areas:
      "txt txt txt"
      "a a b"
      "c d d"
      "e e f"
      "g h h"
      "i j k"
      "l m n";
  }

  .laurel-grid span img {
    height: 100%;
    width: 100%;
  }

  .award-block {
    margin-top: 3rem;
    row-gap: 1rem;
    margin-inline: 2rem;
  }

  .award-count {
    font-size: 4rem;
    max-width: 8rem;
    text-align: center;
  }

  .award-text {
    font-size: 2rem;
  }

  .and-count {
    margin-top: -1rem;
  }

  /* --Film Sections-- */

  .film-section {
    padding-block: 10rem;
  }

  .sonia,
  .pat {
    align-items: center;
  }

  .pat .headshot,
  .sonia .headshot {
    justify-content: center;
    width: 60%;
    height: auto;
    margin-inline: auto;
  }

  .sonia {
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    background-attachment: scroll;
    background-image: url(Images/00_Background_Sonia_Mobile.png);
    width: 100%;
    height: auto;
  }

  .pat {
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    background-attachment: scroll;
    background-image: url(Images/00_Background_Pat_Mobile.png);
    width: 100%;
    height: auto;
  }

  /* --Cast & Crew Sections-- */

  .team-head {
    width: clamp(200px, 100%, 95vw);
    font-size: 7rem;
  }

  .team-head span {
    padding-inline: 0rem;
  }

  .crew-page {
    display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: 3rem;
    min-height: auto;
    max-height: none;
    padding-block: 5rem;
    width: clamp(89%, 90%, 99vw);
  }

  .sonia .grid-section {
    display: flex;
    flex-direction: column;
  }

  .pat .grid-section {
    display: flex;
    flex-direction: column-reverse;
  }

  .cast,
  .crew,
  .inside,
  .inner-large {
    margin-inline: 0;
  }

  .read-more,
  .awards-button {
    font-size: 1rem;
  }

  .prod-logo {
    height: 6rem;
  }

  /* --Cast & Crew Scrollers-- */

  .scroll-head {
    height: 7rem;
  }

  .scroller-wrap {
    width: clamp(95vw, 100%, 98vw);
    padding: 0;
  }

  .scroller {
    padding-inline: 1.5rem;
    margin-block: 0;
    width: auto;
    height: auto;
    overflow-x: scroll;
  }

  .scroller-fade-left,
  .scroller-fade-right {
    display: none;
  }

  /* --Filter Btns-- */

  .filters {
    width: 100%;
    margin-top: -3rem;
    top: 1rem;
    justify-content: space-around;
    padding-right: 0;
  }

  .filters button {
    font-size: clamp(1rem, 1.2rem, 1.5rem);
    padding: 4px 6px;
  }

  .filters button,
  .read-more,
  .awards-button {
    white-space: nowrap;
  }

  /* --Crew Cards-- */

  .scroller-move {
    width: clamp(90vw, 95vw, 99vw);
  }

  .card-content {
    display: flex;
    flex-direction: column;
  }

  .crew-card-large {
    min-height: auto;
    max-width: auto;
  }

  .crew-card-large .headshot img {
    min-width: 75px;
  }

  .crew-card-large .crew-desc {
    width: 90%;
  }

  .cast-card,
  .crew-card {
    width: clamp(200px, 400px, 80vw);
    padding: 1rem;
    align-items: center;
    max-height: 500px;
  }

  .cast-card .headshot,
  .crew-card .headshot {
    height: auto;
    width: auto;
    align-self: center;
  }

  .cast-card .headshot img,
  .crew-card .headshot img {
    width: 100%;
    height: auto;
    max-height: 500px;
    object-fit: cover;
    border-radius: 1.5rem;
  }

  .crew-desc {
    text-align: left;
  }

  .crew-desc-small {
    width: 100%;
    text-align: center;
  }

  /* --Gallery-- */

  .gallery {
    display: flex;
    flex-direction: column;
    gap: 5rem;
    padding-inline: 0;
    padding-block: 0 5rem;
    background-color: var(--dark-back);
  }

  .gallery-heading {
    position: static;
    height: 10rem;
    font-size: 6rem;
  }

  .gallery-wrap {
    width: 100%;
    height: 28rem;
    margin-bottom: 0;
  }

  .gallery-section {
    width: 100%;
    height: 100%;
  }

  .images {
    display: flex;
    flex-direction: row;
    overflow-x: scroll;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 1rem;
    height: 16rem;
    padding-left: 1.5rem;
  }

  .images img {
    flex: 0 0 auto;
    height: 100%;
    width: auto;
    scroll-snap-align: center;
  }

  .images .spacer {
    display: none;
  }

  .gallery-footer {
    display: none;
  }

  /* --Screenings-- */

  .screenings {
    margin-top: 0;
  }

  .screening-head {
    height: 100%;
    width: 90%;
    box-shadow: none;
    padding-inline: 0;
  }

  .screening-wrap {
    width: 100%;
    height: auto;
    margin-top: 3rem;
  }

  .screening-wrap .spacer {
    display: none;
  }

  .screening-wrap::-webkit-scrollbar {
    height: 12px;
    width: 12px;
  }

  .screening-wrap::-webkit-scrollbar-track {
    background: var(--dark-back);
  }

  .screening-wrap::-webkit-scrollbar-thumb {
    background-color: var(--light-text);
    border-radius: 10px;
    border: 2px solid var(--dark-back);
  }

  .screening-list {
    display: flex;
    flex-direction: row;
    overflow-x: scroll;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 2rem;
    width: 100%;
    padding-inline: 8rem 5rem;
  }

  .screening {
    display: grid;
    grid-template-columns: 1fr 6fr;
    grid-template-rows: auto auto;
    grid-template-areas:
      "calendar text"
      "button text";
    gap: 0.5rem;
    align-items: start;
    width: auto;
    min-width: 350px;
    padding: 1rem;
    scroll-snap-align: center;
  }

  .screen-head {
    font-size: 1.75rem;
  }

  /* --Contact-- */

  .contact {
    align-items: center;
    height: auto;
    width: clamp(98vw, 100%, 99vw);
    padding-block: 12rem 15rem;
    text-align: center;
  }

  #contact-heading {
    width: 100%;
    font-size: 1rem;
    text-align: center;
  }

  .contact .grid-section {
    width: 100%;
    display: flex;
    flex-direction: column-reverse;
  }

  .contact .grid-item {
    width: 100%;
  }

  #contact-form {
    width: 100%;
    row-gap: 1rem;
    margin-inline: auto;
  }

  /* --Footer-- */

  footer {
    padding-inline: 1.5rem;
    margin: 3rem 0 8rem 0;
  }

  footer .foot-content {
    width: 100%;
  }

  .foot-right {
    width: 100%;
  }

  /* --Spacers-- */

  .spacer-slash-right,
  .spacer-slash-left {
    height: 5rem;
  }

  .spacer-steps {
    height: 1px;
  }

  .spacer-hills {
    display: none;
  }

  .wave-frame {
    height: 5rem;
  }

  /* --Modals-- */

  .modal .grid-section {
    display: flex;
    flex-direction: column;
    max-height: 80vh;
    width: auto;
    overflow-y: auto;
  }

  .modal-content {
    max-width: 100%;
  }

  .modal .grid-section::-webkit-scrollbar {
    width: 8px;
    margin-block: 1rem;
    border-radius: 4px;
  }
  .modal .grid-section::-webkit-scrollbar-thumb {
    background: var(--light-back);
    border-radius: 4px;
  }

  .modal-image img {
    width: 70%;
  }

  .modal-info.no-image {
    margin-inline: 0;
  }

  .modal .bio {
    max-height: unset;
    overflow: visible;
    padding-right: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
  }
}
