/* _content/Alloc42BlazorServer/Components/Cards/FlipCard.razor.rz.scp.css */
/* Flip Card Container */
.flip-card[b-4vmv0ouu3i] {
	background-color: transparent;
	width: 100%;
	height: 448px; /* Increased height for badges and long descriptions */
	max-height: 448px;
	min-height: 448px;
	perspective: 1000px;
	transition: transform 0.3s ease;
	position: relative; /* Ensure absolutely positioned faces are contained */
}

/* Shy animations based on mouse direction */
.flip-card.shy-top[b-4vmv0ouu3i] {
	transform: translateY(20px) translateX(0px);
	transition: transform 0.4s ease-out;
}

.flip-card.shy-bottom[b-4vmv0ouu3i] {
	transform: translateY(-20px) translateX(0px);
	transition: transform 0.4s ease-out;
}

.flip-card.shy-left[b-4vmv0ouu3i] {
	transform: translateY(0px) translateX(20px);
	transition: transform 0.4s ease-out;
}

.flip-card.shy-right[b-4vmv0ouu3i] {
	transform: translateY(0px) translateX(-20px);
	transition: transform 0.4s ease-out;
}

.flip-card.shy-top-left[b-4vmv0ouu3i] {
	transform: translateY(20px) translateX(20px);
	transition: transform 0.4s ease-out;
}

.flip-card.shy-top-right[b-4vmv0ouu3i] {
	transform: translateY(20px) translateX(-20px);
	transition: transform 0.4s ease-out;
}

.flip-card.shy-bottom-left[b-4vmv0ouu3i] {
	transform: translateY(-20px) translateX(20px);
	transition: transform 0.4s ease-out;
}

.flip-card.shy-bottom-right[b-4vmv0ouu3i] {
	transform: translateY(-20px) translateX(-20px);
	transition: transform 0.4s ease-out;
}

/* Slowdown effect when card is being chased */
.flip-card.shy-slowdown[b-4vmv0ouu3i] {
	transition: transform 0.8s ease-in-out;
}

/* Return to start position */
.flip-card.shy-return[b-4vmv0ouu3i] {
	transform: translateY(0px) translateX(0px);
	transition: transform 0.3s ease-in;
}

/* Flip Card Inner */
.flip-card-inner[b-4vmv0ouu3i] {
	position: relative;
	width: 100%;
	height: 100%;
	text-align: center;
	transition: all 2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	transform-style: preserve-3d;
	transform: rotateY(0deg) translateZ(0px); /* Ensure card starts in front position */
	will-change: transform; /* Hint for browser optimization */
}

/* Multi-stage flip animation */
.flip-card-inner.flipping[b-4vmv0ouu3i] {
	animation: cardFlip-b-4vmv0ouu3i 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.flip-card-inner.flipping-back[b-4vmv0ouu3i] {
	animation: cardFlipBack-b-4vmv0ouu3i 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

@keyframes cardFlip-b-4vmv0ouu3i {
	0% {
		transform: rotateY(0deg);
	}
	100% {
		transform: rotateY(180deg);
	}
}

@keyframes cardFlipBack-b-4vmv0ouu3i {
	0% {
		transform: rotateY(180deg);
	}
	100% {
		transform: rotateY(0deg);
	}
}

/* Text transition during flip - prevent mirroring */
/* Removed text fade-in/fade-out animations and opacity for always-visible text during flip */

/* Flipped State */
.flip-card-inner.flipped[b-4vmv0ouu3i] {
	transform: rotateY(180deg);
}

/* Flip Card Faces */
.flip-card-front[b-4vmv0ouu3i],
.flip-card-back[b-4vmv0ouu3i] {
	position: absolute;
	width: 100%;
	height: 100%;
	border-radius: var(--radius-lg);
	padding: var(--spacing-lg);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	box-sizing: border-box;
	top: 0;
	left: 0;
	backface-visibility: hidden;
	transition: none;
	overflow: visible !important;
	z-index: 2;
}

/* Front Face */
.flip-card-front[b-4vmv0ouu3i] {
	z-index: 2;
}

/* Back Face */
.flip-card-back[b-4vmv0ouu3i] {
	transform: rotateY(180deg);
	z-index: 2;
	justify-content: center;
}

/* Specialization Card (Glass Effect) */
.specialization-card[b-4vmv0ouu3i] {
	background: var(--glass-bg-light, #23283a); /* Lighter card background */
	backdrop-filter: blur(var(--glass-blur));
	border: 1px solid var(--glass-border);
	border-radius: var(--radius-2xl);
	padding: calc(var(--spacing-xl) + 2px);
	transition: all var(--transition-normal);
	/* position: relative; -- removed to fix flip alignment */
	overflow: hidden; /* Prevent content from spilling out */
	height: 100%;
	min-height: 0;
	max-height: 100%;
	display: flex;
	flex-direction: column;
}

/* Card Title - larger and more prominent */
.specialization-title[b-4vmv0ouu3i] {
	font-size: var(--text-xl);
	font-weight: var(--font-weight-bold);
	line-height: var(--leading-tight);
	margin-bottom: var(--spacing-sm);
	color: var(--text-primary);
}

/* Description styling per reference */
.specialization-description[b-4vmv0ouu3i] {
	font-size: var(--text-base);
	line-height: var(--leading-relaxed);
	color: var(--text-secondary);
	margin-bottom: var(--spacing-lg);
	flex-grow: 1;
}

/* Most Popular badge styles disabled — visual badge removed but kept in code
   so it can be re-enabled when interaction-based popularity is implemented. */

/* Specialization Icon Styling */
.specialization-icon[b-4vmv0ouu3i] {
	width: 64px;
	height: 64px;
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--spacing-lg);
	color: var(--text-inverse);
	box-shadow: var(--shadow-glow);
	flex-shrink: 0;
	align-self: center;
}

.specialization-icon svg[b-4vmv0ouu3i] {
	width: 32px;
	height: 32px;
	display: block;
}

/* Benefit Tags - removed, replaced by .flip-card-badge */

/* Glass effect for specialization cards (for .glass class) */
.glass[b-4vmv0ouu3i] {
	background: var(--glass-bg);
	backdrop-filter: blur(var(--glass-blur));
	border: 1px solid var(--glass-border);
	border-radius: var(--radius-2xl);
}

/* Buttons */
.more-button[b-4vmv0ouu3i] {
	background: linear-gradient(
		135deg,
		var(--accent-mint) 0%,
		var(--primary) 100%
	);
	color: var(--bg-primary);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	padding: var(--spacing-sm) var(--spacing-lg);
	border-radius: var(--radius-full);
	border: none;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: var(--shadow-md);
	margin: var(--spacing-md) auto;
	align-self: center;
	min-width: 100px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	z-index: 10;
	position: relative;
}

.back-button[b-4vmv0ouu3i] {
	background: transparent;
	color: var(--primary);
	border: 2px solid var(--primary);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-bold);
	padding: var(--spacing-sm) var(--spacing-lg);
	border-radius: var(--radius-full);
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: var(--shadow-md);
	margin: var(--spacing-md) auto;
	align-self: center;
	min-width: 100px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	z-index: 10;
	position: relative;
}

.back-button:hover[b-4vmv0ouu3i] {
	background: var(--primary);
	color: var(--bg-primary);
}

.more-button:hover[b-4vmv0ouu3i],
.back-button:hover[b-4vmv0ouu3i] {
	transform: scale(1.05);
	box-shadow: var(--shadow-lg);
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
}

.back-buttons[b-4vmv0ouu3i] {
	display: flex;
	gap: var(--spacing-sm);
	justify-content: center;
	margin-top: 1.25rem; /* Add extra space between description and buttons */
}

.contact-button[b-4vmv0ouu3i] {
	background: linear-gradient(
		135deg,
		var(--accent-mint) 0%,
		var(--primary) 100%
	);
	color: var(--bg-primary);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-bold);
	padding: var(--spacing-sm) var(--spacing-lg);
	border-radius: var(--radius-full);
	border: none;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: var(--shadow-md);
	margin: var(--spacing-md) auto;
	align-self: center;
	min-width: 100px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	z-index: 10;
	position: relative;
}

.contact-button:hover[b-4vmv0ouu3i],
.contact-button:focus[b-4vmv0ouu3i] {
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-mint) 100%
	);
	color: var(--bg-primary);
	transform: scale(1.05);
	box-shadow: var(--shadow-lg);
	outline: none;
}

/* Back Card Content */
.back-content[b-4vmv0ouu3i] {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	height: 100%;
	text-align: center;
	direction: ltr;
	padding: 1rem 1.25rem 1.25rem 1.25rem; /* Reduced top padding */
	box-sizing: border-box;
	width: 100%;
}

.back-text[b-4vmv0ouu3i] {
	color: var(--text-primary);
	font-size: var(--text-base);
	line-height: 1.6;
	margin-bottom: var(--spacing-lg);
	max-width: 90%;
	overflow-y: auto;
	max-height: 120px; /* Prevent overflow, allow scroll for long text */
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	overflow-wrap: anywhere;
	word-break: break-word;
}

/* Flip Card Badges */
.flip-card-badges[b-4vmv0ouu3i] {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.6rem;
	margin-bottom: 0.5rem;
}

.flip-card-badge[b-4vmv0ouu3i] {
	color: var(--accent-mint);
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	background: var(--bg-surface);
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: var(--radius-full);
	border-width: 1px;
	border-style: solid;
	border-color: rgba(41, 240, 180, 0.2);
	border-image: initial;
}

/* Responsive adjustments */
@media (max-width: 900px) {
	.specialization-card[b-4vmv0ouu3i] {
		padding: var(--spacing-lg);
	}
}

@media (max-width: 600px) {
	.specialization-card[b-4vmv0ouu3i] {
		padding: var(--spacing-md);
	}
}

/* Animations for flipping (optional, can be extended) */
@keyframes cardFlip-b-4vmv0ouu3i {
	0% {
		transform: rotateY(0deg);
	}
	100% {
		transform: rotateY(180deg);
	}
}

