@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');

@font-face {
	font-family: 'Montserrat';
	src: url('/font/Montserrat/Montserrat-VariableFont_wght.ttf') format('truetype');
	font-weight: 100 900; /* supports full weight range */
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Montserrat';
	src: url('/font/Montserrat/Montserrat-Italic-VariableFont_wght.ttf') format('truetype');
	font-weight: 100 900;
	font-style: italic;
	font-display: swap;
}

:root {
	/* Primary Branding - Deep Indigo */
	--color-primary: #3F4191;
	--color-primary-light: #5A5CB5;
	--color-primary-dark: #2E3075;
	--color-primary-hover: #353775;
	/* Buttons/Highlights */
	--color-secondary: #D95179; /* Milk Out - Coral/Pink */
	--color-tertiary: #55B3E3; /* Milk In - Sky Blue */
	/* Semantic Colors */
	--color-info: #55B3E3;
	--color-success: #4CB45E; /* Earnings Green */
	--color-warning: #F78D5E; /* Orange */
	--color-error: #C62828; /* Red */
	--color-brown: #5D4037; /* Brown */
	/* Backgrounds */
	--color-ui-background: #F0F2F9;
	--color-background: #F5F6FA;
	--color-surface: #FFFFFF;
	--color-drawer: #3F4191;
	--color-card-hover: #F8F9FC;
	/* Text */
	--color-text-primary: #1E1F2A;
	--color-text-secondary: #7A7D85;
	--color-text-light: rgba(255, 255, 255, 0.7);
	--color-text-white: #FFFFFF;
	--color-text-black: #000000;
	/* Borders & Shadows */
	--radius-sm: 8px;
	--radius-md: 12px;
	--radius-lg: 16px;
	--radius-xl: 24px;
	--shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.04);
	--shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
	--shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);
	/* Spacing */
	--spacing-xs: 4px;
	--spacing-sm: 8px;
	--spacing-md: 16px;
	--spacing-lg: 24px;
	--spacing-xl: 32px;
	/* Scrollbar */
	--scrollbar-width: 3px;
	--scrollbar-track: #EEF1FB;
	--scrollbar-thumb: #6D71B8;
	--scrollbar-thumb-hover: #2E3075;
}

*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	/* SCROLLBAR */
	scrollbar-width: thin !important;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track) !important;
	-webkit-font-smoothing: antialiased !important;
	-moz-osx-font-smoothing: grayscale !important;
	text-rendering: optimizeLegibility;
}

html, body {
	margin: 0;
	padding: 0;
	height: 100%;
	font-family: 'Montserrat', 'Roboto', 'JetBrains Mono', sans-serif !important;
	font-weight: 600;
	text-transform: none;
	background-color: var(--color-background);
	color: var(--color-text-primary);
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* SCROLLBAR (Chrome, Safari, Edge) */
::-webkit-scrollbar {
	width: var(--scrollbar-width) !important;
	height: var(--scrollbar-width) !important;
}

::-webkit-scrollbar-track {
	background: var(--scrollbar-track) !important;
	border-radius: 99px;
}

::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb) !important;
	border-radius: 99px !important;
	border: 2px solid var(--scrollbar-track); /* inset padding trick */
}

	::-webkit-scrollbar-thumb:hover {
		background: var(--scrollbar-thumb-hover) !important; /* primary-light on hover */
	}

::-webkit-scrollbar-corner {
	background: var(--scrollbar-track) !important;
}

/* SELECTION */
::selection {
	background: var(--color-warning);
	color: var(--color-text-white);
}

/* ---------- Buttons & Links ---------- */
a, .btn-link {
	color: var(--color-primary);
	text-decoration: none;
	transition: color 0.2s ease;
}

	a:hover, .btn-link:hover {
		color: var(--color-primary-light);
		text-decoration: none;
	}

.btn-primary {
	color: #fff;
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	border-radius: var(--radius-md);
	font-weight: 600;
	padding: 10px 20px;
	transition: all 0.2s ease;
}

	.btn-primary:hover {
		background-color: var(--color-primary-dark);
		border-color: var(--color-primary-dark);
		transform: translateY(-1px);
		box-shadow: var(--shadow-md);
	}

.btn:focus, .btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
	box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem rgba(63, 65, 145, 0.3);
}


/* Mud Blazor OverRide*/

/*Required * overRide */
.mud-input-control.mud-input-required > .mud-input-control-input-container > .mud-input-label::after {
	color: var(--color-error) !important;
}

/* MudTabs Over ride */
.mud-tab {
	text-transform: capitalize !important;
}

/* Mud Expandable Panels Over ride */
.mud-expand-panel-header {
	border-radius: var(--radius-sm) !important;
	background-color: var(--color-primary) !important;
	transition: all 0.3s ease;
}

	.mud-expand-panel-header .mud-typography {
		color: var(--color-text-white) !important;
	}

	.mud-expand-panel-header .mud-icon-root.mud-svg-icon {
		color: var(--color-text-white);
	}

	.mud-expand-panel-header:hover {
		background-color: var(--color-primary-hover) !important;
	}

