/* Digital Dilemmas info 23.05 */

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    font-size: 17px;
}

body {
    font-family: "Suisse Intl", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    background-color: #111111;
    color: #fff;
    margin: 0;
}

img {
    width: 100%;
    height: auto;
    display: block;
}

.container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 15px;
    position: relative;
}

h2 {
    font-size: 5rem;
    text-transform: uppercase;
    margin: 0;
    line-height: 1;
}

h3 {
    font-size: 1.5rem;
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: 1rem;
}

.subtitle {
    color: #FA2D35;
    text-transform: uppercase;
    font-size: 3rem;
    margin: 0 0 2rem;
    line-height: 1;
    font-weight: 700;
}

.cta {
    text-transform: uppercase;
    background-color: #FA2D35;
    border: 2px solid #FA2D35;
    text-decoration: none;
    padding: .5em 1.4em;
    font-family: Oswald, serif;
    color: #fff;
    font-size: .8rem;
    display: inline-block;
    margin: 0 1rem 1rem 0;
}

.cta:hover {
    background: #fff;
    color: #FA2D35;
}

/* #region Top */

.top {
    background: url('img/top.jpg') no-repeat center center;
    background-size: cover;
    padding: 25vh 0 20vh;
    text-align: center;
    position: relative;
}

.top-inner {
    padding: 0 15px;
    position: relative;
}

.top p {
    font-weight: 500;
    max-width: 340px;
    margin: 0 auto 2rem;
    font-size: 1.1rem;
}

.top .back {
    position: absolute;
    right: 0;
    top: 15px;
}

.top .scroll {
    display: inline-block;
    margin: 5vh auto 0;
    display: block;
    overflow: hidden;
    text-indent: -300px;
    background: url('img/arrow-down.png') no-repeat center center;
    background-size: contain;
    width: 40px;
    height: 100px;
}

.top .hashtags {
    display: inline-block;
    border: 2px solid #fff;
    padding: 1em 1.5em;
    font-weight: 500;
    letter-spacing: .1em;
    line-height: 1;
}

.top .hashtags img {
    width: 30px;
    display: inline-block;
    margin: 0 10px;
}

.sharelinks {
    display: flex;
    margin: 10px 0 0;
}

@media (min-width: 768px) {
    .top .hashtags {
        position: absolute;
        right: 0;
        bottom: 0;
        border-right: 0 none;
        text-align: left;
        /* display: flex;
        align-items: center; */
    }
}

/* #endregion */


/* #region Data */

.data .container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    padding-top: 10vh;
    padding-bottom: 10vh;
}

.data article {
    border: 1px solid #fff;
    text-align: center;
    padding: 1em 1.5em 0;
    margin-bottom: 3rem;
}

@media (min-width: 768px) {

    .data article,
    .data-last {
        width: 48%;
    }
}

.data article .cta {
    position: relative;
    top: 1.3em;
    margin: 0;
}

.data-last {
    align-self: stretch;
    display: flex;
    align-items: flex-end;
    padding-bottom: 3rem;
}

.data .back {
    font-family: Oswald, sans-serif;
    text-transform: uppercase;
    font-size: 1.5rem;
    background: url('img/arrow-left.png') no-repeat left bottom;
    padding-bottom: 2rem;
    color: #666;
    text-decoration: none;
}

.data .back:hover {
    color: #fff;
}

/* #endregion */


/* #region what where */

.what,
.where {
    padding: 10vh 0;
    margin-bottom: 10vh;
    background: url('img/what2.jpg') no-repeat right center;
    background-size: cover;
}

.where {
    background-image: url('img/where.jpg');
}

.what p,
.where p {
    max-width: 600px;
    font-weight: 500;
}


/* #endregion */


/* #region Footer */

footer {
    background-color: #fff;
    padding: 8vh 0;
    color: #111111;
    font-weight: 500;
}

footer .container {
    padding-top: 7vh;
}

