/*=================================*/
/* RW Media - CSS file */
/*=================================*/

/* 
Variables used for the Hero Component:
    // Hero
    --hero-bg--height: 100vh;
    --hero-bg--object-fit: cover;
    --hero-bg--object-position: center;
    --hero-content--padding-top: 0;
    --hero-content--padding-left: 100px;
    --hero-content--padding-bottom: 0;
    --hero-content--padding-right: 0;
    --hero-content--position-top: 50%;
    --hero-content--position-bottom: auto;
    --hero-content--translateY: translateY(-50%);
    --hero-content--item-spacing: 1rem;

    // Banner
    --banner-width: 80%;
    --banner-bg--object-fit: cover;
    --banner-bg--object-position: center;
    --banner-icon-width: 100px;
    --banner-icon-height: 100px;
    --banner-icon-padding: 20px;
    --banner-items-spacing: 2rem;
    --banner-content--max-width: 60%;

    // Teaser
    --teaser-img--max-width: 512px;
    --teaser-img--padding: 20px;
    --teaser-cta--position-top: 80px;
    --teaser-cta--position-right: -80%;
    --teaser-triangle--width: 180px;
    --teaser-triangle--height: 180px;
 */

 /* HERO */
.paragraph--type--rw-media.paragraph--view-mode--homepage-slide {
    position: relative;
}
.paragraph--type--rw-media.paragraph--view-mode--homepage-slide .field--name-field-title,
.paragraph--type--rw-media.paragraph--view-mode--homepage-slide h1 {
    position: absolute;
    text-align: center;
    left: 0;
    right: 0;
    margin: auto;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-white);
    font-size: var(--fz-hero);
    line-height: var(--lh-hero);
    text-shadow: 0 0 3px var(--color-black);
    padding: var(--gutter) / 4;
}
.paragraph--type--rw-media.paragraph--view-mode--homepage-slide i.fas.fa-chevron-down,
.svg-inline--fa.fa-chevron-down {
    width: 34px;
    height: 39px;
    position: absolute;
    bottom: 5vw;
    left: 0;
    right: 0;
    margin: auto;
    cursor: pointer;
    color: var(--color-white);
    text-shadow: 0 0 3px var(--color-black);
}

.field--name-field-hero-comp .paragraph--view-mode--homepage-slide {
    /* position: relative; */
    max-height: 100vh;
}
/* .field--name-field-hero-comp .paragraph--view-mode--homepage-slide:after {
    content: var(--fa-arrow-down);
    position: absolute;
    bottom: 40px;
    left: 0;
    right: 0;
    margin: auto;
    font-family: var(--ff-font-awesome);
    color: var(--color-white);
    font-weight: 600;
    font-size: 34px;
    line-height: 39px;
    width: 34px;
    height: 39px;
    cursor: pointer;
} */
@media only screen and (min-width: 1024px) {
    .paragraph--type--rw-media.paragraph--view-mode--homepage-slide .field--name-field-title,
    .paragraph--type--rw-media.paragraph--view-mode--homepage-slide h1 {
        max-width: 50%;
    }
}

