/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
 * or any plugin's vendor/assets/stylesheets directory can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the bottom of the
 * compiled file so the styles you add here take precedence over styles defined in any other CSS/SCSS
 * files in this directory. Styles in this file should be added after the last require_* statement.
 * It is generally better to create a new file per style scope.
 *










 */



/* ------------------- main.css ------------------- */

* 
{
	margin: 0;
	box-sizing: border-box;
}

/************************** layout ***************************/
@font-face {
  font-family: 'Itim';
  src: url(/assets/Itim/Itim-Regular-655bf471efb792baa69f7111b18b9c66fc770c4acabc695153fd99bf4cee759a.ttf) format('truetype');
  font-weight: normal;
  font-style: normal;
}

html, body
{
	position: relative;
	height: 100%;
	font-family: Itim;
}

header
{
	/* height = 60px, depends on contained h1 line-height */
	z-index: 2;
	position: fixed;
	top: 0; left: 0; right: 0; 
	height: 60px;
	background-color: #cfc;
	color: #999;
	border-top: 1px solid #CEEFD0;
	border-bottom: 5px solid #999;
  display: flex;
	align-items: center;
}

header > *
{
	flex: 1;
}

header h1
{
	font-size: 2rem;
	line-height: 1.5;
	text-align: center;
}

header button.A2
{
  background-color: #a00;
}

header button.A3
{
  background-color: #099;
}

header button.A4
{
  background-color: #e70;
}

header div.left
{
  border: none;
  border-radius: 5px;
  color: white;
  font-size: 16px;
  margin-left: 30px;
  padding: 5px 15px;
	display: inline-block;
}

header #right_content
{
	display: flex; 
	justify-content: flex-end;
}

header *
{
	white-space: nowrap;
}    

header h3.right
{
	margin-right: 30px;
	padding-top: 3px;
}

header .left form button
{
	margin: 0 30px 0 0;
}

header button.right
{
	margin: 0 30px 0 0;
}

header a
{
	text-decoration: none;
}

header a h1
{
	color: #999;
}

main
{
	overflow-y: auto;
	position: fixed;
	top: 75px;
	left: 190px;
	right: 0;
  bottom: 45px;
  padding: 0 8px 8px 8px;
	opacity: 0;
}

footer
{
	z-index: 2;
	padding: 11px;
	padding: 11px 30px;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	text-align: center;
	background-color: #cfc;
	line-height: 1rem;
	border-top: 3px solid #ccc;
	display: flex;
}

footer > *
{
	flex: 1 1 0;
}

footer #video_links
{
	text-align: right;
}

footer span#watch2
{
	margin-left: 15px;
}

.flex_container
{
  display: flex;
	min-width: 750px;
	max-height: 100%;    /* don't let 'main' extend outside of it's container */
  justify-content: space-around;
}

/****************************** js related ******************************/
#js_disabled
{
	position: relative;
	top: 80px;
	padding-left: 190px;
	padding-right: 10px;
}

#js_disabled h1
{
	text-align: center;
}

span#preselect_key_id,
span#preselect_key_cut,
span#system_base_number,
span.parent_key_cut,
span.parent_key_label,
span.description,
span.individual_keys_used,
span.max_ind_keys,
span.available_sm_sizes,
span.children_total_size,
span.key_type
{
    display: none;
}

/****************************** Flash mesages ******************************/
div.flash
{
	display: flex;
	justify-content: space-between;

	position: fixed;
	top: 1px;
	height: 54px;
	line-height: 54px;
	width: 100%;
	padding-left: 30px;

	font-size: 1.5em;
	font-weight: bold;
	color: #fff;
}

div.alert,
div.error
{
	background-color: #d00;
}

div.notice,
div.confirm
{
	background-color: #008B8B;
}

a.button
{
	background-color: #008B8B;
}

#circle_x {
    width: 20px;
    height: 20px;
		padding: 9px 10px 10px 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid white;
    border-radius: 50%;
    font-size: 20px;
    cursor: pointer;
		margin: 5px 10px;
}

#pageInternational h1
{
	margin-top: 50px;
	color: red;
}