@keyframes cardFlipBack-b-4vmv0ouu3i {
	0% {
		transform: rotateY(180deg);
	}
	100% {
		transform: rotateY(0deg);
	}
}
/* _content/Alloc42BlazorServer/Components/Cards/SpecializationCard.razor.rz.scp.css */
.spec-card[b-i5prze2vez] {
    width: 220px;
    min-width: 220px;
    background: var(--glass-bg, rgba(255,255,255,0.02));
    border-radius: 12px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 6px 18px rgba(4,4,10,0.06);
    transition: transform 220ms ease, box-shadow 220ms ease;
}
.spec-card:focus[b-i5prze2vez],
.spec-card:hover[b-i5prze2vez] {
    transform: translateY(-6px);
    box-shadow: 0 18px 36px rgba(4,4,10,0.12);
    outline: none;
}
.spec-image[b-i5prze2vez] {
    height: 120px;
    background-size: cover;
    background-position: center;
}
.spec-content[b-i5prze2vez] {
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.spec-content h3[b-i5prze2vez] {
    margin: 0;
    font-size: 1rem;
}
.spec-content .short[b-i5prze2vez] {
    margin: 0;
    color: var(--text-secondary, #6b7280);
    font-size: 0.9rem;
}
.spec-card .btn-ghost[b-i5prze2vez] {
    margin-top: auto;
    align-self: flex-start;
    padding: 0.35rem 0.6rem;
}

@media (max-width: 720px) {
    .spec-card[b-i5prze2vez] { width: 180px; min-width: 180px; }
    .spec-image[b-i5prze2vez] { height: 100px; }
}
/* _content/Alloc42BlazorServer/Components/Forms/CallRequestForm.razor.rz.scp.css */
.call-form[b-59a4hg1wyk] {
	padding: 0;
}

.form-group[b-59a4hg1wyk] {
	margin-bottom: var(--spacing-md);
}

/* Generic form labels and form-input/form-textarea visuals are centralized
   in `wwwroot/app.css`. Component css should only include call-form-specific
   rules (prefixed) below. */

.form-input[b-59a4hg1wyk]::before,
.form-textarea[b-59a4hg1wyk]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(
		135deg,
		rgba(110, 231, 255, 0.05) 0%,
		rgba(155, 140, 255, 0.05) 100%
	);
	opacity: 0;
	transition: opacity var(--transition-normal);
	pointer-events: none;
	z-index: 1;
}

.form-input:hover[b-59a4hg1wyk]::before,
.form-textarea:hover[b-59a4hg1wyk]::before {
	opacity: 1;
}

.form-input:focus[b-59a4hg1wyk],
.form-textarea:focus[b-59a4hg1wyk] {
	outline: none;
	border-color: var(--primary);
	box-shadow:
		0 0 0 4px var(--primary-glow),
		var(--shadow-xl),
		var(--shadow-glow);
	background: linear-gradient(
		135deg,
		var(--bg-surface) 0%,
		var(--bg-surface-elevated) 100%
	);
	transform: translateY(-2px);
}

.form-input:focus[b-59a4hg1wyk]::before,
.form-textarea:focus[b-59a4hg1wyk]::before {
	opacity: 1;
	background: linear-gradient(
		135deg,
		rgba(110, 231, 255, 0.1) 0%,
		rgba(155, 140, 255, 0.1) 100%
	);
}

.form-input:hover[b-59a4hg1wyk],
.form-textarea:hover[b-59a4hg1wyk] {
	border-color: var(--primary);
	background: linear-gradient(
		135deg,
		var(--bg-surface) 0%,
		var(--bg-surface-elevated) 100%
	);
	box-shadow: var(--shadow-lg), var(--shadow-glow);
	transform: translateY(-1px);
}

.form-input[b-59a4hg1wyk]::placeholder,
.form-textarea[b-59a4hg1wyk]::placeholder {
	color: var(--text-muted);
	opacity: 0.7;
	font-style: italic;
}

.form-textarea[b-59a4hg1wyk] {
	min-height: 120px;
	resize: vertical;
}

/* Clean Select Dropdown Styling */
.call-form-select[b-59a4hg1wyk] {
	width: 100%;
	appearance: none !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	background: linear-gradient(
		135deg,
		var(--bg-primary) 0%,
		var(--bg-surface) 100%
	) !important;
	border: 2px solid var(--border-primary) !important;
	border-radius: var(--radius-xl) !important;
	color: var(--text-primary) !important;
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	padding: var(--spacing-md) var(--spacing-lg) !important;
	padding-right: calc(var(--spacing-lg) + 24px) !important;
	box-shadow: var(--shadow-md) !important;
	background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236ee7ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e") !important;
	background-repeat: no-repeat !important;
	background-position: right var(--spacing-lg) center !important;
	background-size: 16px !important;
	cursor: pointer;
	transition: all var(--transition-normal);
}

.call-form-select:hover[b-59a4hg1wyk],
.call-form-select:focus[b-59a4hg1wyk] {
	border-color: var(--primary) !important;
	box-shadow:
		0 0 0 4px var(--primary-glow),
		var(--shadow-xl),
		var(--shadow-glow) !important;
	filter: drop-shadow(0 2px 4px var(--primary-glow));
	background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239b8cff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e") !important;
	background-size: 22px !important;
	transform: scale(1.04) rotateX(8deg);
}

/* select.form-input:hover { ... } removed */

/* select.form-input:focus { ... } removed */

.call-form-select option[b-59a4hg1wyk] {
	background: var(--bg-surface);
	color: var(--text-primary);
	font-family: var(--font-body);
	font-size: var(--text-base);
	border-radius: var(--radius-lg);
	padding: var(--spacing-md) var(--spacing-lg);
}

/* Input Field Icons and Visual Enhancements */
.form-input:not([type="select"]):not([type="textarea"])[b-59a4hg1wyk] {
	position: relative;
}

.form-input:not([type="select"]):not([type="textarea"])[b-59a4hg1wyk]::after {
	content: "";
	position: absolute;
	right: var(--spacing-lg);
	top: 50%;
	transform: translateY(-50%);
	width: 2px;
	height: 20px;
	background: linear-gradient(
		180deg,
		transparent 0%,
		var(--primary) 50%,
		transparent 100%
	);
	opacity: 0;
	transition: opacity var(--transition-normal);
}

.form-input:focus:not([type="select"]):not([type="textarea"])[b-59a4hg1wyk]::after {
	opacity: 0.6;
	animation: pulse-b-59a4hg1wyk 2s infinite;
}

@keyframes pulse-b-59a4hg1wyk {
	0%,
	100% {
		opacity: 0.6;
	}
	50% {
		opacity: 1;
	}
}

/* Floating Label Effect */
.form-group[b-59a4hg1wyk] {
	position: relative;
}

/* Floating label handled globally in wwwroot/app.css. */

/* Input Field Glow Effects */
.form-input:focus[b-59a4hg1wyk],
.form-textarea:focus[b-59a4hg1wyk] {
	position: relative;
}

.form-input:focus[b-59a4hg1wyk]::after,
.form-textarea:focus[b-59a4hg1wyk]::after {
	content: "";
	position: absolute;
	top: -2px;
	left: -2px;
	right: -2px;
	bottom: -2px;
	background: linear-gradient(
		45deg,
		var(--primary),
		var(--accent-violet),
		var(--accent-mint),
		var(--primary)
	);
	border-radius: var(--radius-xl);
	z-index: -1;
	opacity: 0.3;
	animation: rotate-b-59a4hg1wyk 3s linear infinite;
}

@keyframes rotate-b-59a4hg1wyk {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

/* Enhanced Textarea Styling */
.form-textarea[b-59a4hg1wyk] {
	position: relative;
}

.form-textarea[b-59a4hg1wyk]::after {
	content: "";
	position: absolute;
	bottom: var(--spacing-sm);
	right: var(--spacing-sm);
	width: 4px;
	height: 4px;
	background: var(--primary);
	border-radius: 50%;
	opacity: 0;
	transition: opacity var(--transition-normal);
}

.form-textarea:focus[b-59a4hg1wyk]::after {
	opacity: 0.6;
	animation: blink-b-59a4hg1wyk 1.5s infinite;
}

@keyframes blink-b-59a4hg1wyk {
	0%,
	50% {
		opacity: 0.6;
	}
	51%,
	100% {
		opacity: 0;
	}
}

/* form actions and modal chrome are provided by global app.css; keep component-specific
   styles here only for unique visual tweaks. */

.validation-message[b-59a4hg1wyk] {
	color: var(--error);
	font-size: var(--text-sm);
	margin-top: var(--spacing-xs);
}

.btn[b-59a4hg1wyk] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-md) var(--spacing-xl);
	border: none;
	border-radius: var(--radius-lg);
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	text-decoration: none;
	cursor: pointer;
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
	white-space: nowrap;
}

.btn:focus-visible[b-59a4hg1wyk] {
	outline: 2px solid var(--primary);
	outline-offset: 2px;
}

.btn-primary[b-59a4hg1wyk] {
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	color: var(--text-inverse);
	box-shadow: var(--shadow-glow);
	position: relative;
	overflow: hidden;
}

.btn-primary[b-59a4hg1wyk]::before {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.2),
		transparent
	);
	transition: left var(--transition-normal);
}

.btn-primary:hover:not(:disabled)[b-59a4hg1wyk] {
	transform: translateY(-3px);
	box-shadow: var(--shadow-glow-strong), var(--shadow-xl);
}

.btn-primary:hover:not(:disabled)[b-59a4hg1wyk]::before {
	left: 100%;
}

.btn-primary:active[b-59a4hg1wyk] {
	transform: translateY(-1px);
}

.btn-primary:disabled[b-59a4hg1wyk] {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}

.btn-secondary[b-59a4hg1wyk] {
	background: linear-gradient(
		135deg,
		var(--glass-bg) 0%,
		var(--bg-surface) 100%
	);
	color: var(--text-primary);
	border: 2px solid var(--border-accent);
	backdrop-filter: blur(var(--glass-blur));
	position: relative;
	overflow: hidden;
}

.btn-secondary[b-59a4hg1wyk]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	opacity: 0;
	transition: opacity var(--transition-normal);
}

.btn-secondary:hover[b-59a4hg1wyk] {
	border-color: var(--primary);
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg), var(--shadow-glow);
}

.btn-secondary:hover[b-59a4hg1wyk]::before {
	opacity: 0.1;
}
/* _content/Alloc42BlazorServer/Components/Forms/DemoRequestForm.razor.rz.scp.css */
.info-request-form[b-hjenb12351] {
	padding: 0;
}

.form-group[b-hjenb12351] {
	margin-bottom: var(--spacing-md);
}
/* Generic form styles (labels, inputs, selects, textareas) are centralized in
	`wwwroot/app.css`. Component files should include only narrowly-targeted
	or prefixed rules. */

/* Hide default arrow in IE/Edge */
select.form-input[b-hjenb12351]::-ms-expand {
	display: none;
}

/* Remove default arrow in Firefox */
select.form-input:-moz-focusring[b-hjenb12351] {
	color: transparent;
	text-shadow: 0 0 0 var(--text-primary);
}

/* Remove default arrow in Chrome/Safari */
select.form-input[b-hjenb12351]::-webkit-select-placeholder,
select.form-input[b-hjenb12351]::-webkit-input-placeholder {
	color: var(--text-muted);
	opacity: 0.7;
	font-style: italic;
}

select.form-input:hover[b-hjenb12351] {
	background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239b8cff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e") !important;
}

select.form-input:focus[b-hjenb12351] {
	background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236ee7ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e") !important;
}

/* Input Field Visual Enhancements */
.form-input:not([type="select"]):not([type="textarea"])[b-hjenb12351] {
	position: relative;
}

/* Floating Label Effect */
.form-group[b-hjenb12351] {
	position: relative;
}

/* Floating label is provided globally in wwwroot/app.css. */

/* Input Field Glow Effects */
.form-input:focus[b-hjenb12351],
.form-textarea:focus[b-hjenb12351] {
	position: relative;
}

/* Enhanced Textarea Styling */
.form-textarea[b-hjenb12351] {
	position: relative;
}

/* form actions are provided by global app.css; component keeps only unique tweaks */

/* .form-actions::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent 0%,
		var(--primary) 50%,
		transparent 100%
	);
	opacity: 0.3;
} */

.validation-message[b-hjenb12351] {
	color: var(--error);
	font-size: var(--text-sm);
	margin-top: var(--spacing-xs);
}

/* Add spacing after the textarea group */
.form-group textarea.form-textarea[b-hjenb12351] {
	margin-bottom: 0;
}

/* More spacing after "What would you like to learn more about?" */
.form-group:last-of-type[b-hjenb12351] {
	margin-bottom: var(--spacing-md);
}

/* form actions and modal chrome are provided by global app.css; keep component-specific
   styles here only for unique visual tweaks. */

/* modal chrome (scrollbars, header, actions) is centralized in wwwroot/app.css */

.btn[b-hjenb12351] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-md) var(--spacing-xl);
	border: none;
	border-radius: var(--radius-lg);
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	text-decoration: none;
	cursor: pointer;
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
	white-space: nowrap;
}

.btn:focus-visible[b-hjenb12351] {
	outline: 2px solid var(--primary);
	outline-offset: 2px;
}

.btn-primary[b-hjenb12351] {
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	color: var(--text-inverse);
	box-shadow: var(--shadow-glow);
	position: relative;
	overflow: hidden;
}

.btn-primary[b-hjenb12351]::before {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.2),
		transparent
	);
	transition: left var(--transition-normal);
}

.btn-primary:hover:not(:disabled)[b-hjenb12351] {
	transform: translateY(-3px);
	box-shadow: var(--shadow-glow-strong), var(--shadow-xl);
}

.btn-primary:hover:not(:disabled)[b-hjenb12351]::before {
	left: 100%;
}

.btn-primary:active[b-hjenb12351] {
	transform: translateY(-1px);
}

.btn-primary:disabled[b-hjenb12351] {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}

.btn-secondary[b-hjenb12351] {
	background: linear-gradient(
		135deg,
		var(--glass-bg) 0%,
		var(--bg-surface) 100%
	);
	color: var(--text-primary);
	border: 2px solid var(--border-accent);
	backdrop-filter: blur(var(--glass-blur));
	position: relative;
	overflow: hidden;
}

.btn-secondary[b-hjenb12351]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	opacity: 0;
	transition: opacity var(--transition-normal);
}

.btn-secondary:hover[b-hjenb12351] {
	border-color: var(--primary);
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg), var(--shadow-glow);
}

.btn-secondary:hover[b-hjenb12351]::before {
	opacity: 0.1;
}
/* _content/Alloc42BlazorServer/Components/Layout/MainLayout.razor.rz.scp.css */
.page[b-t01e9gpqjo] {
    position: relative;
    display: flex;
    flex-direction: column;
}

main[b-t01e9gpqjo] {
    flex: 1;
}

.sidebar[b-t01e9gpqjo] {
    background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
}

.top-row[b-t01e9gpqjo] {
    background-color: #f7f7f7;
    border-bottom: 1px solid #d6d5d5;
    justify-content: flex-end;
    height: 3.5rem;
    display: flex;
    align-items: center;
}

    .top-row[b-t01e9gpqjo]  a, .top-row[b-t01e9gpqjo]  .btn-link {
        white-space: nowrap;
        margin-left: 1.5rem;
        text-decoration: none;
    }

    .top-row[b-t01e9gpqjo]  a:hover, .top-row[b-t01e9gpqjo]  .btn-link:hover {
        text-decoration: underline;
    }

    .top-row[b-t01e9gpqjo]  a:first-child {
        overflow: hidden;
        text-overflow: ellipsis;
    }

@media (max-width: 640.98px) {
    .top-row[b-t01e9gpqjo] {
        justify-content: space-between;
    }

    .top-row[b-t01e9gpqjo]  a, .top-row[b-t01e9gpqjo]  .btn-link {
        margin-left: 0;
    }
}

@media (min-width: 641px) {
    .page[b-t01e9gpqjo] {
        flex-direction: row;
    }

    .sidebar[b-t01e9gpqjo] {
        width: 250px;
        height: 100vh;
        position: sticky;
        top: 0;
    }

    .top-row[b-t01e9gpqjo] {
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .top-row.auth[b-t01e9gpqjo]  a:first-child {
        flex: 1;
        text-align: right;
        width: 0;
    }

    .top-row[b-t01e9gpqjo], article[b-t01e9gpqjo] {
        padding-left: 2rem !important;
        padding-right: 1.5rem !important;
    }
}

#blazor-error-ui[b-t01e9gpqjo] {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss[b-t01e9gpqjo] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* _content/Alloc42BlazorServer/Components/Layout/NavMenu.razor.rz.scp.css */
.navbar-toggler[b-7gge6il6i0] {
    appearance: none;
    cursor: pointer;
    width: 3.5rem;
    height: 2.5rem;
    color: white;
    position: absolute;
    top: 0.5rem;
    right: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") no-repeat center/1.75rem rgba(255, 255, 255, 0.1);
}

.navbar-toggler:checked[b-7gge6il6i0] {
    background-color: rgba(255, 255, 255, 0.5);
}

.top-row[b-7gge6il6i0] {
    min-height: 3.5rem;
    background-color: rgba(0,0,0,0.4);
}

.navbar-brand[b-7gge6il6i0] {
    font-size: 1.1rem;
}

.bi[b-7gge6il6i0] {
    display: inline-block;
    position: relative;
    width: 1.25rem;
    height: 1.25rem;
    margin-right: 0.75rem;
    top: -1px;
    background-size: cover;
}

.bi-house-door-fill-nav-menu[b-7gge6il6i0] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-house-door-fill' viewBox='0 0 16 16'%3E%3Cpath d='M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5Z'/%3E%3C/svg%3E");
}

