/* cmsms stylesheet: allsheets modified: 06/03/26 08:10:43 */
#topgarage {text-align: center; padding-top: 30px;}

#MOTIframe {
    border: 2px solid #9acb1f;
    display: block;
    margin: 0px auto;
    width: 800px;
    max-width: 100%;
    height: 1280px;
    -webkit-box-shadow: 5px 5px 5px 0px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 5px 5px 5px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 5px 5px 5px 0px rgba(0, 0, 0, 0.2);
}

#faqs h4 {
  cursor: pointer;
  background: #eee;
  padding: 10px;
  margin: 0;
  border-radius: 6px;
}
#faqs p {
  padding: 10px;
  margin: 0;
  background: #fafafa;
  border-left: 3px solid #ccc;
}
.faq-item + .faq-item {
  margin-top: 10px;
}

#bottomMenu {
  text-align: center;
  margin: 20px 0px;
}

#bottomMenu h3 {color: #ffffff;
font-size: 110%;
margin-bottom: 10px;}

#bottomMenu ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; /* Keeps orphan rows centred */
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 10px 30px; /* row gap, column gap */
}

#bottomMenu li {
  flex: 1 1 calc(20% - 30px); /* roughly 5 per row, accounting for gaps */
  max-width: 200px;
  min-width: 120px; /* keeps things from getting too squashed */
  text-align: center;
}

#bottomMenu a {
  display: inline-block;
  text-decoration: none;
  padding: 5px 0;
  transition: color 0.2s ease;
font-size: 80%;
}

#bottomMenu a:hover,
#bottomMenu a.menuactive {

}
/* cmsms stylesheet: pointST modified: 06/03/26 08:10:43 */
/* Utility classes */
    .container {
      margin-left: auto;
      margin-right: auto;
      padding: 0;
    }

    .section {
      padding: 20px 0;
    }

    .columns {
      display: flex;
      flex-wrap: wrap;
      gap: 20px;
    }

    .column {
      flex: 1;
      min-width: 280px;
    }

    /* Hero header (Step 1) */
    .hero {
      position: relative;
      width: 100%;
      height: 400px;
      background-image: url('uploads/Point%20S%20Tyres%20Brand%20Page%20Website%20Uploads/Point%20S%20Members%20Website%20Desktop%20Header%20Image%202500x1000.jpg');
      background-size: cover;
      background-position: center;
      display: flex;
      align-items: flex-end;
      justify-content: flex-start;
      color: #fff;
    }

    .hero-overlay {
      background: rgba(0, 0, 0, 0.4);
      width: 100%;
      padding: 1.5rem;
    }

    .hero h1 {
      color: #fff;
      font-size: 2rem;
    }

    /* Step 2 styles */
    .benefits {
      background-color: #213BA7;
      color: #fff;
      padding: 2rem;
    }

    .benefits ul {
      list-style: none;
      padding-left: 0;
    }

    .benefits li {
      margin-bottom: 0.5rem;
      padding-left: 1.2rem;
      position: relative;
    }

    .benefits li::before {
      content: '\2022'; /* bullet point */
      color: #fff;
      font-weight: bold;
      position: absolute;
      left: 0;
    }

    .eu-badge {
      margin-top: 1.5rem;
      width: 80px;
      height: auto;
    }

    /* Cards for Step 4 */
    .card-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
      gap: 2rem;
    }

    .card {
      text-align: center;
    }

    .card img {
      width: 100%;
      height: auto;
    }

    /* Ensure images in generic column layouts scale appropriately */
    /* Apply to all images except those labelled with the eu-badge class */
    .columns img:not(.eu-badge) {
      width: 100%;
      height: auto;
      display: block;
    }

    /* Videos (Step 5) */
    .video-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
      gap: 2rem;
    }

    .video-grid iframe {
      width: 100%;
      aspect-ratio: 16 / 9;
    }

    /* Two‑column layouts for Steps 6–9 */
    .content-with-image {
      display: flex;
      flex-wrap: wrap;
      gap: 2rem;
      align-items: center;
    }

    .content-with-image .text {
      flex: 1 1 300px;
    }

    .content-with-image .image {
      flex: 1 1 300px;
    }

    .content-with-image img {
      width: 100%;
      height: auto;
    }

    /* Footnote */
    .footnote {
      font-size: 0.85rem;
      color: #666;
      margin-top: 2rem;
    }

    /* About section */
    .about {
      background-color: #f7f7f7;
      padding: 3rem 1rem;
      text-align: center;
    }

    .about img {
      max-width: 200px;
      margin-bottom: 1rem;
    }

    @media (max-width: 768px) {
      .hero {
        height: 250px;
      }
    }
