html {
	font-size: 16px; /* Default root font size */ /*ChatGPT*/
	color: #311254;
}

body {
	font-family: "Montserrat";
	overflow: hidden;
}

header {
	z-index: 100;
	width: 100%;
	height: 7.188rem;
	position: absolute;
	left: 0;
	top: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	background: rgba(255, 255, 255, 0.3);
	box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.25);
	backdrop-filter: blur(10px);
}

header:first-child {
	font-family: "Times New Roman";
	font-size: 3.125rem;
	color: #311254;
}

.background-image {
	min-width: 100%;
	min-height: 100%;
	z-index: -10;
	position: fixed;
	bottom: 0;
	left: 0;
	pointer-events: none;
	-moz-user-select: none;
	-webkit-user-select: none;
	user-select: none;
}

.card {
	height: 40rem;
	width: 68.438rem;
	border-radius: 1.5rem;
	background: rgba(255, 255, 255, 0.3);
	box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.25);
	backdrop-filter: blur(10px);
	/*ChatGPT*/
	position: absolute;
	top: 52.5%;
	left: 50%;
	transform: translate(-50%, -47.5%);
}

.step {
	font-weight: 700;
	font-size: 1.25rem;
	color: #ffffff;
	margin-left: 1.5rem;
}

.step-bar {
	background-color: #311254;
	height: 100%;
	width: 25%;
	border-top-left-radius: 1.5rem;
	display: flex;
	align-items: center;
	transition: 400ms ease-in-out;
}

.step-bar-container {
	height: 2.5rem;
}

.all-steps {
	width: 24rem;
	height: auto;
	margin-top: 5.125rem;
	margin-left: 10.25rem;
	margin-right: 0;
	overflow: hidden;
	transition: 250ms;
}

.step-3 {
	width: 24rem;
	height: auto;
	margin-top: 1rem;
	margin-left: 10.25rem;
	margin-right: 0;
	overflow: hidden;
	transition: 250ms;
	z-index: 10;
}

.long {
	display: block;
	height: 3.125rem;
	width: 17.391rem;
	border: none;
	background-color: #e7d9f7;
	border-radius: 0.625rem;
	padding-left: 0.5rem;
	margin-bottom: 0.625rem;
	color: #311254;
	font-size: 1.25rem;
	font-weight: medium;
	font-family: "Montserrat";
}

.long:focus {
	display: block;
	height: 3.125rem;
	width: 17.391rem;
	border: none;
	outline: none;
	background-color: #e7d9f7;
	border-radius: 0.625rem;
	padding-left: 0.5rem;
	margin-bottom: 0.625rem;
	color: #311254;
	font-size: 1.25rem;
	font-weight: medium;
	font-family: "Montserrat";
}

label {
	margin-left: 0.5rem;
	color: #311254;
	font-size: 1.25rem;
	font-weight: 700;
	z-index: 1;
}

.step-title {
	font-size: 2rem;
	font-weight: 700;
	color: #311254;
	margin-bottom: 2.5rem;
}

.step3-title {
	font-size: 2rem;
	font-weight: 700;
	color: #311254;
	margin-bottom: 0.5rem;
}

.logo {
	z-index: 10;
	width: 21.062rem;
	height: 26.249rem;
	position: absolute;
	left: 57%;
	top: 15%;
	transition: 250ms;
}

.footer-container {
	height: 100%;
	width: 100%;
	position: relative;
	transition: 250ms;
}

.footer-buttons {
	height: 3.125rem;
	width: 62.938rem;
	position: absolute;
	bottom: 10rem;
	margin-left: 2.75rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	transition: 250ms;
}

.footer-buttons1 {
	justify-content: flex-end;
	transition: 250ms;
}

.footer-buttons3 {
	height: 3.125rem;
	width: 62.938rem;
	position: absolute;
	bottom: 5.5rem;
	margin-left: 2.75rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	pointer-events: none;
	transition: 250ms;
}

.next {
	background: #311254;
	border-radius: 0.625rem;
	color: #ffffff;
	font-weight: 700;
	font-size: 1.25rem;
	font-family: "Montserrat";
	border: none;
	outline: none;
	width: 5.688rem;
	height: 3.125rem;
	cursor: pointer;
	pointer-events: auto;
}

.back {
	background: none;
	border-radius: 0.625rem;
	color: #311254;
	font-weight: 700;
	font-size: 1.25rem;
	font-family: "Montserrat";
	border: none;
	outline: none;
	width: 5.688rem;
	height: 3.125rem;
	cursor: pointer;
	pointer-events: auto;
}

.radio {
	opacity: 0;
	margin: 0;
	height: 0;
	width: 0;
}

.radio-title {
	margin-left: 0.5rem;
	color: #311254;
	font-size: 1.25rem;
	font-weight: 700;
	z-index: 1;
	margin-top: 0.625rem;
	display: block;
	margin-bottom: 0.125rem;
}

.radio-wrapper {
	display: flex;
	width: 5.75rem;
	height: 3.125rem;
	align-items: center;
	flex-wrap: wrap;
	justify-content: center;
}

.radio-label {
	background-color: #e7d9f7;
	color: #311254;
	border-radius: 0.625rem;
	border: none;
	outline: none;
	width: 6rem;
	height: 3.125rem;
	font-size: 1.25rem;
	font-weight: 500;
	z-index: 2;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0.625rem;
	margin-left: 0;
}

