.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

fieldset {
	border: none;
	padding: 0px;
	margin: 0 0 25px 0;
}

legend {
	padding: 0 5px;
	font-weight: bold;
}

button {
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
}

button:focus, button:hover {
	outline: 2px solid #0066cc;
}

input:focus, select:focus {
	outline: 2px solid #0066cc;
}

h1 {
	font-size: 1.2em;
	color: #003366;
	margin-bottom: 10px;
}

h2 {
	font-size: 1.2em;
	color: #003366;
	margin-bottom: 10px;
}

table {
	border-collapse: collapse;
}

.blue-table-container {
	border: 2px solid #2C68B1;
	background-color: #FFFFFF;
	padding: 8px;
	margin: 0px;
	border-collapse: separate;
	border-spacing: 0;
}

.header-container {
	width: 600px;
}

.header-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.header-logo-section {
	flex: 0 0 250px;
}

.header-title-section {
	flex: 1;
	text-align: left;
}

.header-separator {
	background-color: #253980;
	height: 20px;
	width: 100%;
	margin-top: 8px;
}

.header-spacer {
	height: 20px;
	width: 100%;
}

.form-introduction {
	width: 600px;
}

.form-introduction-content {
	text-align: left;
}

.date-selection-container {
	margin-bottom: 0px;
}

.date-selection-row {
	display: flex;
	align-items: center;
	margin-bottom: 5px;
}

.date-radio-column {
	width: 29px;
	text-align: center;
}

.date-label-column {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 10px;
}

.date-inputs {
	display: flex;
	align-items: center;
	gap: 5px;
}

.form-section {
	margin-bottom: 10px;
}

.form-row {
	display: flex;
	align-items: flex-end;
	gap: 10px;
	margin-bottom: 0px;
}

.form-field {
	display: flex;
	flex-direction: column;
}

.form-field label {
	margin-bottom: 0px;
	font-weight: normal;
	white-space: nowrap;
}

.form-field-very-small {
	width: 26px;
}

.form-field-small {
	width: 60px;
}

.form-field-medium {
	width: 130px;
}

.form-field-large {
	width: 250px;
}

.form-field-full {
	flex: 1;
}

.ssn-group {
	display: flex;
	align-items: center;
	gap: 4px;
}

.address-section {
	margin: 0px 0;
}

.address-row {
	display: flex;
	gap: 15px;
	margin-bottom: 10px;
}

.county-country-section {
	display: flex;
	gap: 15px;
	align-items: flex-end;
}

.payment-section {
	margin-left: 150px;
	padding: 15px;
}

.payment-amount-container {
	display: flex;
	gap: 10px;
	margin: 0px;
}

.warning-text {
	color: #990000;
	font-weight: bold;
}

.buttons-section {
	text-align: center;
	margin: 0px;
}

.form-separator {
	width: 85%;
	margin-bottom:  10px;
	border: none;
	border-top: 3px solid #2C68B1;
}