.secondary-primary:hover {
	background-color: var(--bs-primary);
}

.bg-table-nodata {
	background-color: var(--bs-tertiary-bg);
}

.cursor-pointer {
	cursor: pointer;
}

.div-lg-row {
	height: 58px;
	line-height: 35px;
}

.btn-lg-row {
	height: 58px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.btn-timer {
	width: 80px;
	height: 80px;
	border-radius: 40px;
	font-size: 35px;
}

.btn-menu {
	min-width: 80px;
}

.form-floating>.form-select {
	line-height: 1.35;
}

.text-nowrap {
	white-space: nowrap;
}

.vh-75 {
	height: 75vh !important;
}

.vh-90 {
	height: 90vh !important;
}

.ql-toolbar.ql-snow {
	border: none;
	padding: 0 0 .25rem 0 !important;
}

.ql-editor {
	border: none;
	padding: 0;
}

.ql-container.ql-snow {
	border: none;
}

.rp-function-icon {
	display: inline-block;
	width: 48px;
	height: 48px;
	mask-size: contain;
	mask-repeat: no-repeat;
	mask-position: center;
	-webkit-mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	background-color: #000000;
}

.input_background {
	background-color: var(--bs-body-bg);
}

[data-bs-theme="dark"] .rp-function-icon {
	background-color: #ffffff;
}

/* ============================================================
   Layout-Redesign — Design Tokens
   ============================================================ */

:root {
	/* Menu section colors — fixed, mandator-independent */
	--menu-section-blue-bg: #e8f0fe;
	--menu-section-blue-icon: #1a73e8;
	--menu-section-green-bg: #e6f4ea;
	--menu-section-green-icon: #1e8e3e;
	--menu-section-indigo-bg: #ece9fe;
	--menu-section-indigo-icon: #5a4bd1;
	--menu-section-orange-bg: #fef0e6;
	--menu-section-orange-icon: #d56e2f;
	--menu-section-yellow-bg: #fff7d6;
	--menu-section-yellow-icon: #c39200;
	--menu-section-gray-bg: #eef0f3;
	--menu-section-gray-icon: #5a6470;
	--menu-section-red-bg: #fde8e8;
	--menu-section-red-icon: #c0392b;
	--menu-section-teal-bg: #d4f0ee;
	--menu-section-teal-icon: #0d8d80;
	--menu-section-pink-bg: #fde8f4;
	--menu-section-pink-icon: #c0277a;
	--menu-section-lime-bg: #f0fae6;
	--menu-section-lime-icon: #5a8a00;
	--menu-section-cyan-bg: #e0f7fa;
	--menu-section-cyan-icon: #0097a7;

	/* Layout */
	--app-rail-width: 82px;
	--tab-bar-height: 64px;

	/* App-Rail palette — fixed (mandator-independent), dark in both themes */
	--app-rail-bg: #1e2531;
	--app-rail-icon: #f6f7f9;
	--app-rail-hover: #2a3142;

	/* Surfaces */
	--surface-soft: #f6f7f9;
	--surface-card: #ffffff;
	--surface-shadow: 0 1px 2px rgba(15, 23, 42, .06), 0 4px 12px rgba(15, 23, 42, .04);
}

[data-bs-theme="dark"] {
	--menu-section-blue-bg: #1c2638;
	--menu-section-blue-icon: #7ab0ff;
	--menu-section-green-bg: #1c2e22;
	--menu-section-green-icon: #6ed28a;
	--menu-section-indigo-bg: #25223a;
	--menu-section-indigo-icon: #a397f5;
	--menu-section-orange-bg: #2f231a;
	--menu-section-orange-icon: #f0a36c;
	--menu-section-yellow-bg: #2e2a12;
	--menu-section-yellow-icon: #e6c75a;
	--menu-section-gray-bg: #20242b;
	--menu-section-gray-icon: #aab3bf;
	--menu-section-red-bg: #3a1f1f;
	--menu-section-red-icon: #f08585;
	--menu-section-teal-bg: #162e2c;
	--menu-section-teal-icon: #5fd6ca;
	--menu-section-pink-bg: #38182e;
	--menu-section-pink-icon: #f590c8;
	--menu-section-lime-bg: #1e2a10;
	--menu-section-lime-icon: #a8d44f;
	--menu-section-cyan-bg: #102a2e;
	--menu-section-cyan-icon: #4dd9e8;

	--surface-soft: #0f1115;
	--surface-card: #181b21;
	--surface-shadow: 0 1px 2px rgba(0, 0, 0, .5), 0 4px 12px rgba(0, 0, 0, .3);
}

/* ============================================================
   App-Rail (≥md)
   ============================================================ */

.app-rail {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	width: var(--app-rail-width);
	padding: .75rem .5rem;
	z-index: 1050;
	background: var(--app-rail-bg);
	color: var(--app-rail-icon);
	border-right: 1px solid rgba(0, 0, 0, .12);
}

.app-rail .btn,
.app-rail__item {
	color: var(--app-rail-icon);
	background: transparent;
	border-color: transparent;
}

.app-rail .btn:hover,
.app-rail__item:hover {
	color: var(--app-rail-icon);
	background: var(--app-rail-hover);
}

/* Offcanvas main menu + account menu start to the right of the rail (md+) and float with margin */
@media (min-width: 768px) {

	body.has-app-rail #mainMenu.offcanvas-start,
	body.has-app-rail #accountMenu.offcanvas-start {
		top: 10px;
		bottom: 10px;
		left: calc(var(--app-rail-width) + 10px);
		height: auto;
		border-radius: .75rem;
		border-right: 0;
		box-shadow: var(--surface-shadow);
	}

	body.has-app-rail .offcanvas-backdrop {
		left: var(--app-rail-width);
	}
}

