:root {
	--psk-primary: #be131a;
	--psk-accent: #171717;
	--psk-bg: #f4f1ec;
	--psk-sidebar-bg: #faf8f5;
	--psk-surface: #ffffff;
	--psk-border: #e7e2da;
	--psk-text: #171717;
	--psk-text-muted: #66615a;
	--psk-nav-hover: #f4d9da;
	--psk-sidebar-width: 250px;
	--psk-sidebar-collapsed-width: 76px;
	--psk-header-height: 84px;
	--psk-radius: 20px;
	--psk-content-padding: 28px;
	--psk-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
	--psk-shadow-lg: 0 16px 40px rgba(0, 0, 0, 0.12);
	--psk-transition: 0.28s ease;
}

/* =========================
   GLOBAL STATE
========================= */

html.psk-lock-scroll,
body.psk-lock-scroll {
	overflow: hidden;
}

/* =========================
   THEME TOKENS
========================= */

html.psk-theme-dark,
body.psk-theme-dark {
	--psk-bg: #111418;
	--psk-sidebar-bg: #171b20;
	--psk-surface: #1b2026;
	--psk-border: #2b3138;
	--psk-text: #edf1f5;
	--psk-text-muted: #a7b0ba;
	--psk-nav-hover: #262d35;
	--psk-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
	--psk-shadow-lg: 0 16px 40px rgba(0, 0, 0, 0.42);
}

/* =========================
   PORTAL LAYOUT
========================= */

.psk-portal {
	display: flex !important;
	flex-direction: row !important;
	align-items: stretch;
	min-height: 100vh;
	width: 100%;
	position: relative;
	background: var(--psk-bg);
	color: var(--psk-text);
}

.psk-portal > .psk-sidebar {
	width: var(--psk-sidebar-width);
	min-width: var(--psk-sidebar-width);
	max-width: var(--psk-sidebar-width);
	position: relative;
	z-index: 30;
	background: var(--psk-sidebar-bg);
	border-right: 1px solid var(--psk-border);
    align-self: stretch;
	transition:
		width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		min-width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		max-width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		transform 360ms cubic-bezier(0.18, 0.89, 0.32, 1.18);
}

.psk-portal > .psk-main {
	flex: 1 1 auto;
	min-width: 0;
	display: flex !important;
	flex-direction: column !important;
	background: var(--psk-bg);
}

.psk-sidebar .elementor-widget-wrap,
.psk-sidebar .e-con-inner,
.psk-sidebar .e-child,
.psk-sidebar .e-con {
	min-height: inherit;
	background: var(--psk-sidebar-bg);
}

.psk-sidebar-inner {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
    height: 100%;
	background: var(--psk-sidebar-bg);
}

.psk-portal {
	align-items: stretch;
	min-height: 100vh;
}

.psk-portal > .psk-sidebar {
	position: relative;
	align-self: stretch;
	min-height: 100vh;
	height: auto;
	background: var(--psk-sidebar-bg);
}

.psk-sidebar-inner {
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	height: auto;
	background: var(--psk-sidebar-bg);
}

.psk-is-sticky-sidebar > .psk-sidebar {
	position: relative;
	top: auto;
	height: auto;
	min-height: 100vh;
	align-self: stretch;
}

.psk-is-sticky-sidebar > .psk-sidebar .psk-sidebar-inner {
	position: sticky;
	top: 0;
	min-height: 100vh;
	height: auto;
}

html.admin-bar .psk-is-sticky-sidebar > .psk-sidebar .psk-sidebar-inner {
	top: 32px;
	min-height: calc(100vh - 32px);
}

/* =========================
   HEADER
========================= */

.psk-header {
	min-height: var(--psk-header-height);
	display: flex !important;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px var(--psk-content-padding);
	position: relative;
	z-index: 20;
	background: rgba(255, 255, 255, 0.7);
	border-bottom: 1px solid var(--psk-border);
	backdrop-filter: blur(10px);
}

html.psk-theme-dark .psk-header,
body.psk-theme-dark .psk-header {
	background: rgba(23, 27, 32, 0.84);
}

.psk-is-sticky-header .psk-header {
	position: sticky;
	top: 0;
	z-index: 80;
}

html.admin-bar .psk-is-sticky-header .psk-header {
	top: 32px;
}

.psk-header-shell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	width: 100%;
	min-width: 0;
}

.psk-header-left {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
	flex: 1 1 auto;
}

