/*
AUTHOR:				Sheen Mathew Justin, US Small Business Administration. 
DATE:				05/18/2021
DESCRIPTION:		CSS Styling to be applied to the home page. 
NOTES:
INPUT:				None. 
OUTPUT:				CSS styling for the home page.
REVISION HISTORY:	05/18/2021, SMJ:	OPSDEV-2586:	Original implementation. 
*/

/*
	CSS  Variables are amazing. Use them as much as you can
	Especially for colors, there should be no reason to go hunting for every instance of a color again.
*/
:root {
	/* The offical SBA colors according to branding guidelines */
	--sba-red: hsl(0, 100%, 40%);
	--sba-white: hsl(0, 0%, 100%);
	--sba-blue: hsl(215, 100%, 21%);
	--sba-gray: hsl(0, 0%, 59%);

	/* Secondary SBA colors according to branding guidelines */
	--sba-light-blue: hsl(200, 100%, 37%);
	--sba-black: hsl(227, 21%, 13%);
	--sba-yellow: hsl(49, 100%, 47%);
	--sba-green:hsl(151, 67%, 30%);

	/* 
		use semantic variables as much as possible instead of directly
		referring to color variables. Makes it easier to hotswap colors
	*/
	--clr-err:var(--sba-red);
	--clr-warn:var(--sba-yellow);
	--clr-comm:var(--sba-green);
	--clr-dis: var(--sba-gray);

	--clr-bg: var(--sba-white);
	--clr-card-bg: var(--sba-white);

	--clr-text: var(--sba-black);
	--clr-link: var(--sba-blue);
	--clr-heading: var(--sba-blue);

	--clr-accent:var(--sba-red);
	--clr-card-accent:var(--sba-blue);

	--padding: 1rem;
	--margin: 2rem;

	--col-width: 250px;
	--card-width: 200px;
	--middle-col-width: 556px;
	/* Combined with middle-col-width above makes gallery ~16/9 ratio */
	--gallery-height: 313px;

	/* At some point maybe create different shadows to indicate hierarchy */
	--sba-shadow: 0 7px 15px 0 hsla(0, 0%, 0%, 0.1);
}
  
* {
	color: var(--clr-text);
}

*, *::before, *::after{
	box-sizing: border-box;
	font-family: "Source Sans Pro", "Helvetica", "Arial", sans-serif;
}

*::before, *::after {
	transition: all .2s ease;
}

.body {
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	margin: 0;
	padding: 0;
	min-height: 100vh;
	background-color: var(--clr-bg);
	font-weight: 100;
	font-size: 16px;
}

h1, h2, h3, h4, h5, h6,
h1 *, h2 *, h3 *, h4 *, h5 *, h6 * {
	font-weight: 900;
	--clr-text: var(--clr-heading);
}

a {
	text-decoration: none;
	--clr-text: var(--clr-link);
	font-weight: 400;
}

a *{
	text-decoration: none;
	-clr-text: var(--clr-link);
}

a:focus,
a:hover {
	box-shadow: inset 0px -3px 0px var(--clr-accent);
	transition: all .2s cubic-bezier(.33,.66,.66,1);
}

input:not([type="radio"],[type="checkbox"]) {
	padding: .75rem 10px;
}

[type="checkbox"]
{
    vertical-align: top;;
}

button,
.button,
.close-modal,
[type="button"],
[type="reset"],
[type="submit"]{
  text-decoration: none;
  cursor: pointer;
  --clr-text: var(--sba-white);
  border: 0 none;

  background-color: var(--clr-link);

  font-size: 1rem;
  font-weight: 700;
  padding: .9rem 4rem;
}

button:hover,
.button:hover,
.close-modal:hover,
[type="reset"]:hover,
[type="button"]:hover,
[type="submit"]:hover,
button:focus,
.button:focus,
.close-modal:focus,
[type="reset"]:focus,
[type="button"]:focus,
[type="submit"]:focus{
    filter: brightness(130%);
}

.button:active,
.close-modal:active,
button:active,
[type="button"]:active,
[type="reset"]:active,
[type="submit"]:active {
    filter: brightness(60%);
}

.close-modal:disabled,
.button:disabled,
button:disabled,
input:disabled,
input:disabled:hover,
form:invalid [type=submit] {
  cursor: default;

  --clr-text: var(--sba-black);
  background-color: var(--clr-dis);
  filter: brightness(100%);
}


input,
label {
	transition: All .4s ease;
}

input:focus,
[type=radio]:focus+label  {
	box-shadow: 0 0 3px var(--sba-blue), 
				0 0 7px var(--sba-blue);
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	border: 0;
}

.errors {
	flex-basis: 100%;
	display: grid;
	place-items: center;
	margin: var(--padding);
}

.newclsmsg {
	display: grid;
	grid-auto-flow: column;
	place-items: center;
	margin: var(--padding);
	max-width: var(--middle-col-width);

	--clr-text: var(--sba-white);
	box-shadow: var(--sba-shadow);
}

