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

html {
	font-size: 16px;
}

@media (max-width: 1024px) {
	html {
		font-size: 18px;
	}
}
body {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: #ddd6fe;
}

textarea {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
	color: white;
	font-weight: bold;
	letter-spacing: -0.01em;
	margin-top: 0.5rem;
	margin-bottom: 0.5rem;
}

h1 {
	font-size: 1.5rem;
	text-align: center;
}

h2 {
	font-size: 1.375rem;
}

h3 {
	font-size: 1.25rem;
}

h4 {
	font-size: 1.125rem;
}

h5, h6 {
	font-size: 1rem;
}

@media (max-width: 1024px) {
	h1 {
		font-size: 1.375rem;
		text-align: center;
	}
	h2 {
		font-size: 1.25rem;
	}
	h3 {
		font-size: 1.125rem;
	}
	h4, h5, h6 {
		font-size: 1rem;
	}
}
p, ol, ul, blockquote, pre, table {
	font-size: 1rem;
	margin-bottom: 1rem;
}

p:last-child {
	margin-bottom: 0;
}

ul, ol {
	padding-left: 1.5rem;
}

li {
	margin-bottom: 0.5rem;
}

li:last-child {
	margin-bottom: 0;
}

.info, .small {
	font-size: 0.875rem;
	color: #9ca3af;
	margin-bottom: 0.75rem;
	text-align: center;
}

label {
	font-size: 0.875rem;
}

.center-text {
	text-align: center;
}

a {
	color: #3b82f6;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}

body {
	background: linear-gradient(135deg, #0f0c29, #302b63, #24243e);
	background-attachment: fixed;
	min-height: 100vh;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
}

.container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 1rem;
	width: 100%;
	-webkit-box-flex: 1;
	    -ms-flex: 1;
	        flex: 1;
}

.break-time {
	display: none;
}

.no-break-time {
	display: inline;
}

label {
	display: inline-block;
}

@media (max-width: 1024px) {
	body {
		width: 100% !important;
		margin: 0 !important;
		padding: 0 !important;
		background: rgb(15, 12, 41) !important;
	}
	.container {
		width: 100% !important;
		padding: 0 !important;
		margin-top: 0 !important;
	}
	.break-time {
		display: inline !important;
	}
	.no-break-time {
		display: none !important;
	}
}
.card-grid {
	display: -ms-grid;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
	margin: 1.5rem 0;
}

.two-col {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 1fr 2rem 1fr;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
}
@media (max-width: 1024px) {
	.two-col {
		-ms-grid-columns: 1fr;
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
}

header {
	margin-bottom: 1.5rem;
}

nav {
	background-color: rgba(15, 12, 41, 0.85);
	-webkit-box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.1);
	        box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.1);
}

nav ul {
	width: 100%;
	min-width: 220px;
	height: 100px;
	list-style: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	margin-bottom: 0;
}

nav li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	margin-bottom: 0 !important;
}

nav a {
	padding: 0 10px;
	text-decoration: none !important;
	/*display: flex;
	align-items: center;*/
	color: #ddd6fe;
}

nav li.highlight a {
	font-weight: bold;
	color: white;
}

nav a:last-child {
	padding-right: 20px;
}

nav a:hover {
	-webkit-transition: color 0.2s;
	transition: color 0.2s;
	color: white;
}

nav svg {
	fill: #ddd6fe;
}

nav svg:hover {
	-webkit-transition: fill 0.2s;
	transition: fill 0.2s;
	fill: white;
}

nav li:first-child {
	margin-right: auto;
}

nav ul:not(.sidebar) li:not(.home) a {
	margin-top: 5px !important;
}