.psk-header-right {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	flex: 0 0 auto;
	flex-wrap: wrap;
}

.psk-page-heading {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.psk-page-title {
	margin: 0;
	font-size: 2rem;
	line-height: 1.02;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--psk-text);
}

.psk-page-subtitle {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.45;
	color: var(--psk-text-muted);
	max-width: 62ch;
}

.psk-header .psk-page-title {
	font-size: 2rem !important;
	line-height: 1.05 !important;
	font-weight: 800 !important;
	letter-spacing: -0.02em;
	color: var(--psk-text) !important;
	margin: 0 !important;
}

.psk-header .psk-page-subtitle {
	font-size: 0.95rem !important;
	line-height: 1.4 !important;
	color: var(--psk-text-muted) !important;
	margin: 0 !important;
}

/* Kill Elementor heading bleed */
.psk-header .elementor-heading-title {
	all: unset;
	display: block;
}

.psk-content {
	padding: var(--psk-content-padding);
	min-width: 0;
	background: var(--psk-bg);
}

.psk-portal .psk-dynamic-content,
.psk-portal .psk-dynamic-content p,
.psk-portal .psk-dynamic-content li,
.psk-portal .psk-dynamic-content span,
.psk-portal .psk-dynamic-content div,
.psk-portal .psk-dynamic-content label {
	color: var(--psk-text);
}

.psk-portal .psk-dynamic-content,
.psk-portal .psk-dynamic-content *,
.psk-portal .psk-dynamic-content .elementor-widget-container,
.psk-portal .psk-dynamic-content .elementor-heading-title,
.psk-portal .psk-dynamic-content .elementor-widget-heading .elementor-heading-title,
.psk-portal .psk-dynamic-content h1,
.psk-portal .psk-dynamic-content h2,
.psk-portal .psk-dynamic-content h3,
.psk-portal .psk-dynamic-content h4,
.psk-portal .psk-dynamic-content h5,
.psk-portal .psk-dynamic-content h6 {
	color: var(--psk-text) !important;
}

.psk-portal .psk-dynamic-content a {
	color: var(--psk-primary) !important;
}
.psk-portal .psk-dynamic-content .elementor-widget-text-editor,
.psk-portal .psk-dynamic-content .elementor-widget-text-editor * {
	color: var(--psk-text);
}

.psk-portal .psk-dynamic-content .elementor-button,
.psk-portal .psk-dynamic-content button,
.psk-portal .psk-dynamic-content input[type="submit"] {
	color: #fff !important;
}

.psk-dynamic-content input,
.psk-dynamic-content select,
.psk-dynamic-content textarea {
	background: var(--psk-surface);
	color: var(--psk-text);
	border-color: var(--psk-border);
}

.psk-dynamic-content table,
.psk-dynamic-content .jet-listing-grid__item,
.psk-dynamic-content .jet-engine-listing-overlay-wrap {
	color: var(--psk-text);
}

.psk-dynamic-card {
	background: var(--psk-surface);
	color: var(--psk-text);
	border: 1px solid var(--psk-border);
	border-radius: var(--psk-radius);
	box-shadow: var(--psk-shadow);
}

.psk-portal,
.psk-sidebar-inner,
.psk-sidebar .elementor-widget-wrap,
.psk-sidebar .e-con,
.psk-sidebar .e-con-inner,
.psk-sidebar .e-child,
.psk-portal > .psk-main,
.psk-content,
.psk-dynamic-content,
.psk-dynamic-content * {
	transition:
		background-color var(--psk-transition),
		background var(--psk-transition),
		color var(--psk-transition),
		border-color var(--psk-transition);
}

.psk-dynamic-content,
.psk-dynamic-content * {
	will-change: background, color;
}

.psk-portal > .psk-sidebar {
	transition:
		width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		min-width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		max-width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		transform 360ms cubic-bezier(0.18, 0.89, 0.32, 1.18),
		background-color var(--psk-transition),
		background var(--psk-transition),
		border-color var(--psk-transition),
		color var(--psk-transition);
}

/* =========================
   CARDS / LAYOUT UTILS
========================= */

.psk-card {
	background: var(--psk-surface);
	border: 1px solid var(--psk-border);
	border-radius: var(--psk-radius);
	box-shadow: var(--psk-shadow);
	padding: 22px;
}

.psk-grid {
	display: grid;
	gap: 20px;
}