.mud-expand-panel-icon {
	color: var(--color-text-white) !important;
}

/* Mud Data Table Over ride */
th.mud-table-cell {
	font-weight: 700 !important;
}

td.mud-table-cell {
	font-weight: 500 !important;
}

/* Navmenu OverRide */
.nav-container {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.nav-menu-scrollable {
	flex: 1;
	overflow-y: auto;
	overflow-x: hidden;
}

.logo-img-nddb {
	max-width: 240px;
	height: auto;
	display: block;
	cursor: pointer;
}

.powered-by {
	position: sticky;
	bottom: 0;
	left: 0;
	right: 0;
	text-align: center;
	padding: 10px;
	background-color: var(--mud-palette-drawer-background);
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}

	.powered-by img {
		max-width: 150px;
		width: 100%;
		height: auto;
		filter: brightness(0) invert(1);
		opacity: 0.9;
	}

.mud-navmenu {
	height: 100%;
	display: flex;
	flex-direction: column;
	padding: var(--spacing-sm);
	background-color: var(--color-drawer);
}

	.mud-navmenu.mud-navmenu-default .mud-svg-icon.mud-nav-link-expand-icon.mud-transform {
		fill: var(--color-text-light);
	}

.mud-nav-link {
	margin: 3px 0;
	padding: 10px;
	border-radius: var(--radius-sm);
	color: var(--color-text-light);
	font-weight: 500;
	transition: background-color 0.4s ease-in-out, color 0.4s ease-in-out, transform 0.3s ease-in-out !important;
}

	.mud-nav-link .mud-nav-link-icon-default {
		color: var(--color-text-light);
		transition: color 0.25s ease, transform 0.25s ease !important;
	}

	.mud-nav-link .mud-nav-link-expand-icon {
		color: var(--color-text-light) !important;
	}

	.mud-nav-link:hover {
		background-color: rgb(255, 255, 255) !important;
		color: var(--color-primary) !important;
	}

		.mud-nav-link:hover .mud-nav-link-icon-default {
			color: var(--color-primary) !important;
			transform: scale(1.08) !important;
		}

		.mud-nav-link:hover .mud-nav-link-expand-icon {
			color: var(--color-primary) !important;
		}

		.mud-nav-link:hover .mud-navmenu.mud-navmenu-default svg.mud-svg-icon.mud-nav-link-expand-icon.mud-transform {
			fill: var(--color-primary);
		}

	.mud-nav-link.active {
		background-color: var(--color-surface) !important;
		color: var(--color-primary) !important;
		box-shadow: var(--shadow-sm) !important;
	}

		.mud-nav-link.active .mud-nav-link-icon-default {
			color: var(--color-primary) !important;
		}

		.mud-nav-link.active .mud-nav-link-icon-default {
			animation: iconPulse 0.4s ease-in-out;
		}

@keyframes iconPulse {
	0%, 100% {
		transform: scale(1);
	}

	50% {
		transform: scale(1.12);
	}
}

.mud-nav-group > .mud-nav-link {
	font-weight: 600;
	letter-spacing: 0.3px;
}

.mud-nav-group * .mud-navmenu .mud-nav-item .mud-nav-link {
	padding-left: 20px !important;
	padding-inline-start: 20px !important;
}

.mud-nav-group .mud-nav-link {
	margin-left: 0px !important;
	font-size: 0.85rem;
}

.mud-divider {
	margin: 14px 12px !important;
	background-color: rgba(255, 255, 255, 0.15) !important;
}


/* Smooth transitions for drawer toggle */
.mud-drawer-responsive {
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}


/* ---------- Validation States ---------- */
.valid.modified:not([type=checkbox]) {
	outline: 2px solid #26b050;
}

.invalid {
	outline: 2px solid red;
}

.validation-message {
	color: red;
	font-size: 0.9rem;
	margin-top: 0.25rem;
}

/* ---------- Layout Fixes ---------- */
.content,
.mud-main-content {
	padding: 1.5rem;
}

.mud-container {
	padding-left: 1rem;
	padding-right: 1rem;
}

.mud-appbar {
	z-index: 1100;
}

.mud-drawer {
	z-index: 1050;
}

/* ---------- Error UI ---------- */
#blazor-error-ui {
	background: lightyellow;
	bottom: 0;
	box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
	display: none;
	left: 0;
	padding: 0.6rem 1.25rem 0.7rem 1.25rem;
	position: fixed;
	width: 100%;
	z-index: 2000;
	color: black;
}

	#blazor-error-ui .dismiss {
		cursor: pointer;
		position: absolute;
		right: 0.75rem;
		top: 0.5rem;
	}

.blazor-error-boundary {
	background: #b32121;
	color: white;
	padding: 1rem;
	border-radius: 8px;
}

	.blazor-error-boundary::after {
		content: "An error has occurred.";
	}

/* ---------- Loading Spinner ---------- */
.loading-container {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	padding: 1rem;
	text-align: center;
}

