:root {
  --clr-teal: #205c69;
  --clr-offwhite-dark: #f9f9fa;
  interpolate-size: allow-keywords;
}

@font-face {
  font-display: swap;
  font-family: "Roboto";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/roboto-v48-latin-regular.woff2") format("woff2");
}

@font-face {
  font-display: swap;
  font-family: "Roboto";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/roboto-v48-latin-500.woff2") format("woff2");
}

@font-face {
  font-display: swap;
  font-family: "Roboto";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/roboto-v48-latin-600.woff2") format("woff2");
}

@font-face {
  font-display: swap;
  font-family: "Roboto";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/roboto-v48-latin-700.woff2") format("woff2");
}

body {
  animation-duration: 0.75s;
  animation-fill-mode: both;
  animation-name: fadeIn;
  transition-timing-function: ease-in;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    display: block;
  }
}

.fadeIn {
  opacity: 0;
}

p {
  text-wrap: pretty;
}

a.link {
  border-radius: 4px;
  color: var(--clr-aubergine);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
  text-underline-offset: 5px;
  transition: all 0.25s ease-in-out;

  &:is(:hover, :active) {
    text-decoration-color: var(--clr-aubergine);
  }

  &:is(:not(:active):focus-visible) {
    outline: 2px solid var(--clr-aubergine);
    outline-offset: max(3px, 0.08em);
    text-decoration: none;
  }
}

a.link-teal {
  color: var(--clr-steelx2);

  &:is(:hover, :active) {
    text-decoration-color: var(--clr-steelx2);
  }
}

a.link-light {
  color: var(--clr-light);

  &:is(:hover, :active) {
    text-decoration-color: var(--clr-light);
  }

  &:is(:not(:active):focus-visible) {
    outline: 2px solid var(--clr-light);
  }
}

:is(header .logo, .fr-link a):focus-visible {
  border-radius: 2px;
  outline: 2px solid var(--clr-aubergine);
  outline-offset: max(3px, 0.08em);
  transition: all 0.25s ease-in-out;
}

.header {
  background-color: var(--clr-light);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.07);
  position: fixed;
  top: 0;
  left: 0;
  inline-size: 100%;
  z-index: 4;

  .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    block-size: 110px;
    padding-inline: clamp(20px, 3vw, 48px);

    @media only screen and (max-width: 767px) {
      block-size: 90px;
    }

    @media only screen and (max-width: 399px) {
      padding-inline: clamp(16px, 3vw, 48px);
    }
  }

  .logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    font-size: 15px; 
    line-height: normal;

    @media only screen and (max-width: 767px) {
      font-size: 12px;
      gap: 8px;
    }

    .top {
      display: flex; 
      gap: 12px;

      @media only screen and (max-width: 767px) {
        gap: 0;
      }

      .en-txt {
        margin-inline-start: 12px; 
        inline-size: clamp(120px, 120px, 120px);

        @media only screen and (max-width: 767px) {
          margin-inline-start: 16px;
        }
      }

      .fr-txt {
        inline-size: clamp(150px, 150px, 150px);

        @media only screen and (max-width: 767px) {
          margin-inline-start: -14px;
          inline-size: clamp(130px, 130px, 130px);
        }
      }
    }

    .bottom {
      background-color: var(--clr-aubergine); 
      color: var(--clr-light); 
      font-size: 13px; 
      line-height: 2.4; 
      text-align: center; 
      inline-size: 100%;

      @media only screen and (max-width: 767px) {
        font-size: 11px;
      }
    }

    img {
      block-size: 30px;
      inline-size: auto;

      @media only screen and (max-width: 767px) {
        block-size: 25px;
      }
    }
  }

  .toggle-container {
    display: flex;
    align-items: center;
    gap: 18px;
  }

  @media only screen and (max-width: 830px) {
    .learner-employer-container {
      background-color: var(--clr-light);
      box-shadow: inset -2px 10px 8px -8px rgba(0, 0, 0, 0.07);
      opacity: 0;
      position: fixed;
      left: 0;
      top: 90px;
      visibility: hidden;
      transition: all 0.25s ease-in-out;
      inline-size: 100%;
    }
  }

  @media only screen and (max-width: 767px) {
    .learner-employer-container {
      top: 60px;
    }
  }

  .btn-container {
    display: flex;
    gap: 12px;

    @media only screen and (max-width: 830px) {
      display: flex;
      justify-content: center;
      align-items: center;
      padding-block: 16px;
      padding-inline: clamp(20px, 3vw, 56px);
    }

    @media only screen and (max-width: 460px) {
      &:lang(fr) {
        flex-wrap: wrap;
      }
    }

    @media only screen and (max-width: 370px) {
      flex-wrap: wrap;
    }

    .mat-flat-button.mat-accent,
    .mat-flat-button.mat-light {
      border-radius: 6px;
      font-size: 15px;
      font-weight: 600;
      line-height: 24px;
      min-block-size: 52px;
      min-inline-size: 180px;
      padding: 14px 24px;
      text-align: center;
      white-space: nowrap;

      @media only screen and (max-width: 830px) {
        font-size: 14px;
        min-inline-size: auto;
        inline-size: 100%;
      }
    }

    .mat-flat-button.mat-light {
      background-color: var(--clr-gray-200);
      color: var(--clr-aubergine);

      &:hover {
        background-color: var(--clr-gray-300);
       color: var(--clr-aubergine);
      }
    }

    .mat-flat-button.mat-accent,
    .mat-flat-button.active {
      background-color: var(--clr-steelx2);
      color: var(--clr-light);

      &:hover {
        background-color: #35575f;
        color: var(--clr-light);
      }
    }
  }

  .global-icon {
    color: var(--clr-aubergine);
    block-size: 18px;
    position: relative;

    @media only screen and (max-width: 767px) {
      top: -0.05em;
    }

    @media only screen and (max-width: 429px) {
      display: none;
    }

    svg {
      vertical-align: initial;
    }
  }

  .fr-link a {
    color: var(--clr-aubergine);
    font-size: clamp(19px, 3vw, 24px);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-decoration: underline;
    text-decoration-color: transparent;
    text-transform: uppercase;
    text-underline-offset: 5px;
    transition: all 0.25s ease-in-out;

    &:is(:hover, :active) {
      text-decoration-color: var(--clr-aubergine);
    }

    &:is(:not(:active):focus-visible) {
      text-decoration: none;
    }
  }
}

