I want to create a button action where upon click, a video light box opens and when the visitor clicks anywhere else outside of the video (the fade), the video closes. So far, other features work except when I click on fade near the edge of the video, it doesn't close. So here's my html, css & js.
<div id="motionVideo">
<div class='motionButton' onclick="motionLightbox_open();"></div>
<div id="motionLight">
<video id="motionShowreel" width='1280' height='720' controls>
<source src="./motionGraphic.mp4" type="video/mp4">
<!--Browser does not support <video> tag -->
</video>
</div>
<div id="motionFade" onClick="motionLightbox_close();">
</div>
<div class="motionShowreel">
<video src="./motionGraphic.mp4" width="100%" height="50%"></video>
</div>
</div>
#motionVideo {
/*background: #ffc8b2;*/
grid-area: motionVideo;
}
.motionButton{
background-image:url(./mg.png);
background-position:center center;
background-repeat: no-repeat;
background-size: 70%;
width:100%;
height:100%;
/*position: relative;
top:20vh;
left:-20vw;*/
}
.motionShowreel{
width: 100%;
height: 100%;
position: relative;
top: -120vh;
left: 0vw;
z-index: -1;
}
#motionFade {
display: none;
position: fixed;
width: 100%;
height: 100%;
background-color: black;
top:0%;
left:0%;
z-index: 1001;
-moz-opacity: 0.8;
opacity: .80;
filter: alpha(opacity=80);
}
#motionLight {
display: none;
position: absolute;
padding: 10vw;
top:0;
align-items: center center;
justify-content: center center;
z-index: 1002;
cursor: pointer;
}
window.document.onkeydown = function(e) {
if (!e) {
e = event;
}
if (e.keyCode == 27) {
motionLightbox_close();
}
}
function motionLightbox_open() {
var lightBoxVideo = document.getElementById("motionGraphic");
window.scrollTo(0,150);
document.getElementById('motionLight').style.display = 'block';
document.getElementById('motionFade').style.display = 'block';
lightBoxVideo.pause();
}
function motionLightbox_close() {
var lightBoxVideo = document.getElementById("motionGraphic");
document.getElementById('motionLight').style.display = 'none';
document.getElementById('motionFade').style.display = 'none';
lightBoxVideo.pause();
}
When I try clicking on the fade near the edge of the video, the video doesn't close. Only by scrolling down further and clicking does it close. How do I fix this issue?
Seems like div by ID motionLight is occupying the space around the player (it has a huge padding). Try adding the close handler also to that div:
<div id="motionLight" onclick="motionLightbox_close()">
</div>
Working example
window.document.onkeydown = function(e) {
if (!e) {
e = event;
}
if (e.keyCode == 27) {
motionLightbox_close();
}
}
function motionLightbox_open() {
var lightBoxVideo = document.getElementById("motionGraphic");
window.scrollTo(0,150);
document.getElementById('motionLight').style.display = 'block';
document.getElementById('motionFade').style.display = 'block';
lightBoxVideo.pause();
}
function motionLightbox_close() {
var lightBoxVideo = document.getElementById("motionGraphic");
document.getElementById('motionLight').style.display = 'none';
document.getElementById('motionFade').style.display = 'none';
lightBoxVideo.pause();
}
#motionVideo {
/*background: #ffc8b2;*/
grid-area: motionVideo;
}
.motionButton{
background-color: #EEEEEE;
width:100%;
height:100%;
width: 100px;
height: 30px;
/*position: relative;
top:20vh;
left:-20vw;*/
}
.motionShowreel{
width: 100%;
height: 100%;
position: relative;
top: -120vh;
left: 0vw;
z-index: -1;
}
#motionFade {
display: none;
position: fixed;
width: 100%;
height: 100%;
background-color: black;
top:0%;
left:0%;
z-index: 1001;
-moz-opacity: 0.8;
opacity: .80;
filter: alpha(opacity=80);
}
#motionLight {
display: none;
position: absolute;
padding: 10vw;
top:0;
align-items: center center;
justify-content: center center;
z-index: 1002;
cursor: pointer;
}
<div id="motionVideo">
<div class="motionButton" onclick="motionLightbox_open();">Open</div>
<div id="motionLight" onclick="motionLightbox_close()">
<video id="motionShowreel" width='1280' height='720' controls>
<source src="./motionGraphic.mp4" type="video/mp4">
<!--Browser does not support <video> tag -->
</video>
</div>
<div id="motionFade" onClick="motionLightbox_close();">
</div>
<div class="motionShowreel">
<video id="motionGraphic" src="./motionGraphic.mp4" width="100%" height="50%"></video>
</div>
</div>
Related
I've learned the basic of HTML5, CSS and a little of JS.
I'm trying to make a site where I can show my projects and knowledge.
The thing is, I want to put 2 JS games that I made in the page, but I don't want them to load instantly with the page. so, I would like it to load only when I click on it.
The game: https://editor.p5js.org/snufupugos/full/jm8j5k5pC
How I got it on the page:
<section class="games"> <iframe src="https://editor.p5js.org/snufupugos/embed/jm8j5k5pC" class="freeway" title="Remake Freeway"></iframe> </section>
The CSS:
.freeway{
background-color:rgba(0, 0, 0, 0.1);
width: 500px;
height: 400px;
margin: 2em auto;
border: 2px solid #801edb;
border-radius: 50px;
border-width: thick;
padding: 5px 5px;
}
My first Idea was to use an image, and then the hover to transform to the iframe, but I think it is not possible since it did not work.
Anyway, can someone help me with this? Any Idea how to do it?
Thank you.
function start(){
document.getElementById("frame").src = "https://editor.p5js.org/snufupugos/embed/jm8j5k5pC";
document.getElementById("imgs").remove();
var news = document.createElement("img");
news.setAttribute('id', 'stop');
news.setAttribute('onclick', 'stop();');
news.setAttribute('class', 'button');
news.setAttribute('width', '25px');
news.setAttribute('src', '');
var element1 = document.getElementById("top");
element1.appendChild(news);
}
function stop(){
document.getElementById("frame").src = "";
document.getElementById("stop").remove();
var neww = document.createElement("img");
neww.setAttribute('id', 'imgs');
neww.setAttribute('onclick', 'start();');
neww.setAttribute('class', 'button');
neww.setAttribute('src', '');
var element = document.getElementById("center");
element.appendChild(neww);
}
.border{
width: 500px;
height: 400px;
margin: 2em auto;
position: relative;
z-index: 9999999999;
}
.freeway{
width: 500px;
height: 400px;
background-color:rgba(0, 0, 0, 0.1);
border: 2px solid #801edb;
border-radius: 50px;
border-width: thick;
}
.show{
display: block;
}
.container {
position: absolute;
text-align: center;
z-index: -1;
}
.centered {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.button {
cursor: pointer;
border: none;
}
.top-right {
position: absolute;
top: 11px;
right: 40px;
}
<section class="games">
<div class="border">
<div class="container">
<iframe src="" id="frame" class="freeway"></iframe>
<div id="top" class="top-right"></div>
<div id="center" class="centered">
<img class="button" src="" onclick="start();" id="imgs"/>
</div>
</div>
</div>
</section>
<script>
window.addEventListener("keydown", function(e) {
// space and arrow keys
if([32, 37, 38, 39, 40].indexOf(e.keyCode) > -1) {
e.preventDefault();
}
}, false);
</script>
Try this!
So on mobile, in the research film page section, I have two videos and a div with some hidden text toggled to be seen or hidden with javascript. The contents of research film are organised by flexbox. On top of these videos and text is a fixed navbar that overlaps the top video "paper boys" . The fixed nav therefore doesn't allow the user to click on the video. The fixed Navbar doesn't respond to z-index (-100) toggled through javascript whenever the user clicks on the "more" button.
Here is the JS to trigger the menu and div to be seen -
const mediaQueryPhone = window.matchMedia('(max-width: 1000px)')
if (mediaQueryPhone.matches) {
let menuOpen = false;
morebtn.addEventListener('click', () => {
processMenu.classList.toggle('fadeMenu');
menuOpen = processMenu.classList.contains('fadeMenu');
if (!menuOpen) {
processMenu.style.touchAction = "none";
processMenu.style.pointerEvents = "none"
} else {
processMenu.style.touchAction = "auto";
processMenu.style.pointerEvents = "all"
}
})
const creditIcon = document.querySelector('.credit-icon');
const creditText = document.querySelector('.credit-text');
let creditOpen = false;
creditIcon.addEventListener('click', () => {
creditText.classList.toggle('hideElement');
creditOpen = creditText.classList.contains('hideElement');
if (!creditOpen) {
creditText.style.display = "block";
} else {
creditText.style.display = "none";
}
})
HTML page with 2 videos
<div class="mobile__header-controls">
<div class="mobile__nav">
<button class="mobile__more">+</button>
<div class="mobile__process-nav">
Show
About
Research Films
Stills
Lookbook
</div>
<div class="mobile__main-nav">
<a class="mabtn" href="/MA.html">MA</a>
<a class="capbtn" href="/capsule.html">Capsule</a>
<a class="babtn user-border" href="/BA.html">BA</a>
</div>
</div>
Back
</div>
<div id="researchFilm-ba" data-tab-content>
<div class="video-wrapper-ba align black-text fade-in">
<p>Dear You (2017)</p>
<video class="mood2" video controls poster="img/BA/Screenshot 2020-08-24 at 12.10.24 am.png"
preload="metadata">
<source src="/img/BA/dear you,.mp4" type="video/mp4">
</video>
</div>
<div id="paperBoys" class="video-wrapper-ba black-text fade-in">
<p>Paper Boys (2018)</p>
<video class="mood" video controls poster="/img/BA/Screenshot 2020-08-24 at 12.10.05 am.png"
preload="metadata">
<source src="/img/BA/Paper Boys.mp4" type="video/mp4">
</video>
</div>
<div class="credit-ba black-text">
<button class="credit-icon">(...)</button>
<div class="credit-text credtitBAMargin hideElement">
<p>
Thank you
to my team of helpers
<br><br>
and the following
<br><br>
Collaborators<br>
<br>Film produced with Taka Hata
<br>Accessories produced by Kristy Fan
<br>Soundtrack composed by Zacharias Wolfe
and Friends at Royal College of Music
<br><br>
Look Book
<br>Make Up by Kristina Pavlovic
<br>Look Book photographed by Simonas Berukstis
<br>Slime Making photographed by Oliver Vanes
<br><br>
Show
<br>Internal Show Make Up by Phoebe Walters
<br>Press Show Make Up by Mariko Yamamoto
<br>Supported by L’Oréal Professionnel
<br><br>
Models
<br>Yota Hoshi
<br>Masato Funaoka
<br>Ryan
<br>Youtian Zhang
<br>Tien Ai Guan
<br>Xander Ang
<br>Wing Fung
<br><br>
and the BAFCSM team</p>
</div>
</div>
</div>
CSS
.mobile__process-nav { // this is the menu dropdown styling
display: flex;
flex-direction: column;
justify-content: space-evenly;
height: 30vh;
height: calc(var(--vh, 1vh) * 30);
color: white;
border: 2px solid white;
opacity: 0;
transition: opacity 0.3s ease-in-out;
-moz-transition: opacity 0.3s ease-in-out;
-webkit-transition: opacity 0.3s ease-in-out;
-ms-transition: opacity 0.3s ease-in-out;
-o-transition: opacity 0.3s ease-in-out;
z-index: 0;
margin-top: 1rem;
margin-left: 2rem;
}
.fadeMenu {
opacity: 1;
}
#researchFilm-ba {
width: 100%;
height: 100vh;
height: calc(var(--vh, 1vh) * 100);
background-color: white;
flex-direction: column-reverse;
justify-content: flex-end;
}
.video-wrapper-ba {
width: 80vw;
height: 35vh;
height: calc(var(--vh, 1vh) * 35);
margin: 0;
margin-top: 2rem;
}
.align {
margin-top: -1.5rem;
}
#researchFilm-ba p,
#researchFilm p {
font-size: 1rem;
font-family: Helvetica, sans-serif;
font-style: italic;
margin-bottom: 0rem;
color: black;
}
.credit-ba {
position: absolute;
display: flex;
flex-direction: column;
margin-left: 80vw;
margin-top: -9vh;
margin-top: calc(var(--vh, 1vh) * -9);
}
.credit-text {
margin-left: -55vw;
width: 67vw;
background-color: white;
margin-top: 0vh;
margin-top: calc(var(--vh, 1vh) * 0);
display: none;
}
.credtitBAMargin {
margin-top: 10vh;
margin-top: calc(var(--vh, 1vh) * 10);
}
.credit-text p {
width: 60vw;
color: black;
}
.credit-icon {
padding: 0;
margin: 1.5rem;
}
#media not all and (pointer: coarse) {
.credit:hover .credit-text,
.credit-ba:hover .credit-text {
display: block;
}
.contact-a a:hover {
color: white;
}
.menu-container:hover .menu {
opacity: 1;
pointer-events: all;
-ms-transform: translateY(0);
transform: translateY(0);
-moz-transform: translateY(0);
-webkit-transform: translateY(0);
outline: none;
}
.stockist p:hover {
background-color: black;
}
}
I have a quiz video overlay that shows up nicely when the videojs player is in standard mode: https://jsfiddle.net/c4nxdf38/
However, when entering fullscreen it disappears (probably behind the video).
I found an obsolete solution which specifies the z-index of the overlay to the maximum. It is not working in the latest Chrome and Firefox.
I found another solution to do the fullscreen with the parent, not the videoplayer itself, but it's not working with the videojs player setup.
Then I found a promising solution how to make overlay elements appear on fullscreen by setting position:absolute; and tried to implement it without success: https://jsfiddle.net/5Lqfyzh4/
HTML from my last attempt (see fiddle):
<div id="main-container">
<div id="overlays-wrap">
<div class="overlay-item" data-overlayid="59" data-time="41">
<p class="vo-question">
Welche Zahl ist die Summe bei 3 + 50 = 53?
</p>
<div class="vtask-choices-wrap">
<div class="vtask-choice-item">
<input class="vtask-choice" type="radio" name="quiz" id="59-a1" value="1" data-correct="0">
<label class="radio-tile" for="59-a1">
<span class="radio-tile-label">
3
</span>
</label>
</div>
<div class="vtask-choice-item">
<input class="vtask-choice" type="radio" name="quiz" id="59-a2" data-correct="0">
<label class="radio-tile" for="59-a2">
<span class="radio-tile-label">
50
</span>
</label>
</div>
<div class="vtask-choice-item">
<input class="vtask-choice" type="radio" name="quiz" id="59-a3" value="3" data-correct="1">
<label class="radio-tile" for="59-a3">
<span class="radio-tile-label">
53
</span>
</label>
</div>
</div> <!-- vtask-choices-wrap -->
<a class="buttonb vtask-btn-continue">Continue</a>
</div> <!-- overlay-item -->
</div>
<div id="videowrapper">
<video id="videoplay" class="video-js vjs-default-skin" controls preload="metadata" width="854" height="480" poster="" autoplay="true">
<source src="http://vjs.zencdn.net/v/oceans.mp4" type="video/mp4">
</video>
</div>
</div>
Javascript:
$(document).ready(function() {
var options = {
playbackRates: [1, 1.5, 2],
muted: true,
};
video = videojs('videoplay', options);
video.ready(function() {
/*
this.on('fullscreenchange',function() {
console.log('fullscreen event');
});
*/
}); // end video.ready
// OVERLAY PREPARE
// $('#overlays-wrap, .overlay-item').hide();
// OVERLAY INTERACTION
$('.radio-tile').click( function() {
// only show if not yet submitted, prevents submit then click again on radio-tile which would show the vtask-btn-continue
var submitted = $(this).closest('.overlay-item').hasClass('overlay-submitted');
if(!submitted)
{
$(this).parent().parent().next('.vtask-btn-continue').css('visibility', 'visible');
// make sure we check the radio button
$(this).prev('.vtask-choice').prop('checked', true);
}
});
$('.vtask-btn-continue').click( function() {
// hide continue button
$(this).css('visibility', 'hidden');
var overlay = $(this).closest('.overlay-item'); // $(this).parent()
overlay.hide();
});
}); // END ready
CSS:
#overlays-wrap {
position: absolute;
width: 100%;
height: 100%;
max-height:460px;
left: 0;
top: 0;
z-index: 2147483647;
}
.overlay-item {
position: absolute;
top: 0;
color: #FFF;
font-size: 20px;
background-color: rgba(0, 0, 0, 0.85);
width: 100%;
height: 100%;
padding: 0;
z-index: 2147483647;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
backface-visibility: hidden;
}
.overlay-item .vo-question {
margin: 10px 0 40px 0;
width: 80%;
text-align: center;
line-height: 1.5;
}
.vtask-choices-wrap {
display: flex;
flex-direction: row;
align-items: flex-start;
justify-content: space-evenly;
width: 100%;
max-width: 1000px;
min-height: 10rem;
}
.vtask-choice-item .vtask-choice {
opacity: 0;
position: absolute;
top: 0;
left: 0;
}
.radio-tile {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
border: 2px solid #079ad9;
border-radius: 5px;
padding: 1rem;
transition: transform 300ms ease;
background: rgba(0,0,0,0.5);
z-index: 500;
cursor: pointer;
font-size: 18px;
text-align: center;
}
.vtask-btn-continue {
color: #FFFFFF!important;
border-color: #2B78C5;
border-bottom-color: #2a65a0;
text-decoration: none;
text-shadow: none;
color: #FFF;
background: #39F;
margin-top: 40px;
padding: 10px 20px;
font-family: Arial,sans-serif;
font-size: 16px;
}
/* FIX according https://stackoverflow.com/a/13388579/1066234 */
#videoplay {
position: absolute;
left: 0px;
top: 0px;
min-height: 100%;
min-width: 100%;
z-index: 9997;
}
#overlays-wrap {
position: absolute;
left: 0px;
top: 0px;
height: 100%;
width: 100%;
z-index: 9998;
}
#main_container {
float: left;
position: relative;
left:0;
top:0;
}
Interestingly, with the videojs plugin at https://github.com/brightcove/videojs-overlay the fullscreen overlays seem to work even on fullscreen. But I cannot figure out how it is doing it. – Demo: http://www.xfaktor.com/overlay/overlay_kroger.html – I have more complex HTML for my overlays and cannot use this plugin.
What is the solution for this video/videojs problem?
Probably it would be best if you can help, having the starting point of this fiddle (my recent implementation): https://jsfiddle.net/w5f7mk19/ Thanks!
The problem appears to be, that this library wraps the video in an additional div, and makes that div fullscreen - but your #overlays-wrap element is outside of that element, and I don’t think z-index is supposed to change anything about that(?).
Putting the overlay directly into #videowrapper in the source code doesn’t do the trick - the player library takes #videoplay, creates the wrapper div and puts the id on that. (It changes the id of the video element itself to #videoplay_html5_api, so no conflict in that regard.) The new div #videoplay becomes fullscreen, but #overlays-wrap still only is a sibling in the DOM, so outside of the fullscreen element.
But if you move #overlays-wrap into #videoplay after the player has initialized, it seems to work:
video = videojs('videoplay', options); // wraps video element into div#videoplay
$('#overlays-wrap').appendTo($('#videoplay')); // append #overlays-wrap to div#videoplay
https://jsfiddle.net/pw89cjqe/
I have problem with canvas tag. I need to append it into parent div. But when I set precise dimensions of parent and embed canvas tag, I get scrollbars. When I do same think with div, it works good. Here is fiddle:
https://jsfiddle.net/57yovrkx/4/
and here is code:
$(function() {
var content1 = $('#content1');
var div = $('<div/>', {width: content1[0].clientWidth, height: content1[0].clientHeight});
content1.append(div);
var content2 = $('#content2');
var canvas = $('<canvas/>', {width: content2[0].clientWidth, height: content2[0].clientHeight});
content2.append(canvas);
})
* {
box-sizing: border-box;
border: 0;
margin: 0;
padding: 0;
}
#wrap1, #wrap2 {
display: flex;
flex-direction: column;
position: absolute;
left: 0;
right: 0;
overflow: auto;
}
#wrap1 {
top: 0;
bottom: 50%;
}
#wrap2 {
top: 50%;
bottom: 0;
}
.header {
flex: 0 0 2rem;
background: darkgrey;
}
#content1, #content2 {
flex: 1;
}
#content1 {
background: lightblue;
}
#content2 {
background: lightgreen;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="wrap1">
<div class="header">
Some header
</div>
<div id="content1">
</div>
</div>
<div id="wrap2">
<div class="header">
Some header
</div>
<div id="content2">
</div>
</div>
Does anybody knows why?
Setting canvas.style.height = '100%'; before you append the canvas seems to do the trick.
https://stackoverflow.com/a/10215724/1482623
So I have this video background made for a website. Now I don't really know how I turn my CSS so it gives a background image for tablets and mobile devices instead of the video.
I hope anyone can help me out with this.
Thanks in advance.
$( document ).ready(function() {
// Resive video
scaleVideoContainer();
initBannerVideoSize('.video-container .poster img');
initBannerVideoSize('.video-container .filter');
initBannerVideoSize('.video-container video');
$(window).on('resize', function() {
scaleVideoContainer();
scaleBannerVideoSize('.video-container .poster img');
scaleBannerVideoSize('.video-container .filter');
scaleBannerVideoSize('.video-container video');
});
});
/** Reusable Functions **/
/********************************************************************/
function scaleVideoContainer() {
var height = $(window).height();
var unitHeight = parseInt(height) + 'px';
$('.homepage-hero-module').css('height',unitHeight);
}
function initBannerVideoSize(element){
$(element).each(function(){
$(this).data('height', $(this).height());
$(this).data('width', $(this).width());
});
scaleBannerVideoSize(element);
}
function scaleBannerVideoSize(element){
var windowWidth = $(window).width(),
windowHeight = $(window).height(),
videoWidth,
videoHeight;
console.log(windowHeight);
$(element).each(function(){
var videoAspectRatio = $(this).data('height')/$(this).data('width'),
windowAspectRatio = windowHeight/windowWidth;
if (videoAspectRatio > windowAspectRatio) {
videoWidth = windowWidth;
videoHeight = videoWidth * videoAspectRatio;
$(this).css({'top' : -(videoHeight - windowHeight) / 2 + 'px', 'margin-left' : 0});
} else {
videoHeight = windowHeight;
videoWidth = videoHeight / videoAspectRatio;
$(this).css({'margin-top' : 0, 'margin-left' : -(videoWidth - windowWidth) / 2 + 'px'});
}
$(this).width(videoWidth).height(videoHeight);
$('.homepage-hero-module .video-container video').addClass('fadeIn animated');
});
}
.homepage-hero-module {
border-right: none;
border-left: none;
position: relative;
}
.no-video .video-container video,
.touch .video-container video {
display: none;
}
.no-video .video-container .poster,
.touch .video-container .poster {
display: block !important;
}
.video-container {
position: relative;
bottom: 0%;
left: 0%;
height: 100%;
width: 100%;
overflow: hidden;
background: #000;
}
.video-container .poster img {
width: 100%;
bottom: 0;
position: absolute;
}
.video-container .title-container {
z-index: 1000;
position: absolute;
top: 35%;
width: 100%;
text-align: center;
color: #fff;
}
.video-container .description .inner {
font-size: 1em;
width: 45%;
margin: 0 auto;
}
.video-container .link {
position: absolute;
bottom: 3em;
width: 100%;
text-align: center;
z-index: 1001;
font-size: 2em;
color: #fff;
}
.video-container .link a {
color: #fff;
}
.video-container video {
position: absolute;
z-index: 0;
bottom: 0;
object-fit: cover;
}
.video-container video.fillWidth {
width: 100%;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<section id="intro" class="parallax-section">
<!-- Main jumbotron for a primary marketing message or call to action -->
<div class="homepage-hero-module">
<div class="video-container">
<div class="title-container">
<div class="headline">
<h1>Welcome to our Company</h1>
</div>
<div class="description">
<div class="inner">Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s</div>
</div>
</div>
<div class="filter"></div>
<video autoplay class="fillWidth">
<source src="http://video.blendertestbuilds.de/download.blender.org/peach/trailer_480p.mov" type="video/mp4" autoplay loop muted />Your browser does not support the video tag. I suggest you upgrade your browser.
<source src="http://video.webmfiles.org/big-buck-bunny_trailer.webm" type="video/webm" autoplay loop muted />Your browser does not support the video tag. I suggest you upgrade your browser.
</video>
<div class="poster hidden">
<img src="images/background.jpg" alt="">
</div>
</div>
</div>
<div class="container" id="content">
<!-- adding this soon -->
</div>
</section>