.newclsmsg > * {
	padding: var(--padding);
}

.newclsmsg .close {
	 position: relative;

	background-color: inherit;
	min-height: 100%;

	padding: var(--padding) calc( var(--padding) / 4);

	--clr-text: rgba(0,0,0,0);
}

.close:hover, .close:focus {
	box-shadow: none;
}
  
.newclsmsg .close::after {
	content: "×";
	font-weight: 900;
	font-size: 2rem;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: var(--sba-white);
}

.msg-warning {
	--clr-text: var(--sba-black);
	background-color: var(--clr-warn);
}

.msg-warning .close::after {
	color: var(--sba-black);
}

.msg-commentary {
	background-color: var(--clr-comm);
}

.msg-error {
	background-color: var(--clr-err);
}

.newclsmsg::before {
	font-weight: bold;
	display: grid;
	place-items: center;
	padding: var(--padding);
}

.msg-error::before {
	content: 'Error(s): ';
}

.msg-warning::before {
	content: 'Warning(s): ';
}

.msg-commentary::before {
	content: 'Info: ';
}

.newclsmanddata {
	border: 2px solid var(--sba-blue);
}
  
.newclsmanddata-error {
	border-color: var(--clr-err);
}
  
.newclsmanddata-error::before {
	content: "";
	color: var(--clr-err);
	/* font-weight: bold; */
}
  
.newclsmandlabel-error {
	--clr-text: var(--clr-err);
	font-weight: bold;
}

.newclsmandlabel::before {
	content: "*";
	color: var(--clr-accent);
}

:user-invalid {
	--clr-text: var(--clr-err);
	border-color: var(--clr-err);
}

.cta,
.close-modal,
#LogOutBtn,
[type="submit"] {
	--clr-link: var(--clr-accent);
}

#skip-navigation {
	position: absolute;
	top: -100%;
	left: -100%;
	color: transparent;
}

#incompat {
	display: none;
}

/* HEADER STYLES */
#header-container{
	/* border-bottom: 5px solid var(--clr-card-accent); */
	padding: var(--padding) var(--margin); 	
	box-shadow: var(--sba-shadow);
	width: 100%;
	background-color: var(--clr-card-bg);
}
header {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
}

header > * {
	flex: 1;
	display: grid;
	place-items: center;
}

header > .logo-container {
	place-items: center left;
}

header > nav {
	place-items: center right;
}

header .logo-container svg{
	width: 250px;
	height: 70px;
	fill: var(--clr-heading);
}

header > h1 {
	flex: 3;
	word-spacing: 5px;
	font-size: 2.5rem;
	font-variant: small-caps;
	text-align: center;
}

header > h1 a,
header > h1 span {
	font-weight: 400;
	text-shadow: 1px 1px 1px var(--sba-black);
}
/* HEADER STYLES */

/* FOOTER */
#footer-container {}

footer {
	text-align: center;
	position: relative;
}

#footer-links {
	max-width: var(--middle-col-width);
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	padding:  calc(2 * var(--padding) );
	text-align: center;
	gap: var(--padding)
}

#AppTimeout {
	flex: 1;
	flex-basis: 100%;
}

.prompt {
	z-index: 999 !important;
}

/* Main content */

main {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--margin);
	margin: var(--margin);
	margin-top: 0;
}

.col {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--margin);
	min-width: var(--col-width);
}

#col2 {
	max-width: var(--middle-col-width);
	flex: 2;
}

.card {
	box-shadow: var(--sba-shadow);
	padding: var(--padding);
	min-width: var(--card-width);
	border-top: 5px solid var(--clr-card-accent);

	background-color: var(--clr-card-bg);
}


.card > h2 {
	padding: 0;
	margin: 0 var(--margin);
	
	text-align: center;
}

.card > h2::after {
	content: '';
	display: block;
	border-bottom: 2px solid var(--clr-accent);
	width: calc(var(--padding) * 3);

	margin: 0 auto;
	margin-top: var(--padding);
}

.card a {
	overflow-wrap: break-word;
}

/* Login */

#login-container {
	margin-top: calc( var(--margin) * 1);
}
.UnderstandAndConsent {
	display: none;
}

/* .UnderstandAndConsent			{font-size: 10px;} */
.UnderstandAndConsent ol		{list-style: none; margin-left: -30px;}
.UnderstandAndConsent li		{counter-increment: section;}
.UnderstandAndConsent li:before	{content: "(" counter(section) ") ";}
#padding 						{text-align: center;}
#pwdlnksleft 					{margin: var(--padding);}

.inputlogpass {
	display: flex;
	flex-direction: column;
	gap: var(--padding);
}

#radiotxt {
	text-align: center;
}

.clsnew_submit button {
	width: 100%;
	margin-top: var(--padding);
}

#login .inputlogpass .newclsmandlabel {
	position: relative;
	left: -9900px;
}
  
