
@import url('https://fonts.googleapis.com/css2?family=Fira+Sans:wght@300;400;500;600;700&display=swap');

:root {
	--primary-color: #6366f1;
	--primary-dark: #4f46e5;
	--tertiary-dark: #0b2f4f;
	--ip-charcoal-rgb: 47, 47, 47;
	--bg-dark: #0f172a;
	--card-bg: #1e293b;
	--bs-heading-font-family: "ff-utility-web-pro", Helvetica, Arial, sans-serif;
	--text-s: clamp(0.8125rem, calc(0.0500373602vw + 0.8012415939rem), 0.8439609902rem);
	--text-m: clamp(1rem, calc(0.1988071571vw + 0.9552683897rem), 1.125rem);
	--text-l: clamp(1.2rem, calc(0.4765407555vw + 1.09277833rem), 1.499625rem);

	--content-width: 85.375rem;
	--width-60: calc(var(--content-width) * 0.6);
	--width-66: calc(var(--content-width) * 0.6);
    --width-70: calc(var(--content-width) * 0.7);
    --width-80: calc(var(--content-width) * 0.8);


	--space-xs: clamp(0.8441720333rem, calc(-0.0172384889vw + 0.8480506933rem), 0.8333333333rem);
    --space-s: clamp(1.1252813203rem, calc(0.1983597291vw + 1.0806503813rem), 1.25rem);
    --space-s-to-xs: clamp(0.8441720333rem, calc(0.6454520346vw + 0.6989453255rem), 1.25rem);
    --space-m: clamp(1.5rem, calc(0.5964214712vw + 1.365805169rem), 1.875rem);
	--section-space-xs: clamp(0.8441720333rem, calc(1.3081425581vw + 0.5498399577rem), 1.6666666667rem);
    --section-space-s: clamp(1.1252813203rem, calc(2.1864312997vw + 0.6333342779rem), 2.5rem);
	--section-space-m: clamp(1.5rem, calc(3.578528827vw + 0.6948310139rem), 3.75rem);
	--gutter: clamp(1rem, calc(6.3618290258vw + -0.4314115308rem), 5rem);
	--section-padding-block: var(--section-space-m);
	--content-gap: var(--space-s);
    --container-gap: var(--space-xl);
    --grid-gap: var(--space-s);
	--grid-3: repeat(3, minmax(0, 1fr));
}

body {
	font-family: 'Fira Sans', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--bs-heading-font-family);
}

body.public-page {
	background: #f4f6f9;
}

