@import url(https://fonts.googleapis.com/css?family=Raleway:900,600,500,800,700);
* {
    box-sizing: border-box;
}
.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}

.clearfix:after {
    clear: both;
}

.clearfix {
    *zoom: 1;
}

body {
    font-family: Raleway, sans-serif;
    background-color: #f8f8f8;
    padding: 0;
    margin: 0;
}

small {
    color: #aaa;
}

header {
    background-color: #fff;
    padding: 1em;
    margin-bottom: 1em;
}

#logo {
    display: inline-block;
    max-width: 250px;
}

.container {
    margin: 0 auto;
    width: 95vw;
    max-width: 1200px;
}

.controls .icon {
    display: inline-block;
}

.preview {
    float: left;
    width: 100%;
    height: 0;
    padding-top: 100%;
    position: relative;

    background-color: #6504c7;
    background-image: url(example.png);
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: normal;
}

.text-container {
    position: absolute;
    top: 50%;
    width: 100%;
    display: none;
}
.text-container:focus {
    outline: 0;
}

h1 {
    position: absolute;
    color: white;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 0;
    right: 0;
    font-size: 1.5em;
    font-weight: 900;
    padding: .25em;
}


#textOptions {
    position: absolute;
    top: -4em;
    left: 1em;
    z-index: 3;
    padding-right: 2em;
    overflow: visible;
    visibility: hidden;
    background-color: #fff;
    cursor: move;
    box-shadow: 0 0 3px 1px rgba(255, 255, 255, .5);
}
#textOptions .icon, select {
    display: inline-block;
    margin: .5em;
}
#textOptions > * {
    position: relative;
}
#textOptions .handle {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}
select {
    z-index: 1;
    vertical-align: middle;
}
select:focus {
    outline: 0;
}


.thumbnail {
    cursor: pointer;
    float: left;
    width: 25%;
    height: 0;
    padding-top: 25%;
    position: relative;
    background-position: 50% 50%;
    background-image: url(example.png);
    background-size: cover;
    background-color: #6504c7;
    position: relative;
}

.thumbnail[data-mode]::after {
    content: attr(data-mode);
    display: block;
    position: absolute;
    top: 0;
    font-size: .8em;
    line-height: 4;
    width: 100%;
    text-align: center;
    color: white;
}

[data-mode="normal"] {
    background-blend-mode: normal;
}
[data-mode="multiply"] {
    background-blend-mode: multiply;
}
[data-mode="screen"] {
    background-blend-mode: screen;
}
[data-mode="overlay"] {
    background-blend-mode: overlay;
}
[data-mode="darken"] {
    background-blend-mode: darken;
}
[data-mode="lighten"] {
    background-blend-mode: lighten;
}
[data-mode="color-dodge"] {
    background-blend-mode: color-dodge;
}
[data-mode="color-burn"] {
    background-blend-mode: color-burn;
}
[data-mode="hard-light"] {
    background-blend-mode: hard-light;
}
[data-mode="soft-light"] {
    background-blend-mode: soft-light;
}
[data-mode="difference"] {
    background-blend-mode: difference;
}
[data-mode="exclusion"] {
    background-blend-mode: exclusion;
}
[data-mode="hue"] {
    background-blend-mode: hue;
}
[data-mode="saturation"] {
    background-blend-mode: saturation;
}
[data-mode="color"] {
    background-blend-mode: color;
}
[data-mode="luminosity"] {
    background-blend-mode: luminosity;
}



img {
    max-width: 100%;
}
svg {
    display: block;
    cursor: pointer;
    fill: #888;
}
.icon svg {
    cursor: pointer;
}
.icon:hover svg:not(.active) {
    fill: #000;
}
.icon {
    margin: .75em;
    width: 1.75em;
    height: 1.75em;
    position: relative;
    vertical-align: middle;
    cursor: pointer;
}
input, select {
    cursor: pointer;
}
.icon.file {
    overflow: hidden; /* for safari issue */
}
.text-icon.active {
    fill: deepPink;
    position: relative;
}
.drop-icon, .color-input, .file-input, .upload-icon {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
}
.drop-icon {
    fill: #6504c7;
}
.color-input {
    z-index: 2;
    height: 3em;
    width: 3em;
    border: 0;
    opacity: 0;
}
.file-input {
    z-index: 2;
    width: 40px;
    height: 40px;
    opacity: 0;
}

