css Audio - Active file-generic CSS - Active Generic - Active HTML - Active JS - Active SVG - Active Text - Active file-generic Video - Active header Love html icon-new-collection icon-person icon-team numbered-list123 pop-out spinner split-screen star tv

Pen Settings

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URL's added here will be added as <link>s in order, and before the CSS in the editor. If you link to another Pen, it will include the CSS from that Pen. If the preprocessor matches, it will attempt to combine them before processing.

+ add another resource

You're using npm packages, so we've auto-selected Babel for you here, which we require to process imports and make it all work. If you need to use a different JavaScript preprocessor, remove the packages in the npm tab.

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

Use npm Packages

We can make npm packages available for you to use in your JavaScript. We use webpack to prepare them and make them available to import. We'll also process your JavaScript with Babel.

⚠️ This feature can only be used by logged in users.

Code Indentation

     

Save Automatically?

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.

HTML Settings

Here you can Sed posuere consectetur est at lobortis. Donec ullamcorper nulla non metus auctor fringilla. Maecenas sed diam eget risus varius blandit sit amet non magna. Donec id elit non mi porta gravida at eget metus. Praesent commodo cursus magna, vel scelerisque nisl consectetur et.

            
              <!--
An illustrative effect showing how user interaction can scale into an illustration.

Pen By Ashley Nolan.

Best viewed in Chrome or IE – bit memory intensive in Firefox and Safari does some weird glitchy animation at the higher scroll points.

Illustrations by Simon Kinslow and Lorena Teruel.

-->

<link href='https://fonts.googleapis.com/css?family=Sancreek' rel='stylesheet' type='text/css'>

<div class="l-container home">
  <div class="illust-container">
    <div class="illust-level illust-level--intro">
      <div class="illustItem illustItem--bgGrass"></div>
      <div class="illustItem illustItem--fencePost illustItem--fencePost--first">
        <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fencepost.svg" alt="Fence post">
        <div class="illustItem illustItem--northpole illustItem--fence-arrow illustItem--fence-arrow-left symbol symbol--northpole">
          <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fence-arrow-left.svg" alt="Fence post Arrow Left">
          <h2 class="symbol-title">North Pole </h2>
        </div>
        <div class="illustItem illustItem--grotto illustItem--fence-arrow illustItem--fence-arrow-right symbol symbol--grotto">
          <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fence-arrow-right.svg" alt="Fence post Arrow Right">
          <h2 class="symbol-title">Grotto</h2>
        </div>
      </div>
      <div class="illustItem illustItem--holly symbol symbol--holly">
        <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/holly.svg" alt="Holly">
      </div>

      <div class="illustItem illustItem--fencePost illustItem--fencePost--second">
        <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fencepost.svg" alt="Fence post">
        <div class="illustItem illustItem--lapland illustItem--fence-arrow illustItem--fence-arrow-right symbol symbol--lapland">
          <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/fence-arrow-right.svg" alt="Fence post arrow right">
          <h2 class="symbol-title">Lapland</h2>
        </div>
      </div>
      <div class="illustItem illustItem--ivy symbol symbol--ivy">
        <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/ivy.svg" alt="Ivy">
      </div>
    </div>
  </div>
  <div class="illust-level--town">
    <div class="illustItem illustItem--snowglobe">
      <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/snowglobe.svg" alt="Snow Globe">
    </div>
    <div class="illustItem illustItem--town">
      <img class="svg-town" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/town.svg" alt="Town">
      <div class="svg-house">
        <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/house.svg" alt="House">
        <img class="svg-lights" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/lights.svg" alt="lights">
      </div>
      <img class="svg-sleigh" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/sleigh.svg" alt="Sleigh">
      <div class="svg-star inactive">
        <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/star.svg" alt="Star">
      </div>
      <img class="svg-sledge" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/sledge.svg" alt="sledge">
      <img class="svg-robins" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/robins.svg" alt="robins">
      <img class="svg-peace" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/peace.svg" alt="peace">
      <img class="svg-shopping" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/shopping.svg" alt="shopping">
      <div class="svg-carollers">
        <img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/carolers.svg" alt="carollers">
      </div>
      <img class="svg-firstfloor" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/firstfloor.svg" alt="firstfloor">
      <img class="svg-secondfloor" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/secondfloor.svg" alt="secondfloor">
      <img class="svg-nativity" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/12207/nativity.svg" alt="nativity">
      
      <div class="illust-level illust-level--symbolsTown">
        <div class="illustItem illustItem--yuletide symbol symbol--yuletide">
          <h2 class="symbol-title">Seasons Greetings</h2>
        </div>
        <div class="symbols--outside">
          <div class="illustItem illustItem--carols symbol symbol--carols">
            <h2 class="symbol-title">Merry Christmas</h2>
          </div>
        </div>
        <div class="symbols--inside inactive">
          <div class="illustItem illustItem--nutcracker symbol symbol--nutcracker">
            <h2 class="symbol-title">Tiny Tim</h2>
          </div>
          <div class="illustItem illustItem--present symbol symbol--present">
            <h2 class="symbol-title">Mum</h2>
          </div>
          <div class="illustItem illustItem--mincepie symbol symbol--mincepie">
            <h2 class="symbol-title">Mince Pies</h2>
          </div>
          <div class="illustItem illustItem--christmascards symbol symbol--christmascards">
            <h2 class="symbol-title">Happy Christmas</h2>
          </div>
          <div class="illustItem illustItem--bingcrosby symbol symbol--bingcrosby">
            <h2 class="symbol-title">Bing Crosby</h2>
          </div>
          <div class="illustItem illustItem--mariahcarey symbol symbol--mariahcarey">
            <h2 class="symbol-title">Mariah Carey</h2>
          </div>
          <div class="illustItem illustItem--endquote">
            <h2 class="symbol-title"><span class="symbol-title-sub">Have</span>a Very Merry Jolly Christmas!</h2>
          </div>
        </div>
      </div>
    </div>
  </div>
  <div id="scroll-proxy"></div>
  <footer class="page-footer">
    <ul class="unstyled page-footer-links">
      <li><a class="page-footer-info" href="https://twitter.com/AshNolan_" target="_blank">By AshNolan_</a>
      </li>
    </ul>
  </footer>
