.tspoll-sp-container {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	*display: inline;
	*zoom: 1;
	/* https://github.com/seballot/spectrum/issues/40 */
	z-index: 9999994;
	overflow: hidden;
}

.tspoll-sp-original-input-container {
	position: relative;
	display: inline-flex;
}

.tspoll-sp-original-input-container input {
	margin: 0 !important;
}

.tspoll-sp-original-input-container .tspoll-sp-add-on {
	width: 2.5rem;
	border-top-right-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
}

input.spectrum.with-add-on {
	/*padding-left: 2.8125rem;*/
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
	border-left: 0;
}

.tspoll-sp-original-input-container .tspoll-sp-add-on .tspoll-sp-colorize {
	height: 100%;
	width: 100%;
	border-radius: inherit;
}

.tspoll-sp-colorize-container {
	background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==');
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='%23ccc' fill-opacity='1'%3E%3Crect x='0' y='0' width='6' height='6' /%3E%3Crect x='6' y='6' width='6' height='6' /%3E%3C/svg%3E");
}

.tspoll-sp-container.tspoll-sp-flat {
	position: relative;
}

/* Fix for * { box-sizing: border-box; } */
.tspoll-sp-container,
.tspoll-sp-container * {
	-webkit-box-sizing: content-box;
	-moz-box-sizing: content-box;
	box-sizing: content-box;
}

/* http://ansciath.tumblr.com/post/7347495869/css-aspect-ratio */
.tspoll-sp-top {
	position: relative;
	width: 100%;
	display: inline-block;
}

.tspoll-sp-top-inner {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}

.tspoll-sp-color {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 1.25rem !important;
}

.tspoll-sp-hue {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: .75rem;
	height: 100%;
	left: initial !important;
}

.tspoll-sp-clear-enabled .tspoll-sp-hue {
	top: 15%;
	height: 85%;
}

.tspoll-sp-fill {
	padding-top: 80%;
}