.psk-grid--2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.psk-grid--3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.psk-grid--4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* =========================
   LINKS / BUTTONS
========================= */

.psk-logo-link,
.psk-profile-link,
.psk-button,
.psk-button-secondary,
.psk-account-chip,
.psk-logout-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	text-decoration: none;
	border-radius: 14px;
	font-weight: 600;
	transition:
		background var(--psk-transition),
		color var(--psk-transition),
		border-color var(--psk-transition),
		transform var(--psk-transition);
}

.psk-profile-link,
.psk-button-secondary,
.psk-account-chip,
.psk-logout-link {
	background: var(--psk-surface);
	color: var(--psk-text);
	border: 1px solid var(--psk-border);
	padding: 10px 16px;
}

.psk-button {
	background: var(--psk-primary);
	color: #fff;
	border: 1px solid var(--psk-primary);
	padding: 10px 16px;
}

.psk-button:hover,
.psk-button-secondary:hover,
.psk-profile-link:hover,
.psk-account-chip:hover,
.psk-logout-link:hover {
	transform: translateY(-1px);
}

.psk-account-chip:hover,
.psk-logout-link:hover,
.psk-profile-link:hover {
	background: var(--psk-surface) !important;
}

html.psk-theme-dark .psk-account-chip:hover,
html.psk-theme-dark .psk-logout-link:hover,
html.psk-theme-dark .psk-profile-link:hover,
body.psk-theme-dark .psk-account-chip:hover,
body.psk-theme-dark .psk-logout-link:hover,
body.psk-theme-dark .psk-profile-link:hover {
	background: #20262d !important;
}

.psk-sidebar-toggle,
.psk-sidebar-toggle:hover,
.psk-sidebar-toggle:focus,
.psk-sidebar-toggle:active,
.psk-sidebar-toggle:visited {
	background: var(--psk-primary) !important;
	color: #fff !important;
	border-color: var(--psk-primary) !important;
	text-decoration: none !important;
	box-shadow: var(--psk-shadow) !important;
}

.psk-sidebar-toggle .psk-toggle-label,
.psk-sidebar-toggle .psk-toggle-icon {
	color: #fff !important;
}

.psk-account-chip,
.psk-account-chip:hover,
.psk-account-chip:focus,
.psk-account-chip:active,
.psk-account-chip:visited,
.psk-logout-link,
.psk-logout-link:hover,
.psk-logout-link:focus,
.psk-logout-link:active,
.psk-logout-link:visited,
.psk-profile-link,
.psk-profile-link:hover,
.psk-profile-link:focus,
.psk-profile-link:active,
.psk-profile-link:visited {
	color: var(--psk-text) !important;
	text-decoration: none !important;
	border-color: var(--psk-border) !important;
}

/* =========================
   BRANDING
========================= */

.psk-logo {
	display: block;
	max-width: 100%;
	height: auto;
}

.psk-portal-name {
	font-weight: 800;
	color: var(--psk-text);
}

.psk-sidebar-brand {
	padding: 16px 14px 18px;
	border-bottom: 1px solid var(--psk-border);
	overflow: hidden;
}

.psk-sidebar-brand-link {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	min-height: 48px;
	overflow: hidden;
	text-decoration: none;
	color: var(--psk-text);
}

.psk-sidebar-brand-link:hover,
.psk-sidebar-brand-link:focus,
.psk-sidebar-brand-link:active,
.psk-sidebar-brand-link:visited {
	color: var(--psk-text);
	text-decoration: none;
}

.psk-sidebar-brand-media {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	overflow: hidden;
}

.psk-sidebar-brand-logo {
	display: block;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 40px;
	object-fit: contain;
}

.psk-sidebar-brand-fallback {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 12px;
	background: var(--psk-primary);
	color: #fff;
	font-weight: 700;
	font-size: 1rem;
}

.psk-brand-label {
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.2;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* =========================
   NAVIGATION
========================= */

.psk-nav,
.psk-mobile-nav {
	width: 100%;
}

.psk-nav-list,
.psk-mobile-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.psk-nav-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.psk-nav-item,
.psk-mobile-nav-item {
	margin: 0;
}

.psk-nav-link {
	display: flex;
	align-items: center;
	gap: 14px;
	min-height: 52px;
	padding: 0 14px;
	border-radius: 14px;
	text-decoration: none;
	color: var(--psk-text);
	transition:
		background var(--psk-transition),
		color var(--psk-transition);
}

.psk-nav-link:hover {
	background: var(--psk-nav-hover);
	color: var(--psk-text);
}

.psk-nav-item.is-active .psk-nav-link {
	background: var(--psk-primary);
	color: #fff;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.psk-nav-item.is-active .psk-nav-link:hover {
	background: var(--psk-primary);
	color: #fff;
}

.psk-nav-item.is-active .psk-nav-icon {
	transform: translateY(-0.5px);
}

.psk-nav-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	min-width: 22px;
	font-size: 1rem;
	line-height: 1;
}