.bi-plus-square-fill-nav-menu[b-7gge6il6i0] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-plus-square-fill' viewBox='0 0 16 16'%3E%3Cpath d='M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z'/%3E%3C/svg%3E");
}

.bi-list-nested-nav-menu[b-7gge6il6i0] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-list-nested' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M4.5 11.5A.5.5 0 0 1 5 11h10a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 3 7h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 1 3h10a.5.5 0 0 1 0 1H1a.5.5 0 0 1-.5-.5z'/%3E%3C/svg%3E");
}

.nav-item[b-7gge6il6i0] {
    font-size: 0.9rem;
    padding-bottom: 0.5rem;
}

    .nav-item:first-of-type[b-7gge6il6i0] {
        padding-top: 1rem;
    }

    .nav-item:last-of-type[b-7gge6il6i0] {
        padding-bottom: 1rem;
    }

    .nav-item[b-7gge6il6i0]  .nav-link {
        color: #d7d7d7;
        background: none;
        border: none;
        border-radius: 4px;
        height: 3rem;
        display: flex;
        align-items: center;
        line-height: 3rem;
        width: 100%;
    }

.nav-item[b-7gge6il6i0]  a.active {
    background-color: rgba(255,255,255,0.37);
    color: white;
}

.nav-item[b-7gge6il6i0]  .nav-link:hover {
    background-color: rgba(255,255,255,0.1);
    color: white;
}

.nav-scrollable[b-7gge6il6i0] {
    display: none;
}

.navbar-toggler:checked ~ .nav-scrollable[b-7gge6il6i0] {
    display: block;
}

@media (min-width: 641px) {
    .navbar-toggler[b-7gge6il6i0] {
        display: none;
    }

    .nav-scrollable[b-7gge6il6i0] {
        /* Never collapse the sidebar for wide screens */
        display: block;

        /* Allow sidebar to scroll for tall menus */
        height: calc(100vh - 3.5rem);
        overflow-y: auto;
    }
}
/* _content/Alloc42BlazorServer/Components/Layouts/HorizontalCarousel.razor.rz.scp.css */
.hc-root[b-oqrqve6u1i] {
  position: relative;
  padding: 24px 0; /* give the carousel some vertical breathing room */
  @media (max-width: 600px) {
    padding: 12px 0;[b-oqrqve6u1i] /* reduce vertical padding on small screens */
  }
}

.hc-arrow[b-oqrqve6u1i] {
  background: var(--glass-bg, rgba(255, 255, 255, 0.02));
  border: none;
  border-radius: 999px;
  padding: 0.3rem 0.6rem;
  cursor: pointer;
}
.hc-track[b-oqrqve6u1i] {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 0.75rem 1rem; /* slightly larger horizontal padding */
  -webkit-overflow-scrolling: touch; /* enables momentum scrolling on iOS */
  touch-action: pan-x; /* hint to the browser that horizontal pan should be handled here */
  box-sizing: border-box; /* ensure padding doesn't add to width */
  width: 100%; /* constrain to parent width */
  max-width: 100%; /* avoid growing beyond container */
  overscroll-behavior-x: contain; /* prevent scroll chaining to the body */

  @media (min-width: 600px) {
    padding: 0;[b-oqrqve6u1i]
  }
}
.hc-track > *[b-oqrqve6u1i] {
  scroll-snap-align: start;
}
.hc-track:focus[b-oqrqve6u1i] {
  outline: none;
}

@media (max-width: 840px) {
  .hc-controls[b-oqrqve6u1i] {
    display: none;
  }
}
/* _content/Alloc42BlazorServer/Components/Layouts/InteractiveStack.razor.rz.scp.css */
.is-root[b-x16ud0nyg2] {
  /* expose the card width as a local CSS variable so scoped CSS works in Blazor */
  --is-card-width: 520px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding-bottom: 8rem;
}
.is-stack[b-x16ud0nyg2] {
  position: relative;
  width: 100%;
  max-width: var(--is-card-width);
  min-height: 520px;
  padding: 24px;
  margin: 0 auto;
  /* prevent scroll chaining to the viewport when interacting with the stack */
  overscroll-behavior: contain;
  /* hint to touch/browser to allow wheel/touch handling inside this element */
  touch-action: none;
}

.is-card[b-x16ud0nyg2] {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: var(--is-card-width);
  transition: transform 320ms cubic-bezier(0.2, 0.9, 0.3, 1), opacity 260ms ease,
    box-shadow 260ms ease;
  will-change: transform, opacity;
  cursor: pointer;
}

/* visual stacking: dim the non-front cards slightly */
.is-card[b-x16ud0nyg2] {
  opacity: 0.85;
}
.is-card.front[b-x16ud0nyg2] {
  opacity: 1;
  transform-origin: center top;
  background-color: black;
  box-shadow: 0 26px 50px rgba(8, 10, 20, 0.24);
  border-radius: 2rem;
}

.is-card .flip-card[b-x16ud0nyg2] {
  width: 100%;
}

.is-card:hover[b-x16ud0nyg2] {
  transform: translateX(-50%) translateY(-4px) scale(1.02);
  box-shadow: 0 18px 40px rgba(8, 10, 20, 0.18);
}

/* responsive sizes */
@media (max-width: 1100px) {
  .is-root[b-x16ud0nyg2] {
    --is-card-width: 460px;
  }
  .is-stack[b-x16ud0nyg2] {
    min-height: 480px;
  }
}

@media (max-width: 840px) {
  .is-root[b-x16ud0nyg2] {
    --is-card-width: 360px;
  }
  .is-stack[b-x16ud0nyg2] {
    min-height: 420px;
    padding: 12px;
  }
}

@media (max-width: 520px) {
  .is-root[b-x16ud0nyg2] {
    --is-card-width: 320px;
  }
  .is-stack[b-x16ud0nyg2] {
    min-height: 380px;
  }
}
/* _content/Alloc42BlazorServer/Components/Layouts/SpotlightDeck.razor.rz.scp.css */
.sd-root[b-bp4qgmrsrd] {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	width: 100%;
}

.sd-track[b-bp4qgmrsrd] {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	min-height: 640px; /* reserve generous vertical space for larger spotlight cards */
	width: 100%;
	max-width: 1200px;
	box-sizing: border-box;
	padding: 1rem 0;
	position: relative;
	overflow: visible; /* allow items to animate in/out; we will clip visually via transforms */

	/* card sizing variables - adjust these to tweak width/gap */
	--sd-card-width: 420px; /* increased default width for spotlight */
	--sd-card-gap: 28px;
}

/* Each item gets a stable width so content doesn't reflow */
.sd-item[b-bp4qgmrsrd] {
	flex: 0 0 var(--sd-card-width);
    width: var(--sd-card-width);
	opacity: 0;
	transform: translateX(0) translateY(12px) scale(0.94);
	transform-origin: center center;
	transition: transform 420ms cubic-bezier(.2,.9,.2,1), opacity 320ms ease, filter 320ms ease;
	display: flex;
	align-items: stretch;
	justify-content: center;
	pointer-events: none; /* only active card receives pointer events */
	position: absolute; /* stack items for smoother motion */
	left: 50%;
	top: 0;
	transform-style: preserve-3d;
	will-change: transform, opacity;
}

.sd-item .flip-card[b-bp4qgmrsrd] {
	width: 100%;
}


.sd-item.active[b-bp4qgmrsrd] {
	opacity: 1;
	transform: translateX(-50%) translateY(0) scale(1);
	z-index: 50;
	pointer-events: auto;
}


.sd-item.prev[b-bp4qgmrsrd] {
	opacity: 0.45;
	transform: translateX(calc(-50% - (var(--sd-card-width) + var(--sd-card-gap)))) translateY(6px) scale(0.96);
	z-index: 30;
}

.sd-item.next[b-bp4qgmrsrd] {
	opacity: 0.45;
	transform: translateX(calc(-50% + (var(--sd-card-width) + var(--sd-card-gap)))) translateY(6px) scale(0.96);
	z-index: 30;
}

.sd-item.hidden[b-bp4qgmrsrd] {
	opacity: 0;
	visibility: hidden;
	transform: translateX(-50%) translateY(18px) scale(0.9);
	z-index: 1;
}

.sd-controls.hc-controls[b-bp4qgmrsrd] {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	display: flex;
	justify-content: space-between;
	pointer-events: none;
	padding: 0 1rem;
	transform: translateY(-50%);
	z-index: 60;
}

.sd-controls.hc-controls .hc-arrow[b-bp4qgmrsrd] {
	pointer-events: auto;
}

@media (max-width: 1200px) {
	/* medium viewports: slightly narrower than desktop but still roomy */
	.sd-track[b-bp4qgmrsrd] { --sd-card-width: 460px; --sd-card-gap: 24px; }
	.sd-track[b-bp4qgmrsrd] { min-height: 580px; }
}

@media (max-width: 980px) {
	.sd-track[b-bp4qgmrsrd] { --sd-card-width: 400px; --sd-card-gap: 20px; }
	.sd-track[b-bp4qgmrsrd] { min-height: 520px; }
}

@media (max-width: 840px) {
	.sd-track[b-bp4qgmrsrd] { --sd-card-width: 360px; --sd-card-gap: 16px; }
	.sd-item[b-bp4qgmrsrd] { flex: 0 0 var(--sd-card-width); }
	.sd-track[b-bp4qgmrsrd] { min-height: 520px; }
}

/* On small screens, move the prev/next controls below the cards and center them */
@media (max-width: 768px) {
	.sd-controls.hc-controls[b-bp4qgmrsrd] {
		position: static;
		transform: none;
		display: flex;
		justify-content: center;
		gap: var(--spacing-lg, 1rem);
		width: 100%;
		padding: 0.5rem 0;
		margin-top: 0.75rem;
		pointer-events: auto;
		z-index: 60;
	}

	/* Slightly larger touch targets for arrows on mobile */
	.sd-controls.hc-controls .hc-arrow[b-bp4qgmrsrd] {
		padding: 0.5rem 0.75rem;
		border-radius: 8px;
	}

	/* Keep the track height reasonable on narrow screens */
	.sd-track[b-bp4qgmrsrd] {
		min-height: 440px;
		padding-bottom: 0.5rem; /* give room for controls */
	}
}
/* _content/Alloc42BlazorServer/Components/Modals/TourModal.razor.rz.scp.css */
.tour-modal[b-1b0a9fuuqm] {
	padding: 0;
}
.form-group[b-1b0a9fuuqm] {
	margin-bottom: var(--spacing-lg);
}
.form-label[b-1b0a9fuuqm] {
	display: block;
	color: var(--text-primary);
	font-weight: var(--font-weight-semibold);
	margin-bottom: calc(var(--spacing-sm) + 2px);
	font-size: var(--text-sm);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	position: relative;
}
.form-label[b-1b0a9fuuqm]::after {
	content: "";
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 0;
	height: 2px;
	background: linear-gradient(
		90deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	transition: width var(--transition-normal);
}
.form-group:focus-within .form-label[b-1b0a9fuuqm]::after {
	width: 60px;
}
/* Tour-specific form controls: these are intentionally prefixed to avoid
   colliding with the global form styles in `wwwroot/app.css`. */
.tour-input[b-1b0a9fuuqm],
.tour-textarea[b-1b0a9fuuqm] {
	width: 100%;
	padding: var(--spacing-md) var(--spacing-lg);
	border: 2px solid var(--border-primary);
	border-radius: var(--radius-xl);
	background: linear-gradient(
		135deg,
		var(--bg-primary) 0%,
		var(--bg-surface) 100%
	);
	color: var(--text-primary);
	font-family: var(--font-body);
	font-size: var(--text-base);
	transition: all var(--transition-normal);
	box-shadow: var(--shadow-md);
	position: relative;
	backdrop-filter: blur(8px);
	overflow: hidden;
}

.tour-input[b-1b0a9fuuqm]::before,
.tour-textarea[b-1b0a9fuuqm]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(
		135deg,
		rgba(110, 231, 255, 0.05) 0%,
		rgba(155, 140, 255, 0.05) 100%
	);
	opacity: 0;
	transition: opacity var(--transition-normal);
	pointer-events: none;
	z-index: 1;
}
.tour-input:hover[b-1b0a9fuuqm]::before,
.tour-textarea:hover[b-1b0a9fuuqm]::before {
	opacity: 1;
}
.tour-input:focus[b-1b0a9fuuqm],
.tour-textarea:focus[b-1b0a9fuuqm] {
	outline: none;
	border-color: var(--primary);
	box-shadow:
		0 0 0 4px var(--primary-glow),
		var(--shadow-xl),
		var(--shadow-glow);
	background: linear-gradient(
		135deg,
		var(--bg-surface) 0%,
		var(--bg-surface-elevated) 100%
	);
	transform: translateY(-2px);
}
.tour-input:focus[b-1b0a9fuuqm]::before,
.tour-textarea:focus[b-1b0a9fuuqm]::before {
	opacity: 1;
	background: linear-gradient(
		135deg,
		rgba(110, 231, 255, 0.1) 0%,
		rgba(155, 140, 255, 0.1) 100%
	);
}
.tour-input:hover[b-1b0a9fuuqm],
.tour-textarea:hover[b-1b0a9fuuqm] {
	border-color: var(--primary);
	background: linear-gradient(
		135deg,
		var(--bg-surface) 0%,
		var(--bg-surface-elevated) 100%
	);
	box-shadow: var(--shadow-lg), var(--shadow-glow);
	transform: translateY(-1px);
}
.tour-input[b-1b0a9fuuqm]::placeholder,
.tour-textarea[b-1b0a9fuuqm]::placeholder {
	color: var(--text-muted);
	opacity: 0.7;
	font-style: italic;
}
.tour-textarea[b-1b0a9fuuqm] {
	min-height: 120px;
	resize: vertical;
}
.tour-select[b-1b0a9fuuqm] {
	width: 100%;
	appearance: none !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	background: linear-gradient(
		135deg,
		var(--bg-primary) 0%,
		var(--bg-surface) 100%
	) !important;
	border: 2px solid var(--border-primary) !important;
	border-radius: var(--radius-xl) !important;
	color: var(--text-primary) !important;
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	padding: var(--spacing-md) var(--spacing-lg) !important;
	padding-right: calc(var(--spacing-lg) + 24px) !important;
	box-shadow: var(--shadow-md) !important;
	background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236ee7ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e") !important;
	background-repeat: no-repeat !important;
	background-position: right var(--spacing-lg) center !important;
	background-size: 16px !important;
	cursor: pointer;
	transition: all var(--transition-normal);
}
.tour-select option[b-1b0a9fuuqm] {
	background: var(--bg-surface);
	color: var(--text-primary);
	font-family: var(--font-body);
	font-size: var(--text-base);
	border-radius: var(--radius-lg);
	padding: var(--spacing-md) var(--spacing-lg);
}