html:has(#pageHome)
{
	background-color: #ddeedd;
	background-color: #eeffee;
}

#hero_img
{
	position: relative;
	width: 90%;
	height: 90%;
	margin: 3% auto 0 auto;
}

#hero_img img#laptop
{
	display: block;
	width: 80%;
	margin: 30px auto 0;
	border-radius: 10px;
}

img#keyCalculusScreen
{
  position: absolute;
	top: 21.7%;
	left: 29.6%;
	width: 38.7%;
	height: 50%;
	border: 15px solid #222;
	border-radius: 10px;
}

#pageHome 
{
	min-width: 800px;
}

#pageHome #links
{
	width: 50%;
	margin: 30px auto 0 auto;
	display: flex;
	justify-content: space-around;
}

#pageHome #links a
{
	color: #555;
	text-decoration: none;
	font-size: 18px;
}

#pageHome #links a:hover
{
	text-decoration: underline;
}

#pageCreate, #pageEdit, #pageKeyCodes, #pagePinningCharts, #pageAccount, #pagePinningChartCalculator
{
	min-width: 900px;
}

.trademark {
	font-size: 0.8em; /* Adjust size as needed */
	vertical-align: super; /* Aligns the symbol properly */
}

/* ------------------- nav.css ------------------- */

nav
{
	padding-top: 70px;
	position: fixed;
  background-image: linear-gradient(#fcf, 50%, #fff);
	top: 0px;
	width: 180px;
	height: 100vh;
	overflow-y: auto;
	padding-bottom: 50px;
}

nav h4
{
	margin: 18px 0 5px 0;
	text-align: center;
}

nav ul
{
	font-size: 14px;
	list-style: none;
	padding: 0 0 0 10px;
}

nav li
{
	transition: background-color 1.0s;
}

nav li:hover
{
	background-color: #c7c;
	color: #fff;
}

nav a
{
	text-decoration: none;
	color: inherit;  /* inherits appropriate color whether highlighted or not */
	display: block;
	padding: 10px;
}

nav li.highlight
{
	background-color: #a0a;
	color: #fff;
}

nav div.disabled
{
	opacity: 0.4; /* Reduce opacity to make items appear dimmed */
	pointer-events: none; /* Disable pointer events to prevent clicks */
}
/* ------------------- key_list.css ------------------- */

#key_list
{
    border: 1px solid #ccc;
    overflow-y: scroll;
    padding: 10px;
		background-image: linear-gradient(#DFFFE9, 50%, #F7FDFC);
    min-width: 231px;
    margin-bottom: auto;
    max-height: 100%;
    cursor: default;
}

#key_list ul
{
    list-style: none;
    font-family: Monaco;
    font-size: 14px;
    padding: 0 10px 0 10px;
}

#key_list li
{
    padding: 1px 0 0 2px;
    line-height: 1.1;
    border: 2px solid transparent;
}

#key_list_wrapper
{
	padding-bottom: 1.2em;  /* enlarge the div a little by adding some padding to accomodate the <h4> */
}

#key_list li.master_key:hover
{
    border: 2px solid #999;
    background-color: #999;
		color: #fff;
}

#key_list li.master_key.selected
{
    border: 2px solid #999;
}

#key_list li.ind_group:hover,
span.ind_group
{
    border: 2px solid #FF6F21;
    background-color: #FF6F21;
		color: #fff;
}

#key_list li.ind_group.selected
{
    border: 2px solid #FF6F21;
}
/* ------------------- sidebar.css ------------------- */

div.sidebar
{
    margin-bottom: auto;
    flex-shrink: 0;
}

div.sidebar h3
{
    letter-spacing: 0.1em;
    text-align: right;
}

div.sidebar fieldset
{
	border: 3px solid #999;
	border-radius: 5px;
	width: 235px;
}

span#key_description
{
	overflow-wrap: anywhere;
}

/* Pie Chart */
#pieChart
{
    margin-top: 20px;
    width: 200px;
    text-align: center;
}

#pieChartLegend div
{
    float: right;
    width: 50%;
    padding-top: 15px;
}

.legendStuff0,
.legendStuff1
{
	display: inline-block;
	width: 20px;
	height: 20px;
}

.legendStuff0
{
	background-color: #FF6F21;
}

.legendStuff1
{
	background-color: #008BFB;
}
/* ------------------- forms.css ------------------- */

#forms
{
    margin-bottom: auto;
}

form#system_config 
{
	max-width: fit-content;
	margin: 0 auto;
}

form input, form select
{
  font-family: Itim;
	font-size: 16px;
}

form fieldset,
#pageNewSystem fieldset
{
    clear: both;
    border-radius: 5px;
    border: 3px solid #a0a;
}

#forms form:first-child fieldset
{
	margin-bottom: 20px;
}

form label
{
  display: block;
  margin-top: 10px;
  font-size: 16px;
}

form label[for="eula"],
form label[for="residency"]
{
  margin-top: 0;
}

div.field.checkbox
{
	display: flex;
	align-items: center;
	margin-top: 16px;
	padding: 5px 0;
}

form select
{
    min-width: 100px;
}

form p.errors
{
    background-color: #d00;
    color: #fff;
    padding: 2px;
}

/*****************************************************/
a.button
{
  background-color: #a0a;		/* purple */
  border: none;
  color: white;
  cursor: pointer;
  font-size: 16px;
  margin: 20px 0 5px 0;;
  padding: 5px 8px;
  font-family: Itim;
	border-radius: 5px;
}

form input[type=submit], button, #goBack, #sampleKeys, #clearKeys
{ 
  background-color: #a0a;		/* purple */
  border: none;
  color: white;
  cursor: pointer;
  display: block;
  font-size: 16px;
  margin: 20px 0 5px 0;;
  padding: 5px 8px;
  font-family: Itim;
	border-radius: 5px;
}

form input[type=submit].disabled
{
	background-color: #dcc6dc; 	/* muted purple */
	cursor: not-allowed;
}

#key_system_config input[type=text]:not(#key_system_description),
#create_form_key_label,
#rename_form_key_name
{
  text-transform: uppercase;
}

form input[type=text]
{
  font-size: 14px;
  width: 18em;
}

form input[type=text]:not(#user_email_verification_code)::placeholder
{
    text-transform: capitalize;
}

#rename_form .btnContainer
{
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#pageKeyCodes form.button_to,
#btn_print_selected_pinning_charts,
#btn_print_selected,
#btn_print_pinning_charts,
#btn_print_codes
{
	display: inline-block;
	margin: 0 0 20px 10px;
}

#goBack
{
	display: inline-block;
}

/* Checkboxes */
.form-check {
  display: flex;
  align-items: center;
  padding: 10px;
}

.form-check.right {
	justify-content: flex-end;
}

.chart input[type=checkbox]
{
  width: 13px;
  height: 13px;
}

.form-check-input {
	margin-top: 1px;
  margin-right: 7px;
  width: 14px;
  height: 14px;
}

.form-check-label {
  margin-top: 0; 
  margin-bottom: 2px;
}

/*****************************************************/
/* Assign Individual Keys Slider */

#slider {
	margin-top: 10px;
	width: 100%;
	background: #008BFB;
}

#slider .ui-slider-range {
	background: #FF6F21;
}

#slider .ui-slider {
	background: #cfc;
	height: 8px;
	border: none;
	border-radius: 4px;
}

#slider .ui-slider-handle {
	width: 20px;
	height: 20px;
	top: -6px;
	background: #fff;
	border: 1px solid #aaa;
	border-radius: 5px;
}

.slider-labels {
	display: flex;
	justify-content: space-between;
}

.slider-labels span {
	font-size: 14px;
}


input[type=text]#delete_form_key_name,
input[type=text]#control_key,
input[type=text]#gm_key,
input[type=text]#create_form_parent_key,
input[type=text]#assign_keys_form_parent_key,
input[type=text]#assign_keys_form_master_size
{
	background-color: #F7F7F7;
	border: 1px solid #ccc;
}

input[type=text]#assign_keys_form_master_size.underWater
{
	background-color: #ff3;
}

.scrambled.checkbox
{
	display: flex;
	align-items: center;
	float: right;
}

input#scrambled
{
	margin-right: 7px;
	width: 14px;
	height: 14px;
}


/* ------------------- form error instructions and highlighting ------------------- */

#pageSignUp fieldset h3
{
	color: red;
	text-align: center;
}

section#error_explanation
{
	border: 3px solid red;
	background-color: yellow;
	margin-bottom: 20px;
}

section#error_explanation ul
{
	margin-top: 5px;
}

.field_with_errors label
{
	color: red
}

p.alert
{
	margin: 10px 0;
	padding: 5px;
	border: 3px solid red;
}

/* ------------------- form and input field sizing --------------- */
#pageKeySystemInfo
{
	min-width: 900px;
}

#pageSupport form,
#pageKeySystemInfo form,
#pagePasswordReset form,
#pageSignUp form,
#pageSignIn form
{
  min-width: 600px;
  width: 50%;
  margin: 30px auto 0 auto;
}

#pageSupport input, #pageSupport textarea,
#pageKeySystemInfo input:not(#archived),
#pagePasswordReset input,
#pageSignUp input:not(#residency):not(#eula),
#pageSignIn input
{
  width: 100%;
}

a.eula
{
	margin-left: 20px;
}

section#contact
{
	padding: 20px;
}

#pageSignUp #send_code
{
	width: 50%;
}

.sideBySide
{
	display: flex;
	align-items: center;
	gap: 50px;
}

div.sideBySide > * {
  flex: 1;
}

/*****************************************************/
/* Pinning Chart Calculator                          */
#pagePinningChartCalculator .buttons
{
	display: flex;
	justify-content: space-between;
}
/* ------------------- system.css ------------------- */

#pageNewSystem
{
	justify-content: space-evenly;
	min-width: 900px;
}

.buttonContainer
{
  display: flex;
	justify-content: center;
	column-gap: 80px;
	margin-bottom: 10px;
}

.buttonContainer label.rdoButton
{
	display:inline-block;
}

#pageNewSystem #autoScroll .buttonContainer
{
	margin-top: 10px;
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
}

button a
{
	text-decoration: none;
	color: white;
}

.a2_system,
label.rdoButton[for="system_type_A2"] {
	color: #a00;
}

.a3_system,
label.rdoButton[for="system_type_A3"] {
	color: #099;
}

.a4_system,
label.rdoButton[for="system_type_A4"] {
	color: #e70;
}

#systemSize.a2_system
{
	text-align: center;
	border: 2px solid #a00;
}

#systemSize.a3_system
{
	text-align: center;
	border: 2px solid #099;
}

#systemSize.a4_system
{
	text-align: center;
	border: 2px solid #e70;
}

#pins
{
	margin-right: 10px;
}

.keyCuts {
  display: flex;
	column-gap: 20px;
}

form#generate_new_system_keys input[type=text]
{
	width: 7em;
	font-size: 18px;
	letter-spacing: 0.3em;
}

fieldset form.button_to
{
	width: 100%;
}

fieldset form.button_to button
{
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}

form.button_to button.A2
{
	background-color: #a00;
}

form.button_to button.A3
{
	background-color: #099;
}

form.button_to button.A4
{
	background-color: #e70;
}

form#save_new_system_keys
{
	margin-top: 20px;
}

#btn_save_new_system_keys
{
  float: right;
}

#btn_generate_new_system
{
  margin: 20px auto;
	width: 100%;
}

#system_description
{
  width: 100%;
  font-size: 16px;
}


#or
{
	align-self: center;
}

section
{
	padding: 10px;
	border: 3px solid #ccc;
}

fieldset#generator
{
	align-self: flex-start;
	min-width: 310px;
}

fieldset#autoScroll
{
	/* TODO: Safari adds extra space to the legend when the scrollbar appears */
	overflow-y: auto;
	padding: 10px 20px;
	min-width: 400px;
}

fieldset#autoScroll ul
{
	padding-left: 0;
}

ul.hidden
{
	display: none;
}
#codeSettingsWrapper h2
{
	margin: 30px 0;
	text-align: center;
}

/* Color the Control, GM, and SM backgrounds differently */
.codeGroup tr.ancestor_codes th
{
	background-color: #cfc;
  border-bottom: 1px solid #ccc;
}

.code_group_header
{
	display: flex;
	justify-content: space-between;
}


table.codeGroup tr.flat_key td
{
	background-color: #fcc;
}
/* ------------------- print_key_codes/overlay.css ------------------- */

.overlay {
  position: fixed;
  top: 75px;
  left: 190px;
  right: 0;
  bottom: 45px;
  z-index: 9999;
  background-color: rgba(255, 255, 255, 1.0);
  padding: 0 8px 8px 8px;
	opacity: 0;
}

.header
{
	font-size: 18px;
}

/* These styles mess up printing, so restrict them to screen */
@media screen
{
	.header
	{
		margin-bottom: 20px;
	}

	#pageKeyCodes div#keyCodeWrapper
	{
	  display: flex;
	  flex-direction: column;
	}
	
	#pageKeyCodes .buttons {
	  flex-shrink: 0; /* prevent the buttons from shrinking when the container is small */
	}
	
	#pageKeyCodes div#allGroupsWrapper
	{
	  flex-grow: 1; /* make the code tables fill the remaining space */
	  overflow-y: auto;
	}
}
/* End of "These styles mess up printing, so restrict them to screen" */