.header .search-input-container {
  opacity: 0;
  visibility: hidden;
  transition: all 0.25s ease-in-out;
  inline-size: 100%;

  @media only screen and (max-width: 1199px) {
    background-color: var(--clr-light);
    box-shadow: inset -2px 10px 8px -8px rgba(0, 0, 0, 0.07);
    position: fixed;
    left: 0;
    top: 110px;
    z-index: 1;
  }

  @media only screen and (max-width: 767px) {
    top: 90px;
  }

  form {
    padding-inline: clamp(20px, 3vw, 56px);
    position: relative;

    @media only screen and (max-width: 1199px) {
      padding-block: 14px;
    }
  }

  .search {
    position: relative;

    svg {
      position: absolute;
      left: 16px;
      top: 18px;

      @media only screen and (max-width: 767px) {
        left: 14px;
        block-size: 20px;
        inline-size: 20px;
      }
    }
  }

  input[type="search"] {
    border: 1px solid var(--clr-aubergine25);
    border-radius: 6px;
    box-shadow: 0 0 0 1px transparent;
    color: var(--clr-aubergine);
    display: block;
    font-size: 18px;
    line-height: normal;
    min-block-size: 60px;
    outline: none;
    padding-block: 12px;
    padding-inline: 52px 14px;
    transition: background-color ease-in-out .25s, border-color ease-in-out .25s;
    inline-size: 100%;
  }

  input[type="search"]::placeholder {
    color: var(--clr-aubergine50);
    opacity: 1;
    transition: color .25s ease-in-out;
  }

  input[type="search"]:focus {
    border-color: var(--clr-aubergine);
    box-shadow: 0 0 0 1px var(--clr-aubergine);
  }

  input[type="search"]:focus::placeholder {
    color: var(--clr-aubergine25);
  }

  @media only screen and (max-width: 767px) {
    input[type="search"] {
      font-size: 15px;
      min-block-size: 54px;
      padding-inline: 44px 14px;
    }
  }
}

.header.show .search-input-container,
.header.show .learner-employer-container {
  opacity: 1;
  visibility: visible;
}

.header.hide .search-input-container {
  opacity: 0;
  visibility: hidden;
}

@media only screen and (max-width: 1199px) {
  .header.mobile-hide .search-input-container,
  .header.mobile-hide .learner-employer-container {
    opacity: 0;
    visibility: hidden;
  }
}

@media only screen and (max-width: 767px) {
  .header.hide .learner-employer-container,
  .header.mobile-hide .learner-employer-container {
    opacity: 0;
    visibility: hidden;
  }
}

.header.header-static {
  position: relative;
  z-index: 2;

  @media only screen and (max-width: 830px) {
    &.show {
      z-index: 4;
    }

    .learner-employer-container {
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.07);
      min-block-size: 90px;
      top: 0;
    }
  }

  @media only screen and (max-width: 767px) {
    .learner-employer-container {
      min-block-size: auto;
    }
  }
}

.header.header-z-index {
  z-index: 3;
}

/* Landing page */

