body {
	/*font: 90%/100% "Trebuchet MS", "Lucida Sans Unicode", Arial, Helvetica, Verdana, sans-serif;*/
	font: 90%/100% Helvetica, sans-serif;
	color: #666; 
	margin: 0; 
	background-color: #343434; }
	p {
		font-size: 18px;
	}
/*	
#logo {
	position:absolute;
	width:auto;
	height:95px;
	top: 0px;
	text-align: left;
	text-indent: 35px;
	padding-top: 5px;
	visibility: visible;
	margin-right: 5px;
}
	
#fwsbar {
	text-indent: 149px;
	height: 31px;
	width: auto;
	position:absolute;
	top: 12px;
	visibility: visible;
	font-family: "Arial Narrow", Helvetica, sans-serif;
	font-size: 19px;
	color: #FFF;
	font-weight:bold;
	margin-top: 6px;
	}
#fwsbarhome {
	text-indent: 149px;
	height: 31px;
	width: auto;
	position: absolute;
	top: 12px;
	visibility: visible;
	z-index:1;
	font-family: "Arial Narrow", Helvetica, sans-serif;
	font-size: 19px;
	color: #FFF;
	font-weight:bold;
	margin-top: 2px;
	}
	
#sitename {
	position:absolute;
	height:36px;
	z-index:1;
	top: 39px;
	font-size: 35px;
	line-height: 40px;
	font-weight: bolder;
	color: #000000;
	text-align: left;
	white-space: nowrap;
	font-family: "Arial Narrow", Helvetica, sans-serif;
	visibility: visible;
	padding-right: 10px;
	padding-left: 0px;
	text-indent: 149px;}
/*
#searchbar {
	height:38px;
	width: auto;
	top: 107px;
	position: absolute;
	padding-top: 2px;
	padding-bottom: 2px;
	visibility: visible;
	vertical-align: middle;
	z-index: 3;
	overflow: hidden;
	padding-left: 10px;
}
.searchbar .search-cell img {
	float: right;
	vertical-align: middle;
	padding-top: 20%;
	top: 50%;
	position: relative;}
#searchbar .search-button {
	margin: 0px;
	padding: 0px;
	font-size: 0.9em;
	font-family: Verdana, Arial, Helvetica, sans-serif;
	letter-spacing: 0em;}
	*/

a:link {
	color: #003366;
	text-decoration: underline;
	background-color: transparent
}
a:visited {
	color: #003366;
	text-decoration: underline;
	background-color: transparent
}
a:active { color: #750508; text-decoration: none; background-color: transparent }
a:hover {	color: #23669A;	text-decoration: none;	background-color: transparent;}
	
	

.contentbox {
	border: 1px solid #999;
	padding: 10px 20px 10px 20px; 
	width: auto; 
	margin-left: 31px;
	color: #666; background-color: #fff;
	margin-top: 20px;
	margin-bottom: 20px;
	line-height:170%;}
	

		
.publications {font-size: 85%; color: #666; background-color: #fff; line-height: 150%;}
.caption {
	font-size: 115%;
	line-height: 140%;
	color: #6b6b6b;
}
.nav {
	font-size: 11px;
	font-family:Arial, Helvetica, sans-serif;
	line-height: 120%;
	color: #c5c5c5; background-color: #111F39;
	font-weight: bold;
	text-transform: uppercase;
	text-decoration:none;
}
a.nav:link  { color: #c5c5c5; text-decoration: none;}
a.nav:visited { color: #c5c5c5; text-decoration: none;}
a.nav:active { color: #e0e0e0; text-decoration: none;}
a.nav:hover { color: #e0e0e0; text-decoration: none;}

.navsub {
	font-size: 10px;
	font-family:Arial, Helvetica, sans-serif;
	line-height: 100%;
	color: #1a1a1a;
	background-color: #A4A4A4;
	font-weight: bold;
	text-transform: uppercase;
	text-decoration:none;
	text-align: center;
}
a.navsub:link  { color: #1a1a1a; text-decoration: none;}
a.navsub:visited { color: #1a1a1a; text-decoration: none;}
a.navsub:active { color: #1a1a1a; text-decoration: none;}
a.navsub:hover { color: #000000;	text-decoration: none;}



.navtertiary {
	font-size: 10px;
	font-family: Verdana, Arial, Helvetica, sans-serif;
	line-height: 100%;
	color: #0000FF;
	background-color: #FFF;
	font-weight: normal;
	text-transform: uppercase;
	text-decoration:none;
}
a.navtertiary:link  { color: #0000FF; text-decoration: none;}
a.navtertiary:visited { color: #0000FF; text-decoration: none;}
a.navtertiary:active { color: #0000FF; text-decoration: none;}
a.navtertiary:hover { color: #333;	text-decoration: none;}


.H1 {
	font-family: Arial, Helvetica, sans-serif;
	font-size: 160%;
	line-height: 100%;
	color: #535353; background-color: #E0E0E0;
	padding-top: 8px; 
	padding-left: 31px;
}
.H2 {
	font-size: 18px;
	font-weight: bold;
	color: black; background-color:#fff;
	line-height: 130%; 
	text-align:left;
}
.H2-bigger {
	font-size: 28px;
	font-weight: bolder;
	color: black;
	background-color: #fff;
	line-height: 28px;
	text-align: left;
}
.H2-biggest {
	font-size: 40px;
	font-weight: bolder;
	color: black;
	background-color: #fff;
	
}
/* Legacy footer class - kept for compatibility */
.footer {
	text-align: left;
	font-size: 70%;
	line-height: 160%;
	color: #333;
	background-color: #E0E0E0;
	font-family: Arial, Helvetica, sans-serif;
	padding-right: 10px;
	padding-left: 10px;
}

/* Modern Footer Styles */
.footer-container {
	max-width: 705px;
	margin: 0 auto 10px;
	padding: 20px;
	background-color: #E0E0E0;
	font-family: Arial, Helvetica, sans-serif;
	color: #333;
}

.footer-main {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 20px;
	align-items: start;
	margin-bottom: 20px;
}

.footer-content {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.footer-info {
	font-size: 12px;
	line-height: 1.6;
}

.footer-update,
.footer-credit {
	margin: 0 0 5px 0;
}

.footer-links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 12px;
	font-size: 12px;
	line-height: 1.6;
}

.footer-links a {
	white-space: nowrap;
}

.footer-links a:not(:last-child)::after {
	content: "|";
	margin-left: 12px;
	color: #333;
	text-decoration: none;
}

.footer-logo {
	flex-shrink: 0;
}

.footer-logo img {
	display: block;
	width: 107px;
	height: 107px;
}

.footer-site-links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 12px;
	padding-top: 15px;
	border-top: 1px solid #ccc;
	font-size: 12px;
	line-height: 1.6;
}

.footer-site-links a:not(:last-child)::after {
	content: "|";
	margin-left: 12px;
	color: #333;
	text-decoration: none;
}

/* Responsive Footer Styles */
@media only screen and (max-width: 968px) {
	.footer-container {
		max-width: 100%;
		padding: 15px;
	}
}

@media only screen and (max-width: 600px) {
	.footer-main {
		grid-template-columns: 1fr;
		gap: 15px;
	}
	
	.footer-logo {
		text-align: center;
	}
	
	.footer-logo img {
		margin: 0 auto;
	}
	
	.footer-links,
	.footer-site-links {
		flex-direction: column;
		gap: 8px;
	}
	
	.footer-links a:not(:last-child)::after,
	.footer-site-links a:not(:last-child)::after {
		content: "";
		margin-left: 0;
	}
}


.go {
	font-size: 11px;
	font-family:Arial, Helvetica, sans-serif;
	color: #999; background-color: #111F39;
	font-weight: bold;
	text-align: center;
	text-transform: uppercase;
	padding-bottom: 10px;
}
.H3 {

	font-size: 16px;
	font-weight: bold;
	color: #D65434; /*background-color:#fff; */
	line-height: 130%; text-align:left;
}

.H3A {

	font-size: 130%;
	font-weight: bold;
	color: #D65434; background-color:#fff;
	line-height: 150%; text-align:left;
}

.H3-Center {
	font-size: 100%;
	font-weight: bold;
	color: #D65434; background-color:#fff;
	line-height: 130%; text-align:center;
}

.H4 {

	font-size: 110%;
	font-weight: bold;
	color: #339933; background-color:#fff;
}
.H5 {
	font-size: 105%;
	font-weight: bold;
	color: #000;
	background-color:#fff;
	text-transform: uppercase;
}
.exitlink {
	font-size: 85%;
	line-height: 160%;
	color: #FF6600;
	background-color: #FFF;
	font-weight: bold;
}
.clear {clear: both;}
img.floatRight { 
    float: right; 
	margin: 10px 0 10px 20px;}
img.floatLeft {
	float: left;
	margin-top: 10px;
	margin-right: 20px;
	margin-bottom: 10px;
	margin-left: 0;
}
.job-alert-table {
	background-color: #FFFFCC;
	border: 2px solid #000066;
}
.job-alert-table-alert-text {
	font-size: 18px;
	line-height: 26px;
	font-weight: bold;
	color: #000033;
	text-align: center;
}

#pagination li {
list-style-image:none;
list-style-position:outside;
list-style-type:none;
display:inline;
margin: 3px;
}
#pagination ul {margin-left: 0; padding-left: 0;}
.current a {
background:#999999;
color:#FFFFFF;
text-decoration:none;
padding: 3px;
}
.fa-browse-table-header {
	font-size: 12px;
	font-weight: normal;
	background-color: #255981;
	color: #FFFFFF;
}
.fa-browse-table-data {
	font-size: 12px;
	font-weight: normal;
	background-color: #CCCCCC;
	color: #000000;
	background-image: none;
}
.dk-red-text {
	color: #660000;
}

.fa-browse-table-data-darker {
	font-size: 12px;
	font-weight: normal;
	background-color: #999999;
	color: #000000;
	background-image: none;
}

/*
////////////////////////////////////////
	Start of feather atlas modifications
/////////////////////////////////////////
	

*/

.full-page-content {
	/* This padding with background color replaces the shim */
	width:968px;
	padding-bottom: 10px;
	background-color: #666;
	padding-left: 10px;
	padding-right: 10px;
	margin-left:auto;
	margin-right:auto;
}

.fa-contentbox {
	width:928px;
	min-height: 830px;
	border: 1px solid #999; 
	color: black; 
	background-color: #fff;
	line-height:170%;
	margin-top: 0px;
	margin-bottom: 20px;
	margin-left:auto;
	margin-right:auto;
	padding: 10px;
	}

.fa-logo {
	width:95%;
}
.fa-logo-small {
	display:none;
}

/* Legacy footer-box class - kept for compatibility */
.footer-box {
	width: 95%;
	padding-left: 10px;
	padding-right: 10px;
	padding-bottom: 10px;
	padding-top: 10px;
	background-color: #E0E0E0;
	margin-bottom:10px;
}

.disappear-on-mobile {
		display:inline-block;
		
	}
	
.kicker {
	display:none;
}

/*
////////////////////////////////////////
	menu for all pages
/////////////////////////////////////////
*/

.fa-navsub {
	font-size: 12px;
	font-family: Tahoma, Geneva, sans-serif;
	line-height: 100%;
	color: #FFFFFF;
	font-weight: bold;
	text-decoration:none;
	text-align: center;
	background-color: #255981;
	width: 100%;
	height:33px;
}

a.fa-navsub:link  { color: #FFFFFF; text-decoration: none;}
a.fa-navsub:visited { color: #FFFFFF; text-decoration: none;}
a.fa-navsub:active { color: #FFFFFF; text-decoration: none;}
a.fa-navsub:hover { color: #c5c5c5;	text-decoration: none;}
	
.fa-nav-icon {
	display: none;
	position: fixed;
	z-index: 8;
	top:103px;
	height:33px;
	width: 100%;
	background: #255981;
}

.bar1, .bar2, .bar3 {
  width: 35px;
  height: 3px;
  background-color:  #FFFFFF;
  margin: 6px;
  transition: 0.4s;
}

/* The side navigation menu */
.sidenav {
  height: 100%; 
  width: 0;
  position: fixed; 
  z-index: 9; 
  top: 0;
  left: 0;
  background-color: #255981; 
 overflow: hidden;
  padding-top: 60px; 
  transition: 0.9s;
}

/* The navigation menu links */
.sidenav a {
  padding: 8px 8px 8px 16px;
	line-height: 100%;
	font-family:Arial, Helvetica, sans-serif;
  text-decoration: none;
  font-size: 20px;
  color: #b8b8b8;
  display: block;
  transition: 0.3s;
}

/* When you mouse over the navigation links, change their color */
.sidenav a:hover {
  color: #f1f1f1;
}

/* Position and style the close button (top right corner) */
.sidenav .closebtn {
  position: absolute;
  top: 0;
  right: 25px;
  font-size: 36px;
  margin-left: 50px;
}


/* menu dropdown */

.dropdown-content {
  display: none;
  position: absolute;
  background-color: #255981;
  min-width: 160px;
  box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
  z-index: 1;
}

.dropdown-content a {
  float: none;
  color: #FFFFFF;
  padding: 12px 16px;
  display: block;
  font-size: 12px;
	font-family: Tahoma, Geneva, sans-serif;
	line-height: 100%;
	font-weight: bold;
	text-decoration:none;
	text-align: center;
}

.show {
  display: block;
}


/* size changing options */

@media only screen and (max-width: 968px) {
	.fa-navsub {
	width: 100%;
	}
}

@media only screen and (max-width: 600px) {
	.fa-nav-icon {
		display: inline-block;
		cursor: pointer;
	}
	.fa-navsub {
		display: none;
	}
}

@media screen and (max-height: 450px) {
	.sidenav {padding-top: 15px;}
	.sidenav a {font-size: 18px;}
}



/*
////////////////////////////////////////
	ID Tool page
/////////////////////////////////////////
*/


.buttonSection {
	margin-right:auto;
	margin-left:auto;
	padding-left:15px;
	padding-right:15px;
	text-align:center;
	align-content:center;
	font-size: 17px;
	line-height: 120%;
}

/* Action buttons bar - positioned after filter selection buttons */
.action-buttons-bar {
	margin: 20px 0;
	padding: 15px 0;
	text-align: center;
	background-color: #f9f9f9;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
}

.btngrp {
	margin-bottom: 10px;
}

.patternButton, .colorButton, .sizeButton, .featherTypeButton, .birdTypeButton {
	padding: 5px 7px; /* Some padding */
	border-radius: 5px;
}

.buttonIcon {
	width:100px;
	height:auto;
	border-radius: 5px;
}

/* Style the  panels  */
.instructionsPanel {
  background-color: #eee;
  width: 100%;
  border: none;
  outline: none;
  overflow:auto;
  text-align: center;
}
.patternPanel, .colorPanel, .sizePanel, .fTypePanel, .bTypePanel{
  background-color: #eee;
  width: 100%;
  border: none;
  outline: none;
  display: none;
  margin-bottom: 20px;
  text-align: center;
  overflow:auto;
}

.fTypeSelector{
	width:70%;
	margin-left:auto;
	margin-right:auto;
	position: relative;
	display: inline-block;
}

#featherTypeImage{
	width:100%;
	height:auto;
	display: block;
	margin: 0;
}

.bTypePanel li {
	line-height:1em;
    min-height:2em;
	
}


/* Style the individual sections for the pattern options */

.items {
	list-style-type: none;
	padding: 0px;
}

.patternOption {
	display: inline-block;
	margin: 5px;
	/* width: 30%; */
	vertical-align: top;
}
.patternImg {
	width:100%;
	height:auto;
	border-radius: 5px;
  	cursor: pointer;
  	transition: 0.3s;
}

.instructions {
	margin: 5px;
}

.colorRow {
	text-align: center;
}
.colorOption {
	margin: 5px;
	width: 30%;
	display: inline-block;
	vertical-align: top; 
}

.colorImg {
	width:100%;
	height:auto;
	border-radius: 5px;
  	cursor: pointer;
	transition: 0.3s;
}





/*
////////////////////////////////////////
	Browse pages
/////////////////////////////////////////
*/

.browseImg {
	width: 100%;
	height: auto;
}

/* Grid container for browse items */
#browse-container {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 15px;
	justify-items: center;
	padding: 10px;
	max-width: 900px;
	margin: 0 auto;
}

.browseItem {
	width: 140px;
	min-height: 200px;
	display: flex;
	flex-direction: column;
	padding: 10px;
	font-size: 12px;
	text-align: center;
	box-sizing: border-box;
}

.browseItem > div {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
}

.browseItem a {
	display: block;
	text-align: center;
	margin-bottom: 5px;
}

.browseItem img {
	margin-bottom: 8px;
}

/*
////////////////////////////////////////
	search page
/////////////////////////////////////////
*/

.searchInput {
	width: 400px;
}

/* Modern form layout styles */
.form-group {
	display: flex;
	align-items: center;
	margin-bottom: 15px;
	gap: 10px;
}

.form-group label {
	min-width: 150px;
	text-align: right;
	flex-shrink: 0;
}

.form-group input {
	flex: 1;
	max-width: 400px;
}

.form-group button {
	margin-left: 160px;
}

/*
////////////////////////////////////////
	index page
/////////////////////////////////////////
*/

.homeInstructions {
	width: 66%;
	
}

.idButtons {
	display:inline-block;
}
/* Style tab links */
.tablink {
  color: white;
  vertical-align: middle;
  border: none;
  outline: none;	
  font-size: 17px;
   font-weight: bold;
  width: 30%;
  
}


/*
////////////////////////////////////////
	Below is transferred from old mobile styles sheet
/////////////////////////////////////////
*/

/*
////////////////////////////////////////
	All pages
/////////////////////////////////////////
	

*/

@media only screen and (max-width: 968px) {
	.full-page-content {
		width:100%;
		padding-left: 0px;
		padding-right: 0px;
	}	
	.fa-logo {
		width :95%;
	}
	
	.fa-contentbox {
		padding: 10px 5px 10px 5px;
		width: 95%;
	}
	.fa-logo {
		display:none;
	}
	.fa-logo-small {
		width:85%;
		display:block;
	}
	.footer-box {
	width: 100%;
	}
	.full-size-images {
		width:100%;
		height:auto;
	}
	.disappear-on-mobile {
		display:none;
		width: 0%;
	}
}


@media only screen and (max-width: 600px) {
	#logo {
	text-indent: 0;
	}
	
	#fwsbar {
		text-indent: 90px;
		font-size: 15px;
	}
	#fwsbarhome {
	}
	
	#sitename {
		text-indent: 90px;
		font-size: 20px;
	}
	
	.fa-contentbox {
		padding: 10px 5px 10px 5px;
		width: 95%;
	}
	.title-area {
		z-index: 8;
		position: fixed;
		top: 0px;
		left: 0px;
	}
	
	.fa-logo-small {
		margin-top: 133px;
	}
	
	
}


/*
////////////////////////////////////////
	ID Tool page
/////////////////////////////////////////
*/

.fTypeSelector {
		display: block;
	}
	.fTypeSelectorMobile {
		display: none;
}

@media only screen and (max-width: 968px) {
	#featherTypeImage{
		display:block;
		float:none;
		margin:0;
	}
}

@media only screen and (max-width: 600px) {
	/* style array of buttons */
	.patternButton, .colorButton, .sizeButton, .featherTypeButton, .birdTypeButton {
		
	}

	.fTypeSelector{
		width:100%;
	}
	
	.patternOption {
		float: left;
		margin: 3px;
		width: 45%;
	}
	.colorOption {
	margin: 3px;
	width: 30%;
	}
}

.featherTypeSelector {
	font-size: 14px;
	white-space: nowrap;
}

.nextButton, .submitButton {
	font-size: 18px; 
	font-weight: bold; 
	color: #000033; 
	text-align: center; 
	margin-bottom:10px;
}

/*
////////////////////////////////////////
	id results pages
/////////////////////////////////////////
*/

.singleResult {
	margin:10px;
	width: 30%;
	height:auto;
	display:inline-block;
	vertical-align: top;
}
.resultImg {
	width:100%;
	height:auto;
	border-radius: 5px;
  	cursor: pointer;
  	transition: 0.3s;
}
@media only screen and (max-width: 720px) {
	.singleResult {
		width: 45%;
		margin: 5px;
	}
}

/*
////////////////////////////////////////
	browse feathers pages
/////////////////////////////////////////
*/

@media only screen and (max-width: 670px) {
	.browse-table {
		width:100%;
	}
	
	#browse-container {
		grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
		gap: 10px;
		padding: 5px;
	}
	
	.browseItem {
		width: 120px;
		min-height: 180px;
		padding: 8px;
		font-size: 11px;
	}
}

/*
////////////////////////////////////////
	id position page
/////////////////////////////////////////
*/

.featherDescriptions {
				display:inline-block; 
				width:33%;
				vertical-align: top;
			}
			@media only screen and (max-width: 968px) {
				.featherDescriptions {
					width:45%;
				}
			}
			@media only screen and (max-width: 740px) {
				.featherDescriptions {
					width:100%;
				}
			}


/*
////////////////////////////////////////
	Glossary page
/////////////////////////////////////////
*/

@media only screen and (max-width: 968px) {
	.two-thirds-size-images {
		width:66%;
		height:auto;
	}
}
@media only screen and (max-width: 600px) {
	.two-thirds-size-images {
		width:100%;
		height:auto;
	}
}

/*
////////////////////////////////////////
	individual feather page
/////////////////////////////////////////
*/

.featherTable  {
	overflow-x: hidden;
}
.featherTable td {
	padding: 10px;
}

.mainFeatherImage {
	width: 100%;
	height: auto;
}

.additionalTable {
	width:80%;
}

@media only screen and (max-width: 670px) {
	.additionalTable {
	width:100%;
}
}

/*
////////////////////////////////////////
	search page
/////////////////////////////////////////
*/


@media only screen and (max-width: 600px) {
	.searchInput {
		width:100%;
	}
	
	.form-group {
		flex-direction: column;
		align-items: flex-start;
		gap: 5px;
	}
	
	.form-group label {
		min-width: auto;
		text-align: left;
	}
	
	.form-group input {
		width: 100%;
		max-width: 100%;
	}
	
	.form-group button {
		margin-left: 0;
		width: 100%;
	}
}

/*
////////////////////////////////////////
	index page
/////////////////////////////////////////
*/
@media only screen and (max-width: 968px) {
	.homeInstructions {
	width:100%;
}
}

/*
////////////////////////////////////////
	faq page
/////////////////////////////////////////
*/
	.screenFAQ {
		display: block;
	}
	.mobileFAQ {
		display: none;
	}

/*
////////////////////////////////////////
	Section 508 Accessibility - Focus Indicators
	Phase 1.1: Visible keyboard focus styles
/////////////////////////////////////////
*/

/* Base focus styles for all interactive elements */
a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus,
label:focus,
.tablink:focus,
.patternButton:focus,
.colorButton:focus,
.sizeButton:focus,
.featherTypeButton:focus,
.birdTypeButton:focus,
.nextButton:focus,
.submitButton:focus {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

/* Modern browsers: only show focus for keyboard navigation */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
label:focus-visible,
.tablink:focus-visible,
.patternButton:focus-visible,
.colorButton:focus-visible,
.sizeButton:focus-visible,
.featherTypeButton:focus-visible,
.birdTypeButton:focus-visible,
.nextButton:focus-visible,
.submitButton:focus-visible {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

/* Remove focus outline for mouse users in modern browsers */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible),
input:focus:not(:focus-visible),
select:focus:not(:focus-visible),
textarea:focus:not(:focus-visible),
label:focus:not(:focus-visible),
.tablink:focus:not(:focus-visible),
.patternButton:focus:not(:focus-visible),
.colorButton:focus:not(:focus-visible),
.sizeButton:focus:not(:focus-visible),
.featherTypeButton:focus:not(:focus-visible),
.birdTypeButton:focus:not(:focus-visible),
.nextButton:focus:not(:focus-visible),
.submitButton:focus:not(:focus-visible) {
	outline: none;
}

/* Enhanced focus for navigation links on dark backgrounds */
a.nav:focus,
a.navsub:focus,
a.fa-navsub:focus,
.sidenav a:focus {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

a.nav:focus-visible,
a.navsub:focus-visible,
a.fa-navsub:focus-visible,
.sidenav a:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

a.nav:focus:not(:focus-visible),
a.navsub:focus:not(:focus-visible),
a.fa-navsub:focus:not(:focus-visible),
.sidenav a:focus:not(:focus-visible) {
	outline: none;
}

/* Focus for clickable images */
img[onclick]:focus,
img[role="button"]:focus,
.patternImg:focus,
.colorImg:focus,
.resultImg:focus,
.browseImg:focus {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
	box-shadow: 0 0 0 4px rgba(0, 102, 204, 0.2);
}

img[onclick]:focus-visible,
img[role="button"]:focus-visible,
.patternImg:focus-visible,
.colorImg:focus-visible,
.resultImg:focus-visible,
.browseImg:focus-visible {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
	box-shadow: 0 0 0 4px rgba(0, 102, 204, 0.2);
}

img[onclick]:focus:not(:focus-visible),
img[role="button"]:focus:not(:focus-visible),
.patternImg:focus:not(:focus-visible),
.colorImg:focus:not(:focus-visible),
.resultImg:focus:not(:focus-visible),
.browseImg:focus:not(:focus-visible) {
	outline: none;
	box-shadow: none;
}

/* Focus for mobile menu hamburger icon */
.fa-nav-icon:focus {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

.fa-nav-icon:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

.fa-nav-icon:focus:not(:focus-visible) {
	outline: none;
}

/* Focus for dropdown menu items */
.dropdown-content a:focus {
	outline: 2px solid #ffffff;
	outline-offset: -2px;
	background-color: rgba(255, 255, 255, 0.1);
}

.dropdown-content a:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: -2px;
	background-color: rgba(255, 255, 255, 0.1);
}

.dropdown-content a:focus:not(:focus-visible) {
	outline: none;
	background-color: transparent;
}

/* Ensure focus indicators work on form elements */
input[type="text"]:focus,
input[type="search"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="checkbox"]:focus,
input[type="radio"]:focus,
select:focus,
textarea:focus {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
	border-color: #0066cc;
}

input[type="text"]:focus-visible,
input[type="search"]:focus-visible,
input[type="email"]:focus-visible,
input[type="tel"]:focus-visible,
input[type="number"]:focus-visible,
input[type="checkbox"]:focus-visible,
input[type="radio"]:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
	border-color: #0066cc;
}

input[type="text"]:focus:not(:focus-visible),
input[type="search"]:focus:not(:focus-visible),
input[type="email"]:focus:not(:focus-visible),
input[type="tel"]:focus:not(:focus-visible),
input[type="number"]:focus:not(:focus-visible),
input[type="checkbox"]:focus:not(:focus-visible),
input[type="radio"]:focus:not(:focus-visible),
select:focus:not(:focus-visible),
textarea:focus:not(:focus-visible) {
	outline: none;
}

/* Focus for browse items */
.browseItem a:focus {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
	border-radius: 3px;
}

.browseItem a:focus-visible {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
	border-radius: 3px;
}

.browseItem a:focus:not(:focus-visible) {
	outline: none;
}

/* Focus for close button in sidenav */
.sidenav .closebtn:focus {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

.sidenav .closebtn:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

.sidenav .closebtn:focus:not(:focus-visible) {
	outline: none;
}

/* High contrast mode support - ensures focus is visible in Windows High Contrast Mode */
@media (prefers-contrast: high) {
	a:focus,
	button:focus,
	input:focus,
	select:focus,
	textarea:focus,
	label:focus {
		outline: 3px solid;
		outline-offset: 2px;
	}
}