.tour-content[b-1b0a9fuuqm] {
	text-align: center;
}

.tour-title[b-1b0a9fuuqm] {
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-extrabold);
	color: var(--text-primary);
	margin-bottom: var(--spacing-lg);
	background: linear-gradient(
		135deg,
		var(--text-primary) 0%,
		var(--primary) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.tour-description[b-1b0a9fuuqm] {
	font-size: var(--text-base);
	color: var(--text-secondary);
	margin-bottom: var(--spacing-xl);
	line-height: var(--leading-relaxed);
}

.tour-video-placeholder[b-1b0a9fuuqm] {
	background: linear-gradient(
		135deg,
		var(--bg-surface) 0%,
		var(--bg-surface-elevated) 100%
	);
	border: 2px dashed var(--primary);
	border-radius: var(--radius-xl);
	padding: var(--spacing-3xl);
	margin-bottom: var(--spacing-2xl);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-lg);
	box-shadow: var(--shadow-lg);
	transition: all var(--transition-normal);
}

.tour-video-placeholder:hover[b-1b0a9fuuqm] {
	border-color: var(--accent-violet);
	box-shadow: var(--shadow-xl), var(--shadow-glow);
	transform: translateY(-2px);
}

.video-icon[b-1b0a9fuuqm] {
	color: var(--primary);
	opacity: 0.7;
}

.video-text[b-1b0a9fuuqm] {
	color: var(--text-muted);
	font-size: var(--text-sm);
	font-style: italic;
}

.tour-actions[b-1b0a9fuuqm] {
	display: flex;
	justify-content: center;
}

.btn[b-1b0a9fuuqm] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-md) var(--spacing-xl);
	border: none;
	border-radius: var(--radius-lg);
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	text-decoration: none;
	cursor: pointer;
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
	white-space: nowrap;
}

.btn:focus-visible[b-1b0a9fuuqm] {
	outline: 2px solid var(--primary);
	outline-offset: 2px;
}

.btn-primary[b-1b0a9fuuqm] {
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--primary-light) 100%
	);
	color: var(--text-inverse);
	box-shadow: var(--shadow-glow);
}

.btn-primary:hover[b-1b0a9fuuqm] {
	transform: translateY(-2px);
	box-shadow: var(--shadow-glow-strong);
}

.btn-primary:active[b-1b0a9fuuqm] {
	transform: translateY(0);
}
/* _content/Alloc42BlazorServer/Components/Pages/Analytics.razor.rz.scp.css */
.analytics-container[b-km7lykguec] {
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--spacing-xl);
    color: var(--text-primary);
}

.analytics-title[b-km7lykguec] {
    font-size: 2.5rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-xl);
    text-align: center;
}

.analytics-grid[b-km7lykguec] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.analytics-card[b-km7lykguec] {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-md);
}

.analytics-card h2[b-km7lykguec] {
    font-size: 1.5rem;
    font-weight: var(--font-weight-semibold);
    color: var(--primary);
    margin-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--accent-mint);
    padding-bottom: var(--spacing-sm);
}

.stats-list[b-km7lykguec] {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.stat-item[b-km7lykguec] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm);
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--accent-mint);
}

.stat-name[b-km7lykguec] {
    font-weight: var(--font-weight-medium);
    color: var(--text-primary);
}

.stat-count[b-km7lykguec] {
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    background: var(--bg-surface);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-full);
    font-size: 0.9rem;
}

.activity-list[b-km7lykguec] {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    max-height: 400px;
    overflow-y: auto;
}

.activity-item[b-km7lykguec] {
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm);
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
}

.activity-type[b-km7lykguec] {
    font-weight: var(--font-weight-medium);
    color: var(--accent-mint);
    text-transform: uppercase;
    font-size: 0.8rem;
}

.activity-element[b-km7lykguec] {
    color: var(--text-primary);
    font-weight: var(--font-weight-medium);
}

.activity-time[b-km7lykguec] {
    color: var(--text-secondary);
    text-align: right;
    font-size: 0.8rem;
}

.analytics-actions[b-km7lykguec] {
    text-align: center;
    margin-top: var(--spacing-xl);
}

.btn[b-km7lykguec] {
    background: linear-gradient(135deg, var(--accent-mint) 0%, var(--primary) 100%);
    color: var(--bg-primary);
    border: none;
    padding: var(--spacing-md) var(--spacing-xl);
    border-radius: var(--radius-full);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.btn:hover[b-km7lykguec] {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent-violet) 100%);
}

.btn-primary[b-km7lykguec] {
    background: linear-gradient(135deg, var(--accent-mint) 0%, var(--primary) 100%);
}

/* Responsive design */
@media (max-width: 768px) {
    .analytics-container[b-km7lykguec] {
        padding: var(--spacing-md);
    }
    
    .analytics-title[b-km7lykguec] {
        font-size: 2rem;
    }
    
    .analytics-grid[b-km7lykguec] {
        grid-template-columns: 1fr;
    }
    
    .activity-item[b-km7lykguec] {
        grid-template-columns: 1fr;
        gap: var(--spacing-xs);
        text-align: center;
    }
    
    .activity-time[b-km7lykguec] {
        text-align: center;
    }
}

/* _content/Alloc42BlazorServer/Components/Pages/ClickStats.razor.rz.scp.css */
.clickstats-container[b-r7a10vyzt7] {
    max-width: 1400px;
    margin: 0 auto;
    padding: var(--spacing-xl);
    color: var(--text-primary);
}

/* Navigation Header */
.navigation-header[b-r7a10vyzt7] {
    background: rgba(255, 255, 255, 0.95);
    border: none;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 30px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
    backdrop-filter: blur(10px);
}

.nav-menu[b-r7a10vyzt7] {
    display: flex;
    gap: 15px;
    align-items: center;
    flex-wrap: wrap;
}

.nav-button[b-r7a10vyzt7] {
    background: linear-gradient(135deg, #6c757d, #495057);
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    text-decoration: none;
    display: inline-block;
}

.nav-button:hover[b-r7a10vyzt7] {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    color: white;
    text-decoration: none;
}

.nav-button.active[b-r7a10vyzt7] {
    background: linear-gradient(135deg, #007bff, #00d4ff);
    box-shadow: 0 4px 15px rgba(0, 123, 255, 0.3);
}

.nav-button.home[b-r7a10vyzt7] {
    background: linear-gradient(135deg, #28a745, #20c997);
}

.clickstats-header[b-r7a10vyzt7] {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.clickstats-title[b-r7a10vyzt7] {
    font-size: 3rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-md);
}

.clickstats-subtitle[b-r7a10vyzt7] {
    font-size: 1.2rem;
    color: var(--text-secondary);
    margin-bottom: 0;
}

/* Date Range Controls */
.date-range-controls[b-r7a10vyzt7] {
    display: flex;
    gap: var(--spacing-lg);
    align-items: end;
    justify-content: center;
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-lg);
    background: var(--bg-surface);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
}

.date-input-group[b-r7a10vyzt7] {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.date-input-group label[b-r7a10vyzt7] {
    font-weight: var(--font-weight-medium);
    color: var(--text-primary);
    font-size: 0.9rem;
}

.date-input-group input[b-r7a10vyzt7] {
    padding: var(--spacing-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 1rem;
}

.date-input-group input:focus[b-r7a10vyzt7] {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 2px rgba(110, 231, 255, 0.2);
}

/* Summary Cards */
.summary-cards[b-r7a10vyzt7] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.summary-card[b-r7a10vyzt7] {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    text-align: center;
    box-shadow: var(--shadow-md);
}

.summary-card h3[b-r7a10vyzt7] {
    font-size: 1.1rem;
    font-weight: var(--font-weight-medium);
    color: var(--text-secondary);
    margin-bottom: var(--spacing-sm);
}

.summary-value[b-r7a10vyzt7] {
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
}

.most-popular-cards[b-r7a10vyzt7] {
    font-size: 1.4rem;
    line-height: 1.4;
    text-align: left;
}

/* Rollup Section */
.rollup-section[b-r7a10vyzt7] {
    margin-bottom: var(--spacing-xl);
}

.rollup-section h2[b-r7a10vyzt7] {
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-lg);
    text-align: center;
}

.rollup-card[b-r7a10vyzt7] {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    box-shadow: var(--shadow-md);
}

.rollup-card h3[b-r7a10vyzt7] {
    font-size: 1.5rem;
    font-weight: var(--font-weight-semibold);
    color: var(--accent-mint);
    margin-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--accent-mint);
    padding-bottom: var(--spacing-sm);
}

.rollup-list[b-r7a10vyzt7] {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    max-height: 400px;
    overflow-y: auto;
}

.rollup-item[b-r7a10vyzt7] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: var(--spacing-sm);
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--primary);
    flex-direction: column;
    gap: var(--spacing-xs);
}

.rollup-time[b-r7a10vyzt7] {
    font-weight: var(--font-weight-medium);
    color: var(--text-primary);
}

.rollup-cards[b-r7a10vyzt7] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    width: 100%;
}

.card-count[b-r7a10vyzt7] {
    background: var(--bg-surface);
    color: var(--text-secondary);
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    border: 1px solid var(--border-color);
}

.rollup-count[b-r7a10vyzt7] {
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    background: var(--bg-surface);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-full);
    font-size: 0.9rem;
}

/* Interaction Summary */
.interaction-summary[b-r7a10vyzt7] {
    margin-bottom: var(--spacing-xl);
}

.interaction-summary h2[b-r7a10vyzt7] {
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-lg);
    text-align: center;
}

.summary-grid[b-r7a10vyzt7] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-md);
}

.interaction-type-card[b-r7a10vyzt7] {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    text-align: center;
    box-shadow: var(--shadow-md);
    transition: transform 0.2s ease;
}

.interaction-type-card:hover[b-r7a10vyzt7] {
    transform: translateY(-2px);
}

.interaction-type-card h4[b-r7a10vyzt7] {
    font-size: 1.1rem;
    font-weight: var(--font-weight-medium);
    color: var(--text-primary);
    margin-bottom: var(--spacing-sm);
}

.interaction-count[b-r7a10vyzt7] {
    font-size: 2.5rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-xs);
}

.interaction-percentage[b-r7a10vyzt7] {
    font-size: 1rem;
    color: var(--accent-mint);
    font-weight: var(--font-weight-medium);
}

/* Detailed Interactions Table */
.detailed-interactions[b-r7a10vyzt7] {
    margin-bottom: var(--spacing-xl);
}

.detailed-interactions h2[b-r7a10vyzt7] {
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-lg);
    text-align: center;
}

.interactions-table[b-r7a10vyzt7] {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
}

.interactions-table table[b-r7a10vyzt7] {
    width: 100%;
    border-collapse: collapse;
}

.interactions-table th[b-r7a10vyzt7] {
    background: var(--bg-primary);
    color: var(--text-primary);
    font-weight: var(--font-weight-semibold);
    padding: var(--spacing-md);
    text-align: left;
    border-bottom: 2px solid var(--border-color);
}

.interactions-table td[b-r7a10vyzt7] {
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
}

.interactions-table tr:hover[b-r7a10vyzt7] {
    background: var(--bg-primary);
}

.table-note[b-r7a10vyzt7] {
    padding: var(--spacing-md);
    text-align: center;
    color: var(--text-secondary);
    font-style: italic;
    margin: 0;
}