.hero-landingpage-container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-block: 110px 32px;
  padding-inline-start: clamp(24px, 6vw, 200px);

  @media only screen and (max-width: 1399px) {
    padding-inline-start: clamp(24px, 4vw, 200px);
    padding-inline-end: clamp(24px, 3vw, 48px);
  }

  @media only screen and (max-width: 1199px) {
    grid-template-columns: 1fr;
    gap: 0;
  }

  @media only screen and (max-width: 767px) {
    margin-block: 90px 48px;
  }

  .left-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-block-start: clamp(48px, 4vw, 120px);
    padding-block-end: 32px;

    @media only screen and (max-width: 767px) {
      padding-block-end: 24px;
     }

    h1, h2 {
      line-height: normal;
      text-wrap: balance;
    }

    h1 {
      font-size: clamp(44px, 6vw, 56px);
    }

    h2 {
      color: #35575f;
      font-size: clamp(26px, 4vw, 38px);
      line-height: 1.25;
      margin-block-end: 4px;
    }

    p {
      font-size: clamp(16px, 4vw, 18px);
      margin-block-end: 0;
      max-width: 75ch;
    }

    .search-container,
    .industries-link {
      a.link {
        cursor: pointer;
        display: inline-block;
        outline: none;
        text-decoration: underline;
        text-decoration-color: transparent;
        text-wrap: pretty;

        &:hover,
        &:focus-visible {
          text-decoration-color: var(--clr-aubergine);
        }

        &:focus-visible {
          text-decoration-thickness: 2px;
        }

        svg {
          position: relative;
          top: -.05em;
        }
      }
    }

    .industries-link {
      margin-block-start: -4px;
    }
  }

  .right-content {
    background-image: url(../images/NationalPortal-Main-Banner.webp);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    block-size: 82vh;

    @media only screen and (max-width: 1199px) {
      display: none;
    }

    @media only screen and (max-width: 767px) {
      display: block;
      block-size: 500px;
    }

    @media only screen and (max-width: 499px) {
      block-size: 400px;
    }

    @media only screen and (max-width: 399px) {
      block-size: 350px;
    }
  }
}

.hero-employer .search-container {
  margin-block-start: 8px;
}

.carousel-container {
  background-color: var(--clr-aubergine);
  overflow: hidden;
  position: relative;
  block-size: 100px;
  inline-size: 100%;
}

.carousel-slides-container {
  block-size: 100px;
  padding: 0 80px;
}

.slides-container {
  display: flex;
  align-items: center;
  block-size: 100%;
  list-style: none;
  margin: 0;
  overflow: hidden;
  padding: 0;
  scroll-behavior: smooth;
  inline-size: 100%;
}

.slide-arrow {
  background: none;
  border: 1px solid var(--clr-aubergine50);
  border-radius: 100px;
  color: var(--clr-light);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  outline: none;
  padding: 0;
  position: absolute;
  top: 0;
  bottom: 0;
  block-size: 48px;
  inline-size: 48px;
  transition: all 0.25s ease-in-out;

  @media only screen and (max-width: 899px) {
    block-size: 40px;
    inline-size: 40px;

    svg {
      block-size: 32px;
      inline-size: 32px;
    }
  }
}

.slide-arrow:hover,
.slide-arrow:focus-visible {
  border-color: var(--clr-light);
}

#slide-arrow-prev {
  left: 16px;
}

#slide-arrow-next {
  right: 16px;
}

.slide {
  display: flex;
  align-items: center;
  justify-content: center;
  block-size: 100%;
  margin: 0;
  flex: 1 0 16.6666%;
  inline-size: 16.6666%;

  @media only screen and (max-width: 1399px) {
    flex: 1 0 20%;
    inline-size: 20%;
  }

  @media only screen and (max-width: 1099px) {
    flex: 1 0 25%;
    inline-size: 25%;
  }

  @media only screen and (max-width: 899px) {
    flex: 1 0 33.3333%;
    inline-size: 33.3333%;
  }

  @media only screen and (max-width: 767px) {
    flex: 1 0 50%;
    inline-size: 50%;
  }

  @media only screen and (max-width: 499px) {
    flex: 1 0 100%;
    inline-size: 100%;
  }
}

.slide img {
  max-block-size: 60px;
  max-inline-size: 160px;
  object-fit: contain;
}

h4 {
  font-size: 20px;
  line-height: 1.3;
}

.section-subtitle {
  color: var(--clr-steelx2);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-wrap: balance;
}

.section-title {
  color: var(--clr-aubergine);
  display: inline-block;
  font-size: clamp(28px, 4vw, 32px);
  line-height: 1.35;
  text-wrap: balance;
}

.upskills-container,
.benefits-container,
.industries-search-container,
.faq-container,
.contact-container {
  padding-inline: clamp(24px, 12vw, 220px);

  @media only screen and (max-width: 1599px) {
    padding-inline: clamp(24px, 5vw, 220px);
  }
}

