reveal.css 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215
  1. @charset "UTF-8";
  2. /*!
  3. * reveal.js
  4. * http://lab.hakim.se/reveal-js
  5. * MIT licensed
  6. *
  7. * Copyright (C) 2011-2012 Hakim El Hattab, http://hakim.se
  8. */
  9. /*********************************************
  10. * RESET STYLES
  11. *********************************************/
  12. html, body, .reveal div, .reveal span, .reveal applet, .reveal object, .reveal iframe,
  13. .reveal h1, .reveal h2, .reveal h3, .reveal h4, .reveal h5, .reveal h6, .reveal p, .reveal blockquote, .reveal pre,
  14. .reveal a, .reveal abbr, .reveal acronym, .reveal address, .reveal big, .reveal cite, .reveal code,
  15. .reveal del, .reveal dfn, .reveal em, .reveal img, .reveal ins, .reveal kbd, .reveal q, .reveal s, .reveal samp,
  16. .reveal small, .reveal strike, .reveal strong, .reveal sub, .reveal sup, .reveal tt, .reveal var,
  17. .reveal b, .reveal u, .reveal i, .reveal center,
  18. .reveal dl, .reveal dt, .reveal dd, .reveal ol, .reveal ul, .reveal li,
  19. .reveal fieldset, .reveal form, .reveal label, .reveal legend,
  20. .reveal table, .reveal caption, .reveal tbody, .reveal tfoot, .reveal thead, .reveal tr, .reveal th, .reveal td,
  21. .reveal article, .reveal aside, .reveal canvas, .reveal details, .reveal embed,
  22. .reveal figure, .reveal figcaption, .reveal footer, .reveal header, .reveal hgroup,
  23. .reveal menu, .reveal nav, .reveal output, .reveal ruby, .reveal section, .reveal summary,
  24. .reveal time, .reveal mark, .reveal audio, video {
  25. margin: 0;
  26. padding: 0;
  27. border: 0;
  28. font-size: 100%;
  29. font: inherit;
  30. vertical-align: baseline;
  31. }
  32. .reveal article, .reveal aside, .reveal details, .reveal figcaption, .reveal figure,
  33. .reveal footer, .reveal header, .reveal hgroup, .reveal menu, .reveal nav, .reveal section {
  34. display: block;
  35. }
  36. /*********************************************
  37. * GLOBAL STYLES
  38. *********************************************/
  39. html,
  40. body {
  41. width: 100%;
  42. height: 100%;
  43. overflow: hidden;
  44. }
  45. body {
  46. position: relative;
  47. line-height: 1;
  48. }
  49. ::selection {
  50. background: #FF5E99;
  51. color: #fff;
  52. text-shadow: none;
  53. }
  54. @media screen and (max-width: 900px), (max-height: 600px) {
  55. .reveal .slides {
  56. font-size: 0.82em;
  57. }
  58. }
  59. @media screen and (max-width: 700px), (max-height: 400px) {
  60. .reveal .slides {
  61. font-size: 0.66em;
  62. }
  63. }
  64. /*********************************************
  65. * HEADERS
  66. *********************************************/
  67. .reveal h1 { font-size: 3.77em; }
  68. .reveal h2 { font-size: 2.11em; }
  69. .reveal h3 { font-size: 1.55em; }
  70. .reveal h4 { font-size: 1em; }
  71. /*********************************************
  72. * VIEW FRAGMENTS
  73. *********************************************/
  74. .reveal .slides section .fragment {
  75. opacity: 0;
  76. -webkit-transition: all .2s ease;
  77. -moz-transition: all .2s ease;
  78. -ms-transition: all .2s ease;
  79. -o-transition: all .2s ease;
  80. transition: all .2s ease;
  81. }
  82. .reveal .slides section .fragment.visible {
  83. opacity: 1;
  84. }
  85. .reveal .slides section .fragment.grow {
  86. opacity: 1;
  87. }
  88. .reveal .slides section .fragment.grow.visible {
  89. -webkit-transform: scale( 1.3 );
  90. -moz-transform: scale( 1.3 );
  91. -ms-transform: scale( 1.3 );
  92. -o-transform: scale( 1.3 );
  93. transform: scale( 1.3 );
  94. }
  95. .reveal .slides section .fragment.shrink {
  96. opacity: 1;
  97. }
  98. .reveal .slides section .fragment.shrink.visible {
  99. -webkit-transform: scale( 0.7 );
  100. -moz-transform: scale( 0.7 );
  101. -ms-transform: scale( 0.7 );
  102. -o-transform: scale( 0.7 );
  103. transform: scale( 0.7 );
  104. }
  105. .reveal .slides section .fragment.roll-in {
  106. opacity: 0;
  107. -webkit-transform: rotateX( 90deg );
  108. -moz-transform: rotateX( 90deg );
  109. -ms-transform: rotateX( 90deg );
  110. -o-transform: rotateX( 90deg );
  111. transform: rotateX( 90deg );
  112. }
  113. .reveal .slides section .fragment.roll-in.visible {
  114. opacity: 1;
  115. -webkit-transform: rotateX( 0 );
  116. -moz-transform: rotateX( 0 );
  117. -ms-transform: rotateX( 0 );
  118. -o-transform: rotateX( 0 );
  119. transform: rotateX( 0 );
  120. }
  121. .reveal .slides section .fragment.fade-out {
  122. opacity: 1;
  123. }
  124. .reveal .slides section .fragment.fade-out.visible {
  125. opacity: 0;
  126. }
  127. .reveal .slides section .fragment.highlight-red,
  128. .reveal .slides section .fragment.highlight-green,
  129. .reveal .slides section .fragment.highlight-blue {
  130. opacity: 1;
  131. }
  132. .reveal .slides section .fragment.highlight-red.visible {
  133. color: #ff2c2d
  134. }
  135. .reveal .slides section .fragment.highlight-green.visible {
  136. color: #17ff2e;
  137. }
  138. .reveal .slides section .fragment.highlight-blue.visible {
  139. color: #1b91ff;
  140. }
  141. /*********************************************
  142. * DEFAULT ELEMENT STYLES
  143. *********************************************/
  144. .reveal img {
  145. /* preserve aspect ratio and scale image so it's bound within the section */
  146. max-width: 100%;
  147. max-height: 100%;
  148. }
  149. .reveal strong,
  150. .reveal b {
  151. font-weight: bold;
  152. }
  153. .reveal em,
  154. .reveal i {
  155. font-style: italic;
  156. }
  157. .reveal ol,
  158. .reveal ul {
  159. display: inline-block;
  160. text-align: left;
  161. margin: 0 0 0 1em;
  162. }
  163. .reveal ol {
  164. list-style-type: decimal;
  165. }
  166. .reveal ul {
  167. list-style-type: disc;
  168. }
  169. .reveal ul ul {
  170. list-style-type: square;
  171. }
  172. .reveal ul ul ul {
  173. list-style-type: circle;
  174. }
  175. .reveal ul ul,
  176. .reveal ul ol,
  177. .reveal ol ol,
  178. .reveal ol ul {
  179. display: block;
  180. margin-left: 40px;
  181. }
  182. .reveal p {
  183. margin-bottom: 10px;
  184. line-height: 1.2em;
  185. }
  186. .reveal q,
  187. .reveal blockquote {
  188. quotes: none;
  189. }
  190. .reveal blockquote {
  191. display: block;
  192. position: relative;
  193. width: 70%;
  194. margin: 5px auto;
  195. padding: 5px;
  196. font-style: italic;
  197. background: rgba(255, 255, 255, 0.05);
  198. box-shadow: 0px 0px 2px rgba(0,0,0,0.2);
  199. }
  200. .reveal blockquote:before {
  201. content: '\201C';
  202. }
  203. .reveal blockquote:after {
  204. content: '\201D';
  205. }
  206. .reveal q {
  207. font-style: italic;
  208. }
  209. .reveal q:before {
  210. content: '\201C';
  211. }
  212. .reveal q:after {
  213. content: '\201D';
  214. }
  215. .reveal pre {
  216. display: block;
  217. position: relative;
  218. width: 90%;
  219. margin: 15px auto;
  220. text-align: left;
  221. font-size: 0.55em;
  222. font-family: monospace;
  223. line-height: 1.2em;
  224. word-wrap: break-word;
  225. box-shadow: 0px 0px 6px rgba(0,0,0,0.3);
  226. }
  227. .reveal pre code {
  228. padding: 5px;
  229. }
  230. .reveal code {
  231. font-family: monospace;
  232. overflow: auto;
  233. max-height: 400px;
  234. }
  235. .reveal table th,
  236. .reveal table td {
  237. text-align: left;
  238. padding-right: .3em;
  239. }
  240. .reveal table th {
  241. text-shadow: rgb(255,255,255) 1px 1px 2px;
  242. }
  243. .reveal sup {
  244. vertical-align: super;
  245. }
  246. .reveal sub {
  247. vertical-align: sub;
  248. }
  249. .reveal small {
  250. display: inline-block;
  251. font-size: 0.6em;
  252. line-height: 1.2em;
  253. vertical-align: top;
  254. }
  255. .reveal small * {
  256. vertical-align: top;
  257. }
  258. /*********************************************
  259. * CONTROLS
  260. *********************************************/
  261. .reveal .controls {
  262. display: none;
  263. position: fixed;
  264. width: 110px;
  265. height: 110px;
  266. z-index: 30;
  267. right: 10px;
  268. bottom: 10px;
  269. }
  270. .reveal .controls div {
  271. position: absolute;
  272. opacity: 0.1;
  273. width: 0;
  274. height: 0;
  275. border: 12px solid transparent;
  276. -webkit-transition: opacity 0.2s ease;
  277. -moz-transition: opacity 0.2s ease;
  278. -ms-transition: opacity 0.2s ease;
  279. -o-transition: opacity 0.2s ease;
  280. transition: opacity 0.2s ease;
  281. }
  282. .reveal .controls div.enabled {
  283. opacity: 0.6;
  284. cursor: pointer;
  285. }
  286. .reveal .controls div.enabled:active {
  287. margin-top: 1px;
  288. }
  289. .reveal .controls div.navigate-left {
  290. top: 42px;
  291. border-right-width: 22px;
  292. border-right-color: #eee;
  293. }
  294. .reveal .controls div.navigate-right {
  295. left: 74px;
  296. top: 42px;
  297. border-left-width: 22px;
  298. border-left-color: #eee;
  299. }
  300. .reveal .controls div.navigate-up {
  301. left: 42px;
  302. border-bottom-width: 22px;
  303. border-bottom-color: #eee;
  304. }
  305. .reveal .controls div.navigate-down {
  306. left: 42px;
  307. top: 74px;
  308. border-top-width: 22px;
  309. border-top-color: #eee;
  310. }
  311. /*********************************************
  312. * PROGRESS BAR
  313. *********************************************/
  314. .reveal .progress {
  315. position: fixed;
  316. display: none;
  317. height: 3px;
  318. width: 100%;
  319. bottom: 0;
  320. left: 0;
  321. z-index: 10;
  322. }
  323. .reveal .progress:after {
  324. content: '';
  325. display: 'block';
  326. position: absolute;
  327. height: 20px;
  328. width: 100%;
  329. top: -20px;
  330. }
  331. .reveal .progress span {
  332. display: block;
  333. height: 100%;
  334. width: 0px;
  335. -webkit-transition: width 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  336. -moz-transition: width 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  337. -ms-transition: width 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  338. -o-transition: width 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  339. transition: width 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  340. }
  341. /*********************************************
  342. * ROLLING LINKS
  343. *********************************************/
  344. .reveal .roll {
  345. display: inline-block;
  346. line-height: 1.2;
  347. overflow: hidden;
  348. vertical-align: top;
  349. -webkit-perspective: 400px;
  350. -moz-perspective: 400px;
  351. -ms-perspective: 400px;
  352. perspective: 400px;
  353. -webkit-perspective-origin: 50% 50%;
  354. -moz-perspective-origin: 50% 50%;
  355. -ms-perspective-origin: 50% 50%;
  356. perspective-origin: 50% 50%;
  357. }
  358. .reveal .roll:hover {
  359. background: none;
  360. text-shadow: none;
  361. }
  362. .reveal .roll span {
  363. display: block;
  364. position: relative;
  365. padding: 0 2px;
  366. pointer-events: none;
  367. -webkit-transition: all 400ms ease;
  368. -moz-transition: all 400ms ease;
  369. -ms-transition: all 400ms ease;
  370. transition: all 400ms ease;
  371. -webkit-transform-origin: 50% 0%;
  372. -moz-transform-origin: 50% 0%;
  373. -ms-transform-origin: 50% 0%;
  374. transform-origin: 50% 0%;
  375. -webkit-transform-style: preserve-3d;
  376. -moz-transform-style: preserve-3d;
  377. -ms-transform-style: preserve-3d;
  378. transform-style: preserve-3d;
  379. -webkit-backface-visibility: hidden;
  380. -moz-backface-visibility: hidden;
  381. backface-visibility: hidden;
  382. }
  383. .reveal .roll:hover span {
  384. background: rgba(0,0,0,0.5);
  385. -webkit-transform: translate3d( 0px, 0px, -45px ) rotateX( 90deg );
  386. -moz-transform: translate3d( 0px, 0px, -45px ) rotateX( 90deg );
  387. -ms-transform: translate3d( 0px, 0px, -45px ) rotateX( 90deg );
  388. transform: translate3d( 0px, 0px, -45px ) rotateX( 90deg );
  389. }
  390. .reveal .roll span:after {
  391. content: attr(data-title);
  392. display: block;
  393. position: absolute;
  394. left: 0;
  395. top: 0;
  396. padding: 0 2px;
  397. -webkit-transform-origin: 50% 0%;
  398. -moz-transform-origin: 50% 0%;
  399. -ms-transform-origin: 50% 0%;
  400. transform-origin: 50% 0%;
  401. -webkit-transform: translate3d( 0px, 110%, 0px ) rotateX( -90deg );
  402. -moz-transform: translate3d( 0px, 110%, 0px ) rotateX( -90deg );
  403. -ms-transform: translate3d( 0px, 110%, 0px ) rotateX( -90deg );
  404. transform: translate3d( 0px, 110%, 0px ) rotateX( -90deg );
  405. }
  406. /*********************************************
  407. * SLIDES
  408. *********************************************/
  409. .reveal {
  410. position: relative;
  411. width: 100%;
  412. height: 100%;
  413. min-height: 640px; /* min height + 40 to account for padding */
  414. }
  415. .reveal .slides {
  416. position: absolute;
  417. max-width: 900px;
  418. min-height: 600px;
  419. width: 80%;
  420. left: 50%;
  421. top: 50%;
  422. overflow: visible;
  423. z-index: 1;
  424. text-align: center;
  425. -webkit-transition: -webkit-perspective .4s ease;
  426. -moz-transition: -moz-perspective .4s ease;
  427. -ms-transition: -ms-perspective .4s ease;
  428. -o-transition: -o-perspective .4s ease;
  429. transition: perspective .4s ease;
  430. -webkit-perspective: 600px;
  431. -moz-perspective: 600px;
  432. -ms-perspective: 600px;
  433. perspective: 600px;
  434. -webkit-perspective-origin: 0% -25%;
  435. -moz-perspective-origin: 0% -25%;
  436. -ms-perspective-origin: 0% -25%;
  437. perspective-origin: 0% -25%;
  438. }
  439. .reveal .slides>section,
  440. .reveal .slides>section>section {
  441. display: none;
  442. position: absolute;
  443. width: 100%;
  444. padding: 20px 0px;
  445. z-index: 10;
  446. line-height: 1.2em;
  447. font-weight: normal;
  448. -webkit-transform-style: preserve-3d;
  449. -moz-transform-style: preserve-3d;
  450. -ms-transform-style: preserve-3d;
  451. transform-style: preserve-3d;
  452. -webkit-transition: -webkit-transform 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  453. visibility 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  454. opacity 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  455. -moz-transition: -moz-transform 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  456. visibility 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  457. opacity 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  458. -ms-transition: -ms-transform 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  459. visibility 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  460. opacity 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  461. -o-transition: -o-transform 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  462. visibility 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  463. opacity 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  464. transition: transform 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  465. visibility 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985),
  466. opacity 800ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  467. }
  468. .reveal .slides>section.present,
  469. .reveal .slides>section>section.present {
  470. display: block;
  471. z-index: 11;
  472. opacity: 1;
  473. }
  474. .reveal .slides>section {
  475. left: -50%;
  476. top: -50%;
  477. }
  478. .reveal.center,
  479. .reveal.center .slides {
  480. min-height: auto;
  481. }
  482. /*********************************************
  483. * DEFAULT TRANSITION
  484. *********************************************/
  485. .reveal .slides>section.past {
  486. display: block;
  487. opacity: 0;
  488. -webkit-transform: translate3d(-100%, 0, 0) rotateY(-90deg) translate3d(-100%, 0, 0);
  489. -moz-transform: translate3d(-100%, 0, 0) rotateY(-90deg) translate3d(-100%, 0, 0);
  490. -ms-transform: translate3d(-100%, 0, 0) rotateY(-90deg) translate3d(-100%, 0, 0);
  491. transform: translate3d(-100%, 0, 0) rotateY(-90deg) translate3d(-100%, 0, 0);
  492. }
  493. .reveal .slides>section.future {
  494. display: block;
  495. opacity: 0;
  496. -webkit-transform: translate3d(100%, 0, 0) rotateY(90deg) translate3d(100%, 0, 0);
  497. -moz-transform: translate3d(100%, 0, 0) rotateY(90deg) translate3d(100%, 0, 0);
  498. -ms-transform: translate3d(100%, 0, 0) rotateY(90deg) translate3d(100%, 0, 0);
  499. transform: translate3d(100%, 0, 0) rotateY(90deg) translate3d(100%, 0, 0);
  500. }
  501. .reveal .slides>section>section.past {
  502. display: block;
  503. opacity: 0;
  504. -webkit-transform: translate3d(0, -50%, 0) rotateX(70deg) translate3d(0, -50%, 0);
  505. -moz-transform: translate3d(0, -50%, 0) rotateX(70deg) translate3d(0, -50%, 0);
  506. -ms-transform: translate3d(0, -50%, 0) rotateX(70deg) translate3d(0, -50%, 0);
  507. transform: translate3d(0, -50%, 0) rotateX(70deg) translate3d(0, -50%, 0);
  508. }
  509. .reveal .slides>section>section.future {
  510. display: block;
  511. opacity: 0;
  512. -webkit-transform: translate3d(0, 50%, 0) rotateX(-70deg) translate3d(0, 50%, 0);
  513. -moz-transform: translate3d(0, 50%, 0) rotateX(-70deg) translate3d(0, 50%, 0);
  514. -ms-transform: translate3d(0, 50%, 0) rotateX(-70deg) translate3d(0, 50%, 0);
  515. transform: translate3d(0, 50%, 0) rotateX(-70deg) translate3d(0, 50%, 0);
  516. }
  517. /*********************************************
  518. * CONCAVE TRANSITION
  519. *********************************************/
  520. .reveal.concave .slides>section.past {
  521. -webkit-transform: translate3d(-100%, 0, 0) rotateY(90deg) translate3d(-100%, 0, 0);
  522. -moz-transform: translate3d(-100%, 0, 0) rotateY(90deg) translate3d(-100%, 0, 0);
  523. -ms-transform: translate3d(-100%, 0, 0) rotateY(90deg) translate3d(-100%, 0, 0);
  524. transform: translate3d(-100%, 0, 0) rotateY(90deg) translate3d(-100%, 0, 0);
  525. }
  526. .reveal.concave .slides>section.future {
  527. -webkit-transform: translate3d(100%, 0, 0) rotateY(-90deg) translate3d(100%, 0, 0);
  528. -moz-transform: translate3d(100%, 0, 0) rotateY(-90deg) translate3d(100%, 0, 0);
  529. -ms-transform: translate3d(100%, 0, 0) rotateY(-90deg) translate3d(100%, 0, 0);
  530. transform: translate3d(100%, 0, 0) rotateY(-90deg) translate3d(100%, 0, 0);
  531. }
  532. .reveal.concave .slides>section>section.past {
  533. -webkit-transform: translate3d(0, -80%, 0) rotateX(-70deg) translate3d(0, -80%, 0);
  534. -moz-transform: translate3d(0, -80%, 0) rotateX(-70deg) translate3d(0, -80%, 0);
  535. -ms-transform: translate3d(0, -80%, 0) rotateX(-70deg) translate3d(0, -80%, 0);
  536. transform: translate3d(0, -80%, 0) rotateX(-70deg) translate3d(0, -80%, 0);
  537. }
  538. .reveal.concave .slides>section>section.future {
  539. -webkit-transform: translate3d(0, 80%, 0) rotateX(70deg) translate3d(0, 80%, 0);
  540. -moz-transform: translate3d(0, 80%, 0) rotateX(70deg) translate3d(0, 80%, 0);
  541. -ms-transform: translate3d(0, 80%, 0) rotateX(70deg) translate3d(0, 80%, 0);
  542. transform: translate3d(0, 80%, 0) rotateX(70deg) translate3d(0, 80%, 0);
  543. }
  544. /*********************************************
  545. * ZOOM TRANSITION
  546. *********************************************/
  547. .reveal.zoom .slides>section,
  548. .reveal.zoom .slides>section>section {
  549. -webkit-transition: all 600ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  550. -moz-transition: all 600ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  551. -ms-transition: all 600ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  552. -o-transition: all 600ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  553. transition: all 600ms cubic-bezier(0.260, 0.860, 0.440, 0.985);
  554. }
  555. .reveal.zoom .slides>section.past {
  556. opacity: 0;
  557. visibility: hidden;
  558. -webkit-transform: scale(16);
  559. -moz-transform: scale(16);
  560. -ms-transform: scale(16);
  561. -o-transform: scale(16);
  562. transform: scale(16);
  563. }
  564. .reveal.zoom .slides>section.future {
  565. opacity: 0;
  566. visibility: hidden;
  567. -webkit-transform: scale(0.2);
  568. -moz-transform: scale(0.2);
  569. -ms-transform: scale(0.2);
  570. -o-transform: scale(0.2);
  571. transform: scale(0.2);
  572. }
  573. .reveal.zoom .slides>section>section.past {
  574. -webkit-transform: translate(0, -150%);
  575. -moz-transform: translate(0, -150%);
  576. -ms-transform: translate(0, -150%);
  577. -o-transform: translate(0, -150%);
  578. transform: translate(0, -150%);
  579. }
  580. .reveal.zoom .slides>section>section.future {
  581. -webkit-transform: translate(0, 150%);
  582. -moz-transform: translate(0, 150%);
  583. -ms-transform: translate(0, 150%);
  584. -o-transform: translate(0, 150%);
  585. transform: translate(0, 150%);
  586. }
  587. /*********************************************
  588. * LINEAR TRANSITION
  589. *********************************************/
  590. .reveal.linear .slides>section.past {
  591. -webkit-transform: translate(-150%, 0);
  592. -moz-transform: translate(-150%, 0);
  593. -ms-transform: translate(-150%, 0);
  594. -o-transform: translate(-150%, 0);
  595. transform: translate(-150%, 0);
  596. }
  597. .reveal.linear .slides>section.future {
  598. -webkit-transform: translate(150%, 0);
  599. -moz-transform: translate(150%, 0);
  600. -ms-transform: translate(150%, 0);
  601. -o-transform: translate(150%, 0);
  602. transform: translate(150%, 0);
  603. }
  604. .reveal.linear .slides>section>section.past {
  605. -webkit-transform: translate(0, -150%);
  606. -moz-transform: translate(0, -150%);
  607. -ms-transform: translate(0, -150%);
  608. -o-transform: translate(0, -150%);
  609. transform: translate(0, -150%);
  610. }
  611. .reveal.linear .slides>section>section.future {
  612. -webkit-transform: translate(0, 150%);
  613. -moz-transform: translate(0, 150%);
  614. -ms-transform: translate(0, 150%);
  615. -o-transform: translate(0, 150%);
  616. transform: translate(0, 150%);
  617. }
  618. /*********************************************
  619. * CUBE TRANSITION
  620. *********************************************/
  621. .reveal.cube .slides {
  622. -webkit-perspective-origin: 0% 25%;
  623. -moz-perspective-origin: 0% 25%;
  624. -ms-perspective-origin: 0% 25%;
  625. perspective-origin: 0% 25%;
  626. -webkit-perspective: 1300px;
  627. -moz-perspective: 1300px;
  628. -ms-perspective: 1300px;
  629. perspective: 1300px;
  630. }
  631. .reveal.cube .slides section {
  632. padding: 30px;
  633. -webkit-backface-visibility: hidden;
  634. -moz-backface-visibility: hidden;
  635. -ms-backface-visibility: hidden;
  636. backface-visibility: hidden;
  637. -webkit-box-sizing: border-box;
  638. -moz-box-sizing: border-box;
  639. box-sizing: border-box;
  640. }
  641. .reveal.cube .slides section:not(.stack):before {
  642. content: '';
  643. position: absolute;
  644. display: block;
  645. width: 100%;
  646. height: 100%;
  647. left: 0;
  648. top: 0;
  649. background: rgba(0,0,0,0.1);
  650. border-radius: 4px;
  651. -webkit-transform: translateZ( -20px );
  652. -moz-transform: translateZ( -20px );
  653. -ms-transform: translateZ( -20px );
  654. -o-transform: translateZ( -20px );
  655. transform: translateZ( -20px );
  656. }
  657. .reveal.cube .slides section:not(.stack):after {
  658. content: '';
  659. position: absolute;
  660. display: block;
  661. width: 90%;
  662. height: 30px;
  663. left: 5%;
  664. bottom: 0;
  665. background: none;
  666. z-index: 1;
  667. border-radius: 4px;
  668. box-shadow: 0px 95px 25px rgba(0,0,0,0.2);
  669. -webkit-transform: translateZ(-90px) rotateX( 65deg );
  670. -moz-transform: translateZ(-90px) rotateX( 65deg );
  671. -ms-transform: translateZ(-90px) rotateX( 65deg );
  672. -o-transform: translateZ(-90px) rotateX( 65deg );
  673. transform: translateZ(-90px) rotateX( 65deg );
  674. }
  675. .reveal.cube .slides>section.stack {
  676. padding: 0;
  677. background: none;
  678. }
  679. .reveal.cube .slides>section.past {
  680. -webkit-transform-origin: 100% 0%;
  681. -moz-transform-origin: 100% 0%;
  682. -ms-transform-origin: 100% 0%;
  683. transform-origin: 100% 0%;
  684. -webkit-transform: translate3d(-100%, 0, 0) rotateY(-90deg);
  685. -moz-transform: translate3d(-100%, 0, 0) rotateY(-90deg);
  686. -ms-transform: translate3d(-100%, 0, 0) rotateY(-90deg);
  687. transform: translate3d(-100%, 0, 0) rotateY(-90deg);
  688. }
  689. .reveal.cube .slides>section.future {
  690. -webkit-transform-origin: 0% 0%;
  691. -moz-transform-origin: 0% 0%;
  692. -ms-transform-origin: 0% 0%;
  693. transform-origin: 0% 0%;
  694. -webkit-transform: translate3d(100%, 0, 0) rotateY(90deg);
  695. -moz-transform: translate3d(100%, 0, 0) rotateY(90deg);
  696. -ms-transform: translate3d(100%, 0, 0) rotateY(90deg);
  697. transform: translate3d(100%, 0, 0) rotateY(90deg);
  698. }
  699. .reveal.cube .slides>section>section.past {
  700. -webkit-transform-origin: 0% 100%;
  701. -moz-transform-origin: 0% 100%;
  702. -ms-transform-origin: 0% 100%;
  703. transform-origin: 0% 100%;
  704. -webkit-transform: translate3d(0, -100%, 0) rotateX(90deg);
  705. -moz-transform: translate3d(0, -100%, 0) rotateX(90deg);
  706. -ms-transform: translate3d(0, -100%, 0) rotateX(90deg);
  707. transform: translate3d(0, -100%, 0) rotateX(90deg);
  708. }
  709. .reveal.cube .slides>section>section.future {
  710. -webkit-transform-origin: 0% 0%;
  711. -moz-transform-origin: 0% 0%;
  712. -ms-transform-origin: 0% 0%;
  713. transform-origin: 0% 0%;
  714. -webkit-transform: translate3d(0, 100%, 0) rotateX(-90deg);
  715. -moz-transform: translate3d(0, 100%, 0) rotateX(-90deg);
  716. -ms-transform: translate3d(0, 100%, 0) rotateX(-90deg);
  717. transform: translate3d(0, 100%, 0) rotateX(-90deg);
  718. }
  719. /*********************************************
  720. * PAGE TRANSITION
  721. *********************************************/
  722. .reveal.page .slides {
  723. -webkit-perspective-origin: 0% 50%;
  724. -moz-perspective-origin: 0% 50%;
  725. -ms-perspective-origin: 0% 50%;
  726. perspective-origin: 0% 50%;
  727. -webkit-perspective: 3000px;
  728. -moz-perspective: 3000px;
  729. -ms-perspective: 3000px;
  730. perspective: 3000px;
  731. }
  732. .reveal.page .slides section {
  733. padding: 30px;
  734. -webkit-box-sizing: border-box;
  735. -moz-box-sizing: border-box;
  736. box-sizing: border-box;
  737. }
  738. .reveal.page .slides section.past {
  739. z-index: 12;
  740. }
  741. .reveal.page .slides section:not(.stack):before {
  742. content: '';
  743. position: absolute;
  744. display: block;
  745. width: 100%;
  746. height: 100%;
  747. left: 0;
  748. top: 0;
  749. background: rgba(0,0,0,0.1);
  750. -webkit-transform: translateZ( -20px );
  751. -moz-transform: translateZ( -20px );
  752. -ms-transform: translateZ( -20px );
  753. -o-transform: translateZ( -20px );
  754. transform: translateZ( -20px );
  755. }
  756. .reveal.page .slides section:not(.stack):after {
  757. content: '';
  758. position: absolute;
  759. display: block;
  760. width: 90%;
  761. height: 30px;
  762. left: 5%;
  763. bottom: 0;
  764. background: none;
  765. z-index: 1;
  766. border-radius: 4px;
  767. box-shadow: 0px 95px 25px rgba(0,0,0,0.2);
  768. -webkit-transform: translateZ(-90px) rotateX( 65deg );
  769. }
  770. .reveal.page .slides>section.stack {
  771. padding: 0;
  772. background: none;
  773. }
  774. .reveal.page .slides>section.past {
  775. -webkit-transform-origin: 0% 0%;
  776. -moz-transform-origin: 0% 0%;
  777. -ms-transform-origin: 0% 0%;
  778. transform-origin: 0% 0%;
  779. -webkit-transform: translate3d(-40%, 0, 0) rotateY(-80deg);
  780. -moz-transform: translate3d(-40%, 0, 0) rotateY(-80deg);
  781. -ms-transform: translate3d(-40%, 0, 0) rotateY(-80deg);
  782. transform: translate3d(-40%, 0, 0) rotateY(-80deg);
  783. }
  784. .reveal.page .slides>section.future {
  785. -webkit-transform-origin: 100% 0%;
  786. -moz-transform-origin: 100% 0%;
  787. -ms-transform-origin: 100% 0%;
  788. transform-origin: 100% 0%;
  789. -webkit-transform: translate3d(0, 0, 0);
  790. -moz-transform: translate3d(0, 0, 0);
  791. -ms-transform: translate3d(0, 0, 0);
  792. transform: translate3d(0, 0, 0);
  793. }
  794. .reveal.page .slides>section>section.past {
  795. -webkit-transform-origin: 0% 0%;
  796. -moz-transform-origin: 0% 0%;
  797. -ms-transform-origin: 0% 0%;
  798. transform-origin: 0% 0%;
  799. -webkit-transform: translate3d(0, -40%, 0) rotateX(80deg);
  800. -moz-transform: translate3d(0, -40%, 0) rotateX(80deg);
  801. -ms-transform: translate3d(0, -40%, 0) rotateX(80deg);
  802. transform: translate3d(0, -40%, 0) rotateX(80deg);
  803. }
  804. .reveal.page .slides>section>section.future {
  805. -webkit-transform-origin: 0% 100%;
  806. -moz-transform-origin: 0% 100%;
  807. -ms-transform-origin: 0% 100%;
  808. transform-origin: 0% 100%;
  809. -webkit-transform: translate3d(0, 0, 0);
  810. -moz-transform: translate3d(0, 0, 0);
  811. -ms-transform: translate3d(0, 0, 0);
  812. transform: translate3d(0, 0, 0);
  813. }
  814. /*********************************************
  815. * TILE-FLIP TRANSITION (CSS shader)
  816. *********************************************/
  817. .reveal.tileflip .slides section.present {
  818. -webkit-transform: none;
  819. -webkit-transition-duration: 800ms;
  820. -webkit-filter: custom( url(shaders/tile-flip.vs) mix(url(shaders/tile-flip.fs) multiply source-atop), 10 10 border-box detached, transform perspective(1000) scale(1) rotateX(0deg) rotateY(0deg) rotateZ(0deg),
  821. amount 0, randomness 0, flipAxis 0 1 0, tileOutline 1
  822. );
  823. }
  824. .reveal.tileflip .slides section.past {
  825. -webkit-transform: none;
  826. -webkit-transition-duration: 800ms;
  827. -webkit-filter: custom( url(shaders/tile-flip.vs) mix(url(shaders/tile-flip.fs) multiply source-atop), 10 10 border-box detached, transform perspective(1000) scale(1) rotateX(0deg) rotateY(0deg) rotateZ(0deg),
  828. amount 1, randomness 0, flipAxis 0 1 0, tileOutline 1
  829. );
  830. }
  831. .reveal.tileflip .slides section.future {
  832. -webkit-transform: none;
  833. -webkit-transition-duration: 800ms;
  834. -webkit-filter: custom( url(shaders/tile-flip.vs) mix(url(shaders/tile-flip.fs) multiply source-atop), 10 10 border-box detached, transform perspective(1000) scale(1) rotateX(0deg) rotateY(0deg) rotateZ(0deg),
  835. amount 1, randomness 0, flipAxis 0 1 0, tileOutline 1
  836. );
  837. }
  838. .reveal.tileflip .slides>section>section.present {
  839. -webkit-filter: custom( url(shaders/tile-flip.vs) mix(url(shaders/tile-flip.fs) multiply source-atop), 10 10 border-box detached, transform perspective(1000) scale(1) rotateX(0deg) rotateY(0deg) rotateZ(0deg),
  840. amount 0, randomness 2, flipAxis 1 0 0, tileOutline 1
  841. );
  842. }
  843. .reveal.tileflip .slides>section>section.past {
  844. -webkit-filter: custom( url(shaders/tile-flip.vs) mix(url(shaders/tile-flip.fs) multiply source-atop), 10 10 border-box detached, transform perspective(1000) scale(1) rotateX(0deg) rotateY(0deg) rotateZ(0deg),
  845. amount 1, randomness 2, flipAxis 1 0 0, tileOutline 1
  846. );
  847. }
  848. .reveal.tileflip .slides>section>section.future {
  849. -webkit-filter: custom( url(shaders/tile-flip.vs) mix(url(shaders/tile-flip.fs) multiply source-atop), 10 10 border-box detached, transform perspective(1000) scale(1) rotateX(0deg) rotateY(0deg) rotateZ(0deg),
  850. amount 1, randomness 2, flipAxis 1 0 0, tileOutline 1
  851. );
  852. }
  853. /*********************************************
  854. * NO TRANSITION
  855. *********************************************/
  856. .reveal.none .slides section {
  857. -webkit-transform: none;
  858. -moz-transform: none;
  859. -ms-transform: none;
  860. -o-transform: none;
  861. transform: none;
  862. -webkit-transition: none;
  863. -moz-transition: none;
  864. -ms-transition: none;
  865. -o-transition: none;
  866. transition: none;
  867. }
  868. /*********************************************
  869. * OVERVIEW
  870. *********************************************/
  871. .reveal.overview .slides {
  872. -webkit-perspective: 700px;
  873. -moz-perspective: 700px;
  874. -ms-perspective: 700px;
  875. perspective: 700px;
  876. }
  877. .reveal.overview .slides section {
  878. height: 600px;
  879. overflow: hidden;
  880. opacity: 1!important;
  881. visibility: visible!important;
  882. cursor: pointer;
  883. background: rgba(0,0,0,0.1);
  884. }
  885. .reveal.overview .slides section .fragment {
  886. opacity: 1;
  887. }
  888. .reveal.overview .slides section:after,
  889. .reveal.overview .slides section:before {
  890. display: none !important;
  891. }
  892. .reveal.overview .slides section>section {
  893. opacity: 1;
  894. cursor: pointer;
  895. }
  896. .reveal.overview .slides section:hover {
  897. background: rgba(0,0,0,0.3);
  898. }
  899. .reveal.overview .slides section.present {
  900. background: rgba(0,0,0,0.3);
  901. }
  902. .reveal.overview .slides>section.stack {
  903. padding: 0;
  904. background: none;
  905. overflow: visible;
  906. }
  907. /*********************************************
  908. * PAUSED MODE
  909. *********************************************/
  910. .reveal .pause-overlay {
  911. position: absolute;
  912. top: 0;
  913. left: 0;
  914. width: 100%;
  915. height: 100%;
  916. background: black;
  917. visibility: hidden;
  918. opacity: 0;
  919. z-index: 100;
  920. -webkit-transition: all 1s ease;
  921. -moz-transition: all 1s ease;
  922. -ms-transition: all 1s ease;
  923. -o-transition: all 1s ease;
  924. transition: all 1s ease;
  925. }
  926. .reveal.paused .pause-overlay {
  927. visibility: visible;
  928. opacity: 1;
  929. }
  930. /*********************************************
  931. * FALLBACK
  932. *********************************************/
  933. .no-transforms {
  934. overflow-y: auto;
  935. }
  936. .no-transforms .slides section {
  937. display: block!important;
  938. opacity: 1!important;
  939. position: relative!important;
  940. height: auto;
  941. min-height: auto;
  942. margin-bottom: 100px;
  943. -webkit-transform: none;
  944. -moz-transform: none;
  945. -ms-transform: none;
  946. transform: none;
  947. }
  948. .no-transition {
  949. -webkit-transition: none;
  950. -moz-transition: none;
  951. -ms-transition: none;
  952. -o-transition: none;
  953. transition: none;
  954. }
  955. /*********************************************
  956. * BACKGROUND STATES
  957. *********************************************/
  958. .reveal .state-background {
  959. position: absolute;
  960. width: 100%;
  961. height: 100%;
  962. background: rgba( 0, 0, 0, 0 );
  963. -webkit-transition: background 800ms ease;
  964. -moz-transition: background 800ms ease;
  965. -ms-transition: background 800ms ease;
  966. -o-transition: background 800ms ease;
  967. transition: background 800ms ease;
  968. }
  969. .alert .reveal .state-background {
  970. background: rgba( 200, 50, 30, 0.6 );
  971. }
  972. .soothe .reveal .state-background {
  973. background: rgba( 50, 200, 90, 0.4 );
  974. }
  975. .blackout .reveal .state-background {
  976. background: rgba( 0, 0, 0, 0.6 );
  977. }
  978. /*********************************************
  979. * SPEAKER NOTES
  980. *********************************************/
  981. .reveal aside.notes {
  982. display: none;
  983. }
  984. /*********************************************
  985. * ZOOM PLUGIN
  986. *********************************************/
  987. .zoomed .reveal *,
  988. .zoomed .reveal *:before,
  989. .zoomed .reveal *:after {
  990. -webkit-transform: none !important;
  991. -moz-transform: none !important;
  992. -ms-transform: none !important;
  993. transform: none !important;
  994. -webkit-backface-visibility: visible !important;
  995. -moz-backface-visibility: visible !important;
  996. -ms-backface-visibility: visible !important;
  997. backface-visibility: visible !important;
  998. }
  999. .zoomed .reveal .progress,
  1000. .zoomed .reveal .controls {
  1001. opacity: 0;
  1002. }
  1003. .zoomed .reveal .roll span {
  1004. background: none;
  1005. }
  1006. .zoomed .reveal .roll span:after {
  1007. visibility: hidden;
  1008. }