/* Actions */
.clickstats-actions[b-r7a10vyzt7] {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
    margin-top: var(--spacing-xl);
}

.btn[b-r7a10vyzt7] {
    padding: var(--spacing-md) var(--spacing-xl);
    border: none;
    border-radius: var(--radius-full);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    text-decoration: none;
    display: inline-block;
}

.btn-primary[b-r7a10vyzt7] {
    background: linear-gradient(135deg, var(--accent-mint) 0%, var(--primary) 100%);
    color: var(--bg-primary);
}

.btn-primary:hover[b-r7a10vyzt7] {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent-violet) 100%);
}

.btn-secondary[b-r7a10vyzt7] {
    background: var(--bg-surface);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

.btn-secondary:hover[b-r7a10vyzt7] {
    background: var(--bg-primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* Responsive Design */
@media (max-width: 768px) {
    .clickstats-container[b-r7a10vyzt7] {
        padding: var(--spacing-md);
    }
    
    .clickstats-title[b-r7a10vyzt7] {
        font-size: 2rem;
    }
    
    .date-range-controls[b-r7a10vyzt7] {
        flex-direction: column;
        align-items: stretch;
    }
    
    .summary-cards[b-r7a10vyzt7] {
        grid-template-columns: 1fr;
    }
    
    .summary-grid[b-r7a10vyzt7] {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    }
    
    .interactions-table[b-r7a10vyzt7] {
        overflow-x: auto;
    }
    
    .interactions-table table[b-r7a10vyzt7] {
        min-width: 600px;
    }
    
    .clickstats-actions[b-r7a10vyzt7] {
        flex-direction: column;
        align-items: center;
    }
}

@media (max-width: 480px) {
    .rollup-item[b-r7a10vyzt7] {
        flex-direction: column;
        gap: var(--spacing-xs);
        text-align: center;
    }
    
    .interaction-type-card h4[b-r7a10vyzt7] {
        font-size: 1rem;
    }
    
    .interaction-count[b-r7a10vyzt7] {
        font-size: 2rem;
    }
}

/* _content/Alloc42BlazorServer/Components/Pages/FlowStats.razor.rz.scp.css */
/* FlowStats Page Styling - Matching ClickStats Theme */

.flow-stats-container[b-gii3kyygdp] {
    max-width: 1400px;
    margin: 0 auto;
    padding: var(--spacing-xl);
    color: var(--text-primary);
    background: var(--background-primary);
    min-height: 100vh;
}

/* Navigation Header */
.navigation-header[b-gii3kyygdp] {
    background: var(--card-background);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
    box-shadow: var(--shadow-md);
}

.nav-menu[b-gii3kyygdp] {
    display: flex;
    gap: var(--spacing-md);
    align-items: center;
    flex-wrap: wrap;
}

.nav-button[b-gii3kyygdp] {
    background: var(--secondary);
    color: var(--text-on-secondary);
    border: none;
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: var(--border-radius);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
    text-decoration: none;
    display: inline-block;
}

.nav-button:hover[b-gii3kyygdp] {
    background: var(--secondary-hover);
    color: var(--text-on-secondary);
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.nav-button.active[b-gii3kyygdp] {
    background: var(--primary);
    color: var(--text-on-primary);
    box-shadow: var(--shadow-md);
}

.nav-button.home[b-gii3kyygdp] {
    background: var(--success);
    color: var(--text-on-success);
}

.nav-button.home:hover[b-gii3kyygdp] {
    background: var(--success-hover);
    color: var(--text-on-success);
}

/* Header Section */
.flow-stats-header[b-gii3kyygdp] {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.flow-stats-header h1[b-gii3kyygdp] {
    font-size: 3rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-md);
}

.flow-stats-header p[b-gii3kyygdp] {
    font-size: 1.2rem;
    color: var(--text-secondary);
    margin-bottom: 0;
}

/* Date Range Controls */
.date-range-controls[b-gii3kyygdp] {
    background: var(--card-background);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
    box-shadow: var(--shadow-md);
}

.date-range-controls h4[b-gii3kyygdp] {
    margin-top: 0;
    color: var(--text-primary);
    font-size: 1.2rem;
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-lg);
}

.date-inputs[b-gii3kyygdp] {
    display: flex;
    gap: var(--spacing-lg);
    align-items: center;
    flex-wrap: wrap;
}

.date-inputs input[b-gii3kyygdp] {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    font-size: 0.9rem;
    background: var(--input-background);
    color: var(--text-primary);
    transition: border-color var(--transition-fast);
}

.date-inputs input:focus[b-gii3kyygdp] {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 2px var(--primary-light);
}

.refresh-button[b-gii3kyygdp] {
    background: var(--primary);
    color: var(--text-on-primary);
    border: none;
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: var(--border-radius);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
}

.refresh-button:hover[b-gii3kyygdp] {
    background: var(--primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

/* Stats Grid */
.stats-grid[b-gii3kyygdp] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.stat-card[b-gii3kyygdp] {
    background: var(--card-background);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-xl);
    text-align: center;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-fast);
}

.stat-card:hover[b-gii3kyygdp] {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.stat-number[b-gii3kyygdp] {
    font-size: 2.5rem;
    font-weight: var(--font-weight-bold);
    color: var(--primary);
    margin-bottom: var(--spacing-sm);
}

.stat-label[b-gii3kyygdp] {
    color: var(--text-primary);
    font-size: 1rem;
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-sm);
}

.stat-detail[b-gii3kyygdp] {
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-style: italic;
}

/* Flow Sections */
.flow-section[b-gii3kyygdp] {
    background: var(--card-background);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
    box-shadow: var(--shadow-md);
}

/* Flow Table Styling */
.flow-table[b-gii3kyygdp] {
    width: 100%;
    border-collapse: collapse;
}

.flow-header[b-gii3kyygdp] {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1fr;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--background-secondary);
    border-bottom: 2px solid var(--primary);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.flow-row[b-gii3kyygdp] {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1fr;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
    transition: all var(--transition-fast);
    align-items: center;
}

.flow-row:hover[b-gii3kyygdp] {
    background: var(--background-secondary);
    transform: translateX(2px);
}

.flow-row:last-child[b-gii3kyygdp] {
    border-bottom: none;
}

.flow-cell[b-gii3kyygdp] {
    color: var(--text-primary);
    font-size: 0.9rem;
    word-break: break-word;
    display: flex;
    align-items: center;
}

.flow-cell.session-id[b-gii3kyygdp] {
    font-family: monospace;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.flow-cell.status-completed[b-gii3kyygdp] {
    color: var(--success);
    font-weight: var(--font-weight-semibold);
}

.flow-cell.status-timeout[b-gii3kyygdp] {
    color: var(--warning);
    font-weight: var(--font-weight-semibold);
}

.flow-cell.status-abandoned[b-gii3kyygdp] {
    color: var(--danger);
    font-weight: var(--font-weight-semibold);
}

.flow-cell.status-started[b-gii3kyygdp] {
    color: var(--info);
    font-weight: var(--font-weight-semibold);
}

.flow-section h3[b-gii3kyygdp] {
    margin-top: 0;
    color: var(--text-primary);
    border-bottom: 2px solid var(--primary);
    padding-bottom: var(--spacing-md);
    font-size: 1.4rem;
    font-weight: var(--font-weight-semibold);
}

.flow-item[b-gii3kyygdp] {
    background: var(--background-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    transition: all var(--transition-fast);
}

.flow-item:hover[b-gii3kyygdp] {
    transform: translateX(4px);
    box-shadow: var(--shadow-sm);
}

.flow-item:last-child[b-gii3kyygdp] {
    margin-bottom: 0;
}

.flow-header[b-gii3kyygdp] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-md);
}

.flow-title[b-gii3kyygdp] {
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    font-size: 1.1rem;
}

.flow-status[b-gii3kyygdp] {
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--border-radius-full);
    font-size: 0.8rem;
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.flow-status.completed[b-gii3kyygdp] {
    background: var(--success-light);
    color: var(--success-dark);
}

.flow-status.started[b-gii3kyygdp] {
    background: var(--warning-light);
    color: var(--warning-dark);
}

.flow-status.abandoned[b-gii3kyygdp] {
    background: var(--danger-light);
    color: var(--danger-dark);
}

.flow-status.timeout[b-gii3kyygdp] {
    background: var(--info-light);
    color: var(--info-dark);
}

.flow-details[b-gii3kyygdp] {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

.flow-details div[b-gii3kyygdp] {
    margin-bottom: var(--spacing-xs);
    display: flex;
    align-items: center;
}

.flow-details div:last-child[b-gii3kyygdp] {
    margin-bottom: 0;
}

.flow-details strong[b-gii3kyygdp] {
    color: var(--text-primary);
    margin-right: var(--spacing-sm);
    min-width: 80px;
}

/* Session Journey */
.session-journey[b-gii3kyygdp] {
    background: var(--background-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.session-journey:last-child[b-gii3kyygdp] {
    margin-bottom: 0;
}

.session-header[b-gii3kyygdp] {
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin-bottom: var(--spacing-sm);
    padding-bottom: var(--spacing-xs);
    border-bottom: 1px solid var(--border-color);
}

.flow-timeline[b-gii3kyygdp] {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.flow-timeline-item[b-gii3kyygdp] {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm);
    background: var(--card-background);
    border-radius: var(--border-radius);
    border-left: 3px solid var(--primary);
}

.flow-timeline-item .flow-type[b-gii3kyygdp] {
    font-weight: var(--font-weight-semibold);
    color: var(--primary);
    min-width: 80px;
}

.flow-timeline-item .flow-element[b-gii3kyygdp] {
    flex: 1;
    color: var(--text-primary);
}

.flow-timeline-item .flow-time[b-gii3kyygdp] {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* Loading and No Data States */
.loading[b-gii3kyygdp] {
    text-align: center;
    padding: var(--spacing-xxl);
    color: var(--text-secondary);
    font-size: 1.1rem;
}

.no-data[b-gii3kyygdp] {
    text-align: center;
    padding: var(--spacing-xxl);
    color: var(--text-secondary);
    font-style: italic;
    font-size: 1.1rem;
}

/* Responsive Design */
@media (max-width: 768px) {
    .flow-stats-container[b-gii3kyygdp] {
        padding: var(--spacing-md);
    }
    
    .flow-stats-header h1[b-gii3kyygdp] {
        font-size: 2rem;
    }
    
    .stats-grid[b-gii3kyygdp] {
        grid-template-columns: 1fr;
    }
    
    .date-inputs[b-gii3kyygdp] {
        flex-direction: column;
        align-items: stretch;
    }
    
    .nav-menu[b-gii3kyygdp] {
        flex-direction: column;
        align-items: stretch;
    }
    
    .nav-button[b-gii3kyygdp] {
        text-align: center;
    }
    
    /* Mobile table adjustments */
    .flow-header[b-gii3kyygdp],
    .flow-row[b-gii3kyygdp] {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
    }
    
    .flow-header[b-gii3kyygdp] {
        display: none; /* Hide header on mobile */
    }
    
    .flow-row[b-gii3kyygdp] {
        display: block;
        padding: var(--spacing-md);
        margin-bottom: var(--spacing-sm);
        border: 1px solid var(--border-color);
        border-radius: var(--border-radius);
    }
    
    .flow-cell[b-gii3kyygdp] {
        display: block;
        margin-bottom: var(--spacing-xs);
        padding: var(--spacing-xs) 0;
    }
    
    .flow-cell[b-gii3kyygdp]:before {
        content: attr(data-label) ": ";
        font-weight: var(--font-weight-semibold);
        color: var(--text-secondary);
        display: inline-block;
        min-width: 100px;
    }
    
    .flow-cell:last-child[b-gii3kyygdp] {
        margin-bottom: 0;
    }
}
/* _content/Alloc42BlazorServer/Components/Pages/Home.razor.rz.scp.css */
/* Home page specific styles */

.hero-section[b-m0zzh5dnzp] {
	padding: var(--spacing-4xl) 0;
}

/* Hero Section Styles */
.hero[b-m0zzh5dnzp] {
	min-height: 100vh;
	display: flex;
	align-items: center;
	position: relative;
	overflow: visible !important;
	padding: var(--spacing-4xl) 0;
	background: linear-gradient(
		135deg,
		var(--bg-primary) 0%,
		var(--bg-secondary) 100%
	);
}

.hero[b-m0zzh5dnzp]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background:
		radial-gradient(circle at 20% 80%, var(--primary-glow) 0%, transparent 50%),
		radial-gradient(
			circle at 80% 20%,
			rgba(155, 140, 255, 0.1) 0%,
			transparent 50%
		);
	pointer-events: none;
}

.hero-container[b-m0zzh5dnzp] {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-4xl);
	align-items: center;
	position: relative;
	z-index: 1;
}

.hero-content[b-m0zzh5dnzp] {
	max-width: 600px;
}

.hero-title[b-m0zzh5dnzp] {
	font-size: var(--text-6xl);
	font-weight: var(--font-weight-extrabold);
	line-height: var(--leading-tight);
	margin-bottom: var(--spacing-lg);
	color: var(--text-primary);
}

.hero-title .highlight[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	text-shadow: 0 0 30px var(--primary-glow);
}

.hero-subtitle[b-m0zzh5dnzp] {
	font-size: var(--text-xl);
	line-height: var(--leading-relaxed);
	color: var(--text-secondary);
	margin-bottom: var(--spacing-2xl);
	max-width: 500px;
}

.hero-ctas[b-m0zzh5dnzp] {
	display: flex;
	gap: var(--spacing-lg);
	flex-wrap: wrap;
}

.hero-visual[b-m0zzh5dnzp] {
	display: flex;
	justify-content: center;
	align-items: center;
}

.code-terminal[b-m0zzh5dnzp] {
	background: var(--bg-surface);
	border-radius: var(--radius-xl);
	border: 1px solid var(--border-primary);
	box-shadow: var(--shadow-xl);
	overflow: hidden;
	max-width: 500px;
	width: 100%;
	font-family: var(--font-mono);
}

.terminal-header[b-m0zzh5dnzp] {
	background: var(--bg-surface-elevated);
	padding: var(--spacing-md) var(--spacing-lg);
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-bottom: 1px solid var(--border-primary);
}

.terminal-dots[b-m0zzh5dnzp] {
	display: flex;
	gap: var(--spacing-sm);
}

.dot[b-m0zzh5dnzp] {
	width: 12px;
	height: 12px;
	border-radius: 50%;
}

.dot.red[b-m0zzh5dnzp] {
	background: #ff5f56;
}

.dot.yellow[b-m0zzh5dnzp] {
	background: #ffbd2e;
}

.dot.green[b-m0zzh5dnzp] {
	background: #27ca3f;
}

.terminal-title[b-m0zzh5dnzp] {
	color: var(--text-secondary);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
}

.terminal-content[b-m0zzh5dnzp] {
	padding: var(--spacing-lg);
	background: var(--bg-primary);
}

.terminal-line[b-m0zzh5dnzp] {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	margin-bottom: var(--spacing-sm);
	font-size: var(--text-sm);
}

.terminal-line:last-child[b-m0zzh5dnzp] {
	margin-bottom: 0;
}

.prompt[b-m0zzh5dnzp] {
	color: var(--primary);
	font-weight: var(--font-weight-medium);
}

.command[b-m0zzh5dnzp] {
	color: var(--text-primary);
}

.output[b-m0zzh5dnzp] {
	color: var(--text-secondary);
	margin-left: var(--spacing-lg);
}

.output.success[b-m0zzh5dnzp] {
	color: var(--success);
}

/* Scroll Indicator */
.scroll-indicator[b-m0zzh5dnzp] {
	position: absolute;
	bottom: var(--spacing-xl);
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
	opacity: 0;
	animation: fadeInUp 1s ease-out 2s forwards;
}

.scroll-indicator-content[b-m0zzh5dnzp] {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-sm);
	color: var(--text-muted);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.scroll-text[b-m0zzh5dnzp] {
	opacity: 0.7;
}

.scroll-arrow[b-m0zzh5dnzp] {
	animation: bounce-b-m0zzh5dnzp 2s infinite;
	color: var(--primary);
}

.scroll-arrow svg[b-m0zzh5dnzp] {
	width: 16px;
	height: 16px;
}

@keyframes bounce-b-m0zzh5dnzp {
	0%,
	20%,
	50%,
	80%,
	100% {
		transform: translateY(0);
	}
	40% {
		transform: translateY(-8px);
	}
	60% {
		transform: translateY(-4px);
	}
}

/* Promise Hero Section */
.promise-hero[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--bg-surface) 0%,
		var(--bg-surface-elevated) 100%
	);
	position: relative;
	overflow: visible !important;
	padding: var(--spacing-4xl) 0;
}

.promise-hero[b-m0zzh5dnzp]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: radial-gradient(
		circle at 50% 50%,
		var(--primary-glow) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.promise-hero-container[b-m0zzh5dnzp] {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
	position: relative;
	z-index: 1;
}

.promise-hero-content[b-m0zzh5dnzp] {
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
}

.promise-hero-title[b-m0zzh5dnzp] {
	font-size: var(--text-5xl);
	font-weight: var(--font-weight-extrabold);
	line-height: var(--leading-tight);
	color: var(--text-primary);
	margin-bottom: var(--spacing-lg);
	background: linear-gradient(
		135deg,
		var(--text-primary) 0%,
		var(--primary) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.promise-hero-subtitle[b-m0zzh5dnzp] {
	font-size: var(--text-xl);
	line-height: var(--leading-relaxed);
	color: var(--text-secondary);
	font-style: italic;
	max-width: 600px;
	margin: 0 auto;
}

/* Specializations Section Styles */
.specializations[b-m0zzh5dnzp] {
	background: var(--bg-primary);
	position: relative;
	padding-top: var(--spacing-3xl);
	padding-bottom: calc(var(--spacing-5xl) + 2rem); /* extra bottom space for tall spotlight deck */
}

.specializations[b-m0zzh5dnzp]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background:
		radial-gradient(circle at 30% 20%, var(--primary-glow) 0%, transparent 60%),
		radial-gradient(
			circle at 70% 80%,
			rgba(155, 140, 255, 0.1) 0%,
			transparent 60%
		);
	pointer-events: none;
}

.specializations-container[b-m0zzh5dnzp] {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
	position: relative;
	z-index: 1;
}

.specializations-header[b-m0zzh5dnzp] {
	text-align: center;
	margin-bottom: var(--spacing-3xl);
	@media (max-width: 600px) {
		margin-bottom: var(--spacing-sm);[b-m0zzh5dnzp]
	}
}

.section-subtitle[b-m0zzh5dnzp] {
	font-size: var(--text-xl);
	line-height: var(--leading-relaxed);
	color: var(--text-secondary);
	max-width: 800px;
	margin: var(--spacing-lg) auto 0;
	font-style: italic;
}

.specializations-grid[b-m0zzh5dnzp] {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: var(--spacing-xl);
	margin-top: var(--spacing-2xl);
	padding: 0 var(--spacing-lg); /* page-level horizontal padding for all specialization layouts */

	@media (max-width: 600px) {
		padding: 0;
		margin-top: var(--spacing-sm);[b-m0zzh5dnzp]
	
	}
}

/* Prevent the specialization area from creating horizontal scroll on small devices
   by clipping at the section level. The inner grid/track remain scrollable. */
.specializations[b-m0zzh5dnzp] {
	overflow-x: hidden;
	box-sizing: border-box;
}

.specialization-card[b-m0zzh5dnzp] {
	background: var(--glass-bg);
	backdrop-filter: blur(var(--glass-blur));
	border: 1px solid var(--glass-border);
	border-radius: var(--radius-2xl);
	padding: var(--spacing-2xl);
	transition: all var(--transition-normal);
	position: relative;
	overflow: visible !important;
	min-height: 280px;
	display: flex;
	flex-direction: column;
}

.specialization-card[b-m0zzh5dnzp]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(
		90deg,
		var(--primary) 0%,
		var(--accent-violet) 50%,
		var(--accent-mint) 100%
	);
	opacity: 0;
	transition: opacity var(--transition-normal);
}

.specialization-card:hover[b-m0zzh5dnzp] {
	/* transform: translateY(-8px); */
	/* box-shadow: var(--shadow-xl), var(--shadow-glow); */
	border-color: var(--primary);
}

.specialization-card:hover[b-m0zzh5dnzp]::before {
	opacity: 1;
}

/* Most Popular badge styles disabled — visual badge removed but kept in code
   so it can be re-enabled when interaction-based popularity is implemented. */

/* Flip Card Styles */
.flip-card[b-m0zzh5dnzp] {
	background-color: transparent;
	width: 100%;
	height: 420px; /* Fixed height to prevent overlapping */
	perspective: 1000px;
	transition: transform 0.3s ease;
	position: relative; /* Ensure absolutely positioned faces are contained */
}

/* Glass effect for specialization cards */
.glass[b-m0zzh5dnzp] {
	background: var(--glass-bg);
	backdrop-filter: blur(var(--glass-blur));
	border: 1px solid var(--glass-border);
	border-radius: var(--radius-2xl);
}

/* Specialization Icon Styling */
.specialization-icon[b-m0zzh5dnzp] {
	width: 64px;
	height: 64px;
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--spacing-lg);
	color: var(--text-inverse);
	box-shadow: var(--shadow-glow);
	flex-shrink: 0;
	align-self: center;
}

.specialization-icon svg[b-m0zzh5dnzp] {
	width: 32px;
	height: 32px;
	display: block;
}

/* Shy animations based on mouse direction - increased movement */
.flip-card.shy-top[b-m0zzh5dnzp] {
    transform: translateY(35px) translateX(0px);
    transition: transform 0.4s ease-out;
}

.flip-card.shy-bottom[b-m0zzh5dnzp] {
    transform: translateY(-35px) translateX(0px);
    transition: transform 0.4s ease-out;
}

.flip-card.shy-left[b-m0zzh5dnzp] {
    transform: translateY(0px) translateX(35px);
    transition: transform 0.4s ease-out;
}

.flip-card.shy-right[b-m0zzh5dnzp] {
    transform: translateY(0px) translateX(-35px);
    transition: transform 0.4s ease-out;
}

.flip-card.shy-top-left[b-m0zzh5dnzp] {
    transform: translateY(30px) translateX(30px);
    transition: transform 0.4s ease-out;
}

.flip-card.shy-top-right[b-m0zzh5dnzp] {
    transform: translateY(30px) translateX(-30px);
    transition: transform 0.4s ease-out;
}

.flip-card.shy-bottom-left[b-m0zzh5dnzp] {
    transform: translateY(-30px) translateX(30px);
    transition: transform 0.4s ease-out;
}

.flip-card.shy-bottom-right[b-m0zzh5dnzp] {
    transform: translateY(-30px) translateX(-30px);
    transition: transform 0.4s ease-out;
}

/* Slowdown effect when card is being chased */
.flip-card.shy-slowdown[b-m0zzh5dnzp] {
	transition: transform 0.8s ease-in-out;
}

/* Return to start position */
.flip-card.shy-return[b-m0zzh5dnzp] {
	transform: translateY(0px) translateX(0px);
	transition: transform 0.3s ease-in;
}

.flip-card-inner[b-m0zzh5dnzp] {
	position: relative;
	width: 100%;
	height: 100%;
	text-align: center;
	transition: all 2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	transform-style: preserve-3d;
	transform: rotateY(0deg) translateZ(0px); /* Ensure card starts in front position */
	will-change: transform; /* Hint for browser optimization */
}

/* Multi-stage flip animation */
.flip-card-inner.flipping[b-m0zzh5dnzp] {
	animation: cardFlip-b-m0zzh5dnzp 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.flip-card-inner.flipping-back[b-m0zzh5dnzp] {
	animation: cardFlipBack-b-m0zzh5dnzp 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

@keyframes cardFlip-b-m0zzh5dnzp {
	0% {
		transform: rotateY(0deg) translateZ(0px);
	}
	25% {
		transform: rotateY(0deg) translateZ(20px) scale(1.05);
	}
	50% {
		transform: rotateY(90deg) translateZ(20px) scale(1.05);
	}
	75% {
		transform: rotateY(90deg) translateZ(20px) scale(1.05);
	}
	100% {
		transform: rotateY(180deg) translateZ(0px) scale(1);
	}
}

/* Text transition during flip - prevent mirroring */
.flip-card-inner.flipping .flip-card-front .specialization-description[b-m0zzh5dnzp] {
	animation: textFadeOut-b-m0zzh5dnzp 0.5s ease-in-out 0.8s forwards;
}

.flip-card-inner.flipping .flip-card-back .back-text[b-m0zzh5dnzp] {
	animation: textFadeIn-b-m0zzh5dnzp 0.5s ease-in-out 1.2s forwards;
	opacity: 0;
	transform: rotateY(0deg) !important; /* Force text to stay readable */
	direction: ltr !important; /* Ensure left-to-right reading */
	text-align: left !important; /* Keep text left-aligned */
}

@keyframes textFadeOut-b-m0zzh5dnzp {
	to {
		opacity: 0;
	}
}

@keyframes textFadeIn-b-m0zzh5dnzp {
	to {
		opacity: 1;
	}
}

@keyframes cardFlipBack-b-m0zzh5dnzp {
	0% {
		transform: rotateY(180deg) translateZ(0px) scale(1);
	}
	25% {
		transform: rotateY(180deg) translateZ(20px) scale(1.05);
	}
	50% {
		transform: rotateY(90deg) translateZ(20px) scale(1.05);
	}
	75% {
		transform: rotateY(90deg) translateZ(20px) scale(1.05);
	}
	100% {
		transform: rotateY(0deg) translateZ(0px) scale(1);
	}
}

/* Add subtle scale effect when flipped */
.flip-card-inner.flipped[b-m0zzh5dnzp] {
	transform: rotateY(180deg) translateZ(0px) scale(1);
}

.flip-card-front[b-m0zzh5dnzp],
.flip-card-back[b-m0zzh5dnzp] {
	position: absolute;
	width: 100%;
	height: 100%;
	border-radius: var(--radius-lg);
	padding: var(--spacing-lg);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	box-sizing: border-box;
}

.flip-card-front[b-m0zzh5dnzp],
.flip-card-back[b-m0zzh5dnzp] {
	position: absolute;
	width: 100%;
	height: 100%;
	border-radius: var(--radius-lg);
	padding: var(--spacing-lg);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	box-sizing: border-box;
	top: 0;
	left: 0;
	backface-visibility: hidden;
	transition: none;
}

.flip-card-back[b-m0zzh5dnzp] {
	transform: rotateY(180deg);
}

/* Text transitions for reverse flip - prevent mirroring */
.flip-card-inner.flipping-back .flip-card-back .back-text[b-m0zzh5dnzp] {
	animation: textFadeOut-b-m0zzh5dnzp 0.5s ease-in-out 0.8s forwards;
}

.flip-card-inner.flipping-back .flip-card-front .specialization-description[b-m0zzh5dnzp] {
	animation: textFadeIn-b-m0zzh5dnzp 0.5s ease-in-out 1.2s forwards;
	opacity: 0;
	transform: rotateY(0deg) !important; /* Force text to stay readable */
	direction: ltr !important; /* Ensure left-to-right reading */
	text-align: left !important; /* Keep text left-aligned */
}

/* Back card styling - looks like the back of a real card */
.back-content[b-m0zzh5dnzp] {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 100%;
	text-align: center;
	direction: ltr;
	padding: var(--spacing-lg);
}

.back-text[b-m0zzh5dnzp] {
	color: var(--text-primary);
	font-size: var(--text-base);
	line-height: 1.6;
	margin-bottom: var(--spacing-lg);
	max-width: 90%;
}

.more-button[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--accent-mint) 0%,
		var(--primary) 100%
	);
	color: var(--bg-primary);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	padding: var(--spacing-sm) var(--spacing-lg);
	border-radius: var(--radius-full);
	border: none;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: var(--shadow-md);
	margin: var(--spacing-md) auto;
	align-self: center;
	min-width: 100px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	z-index: 10;
	position: relative;
}

.back-button[b-m0zzh5dnzp] {
	background: transparent;
	color: var(--primary);
	border: 2px solid var(--primary);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-bold);
	padding: var(--spacing-sm) var(--spacing-lg);
	border-radius: var(--radius-full);
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: var(--shadow-md);
	margin: var(--spacing-md) auto;
	align-self: center;
	min-width: 100px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	z-index: 10;
	position: relative;
}

.back-button:hover[b-m0zzh5dnzp] {
	background: var(--primary);
	color: var(--bg-primary);
}

.more-button:hover[b-m0zzh5dnzp],
.back-button:hover[b-m0zzh5dnzp] {
	transform: scale(1.05);
	box-shadow: var(--shadow-lg);
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
}

.back-button[b-m0zzh5dnzp] {
	background: transparent;
	color: var(--primary);
	border: 2px solid var(--primary);
	font-weight: var(--font-weight-bold);
}

.back-button:hover[b-m0zzh5dnzp] {
	background: var(--primary);
	color: var(--bg-primary);
}

.back-buttons[b-m0zzh5dnzp] {
	display: flex;
	gap: var(--spacing-sm);
	justify-content: center;
	margin-top: var(--spacing-md);
}

.contact-button[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--accent-mint) 0%,
		var(--primary) 100%
	);
	color: var(--bg-primary);
	font-weight: var(--font-weight-bold);
	border: none;
}

