<?xml version='1.0' encoding='UTF-8'?><rss xmlns:atom="http://www.w3.org/2005/Atom" xmlns:openSearch="http://a9.com/-/spec/opensearchrss/1.0/" xmlns:blogger="http://schemas.google.com/blogger/2008" xmlns:georss="http://www.georss.org/georss" xmlns:gd="http://schemas.google.com/g/2005" xmlns:thr="http://purl.org/syndication/thread/1.0" version="2.0"><channel><atom:id>tag:blogger.com,1999:blog-2441310466914017833</atom:id><lastBuildDate>Fri, 16 Jan 2026 00:46:48 +0000</lastBuildDate><category>infographic</category><category>bored and insane</category><category>john larwood</category><category>animation</category><category>art</category><category>cartoon</category><category>comic</category><category>funny</category><category>killer whale</category><category>music</category><category>Olympics</category><category>Robert Burton</category><category>ambigram</category><category>apartment</category><category>athletics</category><category>biggest badass</category><category>black</category><category>blog</category><category>book design</category><category>bored</category><category>cardboard sculpture</category><category>chart</category><category>cracked.com</category><category>data</category><category>douche</category><category>game</category><category>garageband</category><category>good music</category><category>graphic design</category><category>new website</category><category>orca</category><category>orcinus orca</category><category>red</category><category>results</category><category>roommate</category><category>running</category><category>shirt</category><category>soundcloud</category><category>statistics</category><category>track &amp; field</category><category>web design</category><category>#NOhalf</category><category>#SLOhalf</category><category>1600x1200</category><category>1st gen starters</category><category>2016</category><category>400 meters</category><category>400m</category><category>8 Mile</category><category>800 meters</category><category>800m</category><category>9gag</category><category>Android</category><category>Easter</category><category>Eminem</category><category>Fiftten Puzzle</category><category>Ian Malcolm</category><category>Jeff Goldblum</category><category>Jurassic Park</category><category>Netflix</category><category>New Year</category><category>Palahniuk</category><category>Pop-Tarts</category><category>Velociraptor</category><category>a secret redemption</category><category>acoustic</category><category>after effects</category><category>ambidexterity</category><category>ambidextrous</category><category>ambigrams</category><category>ambiguous</category><category>ambrose bierce</category><category>american</category><category>an occurrence at owl creek bridge</category><category>and other distressing facts</category><category>animated gif</category><category>app</category><category>apparel</category><category>apple</category><category>art techniques</category><category>artist</category><category>awesome</category><category>background</category><category>bathroom</category><category>batman</category><category>beach</category><category>bear</category><category>bell peppers</category><category>bernard</category><category>bible</category><category>bird shit</category><category>blue</category><category>boredom</category><category>bright</category><category>bucky katt</category><category>bulbasaur</category><category>bunny</category><category>burns</category><category>business</category><category>buy</category><category>cal poly</category><category>california polytechnic state university</category><category>caped crusader</category><category>cardboard</category><category>casino royale</category><category>cat</category><category>charmander</category><category>cheese</category><category>chicks</category><category>child safety</category><category>cleaning</category><category>clubs</category><category>color picker</category><category>combination</category><category>comic strip</category><category>comparison</category><category>convergence</category><category>cracked</category><category>crayon art</category><category>crazy art</category><category>creation</category><category>crocodiles</category><category>crossing guard</category><category>crucifix</category><category>customize</category><category>cute</category><category>dark knight</category><category>dark knight rises</category><category>deck of cards</category><category>design</category><category>designer</category><category>desktop</category><category>development</category><category>diamonds</category><category>diarrhea</category><category>dinosaur</category><category>discovery</category><category>dolphin</category><category>doodle</category><category>douching it up</category><category>drawing</category><category>dribbble bored and insane eye of the hawk mendocino brewing company select ale redesign</category><category>ducks</category><category>dudes</category><category>dumb</category><category>dumb running sonic</category><category>easter day</category><category>edgar allan poe</category><category>existential crisis</category><category>expressive type</category><category>eye</category><category>fight</category><category>flaming hot</category><category>flourescent guy</category><category>follow the boredom</category><category>football</category><category>frank the spider</category><category>funny comic</category><category>gameboy</category><category>get fuzzy</category><category>gradients</category><category>habanero</category><category>heart</category><category>hearts</category><category>heat</category><category>heat scale</category><category>hilarious</category><category>honey badger</category><category>hot</category><category>human</category><category>hurdles</category><category>iOS</category><category>illustrator</category><category>in the animal kingdom</category><category>inverted portrait</category><category>iphone</category><category>jalapeno</category><category>jesus</category><category>just a bunch of words</category><category>keystone light</category><category>killer</category><category>lame ideas</category><category>land</category><category>letter l</category><category>light</category><category>light art</category><category>link</category><category>lion chasing giraffe</category><category>look out</category><category>m16</category><category>magic square</category><category>marathon</category><category>mobile</category><category>mobile site</category><category>modern art</category><category>non-dominant</category><category>notes</category><category>office</category><category>on a tank</category><category>organization</category><category>organoleptic test</category><category>passive aggressive</category><category>pear films</category><category>pearls before swine</category><category>peppers</category><category>perception</category><category>perception is everything</category><category>picasso</category><category>pig</category><category>piquancy</category><category>pixel art</category><category>pointilism</category><category>pokemon</category><category>pop tarts</category><category>predator</category><category>profanity</category><category>public speaking</category><category>pun</category><category>puzzle game</category><category>quick sketch</category><category>quitting</category><category>rabbit</category><category>random</category><category>rat</category><category>redesign</category><category>resolutions</category><category>resurrection</category><category>retro bowl</category><category>reversed image</category><category>ridiculous</category><category>santa claus</category><category>satchel pootch</category><category>scorched asshole</category><category>scoville heat</category><category>scoville units</category><category>shark week</category><category>sharks</category><category>sharpie</category><category>sheep</category><category>shiny</category><category>shower</category><category>size comparison chart</category><category>sketch</category><category>skull</category><category>slow</category><category>smooth</category><category>snow</category><category>song</category><category>spades</category><category>spiciness</category><category>spicy</category><category>spider</category><category>spread the insanity</category><category>sprites</category><category>squirtle</category><category>stephan pastis</category><category>stress is killing you</category><category>symbols</category><category>tank</category><category>team editor</category><category>tell-tale heart</category><category>terrible web site</category><category>the oatmeal</category><category>the prestige</category><category>the toast</category><category>total randomness</category><category>traditional</category><category>tradtional art</category><category>typographic expression</category><category>typography</category><category>unconventional</category><category>uniform</category><category>uniform designs</category><category>vector</category><category>veloci-rooster</category><category>video</category><category>video games</category><category>wallpaper</category><category>watching you</category><category>web principles</category><category>webclip icon</category><category>website</category><category>whale</category><category>whales</category><category>winnie the pooh</category><category>wolf</category><category>words</category><category>worms</category><category>youtube</category><category>zelda</category><category>zombie</category><category>zombie jesus</category><category>zombie movie</category><title>Bored and Insane</title><description>I am an artist. This is my art.</description><link>http://boredandinsane.blogspot.com/</link><managingEditor>noreply@blogger.com (Bored and Insane)</managingEditor><generator>Blogger</generator><openSearch:totalResults>53</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>25</openSearch:itemsPerPage><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-4918028389839043889</guid><pubDate>Thu, 15 Jan 2026 04:19:00 +0000</pubDate><atom:updated>2026-01-14T20:52:38.041-08:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">color picker</category><category domain="http://www.blogger.com/atom/ns#">customize</category><category domain="http://www.blogger.com/atom/ns#">football</category><category domain="http://www.blogger.com/atom/ns#">game</category><category domain="http://www.blogger.com/atom/ns#">mobile</category><category domain="http://www.blogger.com/atom/ns#">retro bowl</category><category domain="http://www.blogger.com/atom/ns#">team editor</category><category domain="http://www.blogger.com/atom/ns#">uniform</category><category domain="http://www.blogger.com/atom/ns#">uniform designs</category><title>Retro Bowl Color Picker</title><description>
&lt;style&gt;
  
  button,hr,input{overflow:visible}audio,canvas,progress,video{display:inline-block}progress,sub,sup{vertical-align:baseline}html{font-family:sans-serif;line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0} menu,article,aside,details,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure,main{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;height:0}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button,input{}button,select{text-transform:none}[type=submit], [type=reset],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:ButtonText dotted 1px}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}[hidden],template{display:none}/*# sourceMappingURL=normalize.min.css.map */
  
  
  body,
html {
  height: 100%;
  display: block;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  justify-content: center;
  align-items: center;
  font-family: arial;
  font-size: 12px;
}

body {
	/* background: #2f68ff;*/
}


.colors {
  clear: both;
  display: block;
  float: left;
  height:auto;
  width: 100%;
}

.colors__inputs {
  display: block;
  float:left;
  text-align: center;
}

.label {
  font-size:.8em;
  font-weight:bold;
  display: block;
  padding: .4em auto;
  width:100%;
  height:2.1em;
}

.single {
	line-height:2.1em;
}

.colors .jscolor{
  border: 1px solid;
  height: 30px;
  border-radius: 5px;
  width:90%;
  padding:10%;
  font-size: .9em;
}

.attribute {
	display: block;
	float: left;
	width: 70px;
  	margin: 10px;
  	text-align: center;
	
}

.helmet, .facemask, .logo, .jersey, .sleeve, .pants, .stripe, .sockshigh, .sockslow  {
  transition: 0.25s ease-in-out;
}
.helmet__overlay, .facemask__overlay, .logo__overlay, .jersey__overlay, .pants__overlay, .stripe__overlay, .sockshigh__overlay, .sockslow__overlay {
  position: absolute;
  top: 0;
  left: 0;
}

