@charset "UTF-8";
@font-face {
  font-family: 'PT Sans';
  src: url(../fonts/PTSans.woff) format("woff"); }
@font-face {
  font-weight: bold;
  font-family: 'PT Sans';
  src: url(../fonts/PTSans.Bold.woff) format("woff"); }
@font-face {
  font-style: italic;
  font-family: 'PT Sans';
  src: url(../fonts/PTSans.Italic.woff) format("woff"); }
@font-face {
  font-style: italic;
  font-weight: bold;
  font-family: 'PT Sans';
  src: url(../fonts/PTSans.Bold.Italic.woff) format("woff"); }
@font-face {
  font-family: 'PT Sans Narrow';
  font-weight: bold;
  src: url(../fonts/PTSans.Narrow.Bold.woff) format("woff"); }
@font-face {
  font-family: 'PT Mono';
  src: url(../fonts/PTMono.woff) format("woff"); }
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

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

body {
  counter-reset: slide;
  font: 25px/2 'PT Sans', sans-serif; }
  @media print {
    body {
      text-rendering: geometricPrecision; } }

a {
  color: #4B86C2;
  background: linear-gradient(to top, currentColor, currentColor 0.09em, transparent 0.09em, transparent) repeat-x;
  text-decoration: none; }

.caption {
  display: none;
  margin: 0 0 50px;
  color: #3C3D40;
  text-shadow: 0 1px 1px #8D8E90; }
  .caption h1 {
    font: bold 50px/1 'PT Sans Narrow', sans-serif; }
  .caption a {
    text-shadow: 0 -1px 1px #1F3F60;
    background: none; }
    .caption a:hover {
      color: #5e93c8; }

.badge {
  position: absolute;
  top: 0;
  right: 0;
  display: none;
  overflow: hidden;
  visibility: hidden;
  width: 11em;
  height: 11em;
  line-height: 2.5;
  font-size: 15px; }

.badge a {
  position: absolute;
  bottom: 50%;
  right: -50%;
  left: -50%;
  visibility: visible;
  background: #4B86C2;
  box-shadow: 0 0 1em rgba(0, 0, 0, 0.3);
  color: #FFF;
  text-decoration: none;
  text-align: center;
  transform-origin: 50% 100%;
  transform: rotate(45deg) translateY(-1em); }
  .badge a:hover {
    background: #568ec6; }

.live-region {
  display: none; }

.slide {
  position: relative;
  width: 1024px;
  height: 640px;
  background: #FFF;
  color: #000;
  -webkit-print-color-adjust: exact;
  -webkit-text-size-adjust: none;
  -moz-text-size-adjust: none;
  -ms-text-size-adjust: none; }
  @media print {
    .slide {
      page-break-before: always; } }
  .slide:after {
    position: absolute;
    top: 0;
    right: 119px;
    padding: 20px 0 0;
    width: 50px;
    height: 80px;
    background: url(../images/ribbon.svg) no-repeat;
    color: #FFF;
    counter-increment: slide;
    content: counter(slide);
    text-align: center;
    font-size: 20px; }
  .slide > div {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    padding: 105px 120px 0;
    width: 784px;
    height: 535px; }

.slide h2 {
  margin: 0 0 37px;
  color: #666;
  font: bold 50px/1 'PT Sans Narrow', sans-serif; }
.slide p {
  margin: 0 0 50px; }
.slide p.note {
  color: #999; }
.slide b, .slide strong {
  font-weight: bold; }
.slide i, .slide em {
  font-style: italic; }
.slide code, .slide kbd, .slide mark, .slide samp {
  padding: 3px 8px;
  border-radius: 8px;
  color: #000; }
.slide kbd, .slide code, .slide samp {
  background: rgba(0, 0, 0, 0.07);
  color: #000;
  line-height: 1;
  font-family: 'PT Mono', monospace; }
.slide mark {
  background: #FAFAA2; }
.slide sub, .slide sup {
  position: relative;
  line-height: 0;
  font-size: 75%; }
.slide sub {
  bottom: -0.25em; }
.slide sup {
  top: -0.5em; }
.slide blockquote {
  font-style: italic; }
  .slide blockquote:before {
    position: absolute;
    margin: -16px 0 0 -80px;
    color: #CCC;
    font: 200px/1 'PT Sans', sans-serif;
    content: '\201C'; }
  .slide blockquote + figcaption {
    margin: -50px 0 50px;
    font-style: italic;
    font-weight: bold; }
.slide ol, .slide ul {
  margin: 0 0 50px;
  counter-reset: list; }
  .slide ol li, .slide ul li {
    text-indent: -2em; }
    .slide ol li:before, .slide ul li:before {
      display: inline-block;
      width: 2em;
      color: #BBB;
      text-align: right; }
  .slide ol ol, .slide ol ul, .slide ul ol, .slide ul ul {
    margin: 0 0 0 2em; }
.slide ul > li:before {
  content: '\2022\00A0\00A0'; }
.slide ul > li:lang(ru):before {
  content: '\2014\00A0\00A0'; }
.slide ol > li:before {
  counter-increment: list;
  content: counter(list) ". "; }
.slide pre {
  margin: 0 0 49px;
  padding: 1px 0 0;
  counter-reset: code;
  white-space: normal;
  tab-size: 4; }
  .slide pre code {
    display: block;
    padding: 0;
    background: none;
    white-space: pre;
    line-height: 2; }
    .slide pre code:before {
      position: absolute;
      margin-left: -50px;
      color: #BBB;
      counter-increment: code;
      content: counter(code,decimal-leading-zero) "."; }
    .slide pre code:only-child:before {
      content: ''; }
  .slide pre mark.important {
    background: #C00;
    color: #FFF; }
  .slide pre mark.comment {
    padding: 0;
    background: none;
    color: #999; }
.slide table {
  margin: 0 0 50px;
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0; }
  .slide table th, .slide table td {
    background: linear-gradient(to top, #BBB, #BBB 0.055em, transparent 0.055em, transparent) repeat-x; }
  .slide table th {
    text-align: left;
    font-weight: bold; }
  .slide table.striped tr:nth-child(even) {
    background: #EEE; }
.slide.cover, .slide.shout {
  z-index: 1; }
  .slide.cover:after, .slide.shout:after {
    visibility: hidden; }
.slide.cover {
  background: #000; }
  .slide.cover img, .slide.cover svg, .slide.cover video,
  .slide.cover object, .slide.cover canvas, .slide.cover iframe {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1; }
  .slide.cover.w img, .slide.cover.w svg, .slide.cover.w video,
  .slide.cover.w object, .slide.cover.w canvas, .slide.cover.w iframe {
    top: 50%;
    width: 100%;
    transform: translateY(-50%); }
  .slide.cover.h img, .slide.cover.h svg, .slide.cover.h video,
  .slide.cover.h object, .slide.cover.h canvas, .slide.cover.h iframe {
    left: 50%;
    height: 100%;
    transform: translateX(-50%); }
  .slide.cover.w.h img, .slide.cover.w.h svg, .slide.cover.w.h video,
  .slide.cover.w.h object, .slide.cover.w.h canvas, .slide.cover.w.h iframe {
    top: 0;
    left: 0;
    transform: none; }
.slide.shout h2 {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  text-align: center;
  line-height: 1;
  font-size: 150px;
  transform: translateY(-50%); }
  .slide.shout h2 a {
    background: linear-gradient(to top, currentColor, currentColor 0.11em, transparent 0.11em, transparent) repeat-x; }
.slide .place {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }
  .slide .place.t.l, .slide .place.t.r, .slide .place.b.r, .slide .place.b.l {
    transform: none; }
  .slide .place.t, .slide .place.b {
    transform: translate(-50%, 0); }
  .slide .place.l, .slide .place.r {
    transform: translate(0, -50%); }
  .slide .place.t, .slide .place.t.l, .slide .place.t.r {
    top: 0; }
  .slide .place.r {
    right: 0;
    left: auto; }
  .slide .place.b, .slide .place.b.r, .slide .place.b.l {
    top: auto;
    bottom: 0; }
  .slide .place.l {
    left: 0; }
.slide footer {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -640px;
  z-index: 1;
  display: none;
  padding: 20px 120px 4px;
  background: #FAFAA2;
  box-shadow: 0 0 0 2px #f0f0ac inset;
  transition: bottom 0.3s; }
  .slide footer p {
    margin: 0 0 16px; }
  .slide footer mark {
    background: rgba(255, 255, 255, 0.7); }
.slide:hover footer {
  bottom: 0; }

@media screen {
  .list {
    position: absolute;
    clip: rect(0, auto, auto, 0);
    padding: 80px 0 40px 100px;
    background: #585A5E url(../images/linen.png); } }
  @media screen and (-webkit-min-device-pixel-ratio: 2), screen and (min-resolution: 192dpi) {
    .list {
      background-image: url(../images/linen@2x.png);
      background-size: 256px; } }
@media screen {
    .list .caption,
    .list .badge {
      display: block; }
    .list .slide {
      float: left;
      margin: 0 -412px -220px 0;
      transform-origin: 0 0;
      transform: scale(0.5); } }
    @media screen and (max-width: 1324px) {
      .list .slide {
        margin: 0 -688px -400px 0;
        transform: scale(0.25); } }
@media screen {
      .list .slide:before {
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        width: 512px;
        height: 320px;
        box-shadow: 0 0 30px rgba(0, 0, 0, 0.005), 0 20px 50px rgba(42, 43, 45, 0.6);
        border-radius: 2px;
        content: '';
        transform-origin: 0 0;
        transform: scale(2); } }
      @media screen and (max-width: 1324px) {
        .list .slide:before {
          width: 256px;
          height: 160px;
          transform: scale(4); } }
@media screen {
      .list .slide:after {
        top: auto;
        right: auto;
        bottom: -80px;
        left: 120px;
        padding: 0;
        width: auto;
        height: auto;
        background: none;
        color: #3C3D40;
        text-shadow: 0 1px 1px #8D8E90;
        font-weight: bold;
        transform-origin: 0 0;
        transform: scale(2); } }
      @media screen and (max-width: 1324px) {
        .list .slide:after {
          bottom: -104px;
          transform: scale(4); } }
@media screen {
      .list .slide:hover:before {
        box-shadow: 0 0 0 10px rgba(42, 43, 45, 0.3), 0 20px 50px rgba(42, 43, 45, 0.6); }
      .list .slide:target:before {
        box-shadow: 0 0 0 1px #376da3, 0 0 0 10px #4B86C2, 0 20px 50px rgba(42, 43, 45, 0.6); } }
      @media screen and (max-width: 1324px) {
        .list .slide:target:before {
          box-shadow: 0 0 0 1px #376da3, 0 0 0 10px #4B86C2, 0 20px 50px rgba(42, 43, 45, 0.6); } }
@media screen {
      .list .slide:target:after {
        text-shadow: 0 1px 1px rgba(42, 43, 45, 0.6);
        color: #4B86C2; }
      .list .slide > div:before {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 2;
        content: ''; }
      .list .slide.cover:after, .list .slide.shout:after {
        visibility: visible; }
      .list .slide footer {
        display: block; }

  .full {
    position: absolute;
    top: 50%;
    left: 50%;
    overflow: hidden;
    margin: -320px 0 0 -512px;
    width: 1024px;
    height: 640px;
    background: #000; }
    .full.debug:after {
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      z-index: 2;
      background: url(../images/grid-16x10.svg) no-repeat;
      content: ''; }
    .full .live-region {
      position: absolute;
      clip: rect(0 0 0 0);
      overflow: hidden;
      margin: -1px;
      padding: 0;
      width: 1px;
      height: 1px;
      border: none;
      display: block; }
    .full .slide {
      position: absolute;
      top: 0;
      left: 0;
      margin-left: 150%; }
      .full .slide .next {
        visibility: hidden; }
        .full .slide .next.active {
          visibility: visible; }
      .full .slide:target {
        margin: 0; }
      .full .slide.shout.grow h2, .full .slide.shout.shrink h2 {
        opacity: 0;
        transition: all 0.4s ease-out; }
      .full .slide.shout.grow:target h2, .full .slide.shout.shrink:target h2 {
        opacity: 1;
        transform: scale(1) translateY(-50%); }
      .full .slide.shout.grow h2 {
        transform: scale(0.1) translateY(-50%); }
      .full .slide.shout.shrink h2 {
        transform: scale(10) translateY(-50%); }
    .full .progress {
      position: absolute;
      right: 0;
      bottom: 0;
      left: 0;
      overflow: hidden;
      height: 10px;
      z-index: 1; }
      .full .progress div {
        position: absolute;
        left: -20px;
        top: -10px;
        width: 0;
        height: 0;
        border: 10px solid transparent;
        border-bottom-color: #4B86C2;
        transition: width 0.2s linear; }
        .full .progress div[style*='100%'] {
          left: 0; } }
@page {
  margin: 0;
  size: 1024px 640px; }

/*# sourceMappingURL=screen.css.map */