.contact-button:hover[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-mint) 100%
	);
}

.specialization-benefits[b-m0zzh5dnzp] {
	margin-top: var(--spacing-lg);
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-sm);
}

.benefit-tag[b-m0zzh5dnzp] {
	background: transparent;
	color: var(--accent-mint);
	font-size: var(--text-xs);
	font-weight: var(--font-weight-bold);
	padding: var(--spacing-xs) var(--spacing-md);
	border-radius: var(--radius-full);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--shadow-lg);
	z-index: 10;
	border: 2px solid var(--accent-mint);
	display: inline-block;
	margin: 0 auto;
}



/* CTA Band */
.cta-band[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--bg-surface) 0%,
		var(--bg-surface-elevated) 100%
	);
	position: relative;
	overflow: hidden;
}

.cta-band[b-m0zzh5dnzp]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: radial-gradient(
		circle at 50% 50%,
		var(--primary-glow) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.cta-container[b-m0zzh5dnzp] {
	max-width: 1200px;
	margin: 0 auto;
	padding: var(--spacing-3xl) var(--spacing-lg);
	position: relative;
	z-index: 1;
}

.cta-content[b-m0zzh5dnzp] {
	text-align: center;
}

.cta-title[b-m0zzh5dnzp] {
	font-size: var(--text-4xl);
	font-weight: var(--font-weight-extrabold);
	line-height: var(--leading-tight);
	color: var(--text-primary);
	margin-bottom: var(--spacing-lg);
}

.cta-subtitle[b-m0zzh5dnzp] {
	font-size: var(--text-lg);
	line-height: var(--leading-relaxed);
	color: var(--text-secondary);
	margin-bottom: var(--spacing-xl);
}

.cta-actions[b-m0zzh5dnzp] {
	display: flex;
	gap: var(--spacing-lg);
	justify-content: center;
	flex-wrap: wrap;
}

.btn[b-m0zzh5dnzp] {
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	padding: var(--spacing-md) var(--spacing-xl);
	border-radius: var(--radius-full);
	border: none;
	cursor: pointer;
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
	white-space: nowrap;
}

.btn-primary[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--accent-violet) 100%
	);
	color: var(--text-inverse);
	box-shadow: var(--shadow-glow);
	position: relative;
	overflow: hidden;
}

