/* -------------------- RESET / BASIC STYLES -------------------- */
body, a {
    margin: 0; 
    padding: 0;
    list-style: none;
    text-decoration: none;
    font-family: Arial, sans-serif;
    box-sizing: border-box;
}

html, body {
    max-width: 100%;
    overflow-x: hidden;
}
/* -------------------- MENU BASE -------------------- */
body {
    background-color: transparent;
    background-image: url("../imgs/bg.png");
    background-repeat: repeat;
}
a {
    color: #337ab7;
}
footer a:hover {
    text-decoration: underline;
}
.site-logo img {
    display: block;
    width: 100%;
}
.wrapper {
    display: block;
    width: 99%;
    max-width: 1200px;
    margin: 0 auto;
}
.border-wrapper {
    display: block;
    border: 2px solid #ccc;
    padding: 20px;
    margin-top: 10px;
    background-color: #000;
    color: #fff;
}
.smaller {
  font-size: smaller;
}

/* -------------------- SCHEDULE ROW -------------------- */
.schedule-row {
    display: flex;
    width: 100%;
    border: 2px solid #ccc;
    padding: 20px;
    flex-wrap: wrap;
    box-sizing: border-box;
    background-color: #000;
    color: #fff;
    margin: 10px 0;
}

/* LEFT COLUMN */
.schedule-date {
    width: 44%;
    padding-right: 10px;
    box-sizing: border-box;
}

.schedule-date .day {
    font-size: 2em;
}

/* RIGHT COLUMN */
.schedule-info {
    width: 55%;
    box-sizing: border-box;
    text-align: right;
}

.schedule-info .venue {
    font-size: 2em;
}

.schedule-info .links a {
    display: inline-block;
    margin: 6px 0;
    color: #337ab7;
    text-decoration: none;
}

/* -------------------- TIME -------------------- */
.schedule-time {
    margin-top: 6px;
    /* display: flex; */
    gap: 6px;
}

/* -------------------- FILM CARD -------------------- */
.film-card {
    position: relative;
    display: block;
    width: 100%;
    padding: 20px;
    border: 2px solid #ccc;
    box-sizing: border-box;
    background-color: #000;
    color: #fff;
    overflow: auto;
    margin-bottom: 10px;
}

/* TIME (top right) */
.film-time {
    position: absolute;
    top: 25px;
    right: 20px;
    font-size: 1.6em;
    color: #1C6EA8;
}
/* POSTER */
.film-poster {
  width: 25%;
  float: left;
}

.film-poster img {
  width: 100%;
  height: auto;
  display: block;
  max-width: 240px;
}

/* INFO */
.film-info {
    width: 74%;
    float: right;
}

.film-title {
    margin: 0 0 6px;
    font-size: 1.4em;
    float: right;
    width: 74%;
    line-height: 1;
}
.film-title .country {
  font-size: 16px;
  font-weight: normal;
  margin-left: 6px;
}

.film-card .smaller {
    font-size: 14px;
}

/* META */
.film-meta {
  margin-bottom: 10px;
}
.director {
    font-size: 1.3em;
    color: #aaa;
    margin: 12px 0 5px;
}
.program {
    font-weight: bold;
    color: #aaa;
    text-transform: uppercase;
    margin: 15px 0;
}

/* DESCRIPTION */
.film-description {
  margin: 10px 0 15px;
  line-height: 1.5;
}
.film-description p {
  margin-bottom: 10px;
}
.premiere {
    color: #aaa;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* BOTTOM ROW */
.film-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.film-social {
    display: flex;
    gap: 10px;
    align-items: center;
    padding: 0;
    margin: 25px 0;
    list-style: none;
    width: 100%;
}
.film-social li {
  display: inline-flex;
}
/* Shared button style */
.film-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5em;
  color: #fff;
  text-decoration: none;
  background-color: #333;
  border-radius: 10px;
  width: 45px;
  height: 45px;
  transition: opacity 0.2s ease;
}

/* Platform colors */
.film-social .fb a {
  background-color: #2d4373;
}
.film-social .x a {
  background-color: #55acee;
}
.film-social .insta a {
  background-color: #3f729b;
}

/* Eventbrite logo tweak */
.film-social .eventbrite a {
  background-color: #000;
  width: 150px;
}
.film-social .eventbrite img {
    width: 100%;
    height: auto;
}
.film-social a:hover {
  opacity: 0.75;
}
.film-extra {
    text-align: right;
    font-size: 1.4em;
    width: 100%;
}
p.film-rating {
    font-size: .8em;
    line-height: 2;
    color: #bbb;
}
.film-date {
    color: #1C6EA8;
}
.movie-award {
    color: #0d9bff;
    font-weight: bold;
    letter-spacing: .5px;
    margin-top: 0;
}

/* -------------------- FOOTER -------------------- */
footer {
    display: block;
    width: 100%;
    max-width: 1200px;
    margin: 10px auto 0;
    border: 2px solid #ccc;
    text-align: center;
    color: #fff;
    background-color: #000;
    padding-bottom: 20px;
    padding-top: 20px;
}
footer h3 {
    font-size: 2em;
}
.footer-para p {
  margin-bottom: 10px;
  line-height: 1.3;
}