.psk-nav-icon-fallback::before {
	content: "•";
	font-size: 1.2rem;
	line-height: 1;
}

.psk-nav-label {
	display: inline-block;
	white-space: nowrap;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
}

.psk-nav,
.psk-nav-list,
.psk-nav-item,
.psk-nav-link {
	overflow: hidden;
}

/* =========================
   ACCOUNT CHIP
========================= */

.psk-account-chip {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-height: 46px;
	padding: 8px 12px;
	box-shadow: 0 1px 0 rgba(0, 0, 0, 0.02);
}

.psk-account-chip-avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 999px;
	background: var(--psk-primary);
	color: #fff;
	font-weight: 700;
	font-size: 0.9rem;
	flex-shrink: 0;
}

.psk-account-chip-text {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.psk-account-chip-label {
	font-size: 0.72rem;
	line-height: 1.05;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--psk-text-muted);
}

.psk-account-chip-name {
	font-size: 0.92rem;
	line-height: 1.2;
	font-weight: 600;
	color: var(--psk-text);
	white-space: nowrap;
}

.psk-logout-link,
.psk-profile-link {
	min-height: 46px;
	box-shadow: 0 1px 0 rgba(0, 0, 0, 0.02);
	white-space: nowrap;
}

.psk-header-right .psk-button,
.psk-header-right .psk-account-chip,
.psk-header-right .psk-logout-link,
.psk-header-right .psk-profile-link {
	min-height: 46px;
}

.psk-header-right .psk-button {
	padding: 0 16px;
	border-radius: 14px;
	box-shadow: var(--psk-shadow);
	white-space: nowrap;
}

.psk-header-right .psk-button:hover,
.psk-header-right .psk-button:focus,
.psk-header-right .psk-button:active,
.psk-header-right .psk-button:visited {
	background: var(--psk-primary) !important;
	color: #fff !important;
	border-color: var(--psk-primary) !important;
	text-decoration: none !important;
}

/* =========================
   TOGGLE / OVERLAY
========================= */

[data-psk-toggle="sidebar"] {
	cursor: pointer;
}

.psk-sidebar-toggle,
.psk-mobile-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 44px;
	padding: 0 14px;
	border: 1px solid transparent;
	background: var(--psk-primary);
	color: #fff;
	border-radius: 12px;
	box-shadow: var(--psk-shadow);
	text-decoration: none;
}

.psk-toggle-label {
	display: inline-block;
}

.psk-header-left .psk-sidebar-toggle {
	min-width: 46px;
	min-height: 46px;
	padding: 0 14px;
	border-radius: 14px;
	flex-shrink: 0;
}

.psk-header-left .psk-sidebar-toggle .psk-toggle-label {
	font-weight: 600;
}

[data-psk-overlay] {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.35);
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--psk-transition);
	z-index: 25;
}

.psk-mobile-open [data-psk-overlay] {
	opacity: 1;
	pointer-events: auto;
}

/* =========================
   COLLAPSED SIDEBAR
========================= */

.psk-is-collapsed > .psk-sidebar {
	width: var(--psk-sidebar-collapsed-width);
	min-width: var(--psk-sidebar-collapsed-width);
	max-width: var(--psk-sidebar-collapsed-width);
}

.psk-is-collapsed .psk-sidebar-brand {
	padding-left: 8px;
	padding-right: 8px;
}

.psk-is-collapsed .psk-sidebar-brand-link {
	justify-content: center;
	gap: 0;
}

.psk-is-collapsed .psk-sidebar-brand-media {
	width: 100%;
	height: 38px;
}

.psk-is-collapsed .psk-sidebar-brand-logo {
	max-height: 28px;
	margin: 0 auto;
}

.psk-is-collapsed .psk-brand-label {
	display: none;
}