table.system_info, table.sm_description
{
  border-collapse: collapse;
	border: 1px solid #ccc;
}

table.system_info td, table.sm_description td
{
	padding: 2px 20px;
}

table.system_info
{
	float: left;
}

.codeGroup table 
{
  border-collapse: collapse;
}

.codeGroup th, .codeGroup td 
{
  text-align: left;
  padding: 3px 8px;
}

.codeGroup th:first-child,
.codeGroup td:first-child 
{
  text-align: right;
  border-right: 1px solid #ccc;
}

.codeGroup th 
{
  background-color: #f2f2f2;
  font-weight: bold;
}

.codeGroup tr:nth-child(even) td
{
  background-color: #f2f2f2;
}

.codeGroup th,
.codeGroup td
{
	font-family: monospace;
  font-size: 18px;
  letter-spacing: 3px;
}

.codeGroupWrapper {
	display: inline-block;
	margin: 30px 20px 20px 0;
}

.codeGroupWrapper table {
	border-collapse: collapse;
	border: 1px solid #ccc;
}

@media print {
	.flex_container {
		display: block;
	}

	.codeGroupWrapper {
		display: inline-block;
		margin: 50px 20px 20px 0;
	}

	table.chart.no_print,
	.codeGroupWrapper.no_print
	{
		display: none;
	}

	.codeGroup tr
	{
		color-adjust: exact;
		-webkit-print-color-adjust: exact;
	}

	.overlay {
		position :static;
	}
	
	.codeGroup th,
	.codeGroup td,
	.codeGroupWrapper h4
	{
		font-size: 14pt;
  	letter-spacing: 4pt;
	}

  .header {
    position: fixed;
    top: 0;
  }
}

#btn_show_charts
{
  float: right;
}

#pinningChartsWrapper {
  display: flex;
  flex-direction: column;
}

.buttons {
  flex-shrink: 0; /* Set flex-shrink to 0 to prevent the buttons from shrinking when the container is too small */
}

div#pinningCharts
{
  flex-grow: 1; /* Set flex-grow to 1 to make the charts div fill the remaining space */
	overflow-y: auto;
	padding-bottom: 20px;
}

table.chart
{
  border-collapse: collapse;
  border: 1px solid #ccc;
  font-size: 18px;
	float: left;
	margin: 20px 20px 0 0;
}

.chart td
{
	font-family: monospace;
	padding: 4px 6px;
  text-align: center;
}

.chart tr td:nth-child(odd) {
	background-color: #f2f2f2;
	background-color: #cfc;
}

.chart tr td:nth-child(even) {
	background-color: #ffffff;
}

.chart tr td:first-child
{
  border-right: 2px solid #aaa;
	background-color: #ddd;
}

/********************* print styles *********************/

@media print {
	body
	{
		zoom: 0.75;
	}

	table.chart
	{
	  font-size: 12pt;
		margin-right: 0.25in;
    color-adjust: exact;
    -webkit-print-color-adjust: exact;
	}
	
	table.chart
	{
  	page-break-inside: avoid;
	}

	div#pinningCharts
	{
		overflow-y: visible;  /* hack to fix Safari printing bug */
	}
}

/* SM sub list */
ul#smSlices
{
		background-color: #DFFFE9;
    list-style: none;
    font-family: Monaco;
    font-size: 14px;
    padding: 0 10px 0 10px;
		margin-bottom: 20px;
		border: 1px solid #ccc;
		max-height: 50vh;
		overflow-y: auto;
}

#smSlices li
{
    padding: 1px 0 0 2px;
    line-height: 1.1;
    border: 2px solid transparent;
}

/*! jQuery UI - v1.13.2 - 2022-07-14
* http://jqueryui.com
* Includes: core.css, accordion.css, autocomplete.css, menu.css, button.css, controlgroup.css, checkboxradio.css, datepicker.css, dialog.css, draggable.css, resizable.css, progressbar.css, selectable.css, selectmenu.css, slider.css, sortable.css, spinner.css, tabs.css, tooltip.css, theme.css
* To view and modify this theme, visit http://jqueryui.com/themeroller/?bgShadowXPos=&bgOverlayXPos=&bgErrorXPos=&bgHighlightXPos=&bgContentXPos=&bgHeaderXPos=&bgActiveXPos=&bgHoverXPos=&bgDefaultXPos=&bgShadowYPos=&bgOverlayYPos=&bgErrorYPos=&bgHighlightYPos=&bgContentYPos=&bgHeaderYPos=&bgActiveYPos=&bgHoverYPos=&bgDefaultYPos=&bgShadowRepeat=&bgOverlayRepeat=&bgErrorRepeat=&bgHighlightRepeat=&bgContentRepeat=&bgHeaderRepeat=&bgActiveRepeat=&bgHoverRepeat=&bgDefaultRepeat=&iconsHover=url(/%22images%2Fui-icons_555555_256x240.png%22)&iconsHighlight=url(/%22images%2Fui-icons_777620_256x240.png%22)&iconsHeader=url(/%22images%2Fui-icons_444444_256x240.png%22)&iconsError=url(/%22images%2Fui-icons_cc0000_256x240.png%22)&iconsDefault=url(/%22images%2Fui-icons_777777_256x240.png%22)&iconsContent=url(/%22images%2Fui-icons_444444_256x240.png%22)&iconsActive=url(/%22images%2Fui-icons_ffffff_256x240.png%22)&bgImgUrlShadow=&bgImgUrlOverlay=&bgImgUrlHover=&bgImgUrlHighlight=&bgImgUrlHeader=&bgImgUrlError=&bgImgUrlDefault=&bgImgUrlContent=&bgImgUrlActive=&opacityFilterShadow=Alpha(Opacity%3D30)&opacityFilterOverlay=Alpha(Opacity%3D30)&opacityShadowPerc=30&opacityOverlayPerc=30&iconColorHover=%23555555&iconColorHighlight=%23777620&iconColorHeader=%23444444&iconColorError=%23cc0000&iconColorDefault=%23777777&iconColorContent=%23444444&iconColorActive=%23ffffff&bgImgOpacityShadow=0&bgImgOpacityOverlay=0&bgImgOpacityError=95&bgImgOpacityHighlight=55&bgImgOpacityContent=75&bgImgOpacityHeader=75&bgImgOpacityActive=65&bgImgOpacityHover=75&bgImgOpacityDefault=75&bgTextureShadow=flat&bgTextureOverlay=flat&bgTextureError=flat&bgTextureHighlight=flat&bgTextureContent=flat&bgTextureHeader=flat&bgTextureActive=flat&bgTextureHover=flat&bgTextureDefault=flat&cornerRadius=3px&fwDefault=normal&ffDefault=Arial%2CHelvetica%2Csans-serif&fsDefault=1em&cornerRadiusShadow=8px&thicknessShadow=5px&offsetLeftShadow=0px&offsetTopShadow=0px&opacityShadow=.3&bgColorShadow=%23666666&opacityOverlay=.3&bgColorOverlay=%23aaaaaa&fcError=%235f3f3f&borderColorError=%23f1a899&bgColorError=%23fddfdf&fcHighlight=%23777620&borderColorHighlight=%23dad55e&bgColorHighlight=%23fffa90&fcContent=%23333333&borderColorContent=%23dddddd&bgColorContent=%23ffffff&fcHeader=%23333333&borderColorHeader=%23dddddd&bgColorHeader=%23e9e9e9&fcActive=%23ffffff&borderColorActive=%23003eff&bgColorActive=%23007fff&fcHover=%232b2b2b&borderColorHover=%23cccccc&bgColorHover=%23ededed&fcDefault=%23454545&borderColorDefault=%23c5c5c5&bgColorDefault=%23f6f6f6
* Copyright jQuery Foundation and other contributors; Licensed MIT */

