Pen Settings



CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URLs added here will be added as <link>s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.

+ add another resource


Babel includes JSX processing.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource


Add Packages

Search for and use JavaScript packages from npm here. By selecting a package, an import statement will be added to the top of the JavaScript editor for this package.


Auto Save

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.


                <section class="title-slide">
    <h1 id="text">Stellar&nbsp;alchemy.<br>Vanquish&nbsp;the&nbsp;Impossible.</h1>

    <div class="content">
        <p>The ash of stellar alchemy Hypatia. Two ghostly white figures in coveralls and helmets are soflty dancing tingling of the spine trillion quasar the ash of stellar alchemy Orion's sword venture another world, intelligent beings how far away muse
            about vanquish the impossible Flatland take root and flourish, billions upon billions consciousness intelligent beings, a still more glorious dawn awaits Drake Equation? Quasar encyclopaedia galactica a billion trillion, vanquish the impossible
            from which we spring rich in heavy atoms a very small stage in a vast cosmic arena Rig Veda.</p>
        <p>Network of wormholes venture. Paroxysm of global death Drake Equation, Orion's sword a mote of dust suspended in a sunbeam. Globular star cluster rich in mystery cosmic fugue as a patch of light finite but unbounded from which we spring birth.
            Explorations globular star cluster cosmic ocean not a sunrise but a galaxyrise Rig Veda gathered by gravity descended from astronomers are creatures of the cosmos. Prime number across the centuries, with pretty stories for which there's little
            good evidence vanquish the impossible encyclopaedia galactica quasar.</p>


                @font-face {
	font-family: 'qanelas_soft_demoextrabold';
	src: url('');
	src: url('') format('embedded-opentype'),
	url('') format('woff2'),
	url('') format('woff'),
	url('') format('truetype'),
	url('') format('svg');
        font-weight: bold;
	font-style: normal;

html {
    height: 100%;
    min-height: 100%;

body {
    background: #eee;

section {
    display: flex;
    justify-content: center;
    align-items: center;

h1 {
    color: #1a1a1a;
    font-size: 5em;
    font-family: qanelas_soft_demoextrabold, sans-serif;
    text-transform: uppercase;
    span {
        display: block;
        float: left;

p {
    font-size: 1.2em;
    line-height: 1.6725;

.title-slide {
    height: 100vh;
    padding: 0 5vw;

.content {
    padding: 50px 25vw;
    background: #1a1a1a;
    color: #eee;


 * recursively get all text nodes as an array for a given element
function getTextNodes(node) {
  var childTextNodes = [];

  if (!node.hasChildNodes()) {

  var childNodes = node.childNodes;
  for (var i = 0; i < childNodes.length; i++) {
    if (childNodes[i].nodeType == Node.TEXT_NODE) {
    } else if (childNodes[i].nodeType == Node.ELEMENT_NODE) {
      Array.prototype.push.apply(childTextNodes, getTextNodes(childNodes[i]));

  return childTextNodes;

 * given a text node, wrap each character in the
 * given tag.
function wrapEachCharacter(textNode, tag) {
  var text = textNode.nodeValue;
  var parent = textNode.parentNode;

  var characters = text.split('');
  var elements = [];
  var i = 0;
  characters.forEach(function(character) {
    var element = document.createElement(tag);
    var characterNode = document.createTextNode(character);


    parent.insertBefore(element, textNode);


var str = document.getElementById("text");

var allTextNodes = getTextNodes(str);

// wrap each character in each text node thus gathered.
allTextNodes.forEach(function(textNode) {

  wrapEachCharacter(textNode, 'span');


var spans = str.children;
var spanList = [];

for (var i = 0; i < spans.length; i++) {
function getRandomArbitrary(min, max) {
    return Math.random() * (max - min) + min;

document.onscroll = function() {
  var i = 0;
  spanList.forEach(function(span) {
    var dsoctop = document.onscroll.all ? iebody.scrollTop : pageYOffset;
    if( i % 2 ) { = "rotate(" + dsoctop/i/4 + "deg) translate3d(" + dsoctop/30 * i/30 + "px, " + dsoctop/30 * i/30 + "px, " + dsoctop * i + "px)";
    } else if( i % 5 ) { = "rotate(" + -dsoctop/i/2 + "deg) translate3d(" + -dsoctop/10 * i/10 + "px, " + -dsoctop/10 * i/10 + "px, " + dsoctop * i + "px)";
    } else { = "rotate(" + dsoctop/i/3+ "deg) translate3d(" + -dsoctop/20 * i/20 + "px, " + -dsoctop/20 * i/20 + "px, " + dsoctop * i + "px)";