.tspoll-sp-sat,
.tspoll-sp-val {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.tspoll-sp-alpha-enabled .tspoll-sp-top {
	margin-bottom: 1.75rem !important;
}

.tspoll-sp-alpha-enabled .tspoll-sp-alpha {
	display: block;
}

.tspoll-sp-alpha-handle {
	position: absolute;
	top: -0.1875rem;
	cursor: pointer;
	height: 1rem;
	border-radius: 50%;
	width: 1rem;
	margin-right: .3125rem;
	left: -0.125rem;
	right: 0;
	background: #f9f9f9;
	box-shadow: 0 0 .125rem 0rem #3a3a3a;
}

.tspoll-sp-alpha {
	display: none;
	position: absolute;
	bottom: -1.125rem;
	right: 0;
	left: 0;
	height: .625rem;
}

.tspoll-sp-alpha-inner {
	border-radius: .25rem;
}

.tspoll-sp-clear {
	display: none;
}

.tspoll-sp-clear.tspoll-sp-clear-display {
	background-position: center;
}

.tspoll-sp-clear-enabled .tspoll-sp-clear {
	display: block;
	position: absolute;
	top: .1875rem;
	right: 0;
	bottom: 0;
	cursor: pointer;
	left: initial;
	height: .875rem;
	width: .875rem;
}

/* Don't allow text selection */
.tspoll-sp-container,
.tspoll-sp-replacer,
.tspoll-sp-preview,
.tspoll-sp-dragger,
.tspoll-sp-slider,
.tspoll-sp-alpha,
.tspoll-sp-clear,
.tspoll-sp-alpha-handle,
.tspoll-sp-container.tspoll-sp-dragging .tspoll-sp-input,
.tspoll-sp-container button {
	-webkit-user-select: none;
	-moz-user-select: -moz-none;
	-o-user-select: none;
	user-select: none;
}

.tspoll-sp-container.tspoll-sp-input-disabled .tspoll-sp-input-container {
	display: none;
}

.tspoll-sp-container.tspoll-sp-buttons-disabled .tspoll-sp-button-container {
	display: none;
}

.tspoll-sp-container.tspoll-sp-palette-buttons-disabled .tspoll-sp-palette-button-container {
	display: none;
}

.tspoll-sp-palette-only .tspoll-sp-picker-container {
	display: none;
}

.tspoll-sp-palette-disabled .tspoll-sp-palette-container {
	display: none;
}

.tspoll-sp-initial-disabled .tspoll-sp-initial {
	display: none;
}

/* Gradients for hue, saturation and value instead of images.  Not pretty... but it works */
.tspoll-sp-sat {
	background-image: -webkit-gradient(linear, 0 0, 100% 0, from(#FFF), to(rgba(204, 154, 129, 0)));
	background-image: -webkit-linear-gradient(left, #FFF, rgba(204, 154, 129, 0));
	background-image: -moz-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
	background-image: -o-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
	background-image: -ms-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
	background-image: linear-gradient(to right, #fff, rgba(204, 154, 129, 0));
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)";
	filter: progid: DXImageTransform.Microsoft.gradient(GradientType=1, startColorstr='#FFFFFFFF', endColorstr='#00CC9A81');
}

.tspoll-sp-val {
	border-radius: .25rem;
	background-image: -webkit-gradient(linear, 0 100%, 0 0, from(#000000), to(rgba(204, 154, 129, 0)));
	background-image: -webkit-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0));
	background-image: -moz-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
	background-image: -o-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
	background-image: -ms-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
	background-image: linear-gradient(to top, #000, rgba(204, 154, 129, 0));
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)";
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81', endColorstr='#FF000000');
}

.tspoll-sp-hue {
	background: -moz-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
	background: -ms-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
	background: -o-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
	background: -webkit-gradient(linear, left top, left bottom, from(#ff0000), color-stop(0.17, #ffff00), color-stop(0.33, #00ff00), color-stop(0.5, #00ffff), color-stop(0.67, #0000ff), color-stop(0.83, #ff00ff), to(#ff0000));
	background: -webkit-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
	background: linear-gradient(to bottom, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
}

/* IE filters do not support multiple color stops.
   Generate 6 divs, line them up, and do two color gradients for each.
   Yes, really.
 */
.tspoll-sp-1 {
	height: 17%;
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ff0000', endColorstr='#ffff00');
}

.tspoll-sp-2 {
	height: 16%;
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ffff00', endColorstr='#00ff00');
}

.tspoll-sp-3 {
	height: 17%;
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#00ff00', endColorstr='#00ffff');
}

.tspoll-sp-4 {
	height: 17%;
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#00ffff', endColorstr='#0000ff');
}

.tspoll-sp-5 {
	height: 16%;
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#0000ff', endColorstr='#ff00ff');
}

.tspoll-sp-6 {
	height: 17%;
	filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff', endColorstr='#ff0000');
}

.tspoll-sp-hidden {
	display: none !important;
}

/* Clearfix hack */
.tspoll-sp-cf:before,
.tspoll-sp-cf:after {
	content: "";
	display: table;
}

.tspoll-sp-cf:after {
	clear: both;
}

.tspoll-sp-cf {
	*zoom: 1;
}

/* Mobile devices, make hue slider bigger so it is easier to slide */
@media (max-device-width: 30rem) {
	.tspoll-sp-color {
		right: 40%;
	}

	.tspoll-sp-hue {
		left: 63%;
	}

	.tspoll-sp-fill {
		padding-top: 60%;
	}
}

.tspoll-sp-dragger {
	border-radius: .3125rem;
	height: .625rem;
	width: .625rem;
	border: .0625rem solid #fff;
	cursor: pointer;
	position: absolute;
	top: 0;
	left: 0;
	margin-left: .1875rem;
	margin-top: .1875rem;
	box-shadow: 0 0 .125rem .0625rem rgba(0, 0, 0, .2);
}

.tspoll-sp-slider {
	position: absolute;
	top: 0;
	cursor: pointer;
	height: 1rem;
	border-radius: 50%;
	width: 1rem;
	left: -0.125rem;
	background: #f9f9f9;
	box-shadow: 0 0 .125rem 0rem #3a3a3a;
	margin-top: .5rem;
}

/*
Theme authors:
Here are the basic themeable display options (colors, fonts, global widths)
*/
.tspoll-sp-container {
	display: inline-flex;
	border-radius: 0;
	background-color: white;
	padding: 0;
	border-radius: .25rem;
	color: black;
	box-shadow: 0 0 0 .0625rem rgba(99, 114, 130, .16), 0 .5rem 1rem rgba(27, 39, 51, .08);
}

.tspoll-sp-container,
.tspoll-sp-container button,
.tspoll-sp-container input,
.tspoll-sp-color,
.tspoll-sp-hue,
.tspoll-sp-clear {
	font-size: .75rem;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

.tspoll-sp-top {
	margin-bottom: .625rem;
}

.tspoll-sp-color,
.tspoll-sp-hue,
.tspoll-sp-clear,
.tspoll-sp-val,
.tspoll-sp-sat {
	border-radius: .1875rem;
}

.tspoll-sp-input-container {
	margin-top: -0.3125rem;
}

.tspoll-sp-input-container.tspoll-sp-cf,
.tspoll-sp-initial.tspoll-sp-thumb.tspoll-sp-cf,
.tspoll-sp-button-container.tspoll-sp-cf {
	height: 1.5625rem;
}

.tspoll-sp-picker-container .tspoll-sp-cf {
	margin-bottom: .625rem;
}

.tspoll-sp-palette-row-initial>span:first-child {
	cursor: pointer;
}

/* Input */
.tspoll-sp-initial-disabled .tspoll-sp-input-container {
	width: 100%;
}

.tspoll-sp-input {
	padding: 0rem .3125rem !important;
	margin: 0;
	width: 100%;
	box-shadow: none !important;
	height: 100% !important;
	background: transparent;
	color: #3a3a3a;
	border-radius: .125rem !important;
	border: .0625rem solid #e0e0e0 !important;
	text-align: center;
	font-family: monospace;
	font-size: inherit !important;
}

.tspoll-sp-input:focus {
	border: .0625rem solid orange;
}

.tspoll-sp-input.tspoll-sp-validation-error {
	border: .0625rem solid red;
	background: #fdd;
}

.tspoll-sp-picker-container,
.tspoll-sp-palette-container {
	position: relative;
	padding: .625rem;
}

.tspoll-sp-picker-container {
	width: 12.5rem;
	padding-bottom: 0;
}

/* Palettes */
.tspoll-sp-palette-container {
	border-right: solid .0625rem #ccc;
}

.tspoll-sp-palette-only .tspoll-sp-palette-container {
	border: 0;
}

.tspoll-sp-palette .tspoll-sp-thumb-el {
	display: block;
	position: relative;
	float: left;
	width: 1.5rem;
	height: .9375rem;
	margin: .1875rem;
	cursor: pointer;
	border: solid .125rem transparent;
}

.tspoll-sp-palette .tspoll-sp-thumb-el:hover,
.tspoll-sp-palette .tspoll-sp-thumb-el.tspoll-sp-thumb-active {
	border-color: orange;
}

.tspoll-sp-thumb-el {
	position: relative;
}

/* Initial */
.tspoll-sp-initial {
	float: left;
}

.tspoll-sp-initial span {
	width: 1.875rem;
	height: 1.5625rem;
	border: none;
	display: block;
	float: left;
	margin: 0;
}

.tspoll-sp-initial .spe-thumb-el.tspoll-sp-thumb-active {
	border-radius: 0 .3125rem .3125rem 0;
}

.tspoll-sp-initial .spe-thumb-el {
	border-radius: .3125rem 0 0 .3125rem;
}

.tspoll-sp-initial .tspoll-sp-clear-display {
	background-position: center;
}

/* Buttons */
.tspoll-sp-button-container {
	float: right;
}

.tspoll-sp-palette-button-container {
	margin-top: .625rem;
}

/* Replacer (the little preview div that shows up instead of the <input>) */
.tspoll-sp-replacer {
	position: relative;
	overflow: hidden;
	cursor: pointer;
	display: inline-block;
	border-radius: .1875rem;
	border: .0625rem solid #aaa;
	color: #666;
	transition: border-color .3s;
	vertical-align: middle;
	width: 3rem;
	height: 1.5rem;
}

.tspoll-sp-replacer:hover,
.tspoll-sp-replacer.tspoll-sp-active {
	border: .0625rem solid #666;
	color: black;
}

.tspoll-sp-replacer.tspoll-sp-disabled {
	cursor: default;
	border-color: silver;
	color: silver;
}

.tspoll-sp-preview {
	position: relative;
	width: 100%;
	height: 100%;
	float: left;
	z-index: 0;
}

.tspoll-sp-preview-inner {
	transition: background-color .2s;
}

.tspoll-sp-preview-inner.tspoll-sp-clear-display {
	display: none;
}

/* Color Picker */
.tspoll-sp-palette .tspoll-sp-thumb-el {
	width: 1rem;
	height: 1rem;
	margin: .1875rem;
	border: none;
	border-radius: .1875rem;
}

/* Buttons: http://hellohappy.org/css3-buttons/ */
.tspoll-sp-container button {
	border-radius: .1875rem;
	border: none;
	background: transparent;
	line-height: 1;
	padding: 0 .5rem;
	height: 1.5625rem;
	text-transform: capitalize;
	text-align: center;
	vertical-align: middle;
	cursor: pointer;
	color: #606c72;
	font-weight: bold;
}

.tspoll-sp-container button.tspoll-sp-choose {
	background-color: #3cab3b;
	color: #fff;
	margin-left: .3125rem;
}

.tspoll-sp-container button:hover {
	opacity: .8;
}

.tspoll-sp-container button.tspoll-sp-palette-toggle {
	width: 100%;
	background-color: #f3f3f3;
	margin: 0;
}

.tspoll-sp-palette span:hover,
.tspoll-sp-palette span.tspoll-sp-thumb-active {
	border-color: #000;
}

.tspoll-sp-preview,
.tspoll-sp-alpha,
.tspoll-sp-thumb-el {
	position: relative;
	background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==');
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='%23ccc' fill-opacity='1'%3E%3Crect x='0' y='0' width='6' height='6' /%3E%3Crect x='6' y='6' width='6' height='6' /%3E%3C/svg%3E");
}

.tspoll-sp-preview-inner,
.tspoll-sp-alpha-inner,
.tspoll-sp-thumb-inner {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}

.tspoll-sp-palette .tspoll-sp-thumb-inner {
	border-radius: .1875rem;
	background-position: 50% 50%;
	background-repeat: no-repeat;
}

.tspoll-sp-palette .tspoll-sp-thumb-light.tspoll-sp-thumb-active .tspoll-sp-thumb-inner {
	background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIVJREFUeNpiYBhsgJFMffxAXABlN5JruT4Q3wfi/0DsT64h8UD8HmpIPCWG/KemIfOJCUB+Aoacx6EGBZyHBqI+WsDCwuQ9mhxeg2A210Ntfo8klk9sOMijaURm7yc1UP2RNCMbKE9ODK1HM6iegYLkfx8pligC9lCD7KmRof0ZhjQACDAAceovrtpVBRkAAAAASUVORK5CYII=');
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='18' height='18'%3E%3Cpath d='M9 16.172l10.594-10.594 1.406 1.406-12 12-5.578-5.578 1.406-1.406z' fill='%23000'%3E%3C/path%3E%3C/svg%3E");
}

.tspoll-sp-palette .tspoll-sp-thumb-dark.tspoll-sp-thumb-active .tspoll-sp-thumb-inner {
	background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAAadEVYdFNvZnR3YXJlAFBhaW50Lk5FVCB2My41LjEwMPRyoQAAAMdJREFUOE+tkgsNwzAMRMugEAahEAahEAZhEAqlEAZhEAohEAYh81X2dIm8fKpEspLGvudPOsUYpxE2BIJCroJmEW9qJ+MKaBFhEMNabSy9oIcIPwrB+afvAUFoK4H0tMaQ3XtlrggDhOVVMuT4E5MMG0FBbCEYzjYT7OxLEvIHQLY2zWwQ3D+9luyOQTfKDiFD3iUIfPk8VqrKjgAiSfGFPecrg6HN6m/iBcwiDAo7WiBeawa+Kwh7tZoSCGLMqwlSAzVDhoK+6vH4G0P5wdkAAAAASUVORK5CYII=');
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='18' height='18'%3E%3Cpath d='M9 16.172l10.594-10.594 1.406 1.406-12 12-5.578-5.578 1.406-1.406z' fill='%23fff'%3E%3C/path%3E%3C/svg%3E");
}

.tspoll-sp-clear-display {
	background-repeat: no-repeat;
	background-position: center;
	background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAOCAYAAAAfSC3RAAABe0lEQVQokYXSsUtcQRTF4d8Jj+VhHSxkEQuLsEUKK0nhTBFTmLSSUhBCMCAWsmgIwWrBLk0akfwLCaSQKBJmtrIIISwpRFKIhViETScphGMzysMtvOVwvpm5d0bGNCuGWAOPgYdl6S8wSDn9b+bUhDHEKWAdeAFMANg+l/TV9ofcz6cjMIbYBvaBMds7QCqZ58CmpBNgPuV0DvAAIMyFGugWtJr7eTv38xEwkPRPErY7QDeG2LqFkjrAgu0dSd/KDVqSNmxvAZ8lfbS9AHRuYemnLWkv5XRVBrQMbAI/gTXgEzAJtJuwBVS2L2OIle03QA/4Lmkl5XQBXEqqbFcAVYFDYChpFngiqWf7l6TXKaezMt2Zkhk24THwG+jZriX9AFZvUAyxLbRke2D75O5zPAO+ADXwEtizjaRHwDvbTyUtppwOmicCHAJvbXcl9YA1SQDjtseA97YPRz7ATcUQp2y/kjRdevsjaTfldNrMjcDGBjXA3T96L7yvrgFzP69+0Ao/HAAAAABJRU5ErkJggg==');
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='14' height='14'%3E%3Cpath d='M12 20.016q3.281 0 5.648-2.367t2.367-5.648q0-2.672-1.734-4.922l-11.203 11.203q2.25 1.734 4.922 1.734zM3.984 12q0 2.672 1.734 4.922l11.203-11.203q-2.25-1.734-4.922-1.734-3.281 0-5.648 2.367t-2.367 5.648zM12 2.016q4.125 0 7.055 2.93t2.93 7.055-2.93 7.055-7.055 2.93-7.055-2.93-2.93-7.055 2.93-7.055 7.055-2.93z' fill='%23000'%3E%3C/path%3E%3C/svg%3E");
}