.instructions {
    clear: both;
    padding: 1em 0;
}

footer {
    clear: both;
    text-align: center;
    padding: 5em 1em 2em;
}
a {
    color: deepPink;
    text-decoration: none;
}

.about {
    position: fixed;
    top: -100%;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: #370145;
    color: white;
    overflow-y: auto;
    z-index: 5;
    -webkit-transition: top .3s linear;
    transition: top .3s linear;
}
.about:target {
    top: 0;
}
.wrapper {
    width: 80%;
    margin: 3em auto;
}
.close {
    position: absolute;
    top: 0;
    right: 0;
    padding: .25em .75em;
    font-size: 3em;
}
hr {
    border: 0;
    height: 1px;
    width: 50%;
    margin: 40px auto;
    background-image: -webkit-linear-gradient(left, rgba(150,150,150,0), rgba(150,150,150,0.75), rgba(150,150,150,0));
    background-image: linear-gradient(to right, rgba(150,150,150,0), rgba(150,150,150,0.75), rgba(150,150,150,0));
}

@media (min-width: 600px) {
    .container {
        width: 93vw;
        margin: 0 auto;
    }
    .controls {
        float: right;
        margin-top: .7em;
    }
    .preview {
        width: 50%;
        padding-top: 50%;
        float: left;
    }
    .thumbnail {
        width: 12.5%;
        padding-top: 12.5%;
    }
}

@media (min-width: 1024px) {
    h1 {
        font-size: 2em;
    }

    li[data-mode]::after {
        line-height: 100px;
    }

    .wrapper {
        width: 60%;
        margin: 5em auto;
    }

}
@media (min-width: 1400px) {
    h1 {
        font-size: 3em;
    }

    .thumbnail[data-mode]::after {
        line-height: 130px;
    }
}

/*
colpick Color Picker / colpick.com
*/