</div>
            
          
!
            
              // Generic colours
$blue                         : #e2f7f6;
$turquoise                    : #34a8a6;
$red                          : #e41f44;
$yellow                       : #f8e32a;
$yellowPale                   : #f2e397;
$brownLight                   : #eee0b7;

// Colour Scheme
$color-primary                : $turquoise;

// Common colours
$color-text                   : #444;
$color-bg                     : #a6e1ee;

// Text Selection
$color-selection              : #fff;
$color-selection-bg           : $color-primary;

// Links
$color-link-default           : $color-primary;
$color-link-hover             : darken($color-primary, 20%);

// Buttons
$btn-default-bg               : $turquoise;
$btn-default-bg-highlight     : darken($btn-default-bg, 10%);


/**
 * Typography
 * =================================
 */
$font-size-base                : 16;
$font-size-base-px             : $font-size-base * 1px;

$leading-base                  : 1.4;
$line-height-base              : round($font-size-base * $leading-base); // 20 * 1.4
$baseline                      : $line-height-base * 1px;

$type-scale                    : 1.25; // Major third
$type-base                     : 16;

$font-family-sans             : "Helvetica Neue", Helvetica, Arial, sans-serif;
$font-family-serif            : 'Sancreek', cursive;
$font-family-mono             : Menlo, Monaco, "Courier New", monospace;

$font-family-base             : $font-family-serif;
$font-family-alt              : $font-family-serif;

$font-family-headings         : inherit; // using inherit will use $font-family-base for all headings
$font-weight-headings         : normal;    // instead of browser default, bold
$line-height-headings         : 1.2;


/**
 *  Breakpoints
*/
$bp-narrow            : 550;  // Set in px
$bp-mid               : 768;  // Set in px
$bp-wide              : 992;  // Set in px
$bp-huge              : 1600; // Set in px


/*
   Min-width media query:
   * Equivalent to: @media screen and (min-width: 20em) { ... }
   * Usage: @include respond-min(500) { ... };
   * Argument is a pixel value WITHOUT a unit of measurement
   ========================================================================== */
@mixin respond-min($width) {
  @media screen and (min-width: $width + px) {
    @content;
  }
}


/*
   Max-width media query:
   * Equivalent to: @media screen and (max-width: 20em) { ... }
   * Usage: @include respond-max(500) { ... };
   * Argument is a pixel value WITHOUT a unit of measurement
   ========================================================================== */
@mixin respond-max($width) {
  // Otherwise, output it using a regular media query
  @media screen and (max-width: $width + px) {
    @content;
	}
}