html.psk-prefers-collapsed .psk-portal > .psk-sidebar {
	width: var(--psk-sidebar-collapsed-width);
	min-width: var(--psk-sidebar-collapsed-width);
	max-width: var(--psk-sidebar-collapsed-width);
}

html.psk-prefers-collapsed .psk-sidebar-brand {
	padding-left: 8px;
	padding-right: 8px;
}

html.psk-prefers-collapsed .psk-sidebar-brand-link {
	justify-content: center;
	gap: 0;
}

html.psk-prefers-collapsed .psk-sidebar-brand-media {
	width: 100%;
	height: 38px;
	justify-content: center;
}

html.psk-prefers-collapsed .psk-sidebar-brand-logo {
	max-height: 28px;
	margin: 0 auto;
}

html.psk-prefers-collapsed .psk-brand-label,
html.psk-prefers-collapsed .psk-nav-label,
.psk-is-collapsed .psk-nav-label {
	display: none !important;
}

html.psk-prefers-collapsed .psk-nav-link {
	justify-content: center;
	padding-left: 10px;
	padding-right: 10px;
	gap: 0;
}

html.psk-prefers-collapsed .psk-nav-icon {
	margin: 0 auto;
}

/* =========================
   SIDEBAR PRELOAD / NO SHIFT
========================= */

html.psk-sidebar-preload .psk-portal > .psk-sidebar,
html.psk-sidebar-preload .psk-portal > .psk-main {
	transition: none !important;
}

html.psk-sidebar-ready .psk-portal > .psk-sidebar {
	transition:
		width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		min-width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		max-width 320ms cubic-bezier(0.22, 1, 0.36, 1),
		transform 360ms cubic-bezier(0.18, 0.89, 0.32, 1.18),
		background-color var(--psk-transition),
		background var(--psk-transition),
		border-color var(--psk-transition),
		color var(--psk-transition);
}

/* =========================
   MOBILE TOOLBAR WRAPPER
========================= */

.psk-mobile-toolbar-wrap {
	display: block;
	position: static;
}

.psk-mobile-toolbar-wrap,
.psk-mobile-toolbar-wrap.e-con,
.psk-mobile-toolbar-wrap.elementor-element,
.psk-mobile-toolbar-wrap > .e-con-inner,
.psk-mobile-toolbar-wrap .elementor-widget,
.psk-mobile-toolbar-wrap .elementor-widget-container {
	background: transparent !important;
	background-color: transparent !important;
	min-height: 0 !important;
	height: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	box-shadow: none !important;
	overflow: visible !important;
}

.psk-mobile-toolbar-wrap .psk-mobile-nav {
	display: none;
}

/* =========================
   SECTION / EMPTY STATE
========================= */

.psk-section-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 14px;
}

.psk-section-title {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--psk-text);
}

.psk-empty-state {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 10px;
	padding: 24px;
	border: 1px dashed var(--psk-border);
	border-radius: var(--psk-radius);
	background: var(--psk-surface);
}

.psk-empty-state-title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--psk-text);
}

.psk-empty-state-text {
	margin: 0;
	line-height: 1.5;
	color: var(--psk-text-muted);
}

.psk-nav-debug {
	padding: 12px 14px;
	font-size: 13px;
	color: var(--psk-text-muted);
	border: 1px dashed var(--psk-border);
	border-radius: 12px;
	background: var(--psk-surface);
}

/* =========================
   THEME TOGGLE
========================= */

.psk-theme-toggle {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.psk-theme-toggle-label {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--psk-text);
}

.psk-theme-toggle .psk-theme-toggle-buttons {
	display: inline-flex !important;
	align-items: center;
	gap: 4px;
	padding: 4px;
	border-radius: 999px;
	background: var(--psk-surface) !important;
	border: 1px solid var(--psk-border) !important;
	box-shadow: none !important;
}

.psk-theme-toggle .psk-theme-toggle-button,
.psk-theme-toggle .psk-theme-toggle-button:hover,
.psk-theme-toggle .psk-theme-toggle-button:focus,
.psk-theme-toggle .psk-theme-toggle-button:active {
	all: unset;
	box-sizing: border-box;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-height: 0 !important;
	height: auto !important;
	padding: 8px 14px !important;
	border: 0 !important;
	border-radius: 999px !important;
	background: transparent !important;
	background-color: transparent !important;
	color: var(--psk-text-muted) !important;
	box-shadow: none !important;
	outline: none !important;
	text-decoration: none !important;
	font-family: inherit !important;
	font-size: 0.85rem !important;
	font-weight: 600 !important;
	line-height: 1 !important;
	cursor: pointer;
	appearance: none !important;
	-webkit-appearance: none !important;
	transition:
		background-color var(--psk-transition),
		background var(--psk-transition),
		color var(--psk-transition),
		transform var(--psk-transition);
}