.upskills-container {
  background-color: var(--clr-offwhite-dark);
  display: grid;
  gap: clamp(44px, 5vw, 64px);
  padding-block-start: clamp(48px, 8vw, 72px);
  padding-block-end: clamp(56px, 12vw, 88px);

  @media only screen and (max-width: 1699px) {
    padding-inline: clamp(24px, 8vw, 220px);
  }

  .upskills-top,
  .upskills-bottom {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
    gap: clamp(48px, 4vw, 64px);

    @media only screen and (max-width: 1099px) {
      grid-template-columns: 1fr;
    }

    img {
      block-size: auto;
      max-inline-size: fit-content;
      inline-size: 100%;

      @media only screen and (max-width: 599px) {
        max-inline-size: 100%;
      }
    }
  }

  .upskills-bottom {
    @media only screen and (max-width: 1099px) {
      display: flex;
      flex-direction: column-reverse;
    }
  }

  .content-container {
    display: flex;
    flex-direction: column;
    gap: 24px;

    h2 {
      color: var(--clr-aubergine);
      font-size: clamp(26px, 4vw, 38px);
      line-height: 1.35;
      text-wrap: balance;
    }

    .subtitle {
      font-size: 20px;
      margin-block-end: 4px;
    }

    p {
      margin-block-end: 0;
    }
  }
}

.benefits-container {
  background-color: var(--clr-light);
  display: grid;
  gap: 16px;
  padding-block-start: clamp(48px, 8vw, 72px);
  padding-block-end: clamp(48px, 12vw, 88px);
  text-align: center;

  .three-columns {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px 48px;
    padding-block-start: clamp(32px, 4vw, 56px);

    @media only screen and (max-width: 991px) {
      grid-template-columns: 1fr;
    }
  }

  .benefit {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    text-align: left;

    h4, p {
      margin-block-end: 0;
      max-inline-size: clamp(100%, 32vw, 48ch);
      padding-inline-start: 16px;
    }
  }
}

.industries-search-container {
  background-color: var(--clr-offwhite-dark);
  padding-block-start: clamp(44px, 8vw, 64px);
  padding-block-end: clamp(64px, 12vw, 88px);
  scroll-margin-block-start: 80px;
  text-align: center;

  @media only screen and (max-width: 1199px) {
    scroll-margin-block-start: 140px;
  }

  @media only screen and (max-width: 830px) {
    scroll-margin-block-start: 200px;
  }

  .sub-title {
    margin-block: clamp(16px, 4vw, 24px) clamp(32px, 6vw, 56px);
  }

  .industries-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 1fr;
    gap: 32px;

    @media only screen and (max-width: 1199px) {
      grid-template-columns: repeat(3, 1fr);
    }

    @media only screen and (max-width: 991px) {
      grid-template-columns: repeat(2, 1fr);
    }

    @media only screen and (max-width: 650px) {
      grid-template-columns: 1fr;
      grid-auto-rows: auto;
    }
  }

  .industry-container {
    background-color: rgba(255, 255, 255, 0.8);
    border: 1px solid var(--clr-gray-400);
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    text-decoration: none;
    transition: all 0.25s ease-in-out;

    &:hover {
      border: 1px solid var(--clr-aubergine);
      box-shadow: 0 0 0 1px var(--clr-aubergine), 0 4px 8px rgba(0, 0, 0, 0.07);
    }

    &:focus-visible {
      outline: 2px solid var(--clr-aubergine);
      outline-offset: max(3px, 0.08em);
    }
  }

  .title-img-container {
    display: grid;
    grid-template-columns: clamp(250px, 12vw, 300px) 1fr;
    flex: 1;

    @media only screen and (max-width: 1199px) {
      display: flex;
      flex-direction: column;
      padding-block-end: 4px;
    }

    .bg-image {
      aspect-ratio: 16 / 9;
      background-position: center;
      background-size: cover;
      border-radius: 6px 0 0 6px;
      inline-size: 100%;

      @media only screen and (max-width: 1199px) {
        border-radius: 6px 6px 0 0;
        max-block-size: 42vw;
      }
    }
  }

  .img-container {
    display: flex;
    inline-size: 100%;
  }

  .content-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    flex: 1;
    gap: 24px;
    padding: 24px 24px 32px;
  }

  .title {
    color: var(--clr-aubergine);
    font-size: clamp(20px, 4vw, 22px);
    font-weight: 600;
    line-height: normal;
    padding-inline: 16px;
    text-wrap: balance;
  }

  .mat-flat-button {
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    block-size: 48px;
    line-height: normal;
    min-inline-size: 200px;

    svg {
      margin-inline-end: -8px;
      position: relative;
      top: -0.02em;
    }
  }
}

