/*  RESET
-------------------------------------------------------------------------- */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote,
code, em, img, strong, sub, sup, b, i, dl, dt, dd, ol, ul, li, fieldset, form,
label, table, tbody, tfoot, thead, tr, th, td, audio, video, a, hr, button
{ border: 0; font: inherit; font-size: 100%; margin: 0; padding: 0; vertical-align: baseline; }

img { display: block; }

input, select, textarea, button { margin: 0; }
label, button { cursor: pointer; }
input, select { vertical-align: middle; }
input[type="checkbox"] { vertical-align: bottom; }
input[type="radio"] { vertical-align: text-bottom; }
textarea { border: 0; overflow: auto; }
button { background: transparent; }

table { border-collapse: collapse; border-spacing: 0; }

sub, sup { font-size: 75%; line-height: 0; position: relative; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }





/*  ELEMENTS
-------------------------------------------------------------------------- */
html { background: #1a1e24; }
#wrap { width: 970px; min-height: 714px; background: #354149; margin: auto; position: relative;
       -webkit-box-shadow: 1px 0 3px #0c0e11, -1px 0 3px #0c0e11;
          -moz-box-shadow: 1px 0 3px #0c0e11, -1px 0 3px #0c0e11;
               box-shadow: 1px 0 3px #0c0e11, -1px 0 3px #0c0e11; }
.ie body { border: 1px #28323b solid; }
body, input, textarea { color: #fff; font: 13px/normal sans-serif; }
h2, h3, h4, h5 { color: #fff; }
h1 { margin: 7px 24px 0 0; }
h3 { font-size: 25px; margin: 0 0 12px; }
h4 { font-size: 26px; margin: 0 0 6px; }
h5 { font-size: 24px; margin: 0 0 12px; }
h6 { font-size: 18px; margin: 0 0 6px; }
p { font-size: 13px; line-height: 1.45; margin: 0 0 14px; }
ul { font-size: 12px; list-style: none; }
a { color: #8faec2; text-decoration: none; }
a:hover { border-bottom: 1px #8faec2 dotted; }
hr { width: 100%; height: 2px; background: #000; border-bottom: 1px #58646d solid; margin: 25px 0; }
.ie hr { height: 1px; }




/*  GLOBAL
-------------------------------------------------------------------------- */
.icon { display: block; background-image: url('../img/icons.png'); background-repeat: no-repeat; text-indent: -9999px; }
a.icon:hover { border: 0; }

.perfsystem { background-position: -51px -873px; width: 444px; height: 43px; }

#header { height: 59px; background: url('../img/bg/header.jpg') repeat-x; overflow: hidden; padding: 0 39px;
          -webkit-box-shadow: 1px 0 0 #28323b inset, -1px 0 0 #28323b inset;
             -moz-box-shadow: 1px 0 0 #28323b inset, -1px 0 0 #28323b inset;
                 -box-shadow: 1px 0 0 #28323b inset, -1px 0 0 #28323b inset; }
h1 { width: 54px; height: 30px; float: left; }
h2 { width: 249px; height: 43px; background-position: -58px 0; border-left: 1px #000 solid; float: left; padding: 0 0 0 20px;
     -webkit-box-shadow: 0px 0px 4px #ffffff;
        -moz-box-shadow: 0px 0px 4px #ffffff;
             box-shadow: 1px 0 0 #303e4b inset; }
#util { line-height: 17px; margin: 12px 0 0; text-transform: uppercase; }
#util .icon { text-indent: 0; }
#util p { float: right; font-size: 10px; line-height: 17px; padding: 0 10px 0 0; }
#util ul { float: right; }
#util li { border-left: 1px #484d50 solid; float: left; padding: 0 10px; }
#util li:last-of-type { padding-right: 0; }
#util #dl_data { background-position: -481px 0; padding-left: 14px; }
#util a { font-size: 10px; }

#footer_wrap { width: 892px; background: #000; clear: both; overflow: hidden; padding: 11px 39px; position: absolute; bottom: 0; left: 0;
               background: -moz-linear-gradient(top, #000000, #14181c);
               background: -o-linear-gradient(top, #000000, #14181c);
               background: -webkit-gradient(linear,left top,left bottom,color-stop(0, #000000),color-stop(1, #14181c));
               background: -webkit-linear-gradient(#000000, #14181c);
               background: linear-gradient(top, #000000, #14181c);
               -pie-background: linear-gradient(top, #000000, #14181c);
                         /*filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#000000', EndColorStr='#14181c');*/
               -webkit-box-shadow: 1px 0 0 #28323b inset, 0 -1px 0 #28323b inset, -1px 0 0 #28323b inset;
                  -moz-box-shadow: 1px 0 0 #28323b inset, 0 -1px 0 #28323b inset, -1px 0 0 #28323b inset;
                      -box-shadow: 1px 0 0 #28323b inset, 0 -1px 0 #28323b inset, -1px 0 0 #28323b inset;
               behavior: url('htc/pie.htc'); }
#footer #logo { width: 41px; height: 22px; background-position: -238px -45px; float: left; margin: 2px 20px 0 0; }
#footer li { border-left: 1px #374149 solid; float: left; padding: 6px 20px; }
#footer a { color: #fff; font-size: 10px; text-transform: uppercase; }

#content_header { min-height: 348px; }
#content { background-color: #354149; background-image: url('../img/bg/content.jpg'); background-repeat: repeat-x; padding: 46px 40px 120px; overflow: hidden; position: relative;
           -webkit-box-shadow: 0 1px 0 #28323b inset, 1px 0 0 #28323b inset, 0 -1px 0 #28323b inset, -1px 0 0 #28323b inset;
              -moz-box-shadow: 0 1px 0 #28323b inset, 1px 0 0 #28323b inset, 0 -1px 0 #28323b inset, -1px 0 0 #28323b inset;
                  -box-shadow: 0 1px 0 #28323b inset, 1px 0 0 #28323b inset, 0 -1px 0 #28323b inset, -1px 0 0 #28323b inset; }

.en-gb #content { background-position: left -37px !important; }
.en-us #content { background-position: left -37px !important; }
.fr-fr #content { background-position: left -37px !important; }

#content.container { background-image: none; padding: 0; }
.container { padding: 0 40px; }
.container:first-child { padding-top: 46px; }
.container:last-child { padding-bottom: 120px; }

#main { width: 420px; float: left; }
#main p { font-size: 12px !important; }

#download #main { width: 387px; }

#app { position: absolute; top: 15px; }

#modules { border-top: 1px #4a535a solid; padding: 42px 0 0; }

#cols { clear: left; }
.col { width: 28%; border-right: 1px #000 solid; border-left: 1px #4a535a solid; float: left; padding: 0 46px 0 20px; }
.col:first-of-type { border-left: 0; padding-left: 0; }
.col:last-of-type { border-right: 0; padding-right: 0; }




/*  LOGIN
-------------------------------------------------------------------------- */
.login #wrap { background: url('../img/bg/login.jpg') repeat-x; }
.login .container { width: 500px; margin: auto; padding: 36px 0 0; }
.login h3 { width: 146px; height: 76px; background-position: -331px 0; margin: 0 auto 18px; }
.login h4 { font-size: 12px; text-align: center; text-transform: uppercase; }
.login #login { width: 405px; margin: auto; }
.login label { width: 110px; }
.login input { width: 268px; }
.ie7 .login label { float: left; margin: 0 8px 0 0; }
.ie7 .login input { float: left; }

/*  REGION  */
#regions { width: 234px; margin: auto; }
#regions li { margin: 0 0 6px; }
#regions .icon { width: 234px; height: 40px; }
#regions .usa { background-position: 0 -45px; }
#regions .usa:hover { background-position: 0 -89px; }
#regions .usa:active { background-position: 0 -133px; }
#regions .eng { background-position: 0 -177px; }
#regions .eng:hover { background-position: 0 -221px; }
#regions .eng:active { background-position: 0 -265px; }
#regions .fra { background-position: 0 -309px; }
#regions .fra:hover { background-position: 0 -353px; }
#regions .fra:active { background-position: 0 -397px; }
#regions .ger { background-position: 0 -441px; }
#regions .ger:hover { background-position: 0 -485px; }
#regions .ger:active { background-position: 0 -529px; }

/*  LOGIN  */
#sub_login { width: 290px; height: 40px; background-position: -238px -80px; float: right; margin: 0 -2px 8px 0; }
#sub_login:hover { background-position: -238px -124px; }
#sub_login:active { background-position: -238px -168px; }

#error { clear: right; color: #d72d2e; font-size: 11px; font-style: italic; margin: 0 0 0 131px; position: relative; text-shadow: 0 1px 1px rgba(0,0,0,0.6); }
#error:before { content: ""; width: 8px; height: 8px; background: url('../img/icons.png') -283px -45px no-repeat; display: block; margin: -5px 0 0; position: absolute; top: 50%; left: -12px; }

.euro_dd { background: url('../img/dd-europe.png') no-repeat; height: 40px; width: 233px; display: block; text-indent: -999em; }
.euro_dd .opts { display: none; margin-top: 32px; margin-left: 2px; width: 230px; }
.euro_dd .opt { background: url('../img/dd-euro-languages.png') no-repeat; display: block; height: 10px; padding: 8px 20px; }
.euro_dd .opt:hover { background-color: #535c65; border: 0px; }
.euro_dd .opt-gb { background-position: 20px 8px; }
.euro_dd .opt-de { background-position: 20px -47px; }
.euro_dd .opt-fr { background-position: 20px -20px; }

.euro_dd:hover, .euro_dd.active { border: 0; background-position: left -40px; height: 136px; }
.euro_dd:hover .opts, .euro_dd.active .opts { display: block; }

/*  DOWNLOAD
-------------------------------------------------------------------------- */
#download #content { background: url('../img/bg/download.jpg') repeat-x !important; background-position: left -32px !important; }
/* .fr-fr #download #content, .en-us #download #content { background-position: 0 -20px; } */
#download #content_header { min-height: 440px; border-bottom: 1px #000 solid; overflow: hidden; padding: 0 0 42px; }

#download h3 { font-size: 37px; }
#download h3 > span { color: #86a1b3; display: block; font-size: 13px; letter-spacing: 1px; text-transform: uppercase; }

#dl_app { float: left; height: 50px; background: url('../img/btns/btn-large.png') no-repeat top right; margin: 4px 0 -2px 46px; display: block; position: relative; text-decoration: none; text-transform: uppercase; }
#dl_app .cap { height: 50px; width: 46px; display: block; background: url('../img/btns/btn-large-cap.png') top left; position: absolute; left: -46px; }
#dl_app .cap-desktop { height: 50px; width: 46px; display: block; background: url('../img/btns/btn-large-cap-desktop.png') top left; position: absolute; left: -46px; }
#dl_app .cap-apple { height: 50px; width: 46px; display: block; background: url('../img/btns/btn-large-cap-apple.png') top left; position: absolute; left: -46px; }
#dl_app .btn-text { display: inline-block; font-family: 'Gotham Medium'; font-size: 14px; color: #fff; text-shadow: 1px 1px #000; line-height: 46px; padding-right: 60px; min-width: 220px; }


#dl_app:hover { background-position: right -54px; border: 0; }
#dl_app:hover .cap { background-position: left -54px; }
#dl_app:active { background-position: right -108px; }
#dl_app:active .cap { background-position: left -108px; }

.ie7 #dl_app { margin: 0 0 82px 45px; }

.devices-label { clear: left; color: #798a96; font-size: 9px; margin: 0 0 6px; text-transform: uppercase; }
.devices { font-size: 11px; font-style: italic; }
.devices > li { float: left; padding: 0 10px; }
.devices > li:first-child { padding-left: 0; }
.devices > li + li { border-left: 1px #49535a solid; }
.devices a { color: #fff; }
.devices .device-desktop { width: 12px; height: 13px; background: url('../img/icon/desktop.png') center no-repeat; display: inline-block; vertical-align: -2px; }
.devices .device-apple { width: 12px; height: 13px; background: url('../img/icon/apple.png') center no-repeat; display: inline-block; vertical-align: -2px; }
.devices .device-android { width: 12px; height: 13px; background: url('../img/icon/android.png') center no-repeat; display: inline-block; vertical-align: -2px; }

#os { color: #798a96; font-size: 9px; margin: 0 0 86px; text-transform: uppercase; }
#os ul { display: inline; font-style: italic; text-transform: none; }
#os li { display: inline-block; margin: 0 6px 0 0; }
#os a { color: #fff; font-size: 11px; }
#os span.icon { height: 14px; display: inline-block; }
#os #mac span.icon { width: 12px; background-position: -481px -45px; margin: 0 3px -3px 0; }
#os #win span.icon { width: 15px; background-position: -481px -63px; margin: 0 3px -4px 0; }
#os .os_size { border-bottom: 1px #576773 solid; font-size: 10px; }
#os a:hover .os_size { border-bottom: 1px #576773 dotted; }
#os .size { color: #798a96; text-transform: uppercase; }
.ie7 #os { display: none; }

.disclaimer { width: 290px; clear: left; color: #798a96; font-size: 10px; font-style: italic; line-height: 1.25; }
.disclaimer .os { color: #fff; }

#dl_instruct { width: 294px; height: 32px; background-position: 0 -433px; }
#dl_instruct:hover { background-position: 0 -469px; }
#dl_instruct:active { background-position: 0 -505px; }

#download #app { top: 62px; right: -47px; }

#vid { width: 410px; height: 231px; float: left; }
video { background: #000;
        -webkit-border-radius: 2px;
           -moz-border-radius: 2px;
                border-radius: 2px;
        -webkit-box-shadow: 1px 1px 1px #4f5e6a;
           -moz-box-shadow: 1px 1px 1px #4f5e6a;
                box-shadow: 1px 1px 1px #4f5e6a; }
video,
object,
#vid img { width: 410px; height: 231px; }

#training { width: 441px; float: right; position: relative; }
#training img { float: left; margin: 0 18px 0 0; }
/*#download #training_resources { width: 214px; height: 32px; background-position: -237px -374px; position: absolute; right: 0; bottom: 0; }
#download #training_resources:hover { background-position: -237px -410px; }
#download #training_resources:active { background-position: -237px -446px; }*/
.ie7 #download #training_resources { bottom: 14px; }




/*  TRAINING & RESOURCES
-------------------------------------------------------------------------- */
#training_resources h4 { color: #9ba1a6; font-size: 9px; margin-bottom: 4px; text-transform: uppercase; }
#training_resources #content { background: url('../img/bg/training_resources.jpg') repeat-x; }
#training_resources.en-us #content { background-position: left -25px !important; }
#training_resources.en-gb #content { background-position: left -25px !important; }
#training_resources.de-de #content { background-position: left -6px !important; }
#training_resources.fr-fr #content { background-position: left -6px !important; }
#training_resources #content_header { min-height: 405px; }

#back { height: 31px; display: inline-block; background: url('../img/btns/btn-med-left.png') no-repeat top right; margin: 0 0 34px 58px; position: relative; text-transform: uppercase; }
#training_resources #back { margin-left: 18px; }

#back .btn-text { color: #fff; text-shadow: 1px 1px #000; line-height: 27px; padding-left: 11px; padding-right: 20px; display: inline-block; font-weight: bold; font-size: 11px; }
#back .btn-cap { position: absolute; height: 31px; width: 18px; display: inline-block; background: url('../img/btns/btn-med-left-cap.png'); left: -18px; top: 0px; }

#back:hover { border: 0px; background-position: right -35px; }
#back:hover .btn-cap { background-position: left -35px; }

#back:active { border: 0px; background-position: right -70px; }
#back:active .btn-cap { background-position: left -70px; }

#training_resources #content_header p { margin-bottom: 22px; }

#training_resources #content #vids li { float: left; margin: 0 2px 0 0; }
#training_resources #content #vids li:last-of-type { margin-right: 0; }
#vids .icon { width: 205px; height: 32px; }
#vids .one { background-position: 0 -573px; }
#vids .one:hover { background-position: 0 -609px; }
#vids .one:active { background-position: 0 -646px; }
#vids .two { background-position: 0 -681px; }
#vids .two:hover { background-position: 0 -717px; }
#vids .two:active { background-position: 0 -754px; }

#training_resources #app { top: 105px; right: -44px; }

#training_resources #content li { margin: 0 0 12px; }
#training_resources #content li:last-child { margin: 0; }

.btn-training-resources { display: inline-block; height: 32px; padding-right: 26px; padding-left: 12px; background: url('../img/btns/btn-med.png') top left no-repeat; position: relative; }
.btn-training-resources .btn-text { color: #fff; font-size: 11px; text-shadow: 1px 1px #000; line-height: 33px; text-transform: uppercase; font-weight: bold; }
.ie7 .btn-training-resources .btn-text { line-height: 30px; }
.btn-training-resources .btn-cap { display: inline-block; height: 32px; width: 18px; background: url('../img/btns/btn-med-cap.png') top left no-repeat; position: absolute; top: 0px; right: -18px; }

.btn-lg-training-resources { display: inline-block; width: 415px; height: 50px; padding-right: 26px; padding-left: 12px; background: url('../img/btns/btn-training.png') top left no-repeat; position: relative; }
.btn-lg-training-resources:hover { border: 0; text-decoration: none; }
.btn-lg-training-resources .btn-text { color: #fff; font-size: 14px; text-shadow: 1px 1px #000; line-height: 45px; text-transform: uppercase; font-weight: bold; }

/*
.en-us .btn-training-resources { margin-top: 47px; }
.en-gb .btn-training-resources { margin-top: 47px; }
.fr-fr .btn-training-resources { margin-top: 28px; }
.ie .fr-fr .btn-training-resources { margin-top: 24px; }
.de-de .btn-training-resources { margin-top: 11px; }
.ie .de-de .btn-training-resources { margin-top: 6px; }
*/

.btn-training-resources:hover,
.btn-training-resources:hover .btn-cap { border: 0px; background-position: left -36px; }

.btn-training-resources:active,
.btn-training-resources:active .btn-cap { border: 0px; background-position: left -72px; }

#player { width: 640px; height: 480px; }
#modal { display: none; z-index: 9999; width: 640px; height: 480px;
         -webkit-box-shadow: 0 0 90px 5px #000, 0 0 90px #000;
            -moz-box-shadow: 0 0 90px 5px #000, 0 0 90px #000;
                 box-shadow: 0 0 90px 5px #000, 0 0 90px #000; }
#exposeMask { cursor: pointer !important; }




/*  SHAFT OPTIMIZER DATA
-------------------------------------------------------------------------- */
#data #content { background: url('../img/bg/data.jpg') repeat-x; }
#data #content_header { min-height: 310px; }

#data h3 { margin: 0 0 30px; }
#data form { width: 544px; float: left; border-right: 1px #000 solid; padding: 36px 0; position: relative; }
#data label { width: 85px; float: left; margin: 0 10px 0 0; }
#data input { width: 184px; float: left; margin: 0 10px 0 0; }

#sub_filters { width: 204px; height: 36px; background-position: -238px -749px; float: left; }
#sub_filters:hover { background-position: -238px -788px; }
#sub_filters:active { background-position: -238px -827px; }

.btn_wrap { width: 344px; height: 164px; border-left: 1px #535f68 solid; float: left; }
#dl_records { width: 310px; height: 50px; background-position: -238px -587px; float: right; margin: 55px 0 0; }
#dl_records:hover { background-position: -238px -641px; }
#dl_records:active { background-position: -238px -695px; }

#records { width: 100%; color: #8faec2; font-size: 12px; line-height: 26px; }
#records th { color: #fff; text-shadow: 0 1px 1px rgba(0,0,0,0.4); text-transform: uppercase; }
#records th:first-child,
#records th:nth-child(2),
#records th:last-child { text-align: left; }

#records td { text-align: center; }
#records tr td:first-child,
#records tr td:nth-child(2),
#records tr td:last-child { text-align: left; }
#records tr td:last-child { width: 100px; }

#pagination,
#pagination p,
#pagination a { color: #8faec2; font-size: 12px; }
#pagination { margin: 25px 0 0; }
#pagination ul { color: #8faec2; float: left; font-style: italic; }
#pagination li { float: left; margin: 0 4px 0 0 !important; }
#pagination li:last-child { margin: 0 0 0 8px !important; }
#pagination .current { color: #fff; }
#pagination p { line-height: 1.15; float: right; }
#pagination a { color: #6d7e89; }




/*  INSTALLATION
-------------------------------------------------------------------------- */
#installation #content { padding-right: 0; padding-left: 0; }

#installation h3,
#installation p { margin-left: 40px; }

#installation p { margin-bottom: 0; }

#steps { margin: 0 0 80px; overflow: hidden; }
#steps li { float: left; }
#steps a:hover { border: 0; }







/*  FORMS
-------------------------------------------------------------------------- */
fieldset { margin: 0 0 10px; position: relative; }
label { width: 110px; color: #b3c9db; display: inline-block; font-size: 12px; line-height: 36px; text-align: right; text-transform: uppercase; }
input { border: 0; color: #b9cdde; float: right; padding: 10px 9px 9px;
        background: #161b20;
        background: -moz-linear-gradient(top, #13181c, #181e23);
        background: -o-linear-gradient(top, #13181c, #181e23);
        background: -webkit-gradient(linear,left top,left bottom,color-stop(0, #13181c),color-stop(1, #181e23));
        background: -webkit-linear-gradient(#13181c, #181e23);
        background: linear-gradient(top, #13181c, #181e23);
        -pie-background: linear-gradient(top, #13181c, #181e23);
                 /*filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#13181c', EndColorStr='#181e23');*/
        -webkit-border-radius: 4px;
           -moz-border-radius: 4px;
                border-radius: 4px;
        -webkit-box-shadow: 0 1px 3px #000 inset, 0 1px 0 rgba(170,216,255,0.1);
           -moz-box-shadow: 0 1px 3px #000 inset, 0 1px 0 rgba(170,216,255,0.1);
                box-shadow: 0 1px 3px #000 inset, 0 1px 0 rgba(170,216,255,0.1);
        behavior: url('htc/pie.htc'); }
.ie8 input { background: #161b20; padding-top: 10px; behavior: none !important; }

.error:after { content: ""; width: 8px; height: 8px; background: url('../img/icons.png') -283px -45px no-repeat; margin: -5px 0 0; position: absolute; top: 50%; right: -16px; }






/*  WEB FONTS
-------------------------------------------------------------------------- */
@font-face {
    font-family: 'Gotham Book'; font-style: normal; font-weight: normal;
            src: url('fonts/gotham-book.eot');
            src: url('fonts/gotham-book.eot?iefix') format('eot'),
                 url('fonts/gotham-book.woff') format('woff'),
                 url('fonts/gotham-book.ttf') format('truetype'),
                 url('fonts/gotham-book.svg#webfont9BAlZEDD') format('svg');
}
.gotham-book, h3, h4, h5, h6, label, th, #util, #util a { font-family: 'Gotham Book', sans-serif; font-style: normal; font-weight: normal; }

@font-face {
    font-family: 'Gotham Medium'; font-style: normal; font-weight: normal;
            src: url('fonts/gotham-medium.eot');
            src: url('fonts/gotham-medium.eot?iefix') format('eot'),
                 url('fonts/gotham-medium.woff') format('woff'),
                 url('fonts/gotham-medium.ttf') format('truetype'),
                 url('fonts/gotham-medium.svg#webfont1m02VQmu') format('svg');
}
.gotham-med, input, #footer { font-family: 'Gotham Medium', sans-serif; font-style: normal; font-weight: normal; }






/*  ACCESSIBILITY
-------------------------------------------------------------------------- */
a:hover, a:active { outline: none; }




/*  SELECTION
-------------------------------------------------------------------------- */
::-moz-selection{ background: #151b1f; color: #fff; text-shadow: none; }
::selection { background: #151b1f; color: #fff; text-shadow: none; }
a:link { -webkit-tap-highlight-color: #151b1f; }




/*  BROWSER TARGETING
-------------------------------------------------------------------------- */
/*  FF  */
button::-moz-focus-inner { border: 0; padding: 0; }

/*  IE  */
.ie7 img { -ms-interpolation-mode: bicubic; }
.ie7 input[type="checkbox"] { vertical-align: baseline; }




/*  NON-SEMANTIC CLASSES
-------------------------------------------------------------------------- */
/*  CLEARFIX  */
.cf:before,
.cf:after { content: ""; display: table; }
.cf:after { clear: both; }
.ie7 .cf { zoom: 1; }


/*  IMAGE REPLACEMENT  */
.ir { background-repeat: no-repeat; display: block; overflow: hidden; text-align: left; text-indent: -9999px;  }


/*  HIDE  */
.hidden { display: none; visibility: hidden; }
.hidden_vis { width: 1px !important; height: 1px !important; border: 0 !important; clip: rect(0 0 0 0); margin: -1px !important; overflow: hidden !important; padding: 0 !important; position: absolute !important; }






/*  PRINT
-------------------------------------------------------------------------- */
@media print {
    @page { margin: 0.5cm; }
    * { background: transparent !important; color: black !important; text-shadow: none !important;
            filter: none !important;
        -ms-filter: none !important; }
    thead { display: table-header-group; }
    tr, img { page-break-inside: avoid; }
    h2, h3, p { orphans: 3; widows: 3; }
    h2, h3 { page-break-after: avoid; }
    a, a:visited { color: #444 !important; text-decoration: underline; }
    a[href]:after { content: " (" attr(href) ")"; }
    .ir a:after,a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; }
    pre, blockquote { border: 1px solid #999; page-break-inside: avoid; }
    abbr[title]:after { content: " (" attr(title) ")"; }
}




/*
VideoJS Default Styles (http://videojs.com)
Version 2.0.2

REQUIRED STYLES (be careful overriding)
================================================================================ */
/* Box containing video, controls, and download links.
   Will be set to the width of the video element through JS
   If you want to add some kind of frame or special positioning, use another containing element, not video-js-box. */
.video-js-box { text-align: left; position: relative; line-height: 0 !important; margin: 0; padding: 0 !important; border: none !important;  }

/* Video Element */
video.video-js { background-color: #000; position: relative; padding: 0; }

.vjs-flash-fallback { display: block; }

/* Poster Overlay Style */
.video-js-box img.vjs-poster { display: block; position: absolute; left: 0; top: 0; width: 100%; height: 100%; margin: 0; padding: 0; cursor: pointer; }
/* Subtiles Style */
.video-js-box .vjs-subtitles { color: #fff; font-size: 20px; text-align: center; position: absolute; bottom: 40px; left: 0; right: 0; }

/* Fullscreen styles for main elements */
.video-js-box.vjs-fullscreen { position: fixed; left: 0; top: 0; right: 0; bottom: 0; overflow: hidden; z-index: 1000; }
.video-js-box.vjs-fullscreen video.video-js,
.video-js-box.vjs-fullscreen .vjs-flash-fallback { position: relative; top: 0; left: 0; width: 100%; height: 100%; z-index: 1000; }
.video-js-box.vjs-fullscreen img.vjs-poster { z-index: 1001; }
.video-js-box.vjs-fullscreen .vjs-spinner { z-index: 1001; }
.video-js-box.vjs-fullscreen .vjs-controls { z-index: 1003; }
.video-js-box.vjs-fullscreen .vjs-big-play-button { z-index: 1004; }
.video-js-box.vjs-fullscreen .vjs-subtitles { z-index: 1004; }

/* Styles Loaded Check */
.vjs-styles-check { height: 5px; position: absolute; }
/* Controls Below Video */
.video-js-box.vjs-controls-below .vjs-controls { position: relative; opacity: 1; background-color: #000; }
.video-js-box.vjs-controls-below .vjs-subtitles { bottom: 75px; } /* Account for height of controls below video */

/* DEFAULT SKIN (override in another file)
================================================================================
Using all CSS to draw the controls. Images could be used if desired.
Instead of editing this file, I recommend creating your own skin CSS file to be included after this file,
so you can upgrade to newer versions easier. */

/* Controls Layout
  Using absolute positioning to position controls */
.video-js-box .vjs-controls {
  position: absolute; margin: 0; opacity: 0.85; color: #fff;
  display: none; /* Start hidden */
  left: 0; right: 0; /* 100% width of video-js-box */
  width: 100%;
  bottom: 0px; /* Distance from the bottom of the box/video. Keep 0. Use height to add more bottom margin. */
  height: 35px; /* Including any margin you want above or below control items */
  padding: 0; /* Controls are absolutely position, so no padding necessary */
}

.video-js-box .vjs-controls > div { /* Direct div children of control bar */
  position: absolute; /* Use top, bottom, left, and right to specifically position the control. */
  text-align: center; margin: 0; padding: 0;
  height: 25px; /* Default height of individual controls */
  top: 5px; /* Top margin to put space between video and controls when controls are below */

  /* CSS Background Gradients
     Using to give the aqua-ish look. */
  /* Default */ background-color: #0B151A;
  /* Webkit  */ background: #1F3744 -webkit-gradient(linear, left top, left bottom, from(#0B151A), to(#1F3744)) left 12px;
  /* Firefox */ background: #1F3744 -moz-linear-gradient(top,  #0B151A,  #1F3744) left 12px;

  /* CSS Curved Corners */
  border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px;

  /* CSS Shadows */
  box-shadow: 1px 1px 2px #000; -webkit-box-shadow: 1px 1px 2px #000; -moz-box-shadow: 1px 1px 2px #000;
}

/* Placement of Control Items
   - Left side of pogress bar, use left & width
   - Rigth side of progress bar, use right & width
   - Expand with the video (like progress bar) use left & right */
.vjs-controls > div.vjs-play-control       { left: 5px;   width: 25px;  }
.vjs-controls > div.vjs-progress-control   { left: 35px;  right: 165px; } /* Using left & right so it expands with the width of the video */
.vjs-controls > div.vjs-time-control       { width: 75px; right: 90px;  } /* Time control and progress bar are combined to look like one */
.vjs-controls > div.vjs-volume-control     { width: 50px; right: 35px;  }
.vjs-controls > div.vjs-fullscreen-control { width: 25px; right: 5px;   }

/* Removing curved corners on progress control and time control to join them. */
.vjs-controls > div.vjs-progress-control {
  border-top-right-radius: 0; -webkit-border-top-right-radius: 0; -moz-border-radius-topright: 0;
  border-bottom-right-radius: 0; -webkit-border-bottom-right-radius: 0; -moz-border-radius-bottomright: 0;
}
.vjs-controls > div.vjs-time-control {
  border-top-left-radius: 0; -webkit-border-top-left-radius: 0; -moz-border-radius-topleft: 0;
  border-bottom-left-radius: 0; -webkit-border-bottom-left-radius: 0; -moz-border-radius-bottomleft: 0;
}

/* Play/Pause
-------------------------------------------------------------------------------- */
.vjs-play-control { cursor: pointer !important; }
/* Play Icon */
.vjs-play-control span { display: block; font-size: 0; line-height: 0; }
.vjs-paused .vjs-play-control span {
  width: 0; height: 0; margin: 8px 0 0 8px;
  /* Drawing the play triangle with borders - http://www.infimum.dk/HTML/slantinfo.html */
  border-left: 10px solid #fff; /* Width & Color of play icon */
  /* Height of play icon is total top & bottom border widths. Color is transparent. */
  border-top: 5px solid rgba(0,0,0,0); border-bottom: 5px solid rgba(0,0,0,0);
}
.vjs-playing .vjs-play-control span {
  width: 3px; height: 10px; margin: 8px auto 0;
  /* Drawing the pause bars with borders */
  border-top: 0px; border-left: 3px solid #fff; border-bottom: 0px; border-right: 3px solid #fff;
}

/* Progress
-------------------------------------------------------------------------------- */
.vjs-progress-holder { /* Box containing play and load progresses */
  position: relative; padding: 0; overflow:hidden; cursor: pointer !important;
  height: 9px; border: 1px solid #777;
  margin: 7px 1px 0 5px; /* Placement within the progress control item */
  border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px;
}
.vjs-progress-holder div { /* Progress Bars */
  position: absolute; display: block; width: 0; height: 9px; margin: 0; padding: 0;
  border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px;
}
.vjs-play-progress {
  /* CSS Gradient */
  /* Default */ background: #fff;
  /* Webkit  */ background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#777));
  /* Firefox */ background: -moz-linear-gradient(top,  #fff,  #777);
}
.vjs-load-progress {
  opacity: 0.8;
  /* CSS Gradient */
  /* Default */ background-color: #555;
  /* Webkit  */ background: -webkit-gradient(linear, left top, left bottom, from(#555), to(#aaa));
  /* Firefox */ background: -moz-linear-gradient(top,  #555,  #aaa);
}

/* Time Display
-------------------------------------------------------------------------------- */
.vjs-controls .vjs-time-control { font-size: 10px; line-height: 1; font-weight: normal; font-family: Helvetica, Arial, sans-serif; }
.vjs-controls .vjs-time-control span { line-height: 25px; /* Centering vertically */ }

/* Volume
-------------------------------------------------------------------------------- */
.vjs-volume-control { cursor: pointer !important; }
.vjs-volume-control div { display: block; margin: 0 5px 0 5px; padding: 4px 0 0 0; }
/* Drawing the volume icon using 6 span elements */
.vjs-volume-control div span { /* Individual volume bars */
  float: left; padding: 0;
  margin: 0 2px 0 0; /* Space between */
  width: 5px; height: 0px; /* Total height is height + bottom border */
  border-bottom: 18px solid #555; /* Default (off) color and height of visible portion */
}
.vjs-volume-control div span.vjs-volume-level-on { border-color: #fff; /* Volume on bar color */ }
/* Creating differnt bar heights through height (transparent) and bottom border (visible). */
.vjs-volume-control div span:nth-child(1) { border-bottom-width: 2px; height: 16px; }
.vjs-volume-control div span:nth-child(2) { border-bottom-width: 4px; height: 14px; }
.vjs-volume-control div span:nth-child(3) { border-bottom-width: 7px; height: 11px; }
.vjs-volume-control div span:nth-child(4) { border-bottom-width: 10px; height: 8px; }
.vjs-volume-control div span:nth-child(5) { border-bottom-width: 14px; height: 4px; }
.vjs-volume-control div span:nth-child(6) { margin-right: 0; }

/* Fullscreen
-------------------------------------------------------------------------------- */
.vjs-fullscreen-control { cursor: pointer !important; }
.vjs-fullscreen-control div {
  padding: 0; text-align: left; vertical-align: top; cursor: pointer !important;
  margin: 5px 0 0 5px; /* Placement within the fullscreen control item */
  width: 20px; height: 20px;
}
/* Drawing the fullscreen icon using 4 span elements */
.vjs-fullscreen-control div span { float: left; margin: 0; padding: 0; font-size: 0; line-height: 0; width: 0; text-align: left; vertical-align: top; }
.vjs-fullscreen-control div span:nth-child(1) { /* Top-left triangle */
  margin-right: 3px; /* Space between top-left and top-right */
  margin-bottom: 3px; /* Space between top-left and bottom-left */
  border-top: 6px solid #fff; /* Height and color */
  border-right: 6px solid rgba(0,0,0,0);  /* Width */
}
.vjs-fullscreen-control div span:nth-child(2) { border-top: 6px solid #fff; border-left: 6px solid rgba(0,0,0,0); }
.vjs-fullscreen-control div span:nth-child(3) { clear: both; margin: 0 3px 0 0; border-bottom: 6px solid #fff; border-right: 6px solid rgba(0,0,0,0); }
.vjs-fullscreen-control div span:nth-child(4) { border-bottom: 6px solid #fff; border-left: 6px solid rgba(0,0,0,0); }
/* Icon when video is in fullscreen mode */
.vjs-fullscreen .vjs-fullscreen-control div span:nth-child(1) { border: none; border-bottom: 6px solid #fff; border-left: 6px solid rgba(0,0,0,0); }
.vjs-fullscreen .vjs-fullscreen-control div span:nth-child(2) { border: none; border-bottom: 6px solid #fff; border-right: 6px solid rgba(0,0,0,0); }
.vjs-fullscreen .vjs-fullscreen-control div span:nth-child(3) { border: none; border-top: 6px solid #fff; border-left: 6px solid rgba(0,0,0,0); }
.vjs-fullscreen .vjs-fullscreen-control div span:nth-child(4) { border: none; border-top: 6px solid #fff; border-right: 6px solid rgba(0,0,0,0); }

/* Download Links - Used for browsers that don't support any video.
---------------------------------------------------------*/
.vjs-no-video { font-size: small; line-height: 1.5; }

/* Big Play Button (at start)
---------------------------------------------------------*/
div.vjs-big-play-button {
  display: none; /* Start hidden */ z-index: 2;
  position: absolute; top: 50%; left: 50%; width: 80px; height: 80px; margin: -43px 0 0 -43px; text-align: center; vertical-align: center; cursor: pointer !important;
  border: 3px solid #fff; opacity: 0.9;
  border-radius: 20px; -webkit-border-radius: 20px; -moz-border-radius: 20px;

  /* CSS Background Gradients */
  /* Default */ background-color: #0B151A;
  /* Webkit  */ background: #1F3744 -webkit-gradient(linear, left top, left bottom, from(#0B151A), to(#1F3744)) left 40px;
  /* Firefox */ background: #1F3744 -moz-linear-gradient(top,  #0B151A,  #1F3744) left 40px;

  /* CSS Shadows */
  box-shadow: 4px 4px 8px #000; -webkit-box-shadow: 4px 4px 8px #000; -moz-box-shadow: 4px 4px 8px #000;
}
div.vjs-big-play-button:hover {
  box-shadow: 0px 0px 80px #fff; -webkit-box-shadow: 0px 0px 80px #fff; -moz-box-shadow: 0px 0px 80px #fff;
}

div.vjs-big-play-button span {
  display: block; font-size: 0; line-height: 0;
  width: 0; height: 0; margin: 20px 0 0 23px;
  /* Drawing the play triangle with borders - http://www.infimum.dk/HTML/slantinfo.html */
  border-left: 40px solid #fff; /* Width & Color of play icon */
  /* Height of play icon is total top & bottom border widths. Color is transparent. */
  border-top: 20px solid rgba(0,0,0,0); border-bottom: 20px solid rgba(0,0,0,0);
}

/* Spinner Styles
---------------------------------------------------------*/
/* CSS Spinners by Kilian Valkhof - http://kilianvalkhof.com/2010/css-xhtml/css3-loading-spinners-without-images/ */
.vjs-spinner { display: none; position: absolute; top: 50%; left: 50%; width: 100px; height: 100px; z-index: 1; margin: -50px 0 0 -50px;
  /* Scaling makes the circles look smoother. */
  transform: scale(0.5); -webkit-transform:scale(0.5); -moz-transform:scale(0.5);
}
/* Spinner circles */
.vjs-spinner div { position:absolute; left: 40px; top: 40px; width: 20px; height: 20px; background: #fff;
  border-radius: 20px; -webkit-border-radius: 20px; -moz-border-radius: 20px;
  border: 1px solid #ccc; /* Added border so can be visible on white backgrounds */
}
/* Each circle */
.vjs-spinner div:nth-child(1) { opacity: 0.12; transform: rotate(000deg) translate(0, -40px) scale(0.1); -webkit-transform: rotate(000deg) translate(0, -40px) scale(0.1); -moz-transform: rotate(000deg) translate(0, -40px) scale(0.1); }
.vjs-spinner div:nth-child(2) { opacity: 0.25; transform: rotate(045deg) translate(0, -40px) scale(0.2); -webkit-transform: rotate(045deg) translate(0, -40px) scale(0.2); -moz-transform: rotate(045deg) translate(0, -40px) scale(0.2); }
.vjs-spinner div:nth-child(3) { opacity: 0.37; transform: rotate(090deg) translate(0, -40px) scale(0.4); -webkit-transform: rotate(090deg) translate(0, -40px) scale(0.4); -moz-transform: rotate(090deg) translate(0, -40px) scale(0.4); }
.vjs-spinner div:nth-child(4) { opacity: 0.50; transform: rotate(135deg) translate(0, -40px) scale(0.6); -webkit-transform: rotate(135deg) translate(0, -40px) scale(0.6); -moz-transform: rotate(135deg) translate(0, -40px) scale(0.6); }
.vjs-spinner div:nth-child(5) { opacity: 0.62; transform: rotate(180deg) translate(0, -40px) scale(0.8); -webkit-transform: rotate(180deg) translate(0, -40px) scale(0.8); -moz-transform: rotate(180deg) translate(0, -40px) scale(0.8); }
.vjs-spinner div:nth-child(6) { opacity: 0.75; transform: rotate(225deg) translate(0, -40px) scale(1.0); -webkit-transform: rotate(225deg) translate(0, -40px) scale(1.0); -moz-transform: rotate(225deg) translate(0, -40px) scale(1.0); }
.vjs-spinner div:nth-child(7) { opacity: 0.87; transform: rotate(270deg) translate(0, -40px) scale(1.1); -webkit-transform: rotate(270deg) translate(0, -40px) scale(1.1); -moz-transform: rotate(270deg) translate(0, -40px) scale(1.1); }
.vjs-spinner div:nth-child(8) { opacity: 1.00; transform: rotate(315deg) translate(0, -40px) scale(1.3); -webkit-transform: rotate(315deg) translate(0, -40px) scale(1.3); -moz-transform: rotate(315deg) translate(0, -40px) scale(1.3); }


.resource-btns { display: block; margin-bottom: 10px; text-decoration: none; }
.resource-btns:hover { border: none !important; }