footer h2 {
    color: #111111;
    font-size: 5rem;
    line-height: .5;
    padding-top: 2rem;
}

footer h2 span {
    font-size: 2.5rem;
}

footer p {
    max-width: 700px;
}

.sn {
    padding-top: 1.5rem;
}

@media (min-width: 768px) {
    .sn {
        position: absolute;
        right: 15px;
        top: 0;
    }
}

.sn a {
    display: inline-block;
    height: 40px;
    width: 40px;
    border-radius: 50%;
    overflow: hidden;
    text-indent: -300px;
    margin-left: 0.5rem;
    background: #111111 url('img/sn-fb-neg.svg') no-repeat center center;
    background-size: auto 18px;
}

.sn .insta {
    background-image: url('img/sn-insta-neg.svg');
}

.sn .yt {
    background-image: url('img/sn-yt-neg.svg');
    background-size: 20px auto;
}

.sn a:hover {
    background-color: #444;
}

footer .logos {
    margin-top: 5rem;
}

footer .logos a {
    display: inline-block;
    width: 200px;
}

footer .logos a img {
    object-fit: contain;
    height: 100px;
}

/* #endregion */


/* #region Logo Glitch */

h1 {
    font-size: 8vw;
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}


.glitch {
    display: inline-block;
    position: relative;
    animation: glitch-skew 1s infinite linear alternate-reverse;
}

.glitch2,
.glitch2::before,
.glitch2::after {
    animation-delay: .8s;
}

.glitch::before {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    left: 2px;
    text-shadow: -2px 0 #ff00c1;
    /* Creates an initial clip for our glitch. This works in
a typical top,right,bottom,left fashion and creates a mask
to only show a certain part of the glitch at a time. */
    clip: rect(44px, 450px, 56px, 0);
    /* Runs our glitch-anim defined below to run in a 5s loop, infinitely,
with an alternating animation to keep things fresh. */
    animation: glitch-anim 5s infinite linear alternate-reverse;
}

.glitch::after {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    left: -2px;
    text-shadow: -2px 0 #00fff9, 2px 2px #ff00c1;
    animation: glitch-anim2 1s infinite linear alternate-reverse;
}

@keyframes glitch-anim {
    0% {
        clip: rect(45px, 9999px, 23px, 0);
        transform: skew(0.89deg);
    }

    5% {
        clip: rect(2px, 9999px, 34px, 0);
        transform: skew(0.04deg);
    }

    10% {
        clip: rect(34px, 9999px, 100px, 0);
        transform: skew(0.56deg);
    }

    15% {
        clip: rect(26px, 9999px, 67px, 0);
        transform: skew(0.74deg);
    }

    20% {
        clip: rect(37px, 9999px, 53px, 0);
        transform: skew(0.78deg);
    }

    25% {
        clip: rect(64px, 9999px, 11px, 0);
        transform: skew(0.68deg);
    }

    30% {
        clip: rect(38px, 9999px, 92px, 0);
        transform: skew(0.25deg);
    }

    35% {
        clip: rect(23px, 9999px, 81px, 0);
        transform: skew(0.41deg);
    }

    40% {
        clip: rect(16px, 9999px, 93px, 0);
        transform: skew(0.47deg);
    }

    45% {
        clip: rect(51px, 9999px, 10px, 0);
        transform: skew(0.78deg);
    }

    50% {
        clip: rect(8px, 9999px, 11px, 0);
        transform: skew(0.49deg);
    }

    55% {
        clip: rect(63px, 9999px, 15px, 0);
        transform: skew(0.35deg);
    }

    60% {
        clip: rect(96px, 9999px, 46px, 0);
        transform: skew(0.71deg);
    }

    65% {
        clip: rect(50px, 9999px, 40px, 0);
        transform: skew(0.92deg);
    }

    70% {
        clip: rect(84px, 9999px, 27px, 0);
        transform: skew(0.93deg);
    }

    75% {
        clip: rect(99px, 9999px, 9px, 0);
        transform: skew(0.33deg);
    }

    80% {
        clip: rect(25px, 9999px, 100px, 0);
        transform: skew(0.36deg);
    }

    85% {
        clip: rect(28px, 9999px, 85px, 0);
        transform: skew(0.62deg);
    }

    90% {
        clip: rect(8px, 9999px, 75px, 0);
        transform: skew(0.58deg);
    }

    95% {
        clip: rect(21px, 9999px, 3px, 0);
        transform: skew(0.56deg);
    }

    100% {
        clip: rect(68px, 9999px, 9px, 0);
        transform: skew(0.02deg);
    }
}