/* -------------------- A-Z PAGE -------------------- */
.az-list {
    display: flex;
    gap: 20px;
    background-color: #000;
    border: 2px solid #ccc;
    padding: 20px;
    margin-top: 10px;
    box-sizing: border-box;
    flex-wrap: wrap; /* ← ADD THIS */
}
.az-list ul {
    flex: 1;
    min-width: 0;
    padding: 0;
    margin: 0;
    list-style: disc;
    padding-left: 10px;
    color: #444;
}
.az-list ul a:hover {
    text-decoration: underline;t
}
li.letter
 {
    display: block;
    padding: 10px 0;
    color: #989898;
    font-weight: bold;
    letter-spacing: .5px;
    font-size: 14px;
}

/* -------------------- TICKET INFO -------------------- */
.ticket-info {
    background-color: #000;
    border: 2px solid #ccc;
    padding: 20px;
    color: #fff;
    margin-top: 10px;
}
.text-center {
    text-align: center;
}
.ticket-warning {
    color: #FF0000;
    font-size: 20px;
}
.award-name {
    color: #1c6ea8;
}
.italic {
    font-style: italic !important;
}
.ticket-info .floatleft {
    float: left;
    width: 100%;
    max-width: 390px;
    padding: 0 20px 20px 0;
}
.underline {
    text-decoration: underline;
}
.checkin-process {
    display: block;
    clear: both;
    padding: 20px;
}
.checkin-process li {
    margin-left: 0;
    margin-bottom: 10px;
}

/* -------------------- AWARDS PAGE -------------------- */
.awards-info {
    background-color: #000;
    border: 2px solid #ccc;
    padding: 20px 50px;
    color: #fff;
    margin-top: 10px;
    text-align: center;
}
/* OUTER WRAPPER */
.laurels-wrapper {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

/* GROUP = A ROW */
.laurel-group {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
  min-width: 0; /* CRITICAL */
}

/* ITEM WRAPPER */
.laurel-item {
  display: flex;
  justify-content: center; /* horizontal centering */
}

/* IMAGE FIX */
.laurel-item img {
  width: 100%;
  height: auto;
  display: block;
  max-width: 450px;
}

/* LAYOUT TYPES */
.one-up .laurel-item {
  flex: 0 1 60%;
  margin: 0 auto;
}

.two-up .laurel-item {
  flex: 0 1 50%;
}
.two-up {
  max-width: 82%;   /* closes the gap without looking squeezed */
  margin: 0 auto;
  gap: 16px;
}

.three-up .laurel-item {
  flex: 0 1 33.333%;
}

/* -------------------- Promenade PAGE -------------------- */
.fourty-sixty {
  display: flex;
  gap: 20px;          /* space between left and right */
  flex-wrap: wrap;     /* stack on smaller screens */
}

.fourty {
  flex: 2;   /* 2 parts */
}

.sixty {
  flex: 3;   /* 3 parts */
}

.fourty img {
  width: 100%;
  height: auto;
  display: block;
}

.bottom-info {
    font-size: 12px;
    width: 100%;
    margin: 0;
}

@media (max-width: 1098px) {
  .film-poster img {
      max-width: 200px;
  }
}

@media (max-width: 960px) {
  .film-time {
      position: relative;
      display: block;
      width: 74%;
      top: 0;
      right: 0;
      float: right;
  }

  .film-poster img {
      max-width: 160px;
  }
}


@media (max-width: 768px) {

/* -------------------- SCHEDULE ROW -------------------- */
    .schedule-date {
        margin-bottom: 5px;
        font-weight: bold;
    }

    .schedule-date, .schedule-info {
        width: 100%;
        text-align: left;
    } 
    .schedule-time {
        flex-direction: column;
        gap: 2px;
    }
    .schedule-info .venue {
        font-size: 22px;
        margin-bottom: 5px;
    }
    .schedule-time {
        font-size: 14px;
    }
    .schedule-date .day {
        font-size: 1.4em;
    }
    
    footer {
        width: 99%;
        padding: 5%;
    }
    .footer-date span {
      display: block;
      margin-bottom: 4px;
    }
    /* -------------------- FILM CARD  -------------------- */
    .film-title, .film-poster, .film-info {
      width: 100%;
    }
    .film-poster {
      margin: 10px 0 20px;
    }
    .film-poster img {
      max-width: 220px;
    }
    .film-time {
        position: relative;
        display: block;
        width: 100%;
        top: 0;
        right: 0;
        float: left;
    }
    .film-social {
        flex-wrap: wrap;
        gap: 12px;
    }
    .film-social .eventbrite {
        width: 100%;
    }
    .film-social .eventbrite a {
        width: 230px;
        margin: 20px 0;
    }
    .film-social a {
        width: 50px;
        height: 50px;
        font-size: 1.7em;
    }
    .film-extra {
        text-align: left;
    }
    .film-extra p {
      margin: 10px 0;
    }
    

    /* -------------------- A-Z PAGE -------------------- */
    .az-list ul {
        flex: 0 0 50%;   /* 2 columns */
    }
    /* -------------------- AWARDS PAGE -------------------- */
    .laurel-group {
        flex-direction: column;
    }

  .one-up .laurel-item,
  .two-up .laurel-item,
  .three-up .laurel-item {
        flex: 0 0 100%;
    }

  .fourty, .sixty {
        flex: 0 0 100%;
      }
    }

}







