:root {
  /* Quotation - Small image */
  --quotation--small-image--border_color: var(--dark_1, #1D42A6);
  /* Quotation - Small image - Quote */
  --quotation--small-image--quote--text_colour: var(--dark_3, #002147);
  --quotation--small-image--quote--font_family: 'Noto Serif';
  --quotation--small-image--quote--font_size: 2.625rem;
  --quotation--small-image--quote--font_style: italic;
  --quotation--small-image--quote--font_weight: 400;
  --quotation--small-image--quote--line_height: 120%;
  --quotation--small-image--quote--margin: 0;
  --quotation--small-image--quote--padding: 0;
  /* Quotation - Small image - Attribution */
  --quotation--small-image--attribution--text_colour: #61615F;
  --quotation--small-image--attribution--font_family: 'Roboto';
  --quotation--small-image--attribution--font_size: 1.375rem;
  --quotation--small-image--attribution--font_style: normal;
  --quotation--small-image--attribution--font_weight: 500;
  --quotation--small-image--attribution--line_height: 120%;
  --quotation--small-image--attribution--margin: 0;
  --quotation--small-image--attribution--padding: 0;
  /* Quotation - Large image - Image */
  --quotation--large-image--image--border_radius: 11px;
  /* Quotation - Large image - Quote */
  --quotation--large-image--quote--text_colour: var(--dark_3, #002147);
  --quotation--large-image--quote--font_family: 'Noto Serif';
  --quotation--large-image--quote--font_size: 2.625rem;
  --quotation--large-image--quote--font_style: italic;
  --quotation--large-image--quote--font_weight: 400;
  --quotation--large-image--quote--line_height: 120%;
  --quotation--large-image--quote--margin: 0;
  --quotation--large-image--quote--padding: 0;
  /* Quotation - Large image - Attribution */
  --quotation--large-image--attribution--text_colour: var(--dark_2, #61615F);
  --quotation--large-image--attribution--font_family: 'Roboto';
  --quotation--large-image--attribution--font_size: 1.375rem;
  --quotation--large-image--attribution--font_style: normal;
  --quotation--large-image--attribution--font_weight: 500;
  --quotation--large-image--attribution--line_height: 120%;
  --quotation--large-image--attribution--padding: 0;
  /* Quotation - No image */
  --quotation--no-image--border_color: var(--dark_1, #1D42A6);
  /* Quotation - No image - Quote */
  --quotation--no-image--quote--text_colour: var(--dark_3, #002147);
  --quotation--no-image--quote--font_family: 'Noto Serif';
  --quotation--no-image--quote--font_size: 2.625rem;
  --quotation--no-image--quote--font_style: italic;
  --quotation--no-image--quote--font_weight: 400;
  --quotation--no-image--quote--line_height: 120%;
  --quotation--no-image--quote--margin: 0;
  --quotation--no-image--quote--padding: 0;
  /* Quotation - No image - Attribution */
  --quotation--no-image--attribution--text_colour: var(--dark_2, #61615F);
  --quotation--no-image--attribution--font_family: 'Roboto';
  --quotation--no-image--attribution--font_size: 1.375rem;
  --quotation--no-image--attribution--font_style: normal;
  --quotation--no-image--attribution--font_weight: 500;
  --quotation--no-image--attribution--line_height: 120%;
  --quotation--no-image--attribution--margin: 0;
  --quotation--no-image--attribution--padding: 0;
  /* Quotation - No image - Quote mark */
  --quotation--no-image--quote-mark--text_colour: var(--dark_1, #1D42A6);
  --quotation--no-image--quote-mark--font_family: 'Noto serif';
}
/* Main styling */
.oxfcms-quotation__wrapper {
  padding: 0 20px 0 0;
  margin: 1.5em 0;
  container-type: inline-size;
  container-name: quotation;
  /* Shared Quote styles */
  .oxfcms-quotation__quote {
    background: none;
    border: none;
    quotes: none;
    text-indent: 0;
    position: relative;
    &::before,
    &::after {
      content: none;
    }
  }
  /* Small Image Quote */
  .oxfcms-quotation__small {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    border-left: 6px solid var(--quotation--small-image--border_color);
    row-gap: 33px;
    padding: 0 0 0 22px;
    .oxfcms-quotation__quote {
      color: var(--quotation--small-image--quote--text_colour);
      font-family: var(--quotation--small-image--quote--font_family);
      font-size: var(--quotation--small-image--quote--font_size);
      font-style: var(--quotation--small-image--quote--font_style);
      font-weight: var(--quotation--small-image--quote--font_weight);
      line-height: var(--quotation--small-image--quote--line_height);
      margin: var(--quotation--small-image--quote--margin);
      padding: var(--quotation--small-image--quote--padding);
    }
    .oxfcms-quotation__image-author-container {
      display: flex;
      align-items: center;
      gap: 17px;
      .oxfcms-quotation__author {
        color: var(--quotation--small-image--attribution--text_colour);
        font-family: var(--quotation--small-image--attribution--font_family);
        font-size: var(--quotation--small-image--attribution--font_size);
        font-style: var(--quotation--small-image--attribution--font_style);
        font-weight: var(--quotation--small-image--attribution--font_weight);
        line-height: var(--quotation--small-image--attribution--line_height);
        margin: var(--quotation--small-image--attribution--margin);
        padding: var(--quotation--small-image--attribution--padding);
      }
    }
    .oxfcms-quotation__image img {
      width: 40px;
      height: 40px;
      border-radius: 50%;
      object-fit: cover;
      background-color: lightgray;
    }
  }
  /* Large Image Quote */
  .oxfcms-quotation__large {
    display: flex;
    align-items: stretch;
    gap: 20px;
    .oxfcms-quotation__left-box {
      width: 33.33%;
      flex-shrink: 0;
      .oxfcms-quotation__image {
        width: 100%;
        height: 100%;
        img {
          border-radius: var(--quotation--large-image--image--border_radius);
          aspect-ratio: 295 / 194;
          width: 100%;
          height: 100%;
          max-height: 388px;
          object-fit: cover;
        }
      }
    }
    .oxfcms-quotation__right-box {
      padding: 0 20px;
      width: 66.67%;
      flex: 1;
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      flex-direction: column;
      gap: 33px;
      .oxfcms-quotation__quote {
        color: var(--quotation--large-image--quote--text_colour);
        font-family: var(--quotation--large-image--quote--font_family);
        font-size: var(--quotation--large-image--quote--font_size);
        font-style: var(--quotation--large-image--quote--font_style);
        font-weight: var(--quotation--large-image--quote--font_weight);
        line-height: var(--quotation--large-image--quote--line_height);
        margin: var(--quotation--large-image--quote--margin);
        padding: var(--quotation--large-image--quote--padding);
        quotes: none;
        position: relative;
        &::before,
        &::after {
          content: none;
        }
      }
      .oxfcms-quotation__author {
        display: block;
        color: var(--quotation--large-image--attribution--text_colour);
        font-family: var(--quotation--large-image--attribution--font_family);
        font-size: var(--quotation--large-image--attribution--font_size);
        font-style: var(--quotation--large-image--attribution--font_style);
        font-weight: var(--quotation--large-image--attribution--font_weight);
        line-height: var(--quotation--large-image--attribution--line_height);
        padding: var(--quotation--large-image--attribution--padding);
        &::before {
          content: "— ";
        }
      }
    }
  }
  /* No Image Quote */
  .oxfcms-quotation__no-image {
    display: flex;
    align-items: stretch;
    gap: 20px;
    .oxfcms-quotation__left-box {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      padding: 0 20px 0 0;
      border-right: 6px solid var(--quotation--no-image--border_color);
      width: 33.33%;
      flex-shrink: 0;
      .oxfcms-quotation__mark {
        color: var(--quotation--no-image--quote-mark--text_colour);
        font-family: var(--quotation--no-image--quote-mark--font_family);
        font-size: 10rem;
        font-style: italic;
        line-height: 6.5rem;
        align-self: flex-start;
      }
      .oxfcms-quotation__author {
        display: block;
        color: var(--quotation--no-image--attribution--text_colour);
        font-family: var(--quotation--no-image--attribution--font_family);
        font-size: var(--quotation--no-image--attribution--font_size);
        font-style: var(--quotation--no-image--attribution--font_style);
        font-weight: var(--quotation--no-image--attribution--font_weight);
        line-height: var(--quotation--no-image--attribution--line_height);
        margin: var(--quotation--no-image--attribution--margin);
        padding: var(--quotation--no-image--attribution--padding);
        &::before {
          content: "— ";
        }
      }
    }
    .oxfcms-quotation__right-box {
      padding: 0 20px;
      width: 66.67%;
      flex: 1;
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      flex-direction: column;
      .oxfcms-quotation__quote {
        color: var(--quotation--no-image--quote--text_colour);
        font-family: var(--quotation--no-image--quote--font_family);
        font-size: var(--quotation--no-image--quote--font_size);
        font-style: var(--quotation--no-image--quote--font_style);
        font-weight: var(--quotation--no-image--quote--font_weight);
        line-height: var(--quotation--no-image--quote--line_height);
        margin: var(--quotation--no-image--quote--margin);
        padding: var(--quotation--no-image--quote--padding);
      }
      .oxfcms-quotation__author {
        display: none;
        color: var(--quotation--no-image--attribution--text_colour);
        font-family: var(--quotation--no-image--attribution--font_family);
        font-size: var(--quotation--no-image--attribution--font_size);
        font-style: var(--quotation--no-image--attribution--font_style);
        font-weight: var(--quotation--no-image--attribution--font_weight);
        line-height: var(--quotation--no-image--attribution--line_height);
        margin: var(--quotation--no-image--attribution--margin);
        padding: var(--quotation--no-image--attribution--padding);
      }
    }
  }
}
/* Narrowing logic */
.l--layout-onecolumn {
  .l__main {
    .l__primary {
      & > .paragraph--type--oxfcms-quotation {
        .oxfcms-quotation__small {
          width: var(--oxfcms-component--small-width);
          margin: auto;
        }
      }
    }
  }
}
/* Breakpoint - Small Desktop */

@media (width < 1280px) {
  .oxfcms-quotation {
    --quotation--small-image--quote--font_size: 2.25rem;
    --quotation--small-image--attribution--font_size: 1.25rem;
    --quotation--large-image--quote--font_size: 2.25rem;
    --quotation--large-image--attribution--font_size: 1.25rem;
    --quotation--no-image--quote--font_size: 2.25rem;
    --quotation--no-image--attribution--font_size: 1.25rem;
  }
}
/* Breakpoint - Tablet */

@media (width <= 768px) {
  .oxfcms-quotation {
    --quotation--small-image--quote--font_size: 1.625rem;
    --quotation--small-image--attribution--font_size: 1rem;
    --quotation--large-image--quote--font_size: 1.625rem;
    --quotation--large-image--attribution--font_size: 1rem;
    --quotation--no-image--quote--font_size: 1.625rem;
    --quotation--no-image--attribution--font_size: 1rem;
    padding: 0;
    .oxfcms-quotation__small {
      row-gap: 24px;
    }

    .oxfcms-quotation__no-image {
      gap: 0;
      .oxfcms-quotation__left-box {
        .oxfcms-quotation__mark {
          align-self: flex-start;
          font-size: 5rem;
          line-height: 0;
        }
        .oxfcms-quotation__author {
          display: none;
        }
      }
    }
    .oxfcms-quotation__no-image,
    .oxfcms-quotation__large {
      flex-direction: column;
      gap: 24px;
      .oxfcms-quotation__left-box {
        border: none;
        width: 100%;
        height: auto;
        padding: 0;
      }
      .oxfcms-quotation__right-box {
        width: 100%;
        padding: 0;
        gap: 24px;
        .oxfcms-quotation__author {
          display: block;
          &::before {
            content: "— ";
          }
        }
      }
    }
  }
}