/* Layout helpers
----------------------------------*/
.ui-helper-hidden {
	display: none;
}
.ui-helper-hidden-accessible {
	border: 0;
	clip: rect(0 0 0 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}
.ui-helper-reset {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	line-height: 1.3;
	text-decoration: none;
	font-size: 100%;
	list-style: none;
}
.ui-helper-clearfix:before,
.ui-helper-clearfix:after {
	content: "";
	display: table;
	border-collapse: collapse;
}
.ui-helper-clearfix:after {
	clear: both;
}
.ui-helper-zfix {
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	position: absolute;
	opacity: 0;
	-ms-filter: "alpha(opacity=0)"; /* support: IE8 */
}

.ui-front {
	z-index: 100;
}


/* Interaction Cues
----------------------------------*/
.ui-state-disabled {
	cursor: default !important;
	pointer-events: none;
}


/* Icons
----------------------------------*/
.ui-icon {
	display: inline-block;
	vertical-align: middle;
	margin-top: -.25em;
	position: relative;
	text-indent: -99999px;
	overflow: hidden;
	background-repeat: no-repeat;
}

.ui-widget-icon-block {
	left: 50%;
	margin-left: -8px;
	display: block;
}

/* Misc visuals
----------------------------------*/

/* Overlays */
.ui-widget-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.ui-accordion .ui-accordion-header {
	display: block;
	cursor: pointer;
	position: relative;
	margin: 2px 0 0 0;
	padding: .5em .5em .5em .7em;
	font-size: 100%;
}
.ui-accordion .ui-accordion-content {
	padding: 1em 2.2em;
	border-top: 0;
	overflow: auto;
}
.ui-autocomplete {
	position: absolute;
	top: 0;
	left: 0;
	cursor: default;
}
.ui-menu {
	list-style: none;
	padding: 0;
	margin: 0;
	display: block;
	outline: 0;
}
.ui-menu .ui-menu {
	position: absolute;
}
.ui-menu .ui-menu-item {
	margin: 0;
	cursor: pointer;
	/* support: IE10, see #8844 */
	list-style-image: url("data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7");
}
.ui-menu .ui-menu-item-wrapper {
	position: relative;
	padding: 3px 1em 3px .4em;
}
.ui-menu .ui-menu-divider {
	margin: 5px 0;
	height: 0;
	font-size: 0;
	line-height: 0;
	border-width: 1px 0 0 0;
}
.ui-menu .ui-state-focus,
.ui-menu .ui-state-active {
	margin: -1px;
}

/* icon support */
.ui-menu-icons {
	position: relative;
}
.ui-menu-icons .ui-menu-item-wrapper {
	padding-left: 2em;
}

/* left-aligned */
.ui-menu .ui-icon {
	position: absolute;
	top: 0;
	bottom: 0;
	left: .2em;
	margin: auto 0;
}

/* right-aligned */
.ui-menu .ui-menu-icon {
	left: auto;
	right: 0;
}
.ui-button {
	padding: .4em 1em;
	display: inline-block;
	position: relative;
	line-height: normal;
	margin-right: .1em;
	cursor: pointer;
	vertical-align: middle;
	text-align: center;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;

	/* Support: IE <= 11 */
	overflow: visible;
}

.ui-button,
.ui-button:link,
.ui-button:visited,
.ui-button:hover,
.ui-button:active {
	text-decoration: none;
}

/* to make room for the icon, a width needs to be set here */
.ui-button-icon-only {
	width: 2em;
	box-sizing: border-box;
	text-indent: -9999px;
	white-space: nowrap;
}

/* no icon support for input elements */
input.ui-button.ui-button-icon-only {
	text-indent: 0;
}

/* button icon element(s) */
.ui-button-icon-only .ui-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -8px;
	margin-left: -8px;
}

.ui-button.ui-icon-notext .ui-icon {
	padding: 0;
	width: 2.1em;
	height: 2.1em;
	text-indent: -9999px;
	white-space: nowrap;

}

input.ui-button.ui-icon-notext .ui-icon {
	width: auto;
	height: auto;
	text-indent: 0;
	white-space: normal;
	padding: .4em 1em;
}

/* workarounds */
/* Support: Firefox 5 - 40 */
input.ui-button::-moz-focus-inner,
button.ui-button::-moz-focus-inner {
	border: 0;
	padding: 0;
}
.ui-controlgroup {
	vertical-align: middle;
	display: inline-block;
}
.ui-controlgroup > .ui-controlgroup-item {
	float: left;
	margin-left: 0;
	margin-right: 0;
}
.ui-controlgroup > .ui-controlgroup-item:focus,
.ui-controlgroup > .ui-controlgroup-item.ui-visual-focus {
	z-index: 9999;
}
.ui-controlgroup-vertical > .ui-controlgroup-item {
	display: block;
	float: none;
	width: 100%;
	margin-top: 0;
	margin-bottom: 0;
	text-align: left;
}
.ui-controlgroup-vertical .ui-controlgroup-item {
	box-sizing: border-box;
}
.ui-controlgroup .ui-controlgroup-label {
	padding: .4em 1em;
}
.ui-controlgroup .ui-controlgroup-label span {
	font-size: 80%;
}
.ui-controlgroup-horizontal .ui-controlgroup-label + .ui-controlgroup-item {
	border-left: none;
}
.ui-controlgroup-vertical .ui-controlgroup-label + .ui-controlgroup-item {
	border-top: none;
}
.ui-controlgroup-horizontal .ui-controlgroup-label.ui-widget-content {
	border-right: none;
}
.ui-controlgroup-vertical .ui-controlgroup-label.ui-widget-content {
	border-bottom: none;
}

/* Spinner specific style fixes */
.ui-controlgroup-vertical .ui-spinner-input {

	/* Support: IE8 only, Android < 4.4 only */
	width: 75%;
	width: calc( 100% - 2.4em );
}
.ui-controlgroup-vertical .ui-spinner .ui-spinner-up {
	border-top-style: solid;
}

.ui-checkboxradio-label .ui-icon-background {
	box-shadow: inset 1px 1px 1px #ccc;
	border-radius: .12em;
	border: none;
}
.ui-checkboxradio-radio-label .ui-icon-background {
	width: 16px;
	height: 16px;
	border-radius: 1em;
	overflow: visible;
	border: none;
}
.ui-checkboxradio-radio-label.ui-checkboxradio-checked .ui-icon,
.ui-checkboxradio-radio-label.ui-checkboxradio-checked:hover .ui-icon {
	background-image: none;
	width: 8px;
	height: 8px;
	border-width: 4px;
	border-style: solid;
}
.ui-checkboxradio-disabled {
	pointer-events: none;
}
.ui-datepicker {
	width: 17em;
	padding: .2em .2em 0;
	display: none;
}
.ui-datepicker .ui-datepicker-header {
	position: relative;
	padding: .2em 0;
}
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
	position: absolute;
	top: 2px;
	width: 1.8em;
	height: 1.8em;
}
.ui-datepicker .ui-datepicker-prev-hover,
.ui-datepicker .ui-datepicker-next-hover {
	top: 1px;
}
.ui-datepicker .ui-datepicker-prev {
	left: 2px;
}
.ui-datepicker .ui-datepicker-next {
	right: 2px;
}
.ui-datepicker .ui-datepicker-prev-hover {
	left: 1px;
}
.ui-datepicker .ui-datepicker-next-hover {
	right: 1px;
}
.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
	display: block;
	position: absolute;
	left: 50%;
	margin-left: -8px;
	top: 50%;
	margin-top: -8px;
}
.ui-datepicker .ui-datepicker-title {
	margin: 0 2.3em;
	line-height: 1.8em;
	text-align: center;
}
.ui-datepicker .ui-datepicker-title select {
	font-size: 1em;
	margin: 1px 0;
}
.ui-datepicker select.ui-datepicker-month,
.ui-datepicker select.ui-datepicker-year {
	width: 45%;
}
.ui-datepicker table {
	width: 100%;
	font-size: .9em;
	border-collapse: collapse;
	margin: 0 0 .4em;
}
.ui-datepicker th {
	padding: .7em .3em;
	text-align: center;
	font-weight: bold;
	border: 0;
}
.ui-datepicker td {
	border: 0;
	padding: 1px;
}
.ui-datepicker td span,
.ui-datepicker td a {
	display: block;
	padding: .2em;
	text-align: right;
	text-decoration: none;
}
.ui-datepicker .ui-datepicker-buttonpane {
	background-image: none;
	margin: .7em 0 0 0;
	padding: 0 .2em;
	border-left: 0;
	border-right: 0;
	border-bottom: 0;
}
.ui-datepicker .ui-datepicker-buttonpane button {
	float: right;
	margin: .5em .2em .4em;
	cursor: pointer;
	padding: .2em .6em .3em .6em;
	width: auto;
	overflow: visible;
}
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current {
	float: left;
}

/* with multiple calendars */
.ui-datepicker.ui-datepicker-multi {
	width: auto;
}
.ui-datepicker-multi .ui-datepicker-group {
	float: left;
}
.ui-datepicker-multi .ui-datepicker-group table {
	width: 95%;
	margin: 0 auto .4em;
}
.ui-datepicker-multi-2 .ui-datepicker-group {
	width: 50%;
}
.ui-datepicker-multi-3 .ui-datepicker-group {
	width: 33.3%;
}
.ui-datepicker-multi-4 .ui-datepicker-group {
	width: 25%;
}
.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header,
.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header {
	border-left-width: 0;
}
.ui-datepicker-multi .ui-datepicker-buttonpane {
	clear: left;
}
.ui-datepicker-row-break {
	clear: both;
	width: 100%;
	font-size: 0;
}