// Opacity
// @include opacity(50);
@mixin opacity($opacity: 100) {
	zoom: 1;
	filter: alpha(opacity=$opacity);
	opacity: $opacity / 100;
}

/* ==========================================================================
   Typography mixins
   ========================================================================== */

// @include font-size(16);
@mixin font-size($sizeValue: $font-size-base){
  font-size: $sizeValue + px;
}

/**
 * Typography
 */
* {
  box-sizing: border-box;
}

html {
	text-size-adjust: 100%;
}

body {
	font-family: $font-family-base;
	@include font-size($type-base);
	line-height: $leading-base;
	color: $color-text;
}

/**
 * Headings
 */
h2 {
	margin: 0;
	font-family: $font-family-headings;
	font-weight: $font-weight-headings;
	line-height: $line-height-headings;
	text-rendering: optimizelegibility; // Fix the character spacing for headings
}

h2 {
	@include font-size(30);
	margin-top: 0;
	margin-bottom: $baseline;
}

/**
 * Links
 */
a {
	& {
		color: $color-link-default;
		text-decoration: none;
	}
	&:hover, &:focus {
		color: $color-link-hover;
	}
}


/**
 * Lists
 */
ul {
	list-style-type: disc;
}

// Unordered and Ordered lists
// Add a .unstyled class to unordered/ordered lists if you want them to have bullets/numbers
ul {
	padding: 0;
	margin: 0 0 $baseline $baseline;
}
.unstyled {
	margin: 0;
	padding: 0;
	list-style: none;
	list-style-image: none;
}


// Text selection
@mixin text-selection($color-selection, $color-selection-bg) {
	::-moz-selection {
		color: $color-selection;
		background: $color-selection-bg;
		text-shadow: none;
	}
	::selection {
		color: $color-selection;
		background: $color-selection-bg;
		text-shadow: none;
	}
}

@include text-selection($color-selection, $color-selection-bg);


.btn {
	display:inline-block;
	vertical-align:middle;
	white-space:nowrap;
	font-family:inherit;
	font-size:100%;
	cursor:pointer;
	border:none;
	margin:0;
	padding-top:   0;
	padding-bottom:0;
	line-height: 2.5;
	height:      2.5em;
	padding-right:1.5em;
	padding-left: 1.5em;
	overflow:visible;
	text-align: center;

	// You may want to change this
	background-color: $btn-default-bg;

	color: #fff;

	border-radius: 5px;
	user-select: none;

	&:hover {
		background-color: $btn-default-bg-highlight;
	}

	&,
	&:hover {
		text-decoration: none;
	}
}

/**
 * Scrollbar styling (only in webkit)
 */

::-webkit-scrollbar {
	width: 10px;
	height: 10px;
	background-color: darken($color-bg, 10%);
}
::-webkit-scrollbar-thumb {
	background: darken($color-bg, 40%);
	cursor: pointer;
	border-radius: 5px;
}


/**
 * Global app/site styles
 */

html, body,
.l-container {
	@include respond-min($bp-narrow) {
		width: 100%;
		height: 100%;
	}
}

body {
	background-color: $color-bg;
	color: #333;

	//snow
	background-image: url('');
	background-repeat: repeat;

	background-position: top left;
	background-attachment: fixed;

	transition: background-color 1000ms;

	&.night {
		background-color: #0d0f27;
		background-image: url('');
	}
}

/**
 * Default layout container
 */
.l-container {
	padding-left: 0px;
	padding-right: 0px;
	width: 95%;
	max-width: 1000px;
	margin: 0 auto;

	// perspective: 300px;

	@include respond-max($bp-narrow - 1) {
		position: relative;
		margin-bottom: 150px;
	}
}
#scroll-proxy {
  height: 10000px;

	&.inactive {
		display: none;
	}
}




	//SYMBOL RELATED STUFF
		.symbol {
			position: relative;
		}
			.symbol-title {
				@include font-size(18);
				text-transform: uppercase;

				.symbol--carols & {
					color: $brownLight;
					@include font-size(20);
				}
				.symbol--mincepie & {
					color: $yellowPale;
					@include font-size(22);
				}
			}

			.symbol-total {
				letter-spacing: 1px;
			}

			//specific text sizing for certain symbols
			.symbol-title,
			.symbol-total {
				margin-bottom: 0;

				//where we want the title and count on one line
				.symbol--inline & {
					display: inline-block;
					@include font-size(18);
				}
				.symbol--yuletide & {
					@include respond-min($bp-narrow) {
						@include font-size(20);
					}
				}
			}

			//hide symbols until needed
			.overlay,
			.symbols--inside,
			.symbols--outside {
				@include opacity(100);
				transition: opacity 300ms;

				&.inactive {
					z-index: -10;
					transition: opacity 300ms, z-index 0ms 300ms;
					@include opacity(0);
				}
			}

			.symbols--inside,
			.symbols--outside {
				position: absolute;
				width: 100%;
				height: 100%;
			}