.skin1 {fill:#E7C49F;}
.skin2 {fill:#573527;}
.skin3 {fill:#ba8857;}

.helmet__overlay {
  z-index: 2;
  fill: #FFFFFF;
}

.facemask__overlay {
  z-index: 3;
  fill: #9E9E9E;
}


.logo__overlay {
  z-index: 2;
  fill: #FF9F3E;
}

.jersey__overlay{
  z-index: 2;
  fill: #000000;
}

.sleeve__overlay{
  z-index: 2;
  fill: #53E227;
}

.pants__overlay {
  z-index: 2;
  fill: #FFA70E;
	
}

.stripe__overlay {
  z-index: 2;
  fill: #FFFFFF;
}


.sockshigh__overlay {
  z-index: 2;
  fill: #21AAC6;
}

.sockslow__overlay {
  z-index: 2;
  fill: #FFFFFF;
}

.backgroundcolor__overlay {
  z-index: 2;
  fill: #557f31;
}



.helmet__overlay.fade, .facemask__overlay.fade, .logo__overlay.fade, .jersey__overlay.fade, .pants__overlay.fade, .stripe__overlay.fade, .sockslow__overlay.fade, .sockshigh__overlay.fade {
  transition: 0.6s ease-in-out;
}

.gen-random {
  display: block;
  float:left;
  clear:both;
  background: #2f68ff;
  padding:15px 30px;
  margin:10px;
  border: 1px solid white;
  color: white;
  border-radius: 5px;
  box-shadow: 1px 1px 1px rgba(255, 255, 255, 1.0);
  font-size: .9em;
  font-weight: bold;
  cursor: pointer;
}

.gen-random:hover {
	background: #2B60EA;
	box-shadow: 0px 0px 10px rgba(0,0,0,0.2);
	
}
  
  .gen-random:active {
	background: #224BB8;
	box-shadow: 0px 0px 10px rgba(0,0,0,0.2);
	
}
  
  @media only screen and (max-width: 800px) {
    
    .attribute {
	width: 50px;
  	margin: 5px;
	}

  }

&lt;/style&gt;

&lt;p&gt;Do you enjoy designing custom uniforms for your Retro Bowl teams, but get frustrated entering in a million hex codes?&lt;/p&gt;
&lt;p&gt;If so, this is a tool for you!&lt;/p&gt;
  
&lt;svg style=&quot;enable-background: new 0 0 490 210;&quot; version=&quot;1.1&quot; viewbox=&quot;0 0 490 210&quot; width=&quot;90%&quot; x=&quot;0px&quot; xml:space=&quot;preserve&quot; xmlns:xlink=&quot;http://www.w3.org/1999/xlink&quot; xmlns=&quot;http://www.w3.org/2000/svg&quot; y=&quot;0px&quot;&gt;	
&lt;g id=&quot;backgroundcolor&quot;&gt;
	&lt;rect class=&quot;backgroundcolor__overlay&quot; height=&quot;210&quot; id=&quot;js-background-color&quot; width=&quot;490&quot;&gt;
&lt;/rect&gt;&lt;/g&gt;
	
	&lt;g id=&quot;shadow&quot; style=&quot;opacity: 0.2;&quot;&gt;
		&lt;polygon points=&quot;150,160 40,160 40,170 30,170 30,180 40,180 40,190 150,190 150,180 160,180 160,170 150,170 	&quot;&gt;&lt;/polygon&gt;
		&lt;polygon points=&quot;300,160 190,160 190,170 180,170 180,180 190,180 190,190 300,190 300,180 310,180 310,170 300,170 	
		&quot;&gt;&lt;/polygon&gt;
		&lt;polygon points=&quot;450,170 450,160 340,160 340,170 330,170 330,180 340,180 340,190 450,190 450,180 460,180 460,170 	
		&quot;&gt;
	&lt;/polygon&gt;&lt;/g&gt;
	
	&lt;g id=&quot;jersey&quot;&gt;
		&lt;g class=&quot;jersey__overlay&quot; id=&quot;js-jersey&quot;&gt;
			&lt;polygon points=&quot;70,60 60,60 60,80 50,80 50,100 70,100 70,110 120,110 120,50 70,50 	&quot;&gt;&lt;/polygon&gt;
			&lt;polygon points=&quot;220,60 210,60 210,80 200,80 200,100 220,100 220,110 270,110 270,50 220,50 	&quot;&gt;&lt;/polygon&gt;
			&lt;polygon points=&quot;370,50 370,60 360,60 360,80 350,80 350,100 370,100 370,110 420,110 420,50 	&quot;&gt;&lt;/polygon&gt;
		&lt;/g&gt;

	&lt;/g&gt;
	
	&lt;g id=&quot;pants&quot;&gt;

			&lt;g class=&quot;pants__overlay&quot; id=&quot;js-pants&quot;&gt;
				&lt;polygon points=&quot;110,100 50,100 50,130 60,130 60,150 80,150 80,130 90,130 90,140 120,140 120,120 110,120 	&quot;&gt;&lt;/polygon&gt;
				&lt;polygon points=&quot;260,100 200,100 200,130 210,130 210,150 230,150 230,130 240,130 240,140 270,140 270,120 260,120 	
		&quot;&gt;&lt;/polygon&gt;
				&lt;polygon points=&quot;410,120 410,100 350,100 350,130 360,130 360,150 380,150 380,130 390,130 390,140 420,140 420,120 	
		&quot;&gt;&lt;/polygon&gt;
			&lt;/g&gt;
&lt;/g&gt;


&lt;g class=&quot;pants_shadow&quot; style=&quot;color:#000;opacity:.12;&quot;&gt;
	&lt;polygon points=&quot;260,100 240,100 240,130 240,140 270,140 270,120 260,120 	&quot;/&gt;
	&lt;polygon points=&quot;410,100 390,100 390,130 390,140 420,140 420,120 410,120 	&quot;/&gt;
	&lt;polygon points=&quot;110,100 90,100 90,130 90,140 120,140 120,120 110,120 	&quot;/&gt;
&lt;/g&gt;

&lt;g class=&quot;skin1&quot;&gt;
	&lt;rect height=&quot;30&quot; width=&quot;20&quot; x=&quot;100&quot; y=&quot;40&quot;&gt;&lt;/rect&gt;
	&lt;polygon points=&quot;130,100 130,90 110,90 110,110 120,110 120,120 140,120 140,100 	&quot;&gt;&lt;/polygon&gt;
	&lt;polygon points=&quot;90,80 70,80 70,110 80,110 80,120 100,120 100,100 90,100 	&quot;&gt;&lt;/polygon&gt;
&lt;/g&gt;
	
	
&lt;g class=&quot;skin2&quot;&gt;
	&lt;rect height=&quot;30&quot; width=&quot;20&quot; x=&quot;250&quot; y=&quot;40&quot;&gt;&lt;/rect&gt;
	&lt;polygon points=&quot;280,100 280,90 260,90 260,110 270,110 270,120 290,120 290,100 	&quot;&gt;&lt;/polygon&gt;
	&lt;polygon points=&quot;240,80 220,80 220,110 230,110 230,120 250,120 250,100 240,100 	&quot;&gt;&lt;/polygon&gt;
&lt;/g&gt;
	
&lt;g class=&quot;skin3&quot;&gt;
  &lt;rect height=&quot;30&quot; width=&quot;20&quot; x=&quot;400&quot; y=&quot;40&quot;&gt;&lt;/rect&gt;
	&lt;polygon points=&quot;430,100 430,90 410,90 410,110 420,110 420,120 440,120 440,100 	&quot;&gt;&lt;/polygon&gt;
	&lt;polygon points=&quot;390,80 370,80 370,110 380,110 380,120 400,120 400,100 390,100 	&quot;&gt;&lt;/polygon&gt;
&lt;/g&gt;
	

&lt;g id=&quot;helmet&quot;&gt;

	&lt;g class=&quot;helmet__overlay&quot; id=&quot;js-helmet&quot;&gt;
	&lt;polygon points=&quot;120,20 90,20 90,30 80,30 80,60 90,60 90,70 100,70 100,40 130,40 130,30 120,30 	&quot;&gt;&lt;/polygon&gt;
	&lt;polygon points=&quot;270,20 240,20 240,30 230,30 230,60 240,60 240,70 250,70 250,40 280,40 280,30 270,30 	&quot;&gt;&lt;/polygon&gt;
    &lt;polygon points=&quot;420,30 420,20 390,20 390,30 380,30 380,60 390,60 390,70 400,70 400,40 430,40 430,30 	&quot;&gt;
	&lt;/polygon&gt;
    &lt;/g&gt;
&lt;/g&gt;	
		
&lt;g id=&quot;facemask&quot;&gt;
	&lt;g class=&quot;facemask__overlay&quot; id=&quot;js-facemask&quot;&gt;
	&lt;rect height=&quot;10&quot; width=&quot;10&quot; x=&quot;100&quot; y=&quot;50&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;110&quot; y=&quot;60&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;260&quot; y=&quot;60&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;10&quot; x=&quot;250&quot; y=&quot;50&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;10&quot; x=&quot;400&quot; y=&quot;50&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;410&quot; y=&quot;60&quot;&gt;&lt;/rect&gt;
	&lt;/g&gt;
&lt;/g&gt;


&lt;g id=&quot;logo&quot;&gt;
	&lt;g class=&quot;logo__overlay&quot; id=&quot;js-logo&quot;&gt;
	&lt;rect height=&quot;10&quot; width=&quot;10&quot; x=&quot;90&quot; y=&quot;30&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;10&quot; x=&quot;240&quot; y=&quot;30&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;10&quot; x=&quot;390&quot; y=&quot;30&quot;&gt;&lt;/rect&gt;
	&lt;/g&gt;
	
&lt;/g&gt;

&lt;g id=&quot;stripe&quot;&gt;
	&lt;g class=&quot;stripe__overlay&quot; id=&quot;js-stripe&quot;&gt;
	&lt;rect height=&quot;30&quot; width=&quot;10&quot; x=&quot;60&quot; y=&quot;100&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;20&quot; width=&quot;10&quot; x=&quot;70&quot; y=&quot;130&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;30&quot; width=&quot;10&quot; x=&quot;210&quot; y=&quot;100&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;20&quot; width=&quot;10&quot; x=&quot;220&quot; y=&quot;130&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;30&quot; width=&quot;10&quot; x=&quot;360&quot; y=&quot;100&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;20&quot; width=&quot;10&quot; x=&quot;370&quot; y=&quot;130&quot;&gt;&lt;/rect&gt;
	&lt;/g&gt;
&lt;/g&gt;
	
	
&lt;g id=&quot;sockshigh&quot;&gt;
	&lt;g class=&quot;sockshigh__overlay&quot; id=&quot;js-sockshigh&quot;&gt;
		&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;60&quot; y=&quot;150&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;100&quot; y=&quot;140&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;210&quot; y=&quot;150&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;250&quot; y=&quot;140&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;360&quot; y=&quot;150&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;400&quot; y=&quot;140&quot;&gt;&lt;/rect&gt;
	&lt;/g&gt;
&lt;/g&gt;
	
&lt;g id=&quot;shoes&quot;&gt;
	&lt;rect height=&quot;10&quot; width=&quot;30&quot; x=&quot;100&quot; y=&quot;160&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;30&quot; x=&quot;60&quot; y=&quot;170&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;30&quot; x=&quot;250&quot; y=&quot;160&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;30&quot; x=&quot;210&quot; y=&quot;170&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;30&quot; x=&quot;400&quot; y=&quot;160&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;30&quot; x=&quot;360&quot; y=&quot;170&quot;&gt;&lt;/rect&gt;
&lt;/g&gt;
	
&lt;g id=&quot;sockslow&quot;&gt;
	&lt;g class=&quot;sockslow__overlay&quot; id=&quot;js-sockslow&quot;&gt;
		&lt;rect class=&quot;st8&quot; height=&quot;10&quot; width=&quot;20&quot; x=&quot;60&quot; y=&quot;160&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;100&quot; y=&quot;150&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;210&quot; y=&quot;160&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;250&quot; y=&quot;150&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;360&quot; y=&quot;160&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;400&quot; y=&quot;150&quot;&gt;&lt;/rect&gt;
	&lt;/g&gt;
&lt;/g&gt;
	

&lt;g id=&quot;sleeve&quot;&gt;
	&lt;g class=&quot;sleeve__overlay&quot; id=&quot;js-sleeve&quot;&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;70&quot; y=&quot;70&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;220&quot; y=&quot;70&quot;&gt;&lt;/rect&gt;
	&lt;rect height=&quot;10&quot; width=&quot;20&quot; x=&quot;370&quot; y=&quot;70&quot;&gt;&lt;/rect&gt;
	&lt;/g&gt;
&lt;/g&gt;
	

&lt;/svg&gt;
	

&lt;div class=&quot;colors&quot;&gt;
	
  &lt;div class=&quot;colors__inputs&quot;&gt;
		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;HELMET&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateHelmet(this)&#39;}&quot; id=&quot;js-color-1&quot; value=&quot;FFFFFF&quot; /&gt;&lt;/div&gt;
		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;FACEMASK&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateFacemask(this)&#39;}&quot; id=&quot;js-color-2&quot; value=&quot;9E9E9E&quot; /&gt;&lt;/div&gt;
   		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;LOGO&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateLogo(this)&#39;}&quot; id=&quot;js-color-3&quot; value=&quot;FF9F3E&quot; /&gt;&lt;/div&gt;
		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;JERSEY&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateJersey(this)&#39;}&quot; id=&quot;js-color-4&quot; value=&quot;000000&quot; /&gt;&lt;/div&gt;
		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;SLEEVE&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateSleeve(this)&#39;}&quot; id=&quot;js-color-5&quot; value=&quot;53E227&quot; /&gt;&lt;/div&gt;
		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;PANTS&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updatePants(this)&#39;}&quot; id=&quot;js-color-6&quot; value=&quot;FFA70E&quot; /&gt;&lt;/div&gt;
    		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;STRIPE&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateStripe(this)&#39;}&quot; id=&quot;js-color-7&quot; value=&quot;FFFFFF&quot; /&gt;&lt;/div&gt;
		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;SOCKS HIGH&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateSockshigh(this)&#39;}&quot; id=&quot;js-color-8&quot; value=&quot;21AAC6&quot; /&gt;&lt;/div&gt;
		&lt;div class=&quot;attribute&quot;&gt;&lt;span class=&quot;label single&quot;&gt;SOCKS LOW&lt;/span&gt;&lt;input class=&quot;jscolor {onFineChange:&#39;updateSockslow(this)&#39;}&quot; id=&quot;js-color-9&quot; value=&quot;FFFFFF&quot; /&gt;&lt;/div&gt;


	 &lt;button class=&quot;gen-random&quot; onclick=&quot;generateRandom()&quot;&gt;RANDOMIZE&lt;/button&gt;
  &lt;/div&gt;
&lt;/div&gt;

&lt;br&gt;
&lt;br&gt;&amp;nbsp;
&lt;br&gt;&amp;nbsp;
&lt;p&gt;Retro Bowl is a fantastic football game that is developed by New Star Games and available on the following platforms:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;iOS: &lt;a href=&quot;https://apps.apple.com/us/app/retro-bowl/id1478902583&quot;&gt;https://apps.apple.com/us/app/retro-bowl/id1478902583&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;Android: &lt;a href=&quot;https://play.google.com/store/apps/details?id=com.newstargames.retrobowl&quot;&gt;https://play.google.com/store/apps/details?id=com.newstargames.retrobowl&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;Nintendo Switch: &lt;a href=&quot;https://www.nintendo.com/games/detail/retro-bowl-switch/&quot;&gt;https://www.nintendo.com/games/detail/retro-bowl-switch/&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;
The color picker functionality is built around code from Kyle Wetton: &lt;a href=&quot;https://codepen.io/kylewetton/pen/OJLmJoV&quot;&gt;https://codepen.io/kylewetton/pen/OJLmJoV&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;em&gt;Updated Jan 2026: Now includes editable facemask colors!&lt;/em&gt;
&lt;/p&gt;

  &lt;script&gt;/**
 * jscolor - JavaScript Color Picker
 *
 * @link    http://jscolor.com
 * @license For open source use: GPLv3
 *          For commercial use: JSColor Commercial License
 * @author  Jan Odvarko
 *
 * See usage examples at http://jscolor.com/examples/
 */


&quot;use strict&quot;;


if (!window.jscolor) { window.jscolor = (function () {


var jsc = {


	register : function () {
		jsc.attachDOMReadyEvent(jsc.init);
		jsc.attachEvent(document, &#39;mousedown&#39;, jsc.onDocumentMouseDown);
		jsc.attachEvent(document, &#39;touchstart&#39;, jsc.onDocumentTouchStart);
		jsc.attachEvent(window, &#39;resize&#39;, jsc.onWindowResize);
	},


	init : function () {
		if (jsc.jscolor.lookupClass) {
			jsc.jscolor.installByClassName(jsc.jscolor.lookupClass);
		}
	},


	tryInstallOnElements : function (elms, className) {
		var matchClass = new RegExp(&#39;(^|\\s)(&#39; + className + &#39;)(\\s*(\\{[^}]*\\})|\\s|$)&#39;, &#39;i&#39;);

		for (var i = 0; i &lt; elms.length; i += 1) {
			if (elms[i].type !== undefined &amp;&amp; elms[i].type.toLowerCase() == &#39;color&#39;) {
				if (jsc.isColorAttrSupported) {
					// skip inputs of type &#39;color&#39; if supported by the browser
					continue;
				}
			}
			var m;
			if (!elms[i].jscolor &amp;&amp; elms[i].className &amp;&amp; (m = elms[i].className.match(matchClass))) {
				var targetElm = elms[i];
				var optsStr = null;

				var dataOptions = jsc.getDataAttr(targetElm, &#39;jscolor&#39;);
				if (dataOptions !== null) {
					optsStr = dataOptions;
				} else if (m[4]) {
					optsStr = m[4];
				}

				var opts = {};
				if (optsStr) {
					try {
						opts = (new Function (&#39;return (&#39; + optsStr + &#39;)&#39;))();
					} catch(eParseError) {
						jsc.warn(&#39;Error parsing jscolor options: &#39; + eParseError + &#39;:\n&#39; + optsStr);
					}
				}
				targetElm.jscolor = new jsc.jscolor(targetElm, opts);
			}
		}
	},


	isColorAttrSupported : (function () {
		var elm = document.createElement(&#39;input&#39;);
		if (elm.setAttribute) {
			elm.setAttribute(&#39;type&#39;, &#39;color&#39;);
			if (elm.type.toLowerCase() == &#39;color&#39;) {
				return true;
			}
		}
		return false;
	})(),


	isCanvasSupported : (function () {
		var elm = document.createElement(&#39;canvas&#39;);
		return !!(elm.getContext &amp;&amp; elm.getContext(&#39;2d&#39;));
	})(),


	fetchElement : function (mixed) {
		return typeof mixed === &#39;string&#39; ? document.getElementById(mixed) : mixed;
	},


	isElementType : function (elm, type) {
		return elm.nodeName.toLowerCase() === type.toLowerCase();
	},


	getDataAttr : function (el, name) {
		var attrName = &#39;data-&#39; + name;
		var attrValue = el.getAttribute(attrName);
		if (attrValue !== null) {
			return attrValue;
		}
		return null;
	},


	attachEvent : function (el, evnt, func) {
		if (el.addEventListener) {
			el.addEventListener(evnt, func, false);
		} else if (el.attachEvent) {
			el.attachEvent(&#39;on&#39; + evnt, func);
		}
	},


	detachEvent : function (el, evnt, func) {
		if (el.removeEventListener) {
			el.removeEventListener(evnt, func, false);
		} else if (el.detachEvent) {
			el.detachEvent(&#39;on&#39; + evnt, func);
		}
	},


	_attachedGroupEvents : {},


	attachGroupEvent : function (groupName, el, evnt, func) {
		if (!jsc._attachedGroupEvents.hasOwnProperty(groupName)) {
			jsc._attachedGroupEvents[groupName] = [];
		}
		jsc._attachedGroupEvents[groupName].push([el, evnt, func]);
		jsc.attachEvent(el, evnt, func);
	},


	detachGroupEvents : function (groupName) {
		if (jsc._attachedGroupEvents.hasOwnProperty(groupName)) {
			for (var i = 0; i &lt; jsc._attachedGroupEvents[groupName].length; i += 1) {
				var evt = jsc._attachedGroupEvents[groupName][i];
				jsc.detachEvent(evt[0], evt[1], evt[2]);
			}
			delete jsc._attachedGroupEvents[groupName];
		}
	},


	attachDOMReadyEvent : function (func) {
		var fired = false;
		var fireOnce = function () {
			if (!fired) {
				fired = true;
				func();
			}
		};

		if (document.readyState === &#39;complete&#39;) {
			setTimeout(fireOnce, 1); // async
			return;
		}

		if (document.addEventListener) {
			document.addEventListener(&#39;DOMContentLoaded&#39;, fireOnce, false);

			// Fallback
			window.addEventListener(&#39;load&#39;, fireOnce, false);

		} else if (document.attachEvent) {
			// IE
			document.attachEvent(&#39;onreadystatechange&#39;, function () {
				if (document.readyState === &#39;complete&#39;) {
					document.detachEvent(&#39;onreadystatechange&#39;, arguments.callee);
					fireOnce();
				}
			})

			// Fallback
			window.attachEvent(&#39;onload&#39;, fireOnce);

			// IE7/8
			if (document.documentElement.doScroll &amp;&amp; window == window.top) {
				var tryScroll = function () {
					if (!document.body) { return; }
					try {
						document.documentElement.doScroll(&#39;left&#39;);
						fireOnce();
					} catch (e) {
						setTimeout(tryScroll, 1);
					}
				};
				tryScroll();
			}
		}
	},


	warn : function (msg) {
		if (window.console &amp;&amp; window.console.warn) {
			window.console.warn(msg);
		}
	},


	preventDefault : function (e) {
		if (e.preventDefault) { e.preventDefault(); }
		e.returnValue = false;
	},


	captureTarget : function (target) {
		// IE
		if (target.setCapture) {
			jsc._capturedTarget = target;
			jsc._capturedTarget.setCapture();
		}
	},


	releaseTarget : function () {
		// IE
		if (jsc._capturedTarget) {
			jsc._capturedTarget.releaseCapture();
			jsc._capturedTarget = null;
		}
	},


	fireEvent : function (el, evnt) {
		if (!el) {
			return;
		}
		if (document.createEvent) {
			var ev = document.createEvent(&#39;HTMLEvents&#39;);
			ev.initEvent(evnt, true, true);
			el.dispatchEvent(ev);
		} else if (document.createEventObject) {
			var ev = document.createEventObject();
			el.fireEvent(&#39;on&#39; + evnt, ev);
		} else if (el[&#39;on&#39; + evnt]) { // alternatively use the traditional event model
			el[&#39;on&#39; + evnt]();
		}
	},


	classNameToList : function (className) {
		return className.replace(/^\s+|\s+$/g, &#39;&#39;).split(/\s+/);
	},


	// The className parameter (str) can only contain a single class name
	hasClass : function (elm, className) {
		if (!className) {
			return false;
		}
		return -1 != (&#39; &#39; + elm.className.replace(/\s+/g, &#39; &#39;) + &#39; &#39;).indexOf(&#39; &#39; + className + &#39; &#39;);
	},


	// The className parameter (str) can contain multiple class names separated by whitespace
	setClass : function (elm, className) {
		var classList = jsc.classNameToList(className);
		for (var i = 0; i &lt; classList.length; i += 1) {
			if (!jsc.hasClass(elm, classList[i])) {
				elm.className += (elm.className ? &#39; &#39; : &#39;&#39;) + classList[i];
			}
		}
	},


	// The className parameter (str) can contain multiple class names separated by whitespace
	unsetClass : function (elm, className) {
		var classList = jsc.classNameToList(className);
		for (var i = 0; i &lt; classList.length; i += 1) {
			var repl = new RegExp(
				&#39;^\\s*&#39; + classList[i] + &#39;\\s*|&#39; +
				&#39;\\s*&#39; + classList[i] + &#39;\\s*$|&#39; +
				&#39;\\s+&#39; + classList[i] + &#39;(\\s+)&#39;,
				&#39;g&#39;
			);
			elm.className = elm.className.replace(repl, &#39;$1&#39;);
		}
	},


	getStyle : function (elm) {
		return window.getComputedStyle ? window.getComputedStyle(elm) : elm.currentStyle;
	},


	setStyle : (function () {
		var helper = document.createElement(&#39;div&#39;);
		var getSupportedProp = function (names) {
			for (var i = 0; i &lt; names.length; i += 1) {
				if (names[i] in helper.style) {
					return names[i];
				}
			}
		};
		var props = {
			borderRadius: getSupportedProp([&#39;borderRadius&#39;, &#39;MozBorderRadius&#39;, &#39;webkitBorderRadius&#39;]),
			boxShadow: getSupportedProp([&#39;boxShadow&#39;, &#39;MozBoxShadow&#39;, &#39;webkitBoxShadow&#39;])
		};
		return function (elm, prop, value) {
			switch (prop.toLowerCase()) {
			case &#39;opacity&#39;:
				var alphaOpacity = Math.round(parseFloat(value) * 100);
				elm.style.opacity = value;
				elm.style.filter = &#39;alpha(opacity=&#39; + alphaOpacity + &#39;)&#39;;
				break;
			default:
				elm.style[props[prop]] = value;
				break;
			}
		};
	})(),


	setBorderRadius : function (elm, value) {
		jsc.setStyle(elm, &#39;borderRadius&#39;, value || &#39;0&#39;);
	},


	setBoxShadow : function (elm, value) {
		jsc.setStyle(elm, &#39;boxShadow&#39;, value || &#39;none&#39;);
	},


	getElementPos : function (e, relativeToViewport) {
		var x=0, y=0;
		var rect = e.getBoundingClientRect();
		x = rect.left;
		y = rect.top;
		if (!relativeToViewport) {
			var viewPos = jsc.getViewPos();
			x += viewPos[0];
			y += viewPos[1];
		}
		return [x, y];
	},


	getElementSize : function (e) {
		return [e.offsetWidth, e.offsetHeight];
	},


	// get pointer&#39;s X/Y coordinates relative to viewport
	getAbsPointerPos : function (e) {
		if (!e) { e = window.event; }
		var x = 0, y = 0;
		if (typeof e.changedTouches !== &#39;undefined&#39; &amp;&amp; e.changedTouches.length) {
			// touch devices
			x = e.changedTouches[0].clientX;
			y = e.changedTouches[0].clientY;
		} else if (typeof e.clientX === &#39;number&#39;) {
			x = e.clientX;
			y = e.clientY;
		}
		return { x: x, y: y };
	},


	// get pointer&#39;s X/Y coordinates relative to target element
	getRelPointerPos : function (e) {
		if (!e) { e = window.event; }
		var target = e.target || e.srcElement;
		var targetRect = target.getBoundingClientRect();

		var x = 0, y = 0;

		var clientX = 0, clientY = 0;
		if (typeof e.changedTouches !== &#39;undefined&#39; &amp;&amp; e.changedTouches.length) {
			// touch devices
			clientX = e.changedTouches[0].clientX;
			clientY = e.changedTouches[0].clientY;
		} else if (typeof e.clientX === &#39;number&#39;) {
			clientX = e.clientX;
			clientY = e.clientY;
		}

		x = clientX - targetRect.left;
		y = clientY - targetRect.top;
		return { x: x, y: y };
	},


	getViewPos : function () {
		var doc = document.documentElement;
		return [
			(window.pageXOffset || doc.scrollLeft) - (doc.clientLeft || 0),
			(window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0)
		];
	},


	getViewSize : function () {
		var doc = document.documentElement;
		return [
			(window.innerWidth || doc.clientWidth),
			(window.innerHeight || doc.clientHeight),
		];
	},


	redrawPosition : function () {

		if (jsc.picker &amp;&amp; jsc.picker.owner) {
			var thisObj = jsc.picker.owner;

			var tp, vp;

			if (thisObj.fixed) {
				// Fixed elements are positioned relative to viewport,
				// therefore we can ignore the scroll offset
				tp = jsc.getElementPos(thisObj.targetElement, true); // target pos
				vp = [0, 0]; // view pos
			} else {
				tp = jsc.getElementPos(thisObj.targetElement); // target pos
				vp = jsc.getViewPos(); // view pos
			}

			var ts = jsc.getElementSize(thisObj.targetElement); // target size
			var vs = jsc.getViewSize(); // view size
			var ps = jsc.getPickerOuterDims(thisObj); // picker size
			var a, b, c;
			switch (thisObj.position.toLowerCase()) {
				case &#39;left&#39;: a=1; b=0; c=-1; break;
				case &#39;right&#39;:a=1; b=0; c=1; break;
				case &#39;top&#39;:  a=0; b=1; c=-1; break;
				default:     a=0; b=1; c=1; break;
			}
			var l = (ts[b]+ps[b])/2;

			// compute picker position
			if (!thisObj.smartPosition) {
				var pp = [
					tp[a],
					tp[b]+ts[b]-l+l*c
				];
			} else {
				var pp = [
					-vp[a]+tp[a]+ps[a] &gt; vs[a] ?
						(-vp[a]+tp[a]+ts[a]/2 &gt; vs[a]/2 &amp;&amp; tp[a]+ts[a]-ps[a] &gt;= 0 ? tp[a]+ts[a]-ps[a] : tp[a]) :
						tp[a],
					-vp[b]+tp[b]+ts[b]+ps[b]-l+l*c &gt; vs[b] ?
						(-vp[b]+tp[b]+ts[b]/2 &gt; vs[b]/2 &amp;&amp; tp[b]+ts[b]-l-l*c &gt;= 0 ? tp[b]+ts[b]-l-l*c : tp[b]+ts[b]-l+l*c) :
						(tp[b]+ts[b]-l+l*c &gt;= 0 ? tp[b]+ts[b]-l+l*c : tp[b]+ts[b]-l-l*c)
				];
			}

			var x = pp[a];
			var y = pp[b];
			var positionValue = thisObj.fixed ? &#39;fixed&#39; : &#39;absolute&#39;;
			var contractShadow =
				(pp[0] + ps[0] &gt; tp[0] || pp[0] &lt; tp[0] + ts[0]) &amp;&amp;
				(pp[1] + ps[1] &lt; tp[1] + ts[1]);

			jsc._drawPosition(thisObj, x, y, positionValue, contractShadow);
		}
	},


	_drawPosition : function (thisObj, x, y, positionValue, contractShadow) {
		var vShadow = contractShadow ? 0 : thisObj.shadowBlur; // px

		jsc.picker.wrap.style.position = positionValue;
		jsc.picker.wrap.style.left = x + &#39;px&#39;;
		jsc.picker.wrap.style.top = y + &#39;px&#39;;

		jsc.setBoxShadow(
			jsc.picker.boxS,
			thisObj.shadow ?
				new jsc.BoxShadow(0, vShadow, thisObj.shadowBlur, 0, thisObj.shadowColor) :
				null);
	},


	getPickerDims : function (thisObj) {
		var displaySlider = !!jsc.getSliderComponent(thisObj);
		var dims = [
			2 * thisObj.insetWidth + 2 * thisObj.padding + thisObj.width +
				(displaySlider ? 2 * thisObj.insetWidth + jsc.getPadToSliderPadding(thisObj) + thisObj.sliderSize : 0),
			2 * thisObj.insetWidth + 2 * thisObj.padding + thisObj.height +
				(thisObj.closable ? 2 * thisObj.insetWidth + thisObj.padding + thisObj.buttonHeight : 0)
		];
		return dims;
	},


	getPickerOuterDims : function (thisObj) {
		var dims = jsc.getPickerDims(thisObj);
		return [
			dims[0] + 2 * thisObj.borderWidth,
			dims[1] + 2 * thisObj.borderWidth
		];
	},


	getPadToSliderPadding : function (thisObj) {
		return Math.max(thisObj.padding, 1.5 * (2 * thisObj.pointerBorderWidth + thisObj.pointerThickness));
	},


	getPadYComponent : function (thisObj) {
		switch (thisObj.mode.charAt(1).toLowerCase()) {
			case &#39;v&#39;: return &#39;v&#39;; break;
		}
		return &#39;s&#39;;
	},


	getSliderComponent : function (thisObj) {
		if (thisObj.mode.length &gt; 2) {
			switch (thisObj.mode.charAt(2).toLowerCase()) {
				case &#39;s&#39;: return &#39;s&#39;; break;
				case &#39;v&#39;: return &#39;v&#39;; break;
			}
		}
		return null;
	},


	onDocumentMouseDown : function (e) {
		if (!e) { e = window.event; }
		var target = e.target || e.srcElement;

		if (target._jscLinkedInstance) {
			if (target._jscLinkedInstance.showOnClick) {
				target._jscLinkedInstance.show();
			}
		} else if (target._jscControlName) {
			jsc.onControlPointerStart(e, target, target._jscControlName, &#39;mouse&#39;);
		} else {
			// Mouse is outside the picker controls -&gt; hide the color picker!
			if (jsc.picker &amp;&amp; jsc.picker.owner) {
				jsc.picker.owner.hide();
			}
		}
	},


	onDocumentTouchStart : function (e) {
		if (!e) { e = window.event; }
		var target = e.target || e.srcElement;

		if (target._jscLinkedInstance) {
			if (target._jscLinkedInstance.showOnClick) {
				target._jscLinkedInstance.show();
			}
		} else if (target._jscControlName) {
			jsc.onControlPointerStart(e, target, target._jscControlName, &#39;touch&#39;);
		} else {
			if (jsc.picker &amp;&amp; jsc.picker.owner) {
				jsc.picker.owner.hide();
			}
		}
	},


	onWindowResize : function (e) {
		jsc.redrawPosition();
	},


	onParentScroll : function (e) {
		// hide the picker when one of the parent elements is scrolled
		if (jsc.picker &amp;&amp; jsc.picker.owner) {
			jsc.picker.owner.hide();
		}
	},


	_pointerMoveEvent : {
		mouse: &#39;mousemove&#39;,
		touch: &#39;touchmove&#39;
	},
	_pointerEndEvent : {
		mouse: &#39;mouseup&#39;,
		touch: &#39;touchend&#39;
	},


	_pointerOrigin : null,
	_capturedTarget : null,


	onControlPointerStart : function (e, target, controlName, pointerType) {
		var thisObj = target._jscInstance;

		jsc.preventDefault(e);
		jsc.captureTarget(target);

		var registerDragEvents = function (doc, offset) {
			jsc.attachGroupEvent(&#39;drag&#39;, doc, jsc._pointerMoveEvent[pointerType],
				jsc.onDocumentPointerMove(e, target, controlName, pointerType, offset));
			jsc.attachGroupEvent(&#39;drag&#39;, doc, jsc._pointerEndEvent[pointerType],
				jsc.onDocumentPointerEnd(e, target, controlName, pointerType));
		};

		registerDragEvents(document, [0, 0]);

		if (window.parent &amp;&amp; window.frameElement) {
			var rect = window.frameElement.getBoundingClientRect();
			var ofs = [-rect.left, -rect.top];
			registerDragEvents(window.parent.window.document, ofs);
		}

		var abs = jsc.getAbsPointerPos(e);
		var rel = jsc.getRelPointerPos(e);
		jsc._pointerOrigin = {
			x: abs.x - rel.x,
			y: abs.y - rel.y
		};

		switch (controlName) {
		case &#39;pad&#39;:
			// if the slider is at the bottom, move it up
			switch (jsc.getSliderComponent(thisObj)) {
			case &#39;s&#39;: if (thisObj.hsv[1] === 0) { thisObj.fromHSV(null, 100, null); }; break;
			case &#39;v&#39;: if (thisObj.hsv[2] === 0) { thisObj.fromHSV(null, null, 100); }; break;
			}
			jsc.setPad(thisObj, e, 0, 0);
			break;

		case &#39;sld&#39;:
			jsc.setSld(thisObj, e, 0);
			break;
		}

		jsc.dispatchFineChange(thisObj);
	},


	onDocumentPointerMove : function (e, target, controlName, pointerType, offset) {
		return function (e) {
			var thisObj = target._jscInstance;
			switch (controlName) {
			case &#39;pad&#39;:
				if (!e) { e = window.event; }
				jsc.setPad(thisObj, e, offset[0], offset[1]);
				jsc.dispatchFineChange(thisObj);
				break;

			case &#39;sld&#39;:
				if (!e) { e = window.event; }
				jsc.setSld(thisObj, e, offset[1]);
				jsc.dispatchFineChange(thisObj);
				break;
			}
		}
	},


	onDocumentPointerEnd : function (e, target, controlName, pointerType) {
		return function (e) {
			var thisObj = target._jscInstance;
			jsc.detachGroupEvents(&#39;drag&#39;);
			jsc.releaseTarget();
			// Always dispatch changes after detaching outstanding mouse handlers,
			// in case some user interaction will occur in user&#39;s onchange callback
			// that would intrude with current mouse events
			jsc.dispatchChange(thisObj);
		};
	},


	dispatchChange : function (thisObj) {
		if (thisObj.valueElement) {
			if (jsc.isElementType(thisObj.valueElement, &#39;input&#39;)) {
				jsc.fireEvent(thisObj.valueElement, &#39;change&#39;);
			}
		}
	},


	dispatchFineChange : function (thisObj) {
		if (thisObj.onFineChange) {
			var callback;
			if (typeof thisObj.onFineChange === &#39;string&#39;) {
				callback = new Function (thisObj.onFineChange);
			} else {
				callback = thisObj.onFineChange;
			}
			callback.call(thisObj);
		}
	},


	setPad : function (thisObj, e, ofsX, ofsY) {
		var pointerAbs = jsc.getAbsPointerPos(e);
		var x = ofsX + pointerAbs.x - jsc._pointerOrigin.x - thisObj.padding - thisObj.insetWidth;
		var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.insetWidth;

		var xVal = x * (360 / (thisObj.width - 1));
		var yVal = 100 - (y * (100 / (thisObj.height - 1)));

		switch (jsc.getPadYComponent(thisObj)) {
		case &#39;s&#39;: thisObj.fromHSV(xVal, yVal, null, jsc.leaveSld); break;
		case &#39;v&#39;: thisObj.fromHSV(xVal, null, yVal, jsc.leaveSld); break;
		}
	},


	setSld : function (thisObj, e, ofsY) {
		var pointerAbs = jsc.getAbsPointerPos(e);
		var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.insetWidth;

		var yVal = 100 - (y * (100 / (thisObj.height - 1)));

		switch (jsc.getSliderComponent(thisObj)) {
		case &#39;s&#39;: thisObj.fromHSV(null, yVal, null, jsc.leavePad); break;
		case &#39;v&#39;: thisObj.fromHSV(null, null, yVal, jsc.leavePad); break;
		}
	},


	_vmlNS : &#39;jsc_vml_&#39;,
	_vmlCSS : &#39;jsc_vml_css_&#39;,
	_vmlReady : false,


	initVML : function () {
		if (!jsc._vmlReady) {
			// init VML namespace
			var doc = document;
			if (!doc.namespaces[jsc._vmlNS]) {
				doc.namespaces.add(jsc._vmlNS, &#39;urn:schemas-microsoft-com:vml&#39;);
			}
			if (!doc.styleSheets[jsc._vmlCSS]) {
				var tags = [&#39;shape&#39;, &#39;shapetype&#39;, &#39;group&#39;, &#39;background&#39;, &#39;path&#39;, &#39;formulas&#39;, &#39;handles&#39;, &#39;fill&#39;, &#39;stroke&#39;, &#39;shadow&#39;, &#39;textbox&#39;, &#39;textpath&#39;, &#39;imagedata&#39;, &#39;line&#39;, &#39;polyline&#39;, &#39;curve&#39;, &#39;rect&#39;, &#39;roundrect&#39;, &#39;oval&#39;, &#39;arc&#39;, &#39;image&#39;];
				var ss = doc.createStyleSheet();
				ss.owningElement.id = jsc._vmlCSS;
				for (var i = 0; i &lt; tags.length; i += 1) {
					ss.addRule(jsc._vmlNS + &#39;\\:&#39; + tags[i], &#39;behavior:url(#default#VML);&#39;);
				}
			}
			jsc._vmlReady = true;
		}
	},


	createPalette : function () {

		var paletteObj = {
			elm: null,
			draw: null
		};

		if (jsc.isCanvasSupported) {
			// Canvas implementation for modern browsers

			var canvas = document.createElement(&#39;canvas&#39;);
			var ctx = canvas.getContext(&#39;2d&#39;);

			var drawFunc = function (width, height, type) {
				canvas.width = width;
				canvas.height = height;

				ctx.clearRect(0, 0, canvas.width, canvas.height);

				var hGrad = ctx.createLinearGradient(0, 0, canvas.width, 0);
				hGrad.addColorStop(0 / 6, &#39;#F00&#39;);
				hGrad.addColorStop(1 / 6, &#39;#FF0&#39;);
				hGrad.addColorStop(2 / 6, &#39;#0F0&#39;);
				hGrad.addColorStop(3 / 6, &#39;#0FF&#39;);
				hGrad.addColorStop(4 / 6, &#39;#00F&#39;);
				hGrad.addColorStop(5 / 6, &#39;#F0F&#39;);
				hGrad.addColorStop(6 / 6, &#39;#F00&#39;);

				ctx.fillStyle = hGrad;
				ctx.fillRect(0, 0, canvas.width, canvas.height);

				var vGrad = ctx.createLinearGradient(0, 0, 0, canvas.height);
				switch (type.toLowerCase()) {
				case &#39;s&#39;:
					vGrad.addColorStop(0, &#39;rgba(255,255,255,0)&#39;);
					vGrad.addColorStop(1, &#39;rgba(255,255,255,1)&#39;);
					break;
				case &#39;v&#39;:
					vGrad.addColorStop(0, &#39;rgba(0,0,0,0)&#39;);
					vGrad.addColorStop(1, &#39;rgba(0,0,0,1)&#39;);
					break;
				}
				ctx.fillStyle = vGrad;
				ctx.fillRect(0, 0, canvas.width, canvas.height);
			};

			paletteObj.elm = canvas;
			paletteObj.draw = drawFunc;

		} else {
			// VML fallback for IE 7 and 8

			jsc.initVML();

			var vmlContainer = document.createElement(&#39;div&#39;);
			vmlContainer.style.position = &#39;relative&#39;;
			vmlContainer.style.overflow = &#39;hidden&#39;;

			var hGrad = document.createElement(jsc._vmlNS + &#39;:fill&#39;);
			hGrad.type = &#39;gradient&#39;;
			hGrad.method = &#39;linear&#39;;
			hGrad.angle = &#39;90&#39;;
			hGrad.colors = &#39;16.67% #F0F, 33.33% #00F, 50% #0FF, 66.67% #0F0, 83.33% #FF0&#39;

			var hRect = document.createElement(jsc._vmlNS + &#39;:rect&#39;);
			hRect.style.position = &#39;absolute&#39;;
			hRect.style.left = -1 + &#39;px&#39;;
			hRect.style.top = -1 + &#39;px&#39;;
			hRect.stroked = false;
			hRect.appendChild(hGrad);
			vmlContainer.appendChild(hRect);

			var vGrad = document.createElement(jsc._vmlNS + &#39;:fill&#39;);
			vGrad.type = &#39;gradient&#39;;
			vGrad.method = &#39;linear&#39;;
			vGrad.angle = &#39;180&#39;;
			vGrad.opacity = &#39;0&#39;;

			var vRect = document.createElement(jsc._vmlNS + &#39;:rect&#39;);
			vRect.style.position = &#39;absolute&#39;;
			vRect.style.left = -1 + &#39;px&#39;;
			vRect.style.top = -1 + &#39;px&#39;;
			vRect.stroked = false;
			vRect.appendChild(vGrad);
			vmlContainer.appendChild(vRect);

			var drawFunc = function (width, height, type) {
				vmlContainer.style.width = width + &#39;px&#39;;
				vmlContainer.style.height = height + &#39;px&#39;;

				hRect.style.width =
				vRect.style.width =
					(width + 1) + &#39;px&#39;;
				hRect.style.height =
				vRect.style.height =
					(height + 1) + &#39;px&#39;;

				// Colors must be specified during every redraw, otherwise IE won&#39;t display
				// a full gradient during a subsequential redraw
				hGrad.color = &#39;#F00&#39;;
				hGrad.color2 = &#39;#F00&#39;;

				switch (type.toLowerCase()) {
				case &#39;s&#39;:
					vGrad.color = vGrad.color2 = &#39;#FFF&#39;;
					break;
				case &#39;v&#39;:
					vGrad.color = vGrad.color2 = &#39;#000&#39;;
					break;
				}
			};
			
			paletteObj.elm = vmlContainer;
			paletteObj.draw = drawFunc;
		}

		return paletteObj;
	},


	createSliderGradient : function () {

		var sliderObj = {
			elm: null,
			draw: null
		};

		if (jsc.isCanvasSupported) {
			// Canvas implementation for modern browsers

			var canvas = document.createElement(&#39;canvas&#39;);
			var ctx = canvas.getContext(&#39;2d&#39;);

			var drawFunc = function (width, height, color1, color2) {
				canvas.width = width;
				canvas.height = height;

				ctx.clearRect(0, 0, canvas.width, canvas.height);

				var grad = ctx.createLinearGradient(0, 0, 0, canvas.height);
				grad.addColorStop(0, color1);
				grad.addColorStop(1, color2);

				ctx.fillStyle = grad;
				ctx.fillRect(0, 0, canvas.width, canvas.height);
			};

			sliderObj.elm = canvas;
			sliderObj.draw = drawFunc;

		} else {
			// VML fallback for IE 7 and 8

			jsc.initVML();

			var vmlContainer = document.createElement(&#39;div&#39;);
			vmlContainer.style.position = &#39;relative&#39;;
			vmlContainer.style.overflow = &#39;hidden&#39;;

			var grad = document.createElement(jsc._vmlNS + &#39;:fill&#39;);
			grad.type = &#39;gradient&#39;;
			grad.method = &#39;linear&#39;;
			grad.angle = &#39;180&#39;;

			var rect = document.createElement(jsc._vmlNS + &#39;:rect&#39;);
			rect.style.position = &#39;absolute&#39;;
			rect.style.left = -1 + &#39;px&#39;;
			rect.style.top = -1 + &#39;px&#39;;
			rect.stroked = false;
			rect.appendChild(grad);
			vmlContainer.appendChild(rect);

			var drawFunc = function (width, height, color1, color2) {
				vmlContainer.style.width = width + &#39;px&#39;;
				vmlContainer.style.height = height + &#39;px&#39;;

				rect.style.width = (width + 1) + &#39;px&#39;;
				rect.style.height = (height + 1) + &#39;px&#39;;

				grad.color = color1;
				grad.color2 = color2;
			};
			
			sliderObj.elm = vmlContainer;
			sliderObj.draw = drawFunc;
		}

		return sliderObj;
	},


	leaveValue : 1&lt;&lt;0,
	leaveStyle : 1&lt;&lt;1,
	leavePad : 1&lt;&lt;2,
	leaveSld : 1&lt;&lt;3,


	BoxShadow : (function () {
		var BoxShadow = function (hShadow, vShadow, blur, spread, color, inset) {
			this.hShadow = hShadow;
			this.vShadow = vShadow;
			this.blur = blur;
			this.spread = spread;
			this.color = color;
			this.inset = !!inset;
		};

		BoxShadow.prototype.toString = function () {
			var vals = [
				Math.round(this.hShadow) + &#39;px&#39;,
				Math.round(this.vShadow) + &#39;px&#39;,
				Math.round(this.blur) + &#39;px&#39;,
				Math.round(this.spread) + &#39;px&#39;,
				this.color
			];
			if (this.inset) {
				vals.push(&#39;inset&#39;);
			}
			return vals.join(&#39; &#39;);
		};

		return BoxShadow;
	})(),


	//
	// Usage:
	// var myColor = new jscolor(&lt;targetElement&gt; [, &lt;options&gt;])
	//

	jscolor : function (targetElement, options) {

		// General options
		//
		this.value = null; // initial HEX color. To change it later, use methods fromString(), fromHSV() and fromRGB()
		this.valueElement = targetElement; // element that will be used to display and input the color code
		this.styleElement = targetElement; // element that will preview the picked color using CSS backgroundColor
		this.required = true; // whether the associated text &lt;input&gt; can be left empty
		this.refine = true; // whether to refine the entered color code (e.g. uppercase it and remove whitespace)
		this.hash = false; // whether to prefix the HEX color code with # symbol
		this.uppercase = true; // whether to uppercase the color code
		this.onFineChange = null; // called instantly every time the color changes (value can be either a function or a string with javascript code)
		this.activeClass = &#39;jscolor-active&#39;; // class to be set to the target element when a picker window is open on it
		this.minS = 0; // min allowed saturation (0 - 100)
		this.maxS = 100; // max allowed saturation (0 - 100)
		this.minV = 0; // min allowed value (brightness) (0 - 100)
		this.maxV = 100; // max allowed value (brightness) (0 - 100)

		// Accessing the picked color
		//
		this.hsv = [0, 0, 100]; // read-only  [0-360, 0-100, 0-100]
		this.rgb = [255, 255, 255]; // read-only  [0-255, 0-255, 0-255]

		// Color Picker options
		//
		this.width = 181; // width of color palette (in px)
		this.height = 101; // height of color palette (in px)
		this.showOnClick = true; // whether to display the color picker when user clicks on its target element
		this.mode = &#39;HSV&#39;; // HSV | HVS | HS | HV - layout of the color picker controls
		this.position = &#39;bottom&#39;; // left | right | top | bottom - position relative to the target element
		this.smartPosition = true; // automatically change picker position when there is not enough space for it
		this.sliderSize = 16; // px
		this.crossSize = 8; // px
		this.closable = false; // whether to display the Close button
		this.closeText = &#39;Close&#39;;
		this.buttonColor = &#39;#000000&#39;; // CSS color
		this.buttonHeight = 18; // px
		this.padding = 12; // px
		this.backgroundColor = &#39;#FFFFFF&#39;; // CSS color
		this.borderWidth = 1; // px
		this.borderColor = &#39;#BBBBBB&#39;; // CSS color
		this.borderRadius = 8; // px
		this.insetWidth = 1; // px
		this.insetColor = &#39;#BBBBBB&#39;; // CSS color
		this.shadow = true; // whether to display shadow
		this.shadowBlur = 15; // px
		this.shadowColor = &#39;rgba(0,0,0,0.2)&#39;; // CSS color
		this.pointerColor = &#39;#4C4C4C&#39;; // px
		this.pointerBorderColor = &#39;#FFFFFF&#39;; // px
        this.pointerBorderWidth = 1; // px
        this.pointerThickness = 2; // px
		this.zIndex = 1000;
		this.container = null; // where to append the color picker (BODY element by default)


		for (var opt in options) {
			if (options.hasOwnProperty(opt)) {
				this[opt] = options[opt];
			}
		}


		this.hide = function () {
			if (isPickerOwner()) {
				detachPicker();
			}
		};


		this.show = function () {
			drawPicker();
		};


		this.redraw = function () {
			if (isPickerOwner()) {
				drawPicker();
			}
		};


		this.importColor = function () {
			if (!this.valueElement) {
				this.exportColor();
			} else {
				if (jsc.isElementType(this.valueElement, &#39;input&#39;)) {
					if (!this.refine) {
						if (!this.fromString(this.valueElement.value, jsc.leaveValue)) {
							if (this.styleElement) {
								this.styleElement.style.backgroundImage = this.styleElement._jscOrigStyle.backgroundImage;
								this.styleElement.style.backgroundColor = this.styleElement._jscOrigStyle.backgroundColor;
								this.styleElement.style.color = this.styleElement._jscOrigStyle.color;
							}
							this.exportColor(jsc.leaveValue | jsc.leaveStyle);
						}
					} else if (!this.required &amp;&amp; /^\s*$/.test(this.valueElement.value)) {
						this.valueElement.value = &#39;&#39;;
						if (this.styleElement) {
							this.styleElement.style.backgroundImage = this.styleElement._jscOrigStyle.backgroundImage;
							this.styleElement.style.backgroundColor = this.styleElement._jscOrigStyle.backgroundColor;
							this.styleElement.style.color = this.styleElement._jscOrigStyle.color;
						}
						this.exportColor(jsc.leaveValue | jsc.leaveStyle);

					} else if (this.fromString(this.valueElement.value)) {
						// managed to import color successfully from the value -&gt; OK, don&#39;t do anything
					} else {
						this.exportColor();
					}
				} else {
					// not an input element -&gt; doesn&#39;t have any value
					this.exportColor();
				}
			}
		};


		this.exportColor = function (flags) {
			if (!(flags &amp; jsc.leaveValue) &amp;&amp; this.valueElement) {
				var value = this.toString();
				if (this.uppercase) { value = value.toUpperCase(); }
				if (this.hash) { value = &#39;#&#39; + value; }

				if (jsc.isElementType(this.valueElement, &#39;input&#39;)) {
					this.valueElement.value = value;
				} else {
					this.valueElement.innerHTML = value;
				}
			}
			if (!(flags &amp; jsc.leaveStyle)) {
				if (this.styleElement) {
					this.styleElement.style.backgroundImage = &#39;none&#39;;
					this.styleElement.style.backgroundColor = &#39;#&#39; + this.toString();
					this.styleElement.style.color = this.isLight() ? &#39;#000&#39; : &#39;#FFF&#39;;
				}
			}
			if (!(flags &amp; jsc.leavePad) &amp;&amp; isPickerOwner()) {
				redrawPad();
			}
			if (!(flags &amp; jsc.leaveSld) &amp;&amp; isPickerOwner()) {
				redrawSld();
			}
		};


		// h: 0-360
		// s: 0-100
		// v: 0-100
		//
		this.fromHSV = function (h, s, v, flags) { // null = don&#39;t change
			if (h !== null) {
				if (isNaN(h)) { return false; }
				h = Math.max(0, Math.min(360, h));
			}
			if (s !== null) {
				if (isNaN(s)) { return false; }
				s = Math.max(0, Math.min(100, this.maxS, s), this.minS);
			}
			if (v !== null) {
				if (isNaN(v)) { return false; }
				v = Math.max(0, Math.min(100, this.maxV, v), this.minV);
			}

			this.rgb = HSV_RGB(
				h===null ? this.hsv[0] : (this.hsv[0]=h),
				s===null ? this.hsv[1] : (this.hsv[1]=s),
				v===null ? this.hsv[2] : (this.hsv[2]=v)
			);

			this.exportColor(flags);
		};


		// r: 0-255
		// g: 0-255
		// b: 0-255
		//
		this.fromRGB = function (r, g, b, flags) { // null = don&#39;t change
			if (r !== null) {
				if (isNaN(r)) { return false; }
				r = Math.max(0, Math.min(255, r));
			}
			if (g !== null) {
				if (isNaN(g)) { return false; }
				g = Math.max(0, Math.min(255, g));
			}
			if (b !== null) {
				if (isNaN(b)) { return false; }
				b = Math.max(0, Math.min(255, b));
			}

			var hsv = RGB_HSV(
				r===null ? this.rgb[0] : r,
				g===null ? this.rgb[1] : g,
				b===null ? this.rgb[2] : b
			);
			if (hsv[0] !== null) {
				this.hsv[0] = Math.max(0, Math.min(360, hsv[0]));
			}
			if (hsv[2] !== 0) {
				this.hsv[1] = hsv[1]===null ? null : Math.max(0, this.minS, Math.min(100, this.maxS, hsv[1]));
			}
			this.hsv[2] = hsv[2]===null ? null : Math.max(0, this.minV, Math.min(100, this.maxV, hsv[2]));

			// update RGB according to final HSV, as some values might be trimmed
			var rgb = HSV_RGB(this.hsv[0], this.hsv[1], this.hsv[2]);
			this.rgb[0] = rgb[0];
			this.rgb[1] = rgb[1];
			this.rgb[2] = rgb[2];

			this.exportColor(flags);
		};


		this.fromString = function (str, flags) {
			var m;
			if (m = str.match(/^\W*([0-9A-F]{3}([0-9A-F]{3})?)\W*$/i)) {
				// HEX notation
				//

				if (m[1].length === 6) {
					// 6-char notation
					this.fromRGB(
						parseInt(m[1].substr(0,2),16),
						parseInt(m[1].substr(2,2),16),
						parseInt(m[1].substr(4,2),16),
						flags
					);
				} else {
					// 3-char notation
					this.fromRGB(
						parseInt(m[1].charAt(0) + m[1].charAt(0),16),
						parseInt(m[1].charAt(1) + m[1].charAt(1),16),
						parseInt(m[1].charAt(2) + m[1].charAt(2),16),
						flags
					);
				}
				return true;

			} else if (m = str.match(/^\W*rgba?\(([^)]*)\)\W*$/i)) {
				var params = m[1].split(&#39;,&#39;);
				var re = /^\s*(\d*)(\.\d+)?\s*$/;
				var mR, mG, mB;
				if (
					params.length &gt;= 3 &amp;&amp;
					(mR = params[0].match(re)) &amp;&amp;
					(mG = params[1].match(re)) &amp;&amp;
					(mB = params[2].match(re))
				) {
					var r = parseFloat((mR[1] || &#39;0&#39;) + (mR[2] || &#39;&#39;));
					var g = parseFloat((mG[1] || &#39;0&#39;) + (mG[2] || &#39;&#39;));
					var b = parseFloat((mB[1] || &#39;0&#39;) + (mB[2] || &#39;&#39;));
					this.fromRGB(r, g, b, flags);
					return true;
				}
			}
			return false;
		};


		this.toString = function () {
			return (
				(0x100 | Math.round(this.rgb[0])).toString(16).substr(1) +
				(0x100 | Math.round(this.rgb[1])).toString(16).substr(1) +
				(0x100 | Math.round(this.rgb[2])).toString(16).substr(1)
			);
		};


		this.toHEXString = function () {
			return &#39;#&#39; + this.toString().toUpperCase();
		};


		this.toRGBString = function () {
			return (&#39;rgb(&#39; +
				Math.round(this.rgb[0]) + &#39;,&#39; +
				Math.round(this.rgb[1]) + &#39;,&#39; +
				Math.round(this.rgb[2]) + &#39;)&#39;
			);
		};


		this.isLight = function () {
			return (
				0.213 * this.rgb[0] +
				0.715 * this.rgb[1] +
				0.072 * this.rgb[2] &gt;
				255 / 2
			);
		};


		this._processParentElementsInDOM = function () {
			if (this._linkedElementsProcessed) { return; }
			this._linkedElementsProcessed = true;

			var elm = this.targetElement;
			do {
				// If the target element or one of its parent nodes has fixed position,
				// then use fixed positioning instead
				//
				// Note: In Firefox, getComputedStyle returns null in a hidden iframe,
				// that&#39;s why we need to check if the returned style object is non-empty
				var currStyle = jsc.getStyle(elm);
				if (currStyle &amp;&amp; currStyle.position.toLowerCase() === &#39;fixed&#39;) {
					this.fixed = true;
				}

				if (elm !== this.targetElement) {
					// Ensure to attach onParentScroll only once to each parent element
					// (multiple targetElements can share the same parent nodes)
					//
					// Note: It&#39;s not just offsetParents that can be scrollable,
					// that&#39;s why we loop through all parent nodes
					if (!elm._jscEventsAttached) {
						jsc.attachEvent(elm, &#39;scroll&#39;, jsc.onParentScroll);
						elm._jscEventsAttached = true;
					}
				}
			} while ((elm = elm.parentNode) &amp;&amp; !jsc.isElementType(elm, &#39;body&#39;));
		};


		// r: 0-255
		// g: 0-255
		// b: 0-255
		//
		// returns: [ 0-360, 0-100, 0-100 ]
		//
		function RGB_HSV (r, g, b) {
			r /= 255;
			g /= 255;
			b /= 255;
			var n = Math.min(Math.min(r,g),b);
			var v = Math.max(Math.max(r,g),b);
			var m = v - n;
			if (m === 0) { return [ null, 0, 100 * v ]; }
			var h = r===n ? 3+(b-g)/m : (g===n ? 5+(r-b)/m : 1+(g-r)/m);
			return [
				60 * (h===6?0:h),
				100 * (m/v),
				100 * v
			];
		}


		// h: 0-360
		// s: 0-100
		// v: 0-100
		//
		// returns: [ 0-255, 0-255, 0-255 ]
		//
		function HSV_RGB (h, s, v) {
			var u = 255 * (v / 100);

			if (h === null) {
				return [ u, u, u ];
			}

			h /= 60;
			s /= 100;

			var i = Math.floor(h);
			var f = i%2 ? h-i : 1-(h-i);
			var m = u * (1 - s);
			var n = u * (1 - s * f);
			switch (i) {
				case 6:
				case 0: return [u,n,m];
				case 1: return [n,u,m];
				case 2: return [m,u,n];
				case 3: return [m,n,u];
				case 4: return [n,m,u];
				case 5: return [u,m,n];
			}
		}


		function detachPicker () {
			jsc.unsetClass(THIS.targetElement, THIS.activeClass);
			jsc.picker.wrap.parentNode.removeChild(jsc.picker.wrap);
			delete jsc.picker.owner;
		}


		function drawPicker () {

			// At this point, when drawing the picker, we know what the parent elements are
			// and we can do all related DOM operations, such as registering events on them
			// or checking their positioning
			THIS._processParentElementsInDOM();

			if (!jsc.picker) {
				jsc.picker = {
					owner: null,
					wrap : document.createElement(&#39;div&#39;),
					box : document.createElement(&#39;div&#39;),
					boxS : document.createElement(&#39;div&#39;), // shadow area
					boxB : document.createElement(&#39;div&#39;), // border
					pad : document.createElement(&#39;div&#39;),
					padB : document.createElement(&#39;div&#39;), // border
					padM : document.createElement(&#39;div&#39;), // mouse/touch area
					padPal : jsc.createPalette(),
					cross : document.createElement(&#39;div&#39;),
					crossBY : document.createElement(&#39;div&#39;), // border Y
					crossBX : document.createElement(&#39;div&#39;), // border X
					crossLY : document.createElement(&#39;div&#39;), // line Y
					crossLX : document.createElement(&#39;div&#39;), // line X
					sld : document.createElement(&#39;div&#39;),
					sldB : document.createElement(&#39;div&#39;), // border
					sldM : document.createElement(&#39;div&#39;), // mouse/touch area
					sldGrad : jsc.createSliderGradient(),
					sldPtrS : document.createElement(&#39;div&#39;), // slider pointer spacer
					sldPtrIB : document.createElement(&#39;div&#39;), // slider pointer inner border
					sldPtrMB : document.createElement(&#39;div&#39;), // slider pointer middle border
					sldPtrOB : document.createElement(&#39;div&#39;), // slider pointer outer border
					btn : document.createElement(&#39;div&#39;),
					btnT : document.createElement(&#39;span&#39;) // text
				};

				jsc.picker.pad.appendChild(jsc.picker.padPal.elm);
				jsc.picker.padB.appendChild(jsc.picker.pad);
				jsc.picker.cross.appendChild(jsc.picker.crossBY);
				jsc.picker.cross.appendChild(jsc.picker.crossBX);
				jsc.picker.cross.appendChild(jsc.picker.crossLY);
				jsc.picker.cross.appendChild(jsc.picker.crossLX);
				jsc.picker.padB.appendChild(jsc.picker.cross);
				jsc.picker.box.appendChild(jsc.picker.padB);
				jsc.picker.box.appendChild(jsc.picker.padM);

				jsc.picker.sld.appendChild(jsc.picker.sldGrad.elm);
				jsc.picker.sldB.appendChild(jsc.picker.sld);
				jsc.picker.sldB.appendChild(jsc.picker.sldPtrOB);
				jsc.picker.sldPtrOB.appendChild(jsc.picker.sldPtrMB);
				jsc.picker.sldPtrMB.appendChild(jsc.picker.sldPtrIB);
				jsc.picker.sldPtrIB.appendChild(jsc.picker.sldPtrS);
				jsc.picker.box.appendChild(jsc.picker.sldB);
				jsc.picker.box.appendChild(jsc.picker.sldM);

				jsc.picker.btn.appendChild(jsc.picker.btnT);
				jsc.picker.box.appendChild(jsc.picker.btn);

				jsc.picker.boxB.appendChild(jsc.picker.box);
				jsc.picker.wrap.appendChild(jsc.picker.boxS);
				jsc.picker.wrap.appendChild(jsc.picker.boxB);
			}

			var p = jsc.picker;

			var displaySlider = !!jsc.getSliderComponent(THIS);
			var dims = jsc.getPickerDims(THIS);
			var crossOuterSize = (2 * THIS.pointerBorderWidth + THIS.pointerThickness + 2 * THIS.crossSize);
			var padToSliderPadding = jsc.getPadToSliderPadding(THIS);
			var borderRadius = Math.min(
				THIS.borderRadius,
				Math.round(THIS.padding * Math.PI)); // px
			var padCursor = &#39;crosshair&#39;;

			// wrap
			p.wrap.style.clear = &#39;both&#39;;
			p.wrap.style.width = (dims[0] + 2 * THIS.borderWidth) + &#39;px&#39;;
			p.wrap.style.height = (dims[1] + 2 * THIS.borderWidth) + &#39;px&#39;;
			p.wrap.style.zIndex = THIS.zIndex;
            p.wrap.style.touchAction = &#39;none&#39;;


			// picker
			p.box.style.width = dims[0] + &#39;px&#39;;
			p.box.style.height = dims[1] + &#39;px&#39;;

			p.boxS.style.position = &#39;absolute&#39;;
			p.boxS.style.left = &#39;0&#39;;
			p.boxS.style.top = &#39;0&#39;;
			p.boxS.style.width = &#39;100%&#39;;
			p.boxS.style.height = &#39;100%&#39;;

			jsc.setBorderRadius(p.boxS, borderRadius + &#39;px&#39;);

			// picker border
			p.boxB.style.position = &#39;relative&#39;;
			p.boxB.style.border = THIS.borderWidth + &#39;px solid&#39;;
			p.boxB.style.borderColor = THIS.borderColor;
			p.boxB.style.background = THIS.backgroundColor;
			jsc.setBorderRadius(p.boxB, borderRadius + &#39;px&#39;);

			// IE hack:
			// If the element is transparent, IE will trigger the event on the elements under it,
			// e.g. on Canvas or on elements with border
			p.padM.style.background =
			p.sldM.style.background =
				&#39;#FFF&#39;;
			jsc.setStyle(p.padM, &#39;opacity&#39;, &#39;0&#39;);
			jsc.setStyle(p.sldM, &#39;opacity&#39;, &#39;0&#39;);

			// pad
			p.pad.style.position = &#39;relative&#39;;
			p.pad.style.width = THIS.width + &#39;px&#39;;
			p.pad.style.height = THIS.height + &#39;px&#39;;


			// pad palettes (HSV and HVS)
			p.padPal.draw(THIS.width, THIS.height, jsc.getPadYComponent(THIS));

			// pad border
			p.padB.style.position = &#39;absolute&#39;;
			p.padB.style.left = THIS.padding + &#39;px&#39;;
			p.padB.style.top = THIS.padding + &#39;px&#39;;
			p.padB.style.border = THIS.insetWidth + &#39;px solid&#39;;
			p.padB.style.borderColor = THIS.insetColor;

			// pad mouse area
			p.padM._jscInstance = THIS;
			p.padM._jscControlName = &#39;pad&#39;;
			p.padM.style.position = &#39;absolute&#39;;
			p.padM.style.left = &#39;0&#39;;
			p.padM.style.top = &#39;0&#39;;
			p.padM.style.width = (THIS.padding + 2 * THIS.insetWidth + THIS.width + padToSliderPadding / 2) + &#39;px&#39;;
			p.padM.style.height = dims[1] + &#39;px&#39;;
			p.padM.style.cursor = padCursor;
            p.padM.style.touchAction = &#39;none&#39;;



			// pad cross
			p.cross.style.position = &#39;absolute&#39;;
			p.cross.style.left =
			p.cross.style.top =
				&#39;0&#39;;
			p.cross.style.width =
			p.cross.style.height =
				crossOuterSize + &#39;px&#39;;


			// pad cross border Y and X
			p.crossBY.style.position =
			p.crossBX.style.position =
				&#39;absolute&#39;;
			p.crossBY.style.background =
			p.crossBX.style.background =
				THIS.pointerBorderColor;
			p.crossBY.style.width =
			p.crossBX.style.height =
				(2 * THIS.pointerBorderWidth + THIS.pointerThickness) + &#39;px&#39;;
			p.crossBY.style.height =
			p.crossBX.style.width =
				crossOuterSize + &#39;px&#39;;
			p.crossBY.style.left =
			p.crossBX.style.top =
				(Math.floor(crossOuterSize / 2) - Math.floor(THIS.pointerThickness / 2) - THIS.pointerBorderWidth) + &#39;px&#39;;
			p.crossBY.style.top =
			p.crossBX.style.left =
				&#39;0&#39;;

			// pad cross line Y and X
			p.crossLY.style.position =
			p.crossLX.style.position =
				&#39;absolute&#39;;
			p.crossLY.style.background =
			p.crossLX.style.background =
				THIS.pointerColor;
			p.crossLY.style.height =
			p.crossLX.style.width =
				(crossOuterSize - 2 * THIS.pointerBorderWidth) + &#39;px&#39;;
			p.crossLY.style.width =
			p.crossLX.style.height =
				THIS.pointerThickness + &#39;px&#39;;
			p.crossLY.style.left =
			p.crossLX.style.top =
				(Math.floor(crossOuterSize / 2) - Math.floor(THIS.pointerThickness / 2)) + &#39;px&#39;;
			p.crossLY.style.top =
			p.crossLX.style.left =
				THIS.pointerBorderWidth + &#39;px&#39;;

			// slider
			p.sld.style.overflow = &#39;hidden&#39;;
			p.sld.style.width = THIS.sliderSize + &#39;px&#39;;
			p.sld.style.height = THIS.height + &#39;px&#39;;

			// slider gradient
			p.sldGrad.draw(THIS.sliderSize, THIS.height, &#39;#000&#39;, &#39;#000&#39;);

			// slider border
			p.sldB.style.display = displaySlider ? &#39;block&#39; : &#39;none&#39;;
			p.sldB.style.position = &#39;absolute&#39;;
			p.sldB.style.right = THIS.padding + &#39;px&#39;;
			p.sldB.style.top = THIS.padding + &#39;px&#39;;
			p.sldB.style.border = THIS.insetWidth + &#39;px solid&#39;;
			p.sldB.style.borderColor = THIS.insetColor;

			// slider mouse area
			p.sldM._jscInstance = THIS;
			p.sldM._jscControlName = &#39;sld&#39;;
			p.sldM.style.display = displaySlider ? &#39;block&#39; : &#39;none&#39;;
			p.sldM.style.position = &#39;absolute&#39;;
			p.sldM.style.right = &#39;0&#39;;
			p.sldM.style.top = &#39;0&#39;;
			p.sldM.style.width = (THIS.sliderSize + padToSliderPadding / 2 + THIS.padding + 2 * THIS.insetWidth) + &#39;px&#39;;
			p.sldM.style.height = dims[1] + &#39;px&#39;;
			p.sldM.style.cursor = &#39;default&#39;;

			// slider pointer inner and outer border
			p.sldPtrIB.style.border =
			p.sldPtrOB.style.border =
				THIS.pointerBorderWidth + &#39;px solid &#39; + THIS.pointerBorderColor;

			// slider pointer outer border
			p.sldPtrOB.style.position = &#39;absolute&#39;;
			p.sldPtrOB.style.left = -(2 * THIS.pointerBorderWidth + THIS.pointerThickness) + &#39;px&#39;;
			p.sldPtrOB.style.top = &#39;0&#39;;

			// slider pointer middle border
			p.sldPtrMB.style.border = THIS.pointerThickness + &#39;px solid &#39; + THIS.pointerColor;

			// slider pointer spacer
			p.sldPtrS.style.width = THIS.sliderSize + &#39;px&#39;;
			p.sldPtrS.style.height = sliderPtrSpace + &#39;px&#39;;

			// the Close button
			function setBtnBorder () {
				var insetColors = THIS.insetColor.split(/\s+/);
				var outsetColor = insetColors.length &lt; 2 ? insetColors[0] : insetColors[1] + &#39; &#39; + insetColors[0] + &#39; &#39; + insetColors[0] + &#39; &#39; + insetColors[1];
				p.btn.style.borderColor = outsetColor;
			}
			p.btn.style.display = THIS.closable ? &#39;block&#39; : &#39;none&#39;;
			p.btn.style.position = &#39;absolute&#39;;
			p.btn.style.left = THIS.padding + &#39;px&#39;;
			p.btn.style.bottom = THIS.padding + &#39;px&#39;;
			p.btn.style.padding = &#39;0 15px&#39;;
			p.btn.style.height = THIS.buttonHeight + &#39;px&#39;;
			p.btn.style.border = THIS.insetWidth + &#39;px solid&#39;;
			setBtnBorder();
			p.btn.style.color = THIS.buttonColor;
			p.btn.style.font = &#39;12px sans-serif&#39;;
			p.btn.style.textAlign = &#39;center&#39;;
			try {
				p.btn.style.cursor = &#39;pointer&#39;;
			} catch(eOldIE) {
				p.btn.style.cursor = &#39;hand&#39;;
			}
			p.btn.onmousedown = function () {
				THIS.hide();
			};
			p.btnT.style.lineHeight = THIS.buttonHeight + &#39;px&#39;;
			p.btnT.innerHTML = &#39;&#39;;
			p.btnT.appendChild(document.createTextNode(THIS.closeText));

			// place pointers
			redrawPad();
			redrawSld();

			// If we are changing the owner without first closing the picker,
			// make sure to first deal with the old owner
			if (jsc.picker.owner &amp;&amp; jsc.picker.owner !== THIS) {
				jsc.unsetClass(jsc.picker.owner.targetElement, THIS.activeClass);
			}

			// Set the new picker owner
			jsc.picker.owner = THIS;

			// The redrawPosition() method needs picker.owner to be set, that&#39;s why we call it here,
			// after setting the owner
			if (jsc.isElementType(container, &#39;body&#39;)) {
				jsc.redrawPosition();
			} else {
				jsc._drawPosition(THIS, 0, 0, &#39;relative&#39;, false);
			}

			if (p.wrap.parentNode != container) {
				container.appendChild(p.wrap);
			}

			jsc.setClass(THIS.targetElement, THIS.activeClass);
		}


		function redrawPad () {
			// redraw the pad pointer
			switch (jsc.getPadYComponent(THIS)) {
			case &#39;s&#39;: var yComponent = 1; break;
			case &#39;v&#39;: var yComponent = 2; break;
			}
			var x = Math.round((THIS.hsv[0] / 360) * (THIS.width - 1));
			var y = Math.round((1 - THIS.hsv[yComponent] / 100) * (THIS.height - 1));
			var crossOuterSize = (2 * THIS.pointerBorderWidth + THIS.pointerThickness + 2 * THIS.crossSize);
			var ofs = -Math.floor(crossOuterSize / 2);
			jsc.picker.cross.style.left = (x + ofs) + &#39;px&#39;;
			jsc.picker.cross.style.top = (y + ofs) + &#39;px&#39;;

			// redraw the slider
			switch (jsc.getSliderComponent(THIS)) {
			case &#39;s&#39;:
				var rgb1 = HSV_RGB(THIS.hsv[0], 100, THIS.hsv[2]);
				var rgb2 = HSV_RGB(THIS.hsv[0], 0, THIS.hsv[2]);
				var color1 = &#39;rgb(&#39; +
					Math.round(rgb1[0]) + &#39;,&#39; +
					Math.round(rgb1[1]) + &#39;,&#39; +
					Math.round(rgb1[2]) + &#39;)&#39;;
				var color2 = &#39;rgb(&#39; +
					Math.round(rgb2[0]) + &#39;,&#39; +
					Math.round(rgb2[1]) + &#39;,&#39; +
					Math.round(rgb2[2]) + &#39;)&#39;;
				jsc.picker.sldGrad.draw(THIS.sliderSize, THIS.height, color1, color2);
				break;
			case &#39;v&#39;:
				var rgb = HSV_RGB(THIS.hsv[0], THIS.hsv[1], 100);
				var color1 = &#39;rgb(&#39; +
					Math.round(rgb[0]) + &#39;,&#39; +
					Math.round(rgb[1]) + &#39;,&#39; +
					Math.round(rgb[2]) + &#39;)&#39;;
				var color2 = &#39;#000&#39;;
				jsc.picker.sldGrad.draw(THIS.sliderSize, THIS.height, color1, color2);
				break;
			}
		}


		function redrawSld () {
			var sldComponent = jsc.getSliderComponent(THIS);
			if (sldComponent) {
				// redraw the slider pointer
				switch (sldComponent) {
				case &#39;s&#39;: var yComponent = 1; break;
				case &#39;v&#39;: var yComponent = 2; break;
				}
				var y = Math.round((1 - THIS.hsv[yComponent] / 100) * (THIS.height - 1));
				jsc.picker.sldPtrOB.style.top = (y - (2 * THIS.pointerBorderWidth + THIS.pointerThickness) - Math.floor(sliderPtrSpace / 2)) + &#39;px&#39;;
			}
		}


		function isPickerOwner () {
			return jsc.picker &amp;&amp; jsc.picker.owner === THIS;
		}


		function blurValue () {
			THIS.importColor();
		}


		// Find the target element
		if (typeof targetElement === &#39;string&#39;) {
			var id = targetElement;
			var elm = document.getElementById(id);
			if (elm) {
				this.targetElement = elm;
			} else {
				jsc.warn(&#39;Could not find target element with ID \&#39;&#39; + id + &#39;\&#39;&#39;);
			}
		} else if (targetElement) {
			this.targetElement = targetElement;
		} else {
			jsc.warn(&#39;Invalid target element: \&#39;&#39; + targetElement + &#39;\&#39;&#39;);
		}

		if (this.targetElement._jscLinkedInstance) {
			jsc.warn(&#39;Cannot link jscolor twice to the same element. Skipping.&#39;);
			return;
		}
		this.targetElement._jscLinkedInstance = this;

		// Find the value element
		this.valueElement = jsc.fetchElement(this.valueElement);
		// Find the style element
		this.styleElement = jsc.fetchElement(this.styleElement);

		var THIS = this;
		var container =
			this.container ?
			jsc.fetchElement(this.container) :
			document.getElementsByTagName(&#39;body&#39;)[0];
		var sliderPtrSpace = 3; // px

		// For BUTTON elements it&#39;s important to stop them from sending the form when clicked
		// (e.g. in Safari)
		if (jsc.isElementType(this.targetElement, &#39;button&#39;)) {
			if (this.targetElement.onclick) {
				var origCallback = this.targetElement.onclick;
				this.targetElement.onclick = function (evt) {
					origCallback.call(this, evt);
					return false;
				};
			} else {
				this.targetElement.onclick = function () { return false; };
			}
		}

		/*
		var elm = this.targetElement;
		do {
			// If the target element or one of its offsetParents has fixed position,
			// then use fixed positioning instead
			//
			// Note: In Firefox, getComputedStyle returns null in a hidden iframe,
			// that&#39;s why we need to check if the returned style object is non-empty
			var currStyle = jsc.getStyle(elm);
			if (currStyle &amp;&amp; currStyle.position.toLowerCase() === &#39;fixed&#39;) {
				this.fixed = true;
			}

			if (elm !== this.targetElement) {
				// attach onParentScroll so that we can recompute the picker position
				// when one of the offsetParents is scrolled
				if (!elm._jscEventsAttached) {
					jsc.attachEvent(elm, &#39;scroll&#39;, jsc.onParentScroll);
					elm._jscEventsAttached = true;
				}
			}
		} while ((elm = elm.offsetParent) &amp;&amp; !jsc.isElementType(elm, &#39;body&#39;));
		*/

		// valueElement
		if (this.valueElement) {
			if (jsc.isElementType(this.valueElement, &#39;input&#39;)) {
				var updateField = function () {
					THIS.fromString(THIS.valueElement.value, jsc.leaveValue);
					jsc.dispatchFineChange(THIS);
				};
				jsc.attachEvent(this.valueElement, &#39;keyup&#39;, updateField);
				jsc.attachEvent(this.valueElement, &#39;input&#39;, updateField);
				jsc.attachEvent(this.valueElement, &#39;blur&#39;, blurValue);
				this.valueElement.setAttribute(&#39;autocomplete&#39;, &#39;off&#39;);
			}
		}

		// styleElement
		if (this.styleElement) {
			this.styleElement._jscOrigStyle = {
				backgroundImage : this.styleElement.style.backgroundImage,
				backgroundColor : this.styleElement.style.backgroundColor,
				color : this.styleElement.style.color
			};
		}

		if (this.value) {
			// Try to set the color from the .value option and if unsuccessful,
			// export the current color
			this.fromString(this.value) || this.exportColor();
		} else {
			this.importColor();
		}
	}

};


//================================
// Public properties and methods
//================================


// By default, search for all elements with class=&quot;jscolor&quot; and install a color picker on them.
//
// You can change what class name will be looked for by setting the property jscolor.lookupClass
// anywhere in your HTML document. To completely disable the automatic lookup, set it to null.
//
jsc.jscolor.lookupClass = &#39;jscolor&#39;;


jsc.jscolor.installByClassName = function (className) {
	var inputElms = document.getElementsByTagName(&#39;input&#39;);
	var buttonElms = document.getElementsByTagName(&#39;button&#39;);

	jsc.tryInstallOnElements(inputElms, className);
	jsc.tryInstallOnElements(buttonElms, className);
};


jsc.register();


return jsc.jscolor;


})(); }&lt;/script&gt;

&lt;script&gt;var background = [&quot;#24243e&quot;, &quot;#302b63&quot;];
const helmet = document.getElementById(&quot;js-helmet&quot;);
const facemask = document.getElementById(&quot;js-facemask&quot;);
const logo = document.getElementById(&quot;js-logo&quot;);
const jersey = document.getElementById(&quot;js-jersey&quot;);
const sleeve = document.getElementById(&quot;js-sleeve&quot;);
const pants = document.getElementById(&quot;js-pants&quot;);
const stripe = document.getElementById(&quot;js-stripe&quot;);
const sockshigh = document.getElementById(&quot;js-sockshigh&quot;);
const sockslow = document.getElementById(&quot;js-sockslow&quot;);


function updateHelmet(picker, string) {
  if (!string) {
  helmet.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      helmet.style.fill = string;
     setTimeout(function(){helmet.classList.remove(&quot;fade&quot;);}, 700); 
    }
}

function updateFacemask(picker, string) {
  if (!string) {
facemask.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      facemask.style.fill = string;
     setTimeout(function(){facemask.classList.remove(&quot;fade&quot;);}, 700); 
    }
}

function updateLogo(picker, string) {
  if (!string) {
  logo.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      logo.style.fill = string;
     setTimeout(function(){logo.classList.remove(&quot;fade&quot;);}, 700); 
    }
}

function updateJersey(picker, string) {
  if (!string) {
  jersey.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      jersey.style.fill = string;
     setTimeout(function(){jersey.classList.remove(&quot;fade&quot;);}, 700); 
    }
}

function updateSleeve(picker, string) {
  if (!string) {
  sleeve.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      sleeve.style.fill = string;
     setTimeout(function(){sleeve.classList.remove(&quot;fade&quot;);}, 700); 
    }
}


function updatePants(picker, string) {
  if (!string) {
  pants.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      pants.style.fill = string;
     setTimeout(function(){pants.classList.remove(&quot;fade&quot;);}, 700); 
    }
}

function updateStripe(picker, string) {
  if (!string) {
  stripe.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      stripe.style.fill = string;
     setTimeout(function(){stripe.classList.remove(&quot;fade&quot;);}, 700); 
    }
}


function updateSockshigh(picker, string) {
  if (!string) {
  sockshigh.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      sockshigh.style.fill = string;
     setTimeout(function(){sockshigh.classList.remove(&quot;fade&quot;);}, 700); 
    }
}

function updateSockslow(picker, string) {
  if (!string) {
  sockslow.style.fill = picker.toHEXString();
    } else {
      // Used when generating random
      sockslow.style.fill = string;
     setTimeout(function(){sockslow.classList.remove(&quot;fade&quot;);}, 700); 
    }
}

// Generate random


function generateRandom() {
// Couch  
var red = Math.floor(Math.random() * 256) ;
var green = Math.floor(Math.random() * 256) ;
var blue = Math.floor(Math.random() * 256) ;
	
	
var red2 = Math.floor(Math.random() * 256) ;
var green2 = Math.floor(Math.random() * 256) ;
var blue2 = Math.floor(Math.random() * 256) ;
	
var red3 = Math.floor(Math.random() * 256) ;
var green3 = Math.floor(Math.random() * 256) ;
var blue3 = Math.floor(Math.random() * 256) ;
	
var red4 = Math.floor(Math.random() * 256) ;
var green4 = Math.floor(Math.random() * 256) ;
var blue4 = Math.floor(Math.random() * 256) ;
	
var red5 = Math.floor(Math.random() * 256) ;
var green5 = Math.floor(Math.random() * 256) ;
var blue5 = Math.floor(Math.random() * 256) ;
	
var red6 = Math.floor(Math.random() * 256) ;
var green6 = Math.floor(Math.random() * 256) ;
var blue6 = Math.floor(Math.random() * 256) ;
  
var red7 = Math.floor(Math.random() * 256) ;
var green7 = Math.floor(Math.random() * 256) ;
var blue7 = Math.floor(Math.random() * 256) ;
	
var red8 = Math.floor(Math.random() * 256) ;
var green8 = Math.floor(Math.random() * 256) ;
var blue8 = Math.floor(Math.random() * 256) ;

var red9 = Math.floor(Math.random() * 256) ;
var green9 = Math.floor(Math.random() * 256) ;
var blue9 = Math.floor(Math.random() * 256) ;  


let hex1 = rgbToHex(red, green, blue);
let hex2 = rgbToHex(red2, green2, blue2);
let hex3 = rgbToHex(red3, green3, blue3);
let hex4 = rgbToHex(red4, green4, blue4);
let hex5 = rgbToHex(red5, green5, blue5);
let hex6 = rgbToHex(red6, green6, blue6);
let hex7 = rgbToHex(red7, green7, blue7);
let hex8 = rgbToHex(red8, green8, blue8);
let hex9 = rgbToHex(red9, green9, blue9);




  
  updateHelmet(null, hex1);
  updateFacemask(null, hex2);
  updateLogo(null, hex3);
  updateJersey(null, hex4);
  updateSleeve(null, hex5);
  updatePants(null, hex6);
  updateStripe(null, hex7);
  updateSockshigh(null, hex8);
  updateSockslow(null, hex9);


  
    helmet.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-1&#39;)
    .jscolor.fromString(hex1);


    facemask.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-2&#39;)
    .jscolor.fromString(hex2);
	
  
    logo.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-3&#39;)
    .jscolor.fromString(hex3);
	
	jersey.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-4&#39;)
    .jscolor.fromString(hex4);
	
	sleeve.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-5&#39;)
    .jscolor.fromString(hex5);
	
	pants.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-6&#39;)
    .jscolor.fromString(hex6);
	
	stripe.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-7&#39;)
    .jscolor.fromString(hex7);
		
	sockshigh.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-8&#39;)
    .jscolor.fromString(hex8);

	sockslow.classList.add(&quot;fade&quot;);
  
 document.getElementById(&#39;js-color-9&#39;)
    .jscolor.fromString(hex9);
  
}

function componentToHex(c) {
    var hex = c.toString(16);
    return hex.length == 1 ? &quot;0&quot; + hex : hex;
}

function rgbToHex(r, g, b) {
    return &quot;#&quot; + componentToHex(r) + componentToHex(g) + componentToHex(b);
}&lt;/script&gt;
</description><link>http://boredandinsane.blogspot.com/2022/02/retro-bowl-color-picker.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>7</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-4401377734696319673</guid><pubDate>Sat, 28 Aug 2021 09:35:00 +0000</pubDate><atom:updated>2021-08-28T02:35:47.445-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">400 meters</category><category domain="http://www.blogger.com/atom/ns#">400m</category><category domain="http://www.blogger.com/atom/ns#">after effects</category><category domain="http://www.blogger.com/atom/ns#">athletics</category><category domain="http://www.blogger.com/atom/ns#">chart</category><category domain="http://www.blogger.com/atom/ns#">data</category><category domain="http://www.blogger.com/atom/ns#">hurdles</category><category domain="http://www.blogger.com/atom/ns#">infographic</category><category domain="http://www.blogger.com/atom/ns#">Olympics</category><category domain="http://www.blogger.com/atom/ns#">results</category><category domain="http://www.blogger.com/atom/ns#">running</category><category domain="http://www.blogger.com/atom/ns#">statistics</category><category domain="http://www.blogger.com/atom/ns#">track &amp; field</category><title>A Chart of Olympic 400m Hurdles Finals Since 1948</title><description>&lt;p&gt;Another Olympic event that was fascinating this year was the 400m Hurdles — both the Men and Women races had some very impressive world record times!&lt;/p&gt;

&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: left;&quot;&gt;&lt;iframe allowfullscreen=&#39;allowfullscreen&#39; webkitallowfullscreen=&#39;webkitallowfullscreen&#39; mozallowfullscreen=&#39;mozallowfullscreen&#39; width=&#39;600&#39; height=&#39;498&#39; src=&#39;https://www.blogger.com/video.g?token=AD6v5dxkSfxFETsCdGisNR4-0_mmZt6E-rG1NLyzFDUChezS-Z-Tb-6LyUUoQzyRsritUSlLn0sWfS_ELXGxzigt1g&#39; class=&#39;b-hbp-video b-uploaded&#39; frameborder=&#39;0&#39;&gt;&lt;/iframe&gt;&lt;/div&gt;

&lt;h2&gt;TOOLS&lt;/h2&gt; 
&lt;p&gt;Numbers app, Illustrator, After Effects, Google/Wikipedia&lt;/p&gt;

&lt;h2&gt;SOURCES&lt;/h2&gt;  

&lt;p&gt;Olympic finals results:
&lt;ul&gt;
  &lt;li&gt;&lt;a href=&quot;https://www.olympedia.org&quot;&gt;https://www.olympedia.org&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;/p&gt;

&lt;p&gt;World Leading Times and World Records — I was unable to find the world leading times for the 1955 &amp; 1958 seasons:

&lt;ul&gt;
 &lt;li&gt;&lt;a href=&quot;https://www.worldathletics.org/records/all-time-toplists/hurdles/400-metres-hurdles/outdoor/women/senior&quot;&gt;https://www.worldathletics.org/records/all-time-toplists/hurdles/400-metres-hurdles/outdoor/women/senior&lt;/a&gt;&lt;/li&gt;
  
   &lt;li&gt;&lt;a href=&quot;https://www.worldathletics.org/records/all-time-toplists/hurdles/400-metres-hurdles/outdoor/men/senior&quot;&gt;https://www.worldathletics.org/records/all-time-toplists/hurdles/400-metres-hurdles/outdoor/men/senior&lt;/a&gt;&lt;/li&gt;

 &lt;li&gt;&lt;a href=&quot;http://trackfield.brinkster.net&quot;&gt;http://trackfield.brinkster.net&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;/p&gt;   

&lt;p&gt;Edwin Moses:   

&lt;ul&gt;
 &lt;li&gt;&lt;a href=&quot;https://olympics.com/en/video/edwin-moses-the-unbeatable-hurdler&quot;&gt;https://olympics.com/en/video/edwin-moses-the-unbeatable-hurdler&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;/p&gt;
&lt;br&gt;</description><link>http://boredandinsane.blogspot.com/2021/08/a-chart-of-olympic-400m-hurdles-finals.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-5706294639677536393</guid><pubDate>Wed, 11 Aug 2021 11:22:00 +0000</pubDate><atom:updated>2021-08-28T01:06:38.092-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">800 meters</category><category domain="http://www.blogger.com/atom/ns#">800m</category><category domain="http://www.blogger.com/atom/ns#">athletics</category><category domain="http://www.blogger.com/atom/ns#">chart</category><category domain="http://www.blogger.com/atom/ns#">data</category><category domain="http://www.blogger.com/atom/ns#">infographic</category><category domain="http://www.blogger.com/atom/ns#">Olympics</category><category domain="http://www.blogger.com/atom/ns#">results</category><category domain="http://www.blogger.com/atom/ns#">running</category><category domain="http://www.blogger.com/atom/ns#">statistics</category><category domain="http://www.blogger.com/atom/ns#">track &amp; field</category><title>A Chart of Men&#39;s Olympic 800m Finals Since 1948</title><description>
&lt;p&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both;&quot;&gt;&lt;a href=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgCrnmXCBVU7Y6EDZyEU2YO8HdUuXa6Fhugd9DdR1lSFB1cLhealczsrPbBmy_JomtPEqJpgGfe0EZu5LdFgTq-__MlZzxUq_MoHwKcnrIYihnY6XLCETPCJDYaGYwDXMtdxA5vJa7fLYMm/s2048/Bored-and-Insane_Mens-Athletics-800m-Olympic-Finals-Chart%25402x.png&quot; style=&quot;display: block; padding: 1em 0; text-align: center; &quot;&gt;&lt;img alt=&quot;&quot; border=&quot;0&quot; width=&quot;600&quot; data-original-height=&quot;1422&quot; data-original-width=&quot;2048&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgCrnmXCBVU7Y6EDZyEU2YO8HdUuXa6Fhugd9DdR1lSFB1cLhealczsrPbBmy_JomtPEqJpgGfe0EZu5LdFgTq-__MlZzxUq_MoHwKcnrIYihnY6XLCETPCJDYaGYwDXMtdxA5vJa7fLYMm/s600/Bored-and-Insane_Mens-Athletics-800m-Olympic-Finals-Chart%25402x.png&quot;/&gt;&lt;/a&gt;&lt;/div&gt;
&lt;/p&gt;

&lt;p&gt;I was fascinated by the relatively slow times in the men’s 800m final this Olympics, and went down a rabbit hole looking through the history of the men’s 800m. Then I figured I might as well put my graphic designer knowledge to good use and share my findings!&lt;/p&gt;   

&lt;p&gt;Of the Olympics finals since 1948, the 800m final in 2000 had the most comparable result to the 2020 final — both had relatively slow winning times and very narrow range of times (less than 1.5 seconds difference between the first and last place runners):
&lt;ul&gt;
&lt;li&gt;Tokyo 2020 fastest/slowest times: 1:45.06 – 1:46.53&lt;/li&gt;
  &lt;li style=&quot;list-style-type: circle; margin-left:1em;&quot;
&gt;Difference of 1.47 seconds between 1st &amp; last (9 runners)&lt;/li&gt;
  &lt;li style=&quot;list-style-type: circle; margin-left:1em;&quot;
&gt;The average of the Olympic final times is 2.92 seconds slower than the world leading time for the year&lt;/li&gt;
&lt;li&gt;Sydney 2000 fastest/slowest times: 1:45.08 – 1:46.24&lt;/li&gt;
  &lt;li style=&quot;list-style-type: circle; margin-left:1em;&quot;
&gt;Difference of 1.16 seconds between 1st &amp; last (8 runners, including one disqualified runner who finished around 1:45.60)&lt;/li&gt; 
  &lt;li style=&quot;list-style-type: circle; margin-left:1em;&quot;
&gt;The average of the Olympic final times is 2.35 seconds slower than the world leading time for the year&lt;/li&gt;
&lt;/ul&gt;
&lt;/p&gt;

&lt;h2&gt;TOOLS&lt;/h2&gt; 
&lt;p&gt;Numbers app, Illustrator, Google/Wikipedia&lt;/p&gt;

&lt;h2&gt;SOURCES&lt;/h2&gt;  

&lt;p&gt;Olympic finals results:&lt;/p&gt;   
&lt;ul&gt;
  &lt;li&gt;&lt;a href=&quot;https://www.olympedia.org/results/358610&quot;&gt;https://www.olympedia.org/results/358610&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;World Leading Times and World Records — I was unable to find a few of the world leading times in years prior to 1966:&lt;/p&gt;   

&lt;ul&gt;
 &lt;li&gt;&lt;a href=&quot;https://www.worldathletics.org/records/all-time-toplists/middlelong/800-metres/outdoor/men/senior&quot;&gt;https://www.worldathletics.org/records/all-time-toplists/middlelong/800-metres/outdoor/men/senior&lt;/a&gt;&lt;/li&gt;

 &lt;li&gt;&lt;a href=&quot;http://trackfield.brinkster.net&quot;&gt;http://trackfield.brinkster.net&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;</description><link>http://boredandinsane.blogspot.com/2021/08/a-chart-of-mens-olympic-800m-finals.html</link><author>noreply@blogger.com (Bored and Insane)</author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgCrnmXCBVU7Y6EDZyEU2YO8HdUuXa6Fhugd9DdR1lSFB1cLhealczsrPbBmy_JomtPEqJpgGfe0EZu5LdFgTq-__MlZzxUq_MoHwKcnrIYihnY6XLCETPCJDYaGYwDXMtdxA5vJa7fLYMm/s72-c/Bored-and-Insane_Mens-Athletics-800m-Olympic-Finals-Chart%25402x.png" height="72" width="72"/><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-910132723410671458</guid><pubDate>Sun, 08 Aug 2021 03:33:00 +0000</pubDate><atom:updated>2022-01-10T00:02:26.407-08:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">1st gen starters</category><category domain="http://www.blogger.com/atom/ns#">blue</category><category domain="http://www.blogger.com/atom/ns#">bulbasaur</category><category domain="http://www.blogger.com/atom/ns#">charmander</category><category domain="http://www.blogger.com/atom/ns#">gameboy</category><category domain="http://www.blogger.com/atom/ns#">heart</category><category domain="http://www.blogger.com/atom/ns#">link</category><category domain="http://www.blogger.com/atom/ns#">pixel art</category><category domain="http://www.blogger.com/atom/ns#">pokemon</category><category domain="http://www.blogger.com/atom/ns#">red</category><category domain="http://www.blogger.com/atom/ns#">shirt</category><category domain="http://www.blogger.com/atom/ns#">sprites</category><category domain="http://www.blogger.com/atom/ns#">squirtle</category><category domain="http://www.blogger.com/atom/ns#">video games</category><category domain="http://www.blogger.com/atom/ns#">zelda</category><title>Pixel Fun</title><description>&lt;p&gt;
Hey, what d&#39;you know, in a world full of super-accessible social media, Patreons, and too many streaming services to keep track of, Google Blogger somehow still exists, for god-knows what demographic. And I&#39;m back here as bored and insane as ever!&lt;/p&gt;

&lt;p&gt;
I&#39;ve been playing with some pixels because sometimes simple is what we need. Sometimes simple is comfort. And in a world of constant chaos, uncertainty, and unrest, one thing still holds very true — people are suckers for nostalgia:
&lt;/p&gt;  
  
&lt;p&gt;
&lt;div style=&quot;text-align:center;line-height:150%&quot;&gt;
&lt;a href=&quot;https://www.zazzle.com/minimalist_monsters_t_shirt-235880169400261951&quot; rel=&quot;nofollow&quot;&gt;&lt;img src=&quot;https://rlv.zcache.com/minimalist_monsters_t_shirt-r866ec5f2156e4813871f72bcc8d42734_k2gm8_1024.jpg?max_dim=500&quot; alt=&quot;Minimalist Monsters T-Shirt&quot; style=&quot;border:0;&quot; /&gt;&lt;/a&gt;
&lt;br/&gt;
&lt;a href=&quot;https://www.zazzle.com/minimalist_monsters_t_shirt-235880169400261951&quot; rel=&quot;nofollow&quot;&gt;Minimalist Monsters T-Shirt&lt;/a&gt;
&lt;br/&gt;by &lt;a href=&quot;https://www.zazzle.com/store/pearboy&quot; rel=&quot;nofollow&quot;&gt;PearBoy&lt;/a&gt;
&lt;/div&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;div style=&quot;text-align:center;line-height:150%&quot;&gt;
&lt;a href=&quot;https://www.zazzle.com/video_game_pixel_heart_button-145517968126748327&quot;&gt;&lt;img src=&quot;https://rlv.zcache.com/video_game_pixel_heart_button-rd9968ac4e8644a28a17b321985019c23_k94r8_1024.jpg?rlvnet=1&amp;max_dim=325&quot; alt=&quot;Video Game Pixel Heart Button&quot; style=&quot;border:0;&quot; /&gt;&lt;/a&gt;
&lt;br/&gt;
&lt;a href=&quot;https://www.zazzle.com/video_game_pixel_heart_button-145517968126748327&quot;&gt;Video Game Pixel Heart Button&lt;/a&gt;
&lt;br/&gt;by &lt;a href=&quot;https://www.zazzle.com/store/pearboy&quot;&gt;PearBoy&lt;/a&gt;
&lt;/div&gt;
&lt;/p&gt;
</description><link>http://boredandinsane.blogspot.com/2021/08/pixel-fun.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-3302366859342583639</guid><pubDate>Sat, 13 Aug 2016 22:25:00 +0000</pubDate><atom:updated>2017-07-12T20:41:03.744-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">comic</category><category domain="http://www.blogger.com/atom/ns#">existential crisis</category><category domain="http://www.blogger.com/atom/ns#">sharpie</category><title>Existential Crisis</title><description>&lt;p&gt;
&lt;a href=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi6vvM38tvXLj0LGQVLY_k3BvVi2Hc05wmjQ7YYekb9goeBu0Gafi91XF5nDb_kTLAcmKHy98vDAsZvTo1Kdl9r0ehDZYRKN5NlMKxn4WDhxtoMtEWZrIU_r-7fATprdsWpfp4ugY5v9Tax/s1600/Larwood_Existential_Crisis.JPG&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[Enjoy your existential crisis!]&quot;&gt;&lt;img alt=&quot;Enjoy your existential crisis!&quot; border=&quot;0&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi6vvM38tvXLj0LGQVLY_k3BvVi2Hc05wmjQ7YYekb9goeBu0Gafi91XF5nDb_kTLAcmKHy98vDAsZvTo1Kdl9r0ehDZYRKN5NlMKxn4WDhxtoMtEWZrIU_r-7fATprdsWpfp4ugY5v9Tax/s1600/Larwood_Existential_Crisis.JPG&quot; title=&quot;Enjoy your existential crisis!&quot; width=&quot;600&quot; /&gt;&lt;/a&gt;&lt;br /&gt;
&lt;/p&gt;
&lt;p&gt;
If you can&#39;t have a little fun, what&#39;s the point?
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2016/08/enjoy-you-existential-crisis.html</link><author>noreply@blogger.com (Bored and Insane)</author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi6vvM38tvXLj0LGQVLY_k3BvVi2Hc05wmjQ7YYekb9goeBu0Gafi91XF5nDb_kTLAcmKHy98vDAsZvTo1Kdl9r0ehDZYRKN5NlMKxn4WDhxtoMtEWZrIU_r-7fATprdsWpfp4ugY5v9Tax/s72-c/Larwood_Existential_Crisis.JPG" height="72" width="72"/><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-2981025667736453113</guid><pubDate>Sun, 01 May 2016 16:36:00 +0000</pubDate><atom:updated>2016-05-01T09:50:10.819-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">#NOhalf</category><category domain="http://www.blogger.com/atom/ns#">#SLOhalf</category><category domain="http://www.blogger.com/atom/ns#">marathon</category><category domain="http://www.blogger.com/atom/ns#">Netflix</category><title>SLO Half Marathon 2016</title><description>&lt;p&gt;You win some, you lose some.&lt;/p&gt;

&lt;iframe width=&quot;560&quot; height=&quot;315&quot; src=&quot;https://www.youtube.com/embed/lXjjrJ4jHZA&quot; frameborder=&quot;0&quot; allowfullscreen&gt;&lt;/iframe&gt;</description><link>http://boredandinsane.blogspot.com/2016/05/slo-half-marathon-2016.html</link><author>noreply@blogger.com (Bored and Insane)</author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://img.youtube.com/vi/lXjjrJ4jHZA/default.jpg" height="72" width="72"/><thr:total>1</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-1397863052298270551</guid><pubDate>Mon, 18 Jan 2016 07:47:00 +0000</pubDate><atom:updated>2016-01-17T23:48:22.376-08:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">cartoon</category><category domain="http://www.blogger.com/atom/ns#">dinosaur</category><category domain="http://www.blogger.com/atom/ns#">Ian Malcolm</category><category domain="http://www.blogger.com/atom/ns#">Jeff Goldblum</category><category domain="http://www.blogger.com/atom/ns#">Jurassic Park</category><category domain="http://www.blogger.com/atom/ns#">pun</category><category domain="http://www.blogger.com/atom/ns#">veloci-rooster</category><category domain="http://www.blogger.com/atom/ns#">Velociraptor</category><title>Veloci-rooster</title><description>&lt;p&gt;
&lt;a href=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2K9QXROUc7Mc7sgsi3lf1_nT7EWjzJN8GGY6YS6q3Zu87lU61HgjCNMRoiHDC-8aMMIa8tAHzSnpK0UZXi9gtXWM1iFj9sveRfGdqjqqzoBLencjpU5JIX9bDrRTl1rQvenTwoUjS3wnX/s1600/Veloci-rooster_800x600.jpg&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[Veloci-rooster]&quot;&gt;&lt;img alt=&quot;Veloci-rooster&quot; border=&quot;0&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2K9QXROUc7Mc7sgsi3lf1_nT7EWjzJN8GGY6YS6q3Zu87lU61HgjCNMRoiHDC-8aMMIa8tAHzSnpK0UZXi9gtXWM1iFj9sveRfGdqjqqzoBLencjpU5JIX9bDrRTl1rQvenTwoUjS3wnX/s640/Veloci-rooster_800x600.jpg&quot; width=&quot;600&quot; /&gt;&lt;/a&gt;
&lt;/p&gt;
&lt;p&gt;
I may have been so preoccupied with whether or not I could that I didn&#39;t stop to think if I should.
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2016/01/veloci-rooster.html</link><author>noreply@blogger.com (Bored and Insane)</author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2K9QXROUc7Mc7sgsi3lf1_nT7EWjzJN8GGY6YS6q3Zu87lU61HgjCNMRoiHDC-8aMMIa8tAHzSnpK0UZXi9gtXWM1iFj9sveRfGdqjqqzoBLencjpU5JIX9bDrRTl1rQvenTwoUjS3wnX/s72-c/Veloci-rooster_800x600.jpg" height="72" width="72"/><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-5882751408917554948</guid><pubDate>Sat, 02 Jan 2016 00:39:00 +0000</pubDate><atom:updated>2016-09-24T14:09:18.316-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">2016</category><category domain="http://www.blogger.com/atom/ns#">New Year</category><category domain="http://www.blogger.com/atom/ns#">resolutions</category><title>New Thoughts for a New Year</title><description>&lt;p&gt;
The New Year has arrived like a big, blank, sparkling clean whiteboard, ready to be defaced and discolored by malodorous streaks of rainbow color. You know some idiot is going to use a goddamn permanent marker again, after you spent all that time cleaning it off last time. &quot;Sharpie&quot; looks nothing like &quot;Expo&quot; — learn to read, assholes!&lt;br /&gt;
&lt;/p&gt;

&lt;p&gt;
What I mean to say is, today is a natural time for both reflection and resolution.
&lt;/p&gt;


&lt;p&gt;
Unfortunately, even with considerable reflection, I have no recollection of making any resolutions a year ago. I either completely neglected to make any resolutions at all, or I failed so spectacularly at resolving myself that I have willfully forgotten any ever existed. In either case, I am not making any resolutions this year.
&lt;/p&gt;

&lt;p&gt;
What I &lt;i&gt;will&lt;/i&gt; be doing, is writing this post.
&lt;/p&gt;

&lt;p&gt;
Look at that. I already finished it! 2016 is off to a great start.
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2016/01/new-thoughts-for-new-year.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-8247312772512946484</guid><pubDate>Sat, 22 Aug 2015 19:09:00 +0000</pubDate><atom:updated>2021-08-08T08:50:45.920-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">Android</category><category domain="http://www.blogger.com/atom/ns#">app</category><category domain="http://www.blogger.com/atom/ns#">Fiftten Puzzle</category><category domain="http://www.blogger.com/atom/ns#">iOS</category><category domain="http://www.blogger.com/atom/ns#">magic square</category><category domain="http://www.blogger.com/atom/ns#">puzzle game</category><category domain="http://www.blogger.com/atom/ns#">smooth</category><title>Fifteen Puzzle Game</title><description>&lt;p&gt;My friend and I made our first app — a puzzle game for iOS and Android:&lt;/p&gt;

&lt;p&gt;&lt;img border=&quot;0&quot; width=&quot;256px&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEivJQadhOAvc1eH0mBZ5fXXpAoeDIXSigN5zVPZ1RgyNxlcGaGbV-rDj5Oq7Y0765aa6tM5wfx3ot9A2Fi9bM_4uwgL-yJYS4FzB94CPPoxzSQdZBFsM2vVD-7tjOH7frk_hw8t1A2s8tJU/s1600/app_icon_android_512x512.png&quot; /&gt;&lt;/p&gt;

&lt;p&gt;
&lt;b&gt;Download Fifteen for iOS:&lt;/b&gt;&lt;/br&gt;
&lt;a href=&quot;https://itunes.apple.com/us/app/fifteen-puzzle-game/id974511729?mt=8&quot;&gt;https://itunes.apple.com/us/app/fifteen-puzzle-game/id974511729?mt=8&lt;/a&gt;
&lt;/p&gt; 

&lt;p&gt;
&lt;b&gt;Download Fifteen for Android:&lt;/b&gt;&lt;/br&gt; 
&lt;a href=&quot;https://play.google.com/store/apps/details?id=com.RobertBurton.Fifteen&amp;hl=en&quot;&gt;https://play.google.com/store/apps/details?id=com.RobertBurton.Fifteen&amp;hl=en&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;
Stay tuned for more games at &lt;a href=&quot;http://apartment-five.com/&quot;&gt;apartment-five.com&lt;/a&gt;, and maybe some more posts on this ghost town of a blog!
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2015/08/fifteen-puzzle-game.html</link><author>noreply@blogger.com (Bored and Insane)</author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEivJQadhOAvc1eH0mBZ5fXXpAoeDIXSigN5zVPZ1RgyNxlcGaGbV-rDj5Oq7Y0765aa6tM5wfx3ot9A2Fi9bM_4uwgL-yJYS4FzB94CPPoxzSQdZBFsM2vVD-7tjOH7frk_hw8t1A2s8tJU/s72-c/app_icon_android_512x512.png" height="72" width="72"/><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-7545519165031884523</guid><pubDate>Sat, 31 Jan 2015 07:55:00 +0000</pubDate><atom:updated>2015-01-31T00:01:40.578-08:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">garageband</category><category domain="http://www.blogger.com/atom/ns#">music</category><category domain="http://www.blogger.com/atom/ns#">soundcloud</category><title>Music Time, Part II</title><description>&lt;p&gt;Well, it looks like I went an entire year without blogging any posts (or would it be &#39;posting any blogs&#39;?). I guess I didn&#39;t have anything remotely interesting to write or share for over 365 days.&lt;/p&gt;

&lt;p&gt;
Here&#39;s some more musical malarkey I made during my year away from boredom and insanity:&lt;/p&gt;

&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/128961122&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;hide_related=false&amp;amp;show_comments=true&amp;amp;show_user=true&amp;amp;show_reposts=false&quot;&gt;&lt;/iframe&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/133775491&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;hide_related=false&amp;amp;show_comments=true&amp;amp;show_user=true&amp;amp;show_reposts=false&quot;&gt;&lt;/iframe&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/137569607&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;hide_related=false&amp;amp;show_comments=true&amp;amp;show_user=true&amp;amp;show_reposts=false&quot;&gt;&lt;/iframe&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/166513762&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;hide_related=false&amp;amp;show_comments=true&amp;amp;show_user=true&amp;amp;show_reposts=false&quot;&gt;&lt;/iframe&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/173970067&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;hide_related=false&amp;amp;show_comments=true&amp;amp;show_user=true&amp;amp;show_reposts=false&quot;&gt;&lt;/iframe&gt;
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2015/01/music-time-part-ii.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-4343915244623738971</guid><pubDate>Sun, 22 Dec 2013 03:57:00 +0000</pubDate><atom:updated>2013-12-21T20:01:49.804-08:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">garageband</category><category domain="http://www.blogger.com/atom/ns#">music</category><category domain="http://www.blogger.com/atom/ns#">soundcloud</category><title>Music Time</title><description>&lt;p&gt;Now that I&#39;m a full-time designer, I spend much less of my free time doing anything design-related. In fact, I tend to squander the majority of my free time watching South Park and mindlessly browsing Reddit.&lt;/p&gt;

&lt;p&gt;Lately, I&#39;ve managed to stay somewhat productive with audio experimentation— despite having a very tentative understanding of music theory:&lt;/p&gt;

&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/124744560&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;show_artwork=true&quot;&gt;&lt;/iframe&gt;
&lt;/p&gt;
&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/125929338&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;show_artwork=true&quot;&gt;&lt;/iframe&gt;&lt;/p&gt;
&lt;br&gt;
&lt;p&gt;
Here&#39;s a track from a couple years ago. My musically-talented friend once said he liked it, which was really all the encouragement I needed:&lt;/p&gt;

&lt;p&gt;
&lt;iframe width=&quot;100%&quot; height=&quot;166&quot; scrolling=&quot;no&quot; frameborder=&quot;no&quot; src=&quot;https://w.soundcloud.com/player/?url=https%3A//api.soundcloud.com/tracks/123782128&amp;amp;color=0070b0&amp;amp;auto_play=false&amp;amp;show_artwork=true&quot;&gt;&lt;/iframe&gt;&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2013/12/music-time.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-5485995614749252405</guid><pubDate>Sat, 05 Oct 2013 05:59:00 +0000</pubDate><atom:updated>2017-07-12T23:02:24.992-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">convergence</category><category domain="http://www.blogger.com/atom/ns#">Palahniuk</category><title>Combined Effort</title><description>&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/Palahniuk_convergence.png&quot; width=&quot;500px&quot; style=&quot;border:1px #ccc solid;&quot; alt=&quot;I am the combined effort of everybody I&#39;ve ever known.&quot;/&gt;</description><link>http://boredandinsane.blogspot.com/2013/10/combined-effort.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-2451665657256003012</guid><pubDate>Tue, 24 Sep 2013 05:15:00 +0000</pubDate><atom:updated>2013-10-27T09:32:47.933-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">honey badger</category><category domain="http://www.blogger.com/atom/ns#">infographic</category><category domain="http://www.blogger.com/atom/ns#">keystone light</category><category domain="http://www.blogger.com/atom/ns#">lame ideas</category><category domain="http://www.blogger.com/atom/ns#">quitting</category><category domain="http://www.blogger.com/atom/ns#">winnie the pooh</category><title>Honey the Badger</title><description>&lt;p&gt;
After publishing my &lt;a href=&quot;http://www.cracked.com/article_19437_how-stress-killing-you-5Bchart5D.html&quot;&gt;stress infographic&lt;/a&gt; in 2011, I began researching and sketching for TWO brand new infographic ideas.
&lt;/p&gt;

&lt;p&gt;
Since it has become increasingly clear that I will never complete either of those infographics, I would like to share some small pieces of what I have created in sporadic fits of inspiration over the past two years.
&lt;/p&gt;

&lt;p&gt;
Enjoy these meager offerings— they are a sad, but necessary farewell to abandoned ideas:
&lt;/p&gt;

&lt;p&gt;
&lt;img border=&quot;0&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiFYK9Vf2zLDwUkmlxEdPj5sBcNDH4tXNqcSsnIgjuuz4jtxApNc2fQwLEyYXOToYJUy3FEsdbRuKT6Ek4LBM_-BuYOjRu8KWMVe2QXpvz4RAI4mny97nke2elJ0XLP9Vig0BhyphenhyphenNFDH46lW/s1600/honey-badger_badass-name-chart.jpg&quot; alt=&quot;honey badger infographic name chart&quot;/&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;img border=&quot;0&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh0AtpVp9p8dCCMsDKfI4pyUqyICpcaWSqChzb6G_h6QjwdSIe9rB_7rwQu6jqzpHCjll2eNjJCCRxiOXErGH8GR2kG-9mFfD0_H2zzxx0Eupugg-jZttFmDYltOjeaQUdHsHiu2si-35zp/s1600/honey-the-badger.png&quot; alt=&quot;honey badger winnie the pooh&quot; title=&quot;Oh bother...&quot;/&gt;
&lt;/p&gt;

&lt;img border=&quot;0&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhrARW2JCg1thpwDmneClzvsWIzbVtOUdbRLFLUDVLVgYboMddOQVEzQMPwDg15WWljr6NVRbfBX2vScm2FxMhOQBH8CU3JX35J-mLhmoAfS7dw_t7lgJz3J51d5d-rZqhgTH0UkWzgkciY/s1600/douche_title_excerpt.png&quot; /&gt;

&lt;p&gt;
&lt;img border=&quot;0&quot; src=&quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjruhOYeo30mcWphKIYMjo5CplsqXX0pW1MqghR5Dy_x3u3fkP3DwYeDC_paPqUe4_KTdx6ukwmh6qpqUxaUvE5BRLMgYjJ_elzI2xNNFxmsjVr3BuiRVUE05Gwn9JAvH7JBWcNwdpCQ8VI/s1600/douche_excerpt.png&quot; alt=&quot;douche&quot; /&gt;
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2013/09/honey-badger.html</link><author>noreply@blogger.com (Bored and Insane)</author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiFYK9Vf2zLDwUkmlxEdPj5sBcNDH4tXNqcSsnIgjuuz4jtxApNc2fQwLEyYXOToYJUy3FEsdbRuKT6Ek4LBM_-BuYOjRu8KWMVe2QXpvz4RAI4mny97nke2elJ0XLP9Vig0BhyphenhyphenNFDH46lW/s72-c/honey-badger_badass-name-chart.jpg" height="72" width="72"/><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-4882423989486886455</guid><pubDate>Sun, 30 Sep 2012 00:41:00 +0000</pubDate><atom:updated>2016-01-02T15:34:37.239-08:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">modern art</category><category domain="http://www.blogger.com/atom/ns#">music</category><category domain="http://www.blogger.com/atom/ns#">picasso</category><title>An Ode to Modern Art</title><description>&lt;p&gt;I made a video.&lt;/p&gt;

&lt;iframe width=&quot;560&quot; height=&quot;315&quot; src=&quot;http://www.youtube.com/embed/kxGuZ4kTf7A&quot; frameborder=&quot;0&quot; allowfullscreen&gt;&lt;/iframe&gt;

&lt;p&gt;I don&#39;t even know why.&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2012/09/an-ode-to-modern-art.html</link><author>noreply@blogger.com (Bored and Insane)</author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="https://img.youtube.com/vi/kxGuZ4kTf7A/default.jpg" height="72" width="72"/><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-7229297748791086537</guid><pubDate>Thu, 26 Jul 2012 21:22:00 +0000</pubDate><atom:updated>2017-07-12T21:25:49.646-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">art</category><category domain="http://www.blogger.com/atom/ns#">batman</category><category domain="http://www.blogger.com/atom/ns#">caped crusader</category><category domain="http://www.blogger.com/atom/ns#">dark knight</category><category domain="http://www.blogger.com/atom/ns#">dark knight rises</category><category domain="http://www.blogger.com/atom/ns#">doodle</category><category domain="http://www.blogger.com/atom/ns#">quick sketch</category><category domain="http://www.blogger.com/atom/ns#">sketch</category><title>Rise.</title><description>&lt;p&gt;I saw &lt;em&gt;The Dark Knight Rises&lt;/em&gt; last weekend— a fantastic end to a superb trilogy!&lt;/p&gt;

&lt;p&gt;
&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/ScannedImage.jpg&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[batman!]&quot;&gt;
&lt;img alt=&quot;If you make yourself more than just a man...&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/ScannedImage-1.jpg&quot;/&gt;
&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;
Major props to &lt;a href=&quot;https://www.facebook.com/hanszimmer&quot;&gt;Hans Zimmer&lt;/a&gt;, who has very decisively become my favorite movie composer in the last few years (He also worked on &lt;em&gt;Inception&lt;/em&gt; and &lt;em&gt;Pirates of the Caribbean&lt;/em&gt;).
&lt;/p&gt;

&lt;p&gt;
Best track from the score: &lt;a href=&quot;http://youtu.be/EgQYveThqwI&quot;&gt;&lt;em&gt;Rise&lt;/em&gt;&lt;/a&gt;.
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2012/07/rise.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-8018268611395672909</guid><pubDate>Sat, 30 Jun 2012 03:09:00 +0000</pubDate><atom:updated>2017-07-12T20:36:21.918-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">ambidexterity</category><category domain="http://www.blogger.com/atom/ns#">ambidextrous</category><category domain="http://www.blogger.com/atom/ns#">artist</category><category domain="http://www.blogger.com/atom/ns#">bucky katt</category><category domain="http://www.blogger.com/atom/ns#">comic strip</category><category domain="http://www.blogger.com/atom/ns#">drawing</category><category domain="http://www.blogger.com/atom/ns#">get fuzzy</category><category domain="http://www.blogger.com/atom/ns#">non-dominant</category><category domain="http://www.blogger.com/atom/ns#">pearls before swine</category><category domain="http://www.blogger.com/atom/ns#">pig</category><category domain="http://www.blogger.com/atom/ns#">rat</category><category domain="http://www.blogger.com/atom/ns#">satchel pootch</category><category domain="http://www.blogger.com/atom/ns#">stephan pastis</category><title>Ambidexterity in Progress</title><description>&lt;p&gt;For those of you who don&#39;t know, I have been training my non-dominant (left) hand for quite some time, in the hope that I will one day be ambidextrous. It has been an interesting journey.&lt;/p&gt;

&lt;p&gt;&lt;center&gt;&lt;img alt=&quot;Get Fuzzy lefty doodle.&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/get-fuzzy_doodle.jpg&quot;/&gt;
&lt;div class=&quot;caption&quot;&gt;Bucky and Satchel have been less than supportive.&lt;/div&gt;
&lt;/center&gt;
&lt;/p&gt;

&lt;p&gt;Also, if you don&#39;t know what Get Fuzzy is, &lt;a href=&quot;http://www.gocomics.com/getfuzzy/&quot;&gt;GO READ IT, NOW&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;
&lt;strong&gt;Update 6/30/2012&lt;/strong&gt; &lt;br&gt;
I got a request for some Pearls Before Swine:
&lt;/p&gt;

&lt;p&gt;
&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/pearls-before-swine_doodle3.jpg&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[swine]&quot;&gt;&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/pearls-before-swine_doodle3.jpg&quot; width=&quot;600&quot;/&gt;&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;You should be reading &lt;a href=&quot;http://www.gocomics.com/pearlsbeforeswine/&quot;&gt;this strip&lt;/a&gt;, as well.&lt;/p&gt;

&lt;p&gt;(And speaking of left-handed drawing, this is a &lt;a href=&quot;http://www.amazon.com/Because-Sometimes-Just-Gotta-Cover/dp/1449410235&quot;&gt;peculiar coincidence&lt;/a&gt;)&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2012/06/ambidexterity-in-progress.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-751912824745664341</guid><pubDate>Sat, 05 May 2012 06:50:00 +0000</pubDate><atom:updated>2017-07-12T22:00:48.257-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">dribbble bored and insane eye of the hawk mendocino brewing company select ale redesign</category><title>I Still Haven&#39;t Been Invited to Dribbble.</title><description>&lt;p&gt;While I have been patiently waiting for some awesome person (yes, YOU!) to invite me to &lt;a href=&quot;http://dribbble.com/johnlarwood&quot;&gt;Dribbble&lt;/a&gt;, I have been pondering alternative methods to display my design work on the internet. Only today did I realize that I can just pretend my blog &lt;em&gt;is&lt;/em&gt; Dribbble.

&lt;p&gt;
So, here is a shot of my latest school project— &lt;a href=&quot;http://www.behance.net/gallery/Eye-of-the-Hawk-redesign/3902985&quot;&gt;a redesign of Eye of the Hawk Select Ale:&lt;/a&gt;&lt;/p&gt;

&lt;center&gt;&lt;p&gt;&lt;a href=&quot;http://www.behance.net/gallery/Eye-of-the-Hawk-redesign/3902985&quot;&gt;&lt;img height=&quot;420&quot; width=&quot;420&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/eye_of_the_hawk_shot.jpg&quot; /&gt;&lt;/a&gt;&lt;/p&gt;&lt;/center&gt;</description><link>http://boredandinsane.blogspot.com/2012/05/i-still-havent-been-invited-to-dribbble.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-2758601081471963955</guid><pubDate>Tue, 10 Apr 2012 05:36:00 +0000</pubDate><atom:updated>2017-07-12T21:32:55.629-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">ambrose bierce</category><category domain="http://www.blogger.com/atom/ns#">an occurrence at owl creek bridge</category><category domain="http://www.blogger.com/atom/ns#">book design</category><title>An Occurrence At Owl Creek Bridge book design</title><description>&lt;p&gt;
I designed, printed, and hand-bound another book!
&lt;/p&gt;

&lt;p&gt;
&lt;em&gt;An Occurrence At Owl Creek Bridge&lt;/em&gt; is a short story set during the Civil War:
&lt;/p&gt;


&lt;center&gt;

&lt;p&gt;&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/artwork/owlcreek-1_WEB.jpg&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[owlcreek]&quot;&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/artwork/owlcreek-1_WEB.jpg&quot; alt=&quot;An Occurrence At Owl Creek Bridge&quot; border=&quot;0&quot; /&gt;&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/artwork/owlcreek-2_WEB.jpg&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[owlcreek]&quot;&gt;
&lt;img class=&quot;border half&quot; style=&quot;margin: 0.5em;&quot;  src=&quot;http://johnlarwood.com/images/boredandinsane/artwork/owlcreek-2_WEB-thumb.jpg&quot; alt=&quot;&quot; border=&quot;0&quot; /&gt;&lt;/a&gt;

&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/artwork/owlcreek-3_WEB.jpg&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[owlcreek]&quot;&gt;
&lt;img class=&quot;border half&quot; style=&quot;margin: 0.5em;&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/artwork/owlcreek-3_WEB-thumb.jpg&quot; alt=&quot;&quot; border=&quot;0&quot; /&gt;&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/artwork/OwlCreekBridge_cover_WEB.jpg&quot; imageanchor=&quot;1&quot; rel=&quot;lightbox[owlcreek]&quot;&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/artwork/OwlCreekBridge_cover_WEB.jpg&quot; alt=&quot;&quot; border=&quot;0&quot; /&gt;&lt;/a&gt;
&lt;/p&gt;

&lt;/center&gt;

&lt;p&gt;
Special thanks to &lt;a href=&quot;http://schoneberger365.blogspot.com/&quot;&gt;Brian Schoneberger&lt;/a&gt; for the photography.
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2012/04/occurrence-at-owl-creek-bridge.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-1831053209839176182</guid><pubDate>Sat, 25 Feb 2012 19:45:00 +0000</pubDate><atom:updated>2017-07-12T20:30:53.970-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">apple</category><category domain="http://www.blogger.com/atom/ns#">boredom</category><category domain="http://www.blogger.com/atom/ns#">follow the boredom</category><category domain="http://www.blogger.com/atom/ns#">iphone</category><category domain="http://www.blogger.com/atom/ns#">mobile site</category><category domain="http://www.blogger.com/atom/ns#">spread the insanity</category><category domain="http://www.blogger.com/atom/ns#">webclip icon</category><title>Bored and Insane mobile is here!</title><description>&lt;img style=&quot;display:none;&quot; height=&quot;1&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/boredandinsane_mobile_THUMB.jpg&quot; /&gt;

&lt;p&gt;The Bored and Insane mobile site has officially launched! Bookmark the blog on your iphone homescreen and feast your eyes on the new webclip icon!&lt;/p&gt;

&lt;p&gt;Grab your nearest mobile device and check it out:&lt;/p&gt;

&lt;p&gt;
&lt;img alt=&quot;Bored and Insane mobile site— Boredom has never been so amazingly convenient&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/boredandinsanemobile.jpg&quot; /&gt;&lt;br&gt;
&lt;img alt=&quot;Bored and Insane mobile site— Spread the insanity!&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/boredandinsanemobile2.jpg&quot; /&gt;
&lt;/p&gt;

&lt;p&gt;
Oh, and let me know if anything is broken. I created and edited quite a bit of CSS code to get this to work— both for the mobile site and the full site— so there is a good chance that something went horribly wrong somewhere.
&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2012/02/bored-and-insane-mobile-is-here.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-6833935495609369818</guid><pubDate>Fri, 03 Feb 2012 19:10:00 +0000</pubDate><atom:updated>2012-07-26T14:42:44.023-07:00</atom:updated><title>Disqus Commenting Might Be Down For A Bit</title><description>&lt;p&gt;
I&#39;ve been having difficulties with Disqus syncing for awhile, and I&#39;ll be doing some major troubleshooting in the next couple days. So if you&#39;re leaving an extended critique of my work and the comment system starts acting inexplicably retarded, it&#39;s probably because I&#39;ve fucked up the code really, really badly. 
&lt;/p&gt;
&lt;p&gt;
Come back in a few days, and you should have no trouble posting disparaging insults all over my blog posts.
&lt;/p&gt;

&lt;p&gt;
&lt;strong&gt;Update May 2012:&lt;/strong&gt;&lt;br&gt;
I completed scrapped Disqus and just customized Blogger&#39;s native comment system. Now I don&#39;t have to worry about syncing at all!

&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2012/02/disqus-commenting-might-be-down-for-bit.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>2</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-7978621286137531656</guid><pubDate>Tue, 31 Jan 2012 00:05:00 +0000</pubDate><atom:updated>2017-07-12T20:32:22.929-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">apartment</category><category domain="http://www.blogger.com/atom/ns#">cleaning</category><category domain="http://www.blogger.com/atom/ns#">douche</category><category domain="http://www.blogger.com/atom/ns#">douching it up</category><category domain="http://www.blogger.com/atom/ns#">notes</category><category domain="http://www.blogger.com/atom/ns#">passive aggressive</category><category domain="http://www.blogger.com/atom/ns#">roommate</category><title>Douching It Up Part 2: Cleaning With Anger</title><description>&lt;p&gt;So, remember how I was leaving passive-aggressive notes around my apartment in an ongoing effort to &lt;a href=&quot;http://boredandinsane.blogspot.com/2011/10/douching-it-up-how-i-keep-my-apartment.html&quot;&gt;promote cleanliness?&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;It turns out I might have a protegé:&lt;/p&gt;

&lt;center&gt;
&lt;p&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/apartment_douchery.jpg&quot; title=&quot;A little sparse with the passive; A bit much with the aggressive.&quot; alt=&quot;A little sparse with the passive; A bit much with the aggressive.&quot;&gt;
&lt;/p&gt;
&lt;/center&gt;

He&#39;s got the aggressive side down— we&#39;ll just have to work a little more on the passive.</description><link>http://boredandinsane.blogspot.com/2012/01/douching-it-up-part-2-cleaning-with.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-5048166206534921912</guid><pubDate>Sat, 21 Jan 2012 01:58:00 +0000</pubDate><atom:updated>2017-07-12T20:34:17.577-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">1600x1200</category><category domain="http://www.blogger.com/atom/ns#">background</category><category domain="http://www.blogger.com/atom/ns#">bored and insane</category><category domain="http://www.blogger.com/atom/ns#">cracked</category><category domain="http://www.blogger.com/atom/ns#">cracked.com</category><category domain="http://www.blogger.com/atom/ns#">desktop</category><category domain="http://www.blogger.com/atom/ns#">illustrator</category><category domain="http://www.blogger.com/atom/ns#">infographic</category><category domain="http://www.blogger.com/atom/ns#">john larwood</category><category domain="http://www.blogger.com/atom/ns#">vector</category><category domain="http://www.blogger.com/atom/ns#">wallpaper</category><title>Spread the Insanity with Desktop Wallpapers</title><description>&lt;img style=&quot;display:none;&quot; height=&quot;1&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/Peppers_wallpaper-01_THUMB.jpg&quot; /&gt;

&lt;div class=&quot;hidden&quot;&gt;&lt;h1&gt;Bored and Insane Desktop Backgrounds.&lt;/h1&gt;Adorn your computers with boredom and insanity.&lt;/div&gt;
&lt;p&gt;
Hey guys, I made some desktop backgrounds based off my &lt;a href=&quot;http://www.cracked.com&quot;&gt;Cracked&lt;/a&gt; infographics. 
&lt;/p&gt;

&lt;p&gt;
Put them on your computers. Put them on your friends computers. Print them out and glue them to the walls of your lavishly decorated mansions:
&lt;/p&gt;

&lt;center&gt;
&lt;p&gt;
&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/Peppers_wallpaper-02.jpg&quot; &gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/Peppers_wallpaper-02_THUMB.jpg&quot; alt=&#39;old school pepper science desktop background&#39;&gt;&lt;br&gt;
(click to view full size)&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/killerwhale_wallpaper-01.jpg&quot; &gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/killerwhale_wallpaper-01_THUMB.jpg&quot; alt=&#39;badass killer whale desktop background&#39;&gt;&lt;br&gt;
(click to view full size)&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/Peppers_wallpaper-01.jpg&quot;&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/Peppers_wallpaper-01_THUMB.jpg&quot; alt=&#39;fiery seed dispersal desktop background&#39;&gt;&lt;br&gt;
(click to view full size)&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/killerwhale_wallpaper-02.jpg&quot;&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/killerwhale_wallpaper-02_THUMB.jpg&quot; alt=&#39;badass killer whale desktop background&#39;&gt;&lt;br&gt;
(click to view full size)&lt;/a&gt;
&lt;/p&gt;
&lt;/center&gt;

&lt;p&gt;At the very least, print them out and use them as toilet paper.&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2012/01/spread-insanity-with-desktop-wallpapers.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-8491306660825068572</guid><pubDate>Thu, 22 Dec 2011 20:00:00 +0000</pubDate><atom:updated>2017-07-23T07:32:26.656-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">animated gif</category><category domain="http://www.blogger.com/atom/ns#">animation</category><category domain="http://www.blogger.com/atom/ns#">dumb running sonic</category><title>Dumb Running Sonic</title><description>&lt;img style=&quot;display:none;&quot; height=&quot;1&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/dumb_running_sonic.jpg&quot; /&gt;

&lt;div class=&quot;hidden&quot;&gt;&lt;h1&gt;Dumb Running Sonic.&lt;/h1&gt; I made an animated gif of Sonic running like an idiot.&lt;/div&gt;

&lt;p&gt;Just in case you haven&#39;t heard, there is this blog called &lt;a href=&quot;http://dumbrunningsonic.tumblr.com/&quot; target=&quot;blank&quot;&gt;Dumb Running Sonic&lt;/a&gt;, which is solely devoted to animated gifs of Sonic running like an idiot.&lt;/p&gt;

&lt;p&gt;Here is my contribution:&lt;/p&gt;

&lt;center&gt;
&lt;img class=&quot;reduced-width&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/dumb_running_sonicgif.gif&quot; /&gt;
&lt;br /&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/dumb_running_sonic-1.jpg&quot; style=&quot;height: 10px; visibility: hidden;&quot; /&gt;
&lt;/center&gt;</description><link>http://boredandinsane.blogspot.com/2011/10/dumb-running-sonic.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-6101779338074774745</guid><pubDate>Mon, 10 Oct 2011 00:22:00 +0000</pubDate><atom:updated>2017-07-12T21:54:02.007-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">apartment</category><category domain="http://www.blogger.com/atom/ns#">douche</category><category domain="http://www.blogger.com/atom/ns#">roommate</category><title>Douching It Up: How I Keep My Apartment Clean</title><description>&lt;p&gt;
Have you ever heard the saying &quot;cleanliness is next to godliness?&quot;&lt;/p&gt;
&lt;p&gt;
I like this saying because I happen to ascribe a lot of value to keeping things nice and tidy. Unfortunately, my two roommates are not as inclined toward cleanliness as I am, and I find myself occasionally miffed by their failure to perform basic tasks like &lt;a href=&quot;http://boredandinsane.blogspot.com/2011/05/organization.html&quot; target=&quot;blank&quot;&gt;cleaning dishes&lt;/a&gt; or &lt;a href=&quot;http://johnlarwood.com/images/boredandinsane/are_you_going_to_empty_that.jpg&quot; rel=&quot;lightbox[blah]&quot;&gt;throwing out their trash.&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;
Naturally, I have found that the most effective remedy for this issue is to leave a large quantity of douchey, passive-aggressive notes all over the apartment:&lt;/p&gt;
&lt;center&gt;
&lt;img border=&quot;0&quot; width=&quot;443&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/living4.jpg&quot; alt=&quot;An optimist would say this glass is half full. I say someone needs to clean up their shit.&quot;/&gt;&lt;/center&gt;

&lt;center&gt;
&lt;img border=&quot;0&quot; width=&quot;550&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/living2.jpg&quot; alt=&quot;I am a bagel. Eat me or throw me away!&quot;/&gt;&lt;/center&gt;

&lt;center&gt;
&lt;img border=&quot;0&quot; width=&quot;413&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/living3.jpg&quot; alt=&quot;Dried pasta is only good for arts and crafts.&quot;/&gt;&lt;/center&gt;

&lt;center&gt;
&lt;img border=&quot;0&quot; width=&quot;550&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/living1.jpg&quot; alt=&quot;Place trash here:&quot;/&gt;&lt;/center&gt;

&lt;center&gt;
&lt;p&gt;
&lt;img border=&quot;0&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/living_continued2.jpg&quot; alt=&quot;Given enough time, evaporation will finish your drinks for you...but it sure as hell won&#39;t wash your dishes.&quot; /&gt;
&lt;/p&gt;
&lt;/center&gt;
&lt;p&gt;
&lt;/p&gt;
I would like to thank Shakespeare for this last one:
&lt;p&gt;
&lt;center&gt;
&lt;img width=&quot;550&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/living5-1.jpg&quot; /&gt;&lt;br&gt;
&lt;span class=&quot;caption&quot;&gt;(I am deeply sorry for breaking iambic pentameter.)&lt;/span&gt;&lt;/center&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;strong&gt;2012 UPDATE:&lt;/strong&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;center&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/living6.jpg&quot; alt=&quot;Looks clean to me!&quot; /&gt;
&lt;/center&gt;
&lt;/p&gt;

&lt;br&gt;

&lt;p&gt;
My roommate left this chicken breast in our fridge for about a month:
&lt;/p&gt;

&lt;center&gt;
&lt;p&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/Free_chicken.jpg&quot; alt=&quot;Rotting chicken in the fridge!&quot; /&gt;
&lt;/p&gt;

&lt;p&gt;
&lt;img src=&quot;http://johnlarwood.com/images/boredandinsane/living_bowls.jpg&quot; alt=&quot;Do your dishes, I want to eat my cereal.&quot; /&gt;
&lt;/p&gt;
&lt;/center&gt;</description><link>http://boredandinsane.blogspot.com/2011/10/douching-it-up-how-i-keep-my-apartment.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>6</thr:total></item><item><guid isPermaLink="false">tag:blogger.com,1999:blog-2441310466914017833.post-8527803084498668516</guid><pubDate>Wed, 14 Sep 2011 20:50:00 +0000</pubDate><atom:updated>2017-07-12T23:06:23.922-07:00</atom:updated><category domain="http://www.blogger.com/atom/ns#">animation</category><category domain="http://www.blogger.com/atom/ns#">art</category><category domain="http://www.blogger.com/atom/ns#">comic</category><category domain="http://www.blogger.com/atom/ns#">game</category><category domain="http://www.blogger.com/atom/ns#">sheep</category><category domain="http://www.blogger.com/atom/ns#">worms</category><title>Blast From the Past: Worms Comic</title><description>&lt;center&gt;&lt;img alt=&quot;Worms comic&quot; src=&quot;http://johnlarwood.com/images/boredandinsane/Worms-edit.jpg&quot; style=&quot;border: 2px #ccc solid;&quot; /&gt;&lt;/center&gt;
&lt;p&gt;I made this comic in 2007, back when I still used Flash MX for &lt;i&gt;everything&lt;/i&gt;. This was probably my last digital comic of any sort before I started making infographics.&lt;/p&gt;
&lt;p&gt;(Oh and if you&#39;re wondering why it says by &lt;i&gt;PearBoy&lt;/i&gt;, that most likely means you didn&#39;t know me during my &lt;a href=&quot;http://www.newgrounds.com/portal/view/307407&quot;&gt;animation&lt;/a&gt; days.)&lt;/p&gt;</description><link>http://boredandinsane.blogspot.com/2011/09/blast-from-past-worms-comic.html</link><author>noreply@blogger.com (Bored and Insane)</author><thr:total>0</thr:total></item></channel></rss>