#login .inputlogpass .newclsmandlabel-error {
	left: 0;
	transition        : All .4s ease;
}

#AnswerLbl {
	display: inline-block;
}

/* PIN */

#contactmodes button, #contactmodes input:not([type=radio]) {
	/* border-radius: 3px; */
	/* padding: .5rem 1rem; */
	white-space: normal;
	word-wrap: break-word;
	margin-bottom: var(--padding);
}

fieldset {
	border: 0;
	margin: var(--padding) 0;
	padding: 0;
}

fieldset input,
fieldset,
fieldset a.button {
	width: 100%;
}

legend {
	color: inherit;
	margin-bottom: var(--padding);
}

#contactmodes input[type=radio] {
	opacity: 0;
	position: fixed;
	width: 0;
	margin: 0;
}

[name="ContactMode"] {
	display: block;
	background-color: var(--sba-white);
	--clr-text: var(--sba-blue);
	padding: .5rem 1rem;
	padding: 10px 20px;
	font-family: sans-serif, Arial;
	/*font-size: 16px;*/
	border: 2px solid var(--sba-blue);
	/* border-radius: 4px; */
	margin: 0;
	/* margin-bottom: calc( -1.6 * var(--padding)); */
	cursor: pointer;
	z-index: 998;
	width: 100%;
}

[name="ContactMode"]:focus,
[name="ContactMode"]:hover {
	background-color: var(--sba-blue);
	--clr-text: var(--sba-white);
	z-index: 999;
}

[name="ContactMode"]:active{
	filter: brightness(40%);
}

.newclsmandlabel {
	display: block;
	margin-bottom: .25rem;
}



#skipform{
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
	margin-bottom: var(--padding);
}

#skip2FAPin, #back_button {
	border: 0;
	padding: 0;
	background-color: inherit;
	--clr-text: var(--clr-heading);
	width: inherit;
}
#skip2FAPin::after, #back_button::before {
	content: "";
	display: inline-block;
	color: inherit;
	width: 0.4em;
	height: 0.4em;
	border-right: 0.15em solid var(--clr-heading);
	border-top: 0.15em solid var(--clr-heading);
	margin-bottom: 1px;
}

#skip2FAPin::after {
	transform: rotate(45deg);
}

#back_button {
	display: none;
}

#back_button::before {
	transform: rotate(-135deg);
}

#skip2FAPin:hover, #back_button:hover {
	transition: all .2s cubic-bezier(.33,.66,.66,1);
	box-shadow: inset 0 -4px 0 var(--sba-red);
}

#Send2FAPin {
	opacity: 0;
	position: fixed;
	width: 0 !important;
	margin-left: -99999em;
}

/* modal */
.modal-background, .blocker  {
	background-color: hsla(0, 0%, 0%, 0.5);
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
}
.modal {
	background-color: var(--clr-card-bg);
	box-shadow: var(--sba-shadow);
	position: absolute;
	top: 90px;
	left: 50%;
	transform: translateX(-50%);
	width: calc( var(--middle-col-width) - var(--margin) );
	/* padding: var(--padding); */
}

.close-modal {
	position: absolute;
	bottom: var(--padding);
	left: 50%;
	transform: translateX(-50%);
}

.modal .ratio {
	width: 100%;
	padding: 0;
	padding-top: 56.25%; /* 1:1 Aspect Ratio */
	position: relative; /* If you want text inside of it */
}

.modal .ratio p {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	padding: var(--margin);
	display: grid;
}

/* buttonbar */

.buttonbar span.icon{
	--clr-text:var(--clr-link);
}

.buttonbar span.icon::before,
.buttonbar span.icon::after {
	font-family: "FontAwesome";
}

.buttonbar span.icon:hover,
.buttonbar span.icon:focus {
	--clr-text:var(--clr-accent);
}

/* Media Queries */

@media (prefers-color-scheme: dark) {
	:root{

		--clr-bg: #333;
		--clr-card-bg: #444;

		--clr-text: var(--sba-white);
		--clr-link: var(--sba-white);
		/* --clr-card-accent: var(--sba-light-blue); */
		--clr-heading: var(--sba-white);
	}

	input,
	select {
		--clr-text: var(--sba-black);
	}

	button,
	.button,
	[type="button"],
	[type="reset"] {
		--clr-link: var(--sba-blue);
	}

	.cta,
	.close-modal,
	#LogOutBtn,
	[type="submit"] {
		--clr-link: var(--clr-accent);
	}
}

@media only screen and (max-width: 1024px) {
	main {
		max-width: var(--middle-col-width);
		margin: 0 auto;
	}

	header svg {
		margin-bottom: var(--padding);
	}

	header > * {
		flex-basis: 100%;
		margin-top: var(--padding)
	}
	header > h1,
	#gallery-container  {
		display: none;
	}
	#choosefunction .category {
		position: static;
	}
}