body.backstage-page {
	background: #f8fafc;
	font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

body.auth-page {
	background: linear-gradient(135deg, var(--bg-dark) 0%, #1a1f35 100%);
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.container {
	max-inline-size: var(--width-70);
}

.site-header {
	background: #2f2f2f;
	color: #fff;
	--bg: #0c5c9a;
	position: relative;
	background: var(--bg);
	overflow: hidden;

	a {
		color: color-mix(in oklch, var(--bs-white) 50%, #007ad3 50%);
		transition: color ease-in 0.2s;

		&:hover {
			color: var(--bs-white);
		}
	}
}

.site-header .header-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
}

.site-header::before,
.site-header::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 120px;
	background-image: url('/images/grid-bookend.svg');
	background-repeat: repeat;
	background-size: 150px 90px;
	background-position: center;
	opacity: 1;
	pointer-events: none;
}

.site-header::before {
	left: 0;
	background-position: left center;
}

.site-header::after {
	right: 0;
	/* transform: scaleX(-1); */
	background-position: right center;
}

.site-header .container {
	position: relative;
	z-index: 1;
}

.return-link {
	margin: 0;
	font-size: 0.85rem;
	font-weight: 500;
	text-align: end;
}

.site-nav {
	background: #2f2f2f;
}


.site-footer {
	--bgc: var(--ip-charcoal-rgb);
    background: linear-gradient(180deg, rgba(var(--bgc), 1) 50%, rgba(var(--bgc), 0.8) 100%);
    color: var(--bs-light);
	padding-block: var(--space-s);
	font-size: var(--text-s);

	a {
		color: var(--bs-light);
		text-decoration: none;

		&:hover {
			text-decoration: underline;
		}
	}
}

.footer-grid {
	display: flex;
	flex-direction: column;
	row-gap:var(--grid-gap);

	> * + * {
		position: relative;
		padding-block-start: var(--grid-gap);
		border-block-start: 1px solid rgba(var(--bs-white-rgb), 0.5);
	}
}

.footer-brand-grid {
	@media (width >= 75rem) {
        display: grid;
        grid-template-columns: var(--grid-3);
    }
}

#copyright-list {
	margin-block-end: 0;

	> .list-inline-item:not(:last-child) {
		padding-inline-end: 0.75rem;
		margin-inline-end: 0.5rem;
		position: relative;

		&:after {
			content: "";
			display: block;
			width: 1px;
			background-color: rgba(var(--bs-light-rgb), 0.4);
			height: 0.8rem;
			position: absolute;
			right: 0;
			top: 50%;
			transform: translateY(-50%);
		}
	}
}

.card-header {
	background: var(--tertiary-dark);
	color: #fff;
}

.card:not(.card .card) {
	--bs-card-border-radius: 0;
	--bs-card-inner-border-radius: 0;
	border-color: transparent;

	.card {
		border-color: #0c5c9a;
	}
}

.card-body {
	padding-block-start: calc( var(--section-padding-block) / 2);
}

.form-control,
.form-select {
	border-color: #0c5c9a;
}

.form-control:focus,
.form-select:focus {
	border-color: #0c5c9a;
	box-shadow: 0 0 0 0.2rem rgba(12, 92, 154, 0.25);
}

.btn {
	--bs-btn-font-weight: 600;
}

.btn-lg {
	--bs-btn-font-size: 1rem;
}

main {
	> section {
		padding-block: var(--section-padding-block);
	}
}

.content-col {
	display: flex;
	row-gap: var(--section-padding-block);
	flex-direction: column;
}

.content-grid {
	display: flex;
	flex-direction: column;
	row-gap: var(--section-padding-block);

	/* if there's an empty div (example: .alertContainer), collapse the row gap otherwise it looks like extra space */
	> *:empty + *,
	> *.is-hidden:first-child:empty + * {
		margin-block-start: calc(var(--section-padding-block) * -1);
	}

	> div + .btn-wrapper:last-child {
		margin-block-start: calc(var(--section-padding-block) * -1);
		padding-block-start: var(--bs-card-spacer-y);
	}

	> #alertContainer .alert {
		--bs-alert-margin-bottom: 0;
	} 
}

.section-title {
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--tertiary-dark);
	font-weight: 700;
	position: relative;
	display: inline-block;
	width: 100%;
	margin-block-end: var(--content-gap);
}

.section-title::after {
	content: "::::::::::::::::::::::::::::::::::::::::::::::::";
	color: #6db2e5;
	font-weight: 700;
	display: block;
	letter-spacing: 0.2em;
}

.section-title-text {
	font-weight: 700;
}

body.backstage-page .section-title {
	font-size: 0.95rem;
}

.page-header {
	background: #0f172a;
	color: #fff;
	padding: 24px 0;
	margin-bottom: 24px;
}

.table thead th {
	background: #e2e8f0;
}

.table tbody tr.standby-row > td {
	background: #ffffc5 !important;
}

.table thead th.action-col {
	width: 1%;
	white-space: nowrap;
}

.is-hidden {
	display: none !important;
}

.filter-select-sm {
	min-width: 140px;
}

.filter-select-md {
	min-width: 160px;
}

.filter-select-lg {
	min-width: 220px;
}

.btn-nowrap {
	white-space: nowrap;
}

.text-slate {
	color: #94a3b8;
}

.login-container {
	width: 100%;
	max-width: 420px;
}

.login-card {
	background: var(--card-bg);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 12px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	backdrop-filter: blur(10px);
	padding: 40px;
	color: #e2e8f0;
}

.login-header {
	text-align: center;
	margin-bottom: 30px;
}