/*Main container*/
.colpick {
    position: absolute;
    width: 346px;
    height: 170px;
    left: -346px;
    overflow: hidden;
    display: none;
    padding: 1em;
    font-family: Arial, Helvetica, sans-serif;
    background:#fff;
    border: 1px solid #eee;
    box-shadow: 0 5px 5px 3px rgba(0,0,0,0.2);
    z-index: 5;

    /*Prevents selecting text when dragging the selectors*/
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
/*Color selection box with gradients*/
.colpick_color {
    position: absolute;
    left: 7px;
    top: 7px;
    width: 156px;
    height: 156px;
    overflow: hidden;
    outline: 1px solid #eee;
    cursor: crosshair;
}
.colpick_color_overlay1 {
    position: absolute;
    left:0;
    top:0;
    width: 156px;
    height: 156px;
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=1,startColorstr='#ffffff', endColorstr='#00ffffff')"; /* IE8 */ /* FF3.6+ */
    background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(255,255,255,1)), color-stop(100%,rgba(255,255,255,0))); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(left, rgba(255,255,255,1) 0%,rgba(255,255,255,0) 100%); /* Chrome10+,Safari5.1+ */ /* Opera 11.10+ */ /* IE10+ */
    background: -webkit-linear-gradient(left, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%);
    background: linear-gradient(to right, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%);
    filter:  progid:DXImageTransform.Microsoft.gradient(GradientType=1,startColorstr='#ffffff', endColorstr='#00ffffff'); /* IE6 & IE7 */
}
.colpick_color_overlay2 {
    position: absolute;
    left:0;
    top:0;
    width: 156px;
    height: 156px;
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#00000000', endColorstr='#000000')"; /* IE8 */ /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(0,0,0,0)), color-stop(100%,rgba(0,0,0,1))); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,1) 100%); /* Chrome10+,Safari5.1+ */ /* Opera 11.10+ */ /* IE10+ */
    background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,1) 100%);
    background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,1) 100%); /* W3C */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#000000',GradientType=0 ); /* IE6-9 */
}
/*Circular color selector*/
.colpick_selector_outer {
    background:none;
    position: absolute;
    width: 11px;
    height: 11px;
    margin: -6px 0 0 -6px;
    border: 1px solid black;
    border-radius: 50%;
}
.colpick_selector_inner{
    position: absolute;
    width: 9px;
    height: 9px;
    border: 1px solid white;
    border-radius: 50%;
}
/*Vertical hue bar*/
.colpick_hue {
    position: absolute;
    top: 6px;
    left: 175px;
    width: 19px;
    height: 156px;
    border: 1px solid #eee;
    cursor: n-resize;
}
/*Hue bar sliding indicator*/
.colpick_hue_arrs {
    position: absolute;
    left: -8px;
    width: 35px;
    height: 7px;
    margin: -7px 0 0 0;
}
.colpick_hue_larr {
    position:absolute;
    width: 0;
    height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 7px solid #858585;
}
.colpick_hue_rarr {
    position:absolute;
    right:0;
    width: 0;
    height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-right: 7px solid #858585;
}
/*New color box*/
.colpick_new_color {
    position: absolute;
    left: 207px;
    top: 6px;
    width: 60px;
    height: 27px;
    background: #f00;
    border: 1px solid #8f8f8f;
}
/*Current color box*/
.colpick_current_color {
    position: absolute;
    left: 277px;
    top: 6px;
    width: 60px;
    height: 27px;
    background: #f00;
    border: 1px solid #8f8f8f;
}
/*Input field containers*/
.colpick_field, .colpick_hex_field  {
    position: absolute;
    height: 20px;
    width: 60px;
    overflow:hidden;
    background:#fff;
    color:#333;
    font-size:12px;
    border:1px solid #eee;
}
.colpick_rgb_r {
    top: 40px;
    left: 207px;
}
.colpick_rgb_g {
    top: 67px;
    left: 207px;
}
.colpick_rgb_b {
    top: 94px;
    left: 207px;
}
.colpick_hsb_h {
    top: 40px;
    left: 277px;
}
.colpick_hsb_s {
    top: 67px;
    left: 277px;
}
.colpick_hsb_b {
    top: 94px;
    left: 277px;
}
.colpick_hex_field {
    width: 68px;
    left: 207px;
    top: 121px;
}
/*Text field container on focus*/
.colpick_focus {
    border-color: #999;
}
/*Field label container*/
.colpick_field_letter {
    position: absolute;
    width: 12px;
    height: 20px;
    line-height: 20px;
    padding-left: 4px;
    background: #fff;
    border-right: 1px solid #eee;
    font-weight: bold;
    color:#333;
}
/*Text inputs*/
.colpick_field input, .colpick_hex_field input {
    position: absolute;
    right: 11px;
    margin: 0;
    padding: 0;
    height: 20px;
    line-height: 20px;
    background: transparent;
    border: none;
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
    color: #555;
    text-align: right;
    outline: none;
}
.colpick_hex_field input {
    right: 4px;
}
/*Field up/down arrows*/
.colpick_field_arrs {
    position: absolute;
    top: 0;
    right: 0;
    width: 9px;
    height: 21px;
    cursor: n-resize;
}
.colpick_field_uarr {
    position: absolute;
    top: 5px;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 4px solid #959595;
}
.colpick_field_darr {
    position: absolute;
    bottom:5px;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid #959595;
}
/*Submit/Select button*/
.colpick_submit {
    position: absolute;
    left: 207px;
    top: 149px;
    width: 130px;
    height: 22px;
    line-height:22px;
    background: #efefef;
    text-align: center;
    color: #555;
    font-size: 12px;
    font-weight:bold;
    border: 1px solid #bdbdbd;
    border-radius: 3px;
}
.colpick_submit:hover {
    background:#f3f3f3;
    border-color:#999;
    cursor: pointer;
}