$layerIndex: level-1, level-2, level-3, level-4, level-5;

.illust-container {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;

	transform: translate3d(0, 0, 0);
	backface-visibility: hidden;
}
	.illust-level {
		position: absolute;
		left: 0;
		top: 0;
	}

	.illust-level--intro {
		position: relative;
		width: 100%;
		height: 700px;
		max-width: 1400px;

		margin: 0 auto;

		& svg,
     & img {
			position: absolute;
			z-index: index($layerIndex, level-2);
			left: 0;
			top: 0;
			width: 100%;
			height: 100%;
		}
		.symbol-title {
			position: relative;
			margin-top: 0;
			z-index: index($layerIndex, level-3);
		}
	}

		.illust-level--town {
			position: fixed;
			top: 50%; left: 50%;
			z-index: index($layerIndex, level-2);
			width: 350px;
			height: 320px;

			transform: translate(-50%, -160px);

			.csstransforms3d & {
				transform: translate3d(-50%, -160px, 0);
				backface-visibility: hidden;
			}

		}

			.illust-level--symbolsTown {
				z-index: index($layerIndex, level-3);
				width: 350px; height: 320px;
				transform-origin: left top;
			}

// INTRO LEVEL (HOME) ILLUSTRATIONS
// INCLUDES (IN Z-INDEX ORDER:
	// BGGRASS
	// SNOWGLOBE
	// SNOWFLAKE
	// DOVES
	// HOLLY
	// IVY

		//every illustration component has this set on it, plus a more precise modifier class with the background
		.illustItem {
			position: absolute;
			background-size: contain;
			background-repeat: no-repeat;
			background-position: center center;
		}

			.illustItem--bgGrass {
				z-index: index($layerIndex, level-2);
				top: 490px; left: 50%;
				width: 200%; height: 50px;
				background-image: url('');
				background-repeat: repeat-x;
				background-position: left top;
				transform: translate(-50%);

				@media screen and (min-height: 750px) { top: 520px; }

				&:before {
					content: '';
					display: block;
					margin-top: 50px;
					width: 100%;
					height: 800px;
					background-color: $blue;
				}
			}

			.illustItem--fencePost {
				z-index: index($layerIndex, level-1);
				width: 25px;
				min-height: 252px;

				@include respond-min($bp-mid) { width: 49px; }

				&.illustItem--fencePost--first {
					top: 320px;
					left: 12%;

					transition: left 300ms;

					@include respond-min(820) { left: 15%; }
					@include respond-min($bp-wide) { left: 20%; }

					@media screen and (min-height: 750px) { top: 350px; }
				}
				&.illustItem--fencePost--second {
					top: 360px;
					right: 10%;

					transition: right 300ms;

					@include respond-min(760) { right: 15%; }

					@media screen and (min-height: 750px) { top: 400px; }
				}

				& .symbol-title {
					display: inline-block;
					@include font-size(20);
				}
			}

				.illustItem--fence-arrow-left {
					z-index: index($layerIndex, level-2);
					text-align: right;
					width: 130px;
					height: 41px;

					@include respond-min($bp-mid) { width: 200px; }

					.symbol-title {
						padding-top: 8px;
						padding-right: 25px;

						@include respond-max($bp-mid) {
							@include font-size(12);
							padding-top: 12px;
						}
					}
				}

				.illustItem--fence-arrow-right {
					z-index: index($layerIndex, level-2);
					width: 120px;
					height: 32px;

					@include respond-min($bp-mid) { width: 158px; }

					.symbol-title {
						padding-top: 4px;
						padding-left: 20px;

						@include respond-max($bp-mid) {
							@include font-size(12);
							padding-top: 8px;
						}
					}
				}
				.illustItem--northpole {
					top: 45px; left: -70px;
					transform: rotate(-4deg);

					@include respond-min($bp-mid) { top: 25px; left: -100px; }
				}

				.illustItem--grotto {
					top: 90px; left: -50px;
					transform: rotate(4deg);
					text-transform: uppercase;
				}

				.illustItem--lapland {
					top: 55px; left: -30px;
					transform: rotate(4deg);

					@include respond-min($bp-mid) { top: 20px; left: -50px; }
				}

			.illustItem--holly {
				z-index: index($layerIndex, level-3);
				top: 540px; left: -260px;
				width: 400px; height: 130px;
				background-repeat: repeat;
				background-position: right center;

				transition: left 300ms;

				@include respond-min(660) { left: -200px; }
				@include respond-min(720) { left: -160px; }
				@include respond-min(840) { left: -100px; }
				@include respond-min(980) { left: -40px; }

				@media screen and (min-height: 750px) { top: 580px; }
			}


			.illustItem--ivy {
				z-index: index($layerIndex, level-3);
				top: 540px; right: -200px;
				width: 325px; height: 114px;

				//spacing for text
				padding: 38px 0 0 80px;

				transition: right 300ms;

				@include respond-min(660) { right: -160px; }
				@include respond-min(800) { right: -80px; }
				@include respond-min($bp-wide) { right: 0; }

				@media screen and (min-height: 750px) { top: 580px; }
			}




			.illustItem--snowglobe {
				z-index: index($layerIndex, level-3);
				width: 102%; height: 116%;
				top: 0; left: 50%;
				transform: translate(-50%);
			}

			.illustItem--town {
				position: relative;
				width: 100%; height: 100%;

				-webkit-user-select: none;  /* Chrome all / Safari all */
				-moz-user-select: none;     /* Firefox all */
				-ms-user-select: none;      /* IE 10+ */
			}

				.svg-town {
					width: 100%; height: 100%;
				}

				.svg-house,
				.svg-carollers,
				.svg-star {
					transition: opacity 300ms;

					&.inactive { @include opacity(0); }

					& svg,
            & img {
						width: 100%;
						height: 100%;
					}
				}

				.svg-house {
					z-index: index($layerIndex, level-3);
					position: absolute;
					width: 100%; height: 100%;
					top: 51%; left: 49.72%;
					transform-origin: left top;
					transform: scale(0.266) translate(-50%, 0);
				}
					.svg-lights {
						z-index: index($layerIndex, level-4);
						position: absolute;
						width: 100%; height: 100%;
						top: 53.1%; left: 50.5%;
						transform-origin: left top;
						transform: scale(0.4) translate(-50%, 0);
					}

				.svg-sleigh {
					position: absolute;
					width: 100%; height: 100%;
					top: 70%; left: 50%;
					transform-origin: left top;
					transform: scale(0.14) translate(-43%, -245%)  rotate(8deg);

					&.inactive { @include opacity(0); }
				}
				.svg-star {
					position: absolute;
					width: 100%; height: 100%;
					top: 38.5%; left: 47%;
					background-color: rgb(13, 15, 39);
					transform-origin: left top;
					transform: scale(0.025) translate(-100%, 0);
				}

				.svg-sledge {
					position: absolute;
					width: 100%; height: 100%;
					top: 75%; left: 64%;
					transform-origin: left top;
					transform: scale(0.14) translate(-50%, 0);
				}
				.svg-carollers {
					z-index: index($layerIndex, level-3);
					position: absolute;
					width: 100%; height: 100%;
					top: 72%; left: 58%;
					transform-origin: left top;
					transform: scale(0.08) translate(-50%, 0);
				}
				.svg-robins {
					z-index: index($layerIndex, level-3);
					position: absolute;
					width: 100%; height: 100%;
					top: 72%; left: 37%;
					transform-origin: left top;
					transform: scale(0.031) translate(0, 0);
				}
				.svg-shopping {
					z-index: index($layerIndex, level-3);
					position: absolute;
					width: 100%; height: 100%;
					top: 76%; left: 17%;
					transform-origin: left top;
					transform: scale(0.06) translate(0, 0);
				}
				.svg-peace {
					z-index: index($layerIndex, level-3);
					position: absolute;
					width: 100%; height: 100%;
					top: 68%; left: 69%;
					transform-origin: left top;
					transform: scale(0.05) translate(0, 0);
				}

				.svg-nativity {
					z-index: index($layerIndex, level-2);
					position: absolute;
					width: 100%; height: 100%;
					top: 54.62%; left: 50%;
					transform-origin: left top;
					transform: scale(0.11) translate(-50%, 0);
				}

				.svg-firstfloor {
					z-index: index($layerIndex, level-2);
					position: absolute;
					width: 100%; height: 100%;
					top: 66.4%; left: 50%;
					transform-origin: left top;
					transform: scale(0.1278) translate(-50.12%, 0);
				}
				.svg-secondfloor {
					z-index: index($layerIndex, level-2);
					position: absolute;
					width: 100%; height: 100%;
					top: 60%; left: 50%;
					transform-origin: left top;
					transform: scale(0.1278) translate(-50.12%, 0);
				}


		// LABELS

			.illustItem--yuletide {
				width: 184px; height: 30px;
				bottom: -37px; left: 24%;

				text-transform: uppercase;
				text-align: center;
			}

		// OUTSIDE LABELS
			.illustItem--carols {
				width: 212px; height: 41px;
				top: 233px; left: 97px;
				padding: 8px 0;
				transform: scale(0.07) translate(0, 15px);
				text-align: center;
			}

		// INSIDE LABELS


			.illustItem--present {
				width: 110px; height: 41px;
				top: 218px; left: 141px;
				transform: scale(0.04) translate(18px, 5px) rotate(-30deg);
				text-align: left;
			}
			.illustItem--nutcracker {
				width: 140px; height: 41px;
				top: 220px; left: 113px;
				transform: scale(0.04) translate(21px, 28px) rotate(14deg);
				text-align: left;
			}




			.illustItem--bingcrosby,
			.illustItem--mariahcarey,
			.illustItem--wham {
				width: 180px; height: 41px;
				top: 188px;
				text-align: center;
			}
			.illustItem--bingcrosby {
				left: 95px;
				transform: scale(0.02) translate(13px, 22px);
			}
			.illustItem--mariahcarey {
				left: 99px;
				transform: scale(0.02) translate(16px, 22px);
			}

			.illustItem--mincepie {
				width: 202px; height: 57px;
				top: 191px; left: 63px;
				padding: 8px 0;
				transform: scale(0.025) translate(20px, 5px);
				text-align: center;
			}


			.illustItem--stocking,
			.illustItem--fireplace {
				width: 202px; height: 57px;
				left: 59px;
				padding: 8px 0;
				text-align: center;
			}
			.illustItem--fireplace {
				top: 187px;
				transform: scale(0.031) translate(12px, 0);
			}

			.illustItem--christmascards {
				width: 100px; height: 57px;
				top: 186px; left: 124px;
				padding: 8px 0;
				transform: scale(0.03) translate(28px, 14px);
			}




		// SLEIGH LABELS

			.illustItem--santa {
				width: 180px; height: 41px;
				top: 126px; left: 105px;
				transform: scale(0.03) translate(-10px, 9px) rotate(8deg);
				text-align: center;

			}
			.illustItem--endquote {
				width: 120px;
				top: 86px; left: 129px;
				transform: scale(0.12) translate(20px, 19px) skew(-12deg) rotate(-10deg);
				color: #fff;
				background-color: rgb(13, 15, 39);
			}
			.symbol-title-sub {
				display: block;
				font-size: 80%;
				margin-bottom: 2px;
			}




