diff options
| -rw-r--r-- | pydis_site/static/css/base/base.css | 34 | ||||
| -rw-r--r-- | pydis_site/static/css/home/index.css | 231 | ||||
| -rw-r--r-- | pydis_site/static/css/home/timeline.css | 14 | ||||
| -rw-r--r-- | pydis_site/static/images/events/100k.png | bin | 0 -> 210477 bytes | |||
| -rw-r--r-- | pydis_site/static/images/waves/wave_dark.svg | 73 | ||||
| -rw-r--r-- | pydis_site/static/images/waves/wave_white.svg | 77 | ||||
| -rw-r--r-- | pydis_site/templates/base/navbar.html | 11 | ||||
| -rw-r--r-- | pydis_site/templates/home/index.html | 165 | ||||
| -rw-r--r-- | pydis_site/templates/home/timeline.html | 24 | 
9 files changed, 508 insertions, 121 deletions
| diff --git a/pydis_site/static/css/base/base.css b/pydis_site/static/css/base/base.css index dc7c504d..306a3def 100644 --- a/pydis_site/static/css/base/base.css +++ b/pydis_site/static/css/base/base.css @@ -12,7 +12,7 @@ main.site-content {      flex: 1;  } -div.card.has-equal-height { +.card.has-equal-height {      height: 100%;      display: flex;      flex-direction: column; @@ -30,16 +30,22 @@ div.card.has-equal-height {      background-color: transparent;  } -.navbar-item.has-left-margin-1 { -    margin-left: 1rem; +.navbar-link:not(.is-arrowless) { +    padding-left: 2rem; +    padding-right: 3.5em;  } -.navbar-item.has-left-margin-2 { -    margin-left: 2rem; +.navbar-link:not(.is-arrowless)::after { +    right: 2em; +    margin-top: -0.42em;  } -.navbar-item.has-left-margin-3 { -    margin-left: 3rem; +/* Dropdown nav needs to be viewable at edge of canvas */ +@media screen and (min-width: 1024px) { +    .navbar-dropdown { +        left: unset; +        right: 0; +    }  }  #navbar-banner { @@ -111,3 +117,17 @@ button.is-size-navbar-menu, a.is-size-navbar-menu {  .codehilite-wrap {      margin-bottom: 1em;  } + +/* 16:9 aspect ratio fixing */ +.force-aspect-container { +    position: relative; +    padding-bottom: 56.25%; +} + +.force-aspect-content { +    top: 0; +    left: 0; +    width: 100%; +    height: 100%; +    position: absolute; +} diff --git a/pydis_site/static/css/home/index.css b/pydis_site/static/css/home/index.css index ba856a8e..58ca8888 100644 --- a/pydis_site/static/css/home/index.css +++ b/pydis_site/static/css/home/index.css @@ -1,87 +1,214 @@ -.discord-banner { -    border-radius: 0.5rem; +h1 { +    padding-bottom: 0.5em;  } -.hero-image { -    width: 20rem; -    margin: auto; +/* Mobile-only notice banner */ + +#mobile-notice { +    margin: 5px; +    margin-bottom: -10px!important;  } -.hero-body { -    padding-top: 1rem; -    padding-bottom: 1rem; +/* Wave hero */ + +#wave-hero { +    position: relative; +    background-color: #7289DA; +    color: #fff; +    height: 32vw; +    min-height: 270px; +    max-height: 500px; +    overflow-x: hidden; +    width: 100%; +    padding: 0;  } -.section-sp img { -    height: 5rem; -    margin-right: 2rem; +#wave-hero .container { +    z-index: 4;  /* keep hero contents above wave animations */  } -.video-container iframe, -.video-container object, -.video-container embed { -    width: 100%; -    height: calc(92vw * 0.5625); -    margin: 8px auto auto auto; +@media screen and (min-width: 769px) and (max-width: 1023px) { +    #wave-hero .columns { +        margin: 0 1em 0 1em;  /* Stop cards touching canvas edges in table-view */ +    } +} + +#wave-hero iframe { +    box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23); +    transition: all 0.3s cubic-bezier(.25,.8,.25,1); +    border-radius: 10px; +    margin-top: 1em; +    border: none; +} + +#wave-hero iframe:hover { +    box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22); +} + +#wave-hero-right img{ +    border-radius: 10px; +    box-shadow: 0 1px 6px rgba(0,0,0,0.16), 0 1px 6px rgba(0,0,0,0.23); +    margin-top: 1em; +    text-align: right; +} + +#wave-hero .wave { +    background: url(../../images/waves/wave_dark.svg) repeat-x; +    position: absolute; +    bottom: 0; +    width: 6400px; +    animation-name: wave; +    animation-timing-function: cubic-bezier(.36,.45,.63,.53); +    animation-iteration-count: infinite; +    transform: translate3d(0,0,0);  /* Trigger 3D acceleration for smoother animation */  } -div.card.github-card { +#front-wave { +    animation-duration: 60s; +    animation-delay: -50s; +    opacity: 0.5; +    height: 178px; +} + +#back-wave { +    animation-duration: 65s; +    height: 198px; +} + +#bottom-wave { +    animation-duration: 50s; +    animation-delay: -10s; +    background: url(../../images/waves/wave_white.svg) repeat-x !important; +    height: 26px; +    z-index: 3; +} + +@keyframes wave { +  0% { +    margin-left: 0; +  } +  100% { +    margin-left: -1600px; +  } +} + +/* Showcase */ + +#showcase { +    margin: 0 1em; +} + +#showcase .mini-timeline { +    height: 3px; +    position: relative; +    margin: 50px 0 50px 0; +    background: linear-gradient(to right, #ffffff00, #666666ff, #ffffff00); +    text-align: center; +} + +#showcase .mini-timeline i { +    display: inline-block; +    vertical-align: middle; +    width: 30px; +    height: 30px; +    border-radius: 50%; +    position: relative; +    top: -14px; +    margin: 0 4% 0 4%; +    background-color: #3EB2EF; +    color: white; +    font-size: 15px; +    line-height: 33px; +    border:none; +    box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24); +    transition: all 0.3s cubic-bezier(.25,.8,.25,1); +} + +#showcase .mini-timeline i:hover { +    box-shadow: 0 2px 5px rgba(0,0,0,0.16), 0 2px 5px rgba(0,0,0,0.23); +    transform: scale(1.5); +} + +/* Projects */ + +#projects { +    padding-top: 0; +} + +#projects .card {      box-shadow: none;      border: #d1d5da 1px solid;      border-radius: 3px; +    transition: all 0.2s cubic-bezier(.25,.8,.25,1); +    height: 100%; +    display: flex; +    flex-direction: column; +} + +#projects .card:hover { +    box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);  } -div.repo-headline { +#projects .card-header { +    box-shadow: none;      font-size: 1.25rem; -    margin-bottom: 8px; +    padding: 1.5rem 1.5rem 0 1.5rem;  } -span.repo-language-dot { -    border-radius: 50%; -    height: 12px; -    width: 12px; -    top: 1px; -    display: inline-block; -    position: relative; +#projects .card-header-icon { +    font-size: 1.5rem; +    padding: 0 1rem 0 0;  } -span.repo-language-dot.python { -    background-color: #3572A5; +#projects .card-header-title { +    padding: 0; +    color: #7289DA;  } -span.repo-language-dot.html { -    background-color: #e34c26; +#projects .card:hover .card-header-title { +    color: #363636;  } -span.repo-language-dot.css { -    background-color: #563d7c; +#projects .card-content { +    padding-top: 8px; +    padding-bottom: 1rem;  } -span.repo-language-dot.javascript { -    background-color: #f1e05a; +#projects .card-footer { +    margin-top: auto; +    border: none;  } -#repo-footer-item { -    margin-left: 1.2rem; +#projects .card-footer-item { +    border: none;  } -#sponsors-hero { -    padding-top: 2rem; -    padding-bottom: 3rem; +#projects .card-footer-item i { +    margin-right: 0.5rem;  } -@media screen and (min-width: 1088px) { -    .video-container iframe { -        height: calc(42vw * 0.5625); -        max-height: 371px; -        max-width: 660px; -    } +#projects .repo-language-dot { +    border-radius: 50%; +    height: 12px; +    width: 12px; +    top: -1px; +    display: inline-block; +    position: relative;  } -@media screen and (max-width: 1087px) { -    .video-container iframe { -        height: calc(92vw * 0.5625); -        max-height: none; -        max-width: none; -    } +#projects .repo-language-dot.python { background-color: #3572A5; } +#projects .repo-language-dot.html { background-color: #e34c26; } +#projects .repo-language-dot.css { background-color: #563d7c; } +#projects .repo-language-dot.javascript { background-color: #f1e05a; } + +/* Sponsors */ + +#sponsors .hero-body { +    padding-top: 2rem; +    padding-bottom: 3rem; +} + +#sponsors img { +    height: 5rem; +    margin-right: 2rem;  } diff --git a/pydis_site/static/css/home/timeline.css b/pydis_site/static/css/home/timeline.css index 07e17e15..89de0887 100644 --- a/pydis_site/static/css/home/timeline.css +++ b/pydis_site/static/css/home/timeline.css @@ -61,20 +61,6 @@ button, input, textarea, select {      background-color: #576297 !important;  } -.video-container { -    position: relative; -    width: 100%; -    height: 0; -    padding-bottom: 75%; -} -.video { -    position: absolute; -    top: 0; -    left: 0; -    width: 100%; -    height: 100%; -} -  .pydis-logo-banner {      background-color: #7289DA !important;      border-radius: 10px; diff --git a/pydis_site/static/images/events/100k.png b/pydis_site/static/images/events/100k.pngBinary files differ new file mode 100644 index 00000000..ae024d77 --- /dev/null +++ b/pydis_site/static/images/events/100k.png diff --git a/pydis_site/static/images/waves/wave_dark.svg b/pydis_site/static/images/waves/wave_dark.svg new file mode 100644 index 00000000..35174c47 --- /dev/null +++ b/pydis_site/static/images/waves/wave_dark.svg @@ -0,0 +1,73 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<svg +   xmlns:dc="http://purl.org/dc/elements/1.1/" +   xmlns:cc="http://creativecommons.org/ns#" +   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" +   xmlns:svg="http://www.w3.org/2000/svg" +   xmlns="http://www.w3.org/2000/svg" +   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" +   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" +   width="1600" +   height="198" +   version="1.1" +   id="svg11" +   sodipodi:docname="wave.svg" +   inkscape:version="1.0.1 (3bc2e813f5, 2020-09-07)"> +  <metadata +     id="metadata15"> +    <rdf:RDF> +      <cc:Work +         rdf:about=""> +        <dc:format>image/svg+xml</dc:format> +        <dc:type +           rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> +      </cc:Work> +    </rdf:RDF> +  </metadata> +  <sodipodi:namedview +     pagecolor="#ffffff" +     bordercolor="#666666" +     borderopacity="1" +     objecttolerance="10" +     gridtolerance="10" +     guidetolerance="10" +     inkscape:pageopacity="0" +     inkscape:pageshadow="2" +     inkscape:window-width="2560" +     inkscape:window-height="1409" +     id="namedview13" +     showgrid="false" +     inkscape:zoom="1.44625" +     inkscape:cx="757.49384" +     inkscape:cy="107.38903" +     inkscape:window-x="4880" +     inkscape:window-y="677" +     inkscape:window-maximized="1" +     inkscape:current-layer="svg11" /> +  <defs +     id="defs7"> +    <linearGradient +       id="a" +       x1="50%" +       x2="50%" +       y1="-10.959%" +       y2="100%"> +      <stop +         stop-color="#57BBC1" +         stop-opacity=".25" +         offset="0%" +         id="stop2" /> +      <stop +         stop-color="#015871" +         offset="100%" +         id="stop4" /> +    </linearGradient> +  </defs> +  <path +     fill="url(#a)" +     fill-rule="evenodd" +     d="M.005 121C311 121 409.898-.25 811 0c400 0 500 121 789 121v77H0s.005-48 .005-77z" +     transform="matrix(-1 0 0 1 1600 0)" +     id="path9" +     style="fill:#5b6daf;fill-opacity:1" /> +</svg> diff --git a/pydis_site/static/images/waves/wave_white.svg b/pydis_site/static/images/waves/wave_white.svg new file mode 100644 index 00000000..441dacff --- /dev/null +++ b/pydis_site/static/images/waves/wave_white.svg @@ -0,0 +1,77 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<svg +   xmlns:dc="http://purl.org/dc/elements/1.1/" +   xmlns:cc="http://creativecommons.org/ns#" +   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" +   xmlns:svg="http://www.w3.org/2000/svg" +   xmlns="http://www.w3.org/2000/svg" +   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" +   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" +   width="1600" +   height="28.745832" +   version="1.1" +   id="svg11" +   sodipodi:docname="wavew.svg" +   inkscape:version="1.0.1 (3bc2e813f5, 2020-09-07)"> +  <metadata +     id="metadata15"> +    <rdf:RDF> +      <cc:Work +         rdf:about=""> +        <dc:format>image/svg+xml</dc:format> +        <dc:type +           rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> +        <dc:title></dc:title> +      </cc:Work> +    </rdf:RDF> +  </metadata> +  <sodipodi:namedview +     pagecolor="#ffffff" +     bordercolor="#666666" +     borderopacity="1" +     objecttolerance="10" +     gridtolerance="10" +     guidetolerance="10" +     inkscape:pageopacity="0" +     inkscape:pageshadow="2" +     inkscape:window-width="2560" +     inkscape:window-height="1409" +     id="namedview13" +     showgrid="false" +     inkscape:zoom="1.44625" +     inkscape:cx="884.40031" +     inkscape:cy="-61.865141" +     inkscape:window-x="4880" +     inkscape:window-y="677" +     inkscape:window-maximized="1" +     inkscape:current-layer="svg11" +     fit-margin-top="0" +     fit-margin-left="0" +     fit-margin-right="0" +     fit-margin-bottom="0" /> +  <defs +     id="defs7"> +    <linearGradient +       id="a" +       x1="0.5" +       x2="0.5" +       y1="-0.10958999" +       y2="1"> +      <stop +         stop-color="#57BBC1" +         stop-opacity=".25" +         offset="0%" +         id="stop2" /> +      <stop +         stop-color="#015871" +         offset="100%" +         id="stop4" /> +    </linearGradient> +  </defs> +  <path +     fill="url(#a)" +     fill-rule="evenodd" +     d="M 1599.995,17.566918 C 1289,17.566918 1190.102,-0.03623696 789,5.6042811e-5 389,5.6042811e-5 289,17.566918 0,17.566918 v 11.178914 h 1600 c 0,0 -0.01,-6.968673 -0.01,-11.178914 z" +     id="path9" +     style="fill:#ffffff;fill-opacity:1;stroke-width:0.381026" /> +</svg> diff --git a/pydis_site/templates/base/navbar.html b/pydis_site/templates/base/navbar.html index c2915025..9453c7b5 100644 --- a/pydis_site/templates/base/navbar.html +++ b/pydis_site/templates/base/navbar.html @@ -20,8 +20,8 @@    <div class="navbar-menu is-paddingless" id="navbar_menu">      <div class="navbar-end"> -      {# Discord invite - only visible in the hamburger on mobile sizes. #} -      <a class="navbar-item is-hidden-desktop" href="https://discord.gg/python"> +      {# Discord #} +      <a class="navbar-item" href="https://discord.gg/python">          <span class="icon is-size-4 is-medium"><i class="fab fa-discord"></i></span>          <span> Discord</span>        </a> @@ -57,7 +57,7 @@        </a>        {# More #} -      <div class="navbar-item has-dropdown is-hoverable has-left-margin-1"> +      <div class="navbar-item has-dropdown is-hoverable">          <a class="navbar-link">            More          </a> @@ -123,11 +123,6 @@          </div>        </div>      </div> - -    {# Join us on Discord! #} -    <a class="navbar-item is-fullsize has-no-highlight has-left-margin-1" href="https://discord.gg/python"> -      <img class="is-hidden-touch" src="{% static "images/navbar/navbar_discordjoin.svg" %}" alt="Join us on Discord!"/> -    </a>    </div>  </nav> diff --git a/pydis_site/templates/home/index.html b/pydis_site/templates/home/index.html index f31363a4..7d91feb4 100644 --- a/pydis_site/templates/home/index.html +++ b/pydis_site/templates/home/index.html @@ -9,12 +9,69 @@  {% block content %}    {% include "base/navbar.html" %} -  <section class="section"> +  <!-- Mobile-only Notice --> +  <section id="mobile-notice" class="message is-primary is-hidden-tablet"> +    <div class="message-header"> +      <p>100K Member Milestone!</p> +    </div> +    <div class="message-body"> +      Thanks to all our members for helping us create this friendly and helpful community! +      <br><br> +      As a nice treat, we've created a <a href="{% url 'timeline' %}">Timeline page</a> for people +      to discover the events that made our community what it is today. Be sure to check it out! +    </div> +  </section> + +  <!-- Wave Hero --> +  <section id="wave-hero" class="section is-hidden-mobile"> + +      <div class="container"> +        <div class="columns is-variable is-8"> + +          {# Embedded Welcome video #} +          <div id="wave-hero-left" class="column is-half"> +            <div class="force-aspect-container"> +              <iframe +              class="force-aspect-content" +              src="https://www.youtube.com/embed/ZH26PuX3re0" +              srcdoc=" +              <style> +                *{padding:0;margin:0;overflow:hidden} +                html,body{height:100%} +                img,span{position:absolute;width:100%;top:0;bottom:0;margin:auto} +                span{height:1.5em;text-align:center;font:68px/1.5 sans-serif;color:#FFFFFFEE;text-shadow:0 0 0.1em #00000020} +              </style> +              <a href=https://www.youtube.com/embed/ZH26PuX3re0?autoplay=1> +                <img src=https://i.ytimg.com/vi/ZH26PuX3re0/maxresdefault.jpg alt='Welcome to Python Discord'> +                <span>▶</span> +              </a>" +              allow="autoplay; accelerometer; clipboard-write; encrypted-media; gyroscope; picture-in-picture" +              allowfullscreen +              ></iframe> +            </div> +          </div> + +          {# Right side content #} +          <div id="wave-hero-right" class="column is-half"> +            <img src="{% static "images/events/100k.png" %}" alt="100K members!"> +          </div> + +        </div> +      </div> + +    {# Animated wave elements #} +    <span id="front-wave" class="wave"></span> +    <span id="back-wave" class="wave"></span> +    <span id="bottom-wave" class="wave"></span> -    {# Who are we? #} -    <div class="container is-spaced"> +  </section> + +  <!-- Main Body --> +  <section id="body" class="section"> + +    <div class="container">        <h1 class="is-size-1">Who are we?</h1> -      <br> +        <div class="columns is-desktop">          <div class="column is-half-desktop content">            <p> @@ -37,45 +94,97 @@            </p>          </div> -        {# Right column container #} -        <div class="column is-half-desktop"> -          <iframe width="560" height="315" src="https://www.youtube.com/embed/ZH26PuX3re0" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe> -        </div> +        {# Showcase box #} +        <section id="showcase" class="column is-half-desktop has-text-centered"> +          <article class="box"> + +            <header class="title">New Timeline!</header> + +            <div class="mini-timeline"> +              <i class="fa fa-asterisk"></i> +              <i class="fa fa-code"></i> +              <i class="fab fa-python"></i> +              <i class="fa fa-alien-monster"></i> +              <i class="fa fa-duck"></i> +              <i class="fa fa-bug"></i> +            </div> + +            <p class="subtitle"> +              Start from our humble beginnings to discover the events that made our community what it is today. +            </p> + +            <div class="buttons are-large is-centered"> +              <a href="{% url 'timeline' %}" class="button is-primary"> +                <span>Check it out!</span> +                <span class="icon"> +                  <i class="fas fa-arrow-right"></i> +                </span> +              </a> +            </div> + +          </article> +        </section> +        </div> +    </div> +  </section> -      {# Projects #} +  <!-- Projects --> +  <section id="projects" class="section"> +    <div class="container">        <h1 class="is-size-1">Projects</h1> -      <br> +        <div class="columns is-multiline is-tablet"> -        {# Display projects from HomeView.repos #} +        {# Generate project data from HomeView.repos #}          {% for repo in repo_data %}            <div class="column is-one-third-desktop is-half-tablet"> -            <div class="card has-equal-height github-card"> -              <div class="card-content"> -                <div class="repo-headline"> -                  <i class="fab fa-github"></i> -                  <a href="https://github.com/{{ repo.repo_name }}"> <strong>{{ repo.repo_name }}</strong></a> -                </div> -                <div> + +            <a href="https://github.com/{{ repo.repo_name }}"> +              <article class="card"> + +                <header class="card-header"> +                  <span class="card-header-icon"> +                    <span class="icon"><i class="fab fa-github"></i></span> +                  </span> +                  <div class="card-header-title"> +                    {{ repo.repo_name|cut:"python-discord/" }} +                  </div> +                </header> + +                <p class="card-content">                    {{ repo.description }} -                  <br><br> -                  </span><span class="repo-language-dot {{ repo.language | lower }}"></span> {{ repo.language }} -                  <span id="repo-footer-item"><i class="fas fa-star"></i> {{ repo.stargazers }}</span> -                  <span id="repo-footer-item"><i class="fas fa-code-branch"></i> {{ repo.forks }}</span> -                </div> -              </div> -            </div> +                </p> + +                <footer class="card-footer"> +                  <div class="card-footer-item"> +                    <i class="repo-language-dot {{ repo.language | lower }}"></i> +                    {{ repo.language }} +                  </div> +                  <div class="card-footer-item"> +                    <i class="fas fa-star"></i> +                    {{ repo.stargazers }} +                  </div> +                  <div class="card-footer-item"> +                    <i class="fas fa-code-branch"></i> +                    {{ repo.forks }} +                  </div> +                </footer> + +              </article> +            </a> +            </div>          {% endfor %}        </div> +      </div>    </section> -  {# Sponsors #} -  <section class="section-sp hero is-light"> -    <div id="sponsors-hero" class="hero-body"> +  <!-- Sponsors --> +  <section id="sponsors" class="hero is-light"> +    <div class="hero-body">        <div class="container">          <h1 class="title is-6 has-text-grey">            Sponsors diff --git a/pydis_site/templates/home/timeline.html b/pydis_site/templates/home/timeline.html index 54cbdc1b..f3c58fc2 100644 --- a/pydis_site/templates/home/timeline.html +++ b/pydis_site/templates/home/timeline.html @@ -14,7 +14,7 @@      <div class="container max-width-lg cd-timeline__container">          <div class="cd-timeline__block">              <div class="cd-timeline__img cd-timeline__img--picture"> -                <img src={% static "images/timeline/cd-icon-picture.svg" %} alt="Picture"> +                <img src="{% static "images/timeline/cd-icon-picture.svg" %}" alt="Picture">              </div>              <div class="cd-timeline__content text-component"> @@ -231,8 +231,8 @@              <div class="cd-timeline__content text-component">                  <h2>PyDis hits 15,000 members; the “hot ones special” video is released</h2> -                <div class="video-container"> -                    <iframe class="video" src="https://www.youtube.com/embed/DIBXg8Qh7bA" frameborder="0" +                <div class="force-aspect-container"> +                    <iframe class="force-aspect-content" src="https://www.youtube.com/embed/DIBXg8Qh7bA" frameborder="0"                          allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"                          allowfullscreen></iframe>                  </div> @@ -319,8 +319,8 @@                      developers join us to judge the event and help out our members during the event. One of them,                      @tshirtman, even joins our staff!</p> -                <div class="video-container"> -                    <iframe class="video" src="https://www.youtube.com/embed/8fbZsGrqBzo" frameborder="0" +                <div class="force-aspect-container"> +                    <iframe class="force-aspect-content" src="https://www.youtube.com/embed/8fbZsGrqBzo" frameborder="0"                          allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"                          allowfullscreen></iframe>                  </div> @@ -377,8 +377,8 @@                      Several of the Code Jam participants also end up getting involved contributing to the Arcade                      repository.</p> -                <div class="video-container"> -                    <iframe class="video" src="https://www.youtube.com/embed/KkLXMvKfEgs" frameborder="0" +                <div class="force-aspect-container"> +                    <iframe class="force-aspect-content" src="https://www.youtube.com/embed/KkLXMvKfEgs" frameborder="0"                          allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"                          allowfullscreen></iframe>                  </div> @@ -450,8 +450,8 @@                      Code Jam for 2020 attracts hundreds of participants, and sees the creation of some fantastic                      projects. Check them out in our judge stream below:</p> -                <div class="video-container"> -                    <iframe class="video" src="https://www.youtube.com/embed/OFtm8f2iu6c" frameborder="0" +                <div class="force-aspect-container"> +                    <iframe class="force-aspect-content" src="https://www.youtube.com/embed/OFtm8f2iu6c" frameborder="0"                          allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"                          allowfullscreen></iframe>                  </div> @@ -481,13 +481,13 @@  	<div class="cd-timeline__block">              <div class="cd-timeline__img cd-timeline__img--picture"> -                <img src={% static "images/timeline/cd-icon-picture.svg" %} alt="Picture"> +                <img src="{% static "images/timeline/cd-icon-picture.svg" %}" alt="Picture">              </div>              <div class="cd-timeline__content text-component">                  <h2>Python Discord hosts the 2020 CPython Core Developer Q&A</h2> -                <div class="video-container"> -                    <iframe class="video" src="https://www.youtube.com/embed/gXMdfBTcOfQ" frameborder="0" +                <div class="force-aspect-container"> +                    <iframe class="force-aspect-content" src="https://www.youtube.com/embed/gXMdfBTcOfQ" frameborder="0"                          allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"                          allowfullscreen></iframe>                  </div> | 