.app-rail__logo {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	margin-bottom: 1rem;
}

.app-rail__item {
	width: 48px;
	height: 48px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.app-rail__avatar {
	display: inline-block;
}

.app-rail__menuitem {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 48px;
	min-height: 48px;
	margin-top: .5rem;
	padding: .25rem;
	border-radius: .5rem;
	text-decoration: none;
	background: var(--menu-tile-bg, var(--menu-section-gray-bg));
	color: var(--menu-tile-icon, var(--menu-section-gray-icon));
	font-size: 1.1rem;
	transition: transform .1s ease;
}

.app-rail__menuitem:hover {
	transform: translateY(-1px);
	color: var(--menu-tile-icon, var(--menu-section-gray-icon));
}

/* Rail items: monochrome (no section colours), icon slightly larger than main-menu tiles (1.875rem) */
.app-rail .app-rail__menuitem {
	--menu-tile-bg: transparent;
	--menu-tile-icon: var(--app-rail-icon);
	font-size: 1.75rem;
}

.app-rail .app-rail__menuitem:hover {
	--menu-tile-bg: var(--app-rail-hover);
}

.app-rail__menuitem:has(.app-rail__menuitem-label) {
	min-height: 52px;
}

.app-rail__menuitem-badge {
	font-size: .6rem;
	min-width: 1.1rem;
	padding: .2em .35em;
}

.app-rail__menuitem-img {
	max-width: 28px;
	max-height: 28px;
	object-fit: contain;
}

.app-rail__menuitem-label {
	display: block;
	margin-top: .15rem;
	max-width: 44px;
	font-size: .55rem;
	line-height: 1;
	color: var(--app-rail-icon);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.app-rail__badge {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	margin-top: .5rem;
	font-size: 1.1rem;
	text-decoration: none;
}

.app-rail__badge:hover {
	background: var(--app-rail-hover);
	border-radius: .5rem;
}

.app-rail__envtag {
	margin-top: .75rem;
	font-size: .7rem;
}

/* Body padding so content does not slide under the rail */
@media (min-width: 768px) {
	body.has-app-rail {
		padding-left: var(--app-rail-width);
	}
}

/* ============================================================
   Hauptmenü — Section Cards + Tile Grid
   ============================================================ */

.menu-section {
	margin-bottom: 1.25rem;
}

.menu-section__title {
	font-size: .85rem;
	font-weight: 700;
	letter-spacing: .02em;
	color: var(--bs-secondary-color);
	margin: 0 0 .5rem 0;
	padding: 0 .25rem;
}

.menu-section__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: .5rem;
}

.menu-tile {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: .75rem .25rem;
	border-radius: .75rem;
	background: var(--menu-tile-bg, var(--menu-section-gray-bg));
	color: var(--menu-tile-icon, var(--menu-section-gray-icon));
	text-decoration: none;
	text-align: center;
	min-height: 80px;
	transition: transform .1s ease, box-shadow .1s ease;
}

.menu-tile:hover {
	transform: translateY(-1px);
	box-shadow: var(--surface-shadow);
	color: var(--menu-tile-icon, var(--menu-section-gray-icon));
}

.menu-tile__icon {
	font-size: 1.875rem;
	margin-bottom: .4rem;
}

.menu-tile__icon--img {
	width: 30px;
	height: 30px;
	object-fit: contain;
}

.menu-tile__label {
	font-size: .75rem;
	line-height: 1.1;
	color: var(--menu-tile-icon, var(--menu-section-gray-icon));
	word-break: break-word;
}

/* Section color variants — each writes the two CSS vars the tile reads */
.menu-section--blue {
	--menu-tile-bg: var(--menu-section-blue-bg);
	--menu-tile-icon: var(--menu-section-blue-icon);
}

.menu-section--green {
	--menu-tile-bg: var(--menu-section-green-bg);
	--menu-tile-icon: var(--menu-section-green-icon);
}

.menu-section--indigo {
	--menu-tile-bg: var(--menu-section-indigo-bg);
	--menu-tile-icon: var(--menu-section-indigo-icon);
}

.menu-section--orange {
	--menu-tile-bg: var(--menu-section-orange-bg);
	--menu-tile-icon: var(--menu-section-orange-icon);
}

.menu-section--yellow {
	--menu-tile-bg: var(--menu-section-yellow-bg);
	--menu-tile-icon: var(--menu-section-yellow-icon);
}

.menu-section--gray {
	--menu-tile-bg: var(--menu-section-gray-bg);
	--menu-tile-icon: var(--menu-section-gray-icon);
}

.menu-section--red {
	--menu-tile-bg: var(--menu-section-red-bg);
	--menu-tile-icon: var(--menu-section-red-icon);
}

.menu-section--teal {
	--menu-tile-bg: var(--menu-section-teal-bg);
	--menu-tile-icon: var(--menu-section-teal-icon);
}

.menu-section--pink {
	--menu-tile-bg: var(--menu-section-pink-bg);
	--menu-tile-icon: var(--menu-section-pink-icon);
}

.menu-section--lime {
	--menu-tile-bg: var(--menu-section-lime-bg);
	--menu-tile-icon: var(--menu-section-lime-icon);
}

.menu-section--cyan {
	--menu-tile-bg: var(--menu-section-cyan-bg);
	--menu-tile-icon: var(--menu-section-cyan-icon);
}

.menu-section--primary {
	--menu-tile-bg: rgba(var(--bs-primary-rgb), .1);
	--menu-tile-icon: var(--bs-primary);
}

/* Tile color variants — same vars as section, applied directly to a single tile.
   Used for the „Mein Menu" section where each tile keeps its origin color. */
.menu-tile--blue {
	--menu-tile-bg: var(--menu-section-blue-bg);
	--menu-tile-icon: var(--menu-section-blue-icon);
}

.menu-tile--green {
	--menu-tile-bg: var(--menu-section-green-bg);
	--menu-tile-icon: var(--menu-section-green-icon);
}

.menu-tile--indigo {
	--menu-tile-bg: var(--menu-section-indigo-bg);
	--menu-tile-icon: var(--menu-section-indigo-icon);
}

.menu-tile--orange {
	--menu-tile-bg: var(--menu-section-orange-bg);
	--menu-tile-icon: var(--menu-section-orange-icon);
}

.menu-tile--yellow {
	--menu-tile-bg: var(--menu-section-yellow-bg);
	--menu-tile-icon: var(--menu-section-yellow-icon);
}

.menu-tile--gray {
	--menu-tile-bg: var(--menu-section-gray-bg);
	--menu-tile-icon: var(--menu-section-gray-icon);
}

.menu-tile--red {
	--menu-tile-bg: var(--menu-section-red-bg);
	--menu-tile-icon: var(--menu-section-red-icon);
}

.menu-tile--teal {
	--menu-tile-bg: var(--menu-section-teal-bg);
	--menu-tile-icon: var(--menu-section-teal-icon);
}

.menu-tile--pink {
	--menu-tile-bg: var(--menu-section-pink-bg);
	--menu-tile-icon: var(--menu-section-pink-icon);
}

.menu-tile--lime {
	--menu-tile-bg: var(--menu-section-lime-bg);
	--menu-tile-icon: var(--menu-section-lime-icon);
}

.menu-tile--cyan {
	--menu-tile-bg: var(--menu-section-cyan-bg);
	--menu-tile-icon: var(--menu-section-cyan-icon);
}

/* ============================================================
   Bottom Tab-Bar
   ============================================================ */

.tab-bar {
	position: fixed;
	left: 50%;
	bottom: 1rem;
	transform: translateX(-50%);
	z-index: 1020;
	background: var(--surface-card);
	border-radius: 1rem;
	box-shadow: var(--surface-shadow);
	padding: .35rem .5rem;
	max-width: calc(100% - 1rem);
}

@media (min-width: 768px) {
	body.has-app-rail .tab-bar {
		left: calc(50% + (var(--app-rail-width) / 2));
	}
}

.tab-bar__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: stretch;
	gap: .25rem;
}