.faq-container {
  background-color: var(--clr-light);
  display: grid;
  gap: clamp(44px, 8vw, 48px);
  padding-block: clamp(44px, 8vw, 64px);
  text-align: center;

  .faqs {
    display: grid;
    gap: 16px;
  }

  details {
    background-color: var(--clr-light);
    border: 1px solid var(--clr-aubergine25);
    border-radius: 8px;
    box-shadow: 0 0 0 2px transparent;
    text-align: left;
    transition: all 0.25s ease-in-out;

    &:is(:hover, :focus-within) {
      border-color: transparent;
      box-shadow: 0 0 0 2px var(--clr-aubergine);
    }
  }

  details[open] {
    box-shadow: 0 0 0 2px transparent;

    &:is(:hover, :focus-within) {
      background-color: var(--clr-light);
      border-color: transparent;
      box-shadow: 0 0 0 2px var(--clr-aubergine);
    }
  }

  details::details-content {
    block-size: 0;
    overflow: hidden;
    transition: block-size 0.3s ease-in-out, content-visibility 0.3s ease-in-out;
    transition-behavior: allow-discrete;
  }

  details[open]::details-content {
    block-size: auto;
  }

  summary {
    color: var(--clr-aubergine);
    cursor: pointer;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    font-size: clamp(19px, 4vw, 20px);
    font-weight: 700;
    line-height: 1.45;
    list-style: none;
    outline: transparent;
    padding-block: clamp(20px, 4vw, 24px);
    padding-inline: clamp(20px, 4vw, 24px) 60px;
    position: relative;
    text-wrap: pretty;
    transition: color 0.25s ease-in-out;

    &::after {
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgb(30, 26, 52)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
      background-position: right center;
      background-size: clamp(22px, 4vw, 24px) auto;
      background-repeat: no-repeat;
      content: "";
      display: block;
      block-size: clamp(22px, 4vw, 24px);
      position: absolute;
      right: clamp(14px, 3vw, 18px);
      transform: rotate(-90deg);
      transition: transform 0.25s ease-in-out;
      inline-size: clamp(22px, 4vw, 24px);
    }
  }

  details[open] > summary:after {
    transform: rotate(0);
  }

  .details-content {
    display: grid;
    padding-block: 0 24px;
    padding-inline: 24px;

    p {
      margin-block-end: 0;
      padding-block-end: 12px;

      &:last-child {
        padding-block-end: 0;
      }
    }

    strong {
      color: var(--clr-aubergine);
    }

    ul {
      display: grid;
      gap: 8px;
      line-height: 1.55;
      margin: 8px 0 16px;
      padding-inline-start: 18px;
    }
  }

  .email-txt {
    font-size: 18px;

    span {
      margin-inline-end: 0.5ch;
    }
  }
}

.contact-container {
  background-color: var(--clr-tangerine);
  display: flex;
  justify-content: center;
  align-items: center;
  padding-block: clamp(48px, 8vw, 64px);
  text-align: left;

  p {
    color: var(--clr-aubergine);
    font-size: clamp(20px, 3vw, 24px);
    margin-block-end: 0;
    max-inline-size: 90ch;
  }
}

footer {
  background-color: var(--clr-aubergine);
  color: var(--clr-light);
  padding-block: 40px;

  .logo-container,
  .bottom-content {
    font-size: 15px;
    padding-inline: clamp(24px, 5vw, 64px);
    text-wrap: pretty;
  }

  .logo-container {
    justify-content: space-between;

    .left-col {
      gap: 80px;

      @media only screen and (max-width: 991px) {
        gap: 24px;
      }

      p {
        margin-block-end: 0;
      }

      .logo img {
        block-size: auto;
      }

      #dclogo {
        &:lang(fr) {
          inline-size: 280px;
        }
      }

      .logos {
        align-items: center;
        display: flex;
        gap: 24px;
        padding-block-start: 16px;
      }

      .logos .divider {
        block-size: 56px;
        margin: 0;
        position: relative;
        top: -2px;
        inline-size: 1px;
      }

      @media only screen and (max-width: 540px) {
        .logos {
          align-items: flex-start;
          flex-direction: column;
          margin-block-end: 4px;
        }

        .logos .divider {
          display: none;
        }
      }

      .text {
        padding-block-start: 14px;
      }
    }
  }

  .logo-container,
  .left-col {
    display: flex;
    align-items: center;

    @media only screen and (max-width: 991px) {
      align-items: flex-start;
      flex-direction: column;
    }
  }

  .divider {
    background-color: var(--clr-aubergine75);
    display: block;
    block-size: 1px;
    margin-block: 40px;
    inline-size: 100%;
  }

  .bottom-content {
    color: var(--clr-light);
    display: flex;
    justify-content: space-between;
    gap: 24px;
    text-wrap: balance;

    @media only screen and (max-width: 991px) {
      flex-direction: column-reverse;
    }

    .copyright, a {
      font-size: 14px;
      font-weight: 400;
    }
  }
}

/* MC Search */

.entry-title-container {
  background-color: var(--clr-tangerine);
  margin-block-start: 110px;
  padding: 72px 24px;
  text-align: center;

  @media only screen and (max-width: 767px) {
    margin-block-start: 90px;
    padding: 56px 24px;
  }

  h1.entry-title {
    color: var(--clr-aubergine);
    font-weight: 600;
    font-style: normal;
    font-size: clamp(38px, 6vw, 48px);
    line-height: normal;
    margin: 0 0 4px;
    text-wrap: balance;
  }
}

.ol-item-search-container {
  margin: 0 auto;
  max-inline-size: 1080px;
  padding-block: 64px 96px;

  @media only screen and (max-width: 1250px) {
    padding-inline: clamp(24px, 6vw, 48px);
  }

  @media only screen and (max-width: 991px) {
    padding-block: 48px 80px;
  }
}