nav.sidebar-showing .sidebar {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

nav.sidebar-hidden .sidebar {
	display: none;
}

.sidebar {
	position: fixed;
	top: 0;
	right: 0;
	height: 100vh;
	width: 250px;
	background-color: rgba(15, 12, 41, 0.85);
	backdrop-filter: blur(8px);
	list-style: none;
	display: none;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	-webkit-box-pack: start;
	    -ms-flex-pack: start;
	        justify-content: flex-start;
	z-index: 999;
	border-left: 1px solid rgba(255, 255, 255, 0.3);
	padding-left: 0;
}

.sidebar li {
	width: 100%;
	margin-bottom: 0;
	padding-left: 1.5rem;
}

.sidebar a {
	width: 100%;
	padding: 0;
	text-decoration: none;
}

.sidebar a:last-child {
	padding-right: 0;
}

.menu-button {
	display: none;
}

@media (max-width: 1024px) {
	header {
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	}
	.hideOnMobile {
		display: none;
	}
	nav.sidebar-showing .menu-button {
		display: none;
	}
	nav.sidebar-hidden .menu-button {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	nav li:first-child {
		height: 100px;
	}
	.sidebar li, .sidebar a {
		height: 50px;
	}
}
@media (max-width: 767px) {
	nav.sidebar-showing .home a {
		display: none;
	}
	nav.sidebar-hidden .home a {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.sidebar {
		width: 100%;
		border-left: 0;
	}
	.sidebar li {
		width: 100%;
		border-bottom: rgba(255, 255, 255, 0.3) 1px solid;
		font-size: 1rem !important;
		padding-top: 70px;
	}
	.sidebar li, .sidebar a {
		height: 100px;
	}
}
footer {
	background: rgba(15, 12, 41, 0.85);
	backdrop-filter: blur(2px);
	padding: 1rem;
	color: #9ca3af;
	text-align: center;
	width: 100%;
	line-height: 16px;
}
footer nav {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	gap: 1.5rem;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	line-height: 16px;
}
footer nav a:hover path {
	-webkit-transition: fill 0.2s;
	transition: fill 0.2s;
	fill: white;
}

@media (max-width: 1024px) {
	footer {
		border-top: rgba(255, 255, 255, 0.1) 1px solid;
	}
	footer nav a path {
		fill: white;
	}
}
.card {
	background: rgba(15, 12, 41, 0.85);
	backdrop-filter: blur(4px);
	border-radius: 24px;
	padding: clamp(1rem, 6vw, 2rem);
	-webkit-box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
	        box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
	border: white 2px solid;
	max-width: 675px;
	margin: 0 auto;
	margin-top: 1.5rem;
	margin-bottom: 3rem;
}
.card > :last-child {
	margin-bottom: 0;
}
.card .inner-header, .card .inner-header-zombie {
	border-bottom: rgba(255, 255, 255, 0.3) 1px solid;
	padding-bottom: 0.75rem;
	margin-bottom: 1.5rem;
}
.card .inner-footer {
	color: #9ca3af;
	text-align: center;
	border-top: rgba(255, 255, 255, 0.3) 1px solid;
	margin-top: 2rem;
	padding-top: 2rem;
	padding-bottom: 0.75rem;
}
.card .inner-footer p {
	font-size: 0.875rem !important;
	margin-left: -0.75rem;
	margin-right: -0.75rem;
}
.card .content {
	padding-top: 0.75rem;
}

@media (max-width: 1024px) {
	.card {
		border-radius: 0 !important;
		margin-top: 0 !important;
		margin-bottom: 0 !important;
		border: 0 !important;
		padding-top: 0 !important;
		padding-bottom: 1rem;
	}
	.card .inner-header, .card .inner-header-zombie {
		padding-bottom: 1.5rem;
		margin-bottom: 2rem;
		border-bottom: rgba(255, 255, 255, 0.1) 1px solid;
	}
	.card .inner-footer {
		border-top: rgba(255, 255, 255, 0.1) 1px solid;
	}
	.card .content {
		padding-top: 0;
	}
}
form {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	gap: 1rem;
}
form input:not([type=submit]), form textarea {
	border-radius: 14px !important;
	border: 1px solid rgba(255, 255, 255, 0.3);
	padding: 0.9rem 1.2rem !important;
	font-size: 1rem;
	background: rgba(0, 0, 0, 0.4);
	width: 100%;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	color: #f1f5f9 !important;
	-webkit-box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
	        box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}
form input:not([type=submit]):focus, form textarea:focus {
	border-color: #3b82f6 !important;
	outline: none;
	-webkit-box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
	        box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}
form input[type=submit] {
	background: linear-gradient(135deg, #3b82f6, #1e3a8a);
	color: white;
	border: none;
	padding: 1rem 1.5rem;
	font-size: 1.1rem;
	font-weight: 500;
	border-radius: 40px;
	width: 100%;
	cursor: pointer;
	-webkit-transition: all 0.2s ease;
	transition: all 0.2s ease;
	margin-top: 1rem;
	letter-spacing: 0.3px;
	-webkit-box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
	        box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}
form input[type=submit]:hover {
	background: linear-gradient(135deg, #2563eb, #1e40af);
	-webkit-transform: scale(1.02);
	        transform: scale(1.02);
}
form input[type=submit]:active {
	-webkit-transform: scale(0.98);
	        transform: scale(0.98);
}
form .hidden-fields {
	display: none;
}
form .email-suggestion {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 8px 12px;
	margin-top: 0;
	margin-bottom: 10px;
	font-size: 0.9em;
	border-radius: 4px;
	display: none;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 8px;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
}
form .email-suggestion.view {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
form .email-suggestion .suggestion-text {
	color: #856404;
}
form .email-suggestion .suggestion-email {
	font-weight: bold;
	cursor: pointer;
	text-decoration: underline;
	color: #0066cc;
}
form .email-suggestion .suggestion-email:hover {
	color: #004499;
}
form .email-suggestion .dismiss {
	margin-left: auto;
	cursor: pointer;
	color: #999;
	font-size: 1.2em;
	line-height: 1;
}
form .email-suggestion .dismiss:hover {
	color: #333;
}
form .form-message {
	margin-top: 1rem;
	padding: 0.75rem;
	border-radius: 8px;
	text-align: center;
}
form .form-message.success {
	background: rgba(34, 197, 94, 0.2);
	border: 1px solid #22c55e;
	color: #22c55e;
}
form .form-message.error {
	background: rgba(239, 68, 68, 0.2);
	border: 1px solid #ef4444;
	color: #ef4444;
}
form .validation-dormant {
	display: none;
}
form .validation-error {
	color: #d32f2f;
	background: #ffebee;
	border-left: 4px solid #d32f2f;
	display: block;
	margin-top: -0.75rem;
	margin-bottom: 0.75rem;
	padding-top: 1px;
	padding-bottom: 1px;
	padding-left: 1rem;
}
form #city_etc-validation.validation-error {
	margin-top: -1.15rem;
	margin-bottom: 1.15rem;
}
form #form-message {
	margin-top: 1rem;
	padding: 0.75rem;
	border-radius: 8px;
	text-align: center;
}
form #form-message.server-dormant {
	display: none;
}
form #form-message.server-success {
	background: #d4edda;
	color: #155724;
	border-left: 4px solid #28a745;
	display: block;
}
form #form-message.server-error {
	background: #f8d7da;
	color: #721c24;
	border-left: 4px solid #dc3545;
	display: block;
}
form .widget__content {
	background: rgba(0, 0, 0, 0.4) !important;
	border: 1px solid rgba(255, 255, 255, 0.3) !important;
	border-radius: 14px !important;
}

#success-message {
	display: none;
	text-align: center;
	width: 100%;
}
#success-message img {
	width: 100%;
}
#success-message h3 {
	font-size: 1.5rem;
	font-weight: bold;
}

.mt-1 {
	margin-top: 0.5rem;
}

.mt-2 {
	margin-top: 0.75rem;
}

.mt-3 {
	margin-top: 1rem;
}

.mb-1 {
	margin-bottom: 0.5rem;
}

.mb-2 {
	margin-bottom: 0.75rem;
}

.mb-3 {
	margin-bottom: 1rem;
}

.text-center {
	text-align: center;
}