/*full layout with no submit button*/
.colpick_full_ns  .colpick_submit, .colpick_full_ns .colpick_current_color{
    display:none;
}
.colpick_full_ns .colpick_new_color {
    width: 130px;
    height: 25px;
}
.colpick_full_ns .colpick_rgb_r, .colpick_full_ns .colpick_hsb_h {
    top: 42px;
}
.colpick_full_ns .colpick_rgb_g, .colpick_full_ns .colpick_hsb_s {
    top: 73px;
}
.colpick_full_ns .colpick_rgb_b, .colpick_full_ns .colpick_hsb_b {
    top: 104px;
}
.colpick_full_ns .colpick_hex_field {
    top: 135px;
}

/*rgbhex layout*/
.colpick_rgbhex .colpick_hsb_h, .colpick_rgbhex .colpick_hsb_s, .colpick_rgbhex .colpick_hsb_b {
    display:none;
}
.colpick_rgbhex {
    width:282px;
}
.colpick_rgbhex .colpick_field, .colpick_rgbhex .colpick_submit {
    width:68px;
}
.colpick_rgbhex .colpick_new_color {
    width:34px;
    border-right:none;
}
.colpick_rgbhex .colpick_current_color {
    width:34px;
    left:240px;
    border-left:none;
}

/*rgbhex layout, no submit button*/
.colpick_rgbhex_ns  .colpick_submit, .colpick_rgbhex_ns .colpick_current_color{
    display:none;
}
.colpick_rgbhex_ns .colpick_new_color{
    width:68px;
    border: 1px solid #8f8f8f;
}
.colpick_rgbhex_ns .colpick_rgb_r {
    top: 42px;
}
.colpick_rgbhex_ns .colpick_rgb_g {
    top: 73px;
}
.colpick_rgbhex_ns .colpick_rgb_b {
    top: 104px;
}
.colpick_rgbhex_ns .colpick_hex_field {
    top: 135px;
}

/*hex layout*/
.colpick_hex .colpick_hsb_h, .colpick_hex .colpick_hsb_s, .colpick_hex .colpick_hsb_b, .colpick_hex .colpick_rgb_r, .colpick_hex .colpick_rgb_g, .colpick_hex .colpick_rgb_b {
    display:none;
}
.colpick_hex {
    width:206px;
    height:201px;
}
.colpick_hex .colpick_hex_field {
    width:72px;
    height:25px;
    top:168px;
    left:80px;
}
.colpick_hex .colpick_hex_field div, .colpick_hex .colpick_hex_field input {
    height: 25px;
    line-height: 25px;
}
.colpick_hex .colpick_new_color {
    left:9px;
    top:168px;
    width:30px;
    border-right:none;
}
.colpick_hex .colpick_current_color {
    left:39px;
    top:168px;
    width:30px;
    border-left:none;
}
.colpick_hex .colpick_submit {
    left:164px;
    top: 168px;
    width:30px;
    height:25px;
    line-height: 25px;
}

/*hex layout, no submit button*/
.colpick_hex_ns  .colpick_submit, .colpick_hex_ns .colpick_current_color {
    display:none;
}
.colpick_hex_ns .colpick_hex_field {
    width:80px;
}
.colpick_hex_ns .colpick_new_color{
    width:60px;
    border: 1px solid #8f8f8f;
}

/*Dark color scheme*/
.colpick_dark {
    background: #161616;
    border-color: #2a2a2a;
}
.colpick_dark .colpick_color {
    outline-color: #333;
}
.colpick_dark .colpick_hue {
    border-color: #555;
}
.colpick_dark .colpick_field, .colpick_dark .colpick_hex_field {
    background: #101010;
    border-color: #2d2d2d;
}
.colpick_dark .colpick_field_letter {
    background: #131313;
    border-color: #2d2d2d;
    color: #696969;
}
.colpick_dark .colpick_field input, .colpick_dark .colpick_hex_field input {
    color: #7a7a7a;
}
.colpick_dark .colpick_field_uarr {
    border-bottom-color:#696969;
}
.colpick_dark .colpick_field_darr {
    border-top-color:#696969;
}
.colpick_dark .colpick_focus {
    border-color:#444;
}
.colpick_dark .colpick_submit {
    background: #131313;
    border-color:#2d2d2d;
    color:#7a7a7a;
}
.colpick_dark .colpick_submit:hover {
    background-color:#101010;
    border-color:#444;
}