/* RTL support */
.ui-datepicker-rtl {
	direction: rtl;
}
.ui-datepicker-rtl .ui-datepicker-prev {
	right: 2px;
	left: auto;
}
.ui-datepicker-rtl .ui-datepicker-next {
	left: 2px;
	right: auto;
}
.ui-datepicker-rtl .ui-datepicker-prev:hover {
	right: 1px;
	left: auto;
}
.ui-datepicker-rtl .ui-datepicker-next:hover {
	left: 1px;
	right: auto;
}
.ui-datepicker-rtl .ui-datepicker-buttonpane {
	clear: right;
}
.ui-datepicker-rtl .ui-datepicker-buttonpane button {
	float: left;
}
.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current,
.ui-datepicker-rtl .ui-datepicker-group {
	float: right;
}
.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header,
.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header {
	border-right-width: 0;
	border-left-width: 1px;
}

/* Icons */
.ui-datepicker .ui-icon {
	display: block;
	text-indent: -99999px;
	overflow: hidden;
	background-repeat: no-repeat;
	left: .5em;
	top: .3em;
}
.ui-dialog {
	position: absolute;
	top: 0;
	left: 0;
	padding: .2em;
	outline: 0;
}
.ui-dialog .ui-dialog-titlebar {
	padding: .4em 1em;
	position: relative;
}
.ui-dialog .ui-dialog-title {
	float: left;
	margin: .1em 0;
	white-space: nowrap;
	width: 90%;
	overflow: hidden;
	text-overflow: ellipsis;
}
.ui-dialog .ui-dialog-titlebar-close {
	position: absolute;
	right: .3em;
	top: 50%;
	width: 20px;
	margin: -10px 0 0 0;
	padding: 1px;
	height: 20px;
}
.ui-dialog .ui-dialog-content {
	position: relative;
	border: 0;
	padding: .5em 1em;
	background: none;
	overflow: auto;
}
.ui-dialog .ui-dialog-buttonpane {
	text-align: left;
	border-width: 1px 0 0 0;
	background-image: none;
	margin-top: .5em;
	padding: .3em 1em .5em .4em;
}
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset {
	float: right;
}
.ui-dialog .ui-dialog-buttonpane button {
	margin: .5em .4em .5em 0;
	cursor: pointer;
}
.ui-dialog .ui-resizable-n {
	height: 2px;
	top: 0;
}
.ui-dialog .ui-resizable-e {
	width: 2px;
	right: 0;
}
.ui-dialog .ui-resizable-s {
	height: 2px;
	bottom: 0;
}
.ui-dialog .ui-resizable-w {
	width: 2px;
	left: 0;
}
.ui-dialog .ui-resizable-se,
.ui-dialog .ui-resizable-sw,
.ui-dialog .ui-resizable-ne,
.ui-dialog .ui-resizable-nw {
	width: 7px;
	height: 7px;
}
.ui-dialog .ui-resizable-se {
	right: 0;
	bottom: 0;
}
.ui-dialog .ui-resizable-sw {
	left: 0;
	bottom: 0;
}
.ui-dialog .ui-resizable-ne {
	right: 0;
	top: 0;
}
.ui-dialog .ui-resizable-nw {
	left: 0;
	top: 0;
}
.ui-draggable .ui-dialog-titlebar {
	cursor: move;
}
.ui-draggable-handle {
	-ms-touch-action: none;
	touch-action: none;
}
.ui-resizable {
	position: relative;
}
.ui-resizable-handle {
	position: absolute;
	font-size: 0.1px;
	display: block;
	-ms-touch-action: none;
	touch-action: none;
}
.ui-resizable-disabled .ui-resizable-handle,
.ui-resizable-autohide .ui-resizable-handle {
	display: none;
}
.ui-resizable-n {
	cursor: n-resize;
	height: 7px;
	width: 100%;
	top: -5px;
	left: 0;
}
.ui-resizable-s {
	cursor: s-resize;
	height: 7px;
	width: 100%;
	bottom: -5px;
	left: 0;
}
.ui-resizable-e {
	cursor: e-resize;
	width: 7px;
	right: -5px;
	top: 0;
	height: 100%;
}
.ui-resizable-w {
	cursor: w-resize;
	width: 7px;
	left: -5px;
	top: 0;
	height: 100%;
}
.ui-resizable-se {
	cursor: se-resize;
	width: 12px;
	height: 12px;
	right: 1px;
	bottom: 1px;
}
.ui-resizable-sw {
	cursor: sw-resize;
	width: 9px;
	height: 9px;
	left: -5px;
	bottom: -5px;
}
.ui-resizable-nw {
	cursor: nw-resize;
	width: 9px;
	height: 9px;
	left: -5px;
	top: -5px;
}
.ui-resizable-ne {
	cursor: ne-resize;
	width: 9px;
	height: 9px;
	right: -5px;
	top: -5px;
}
.ui-progressbar {
	height: 2em;
	text-align: left;
	overflow: hidden;
}
.ui-progressbar .ui-progressbar-value {
	margin: -1px;
	height: 100%;
}
.ui-progressbar .ui-progressbar-overlay {
	background: url("data:image/gif;base64,R0lGODlhKAAoAIABAAAAAP///yH/C05FVFNDQVBFMi4wAwEAAAAh+QQJAQABACwAAAAAKAAoAAACkYwNqXrdC52DS06a7MFZI+4FHBCKoDeWKXqymPqGqxvJrXZbMx7Ttc+w9XgU2FB3lOyQRWET2IFGiU9m1frDVpxZZc6bfHwv4c1YXP6k1Vdy292Fb6UkuvFtXpvWSzA+HycXJHUXiGYIiMg2R6W459gnWGfHNdjIqDWVqemH2ekpObkpOlppWUqZiqr6edqqWQAAIfkECQEAAQAsAAAAACgAKAAAApSMgZnGfaqcg1E2uuzDmmHUBR8Qil95hiPKqWn3aqtLsS18y7G1SzNeowWBENtQd+T1JktP05nzPTdJZlR6vUxNWWjV+vUWhWNkWFwxl9VpZRedYcflIOLafaa28XdsH/ynlcc1uPVDZxQIR0K25+cICCmoqCe5mGhZOfeYSUh5yJcJyrkZWWpaR8doJ2o4NYq62lAAACH5BAkBAAEALAAAAAAoACgAAAKVDI4Yy22ZnINRNqosw0Bv7i1gyHUkFj7oSaWlu3ovC8GxNso5fluz3qLVhBVeT/Lz7ZTHyxL5dDalQWPVOsQWtRnuwXaFTj9jVVh8pma9JjZ4zYSj5ZOyma7uuolffh+IR5aW97cHuBUXKGKXlKjn+DiHWMcYJah4N0lYCMlJOXipGRr5qdgoSTrqWSq6WFl2ypoaUAAAIfkECQEAAQAsAAAAACgAKAAAApaEb6HLgd/iO7FNWtcFWe+ufODGjRfoiJ2akShbueb0wtI50zm02pbvwfWEMWBQ1zKGlLIhskiEPm9R6vRXxV4ZzWT2yHOGpWMyorblKlNp8HmHEb/lCXjcW7bmtXP8Xt229OVWR1fod2eWqNfHuMjXCPkIGNileOiImVmCOEmoSfn3yXlJWmoHGhqp6ilYuWYpmTqKUgAAIfkECQEAAQAsAAAAACgAKAAAApiEH6kb58biQ3FNWtMFWW3eNVcojuFGfqnZqSebuS06w5V80/X02pKe8zFwP6EFWOT1lDFk8rGERh1TTNOocQ61Hm4Xm2VexUHpzjymViHrFbiELsefVrn6XKfnt2Q9G/+Xdie499XHd2g4h7ioOGhXGJboGAnXSBnoBwKYyfioubZJ2Hn0RuRZaflZOil56Zp6iioKSXpUAAAh+QQJAQABACwAAAAAKAAoAAACkoQRqRvnxuI7kU1a1UU5bd5tnSeOZXhmn5lWK3qNTWvRdQxP8qvaC+/yaYQzXO7BMvaUEmJRd3TsiMAgswmNYrSgZdYrTX6tSHGZO73ezuAw2uxuQ+BbeZfMxsexY35+/Qe4J1inV0g4x3WHuMhIl2jXOKT2Q+VU5fgoSUI52VfZyfkJGkha6jmY+aaYdirq+lQAACH5BAkBAAEALAAAAAAoACgAAAKWBIKpYe0L3YNKToqswUlvznigd4wiR4KhZrKt9Upqip61i9E3vMvxRdHlbEFiEXfk9YARYxOZZD6VQ2pUunBmtRXo1Lf8hMVVcNl8JafV38aM2/Fu5V16Bn63r6xt97j09+MXSFi4BniGFae3hzbH9+hYBzkpuUh5aZmHuanZOZgIuvbGiNeomCnaxxap2upaCZsq+1kAACH5BAkBAAEALAAAAAAoACgAAAKXjI8By5zf4kOxTVrXNVlv1X0d8IGZGKLnNpYtm8Lr9cqVeuOSvfOW79D9aDHizNhDJidFZhNydEahOaDH6nomtJjp1tutKoNWkvA6JqfRVLHU/QUfau9l2x7G54d1fl995xcIGAdXqMfBNadoYrhH+Mg2KBlpVpbluCiXmMnZ2Sh4GBqJ+ckIOqqJ6LmKSllZmsoq6wpQAAAh+QQJAQABACwAAAAAKAAoAAAClYx/oLvoxuJDkU1a1YUZbJ59nSd2ZXhWqbRa2/gF8Gu2DY3iqs7yrq+xBYEkYvFSM8aSSObE+ZgRl1BHFZNr7pRCavZ5BW2142hY3AN/zWtsmf12p9XxxFl2lpLn1rseztfXZjdIWIf2s5dItwjYKBgo9yg5pHgzJXTEeGlZuenpyPmpGQoKOWkYmSpaSnqKileI2FAAACH5BAkBAAEALAAAAAAoACgAAAKVjB+gu+jG4kORTVrVhRlsnn2dJ3ZleFaptFrb+CXmO9OozeL5VfP99HvAWhpiUdcwkpBH3825AwYdU8xTqlLGhtCosArKMpvfa1mMRae9VvWZfeB2XfPkeLmm18lUcBj+p5dnN8jXZ3YIGEhYuOUn45aoCDkp16hl5IjYJvjWKcnoGQpqyPlpOhr3aElaqrq56Bq7VAAAOw==");
	height: 100%;
	-ms-filter: "alpha(opacity=25)"; /* support: IE8 */
	opacity: 0.25;
}
.ui-progressbar-indeterminate .ui-progressbar-value {
	background-image: none;
}
.ui-selectable {
	-ms-touch-action: none;
	touch-action: none;
}
.ui-selectable-helper {
	position: absolute;
	z-index: 100;
	border: 1px dotted black;
}
.ui-selectmenu-menu {
	padding: 0;
	margin: 0;
	position: absolute;
	top: 0;
	left: 0;
	display: none;
}
.ui-selectmenu-menu .ui-menu {
	overflow: auto;
	overflow-x: hidden;
	padding-bottom: 1px;
}
.ui-selectmenu-menu .ui-menu .ui-selectmenu-optgroup {
	font-size: 1em;
	font-weight: bold;
	line-height: 1.5;
	padding: 2px 0.4em;
	margin: 0.5em 0 0 0;
	height: auto;
	border: 0;
}
.ui-selectmenu-open {
	display: block;
}
.ui-selectmenu-text {
	display: block;
	margin-right: 20px;
	overflow: hidden;
	text-overflow: ellipsis;
}
.ui-selectmenu-button.ui-button {
	text-align: left;
	white-space: nowrap;
	width: 14em;
}
.ui-selectmenu-icon.ui-icon {
	float: right;
	margin-top: 0;
}
.ui-slider {
	position: relative;
	text-align: left;
}
.ui-slider .ui-slider-handle {
	position: absolute;
	z-index: 2;
	width: 1.2em;
	height: 1.2em;
	cursor: pointer;
	-ms-touch-action: none;
	touch-action: none;
}
.ui-slider .ui-slider-range {
	position: absolute;
	z-index: 1;
	font-size: .7em;
	display: block;
	border: 0;
	background-position: 0 0;
}