.radio:checked + .radio-label {
	background-color: #311254;
	color: #ffffff;
	border-radius: 0.625rem;
	border: none;
	outline: none;
	width: 6rem;
	height: 3.125rem;
	font-size: 1.25rem;
	font-weight: 500;
	z-index: 2;
}

.wrapper {
	width: 17.875rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

fieldset {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	border: 0;
	padding: 0;
	margin: 0;
}

.create-account {
	background: #311254;
	border-radius: 0.625rem;
	color: #ffffff;
	font-weight: 700;
	font-size: 1.25rem;
	font-family: "Montserrat";
	border: none;
	outline: none;
	width: 11.063rem;
	height: 3.125rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: 250ms;
}

.gender-wrapper {
	width: 17.938rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 0.625rem;
}

.small-text {
	font-size: 0.938rem;
	font-weight: 500;
	color: #311254;
	transition: 250ms;
}

input[type="submit"] {
	opacity: 0;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
}

.confirmation-title1 {
	font-weight: 700;
	font-size: 2rem;
	transition: 250ms;
}

.confirmation-title2 {
	font-weight: 700;
	font-size: 2rem;
	transition: 250ms;
}

#submit {
	pointer-events: none;
}

.confirmation-banner {
	position: absolute;
	width: 100%;
	display: flex;
	top: 7.7rem;
	justify-content: center;
	font-weight: 700;
	font-size: 2.5rem;
}

.character-container {
	margin: 6.125rem 0 0 9.188rem;
	height: auto;
	width: auto;
	transition: 250ms;
}

.info-container {
	margin: 6.125rem 13rem 0 0;
	height: auto;
	width: auto;
	transition: 250ms;
}

.image-container {
	margin-top: 2rem;
	width: 20.875rem;
	height: 20.875rem;
	transition: 250ms;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	border-radius: 0.625rem;
	margin-right: 7.5rem;
	box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.25);
}

.generated-image {
	width: 20.875rem;
	height: 20.875rem;
	transition: 250ms;
}

.confirmation-page {
	height: 25.313rem;
	display: flex;
	justify-content: space-between;
	transition: 250ms;
}

.result {
	pointer-events: none;
}

.highlight {
	border: solid 0.01rem #311254;
	transition: 250ms;
}

.country {
	pointer-events: none;
	display: block;
	height: 3.125rem;
	width: 17.391rem;
	border: none;
	background-color: #e7d9f7;
	border-radius: 0.625rem;
	padding-left: 0.5rem;
	margin-bottom: 0.625rem;
	color: #311254;
	font-size: 1.25rem;
	font-weight: medium;
	font-family: "Montserrat";
}

.semi-long {
	display: block;
	height: 3.125rem;
	width: 11.5rem;
	border: none;
	background-color: #e7d9f7;
	border-radius: 0.625rem;
	padding-left: 0.5rem;
	margin-bottom: 0.625rem;
	color: #311254;
	font-size: 1.25rem;
	font-weight: medium;
	font-family: "Montserrat";
}

.num {
	display: block;
	height: 3.125rem;
	width: 5.75rem;
	border: none;
	background-color: #e7d9f7;
	border-radius: 0.625rem;
	padding-left: 0.5rem;
	margin-bottom: 0.625rem;
	color: #311254;
	font-size: 1.25rem;
	font-weight: medium;
	font-family: "Montserrat";
}

#zip,
#street {
	margin-right: 0.313rem;
}

.semi-long:focus {
	border: none;
	outline: none;
}

.num:focus {
	border: none;
	outline: none;
	-moz-appearance: textfield;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
	/*https://www.w3schools.com/howto/howto_css_hide_arrow_number.asp*/
	-webkit-appearance: none;
	margin: 0;
}

.radio-label-result {
	background-color: #311254;
	color: #ffffff;
	border-radius: 0.625rem;
	border: none;
	outline: none;
	width: 6rem;
	height: 3.125rem;
	font-size: 1.25rem;
	font-weight: 500;
	z-index: 2;
	margin-left: 0;
}

.invisible {
	display: none;
	transition: 250ms;
}

@media only screen and (min-width: 481px) and (max-width: 780px) {
	.logo {
		display: none;
	}

	.card {
		width: 80%;
		height: 75%;
		top: 57%;
	}

	.step {
		font-size: 0.75rem;
	}

	.long {
		width: 80%;
	}

	.all-steps {
		width: 24rem;
		height: auto;
		margin-top: 0.75rem;
		margin-left: 2.75rem;
		margin-right: 0;
		overflow: hidden;
		transition: 250ms;
	}

	.footer-buttons {
		height: 3%;
		width: 22.75rem;
		position: absolute;
		bottom: 5.75rem;
		margin-left: 2.75rem;
		display: flex;
		align-items: center;
		justify-content: space-between;
		transition: 250ms;
	}

	.footer-buttons1 {
		justify-content: flex-end;
		transition: 250ms;
	}

	.invisible {
		display: none;
		transition: 250ms;
	}
}

@media only screen and (max-width: 480px) {
	.logo {
		display: none;
	}

	.invisible {
		display: none;
		transition: 250ms;
	}

	.card {
		width: 80%;
		height: 75%;
		top: 57%;
	}

	.step {
		font-size: 0.5rem;
	}

	.long {
		width: 80%;
	}
}