.btn-secondary[b-m0zzh5dnzp] {
	background: linear-gradient(
		135deg,
		var(--glass-bg) 0%,
		var(--bg-surface) 100%
	);
	color: var(--text-primary);
	border: 2px solid var(--border-accent);
	backdrop-filter: blur(var(--glass-blur));
	position: relative;
	overflow: hidden;
}

.btn-large[b-m0zzh5dnzp] {
	font-size: var(--text-lg);
	padding: var(--spacing-lg) var(--spacing-2xl);
}

.btn-ghost[b-m0zzh5dnzp] {
	background: transparent;
	color: var(--primary);
	border: 2px solid var(--primary);
}

.btn-ghost:hover[b-m0zzh5dnzp] {
	background: var(--primary);
	color: var(--text-inverse);
}

.btn:focus[b-m0zzh5dnzp] {
	outline: 2px solid var(--primary);
	outline-offset: 2px;
}

.btn:active[b-m0zzh5dnzp] {
	transform: scale(0.98);
}

@media (max-width: 600px) {
	.cta-container[b-m0zzh5dnzp] {
		padding: var(--spacing-xl) var(--spacing-lg);
	}
	.cta-title[b-m0zzh5dnzp] {
		font-size: var(--text-2xl);
	}
	.cta-actions[b-m0zzh5dnzp] {
		flex-direction: column;
		gap: var(--spacing-md);
	}
}

/* Footer */
.footer[b-m0zzh5dnzp] {
	background: var(--bg-surface);
	padding: var(--spacing-2xl) 0;
	border-top: 1px solid var(--border-primary);
}

.footer-container[b-m0zzh5dnzp] {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}

.footer-brand[b-m0zzh5dnzp] {
	display: flex;
	align-items: baseline;
	gap: var(--spacing-xs);
}

.brand-text[b-m0zzh5dnzp] {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-extrabold);
	color: var(--primary);
	letter-spacing: 1px;
}

.brand-inc[b-m0zzh5dnzp] {
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	color: var(--text-muted);
	text-transform: uppercase;
	letter-spacing: 1.5px;
}

.footer-tagline[b-m0zzh5dnzp] {
	font-size: var(--text-base);
	color: var(--text-secondary);
	font-style: italic;
	margin-left: var(--spacing-lg);
	cursor: pointer;
	transition: color 0.2s;
}

.footer-tagline:hover[b-m0zzh5dnzp] {
	color: var(--primary);
}

.footer-links[b-m0zzh5dnzp] {
	display: flex;
	gap: var(--spacing-lg);
}

.footer-link[b-m0zzh5dnzp] {
	color: var(--text-muted);
	font-size: var(--text-sm);
	text-decoration: none;
	transition: color 0.2s;
}

.footer-link:hover[b-m0zzh5dnzp] {
	color: var(--primary);
}

@media (max-width: 900px) {
	.footer-container[b-m0zzh5dnzp] {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-lg);
	}
	.footer-tagline[b-m0zzh5dnzp] {
		margin-left: 0;
		margin-top: var(--spacing-md);
	}
}



/* Notification Styles */
.notification-overlay[b-m0zzh5dnzp] {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(24, 28, 36, 0.3);
	z-index: 2000;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	pointer-events: none;
}

.notification[b-m0zzh5dnzp] {
	margin-top: var(--spacing-3xl);
	background: var(--glass-bg);
	backdrop-filter: blur(var(--glass-blur));
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-xl);
	padding: var(--spacing-xl) var(--spacing-2xl);
	display: flex;
	align-items: center;
	gap: var(--spacing-lg);
	animation: slideInDown-b-m0zzh5dnzp 0.4s ease-out;
	position: relative;
	overflow: hidden;
}

.notification.success[b-m0zzh5dnzp] {
	border-left: 6px solid var(--success);
}

.notification.error[b-m0zzh5dnzp] {
	border-left: 6px solid var(--danger);
}

.notification-content[b-m0zzh5dnzp] {
	display: flex;
	align-items: center;
	gap: var(--spacing-lg);
}

.notification-icon[b-m0zzh5dnzp] {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
}

.notification-message[b-m0zzh5dnzp] {
	font-size: var(--text-base);
	color: var(--text-primary);
}

.notification-close[b-m0zzh5dnzp] {
	background: none;
	border: none;
	font-size: var(--text-lg);
	color: var(--text-muted);
	cursor: pointer;
	transition: color 0.2s;
	margin-left: var(--spacing-lg);
}

.notification-close:hover[b-m0zzh5dnzp] {
	color: var(--primary);
}

@keyframes slideInDown-b-m0zzh5dnzp {
	from {
		transform: translateY(-40px);
		opacity: 0;
	}
	to {
		transform: translateY(0);
		opacity: 1;
	}
}

/* Mobile hug for hero: stack into a single column and reduce spacing
   Targets the actual markup in Home.razor which uses .hero-section and
   utility classes rather than bespoke hero-* class names. */
@media (max-width: 768px) {
	/* Target the inner grid used in the hero markup */
	.hero-section .grid.grid-cols-2[b-m0zzh5dnzp] {
		grid-template-columns: 1fr !important;
		gap: var(--spacing-lg) !important;
		padding: 0 var(--spacing-lg) !important;
	}

	/* Left column wrapper in the markup */
	.hero-section .max-w-2xl[b-m0zzh5dnzp],
	.hero-section .hero-visual[b-m0zzh5dnzp] {
		width: 100% !important;
		max-width: 100% !important;
	}

	.hero-section .hero-visual[b-m0zzh5dnzp] {
		margin-top: var(--spacing-md);
		justify-content: center;
	}

	/* Headline and paragraph sizing inside the hero left column */
	.hero-section h1[b-m0zzh5dnzp] {
		font-size: var(--text-3xl) !important;
		line-height: 1.12 !important;
	}

	.hero-section .max-w-2xl p[b-m0zzh5dnzp],
	.hero-section .max-w-2xl .flex[b-m0zzh5dnzp] {
		font-size: var(--text-base) !important;
	}

	.hero-section .code-terminal[b-m0zzh5dnzp] {
		max-width: 100% !important;
		width: 100% !important;
	}

	/* Slightly reduced but comfortable hero buttons on narrow screens and centered CTAs */
	.hero-section .btn.btn-primary.btn-lg[b-m0zzh5dnzp],
	.hero-section .btn.btn-secondary.btn-lg[b-m0zzh5dnzp] {
		padding: 0.65rem 1rem !important;
		font-size: var(--text-sm) !important;
	}

	/* Center the CTA row on mobile */
	.hero-section .max-w-2xl .flex[b-m0zzh5dnzp] {
		justify-content: center !important;
	}

	/* Reduce top spacing above specializations on mobile */
	.specializations[b-m0zzh5dnzp] {
		padding: calc(var(--spacing-2xl) / 2) 0;
		height: 700px;
		
	}
}
/* _content/Alloc42BlazorServer/Components/Shared/Footer.razor.rz.scp.css */
/* Footer styles extracted from Home.razor.css */
.footer[b-xegoup3q9y] {
	background: var(--bg-surface);
	padding: var(--spacing-2xl) 0;
	border-top: 1px solid var(--border-primary);
}

.footer-container[b-xegoup3q9y] {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}

.footer-brand[b-xegoup3q9y] {
	display: flex;
	align-items: baseline;
	gap: var(--spacing-xs);
}

.brand-text[b-xegoup3q9y] {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-extrabold);
	color: var(--primary);
	letter-spacing: 1px;
}

.brand-inc[b-xegoup3q9y] {
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	color: var(--text-muted);
	text-transform: uppercase;
	letter-spacing: 1.5px;
}

.footer-tagline[b-xegoup3q9y] {
	font-size: var(--text-base);
	color: var(--text-secondary);
	font-style: italic;
	margin-left: var(--spacing-lg);
	cursor: pointer;
	transition: color 0.2s;
}

.footer-tagline:hover[b-xegoup3q9y] {
	color: var(--primary);
}

.footer-links[b-xegoup3q9y] {
	display: flex;
	gap: var(--spacing-lg);
}

.footer-link[b-xegoup3q9y] {
	color: var(--text-muted);
	font-size: var(--text-sm);
	text-decoration: none;
	transition: color 0.2s;
}

.footer-link:hover[b-xegoup3q9y] {
	color: var(--primary);
}

@media (max-width: 900px) {
	.footer-container[b-xegoup3q9y] {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-lg);
	}
	.footer-tagline[b-xegoup3q9y] {
		margin-left: 0;
		margin-top: var(--spacing-md);
	}
}

/* Reduce footer vertical padding on narrow screens */
@media (max-width: 880px) {
  .footer[b-xegoup3q9y] {
    padding: var(--spacing-lg) 0; /* tighter than 2xl */
  }

  .footer-container[b-xegoup3q9y] {
    padding: 0 var(--spacing-md);
  }
}