.page-footer {
	z-index: 100;
	position: fixed;
	width: 100%;
	padding: 0px 5% 16px;
	background: #fff;
	bottom: 0;
	left: 0;

	@include respond-min($bp-narrow) {
		padding: 10px 20px;
	}
	@include respond-min($bp-wide) {
		padding: 12px 6%;
	}

	&:before {
		content: '';
		position: absolute;
		bottom: 100%;
		left: 0;
		display: block;
		width: 100%;
		height: 44px;
		background-image: url('');

		@include respond-min($bp-narrow) {
			bottom: 90%;
		}
	}

	&:after {
		@include respond-min($bp-narrow) {
			content: 'SCROLL';
			position: absolute;
			bottom: 10px;
			left: 50%;
			transform: translate(-50%, 0);
			display: block;
			width: 125px;
			height: 57px;
			background-image: url('');
			background-position: -4px bottom;
			background-repeat: no-repeat;
			text-align: center;
		}
	}


}

	.page-footer-links {
		text-align: center;
		text-transform: uppercase;
		@include font-size(18);

		@include respond-min($bp-narrow) {
			width: 100%;
			text-align: right;
			margin-top: -10px;
		}

		li {
			display: inline-block;

			@include respond-min($bp-mid) {
				margin-bottom: 0;
			}
			@include respond-max($bp-mid) {
				display: block;
			}

			&:first-child {
				@include respond-min($bp-narrow) {
					float: left;
				}
			}
			&:last-child {
				margin-bottom: 0;
			}
		}

		a {
			color: black;
		}

		.page-footer-info {
			display: inline-block;
			text-decoration: underline;
			display: inline-block;
			vertical-align: middle;
			height: 2.5em;
			line-height: 2.5;

			@include respond-min($bp-narrow) {
				padding-top: 5px;
			}
		}
		.page-footer-site {
			color: #333;
			background: url('') no-repeat center center;
			padding-top: 5px;
			@include respond-min($bp-narrow) {
				margin-left: 20px;
			}
		}
	}

            
          