.logo-wrapper {
	position: relative;
	margin-bottom: 2rem;
	animation: fadeInScale 0.6s ease-out;
}

.loading-logo {
	width: clamp(180px, 40vw, 380px);
	height: auto;
	filter: drop-shadow(0 8px 24px rgba(0,0,0,0.15));
	animation: pulse 2s ease-in-out infinite;
}

/* Animated glow effect behind logo */
.logo-glow {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: clamp(160px, 35vw, 320px);
	height: clamp(60px, 12vw, 120px);
	animation: glowPulse 2s ease-in-out infinite;
	z-index: -1;
}

/* Modern progress bar */
.loading-bar-container {
	width: min(90vw, 380px);
	height: 4px;
	border-radius: 10px;
	overflow: hidden;
	position: relative;
	margin-bottom: 1.5rem;
}

.loading-bar {
	height: 100%;
	border-radius: 10px;
	width: calc(var(--blazor-load-percentage, 0%) * 1%);
	transition: width 0.3s ease-out;
	box-shadow: 0 0 10px rgba(255,255,255,0.5);
}

	/* Animated shimmer effect on progress bar */
	.loading-bar::after {
		content: '';
		position: absolute;
		top: 0;
		left: -100%;
		width: 100%;
		height: 100%;
		background: var(--color-primary);
		animation: shimmer 1.2s infinite;
	}

/* Loading text with dots animation */
.loading-text {
	color: var(--color-primary);
	font-size: clamp(0.9rem, 2.5vw, 1.1rem);
	font-weight: 500;
	letter-spacing: 0.5px;
	margin-bottom: 0.5rem;
}

	.loading-text::after {
		content: var(--blazor-load-percentage-text, "Loading");
	}

.loading-dots {
	display: inline-flex;
	gap: 6px;
	margin-left: 4px;
}

	.loading-dots span {
		width: 6px;
		height: 6px;
		background: var(--color-primary);
		border-radius: 50%;
		animation: dotBounce 1.4s infinite ease-in-out both;
	}

		.loading-dots span:nth-child(1) {
			animation-delay: -0.32s;
		}

		.loading-dots span:nth-child(2) {
			animation-delay: -0.16s;
		}

.loading-percentage {
	color: rgba(255,255,255,0.9);
	font-size: clamp(0.8rem, 2vw, 0.9rem);
}

	.loading-percentage::after {
		content: var(--blazor-load-percentage, "0") "%";
	}

@keyframes pulse {
	0%, 100% {
		transform: scale(1);
	}

	50% {
		transform: scale(1.02);
	}
}

@keyframes glowPulse {
	0%, 100% {
		opacity: 0.3;
		transform: translate(-50%, -50%) scale(1);
	}

	50% {
		opacity: 0.6;
		transform: translate(-50%, -50%) scale(1.1);
	}
}

@keyframes shimmer {
	0% {
		left: -100%;
	}

	50% {
		left: 100%;
	}

	100% {
		left: 200%;
	}
}

@keyframes dotBounce {
	0%, 80%, 100% {
		transform: scale(0);
		opacity: 0.5;
	}

	40% {
		transform: scale(1);
		opacity: 1;
	}
}

@keyframes fadeInScale {
	from {
		opacity: 0;
		transform: scale(0.9);
	}

	to {
		opacity: 1;
		transform: scale(1);
	}
}


/* ---------- Optional Carousel Height Fix ---------- */
.mud-carousel-height-400 {
	height: 400px;
}

/* ---------- Bottom Nav Safe Area ---------- */
.mud-bottom-navigation {
	padding-bottom: env(safe-area-inset-bottom);
}



.mud-table-toolbar {
	background-color: var(--color-primary) !important;
	color: var(--color-text-white) !important;
	border-radius: 5px 5px 0 0 !important;
}



/* Fix MudSelect popover positioning issues */
.mud-popover {
	position: fixed !important;
	z-index: 9999 !important;
}

.mud-popover-provider {
	position: relative;
}

/* Ensure popover stays attached to trigger */
.mud-select {
	position: relative;
}

.mud-popover-open {
	transform: none !important;
}

/* Mobile specific styles */
@media (max-width: 960px) {
	.mud-navmenu {
		padding: var(--spacing-sm);
	}

	.mud-nav-link {
		padding: 10px 14px;
		font-size: 0.9rem;
	}
}


@media (max-width: 768px) {
	.mud-main-content {
		padding: 1rem;
	}

	.mud-appbar .mud-button {
		font-size: 0.85rem;
	}

	.mud-container--gutters {
		padding-left: 0px !important;
		padding-right: 0px !important;
	}

	.mud-tabs-tabbar .pa-6 {
		padding: 6px !important;
	}
}
/* Prevent popover from going off-screen */
@media (max-height: 600px) {
	.mud-popover {
		max-height: 150px !important;
		overflow-y: auto !important;
	}
}

@media (max-width: 480px) {
	.logo-wrapper {
		margin-bottom: 1.5rem;
	}

	.loading-bar-container {
		height: 3px;
	}

	.loading-dots span {
		width: 5px;
		height: 5px;
	}
}
