/* ── PWA / scrollbar utilities ───────────────────────────────────────────── */
.no-scrollbar {
    scrollbar-width: none;       /* Firefox */
    -ms-overflow-style: none;    /* IE/Edge */
}
.no-scrollbar::-webkit-scrollbar {
    display: none;               /* Chrome/Safari/WebKit */
}

:root {
	--brand-pink: #d05591;
	--primary: #5b7aa3;
	--brand-pink-glow: rgba(208, 85, 145, 0.4);
	--brand-blue: #5b7aa3;
	--brand-pale-pink: #fde2e4;
	--bg-radio-group: #dfe7fd;
	--brand-linen: #fff1e6;
	--navbar-bg: rgba(91, 122, 163, 0.85);
	--glass-border: rgba(255, 255, 255, 0.1);
	--card-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.15);
	--surface-gray-2: #f3f4f6;
	--text-primary: #374151;
	--text-body: #111827;
	--bg-body: #ffffff;
	--radio-container-bg: #f3f4f6;
	--radio-container-border: transparent;
	--radio-unselected-text: #6b7280;
	--radio-selected-bg: #ffffff;
	--radio-selected-text: var(--brand-blue);
	--radio-selected-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
	--expired-text: #721c24;
}

[data-theme="dark"] {
	--surface-gray-2: #1f2937;
	--text-primary: #e5e7eb;
	--text-body: #f3f4f6;
	--bg-body: #111827;
	--brand-linen: #0f0f0f;
	--bg-radio-group: #1f2937;
	--radio-container-bg: #111827;
	--radio-container-border: #374151;
	--radio-unselected-text: #9ca3af;

	--radio-selected-bg: #f3f4f6;
	--radio-selected-text: #111827;
	--radio-selected-shadow: none;
}

header.navbar,
.navbar {
	background: var(--navbar-bg) !important;
	backdrop-filter: blur(10px) !important;
	-webkit-backdrop-filter: blur(10px) !important;
	border-bottom: 1px solid var(--glass-border) !important;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
	transition: all 0.3s ease;
}

body {
	font-family:
		"Inter",
		-apple-system,
		BlinkMacSystemFont,
		"Segoe UI",
		Roboto,
		sans-serif !important;
	background-color: var(--bg-body) !important;
	color: var(--text-body) !important;
}

.body-sidebar {
	background: var(--brand-linen) !important;
}

.bg-surface-menu-bar {
	background-color: var(--brand-linen) !important;
}

.text-ink-gray-9,
.text-ink-gray-8 {
	color: var(--text-body) !important;
}

.btn:hover,
a:hover {
	transition: transform 0.2s ease;
}

.btn-primary {
	background-color: var(--brand-blue) !important;
	border-color: var(--brand-blue) !important;
}

.btn-primary:hover {
	background-color: var(--brand-blue) !important;
	transform: translateY(-1px);
}

.bg-surface-gray-7,
[class*="bg-surface-gray-7"] {
	background-color: var(--brand-blue) !important;
	color: white !important;
}

.hover\:bg-surface-gray-6:hover,
[class*="hover:bg-surface-gray-6"]:hover {
	background-color: #4a6a93 !important;
	color: white !important;
}

.active\:bg-surface-gray-5:active,
[class*="active:bg-surface-gray-5"]:active {
	background-color: #3b5a83 !important;
	color: white !important;
}

.bg-surface-gray-7 svg,
.bg-surface-gray-7 .lucide {
	color: white !important;
	stroke: white !important;
}

.bg-surface-gray-2 {
	background-color: var(--surface-gray-2) !important;
	color: var(--text-primary) !important;
}

button.bg-surface-gray-2:not(:has([class*="chevron-down"])):not([role="combobox"]):not(
		[role="radio"]
	),
.btn.bg-surface-gray-2:not(:has([class*="chevron-down"])):not([role="combobox"]):not(
		[role="radio"]
	) {
	color: var(--brand-blue) !important;
	background-color: var(--bg-radio-group) !important;
}

div[role="radiogroup"] > .bg-surface-gray-2 {
	background-color: var(--bg-radio-group) !important;
	border: 1px solid var(--radio-container-border) !important;
	padding: 2px !important;
}

div[role="radiogroup"] [role="radio"] button.bg-surface-gray-2 {
	background-color: transparent !important;
	color: var(--radio-unselected-text) !important;
	border: none !important;
	box-shadow: none !important;
}

div[role="radiogroup"] [role="radio"][aria-checked="true"] button.bg-surface-gray-2 {
	background-color: var(--radio-selected-bg) !important;
	color: var(--radio-selected-text) !important;
	font-weight: 600 !important;
	box-shadow: var(--radio-selected-shadow) !important;
}

/* Suppress edit/delete controls on the "Download content for offline" nav item. */
button[data-sneha-offline-nav] .space-x-2.invisible {
    display: none !important;
}

/* Hide offline-only actions when the user is offline. */
.sneha-is-offline button[data-sneha-offline-nav],
.sneha-is-offline #sneha-duplicate-course {
    display: none !important;
}


/* ── Offline login CTA ────────────────────────────────────────────────────── */
#sneha-offline-login-cta {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: max(2rem, env(safe-area-inset-top)) 1.5rem max(2rem, env(safe-area-inset-bottom));
    background: #fff;
    color: #111827;
    text-align: center;
}

#sneha-offline-login-cta p {
    margin: 0 0 0.25rem;
    font-size: 1.125rem;
    font-weight: 600;
}

#sneha-offline-login-btn {
    display: inline-block;
    padding: 0.625rem 1.5rem;
    background: #111827;
    color: #fff;
    border-radius: 9999px;
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
    transition: opacity 0.15s;
}

#sneha-offline-login-btn:hover {
    opacity: 0.85;
}

.datepicker--cell.-selected-, .datepicker--cell.-current-.-selected- {
    background-color: var(--brand-blue) !important;
}

.datepicker--cell.-current- {
	color: var(--brand-blue) !important;
}

.datepicker--cell.-selected-:hover {
	background-color: var(--brand-blue) !important;
	opacity: 0.8;
}

.datepicker--nav-action:hover,
.datepicker--nav-title:hover {
	background-color: var(--bg-radio-group) !important;
	color: var(--brand-blue) !important;
}

.datepicker--button {
	color: var(--brand-blue) !important;
}
.datepicker--button:hover {
	background-color: var(--bg-radio-group) !important;
}

input:where([type="checkbox"]):checked,
input:where([type="radio"]):checked {
	background-color: var(--brand-blue) !important;
	border-color: var(--brand-blue) !important;
	background-image: none !important;
}

input:where([type="checkbox"]):checked {
	background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e") !important;
}