!
            
              ;(function(KO, $) {

	$(function() {

		KO.UI.init();

	});


	KO.UI = {

		scrollActive: false,

		supports : {
			transform3d: false
		},


		init : function () {
			this.handleZooming();
		},

		handleZooming : function () {

			var zoomContent = $('.illust-container');

			ZUI = new Zoomer(zoomContent);

			//make sure page is at the top when reloaded
			window.scrollTo(0, 0);

		}
	};

// the constructor that will do all the work
function Zoomer( content ) {

	this.setLevels = function() {

		if (this.docWidth > 1500) {
			this.levels = 6.2;
			this.verticalTranslate = 3000;
		} else if (this.docWidth > 1350) {
			this.levels = 6;
			this.verticalTranslate = 2750;
		} else if (this.docWidth > 1250) {
			this.levels = 5.8;
			this.verticalTranslate = 2450;
		} else if (this.docWidth > 1150) {
			this.levels = 5.7;
			this.verticalTranslate = 2350;
		} else if (this.docWidth > 1050) {
			this.levels = 5.5;
			this.verticalTranslate = 2100;
		} else if (this.docWidth > 950) {
			this.levels = 5.35;
			this.verticalTranslate = 1900;
		} else if (this.docWidth > 850) {
			this.levels = 5.15;
			this.verticalTranslate = 1700;
		} else {
			this.levels = 4.9;
			this.verticalTranslate = 1520;
		}

	};



	// keep track of DOM
	this.content = content;

	this.header = $('.page-header');
	this.body = $('body');
	this.town = $('.illust-level--town');
	this.townSymbols = $('.illust-level--symbolsTown');
	this.house = $('.svg-house');
	this.carollers = $('.svg-carollers');
	this.star = $('.svg-star');

	// position of vertical scroll
	this.scrolled = 0;

	var body = document.body,
		html = document.documentElement;

	// height of document
	this.docHeight = Math.max( body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight );
	this.docWidth = html.clientWidth;

	// zero-based number of sections
	this.setLevels();


	// bind Zoomer to scroll event
	window.addEventListener( 'scroll', this, false);
}

// enables constructor to be used within event listener
// like obj.addEventListener( eventName, this, false )
Zoomer.prototype.handleEvent = function( event ) {
	if ( this[event.type] ) {
		this[event.type](event);
	}
};

// triggered every time window scrolls
Zoomer.prototype.scroll = function( event ) {

	this.recalculatePositions();

};

Zoomer.prototype.recalculatePositions = function () {

	//LETS HAVE SOME DEFAULTS HERE
	var INITIAL_TOWN_WIDTH = 350,
		INITIAL_TOWN_HEIGHT = 320,
		TARGET_TOWN_WIDTH = 2800,
		TARGET_TOWN_HEIGHT = 2560,

		TARGET_BG_ZSCALE = 200,

		OFFSET_MARGIN = 80,

		TARGET_VERTICAL_TRANSLATE = 2600;


	var supportPageOffset = window.pageXOffset !== undefined;
	var isCSS1Compat = ((document.compatMode || "") === "CSS1Compat");

	var yOffset = supportPageOffset ? window.pageYOffset : isCSS1Compat ? document.documentElement.scrollTop : document.body.scrollTop;

	// normalize scroll value from 0 to 1
	this.scrolled = yOffset / ( this.docHeight - window.innerHeight );

	var transformValue,
		townTransform,
		symboltransformValue;

	this.checkStates();

	var scrollFactor = (this.scrolled < 0.5 ? this.scrolled : 0.5);
	var scale = Math.pow( 3, scrollFactor * this.levels );
	var townHeight = Math.round(scale * INITIAL_TOWN_HEIGHT);
	var townWidth = Math.round(scale * INITIAL_TOWN_WIDTH);
	var townOffset = Math.round(scale * OFFSET_MARGIN) - OFFSET_MARGIN;

	//first half of app is the scale – this zooms into the house
	if (scrollFactor < 0.5) {

		var townYPos = Math.round(((townHeight / 2) + townOffset));

		//if we support translate3d
		if (KO.UI.supports.transform3d) {
			transformValue = 'translate3d(0, 0, 0) scale(' + scale + ')';

			townTransform = 'translate3d(-50%, -' + townYPos + 'px, 0)';
			symboltransformValue = 'translate3d(-' + (townWidth / 2) + 'px, -' + townYPos + 'px, 0)' + ' scale(' + scale + ')';
		} else {
			transformValue = 'translate(0, 0) scale(' + scale + ')';

			townTransform = 'translate(-50%, -' + townYPos + 'px)';
			symboltransformValue = 'translate(-' + (townWidth / 2) + 'px, -' + townYPos + 'px)' + ' scale(' + scale + ')';
		}

	//the second half is the translate vertically
	} else {

		var percentageThroughSection = ((this.scrolled - 0.5) / 0.5); //get the percentage of the amount through the section (on a scale 0-1)
		var verticalTranslate = percentageThroughSection * this.verticalTranslate; //gets a scaled amount dependent on the percentage of the section scrolled through

		var townYPos = Math.round((townHeight / 2) + townOffset - verticalTranslate);

		//if we support translate3d
		if (KO.UI.supports.transform3d) {
			transformValue = 'translate3d(0, 0, 0) scale(' + scale + ')';
			townTransform = 'translate3d(-50%, -' + townYPos + 'px, 0)';
		} else {
			transformValue = 'translate(0, 0) scale(' + scale + ')';
			townTransform = 'translate(-50%, -' + townYPos + 'px)';
		}

	}

	// SETTING OF OUR NEW VALUES

	//update width and height of town
	this.town[0].style.width = townWidth + 'px';
	this.town[0].style.height = townHeight + 'px';

	// //update the transformed value for the town
	this.town[0].style.WebkitTransform = townTransform;
	this.town[0].style.MozTransform = townTransform;
	this.town[0].style.msTransform = townTransform;
	this.town[0].style.transform = townTransform;

	// //update scale factor of the outside illustrations and text
	// if(navigator.userAgent.toLowerCase().indexOf('firefox') === -1) {
		this.content[0].style.WebkitTransform = transformValue;
		this.content[0].style.MozTransform = transformValue;
		this.content[0].style.msTransform = transformValue;
		this.content[0].style.transform = transformValue;
	// }

	// //town symbols scaling
	this.townSymbols[0].style.WebkitTransform = 'scale(' + scale + ')';
	this.townSymbols[0].style.MozTransform = 'scale(' + scale + ')';
	this.townSymbols[0].style.msTransform = 'scale(' + scale + ')';
	this.townSymbols[0].style.transform = 'scale(' + scale + ')';

};


Zoomer.prototype.checkStates = function () {

	if (this.scrolled > 0) {
		this.header.addClass('scaled');
	} else {
		this.header.removeClass('scaled');
	}


	//do a test whether to switch to night or not (after 0.25 scrolled)
	if (this.scrolled > 0.15) {
		this.body.addClass('night');
	} else {
		this.body.removeClass('night');
	}

	//test between state of movement
	if (this.scrolled < 0.5) {

		this.house.removeClass('inactive'); //make house visible
		this.carollers.removeClass('inactive'); //make carollers invisible
		this.star.addClass('inactive'); //make carollers invisible
		this.townSymbols.find('.symbols--inside').addClass('inactive'); //make nativity symbols not visible
		this.townSymbols.find('.symbols--outside').removeClass('inactive'); //make nativity symbols not visible

	} else {

		this.house.addClass('inactive'); //make house not visible
		this.carollers.addClass('inactive'); //make carollers invisible
		this.star.removeClass('inactive'); //make carollers invisible
		this.townSymbols.find('.symbols--inside').removeClass('inactive'); //make nativity symbols visible
		this.townSymbols.find('.symbols--outside').addClass('inactive'); //make nativity symbols not visible
	}
};


})(window.KO = window.KO || {}, jQuery);

            
          
!
999px
🕑 One or more of the npm packages you are using needs to be built. You're the first person to ever need it! We're building it right now and your preview will start updating again when it's ready.
Loading ..................

Console