@keyframes glitch-anim2 {
    0% {
        clip: rect(10px, 9999px, 12px, 0);
        transform: skew(0.69deg);
    }

    5% {
        clip: rect(79px, 9999px, 90px, 0);
        transform: skew(0.28deg);
    }

    10% {
        clip: rect(38px, 9999px, 75px, 0);
        transform: skew(0.29deg);
    }

    15% {
        clip: rect(21px, 9999px, 13px, 0);
        transform: skew(0.08deg);
    }

    20% {
        clip: rect(66px, 9999px, 12px, 0);
        transform: skew(0.22deg);
    }

    25% {
        clip: rect(66px, 9999px, 76px, 0);
        transform: skew(0.42deg);
    }

    30% {
        clip: rect(2px, 9999px, 64px, 0);
        transform: skew(1deg);
    }

    35% {
        clip: rect(51px, 9999px, 40px, 0);
        transform: skew(0.69deg);
    }

    40% {
        clip: rect(54px, 9999px, 27px, 0);
        transform: skew(0.11deg);
    }

    45% {
        clip: rect(85px, 9999px, 96px, 0);
        transform: skew(0.61deg);
    }

    50% {
        clip: rect(87px, 9999px, 12px, 0);
        transform: skew(0.09deg);
    }

    55% {
        clip: rect(87px, 9999px, 17px, 0);
        transform: skew(0.8deg);
    }

    60% {
        clip: rect(44px, 9999px, 61px, 0);
        transform: skew(0.39deg);
    }

    65% {
        clip: rect(20px, 9999px, 41px, 0);
        transform: skew(0.19deg);
    }

    70% {
        clip: rect(7px, 9999px, 84px, 0);
        transform: skew(0.04deg);
    }

    75% {
        clip: rect(74px, 9999px, 80px, 0);
        transform: skew(0.63deg);
    }

    80% {
        clip: rect(50px, 9999px, 4px, 0);
        transform: skew(1deg);
    }

    85% {
        clip: rect(64px, 9999px, 14px, 0);
        transform: skew(0.39deg);
    }

    90% {
        clip: rect(100px, 9999px, 31px, 0);
        transform: skew(0.38deg);
    }

    95% {
        clip: rect(14px, 9999px, 93px, 0);
        transform: skew(0.06deg);
    }

    100% {
        clip: rect(55px, 9999px, 50px, 0);
        transform: skew(0.81deg);
    }
}

@keyframes glitch-skew {
    0% {
        transform: skew(5deg);
    }

    10% {
        transform: skew(-2deg);
    }

    20% {
        transform: skew(0deg);
    }

    30% {
        transform: skew(-3deg);
    }

    40% {
        transform: skew(5deg);
    }

    50% {
        transform: skew(5deg);
    }

    60% {
        transform: skew(-1deg);
    }

    70% {
        transform: skew(4deg);
    }

    80% {
        transform: skew(-2deg);
    }

    90% {
        transform: skew(2deg);
    }

    100% {
        transform: skew(2deg);
    }
}

/* #endregion */

@media (max-width:767.98px) {
    html {
        font-size: 16px;
    }

    h2 {
        font-size: 2.6rem;
    }

    .subtitle {
        font-size: 1.8rem;
    }
}