.psk-theme-toggle .psk-theme-toggle-button:hover {
	background: var(--psk-nav-hover) !important;
	background-color: var(--psk-nav-hover) !important;
	color: var(--psk-text) !important;
	transform: translateY(-1px);
}

.psk-theme-toggle .psk-theme-toggle-button.is-active,
.psk-theme-toggle .psk-theme-toggle-button[aria-pressed="true"] {
	background: var(--psk-primary) !important;
	background-color: var(--psk-primary) !important;
	color: #fff !important;
}

.psk-theme-toggle .psk-theme-toggle-button.is-active:hover,
.psk-theme-toggle .psk-theme-toggle-button[aria-pressed="true"]:hover {
	background: var(--psk-primary) !important;
	background-color: var(--psk-primary) !important;
	color: #fff !important;
}

/* =========================
   MOBILE NAV
========================= */

.psk-mobile-nav {
	display: none;
}

.psk-mobile-nav-list {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 4px;
}

.psk-mobile-nav-link {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	min-height: 56px;
	padding: 6px 4px;
	border-radius: 14px;
	text-decoration: none;
	color: var(--psk-text-muted);
	transition:
		background var(--psk-transition),
		color var(--psk-transition);
}

.psk-mobile-nav-item.is-active .psk-mobile-nav-link {
	background: color-mix(in srgb, var(--psk-primary) 14%, transparent);
	color: var(--psk-primary);
}

.psk-mobile-nav-label {
	font-size: 0.78rem;
	line-height: 1.2;
	font-weight: 600;
	text-align: center;
}

body:has(.psk-portal),
body:has(.psk-mobile-toolbar-wrap) {
	background: var(--psk-bg) !important;
	background-color: var(--psk-bg) !important;
}

body:has(.psk-portal) #page,
body:has(.psk-portal) .site,
body:has(.psk-portal) .site-content,
body:has(.psk-portal) .content-area,
body:has(.psk-portal) main,
body:has(.psk-portal) .elementor,
body:has(.psk-portal) .elementor-section-wrap {
	background: var(--psk-bg) !important;
	background-color: var(--psk-bg) !important;
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 1200px) {
	.psk-grid--4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1024px) {
	.psk-grid--3,
	.psk-grid--4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.psk-header {
		padding-left: 20px;
		padding-right: 20px;
	}

	.psk-content {
		padding: 20px;
	}

	.psk-header-shell {
		gap: 14px;
	}

	.psk-page-title {
		font-size: 1.75rem;
	}

	.psk-header-right {
		gap: 8px;
	}
}

@media screen and (max-width: 782px) {
	html.admin-bar .psk-is-sticky-sidebar > .psk-sidebar .psk-sidebar-inner {
		top: 46px;
		min-height: calc(100vh - 46px);
	}
}