.tab-bar__item {
	display: flex;
	width: 72px;
	flex-shrink: 0;
}

.tab-bar__link {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: .4rem .5rem;
	border-radius: 1.5rem;
	text-decoration: none;
	color: var(--bs-secondary-color);
	font-size: .8rem;
	line-height: 1.1;
	width: 100%;
	transition: color .1s ease, background-color .1s ease;
}

.tab-bar__link i {
	font-size: 1.1rem;
	margin-bottom: .2rem;
}

.tab-bar__link:hover {
	color: var(--bs-body-color);
}

.tab-bar__item.is-active .tab-bar__link {
	color: var(--bs-primary);
}

.tab-bar__item.is-active .tab-bar__link::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 25%;
	right: 25%;
	height: 2px;
	border-radius: 2px;
	background: var(--bs-primary);
}

.tab-bar__label {
	font-size: .75rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 100%;
}

.tab-bar__transform {
	transform: translate(-110%, -30%) !important;
}

.table_header_sort_icon {
	font-size: .75rem;
	margin-left: .25rem;
}

.table_header_row {
	height: 4rem;
}

body.pb-5 {
	padding-bottom: calc(var(--tab-bar-height) + 1.5rem) !important;
}

/* ============================================================
   Content Surface
   ============================================================ */

body {
	background: var(--surface-soft);
}

.card {
	border-radius: .75rem;
	border-color: rgba(0, 0, 0, .06);
	box-shadow: var(--surface-shadow);
}

[data-bs-theme="dark"] .card {
	border-color: rgba(255, 255, 255, .08);
	background: var(--surface-card);
}