/* Error Pages */

.error-container {
  margin: 0 auto;
  max-inline-size: 1080px;
  padding-block: clamp(24px, 4vw, 64px);
  padding-inline: clamp(24px, 4vw, 64px);

  h1 {
    font-size: 68px;
    line-height: 1.35;
    margin-block-end: 8px;
  }

  h2 {
    font-size: 30px;
    line-height: 1.35;
    margin-block-end: 16px;
    text-wrap: balance;
  }

  .back-btn {
    line-height: 1.25;
    margin-block: 32px;
    padding: 20px 36px;

    @media only screen and (max-width: 499px) {
      inline-size: 100%;
    }
  }
}

/* AI Fundamentals Banner Section */

.ai-banner-container {
  padding: clamp(40px, 6vw, 80px) clamp(24px, 5vw, 64px);
  padding-block-end: 0;
}

.explore-more {
  display: flex;
  justify-content: center;
  padding-block: 32px 48px;
}

.ai-banner-content {
  background-color: var(--clr-aubergine5);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(20px, 4vw, 40px);
  align-items: center;
  margin-inline: auto;
  max-inline-size: 1440px;

  @media only screen and (max-width: 991px) {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

.ai-banner-image {
  block-size: 100%;

  img {
    block-size: 100%;
    inline-size: 100%;
    object-fit: cover;
  }

  @media only screen and (max-width: 991px) {
    order: 2;
    min-block-size: 400px;
  }
}

.ai-banner-text {
  color: var(--clr-aubergine);
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 56px 32px;

  @media only screen and (max-width: 991px) {
    order: 1;
    padding: 48px 32px;
  }
}

.ai-badge {
  background-color: #fbe9c1;
  border-radius: 20px;
  color: var(--clr-aubergine);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .035em;
  padding: 10px 20px;
  text-transform: uppercase;
  inline-size: fit-content;
}

.ai-banner-text h2 {
  color: var(--clr-aubergine);
  font-size: clamp(24px, 4vw, 36px);
  font-weight: 700;
  line-height: 1.2;
}

.ai-banner-text p {
  color: var(--clr-aubergine);
  font-size: clamp(16px, 2.5vw, 18px);
  margin-block-end: 8px;
}

.ai-banner-text .mat-flat-button {
  display: flex;
  align-items: center;
  align-self: flex-start;
}

.ai-banner-link {
  color: var(--clr-teal);
  text-decoration: underline;
  text-decoration-color: var(--clr-teal);
  text-decoration-color: var(--clr-gray-400);
  text-decoration-thickness: 2px;
  text-underline-offset: 7px;
  transition: all .25s ease-in-out;

  &:is(:hover, :focus) {
    color: var(--clr-teal);
    text-decoration-color: var(--clr-teal);
  }

  &:focus-visible {
    border-radius: 2px;
    outline: 2px solid var(--clr-teal);
    outline-offset: 3px;
  }
}

/* AI Fundamentals Page Styles */

.ai-hero-section {
  background-color: #fbe9c1;
  margin-block-start: 110px;
  padding: clamp(40px, 6vw, 64px) clamp(24px, 5vw, 64px);

  @media only screen and (max-width: 767px) {
    margin-block-start: 90px;
  }
}

.ai-hero-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
  max-inline-size: 1200px;
  margin-inline: auto;

  @media only screen and (max-width: 991px) {
    grid-template-columns: 1fr;
    gap: 36px;
    text-align: center;
  }
}

.ai-hero-text h1 {
  font-size: clamp(32px, 4.5vw, 48px);
  line-height: 1.2;
}

.ai-hero-image {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  position: relative;

  @media only screen and (max-width: 991px) {
    justify-content: center;
  }

  picture {
    max-inline-size: 400px;

    @media only screen and (max-width: 991px) {
      max-inline-size: 350px;
    }

    @media only screen and (max-width: 767px) {
      max-inline-size: 300px;
    }
  }

  img {
    block-size: auto;
    inline-size: 100%;
  }
}

/* AI Details Section */

.ai-details-section {
  background-color: var(--clr-light);
  padding: clamp(48px, 8vw, 80px) clamp(24px, 5vw, 64px);
}

.ai-details-container {
  max-inline-size: 1440px;
  margin-inline: auto;
  text-align: center;

  h2 {
    font-size: clamp(28px, 4vw, 40px);
    margin-block-end: 32px;
  }

  > p {
    color: var(--clr-aubergine);
    font-size: clamp(16px, 2.5vw, 18px);
    line-height: 1.6;
    margin-block-end: 48px;
    margin-inline: auto;
    max-inline-size: 800px;
  }
}

/* AI Modules Grid */

.ai-modules-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-block-start: 48px;

  @media only screen and (max-width: 991px) {
    grid-template-columns: repeat(2, 1fr);
  }

  @media only screen and (max-width: 767px) {
    grid-template-columns: 1fr;
  }
}