.rw__component_media.hero {
    position: relative;
}
.rw__component_media .hero__bg {
    width: 100%;
    height: var(--hero-bg--height);
}
.user-logged-in .rw__component_media .hero__bg {
    overflow: hidden;
}
.rw__component_media .hero__bg img {
    position: absolute;
    width: 100%;
    object-fit: var(--hero-bg--object-fit);
    object-position: var(--hero-bg--object-position);
}
body:not(.user-logged-in) .rw__component_media .hero__bg img {
    height: 100%;
}
.rw__component_media .hero__bg.hero__bg_colour--primary {
    background: var(--color-primary);
}
.rw__component_media .hero__bg.hero__bg_colour--secondary {
    background: var(--color-secondary);
}
/* .rw__component_media .hero__bg img,
.rw__component_media .hero__bg.hero__bg_colour--primary,
.rw__component_media .hero__bg.hero__bg_colour--secondary {
    border-top-left-radius: var(--border-radius-large);
    border-top-right-radius: var(--border-radius-large);
} */
.rw__component_media .hero__content  {
    position: absolute;
    top: var(--hero-content--position-top);
    left: 0;
    transform: var(--hero-content--translateY);
    width: 40%;
    padding: var(--hero-content--padding-top) var(--hero-content--padding-right) var(--hero-content--padding-bottom) var(--hero-content--padding-left);
}
.field--name-field-hero-comp .field--name-field-title,
.rw__component_media .hero__content--title {
    font-size: var(--fz-hero);
    line-height: var(--lh-hero);
    font-weight: var(--fw-900);
}
.rw__component_media .hero__content .hero__content--title .field--name-field-title {
    padding: 0;
}
.field--name-field-hero-comp .field--name-field-title {
    padding: var(--hero-content--padding-top) var(--hero-content--padding-right) var(--hero-content--padding-bottom) var(--hero-content--padding-left);
}
.rw__component_media .hero__content--title,
.rw__component_media .hero__content--body {
    color: var(--color-white);
}
.rw__component_media .hero__content--title,
.rw__component_media .hero__content--body,
.rw__component_media .hero__content--icon,
.rw__component_media .hero__content--file,
.rw__component_media .hero__content--cta {
    margin-bottom: var(--hero-content--item-spacing);
}
.rw__component_media .hero__content--icon,
.rw__component_media .hero__content--file {
    display: none;
}

/* BANNER */
.rw__component_media.banner .contextual-region.media--type-image {
    position: static;
}
.rw__component_media.banner {
    position: relative;
    width: 100%;
    max-width: var(--banner-width);
    margin: auto;
    display: block;
    border-top-left-radius: var(--border-radius-large);
    border-top-right-radius: var(--border-radius-large);
    overflow: hidden;
}
.rw__component_media .banner__bg img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: var(--banner-bg--object-fit);
    object-position: var(--banner-bg--object-position);
}
.rw__component_media .banner__content {
    position: relative;
    padding: var(--box-spacing);
    max-width: var(--banner-content--max-width);
    margin: auto;
}
.rw__component_media .banner__content--icon {
    width: var(--banner-icon-width);
    height: var(--banner-icon-height);
    background: var(--color-white);
    border-radius: 50%;
    margin: auto;
}
.rw__component_media .banner__content--icon img {
    height: auto;
    padding: var(--banner-icon-padding);
}
.rw__component_media .banner__content--title,
.rw__component_media .banner__content--body {
    color: var(--color-white);
}
.rw__component_media .banner__content--title,
.rw__component_media .banner__content--body,
.rw__component_media .banner__content--icon,
.rw__component_media .banner__content--cta {
    text-align: center;
    margin-bottom: var(--banner-items-spacing);
}
.rw__component_media .banner__content--cta {
    position: relative;
    z-index: 1;
    margin-bottom: 0;
}
.rw__component_media .banner__content--cta .cta.button {
    text-align: left;
}

/* TEASER */
.rw__component_media.teaser {
    position: relative;
    max-width: var(--teaser-img--max-width);
}
.rw__component_media .teaser--img img {
    width: 100%;
    max-width: var(--teaser-img--max-width);
    padding: var(--teaser-img--padding);
    display: block;
    position: relative;
    z-index: 2;
}
.rw__component_media .teaser--img > div {
    position: relative;
}
.rw__component_media .teaser--img > div:before,
.rw__component_media .teaser--img > div:after {
    content: "";
    position: absolute;
    width: var(--teaser-triangle--width);
    height: var(--teaser-triangle--height);
    background: var(--color-primary);
    background: linear-gradient(45deg, var(--color-primary) 0, var(--color-primary) 50%, transparent 50%, transparent 100%);
    display: block;
    z-index: 1;
}
.rw__component_media .teaser--img > div:before {
    left: 0;
    bottom: 0;
}
.rw__component_media .teaser--img > div:after {
    top: 0;
    right: 0;
    transform: rotateZ(180deg);
}
.rw__component_media .teaser--cta {
    width: 100%;
}
.rw__component_media .teaser--cta .cta.button {
    display: block;
    margin: auto;
}
@media only screen and (min-width: 768px) {
    .rw__component_media .teaser--cta {
        position: absolute;
        top: var(--teaser-cta--position-top);
        right: var(--teaser-cta--position-right);
        z-index: 2;
    }
    .rw__component_media .teaser--cta .cta.button {
        margin: 0;
    }
}