/* Remove additional top margin for the footer-tagline on narrow screens */
@media (max-width: 880px) {
	.footer-tagline[b-xegoup3q9y] {
		margin-top: 0;
		margin-left: 0;
	}
}
/* _content/Alloc42BlazorServer/Components/Shared/Header.razor.rz.scp.css */
/* alloc42_marketing/Components/Shared/Header.razor.css
   Header-specific styles for the shared Header component.
   Keeps the Home logo spacing, Academy overlay nav appearance,
   and the Home gradient primary button look.
*/

/* Layout containers */
.header-container[b-hpb3sv1ppy] {
	width: 100%;
	left: 0;
	top: 0;
	z-index: 60;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Site (non-overlay) variant - matches the Home spacing and glass look */
.header-container.site[b-hpb3sv1ppy] {
	position: fixed;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	background: rgba(
		255,
		255,
		255,
		0.02
	); /* subtle glass, Tailwind classes already may apply */
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}

/* Overlay (hero) variant - transparent, light text intended for dark hero backgrounds */
.header-container.overlay[b-hpb3sv1ppy] {
	position: absolute;
	background: transparent;
	box-shadow: none;
	border-bottom: none; /* ensure no visual divider when used over dark hero */
	padding: 0.5rem 0;
	/* lighter active color when the header sits on a dark hero */
	--nav-active-color: rgba(255, 255, 255, 0.18);
}

/* Inner container keeps Home spacing but is flexible */
.header-inner[b-hpb3sv1ppy] {
	max-width: 1120px; /* matches max-w-7xl-ish */
	margin: 0 auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

/* Logo area - follow Home page style */
.header-logo[b-hpb3sv1ppy] {
	display: flex;
	align-items: baseline;
	gap: 0.25rem;
	white-space: nowrap;
}

.header-logo .brand-name[b-hpb3sv1ppy] {
	font-size: 2rem;
	font-weight: 800;
	text-shadow: 0 0 12px var(--primary-glow, rgba(99, 102, 241, 0.35));
	line-height: 1;
	letter-spacing: -0.01em;
}

.header-logo .brand-inc[b-hpb3sv1ppy] {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--muted, rgba(255, 255, 255, 0.7));
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-left: 0.125rem;
	line-height: 1;
}

/* Navigation and actions */
.header-nav[b-hpb3sv1ppy] {
	display: flex;
	align-items: center;
	gap: 1rem;
}

/* Hamburger button - hidden on desktop, visible on small screens */
.hamburger-btn[b-hpb3sv1ppy] {
	display: none;
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 0.35rem;
	border-radius: 6px;
}
.hamburger-btn svg[b-hpb3sv1ppy] { color: var(--text-secondary); }

/* Link group */
.nav-links[b-hpb3sv1ppy] {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

/* Default link reset for anchors rendered inside the header - base button-like appearance.
   Links should look consistent across pages; only the active link receives a visible highlight.
   Use a CSS variable to control the default link color so theme/site overrides can be applied. */
.header-container a[b-hpb3sv1ppy] {
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.35rem 0.6rem;
	border-radius: 0.5rem;
	transition: all 180ms ease;
	font-weight: 700;
	font-size: 0.92rem;
	background: transparent;
	/* default link color can be overridden by site/theme; keep it subtle by default */
	color: var(--nav-link-color, var(--text-secondary, #6b7280));
}

/* Ghost link appearance used in overlay (academy hero) */
.header-container.overlay a.btn.btn-ghost[b-hpb3sv1ppy],
.header-container.overlay a[role="link"].ghost[b-hpb3sv1ppy],
.header-container.overlay a.ghost[b-hpb3sv1ppy] {
	color: var(--white, #ffffff);
	background: transparent;
	border: none;
}
.header-container.overlay a.btn.btn-ghost:hover[b-hpb3sv1ppy],
.header-container.overlay a.ghost:hover[b-hpb3sv1ppy] {
	background: rgba(255, 255, 255, 0.06);
}

/* Primary-looking nav link (academy overlay) - reuses 'btn btn-primary' in markup,
   but we provide fallback styling here to ensure consistency if utility classes aren't applied */
.header-container.overlay a.btn.btn-primary[b-hpb3sv1ppy],
.header-container.overlay a.primary[b-hpb3sv1ppy] {
	color: var(--text-inverse, #fff);
	background: linear-gradient(
		135deg,
		var(--primary, #2563eb) 0%,
		var(--accent-violet, #7c3aed) 100%
	);
	box-shadow:
		0 8px 30px rgba(124, 58, 237, 0.12),
		0 2px 6px rgba(37, 99, 235, 0.08);
	padding: 0.5rem 0.9rem;
}
.header-container.overlay a.btn.btn-primary:hover[b-hpb3sv1ppy],
.header-container.overlay a.primary:hover[b-hpb3sv1ppy] {
	transform: translateY(-3px);
}

/* Home/site-style text links (subtle) */
.header-container.site a[b-hpb3sv1ppy] {
	color: var(--text-secondary, rgba(17, 24, 39, 0.75));
	background: transparent;
	padding: 0.15rem 0.4rem;
}
.header-container.site a:hover[b-hpb3sv1ppy] {
	color: var(--primary, #2563eb);
}

/* Primary nav links (academy-like appearance). Keep primary link gradient and button-like styling separate from .request-button */
.nav-link.primary[b-hpb3sv1ppy] {
	color: var(--text-inverse, #fff);
	background: linear-gradient(
		135deg,
		var(--primary, #2563eb) 0%,
		var(--accent-violet, #7c3aed) 100%
	);
	box-shadow: 0 8px 24px rgba(124, 58, 237, 0.1);
	padding: 0.45rem 0.9rem;
	border-radius: 0.5rem;
}

/* Visual sheen (subtle) */
.request-button[b-hpb3sv1ppy]::before {
	content: "";
	position: absolute;
	top: 0;
	left: -90%;
	width: 120%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.12),
		transparent
	);
	transform: skewX(-12deg);
	transition: left 420ms cubic-bezier(0.2, 0.9, 0.2, 1);
	pointer-events: none;
}
.request-button:hover[b-hpb3sv1ppy]::before {
	left: 100%;
}
.request-button:hover[b-hpb3sv1ppy] {
	transform: translateY(-3px);
	box-shadow:
		0 14px 40px rgba(99, 102, 241, 0.12),
		0 8px 24px rgba(37, 99, 235, 0.08);
}
.request-button:active[b-hpb3sv1ppy] {
	transform: translateY(-1px);
}

/* Active page indicator:
   - Use a single CSS variable --nav-active-color so theme/site can alter the highlight.
   - Keep the highlight subtle and not change other link styles. */
.header-container .header-inner a[aria-current="page"][b-hpb3sv1ppy],
.header-container .header-inner .active[b-hpb3sv1ppy] {
	outline: none;
	/* Make active link look like a pill/button to be more obvious. Use the shared --nav-active-color
	   as the gradient endpoint so themes can control it. Keep contrast high for accessibility. */
	color: var(--text-inverse, #fff) !important;
	background: linear-gradient(135deg, var(--primary, #2563eb) 0%, var(--nav-active-color, var(--accent-violet, #7c3aed)) 100%);
	box-shadow: 0 8px 24px rgba(37, 99, 235, 0.12), inset 0 -2px 0 rgba(255,255,255,0.06);
	transform: translateY(-1px);
	padding: 0.45rem 0.9rem;
	border-radius: 0.5rem;
	font-weight: 800;
}

/* Keep a subtle hover/focus lift for interactive affordance */
.header-container .header-inner a:hover[b-hpb3sv1ppy],
.header-container .header-inner a:focus[b-hpb3sv1ppy] {
	transform: translateY(-2px);
	box-shadow: 0 12px 36px rgba(37, 99, 235, 0.10);
}

/* Accessibility focus state */
.header-inner a:focus[b-hpb3sv1ppy],
.header-inner button:focus[b-hpb3sv1ppy] {
	box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
	outline: none;
}

/* Responsive behavior */
@media (max-width: 880px) {
	.header-inner[b-hpb3sv1ppy] {
		padding-left: 1rem;
		padding-right: 1rem;
		gap: 0.5rem;
	}

	/* Stack logo and action on small screens */
	.header-inner[b-hpb3sv1ppy] {
		display: flex;
		align-items: center;
		justify-content: space-between;
	}

	.nav-links[b-hpb3sv1ppy] {
		display: none; /* hide links on small by default; mobile menu can be added later */
	}

	/* show hamburger on small screens */
	.hamburger-btn[b-hpb3sv1ppy] { display: inline-flex; }

	/* hide the request button in the header -- moved into the mobile drawer */
	.header-nav > .request-button[b-hpb3sv1ppy] { display: none; }
	.request-button[b-hpb3sv1ppy] {
		padding: 0.45rem 0.7rem;
		min-height: 2rem;
	}

	.header-logo .brand-name[b-hpb3sv1ppy] {
		font-size: 1.125rem;
	}

	.header-logo .brand-inc[b-hpb3sv1ppy] {
		font-size: 0.675rem;
	}
}

/* Tight small-screen tweaks for very small devices */
@media (max-width: 420px) {
	.header-inner[b-hpb3sv1ppy] {
		padding-left: 0.75rem;
		padding-right: 0.75rem;
	}

	.request-button[b-hpb3sv1ppy] {
		padding-left: 0.6rem;
		padding-right: 0.6rem;
		min-height: 1.9rem;
		font-size: 0.925rem;
	}
}

/* Mobile drawer overlay and panel */
.mobile-drawer-overlay[b-hpb3sv1ppy] {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	background: rgba(0,0,0,0.55);
	z-index: 9999 !important;
	display: flex;
	justify-content: flex-start; /* align to left so drawer slides in from left */
	align-items: stretch;
}

/* open/closing states for animation */
.mobile-drawer-overlay.open[b-hpb3sv1ppy] { opacity: 1; }
.mobile-drawer-overlay.closing[b-hpb3sv1ppy] { opacity: 0; transition: opacity 220ms ease; }

.mobile-drawer[b-hpb3sv1ppy] {
	width: 280px;
	max-width: 90%;
	/* Left-side drawer surface */
	background: linear-gradient(180deg, rgba(8,12,20,0.98), rgba(12,18,28,0.98));
	color: var(--text-inverse, #fff);
	padding: 1.25rem;
	box-shadow: 0 30px 60px rgba(2,6,23,0.7);
	display: flex;
	flex-direction: column;
	gap: 1rem;
	border-radius: 0 12px 12px 0; /* rounded right edge since it comes from left */
	transform: translateX(-8px);
	transition: transform 260ms cubic-bezier(.2,.9,.2,1), opacity 180ms ease;
}

.mobile-drawer.open[b-hpb3sv1ppy] { transform: translateX(0); }
.mobile-drawer.closing[b-hpb3sv1ppy] { transform: translateX(-12px); opacity: 0.0; }

.mobile-drawer .mobile-drawer-links[b-hpb3sv1ppy] {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	
}

.mobile-drawer .nav-link[b-hpb3sv1ppy] {
	/* Mirror header link appearance but tuned for the dark drawer */
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.6rem 0.75rem;
	border-radius: 0.5rem;
	transition: all 180ms ease;
	font-weight: 700;
	font-size: 0.98rem;
	background: transparent;
	color: var(--text-secondary, rgba(255 255 255 / 0.75));
	text-decoration: none;
}

.mobile-drawer .nav-link:hover[b-hpb3sv1ppy] {
	background: rgba(255,255,255,0.04);
}

/* Active link styling in drawer: reuse desktop header active gradient */
.mobile-drawer .nav-link[aria-current="page"][b-hpb3sv1ppy],
.mobile-drawer .nav-link.active[b-hpb3sv1ppy] {
	color: var(--text-inverse, #fff) !important;
	background: linear-gradient(135deg, var(--primary, #2563eb) 0%, var(--nav-active-color, var(--accent-violet, #7c3aed)) 100%);
	box-shadow: 0 8px 24px rgba(37, 99, 235, 0.12), inset 0 -2px 0 rgba(255,255,255,0.06);
	transform: translateY(-1px);
	padding: 0.6rem 0.9rem;
	border-radius: 0.5rem;
	font-weight: 800;
}

/* make the logo lighter for dark drawer */
.mobile-drawer .drawer-logo .brand-name[b-hpb3sv1ppy],
.mobile-drawer .drawer-logo .brand-inc[b-hpb3sv1ppy] {
	color: rgba(255,255,255,0.95);
}

/* Request button inside drawer should retain primary styling */
.mobile-drawer .request-button[b-hpb3sv1ppy] {
	background: linear-gradient(135deg, var(--primary, #2563eb) 0%, var(--accent-violet, #7c3aed) 100%);
	color: var(--text-inverse, #fff);
	padding: 0.6rem 0.95rem;
	border-radius: 8px;
	box-shadow: 0 12px 32px rgba(37,99,235,0.12);
}

.mobile-drawer .mobile-drawer-actions[b-hpb3sv1ppy] {
	margin-top: auto;
}

.mobile-drawer-top[b-hpb3sv1ppy] {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid rgba(255,255,255,0.04);
}

.mobile-drawer .drawer-logo .brand-name[b-hpb3sv1ppy] {
	font-size: 1.4rem;
}

.mobile-drawer .drawer-logo .brand-inc[b-hpb3sv1ppy] {
	font-size: 0.7rem;
}