.login-header h1 {
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 8px;
	background: linear-gradient(135deg, var(--primary-color), #a78bfa);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.login-header p {
	color: #94a3b8;
	font-size: 14px;
}

.form-group {
	margin-bottom: 20px;
}

.form-label {
	color:var(--tertiary-dark);
	margin-bottom: 8px;
	display: block;
	font-size: 14px;
	font-weight: 500;
}

/* previous sibling selector - behold the amazingness that modern css is */
.form-label:has(+ .form-control-plaintext) {
  margin-bottom: 0;
}

.auth-page .form-control,
.login-card .form-control,
.auth-card .form-control {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.1);
	color: #e2e8f0;
	padding: 12px 14px;
	border-radius: 8px;
	font-size: 14px;
	transition: all 0.3s ease;
}

.auth-page .form-control:focus,
.login-card .form-control:focus,
.auth-card .form-control:focus {
	background: rgba(255, 255, 255, 0.08);
	border-color: var(--primary-color);
	color: #e2e8f0;
	box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.login-card .form-control::placeholder,
.auth-card .form-control::placeholder {
	color: #64748b;
}

.btn-login {
	width: 100%;
	background: linear-gradient(135deg, var(--primary-color), var(--primary-dark));
	border: none;
	color: white;
	padding: 12px;
	border-radius: 8px;
	font-weight: 600;
	font-size: 14px;
	transition: all 0.3s ease;
	margin-top: 20px;
}

.btn-login:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 25px rgba(99, 102, 241, 0.3);
	color: white;
}

.btn-login:active {
	transform: translateY(0);
}

.btn-login:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.btn {
	border-radius: 4px;
}

.btn-primary {
	--bs-btn-bg: #ffc400;
	--bs-btn-border-color: #ffc400;
	--bs-btn-hover-bg: #e6b000;
	--bs-btn-hover-border-color: #e6b000;
	--bs-btn-active-bg: #cc9a00;
	--bs-btn-active-border-color: #cc9a00;
	--bs-btn-color: #1a1a1a;
	--bs-btn-hover-color: #1a1a1a;
	--bs-btn-active-color: #1a1a1a;
}

.btn-outline-primary {
    --bs-btn-color: #1a1a1a;
    --bs-btn-border-color: #ffc400;
    --bs-btn-hover-color: #1a1a1a;
    --bs-btn-hover-bg: #ffc400;
    --bs-btn-hover-border-color: #ffc400;
    --bs-btn-focus-shadow-rgb: 13, 110, 253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #ffc400;
    --bs-btn-active-border-color: #ffc400;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #ffc400;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #ffc400;
    --bs-gradient: none;
}

.btn-outline-secondary,
.btn-outline-danger,
.btn-outline-info,
.btn-outline-success {
	border-radius: 4px;
}

.auth-container {
	width: 100%;
	max-width: 460px;
}

.auth-card {
	background: var(--card-bg);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 12px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	padding: 40px;
	color: #e2e8f0;
}

.auth-header {
	text-align: center;
	margin-bottom: 24px;
}

.auth-header h1 {
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 6px;
	background: linear-gradient(135deg, var(--primary-color), #a78bfa);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.auth-page .btn-primary {
	width: 100%;
	background: linear-gradient(135deg, var(--primary-color), var(--primary-dark));
	border: none;
	color: white;
	padding: 12px;
	border-radius: 8px;
	font-weight: 600;
	font-size: 14px;
	transition: all 0.3s ease;
	margin-top: 16px;
}

.auth-page .btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 25px rgba(99, 102, 241, 0.3);
}

.auth-page .alert,
.login-card .alert {
	border-radius: 8px;
	border: none;
	font-size: 14px;
	margin-bottom: 16px;
}

.auth-page .alert-danger,
.login-card .alert-danger {
	background: rgba(239, 68, 68, 0.1);
	color: #fca5a5;
}

.auth-page .alert-success {
	background: rgba(34, 197, 94, 0.1);
	color: #86efac;
}

.login-card .spinner-border {
	width: 16px;
	height: 16px;
	margin-right: 8px;
}

.text-success {
	color: #0915a9;
}

.lead {
	font-weight: 400;
	font-size: var(--text-m);
	max-inline-size: 75ch;
	margin-inline: auto;
}