@media (max-width: 767px) {
	.psk-portal {
		display: block !important;
	}

	.psk-portal > .psk-sidebar {
		display: none !important;
	}

	.psk-mobile-open > .psk-sidebar {
		transform: translateX(0);
		animation: pskSidebarSlideIn 360ms cubic-bezier(0.18, 0.89, 0.32, 1.18);
	}

	.psk-is-collapsed > .psk-sidebar,
	html.psk-prefers-collapsed .psk-portal > .psk-sidebar {
		width: min(86vw, 320px);
		min-width: min(86vw, 320px);
		max-width: min(86vw, 320px);
	}

	.psk-is-collapsed .psk-nav-label,
	.psk-is-collapsed .psk-brand-label,
	html.psk-prefers-collapsed .psk-nav-label,
	html.psk-prefers-collapsed .psk-brand-label {
		display: inline-block !important;
		opacity: 1;
		width: auto;
		overflow: visible;
		pointer-events: auto;
	}

	.psk-is-collapsed .psk-nav-link,
	html.psk-prefers-collapsed .psk-nav-link {
		justify-content: flex-start;
		padding-left: 14px;
		padding-right: 14px;
		gap: 12px;
	}

	.psk-is-collapsed .psk-sidebar-brand-link,
	html.psk-prefers-collapsed .psk-sidebar-brand-link {
		justify-content: flex-start;
		gap: 12px;
	}

	.psk-header {
		min-height: 72px;
		padding: 14px 16px;
	}

	.psk-header-shell {
		gap: 12px;
	}

	.psk-header-left {
		gap: 10px;
	}

	.psk-page-title {
		font-size: 1.45rem;
	}

	.psk-page-subtitle {
		font-size: 0.88rem;
		max-width: none;
	}

	.psk-header-right {
		display: none;
	}

	.psk-content {
		padding: 16px 16px 90px;
		background: var(--psk-bg);
	}

	.psk-grid,
	.psk-grid--2,
	.psk-grid--3,
	.psk-grid--4 {
		grid-template-columns: 1fr;
		gap: 14px;
	}

    .psk-mobile-toolbar-wrap .psk-mobile-nav {
		display: block;
		position: fixed;
		left: 12px;
		right: 12px;
		bottom: 12px;
		z-index: 90;
		padding: 8px;
		background: var(--psk-surface);
		border: 1px solid var(--psk-border);
		border-radius: 20px;
		box-shadow: var(--psk-shadow-lg);
		backdrop-filter: blur(12px);
	}

    .psk-mobile-toolbar-wrap {
        display: block;
        position: static;
    }

    /* Make sure toolbar wrapper never behaves like the portal layout */
    .psk-mobile-toolbar-wrap.psk-portal,
    .psk-mobile-toolbar-wrap .psk-portal {
	display: block !important;
	min-height: 0 !important;
	background: transparent !important;
    }

	.psk-sidebar-toggle {
		display: none !important;
	}

	.psk-toggle-label {
		display: none;
	}
}

@keyframes pskSidebarSlideIn {
	0% {
		transform: translateX(-100%);
	}
	78% {
		transform: translateX(8px);
	}
	100% {
		transform: translateX(0);
	}
}

/* =========================
   NOTIFICATION BELL (Echoholics Notifications)
========================= */

.psk-notification-bell {
    position:        relative;
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    width:           38px;
    height:          38px;
    border-radius:   50%;
    border:          1px solid var(--psk-border) !important;
    background:      transparent !important;
    color:           var(--psk-text) !important;
    cursor:          pointer;
    transition:      background var(--psk-transition), border-color var(--psk-transition);
    flex-shrink:     0;
    /* Kill every Elementor button override */
    box-shadow:      none !important;
    text-decoration: none !important;
    padding:         0 !important;
    line-height:     1 !important;
    font-size:       inherit !important;
}

/* Elementor injects .elementor-button styles on any button — kill them here */
.psk-header-right .psk-notification-bell,
.psk-header-right .psk-notification-bell:hover,
.psk-header-right .psk-notification-bell:focus,
.psk-header-right .psk-notification-bell:active,
.psk-header-right .psk-notification-bell:visited,
.e-con .psk-notification-bell,
.elementor-widget-wrap .psk-notification-bell {
    background:      transparent !important;
    background-color: transparent !important;
    color:           var(--psk-text) !important;
    border:          1px solid var(--psk-border) !important;
    border-radius:   50% !important;
    box-shadow:      none !important;
    outline:         none !important;
    padding:         0 !important;
}

.psk-notification-bell:hover {
    background: var(--psk-nav-hover) !important;
}

.psk-notification-bell:focus,
.psk-notification-bell:focus-visible,
.psk-notification-bell:active {
    outline:    2px solid transparent !important;
    box-shadow: none !important;
}

.psk-notification-bell:focus-visible {
    outline:        2px solid var(--psk-primary) !important;
    outline-offset: 2px !important;
}

.psk-notification-bell .psk-bell-icon {
    font-size:      17px;
    line-height:    1;
    pointer-events: none;
}

.psk-notification-bell .ech-notif-badge {
    top:   -4px;
    right: -4px;
}

.psk-header-right .ech-notif-dropdown {
    top:     calc(100% + 10px);
    right:   0;
    z-index: 9999;
}

/* Dark mode bell */
html.psk-theme-dark .psk-notification-bell,
body.psk-theme-dark .psk-notification-bell {
    border-color: var(--psk-border) !important;
    color:        var(--psk-text) !important;
    background:   transparent !important;
}

html.psk-theme-dark .psk-notification-bell:hover,
body.psk-theme-dark .psk-notification-bell:hover {
    background: var(--psk-nav-hover) !important;
}