.ai-module-card {
  background-color: var(--clr-light);
  border-radius: 12px;
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  text-align: left;
  transition: all 0.25s ease-in-out;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.14);

  &:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
  }
}

.ai-module-logo {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  min-block-size: 80px;

  img {
    object-fit: contain;
  }

  img[src*="skillsfinder"],
  img[src*="techmien"] {
    inline-size: 150px;
  }
}

.ai-module-card h3 {
  font-size: clamp(20px, 3vw, 24px);
  line-height: 1.3;
}

.ai-module-card p {
  color: var(--clr-aubergine);
}

.ai-module-button {
  margin-block-start: auto;
  inline-size: fit-content;
}

.ai-module-coming-soon {
  border: 2px solid var(--clr-teal);
  border-radius: 6px;
  color: var(--clr-teal);
  font-weight: 700;
  letter-spacing: .035em;
  margin-block-start: auto;
  padding: 12px 24px;
  text-align: center;
  text-transform: uppercase;
  inline-size: fit-content;
}

.additional-resources-section {
  padding: clamp(48px, 8vw, 80px) clamp(24px, 5vw, 64px);
}

/* Browse Catalogue Section */

.browse-catalogue-section {
  background: linear-gradient(135deg, #c8e4eb 0%, #d4e9ef 100%);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: clamp(48px, 8vw, 80px) clamp(24px, 5vw, 64px);
}

.browse-catalogue-container {
  max-inline-size: 800px;
  text-align: center;
}

.browse-catalogue-title {
  font-size: clamp(24px, 4vw, 32px);
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 32px 0;
}

.browse-catalogue-button {
  background-color: var(--clr-aubergine);
  border: 1px solid var(--clr-aubergine);
  border-radius: 6px;
  color: var(--clr-tangerine);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .035em;
  padding: 14px 32px;
  text-decoration: none;
  text-transform: uppercase;
  transition: all .25s ease-in-out;

  &:hover {
    background-color: var(--clr-tangerine);
    border: 1px solid var(--clr-aubergine);
    color: var(--clr-aubergine);
  }

  svg {
    position: relative;
    top: -1px;
    transition: all .25s ease-in-out;
  }

  &:hover svg {
    transform: translateX(2px);
  }
}

/* Work-Sharing Content Section */
.work-sharing-content {
  background-color: #f9f9fa;
  padding: clamp(48px, 8vw, 80px) clamp(24px, 5vw, 64px);
}

.work-sharing-content .container {
  max-inline-size: 1200px;
  margin-inline: auto;
}

.work-sharing-content h1 {
  color: var(--clr-aubergine);
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700;
  line-height: 1.3;
  margin-block-end: clamp(24px, 4vw, 32px);
  text-align: center;
}

.ws-description p {
  color: var(--clr-aubergine);
  font-size: clamp(16px, 2vw, 18px);
  line-height: 1.6;
  margin-block-end: 20px;
}

.ws-description p:last-child {
  margin-block-end: 0;
}

.ws-link {
  color: var(--clr-teal) !important;
  cursor: pointer;
  font-weight: 600;
  text-decoration: underline !important;
  text-decoration-thickness: 2px !important;
  text-underline-offset: 3px;
  transition: all .25s ease-in-out;
}

.ws-link:hover,
.ws-link:active {
  color: var(--clr-steelx2) !important;
  text-decoration: underline !important;
  text-decoration-color: var(--clr-steelx2) !important;
}

.ws-link:focus-visible {
  border-radius: 2px;
  outline: 2px solid var(--clr-teal);
  outline-offset: 3px;
}

/* Browse by Industry Section */
.browse-by-industry {
  background-color: var(--clr-light);
  padding: clamp(48px, 8vw, 80px) clamp(24px, 5vw, 64px);
}

.browse-by-industry .container {
  max-inline-size: 1200px;
  margin-inline: auto;
}

.browse-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-block-end: 32px;
  flex-wrap: wrap;
  gap: 16px;
}

.browse-header h2 {
  color: var(--clr-aubergine);
  font-size: clamp(28px, 4vw, 36px);
  font-weight: 700;
  margin: 0;
}

.browse-info {
  display: flex;
  align-items: center;
  gap: 16px;
}

.category-count {
  color: var(--clr-aubergine);
  font-size: 16px;
  font-weight: 500;
}

.clear-all-btn {
  background: none;
  border: 1px solid var(--clr-aubergine);
  border-radius: 4px;
  color: var(--clr-aubergine);
  cursor: pointer;
  font-weight: 600;
  padding: 8px 16px;
  transition: all 0.3s ease;
}

.clear-all-btn:hover {
  background-color: var(--clr-aubergine);
  color: var(--clr-light);
}

/* Industry Filter Tabs */
.industry-tabs {
  display: flex;
  gap: 12px;
  margin-block-end: 40px;
  flex-wrap: wrap;
}