/* support: IE8 - See #6727 */
.ui-slider.ui-state-disabled .ui-slider-handle,
.ui-slider.ui-state-disabled .ui-slider-range {
	filter: inherit;
}

.ui-slider-horizontal {
	height: .8em;
}
.ui-slider-horizontal .ui-slider-handle {
	top: -.3em;
	margin-left: -.6em;
}
.ui-slider-horizontal .ui-slider-range {
	top: 0;
	height: 100%;
}
.ui-slider-horizontal .ui-slider-range-min {
	left: 0;
}
.ui-slider-horizontal .ui-slider-range-max {
	right: 0;
}

.ui-slider-vertical {
	width: .8em;
	height: 100px;
}
.ui-slider-vertical .ui-slider-handle {
	left: -.3em;
	margin-left: 0;
	margin-bottom: -.6em;
}
.ui-slider-vertical .ui-slider-range {
	left: 0;
	width: 100%;
}
.ui-slider-vertical .ui-slider-range-min {
	bottom: 0;
}
.ui-slider-vertical .ui-slider-range-max {
	top: 0;
}
.ui-sortable-handle {
	-ms-touch-action: none;
	touch-action: none;
}
.ui-spinner {
	position: relative;
	display: inline-block;
	overflow: hidden;
	padding: 0;
	vertical-align: middle;
}
.ui-spinner-input {
	border: none;
	background: none;
	color: inherit;
	padding: .222em 0;
	margin: .2em 0;
	vertical-align: middle;
	margin-left: .4em;
	margin-right: 2em;
}
.ui-spinner-button {
	width: 1.6em;
	height: 50%;
	font-size: .5em;
	padding: 0;
	margin: 0;
	text-align: center;
	position: absolute;
	cursor: default;
	display: block;
	overflow: hidden;
	right: 0;
}
/* more specificity required here to override default borders */
.ui-spinner a.ui-spinner-button {
	border-top-style: none;
	border-bottom-style: none;
	border-right-style: none;
}
.ui-spinner-up {
	top: 0;
}
.ui-spinner-down {
	bottom: 0;
}
.ui-tabs {
	position: relative;/* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
	padding: .2em;
}
.ui-tabs .ui-tabs-nav {
	margin: 0;
	padding: .2em .2em 0;
}
.ui-tabs .ui-tabs-nav li {
	list-style: none;
	float: left;
	position: relative;
	top: 0;
	margin: 1px .2em 0 0;
	border-bottom-width: 0;
	padding: 0;
	white-space: nowrap;
}
.ui-tabs .ui-tabs-nav .ui-tabs-anchor {
	float: left;
	padding: .5em 1em;
	text-decoration: none;
}
.ui-tabs .ui-tabs-nav li.ui-tabs-active {
	margin-bottom: -1px;
	padding-bottom: 1px;
}
.ui-tabs .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor,
.ui-tabs .ui-tabs-nav li.ui-state-disabled .ui-tabs-anchor,
.ui-tabs .ui-tabs-nav li.ui-tabs-loading .ui-tabs-anchor {
	cursor: text;
}
.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor {
	cursor: pointer;
}
.ui-tabs .ui-tabs-panel {
	display: block;
	border-width: 0;
	padding: 1em 1.4em;
	background: none;
}
.ui-tooltip {
	padding: 8px;
	position: absolute;
	z-index: 9999;
	max-width: 300px;
}
body .ui-tooltip {
	border-width: 2px;
}

/* Component containers
----------------------------------*/
.ui-widget {
	font-family: Arial,Helvetica,sans-serif;
	font-size: 1em;
}
.ui-widget .ui-widget {
	font-size: 1em;
}
.ui-widget input,
.ui-widget select,
.ui-widget textarea,
.ui-widget button {
	font-family: Arial,Helvetica,sans-serif;
	font-size: 1em;
}
.ui-widget.ui-widget-content {
	border: 1px solid #c5c5c5;
}
.ui-widget-content {
	border: 1px solid #dddddd;
	background: #ffffff;
	color: #333333;
}
.ui-widget-content a {
	color: #333333;
}
.ui-widget-header {
	border: 1px solid #dddddd;
	background: #e9e9e9;
	color: #333333;
	font-weight: bold;
}
.ui-widget-header a {
	color: #333333;
}

/* Interaction states
----------------------------------*/
.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default,
.ui-button,

/* We use html here because we need a greater specificity to make sure disabled
works properly when clicked or hovered */
html .ui-button.ui-state-disabled:hover,
html .ui-button.ui-state-disabled:active {
	border: 1px solid #c5c5c5;
	background: #f6f6f6;
	font-weight: normal;
	color: #454545;
}
.ui-state-default a,
.ui-state-default a:link,
.ui-state-default a:visited,
a.ui-button,
a:link.ui-button,
a:visited.ui-button,
.ui-button {
	color: #454545;
	text-decoration: none;
}
.ui-state-hover,
.ui-widget-content .ui-state-hover,
.ui-widget-header .ui-state-hover,
.ui-state-focus,
.ui-widget-content .ui-state-focus,
.ui-widget-header .ui-state-focus,
.ui-button:hover,
.ui-button:focus {
	border: 1px solid #cccccc;
	background: #ededed;
	font-weight: normal;
	color: #2b2b2b;
}
.ui-state-hover a,
.ui-state-hover a:hover,
.ui-state-hover a:link,
.ui-state-hover a:visited,
.ui-state-focus a,
.ui-state-focus a:hover,
.ui-state-focus a:link,
.ui-state-focus a:visited,
a.ui-button:hover,
a.ui-button:focus {
	color: #2b2b2b;
	text-decoration: none;
}

.ui-visual-focus {
	box-shadow: 0 0 3px 1px rgb(94, 158, 214);
}
.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active,
a.ui-button:active,
.ui-button:active,
.ui-button.ui-state-active:hover {
	border: 1px solid #003eff;
	background: #007fff;
	font-weight: normal;
	color: #ffffff;
}
.ui-icon-background,
.ui-state-active .ui-icon-background {
	border: #003eff;
	background-color: #ffffff;
}
.ui-state-active a,
.ui-state-active a:link,
.ui-state-active a:visited {
	color: #ffffff;
	text-decoration: none;
}

/* Interaction Cues
----------------------------------*/
.ui-state-highlight,
.ui-widget-content .ui-state-highlight,
.ui-widget-header .ui-state-highlight {
	border: 1px solid #dad55e;
	background: #fffa90;
	color: #777620;
}
.ui-state-checked {
	border: 1px solid #dad55e;
	background: #fffa90;
}
.ui-state-highlight a,
.ui-widget-content .ui-state-highlight a,
.ui-widget-header .ui-state-highlight a {
	color: #777620;
}
.ui-state-error,
.ui-widget-content .ui-state-error,
.ui-widget-header .ui-state-error {
	border: 1px solid #f1a899;
	background: #fddfdf;
	color: #5f3f3f;
}
.ui-state-error a,
.ui-widget-content .ui-state-error a,
.ui-widget-header .ui-state-error a {
	color: #5f3f3f;
}
.ui-state-error-text,
.ui-widget-content .ui-state-error-text,
.ui-widget-header .ui-state-error-text {
	color: #5f3f3f;
}
.ui-priority-primary,
.ui-widget-content .ui-priority-primary,
.ui-widget-header .ui-priority-primary {
	font-weight: bold;
}
.ui-priority-secondary,
.ui-widget-content .ui-priority-secondary,
.ui-widget-header .ui-priority-secondary {
	opacity: .7;
	-ms-filter: "alpha(opacity=70)"; /* support: IE8 */
	font-weight: normal;
}
.ui-state-disabled,
.ui-widget-content .ui-state-disabled,
.ui-widget-header .ui-state-disabled {
	opacity: .35;
	-ms-filter: "alpha(opacity=35)"; /* support: IE8 */
	background-image: none;
}
.ui-state-disabled .ui-icon {
	-ms-filter: "alpha(opacity=35)"; /* support: IE8 - See #6059 */
}

/* Icons
----------------------------------*/

/* states and images */
.ui-icon {
	width: 16px;
	height: 16px;
}
.ui-icon,
.ui-widget-content .ui-icon {
	background-image: url(/images/ui-icons_444444_256x240.png);
}
.ui-widget-header .ui-icon {
	background-image: url(/images/ui-icons_444444_256x240.png);
}
.ui-state-hover .ui-icon,
.ui-state-focus .ui-icon,
.ui-button:hover .ui-icon,
.ui-button:focus .ui-icon {
	background-image: url(/images/ui-icons_555555_256x240.png);
}
.ui-state-active .ui-icon,
.ui-button:active .ui-icon {
	background-image: url(/images/ui-icons_ffffff_256x240.png);
}
.ui-state-highlight .ui-icon,
.ui-button .ui-state-highlight.ui-icon {
	background-image: url(/images/ui-icons_777620_256x240.png);
}
.ui-state-error .ui-icon,
.ui-state-error-text .ui-icon {
	background-image: url(/images/ui-icons_cc0000_256x240.png);
}
.ui-button .ui-icon {
	background-image: url(/images/ui-icons_777777_256x240.png);
}

/* positioning */
/* Three classes needed to override `.ui-button:hover .ui-icon` */
.ui-icon-blank.ui-icon-blank.ui-icon-blank {
	background-image: none;
}
.ui-icon-caret-1-n { background-position: 0 0; }
.ui-icon-caret-1-ne { background-position: -16px 0; }
.ui-icon-caret-1-e { background-position: -32px 0; }
.ui-icon-caret-1-se { background-position: -48px 0; }
.ui-icon-caret-1-s { background-position: -65px 0; }
.ui-icon-caret-1-sw { background-position: -80px 0; }
.ui-icon-caret-1-w { background-position: -96px 0; }
.ui-icon-caret-1-nw { background-position: -112px 0; }
.ui-icon-caret-2-n-s { background-position: -128px 0; }
.ui-icon-caret-2-e-w { background-position: -144px 0; }
.ui-icon-triangle-1-n { background-position: 0 -16px; }
.ui-icon-triangle-1-ne { background-position: -16px -16px; }
.ui-icon-triangle-1-e { background-position: -32px -16px; }
.ui-icon-triangle-1-se { background-position: -48px -16px; }
.ui-icon-triangle-1-s { background-position: -65px -16px; }
.ui-icon-triangle-1-sw { background-position: -80px -16px; }
.ui-icon-triangle-1-w { background-position: -96px -16px; }
.ui-icon-triangle-1-nw { background-position: -112px -16px; }
.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
.ui-icon-arrow-1-n { background-position: 0 -32px; }
.ui-icon-arrow-1-ne { background-position: -16px -32px; }
.ui-icon-arrow-1-e { background-position: -32px -32px; }
.ui-icon-arrow-1-se { background-position: -48px -32px; }
.ui-icon-arrow-1-s { background-position: -65px -32px; }
.ui-icon-arrow-1-sw { background-position: -80px -32px; }
.ui-icon-arrow-1-w { background-position: -96px -32px; }
.ui-icon-arrow-1-nw { background-position: -112px -32px; }
.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
.ui-icon-arrowthick-1-n { background-position: 1px -48px; }
.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
.ui-icon-arrow-4 { background-position: 0 -80px; }
.ui-icon-arrow-4-diag { background-position: -16px -80px; }
.ui-icon-extlink { background-position: -32px -80px; }
.ui-icon-newwin { background-position: -48px -80px; }
.ui-icon-refresh { background-position: -64px -80px; }
.ui-icon-shuffle { background-position: -80px -80px; }
.ui-icon-transfer-e-w { background-position: -96px -80px; }
.ui-icon-transferthick-e-w { background-position: -112px -80px; }
.ui-icon-folder-collapsed { background-position: 0 -96px; }
.ui-icon-folder-open { background-position: -16px -96px; }
.ui-icon-document { background-position: -32px -96px; }
.ui-icon-document-b { background-position: -48px -96px; }
.ui-icon-note { background-position: -64px -96px; }
.ui-icon-mail-closed { background-position: -80px -96px; }
.ui-icon-mail-open { background-position: -96px -96px; }
.ui-icon-suitcase { background-position: -112px -96px; }
.ui-icon-comment { background-position: -128px -96px; }
.ui-icon-person { background-position: -144px -96px; }
.ui-icon-print { background-position: -160px -96px; }
.ui-icon-trash { background-position: -176px -96px; }
.ui-icon-locked { background-position: -192px -96px; }
.ui-icon-unlocked { background-position: -208px -96px; }
.ui-icon-bookmark { background-position: -224px -96px; }
.ui-icon-tag { background-position: -240px -96px; }
.ui-icon-home { background-position: 0 -112px; }
.ui-icon-flag { background-position: -16px -112px; }
.ui-icon-calendar { background-position: -32px -112px; }
.ui-icon-cart { background-position: -48px -112px; }
.ui-icon-pencil { background-position: -64px -112px; }
.ui-icon-clock { background-position: -80px -112px; }
.ui-icon-disk { background-position: -96px -112px; }
.ui-icon-calculator { background-position: -112px -112px; }
.ui-icon-zoomin { background-position: -128px -112px; }
.ui-icon-zoomout { background-position: -144px -112px; }
.ui-icon-search { background-position: -160px -112px; }
.ui-icon-wrench { background-position: -176px -112px; }
.ui-icon-gear { background-position: -192px -112px; }
.ui-icon-heart { background-position: -208px -112px; }
.ui-icon-star { background-position: -224px -112px; }
.ui-icon-link { background-position: -240px -112px; }
.ui-icon-cancel { background-position: 0 -128px; }
.ui-icon-plus { background-position: -16px -128px; }
.ui-icon-plusthick { background-position: -32px -128px; }
.ui-icon-minus { background-position: -48px -128px; }
.ui-icon-minusthick { background-position: -64px -128px; }
.ui-icon-close { background-position: -80px -128px; }
.ui-icon-closethick { background-position: -96px -128px; }
.ui-icon-key { background-position: -112px -128px; }
.ui-icon-lightbulb { background-position: -128px -128px; }
.ui-icon-scissors { background-position: -144px -128px; }
.ui-icon-clipboard { background-position: -160px -128px; }
.ui-icon-copy { background-position: -176px -128px; }
.ui-icon-contact { background-position: -192px -128px; }
.ui-icon-image { background-position: -208px -128px; }
.ui-icon-video { background-position: -224px -128px; }
.ui-icon-script { background-position: -240px -128px; }
.ui-icon-alert { background-position: 0 -144px; }
.ui-icon-info { background-position: -16px -144px; }
.ui-icon-notice { background-position: -32px -144px; }
.ui-icon-help { background-position: -48px -144px; }
.ui-icon-check { background-position: -64px -144px; }
.ui-icon-bullet { background-position: -80px -144px; }
.ui-icon-radio-on { background-position: -96px -144px; }
.ui-icon-radio-off { background-position: -112px -144px; }
.ui-icon-pin-w { background-position: -128px -144px; }
.ui-icon-pin-s { background-position: -144px -144px; }
.ui-icon-play { background-position: 0 -160px; }
.ui-icon-pause { background-position: -16px -160px; }
.ui-icon-seek-next { background-position: -32px -160px; }
.ui-icon-seek-prev { background-position: -48px -160px; }
.ui-icon-seek-end { background-position: -64px -160px; }
.ui-icon-seek-start { background-position: -80px -160px; }
/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
.ui-icon-seek-first { background-position: -80px -160px; }
.ui-icon-stop { background-position: -96px -160px; }
.ui-icon-eject { background-position: -112px -160px; }
.ui-icon-volume-off { background-position: -128px -160px; }
.ui-icon-volume-on { background-position: -144px -160px; }
.ui-icon-power { background-position: 0 -176px; }
.ui-icon-signal-diag { background-position: -16px -176px; }
.ui-icon-signal { background-position: -32px -176px; }
.ui-icon-battery-0 { background-position: -48px -176px; }
.ui-icon-battery-1 { background-position: -64px -176px; }
.ui-icon-battery-2 { background-position: -80px -176px; }
.ui-icon-battery-3 { background-position: -96px -176px; }
.ui-icon-circle-plus { background-position: 0 -192px; }
.ui-icon-circle-minus { background-position: -16px -192px; }
.ui-icon-circle-close { background-position: -32px -192px; }
.ui-icon-circle-triangle-e { background-position: -48px -192px; }
.ui-icon-circle-triangle-s { background-position: -64px -192px; }
.ui-icon-circle-triangle-w { background-position: -80px -192px; }
.ui-icon-circle-triangle-n { background-position: -96px -192px; }
.ui-icon-circle-arrow-e { background-position: -112px -192px; }
.ui-icon-circle-arrow-s { background-position: -128px -192px; }
.ui-icon-circle-arrow-w { background-position: -144px -192px; }
.ui-icon-circle-arrow-n { background-position: -160px -192px; }
.ui-icon-circle-zoomin { background-position: -176px -192px; }
.ui-icon-circle-zoomout { background-position: -192px -192px; }
.ui-icon-circle-check { background-position: -208px -192px; }
.ui-icon-circlesmall-plus { background-position: 0 -208px; }
.ui-icon-circlesmall-minus { background-position: -16px -208px; }
.ui-icon-circlesmall-close { background-position: -32px -208px; }
.ui-icon-squaresmall-plus { background-position: -48px -208px; }
.ui-icon-squaresmall-minus { background-position: -64px -208px; }
.ui-icon-squaresmall-close { background-position: -80px -208px; }
.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
.ui-icon-grip-diagonal-se { background-position: -80px -224px; }


/* Misc visuals
----------------------------------*/

/* Corner radius */
.ui-corner-all,
.ui-corner-top,
.ui-corner-left,
.ui-corner-tl {
	border-top-left-radius: 3px;
}
.ui-corner-all,
.ui-corner-top,
.ui-corner-right,
.ui-corner-tr {
	border-top-right-radius: 3px;
}
.ui-corner-all,
.ui-corner-bottom,
.ui-corner-left,
.ui-corner-bl {
	border-bottom-left-radius: 3px;
}
.ui-corner-all,
.ui-corner-bottom,
.ui-corner-right,
.ui-corner-br {
	border-bottom-right-radius: 3px;
}

/* Overlays */
.ui-widget-overlay {
	background: #aaaaaa;
	opacity: .003;
	-ms-filter: Alpha(Opacity=.3); /* support: IE8 */
}
.ui-widget-shadow {
	-webkit-box-shadow: 0px 0px 5px #666666;
	box-shadow: 0px 0px 5px #666666;
}
#pagePinningChartCalculator form
{
	width: 50%;
	min-width: 450px;
	margin: 30px auto 0 auto;
}

#change_keys
{
	font-family: Itim;
	font-size: 16px;
	width: 100%;
}

#pagePinningChartCalculator input[type=text]
{
	font-family: Itim;
	font-size: 18px;
  letter-spacing: 0.3em;
	width: 200px;
}

#pagePinningChartCalculator .topSection
{
  display: flex;
  justify-content: space-between;
  margin-bottom: 20px;
}

#pagePinningChartCalculator .topSection label.rdoButton
{
  display:inline-block;
}

#pagePinningChartCalculator #systemType
{
	display: flex;
	flex-direction: column;
	justify-content: space-evenly;
	margin-left: 20px;
}

#sampleKeys, #clearKeys
{
	display: inline-block;
}

/* Pin Segments tables **********************************/
#pin_segments_wrapper
{
	margin-top: 20px;
	border: 10px solid #ccc;
	width: fit-content;
	float: left;
	clear: left;
}

table.pin_segments
{
	border-collapse: collapse;
	width: fit-content;
	float: left;
}

table.pin_segments caption
{
	text-wrap: nowrap;
	padding: 5px 10px 5px 10px;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
}

table.pin_segments, table.pin_segments td, table.pin_segments th
{
	text-align: center;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-top: 1px solid #ccc;
	padding: 5px;
  font-weight: normal;	/* Safari bolds <th> by default */

}

#pin_segments_wrapper h3
{
	color: #f00;
	float: right;
  position: relative;
  z-index: 1;
	padding-right: 5px;
  margin-left: -20px;
	cursor: pointer;
}


#pagePinningChartCalculator #cross_keys
{
	width: 100%;
	font-size: 16px;
	letter-spacing: initial;
}
@media print {
  body 
  { 
    font-size: 12pt;
  }

  main
  {
    position: static;
  }

	nav, header, footer, #forms, #key_list_wrapper, .buttons, #codeSettingsWrapper, .sidebar
	{
		display: none;
	}

  .noPrint {
    display: none;
  }

	input[type=checkbox]
	{
  	display: none;
	}

}
div.terms
{
	overflow-y: auto;
	height: 100%;
	padding: 10px 75px;
}

h1
{
	text-align: center;
}

#pagePinningChartCalculator,
#pageSupport, #pagePrivacy
{
	padding-top: 10px;
}

#pageTerms, #pagePrivacy, #pageSupport, div.terms
{
	min-width: 900px;
}

#pageTerms p, #pageSupport p, #pagePrivacy p
{
	margin: 6px 0;
}

#pageTerms h1, #pageSupport h1, #pagePrivacy h1
{
	margin: 0 0 20px 0;
}

#pageSupport h1
{
	margin: 0 0 10px 0;
}

#pageSupport p
{
	text-align: center;
}

#pageTerms h2, #pageSupport h2, #pagePrivacy h2
{
	margin-top: 30px;
}

ol
{
	padding-inline-start: 0;
}

p
{
	margin: 6px 0 18px 0
}

ol ul
{
	margin-top: -5px;
}

/********************* print styles *********************/

@media print {
	li
	{
		page-break-inside: avoid;
	}
}

#pageThankYou
{
  overflow-y: auto;
  height: 100%;
	padding: 10px 75px;
}

#pageThankYou h1
{
	margin-bottom: 20px;
}
#pageBilling,
#pagePrintingTips
{
	padding: 10px 60px 10px 30px;
	min-width: 900px;
}

#pageBilling h1,
#pagePrintingTips h1
{
	margin-bottom: 40px;
}

#pageBilling li,
#pagePrintingTips li
{
	padding: 10px 0;
}

#pageBilling
{
	padding-right: 10%;
}