.industry-tab {
  background: #f7f7f6;
  border: 1px solid #d0d0d0;
  padding: 10px 20px;
  color: var(--clr-aubergine);
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 4px;
  white-space: nowrap;
}

.industry-tab:hover {
  background-color: #dae8ed;
  border-color: var(--clr-teal);
}

.industry-tab.active {
  background-color: #dae8ed;
  border-color: var(--clr-teal);
  font-weight: 600;
  color: var(--clr-aubergine);
}

.industry-tab:focus {
  outline: 3px solid var(--clr-teal) !important;
  outline-offset: 3px !important;
}

.industry-tab:focus-visible {
  outline: 3px solid var(--clr-teal) !important;
  outline-offset: 3px !important;
}

.industry-tab:focus:not(:focus-visible) {
  outline: none;
}

/* Industry Cards Grid */
.industry-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
  margin-block-end: 40px;
}

@media only screen and (max-width: 767px) {
  .industry-cards-grid {
    grid-template-columns: 1fr;
  }
}

/* Industry Card */
.industry-card {
  background: var(--clr-light);
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  block-size: 100%;
  overflow: hidden;
}

.industry-card-image {
  inline-size: 100%;
  block-size: 200px;
  overflow: hidden;
  background-color: #f0f0f0;
}

.industry-card-image img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.industry-card-content {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.industry-card-title {
  color: var(--clr-aubergine);
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 12px 0;
  line-height: 1.3;
}

.industry-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-block-end: 20px;
}

.industry-tag {
  background-color: #e8f4f8;
  color: var(--clr-teal);
  padding: 4px 12px;
  border-radius: 16px;
  font-size: 13px;
  font-weight: 600;
}

.industry-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #f1b434;
  color: var(--clr-aubergine);
  padding: 14px 32px;
  border-radius: 4px;
  text-decoration: none;
  font-weight: 700;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-block-start: auto;
  align-self: flex-start;
  inline-size: auto;
  border: none;
}

.industry-card-link:hover {
  background-color: var(--clr-tangerine75);
  border-color: var(--clr-tangerine75);
  color: var(--clr-aubergine);
}

.industry-card-link:focus {
  outline: 3px solid var(--clr-aubergine) !important;
  outline-offset: 3px !important;
}

.industry-card-link:focus-visible {
  outline: 3px solid var(--clr-aubergine) !important;
  outline-offset: 3px !important;
}

.industry-card-link:focus:not(:focus-visible) {
  outline: none;
}

/* Show More Button */
.show-more-container {
  display: flex;
  justify-content: center;
  margin-block-start: 20px;
}

.show-more-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: var(--clr-light);
  color: var(--clr-aubergine);
  padding: 14px 32px;
  border: 2px solid var(--clr-aubergine);
  border-radius: 4px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
}

.show-more-btn:hover,
.show-more-btn:active {
  background-color: var(--clr-aubergine);
  color: var(--clr-light);
}

.show-more-btn:focus {
  outline: 3px solid var(--clr-teal) !important;
  outline-offset: 3px !important;
}

.show-more-btn:focus-visible {
  outline: 3px solid var(--clr-teal) !important;
  outline-offset: 3px !important;
}

.show-more-btn:focus:not(:focus-visible) {
  outline: none;
}

/* Hidden class for cards */
.industry-card.hidden {
  display: none;
}

/* Additional Skills Section */
.additional-skills-section {
  background-color: #edeaea
  padding: clamp(40px, 6vw, 80px) clamp(24px, 5vw, 64px);
}

.additional-skills-section .container {
  max-inline-size: 1200px;
  margin-inline: auto;
}

.additional-skills-section .additionalSkillsHeading {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  color: var(--clr-aubergine);
  margin-block-end: 16px;
  text-align: center;
}

.additional-skills-section .subtitle {
  font-size: clamp(18px, 2.5vw, 20px);
  color: var(--clr-aubergine);
  text-align: center;
  margin-block-end: 48px;
}

.additional-skills-section .ai-banner-content {
  margin-block-end: 48px;
}

/* Skills Cards Grid */
.skills-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 32px;
}

@media only screen and (max-width: 768px) {
  .skills-cards-grid {
    grid-template-columns: 1fr;
  }
}

.skills-card {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 32px;
  background-color: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  transition: box-shadow 0.3s ease;
}

.skills-card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.skills-card-logo {
  display: flex;
  align-items: center;
  block-size: 60px;
}

.skills-card-logo img {
  max-inline-size: 135px;
  block-size: auto;
}

.skills-card h3 {
  color: var(--clr-aubergine);
  font-size: clamp(20px, 2.5vw, 24px);
  font-weight: 700;
  line-height: 1.3;
  margin: 0;
}

.skills-card p {
  color: var(--clr-aubergine);
  font-size: 16px;
  line-height: 1.6;
  margin: 0;
  flex-grow: 1;
}

.skills-card .mat-flat-button {
  inline-size: fit-content;
  align-self: flex-start;
}
