@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Be+Vietnam+Pro:wght@300;400;500;600;700&display=swap');

:root {
	--primary-container: #002ea0;
	--secondary-fixed-dim: #66df66;
	--primary-fixed: #dde1ff;
	--surface-dim: #d2d8ff;
	--on-surface: #001454;
	--surface-variant: #dde1ff;
	--on-surface-variant: #444653;
	--on-primary: #ffffff;
	--inverse-surface: #002585;
	--on-background: #001454;
	--on-secondary-container: #00751b;
	--secondary-fixed: #83fd7f;
	--on-secondary-fixed: #002203;
	--background: #fbf8ff;
	--error: #ba1a1a;
	--primary: #001c6d;
	--surface-container-highest: #dde1ff;
	--on-primary-fixed: #001454;
	--outline-variant: #c5c5d5;
	--surface-container-low: #f3f2ff;
	--secondary: #006e18;
	--surface-container: #ececff;
	--surface-container-lowest: #ffffff;
	--font-headline: 'Space Grotesk', sans-serif;
	--font-body: 'Be Vietnam Pro', sans-serif;
}

* {
	box-sizing: border-box;
}

html,
body,
.fisholg-portal-canvas-root,
.fisholg-portal-canvas-main,
.fisholg-portal-canvas-entry,
.fisholg-menu-portal-shell {
	min-height: 100%;
}

body.fisholg-portal-canvas-template {
	margin: 0;
	background: var(--surface-container-low);
	font-family: var(--font-body);
	color: var(--on-background);
}

.material-symbols-outlined {
	font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.fisholg-portal-shell {
	min-height: 100vh;
	background: var(--surface-container-low);
	width: 100%;
	overflow-x: hidden;
}

.fisholg-portal-layout {
	display: flex;
	min-height: 100vh;
	width: 100%;
}

.fisholg-portal-sidebar {
	width: 260px;
	flex-shrink: 0;
	background: linear-gradient(180deg, var(--primary) 0%, #002460 60%, var(--primary-container) 100%);
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	height: 100dvh;
	overflow-y: auto;
	overflow-x: hidden;
	z-index: 100;
}

.fisholg-portal-sidebar-inner {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.fisholg-portal-sidebar-brand {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 22px 18px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	min-height: 60px;
}

.fisholg-portal-sidebar-logo {
	display: block;
	width: 50%;
	max-width: 132px;
	height: auto;
	filter: brightness(0) invert(1);
}

.fisholg-portal-sidebar-nav {
	padding: 14px 10px;
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.fisholg-portal-sidebar-link,
.fisholg-portal-sidebar-logout {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	border-radius: 12px;
	text-decoration: none;
	font-family: var(--font-headline);
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
	white-space: nowrap;
}

.fisholg-portal-sidebar-link {
	color: rgba(255, 255, 255, 0.6);
}

.fisholg-portal-sidebar-link:hover,
.fisholg-portal-sidebar-link.is-active {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
}

.fisholg-portal-sidebar-stats {
	margin-top: auto;
	padding: 0 10px 18px;
	display: grid;
	gap: 10px;
}

.fisholg-portal-sidebar-stat-card {
	display: grid;
	gap: 6px;
	padding: 14px 14px 16px;
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.fisholg-portal-sidebar-stat-card span {
	font-family: var(--font-headline);
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.58);
}

.fisholg-portal-sidebar-stat-card strong {
	font-family: var(--font-headline);
	font-size: 1.8rem;
	font-weight: 900;
	line-height: 1;
	color: #fff;
}

.fisholg-portal-sidebar-footer {
	padding: 12px 10px 20px;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.fisholg-portal-user-chip-sidebar {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.08);
	overflow: hidden;
}

.fisholg-portal-user-chip-sidebar .material-symbols-outlined {
	font-size: 1.2rem;
	color: rgba(255, 255, 255, 0.65);
	flex-shrink: 0;
}

.fisholg-sidebar-user-info {
	overflow: hidden;
	max-width: 200px;
	min-width: 0;
}

.fisholg-portal-user-chip-sidebar strong {
	display: block;
	font-family: var(--font-headline);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #fff;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.fisholg-portal-user-chip-sidebar span {
	display: block;
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.7rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.fisholg-portal-sidebar-logout {
	background: rgba(220, 38, 38, 0.18);
	color: #fca5a5;
}

.fisholg-portal-sidebar-logout:hover {
	background: rgba(220, 38, 38, 0.32);
	color: #fff;
}

.fisholg-portal-main {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	background: var(--surface-container-low);
	margin-left: 260px;
	min-height: 100vh;
}

.fisholg-portal-content {
	display: grid;
	gap: 24px;
	padding: 36px 40px 56px;
	background: var(--surface-container-low);
	flex: 1;
}

.fisholg-portal-section-head-offers {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: center;
	gap: 24px;
	padding: 28px 32px;
	margin: 0;
	border-radius: 24px;
	background: linear-gradient(135deg, rgba(0, 28, 109, 0.98) 0%, rgba(0, 46, 160, 0.95) 58%, rgba(0, 110, 24, 0.88) 100%);
	color: #fff;
	box-shadow: 0 18px 44px rgba(0, 28, 109, 0.14);
}

.fisholg-portal-section-head-offers .fisholg-portal-eyebrow,
.fisholg-portal-section-head-offers h2,
.fisholg-portal-section-head-offers p {
	color: #fff;
}

.fisholg-portal-section-head-offers .fisholg-portal-eyebrow {
	margin-bottom: 12px;
	color: rgba(255, 255, 255, 0.72);
}

.fisholg-portal-section-head-offers .fisholg-portal-eyebrow::before {
	background: var(--secondary-fixed-dim);
}

.fisholg-portal-section-head-offers h2 {
	margin: 0 0 10px;
	font-family: var(--font-headline);
	font-size: clamp(1.8rem, 3vw, 2.4rem);
	font-weight: 900;
	line-height: 0.98;
	letter-spacing: -0.02em;
	text-transform: uppercase;
}

.fisholg-portal-section-head-offers p {
	max-width: 720px;
	margin: 0;
	color: rgba(255, 255, 255, 0.82);
	font-size: 0.92rem;
	line-height: 1.65;
}

.fisholg-portal-offers-cta {
	min-width: 220px;
	min-height: 52px;
	padding: 0 28px;
	background: var(--secondary-fixed-dim);
	color: var(--on-secondary-fixed);
	box-shadow: 0 16px 30px rgba(102, 223, 102, 0.24);
}

.fisholg-portal-offers-cta .material-symbols-outlined {
	font-size: 1.2rem;
}

.fisholg-portal-offers-cta:hover {
	background: #92ff92;
	box-shadow: 0 18px 34px rgba(102, 223, 102, 0.3);
}

.fisholg-portal-header {
	background: linear-gradient(148deg, var(--primary) 0%, #002460 55%, var(--primary-container) 100%);
	padding: 52px 56px 60px;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 32px;
	align-items: start;
	position: relative;
	overflow: hidden;
}

.fisholg-portal-header::before {
	content: '';
	position: absolute;
	top: -140px;
	right: -140px;
	width: 460px;
	height: 460px;
	border-radius: 50%;
	background: rgba(102, 223, 102, 0.05);
}

.fisholg-portal-header::after {
	content: '';
	position: absolute;
	bottom: -80px;
	left: 25%;
	width: 300px;
	height: 300px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.03);
}

.fisholg-portal-header-copy,
.fisholg-portal-header-actions {
	position: relative;
	z-index: 1;
}

.fisholg-portal-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
	color: rgba(255, 255, 255, 0.58);
	font-family: var(--font-headline);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.fisholg-portal-eyebrow::before {
	content: '';
	width: 28px;
	height: 3px;
	border-radius: 999px;
	background: var(--secondary-fixed-dim);
}

.fisholg-portal-header h1,
.fisholg-portal-login-copy h1 {
	font-family: var(--font-headline);
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	font-weight: 900;
	line-height: 0.96;
	letter-spacing: -0.02em;
	text-transform: uppercase;
	color: #fff;
	margin: 0 0 14px;
}

.fisholg-portal-header-copy p,
.fisholg-portal-login-copy p {
	color: rgba(255, 255, 255, 0.65);
	font-size: 0.92rem;
	line-height: 1.65;
	max-width: 540px;
	margin: 0;
}

.fisholg-portal-header-actions {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 14px;
}

.fisholg-portal-user-chip {
	display: inline-flex;
	flex-direction: column;
	gap: 3px;
	padding: 14px 18px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.12);
	text-align: right;
}

.fisholg-portal-user-chip strong {
	font-family: var(--font-headline);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #fff;
}

.fisholg-portal-user-chip span {
	color: rgba(255, 255, 255, 0.55);
	font-size: 0.8rem;
}

.fisholg-portal-stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	background: var(--surface-container-lowest);
	border-bottom: 1px solid rgba(0, 28, 109, 0.07);
}

.fisholg-portal-stat-card {
	display: grid;
	gap: 6px;
	padding: 28px 44px;
	border-right: 1px solid rgba(0, 28, 109, 0.07);
}

.fisholg-portal-stat-card:last-child {
	border-right: 0;
}

.fisholg-portal-stat-card span {
	font-family: var(--font-headline);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--on-surface-variant);
}

.fisholg-portal-stat-card strong {
	font-family: var(--font-headline);
	font-size: clamp(2rem, 3vw, 2.6rem);
	font-weight: 900;
	line-height: 1;
	color: var(--primary);
}

.fisholg-portal-stat-card small {
	color: var(--on-surface-variant);
	font-size: 0.88rem;
	line-height: 1.6;
}

.fisholg-portal-grid {
	display: grid;
	gap: 24px;
	padding: 32px;
}

.fisholg-portal-dashboard-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	padding: 0;
	gap: 0;
}

.fisholg-portal-panel-block {
	background: var(--surface-container-lowest);
	border-radius: 20px;
	padding: 24px;
	box-shadow: 0 20px 50px rgba(0, 28, 109, 0.08);
}

.fisholg-portal-panel-block-wide {
	grid-column: 1 / -1;
}

.fisholg-portal-panel-heading {
	display: grid;
	gap: 6px;
	margin-bottom: 18px;
}

.fisholg-portal-panel-block-compact {
	max-width: 540px;
	margin: 0 auto;
}

.fisholg-portal-panel-block h2,
.fisholg-portal-panel-block h3,
.fisholg-menu-portal-comment-card h3,
.fisholg-menu-portal-day-card h3 {
	margin: 0 0 16px;
	color: var(--primary);
	font-family: var(--font-headline);
	text-transform: uppercase;
}

.fisholg-portal-section-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 20px;
}

.fisholg-portal-muted,
.fisholg-portal-empty-inline,
.fisholg-portal-metric-item span,
.fisholg-menu-portal-comment-meta,
.fisholg-menu-portal-comment-code,
.fisholg-menu-portal-day-head p {
	color: var(--on-surface-variant);
	font-size: 0.875rem;
}

.fisholg-portal-kpis,
.fisholg-portal-metric-list {
	display: grid;
	gap: 12px;
}

.fisholg-portal-insights-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
	margin-bottom: 16px;
}

.fisholg-portal-insight-card {
	display: grid;
	gap: 8px;
	padding: 18px;
	border-radius: 18px;
	background: linear-gradient(135deg, rgba(102, 223, 102, 0.14), rgba(0, 46, 160, 0.06));
	border: 1px solid rgba(102, 223, 102, 0.18);
}

.fisholg-portal-insight-card.is-warning {
	background: linear-gradient(135deg, rgba(255, 190, 92, 0.16), rgba(255, 255, 255, 0.92));
	border-color: rgba(255, 190, 92, 0.26);
}

.fisholg-portal-insight-card.is-neutral {
	background: linear-gradient(135deg, rgba(0, 46, 160, 0.08), rgba(255, 255, 255, 0.98));
	border-color: rgba(0, 46, 160, 0.12);
}

.fisholg-portal-insight-card span {
	font-family: var(--font-headline);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--on-surface-variant);
}

.fisholg-portal-insight-card strong {
	font-family: var(--font-headline);
	font-size: 1.05rem;
	font-weight: 800;
	line-height: 1.2;
	color: var(--primary);
}

.fisholg-portal-insight-card small {
	font-size: 0.85rem;
	line-height: 1.55;
	color: var(--on-surface-variant);
}

.fisholg-portal-kpi-row,
.fisholg-portal-metric-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 16px;
	border-radius: 16px;
	background: var(--surface-container-low);
}

.fisholg-portal-kpi-copy,
.fisholg-portal-metric-item div {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.fisholg-portal-kpi-copy span,
.fisholg-portal-metric-item strong {
	font-family: var(--font-headline);
	color: var(--primary);
	font-weight: 700;
	text-transform: uppercase;
	font-size: 0.76rem;
	letter-spacing: 0.08em;
}

.fisholg-portal-kpi-track {
	width: min(280px, 100%);
	height: 10px;
	border-radius: 999px;
	background: rgba(0, 28, 109, 0.08);
	overflow: hidden;
}

.fisholg-portal-kpi-track i {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, var(--secondary-fixed-dim), var(--primary-container));
}

.fisholg-portal-filter-panel {
	display: flex;
	align-items: flex-end;
	gap: 12px;
	flex-wrap: wrap;
	padding: 18px 20px;
	background: var(--surface-container-lowest);
	border-radius: 16px;
	border: 1px solid rgba(0, 28, 109, 0.07);
	margin-bottom: 20px;
}

.fisholg-portal-filter-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 130px;
}

.fisholg-portal-filter-group-wide {
	flex: 1;
	min-width: 220px;
}

.fisholg-portal-filter-group-reset {
	min-width: auto;
}

.fisholg-portal-filter-group label,
.fisholg-portal-field label,
.fisholg-menu-portal-holiday-toggle span {
	font-family: var(--font-headline);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--on-surface-variant);
}

.fisholg-portal-field {
	display: grid;
	gap: 10px;
}

.fisholg-portal-input,
.fisholg-portal-select {
	width: 100%;
	padding: 13px 0 11px;
	border: none;
	border-bottom: 2px solid rgba(0, 28, 109, 0.18);
	border-radius: 0;
	background: transparent;
	color: var(--on-surface);
	font-family: var(--font-body);
	font-size: 1rem;
	transition: border-color 0.25s ease;
	appearance: none;
}

.fisholg-portal-select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23444653' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 2px center;
	padding-right: 28px;
	cursor: pointer;
}

.fisholg-portal-input:focus,
.fisholg-portal-select:focus,
.fisholg-portal-textarea:focus {
	outline: none;
	border-color: var(--secondary-fixed-dim);
	border-bottom-color: var(--secondary-fixed-dim);
}

.fisholg-portal-textarea {
	width: 100%;
	padding: 16px 18px;
	border: 2px solid rgba(0, 28, 109, 0.1);
	border-radius: 16px;
	background: var(--surface-container-lowest);
	color: var(--on-surface);
	font-family: var(--font-body);
	font-size: 1rem;
	resize: vertical;
	transition: border-color 0.25s ease;
}

.fisholg-portal-remember {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--on-surface-variant);
	font-size: 0.88rem;
	cursor: pointer;
}

.fisholg-portal-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 48px;
	padding: 0 26px;
	border: 0;
	border-radius: 999px;
	text-decoration: none;
	font-family: var(--font-headline);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	white-space: nowrap;
}

.fisholg-portal-btn:hover {
	transform: translateY(-2px);
}

.fisholg-portal-btn-primary {
	background: var(--primary-container);
	color: var(--on-primary);
	box-shadow: 0 8px 24px rgba(0, 46, 160, 0.22);
}

.fisholg-portal-btn-secondary {
	background: rgba(0, 28, 109, 0.07);
	color: var(--primary);
}

.fisholg-portal-btn-ghost {
	background: transparent;
	color: var(--on-surface-variant);
	border: 1.5px solid rgba(0, 28, 109, 0.18);
}

.fisholg-portal-btn-compact {
	min-height: 40px;
}

.fisholg-portal-stats-compact {
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 20px 50px rgba(0, 28, 109, 0.08);
}

.fisholg-portal-nav-back {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 40px;
	padding: 0 20px;
	border-radius: 999px;
	color: var(--primary);
	background: rgba(0, 28, 109, 0.07);
	text-decoration: none;
	font-family: var(--font-headline);
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: background 0.2s ease, color 0.2s ease;
}

.fisholg-portal-nav-back:hover {
	background: rgba(0, 28, 109, 0.12);
	color: var(--primary-container);
}

.fisholg-portal-filter-select {
	height: 40px;
	padding: 0 34px 0 14px;
	border: 1.5px solid rgba(0, 28, 109, 0.15);
	border-radius: 999px;
	background-color: var(--surface-container-lowest);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23001c6d' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	color: var(--on-surface);
	font-family: var(--font-headline);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.fisholg-portal-filter-select:focus {
	outline: none;
	border-color: var(--primary-container);
	box-shadow: 0 0 0 3px rgba(0, 46, 160, 0.1);
}

.fisholg-portal-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 12px;
	border: none;
	cursor: pointer;
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	position: relative;
	flex-shrink: 0;
}

.fisholg-portal-icon-btn .material-symbols-outlined {
	font-size: 1.1rem;
	pointer-events: none;
}

.fisholg-portal-icon-btn::after {
	content: attr(title);
	position: absolute;
	bottom: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%);
	background: rgba(0, 20, 60, 0.85);
	color: #fff;
	padding: 5px 10px;
	border-radius: 8px;
	font-family: var(--font-headline);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	white-space: nowrap;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.15s ease;
	z-index: 10;
}

.fisholg-portal-icon-btn:hover::after {
	opacity: 1;
}

.fisholg-portal-icon-btn:hover {
	transform: translateY(-2px);
}

.fisholg-portal-icon-btn-edit {
	background: var(--secondary-fixed-dim);
	color: var(--on-secondary-fixed);
	box-shadow: 0 4px 12px rgba(102, 223, 102, 0.22);
}

.fisholg-portal-icon-btn-edit:hover {
	background: #52d152;
	box-shadow: 0 8px 20px rgba(102, 223, 102, 0.35);
}

.fisholg-portal-icon-btn-applications,
.fisholg-portal-icon-btn-view {
	background: rgba(0, 28, 109, 0.08);
	color: var(--primary);
}

.fisholg-portal-icon-btn-applications:hover,
.fisholg-portal-icon-btn-view:hover {
	background: rgba(0, 28, 109, 0.14);
}

.fisholg-portal-icon-btn-duplicate {
	background: transparent;
	color: var(--on-surface-variant);
	border: none;
	box-shadow: none;
}

.fisholg-portal-icon-btn-duplicate:hover {
	background: rgba(0, 28, 109, 0.04);
	color: var(--primary);
	box-shadow: none;
}

.fisholg-portal-offer-card {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 32px;
	padding: 28px 32px;
	border-radius: 20px;
	background: var(--surface-container-lowest);
	border-left: 4px solid rgba(0, 46, 160, 0.12);
	margin-bottom: 14px;
	transition: background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.fisholg-portal-offer-card:hover {
	background: var(--surface-container-low);
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(0, 28, 109, 0.1);
	border-left-color: var(--primary-container);
}

.fisholg-portal-offer-card:last-child {
	margin-bottom: 0;
}

.fisholg-portal-offer-main,
.fisholg-portal-offer-heading {
	display: grid;
	gap: 20px;
}

.fisholg-portal-offer-heading {
	gap: 8px;
}

.fisholg-portal-offer-title-row h2 {
	margin: 0;
	font-family: var(--font-headline);
	font-size: clamp(1.4rem, 2vw, 1.9rem);
	font-weight: 900;
	line-height: 1;
	color: var(--on-surface);
	text-transform: uppercase;
}

.fisholg-portal-offer-heading p {
	margin: 0;
	color: var(--on-surface-variant);
	line-height: 1.65;
}

.fisholg-portal-badges {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 6px;
}

.fisholg-portal-badge {
	display: inline-flex;
	align-items: center;
	padding: 3px 10px;
	border-radius: 999px;
	font-family: var(--font-headline);
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	line-height: 1.6;
}

.fisholg-portal-badge.is-open {
	background: rgba(11, 103, 31, 0.1);
	color: #0b671f;
}

.fisholg-portal-badge.is-neutral {
	background: rgba(0, 46, 160, 0.09);
	color: var(--primary-container);
}

.fisholg-portal-badge.is-scheduled {
	background: rgba(193, 108, 0, 0.1);
	color: #7a5200;
}

.fisholg-portal-badge.is-archived {
	background: rgba(0, 28, 109, 0.08);
	color: var(--primary);
}

.fisholg-portal-meta-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 8px;
}

.fisholg-portal-meta-grid div {
	display: grid;
	gap: 4px;
	padding: 12px 14px;
	border-radius: 14px;
	background: var(--surface-container-low);
	transition: background 0.2s ease;
}

.fisholg-portal-offer-card:hover .fisholg-portal-meta-grid div {
	background: #fff;
}

.fisholg-portal-meta-grid span {
	font-family: var(--font-headline);
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.11em;
	text-transform: uppercase;
	color: var(--on-surface-variant);
}

.fisholg-portal-meta-grid strong {
	color: var(--on-surface);
	font-size: 0.9rem;
}

.fisholg-portal-actions {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	justify-content: center;
	gap: 10px;
}

.fisholg-portal-empty {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 16px;
	padding: 48px 0;
}

.fisholg-portal-empty h2 {
	margin: 0;
	font-family: var(--font-headline);
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--on-surface);
}

.fisholg-portal-empty p {
	margin: 0;
	color: var(--on-surface-variant);
	max-width: 440px;
	line-height: 1.6;
}

.fisholg-menu-week-card.is-current-week {
	border-left-color: var(--secondary-fixed-dim);
	box-shadow: 0 18px 42px rgba(0, 28, 109, 0.12);
}

.fisholg-menu-weeks-list {
	display: grid;
	gap: 14px;
	margin-top: 24px;
}

.fisholg-menu-editor-head {
	padding-bottom: 8px;
	border-bottom: 2px solid rgba(0, 28, 109, 0.06);
}

.fisholg-menu-editor-head .fisholg-portal-eyebrow {
	color: var(--primary-container);
}

.fisholg-menu-editor-head h2 {
	margin: 0 0 10px;
	font-family: var(--font-headline);
	font-size: clamp(1.7rem, 3vw, 2.4rem);
	font-weight: 900;
	line-height: 0.98;
	letter-spacing: -0.02em;
	text-transform: uppercase;
	color: var(--on-surface);
}

.fisholg-menu-editor-form {
	display: grid;
	gap: 28px;
}

.fisholg-menu-editor-toolbar {
	display: grid;
	grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
	gap: 24px;
	align-items: end;
}

.fisholg-menu-editor-source-note {
	display: grid;
	gap: 6px;
	padding: 16px 18px;
	border-radius: 16px;
	background: rgba(0, 46, 160, 0.05);
	border: 1px solid rgba(0, 46, 160, 0.08);
}

.fisholg-menu-editor-source-note strong {
	font-family: var(--font-headline);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--primary);
}

.fisholg-menu-editor-source-note span {
	color: var(--on-surface-variant);
	font-size: 0.92rem;
}

.fisholg-menu-portal-days-grid.fisholg-menu-editor-days-grid {
	grid-template-columns: 1fr;
}

.fisholg-menu-editor-day-card {
	display: none;
	gap: 20px;
	animation: fisholgFadeIn 0.3s ease;
}

.fisholg-menu-editor-day-card.is-active {
	display: grid;
}

@keyframes fisholgFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}

.fisholg-menu-editor-day-card .fisholg-menu-portal-day-fields {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.fisholg-menu-editor-service-block {
	display: grid;
	gap: 16px;
	padding: 24px;
	border-radius: 24px;
	background: var(--surface-container-low);
	border: 1px solid rgba(0, 28, 109, 0.05);
	align-content: start;
}

.fisholg-menu-editor-service-block h4 {
	margin: 0 0 4px;
	font-family: var(--font-headline);
	font-size: 0.85rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--primary);
	border-bottom: 2px solid rgba(0, 28, 109, 0.06);
	padding-bottom: 8px;
}

.fisholg-menu-editor-service-grid,
.fisholg-menu-editor-service-grid-snack {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.fisholg-menu-editor-input {
	padding-top: 10px;
	padding-bottom: 10px;
}

.fisholg-menu-feedback-actions {
	display: flex;
	justify-content: flex-end;
}

.fisholg-menu-feedback-service-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

.fisholg-menu-feedback-service-list div {
	display: grid;
	gap: 4px;
	padding: 14px 16px;
	border-radius: 16px;
	background: var(--surface-container-low);
}

.fisholg-menu-feedback-service-list span {
	font-family: var(--font-headline);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--on-surface-variant);
}

.fisholg-menu-feedback-service-list strong {
	color: var(--primary);
	font-size: 0.92rem;
}

.fisholg-portal-shell .success-message,
.fisholg-portal-shell .error-message {
	display: block;
	padding: 14px 20px;
	font-size: 0.95rem;
	margin: 24px 32px 0;
	border-radius: 0 12px 12px 0;
	border-left: 3px solid;
	background: #fff;
	box-shadow: 0 8px 24px rgba(0, 28, 109, 0.06);
}

.fisholg-portal-shell .success-message {
	background: rgba(102, 223, 102, 0.12);
	border-left-color: var(--secondary-fixed-dim);
	color: #0b671f;
}

.fisholg-portal-shell .error-message {
	background: rgba(186, 26, 26, 0.07);
	border-left-color: var(--error);
	color: var(--error);
}

.fisholg-portal-login {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px 24px;
	background: radial-gradient(ellipse at top left, rgba(0, 110, 24, 0.12) 0%, transparent 50%), radial-gradient(ellipse at bottom right, rgba(0, 46, 160, 0.14) 0%, transparent 50%), var(--surface-container-low);
}

.fisholg-portal-login-card {
	display: grid;
	grid-template-columns: 42% 58%;
	width: min(100%, 960px);
	border-radius: 32px;
	overflow: hidden;
	box-shadow: 0 40px 80px rgba(0, 28, 109, 0.14), 0 8px 24px rgba(0, 28, 109, 0.08);
	background: var(--surface-container-lowest);
	position: relative;
}

.fisholg-portal-login-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 42%;
	height: 100%;
	background: linear-gradient(148deg, var(--primary) 0%, #003a8c 45%, var(--secondary) 100%);
	z-index: 0;
}

.fisholg-portal-login-card::after {
	content: '';
	position: absolute;
	bottom: -80px;
	left: calc(42% - 160px);
	width: 320px;
	height: 320px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.04);
	z-index: 0;
}

.fisholg-portal-login-copy {
	grid-column: 1;
	padding: 56px 44px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 40px;
	position: relative;
	z-index: 1;
}

.fisholg-portal-login-card .success-message,
.fisholg-portal-login-card .error-message {
	grid-column: 2;
	margin: 32px 44px 0;
	border-radius: 0 10px 10px 0;
	box-shadow: none;
	border-top: 0;
	border-right: 0;
	border-bottom: 0;
}

.fisholg-portal-form {
	grid-column: 2;
	display: grid;
	gap: 24px;
	padding: 56px 44px;
	background: var(--surface-container-lowest);
	align-content: center;
}

.fisholg-portal-form::before {
	content: 'Acceso al portal';
	display: block;
	font-family: var(--font-headline);
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	font-weight: 900;
	line-height: 1;
	letter-spacing: -0.02em;
	text-transform: uppercase;
	color: var(--on-surface);
	margin-bottom: 4px;
}

.fisholg-portal-denied {
	min-height: 100vh;
	display: grid;
	place-items: center;
	padding: 32px;
}

.fisholg-menu-portal-days-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.fisholg-menu-portal-day-card {
	padding: 20px;
	border-radius: 20px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 249, 255, 0.96));
	border: 1px solid rgba(0, 46, 160, 0.08);
}

.fisholg-menu-portal-day-head {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	align-items: start;
	margin-bottom: 16px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(0, 46, 160, 0.12);
}

.fisholg-menu-portal-day-head p {
	margin: 0 0 8px;
	font-size: 0.8rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 700;
	color: rgba(0, 46, 160, 0.7);
}

/* ==========================================================================
   PREMIUM COMMENTS SECTION STYLES
   ========================================================================== */
.fisholg-comments-control-panel {
	margin-top: 48px;
	display: grid;
	gap: 28px;
}

.fisholg-comments-control-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: 16px;
	border-bottom: 2px solid rgba(0, 46, 160, 0.08);
}

.fisholg-comments-header-left {
	display: flex;
	align-items: center;
	gap: 16px;
}

.fisholg-comments-header-icon {
	font-size: 2.2rem;
	color: var(--primary);
	background: rgba(0, 46, 160, 0.06);
	padding: 10px;
	border-radius: 16px;
}

.fisholg-comments-header-left h2 {
	margin: 0 0 4px 0;
	font-family: var(--font-headline);
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--primary);
}

.fisholg-comments-header-left p {
	margin: 0;
	font-size: 0.9rem;
	color: var(--on-surface-variant);
}

/* Comments stats cards */
.fisholg-comments-stats-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}

@media (max-width: 768px) {
	.fisholg-comments-stats-grid {
		grid-template-columns: 1fr;
	}
}

.fisholg-comments-stat-card {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 24px;
	border-radius: 20px;
	background: var(--surface-container-lowest);
	border: 1px solid rgba(0, 46, 160, 0.06);
	box-shadow: 0 8px 24px rgba(0, 28, 109, 0.02);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.fisholg-comments-stat-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 30px rgba(0, 28, 109, 0.05);
}

.fisholg-comments-stat-card.is-total {
	border-left: 4px solid var(--primary);
}

.fisholg-comments-stat-card.is-pending {
	border-left: 4px solid var(--error);
}

.fisholg-comments-stat-card.is-attended {
	border-left: 4px solid var(--secondary);
}

.fisholg-comments-stat-info {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.fisholg-comments-stat-info span {
	font-family: var(--font-headline);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--on-surface-variant);
}

.fisholg-comments-stat-info strong {
	font-family: var(--font-headline);
	font-size: 2.2rem;
	font-weight: 700;
	color: var(--primary);
}

.fisholg-comments-stat-icon {
	font-size: 2.5rem;
	opacity: 0.25;
}

.fisholg-comments-stat-card.is-total .fisholg-comments-stat-icon {
	color: var(--primary);
}

.fisholg-comments-stat-card.is-pending .fisholg-comments-stat-icon {
	color: var(--error);
}

.fisholg-comments-stat-card.is-attended .fisholg-comments-stat-icon {
	color: var(--secondary);
}

/* Filter bar */
.fisholg-comments-filter-bar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 20px;
	padding: 20px 28px;
	background: var(--surface-container-lowest);
	border-radius: 20px;
	border: 1px solid rgba(0, 46, 160, 0.06);
	box-shadow: 0 4px 18px rgba(0, 28, 109, 0.01);
}

.fisholg-comments-filter-form {
	display: flex;
	align-items: center;
}

.fisholg-comments-select-group {
	display: flex;
	align-items: center;
	gap: 12px;
}

.fisholg-comments-select-group label {
	font-family: var(--font-headline);
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--on-surface);
	white-space: nowrap;
}

.fisholg-comments-select-group select {
	min-width: 220px;
}

.fisholg-comments-status-filter {
	display: flex;
	align-items: center;
	gap: 16px;
}

.fisholg-comments-filter-title {
	font-family: var(--font-headline);
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--on-surface);
}

/* Premium Comments Cards Grid */
.fisholg-comments-premium-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px;
}

@media (max-width: 1024px) {
	.fisholg-comments-premium-grid {
		grid-template-columns: 1fr;
	}
}

.fisholg-comment-premium-card {
	display: flex;
	flex-direction: column;
	gap: 20px;
	padding: 24px;
	background: var(--surface-container-lowest);
	border-radius: 20px;
	border: 1px solid rgba(0, 46, 160, 0.06);
	box-shadow: 0 10px 30px rgba(0, 28, 109, 0.03);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.fisholg-comment-premium-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 36px rgba(0, 28, 109, 0.06);
}

.fisholg-comment-premium-card.is-pending {
	border-left: 5px solid var(--error);
}

/* Card Header */
.fisholg-comment-premium-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
}

.fisholg-comment-user-info {
	display: flex;
	align-items: center;
	gap: 12px;
}

.fisholg-comment-user-avatar {
	font-size: 2.8rem;
	color: var(--outline-variant);
}

.fisholg-comment-user-info h3 {
	margin: 0 0 6px 0;
	font-family: var(--font-headline);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--primary);
}

.fisholg-comment-user-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.fisholg-comment-dni-badge,
.fisholg-comment-date-badge {
	font-size: 0.72rem;
	padding: 2px 10px;
	border-radius: 6px;
	background: var(--surface-container-low);
	color: var(--on-surface-variant);
}

.fisholg-comment-time-status {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 8px;
}

.fisholg-comment-time-label {
	font-family: var(--font-headline);
	font-size: 0.72rem;
	font-weight: 600;
	color: var(--on-surface-variant);
}

.fisholg-comment-status-pill {
	font-family: var(--font-headline);
	font-size: 0.65rem;
	font-weight: 800;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 999px;
	letter-spacing: 0.05em;
}

.fisholg-comment-status-pill.is-pending {
	background: rgba(186, 26, 26, 0.1);
	color: var(--error);
}

.fisholg-comment-status-pill.is-attended {
	background: rgba(0, 110, 24, 0.1);
	color: var(--secondary);
}

/* Services */
.fisholg-comment-premium-services {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.fisholg-comment-service-badge {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	padding: 4px 12px;
	border-radius: 999px;
	background: rgba(0, 46, 160, 0.05);
	color: var(--primary-container);
}

/* Body & Details Grid */
.fisholg-comment-premium-body-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}

.fisholg-comment-premium-message {
	padding: 16px 20px;
	background: var(--surface-container-low);
	border-radius: 16px;
	border-left: 3px solid var(--outline-variant);
}

.fisholg-comment-section-lbl {
	display: block;
	font-family: var(--font-headline);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--on-surface-variant);
	margin-bottom: 8px;
}

.fisholg-comment-premium-message p {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.6;
	color: var(--on-surface);
}

/* Reference menus details */
.fisholg-comment-premium-details-list {
	display: grid;
	gap: 10px;
}

.fisholg-comment-premium-detail-item {
	padding: 12px 16px;
	background: var(--surface-container-low);
	border-radius: 12px;
	font-size: 0.82rem;
}

.fisholg-comment-premium-detail-item span {
	display: block;
	font-family: var(--font-headline);
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--on-surface-variant);
	margin-bottom: 4px;
}

.fisholg-comment-premium-detail-item strong {
	color: var(--on-surface);
	font-weight: 500;
	line-height: 1.4;
}

/* Action button */
.fisholg-comment-premium-actions {
	display: flex;
	justify-content: flex-end;
	margin-top: auto;
	padding-top: 12px;
	border-top: 1px solid rgba(0, 46, 160, 0.06);
}

.fisholg-comment-action-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-headline);
	font-weight: 600;
	font-size: 0.8rem;
	text-transform: none;
	padding: 8px 16px;
	border-radius: 10px;
	cursor: pointer;
}

.fisholg-menu-portal-holiday-toggle {
	display: grid;
	gap: 8px;
	min-width: 160px;
}

.fisholg-menu-portal-day-fields {
	display: grid;
	gap: 14px;
}

.fisholg-menu-portal-day-fields.is-disabled {
	opacity: 0.55;
}

.fisholg-menu-portal-textarea {
	min-height: 120px;
}

.fisholg-menu-portal-day-stats {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin-top: 18px;
}

.fisholg-menu-portal-day-stats span {
	padding: 14px 16px;
	border-radius: 16px;
	background: var(--surface-container-low);
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--primary);
}

.fisholg-menu-portal-comment-code {
	margin: 0;
}

.fisholg-menu-portal-actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 20px;
}

.fisholg-menu-supplies-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.fisholg-menu-supplies-card,
.fisholg-menu-supplies-list,
.fisholg-menu-supply-item,
.fisholg-menu-inline-supply {
	display: grid;
	gap: 12px;
}

.fisholg-menu-supplies-card-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 12px;
}

.fisholg-menu-supplies-kicker {
	margin: 0 0 8px;
	font-family: var(--font-headline);
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(0, 46, 160, 0.72);
}

.fisholg-menu-supplies-create-form,
.fisholg-menu-supply-edit-form,
.fisholg-menu-supply-toggle-form {
	display: grid;
	gap: 10px;
}

.fisholg-menu-supplies-create-row,
.fisholg-menu-supply-item,
.fisholg-menu-inline-supply-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.fisholg-menu-supplies-create-row .fisholg-portal-input,
.fisholg-menu-supply-edit-form .fisholg-portal-input {
	flex: 1 1 220px;
}

.fisholg-menu-supply-item {
	padding: 14px;
	border-radius: 16px;
	background: var(--surface-container-low);
	border: 1px solid rgba(0, 46, 160, 0.08);
	justify-content: space-between;
}

.fisholg-menu-supply-item.is-inactive {
	opacity: 0.68;
}

.fisholg-menu-editor-tabs-nav {
	display: flex;
	gap: 8px;
	margin-bottom: 28px;
	padding: 6px;
	background: var(--surface-container-low);
	border-radius: 18px;
	border: 1px solid rgba(0, 28, 109, 0.06);
	overflow-x: auto;
	scrollbar-width: none; /* Hide scrollbar for Firefox */
}

.fisholg-menu-editor-tabs-nav::-webkit-scrollbar {
	display: none; /* Hide scrollbar for Chrome, Safari and Opera */
}

.fisholg-menu-editor-tab-btn {
	flex: 1;
	min-width: 130px;
	min-height: 60px;
	padding: 10px 16px;
	border: none;
	border-radius: 14px;
	background: transparent;
	color: var(--on-surface-variant);
	cursor: pointer;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	transition: all 0.25s ease;
	font-family: var(--font-body);
	position: relative;
}

.fisholg-menu-editor-tab-btn:hover {
	background: rgba(0, 28, 109, 0.05);
	color: var(--primary);
}

.fisholg-menu-editor-tab-btn.is-active {
	background: linear-gradient(135deg, var(--primary) 0%, var(--primary-container) 100%);
	color: #fff;
	box-shadow: 0 10px 24px rgba(0, 28, 109, 0.16);
}

.fisholg-tab-day-name {
	font-family: var(--font-headline);
	font-size: 0.85rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.fisholg-tab-day-date {
	font-size: 0.72rem;
	font-weight: 500;
	opacity: 0.75;
}

.fisholg-menu-editor-tab-btn.is-active .fisholg-tab-day-date {
	opacity: 0.9;
}

.fisholg-tab-holiday-badge {
	position: absolute;
	top: -6px;
	right: -4px;
	background: var(--error);
	color: #fff;
	font-family: var(--font-headline);
	font-size: 0.58rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 2px 6px;
	border-radius: 6px;
	box-shadow: 0 4px 8px rgba(186, 26, 26, 0.24);
}

.fisholg-menu-editor-select-field {
	align-content: start;
	position: relative;
}

.fisholg-menu-editor-select {
	min-height: 48px;
}

.fisholg-modal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease;
}

.fisholg-modal.is-visible {
	opacity: 1;
	pointer-events: auto;
}

.fisholg-modal-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 20, 60, 0.45);
	backdrop-filter: blur(4px);
}

.fisholg-modal-container {
	position: relative;
	background: var(--surface-container-lowest);
	width: min(90%, 460px);
	border-radius: 24px;
	padding: 32px;
	box-shadow: 0 24px 64px rgba(0, 28, 109, 0.2);
	z-index: 1001;
	transform: translateY(20px);
	transition: transform 0.25s ease;
	display: grid;
	gap: 20px;
}

.fisholg-modal.is-visible .fisholg-modal-container {
	transform: translateY(0);
}

.fisholg-modal-close-btn {
	position: absolute;
	top: 20px;
	right: 20px;
	background: transparent;
	border: none;
	font-size: 1.8rem;
	line-height: 1;
	color: var(--on-surface-variant);
	cursor: pointer;
	padding: 0;
}

.fisholg-modal-close-btn:hover {
	color: var(--primary);
}

.fisholg-modal-header h3 {
	margin: 0;
}

.fisholg-modal-body {
	display: grid;
	gap: 16px;
}

.fisholg-modal-footer {
	display: flex !important;
	gap: 16px !important;
	justify-content: flex-end !important;
	background: transparent !important;
	padding: 0 !important;
	border: none !important;
	box-shadow: none !important;
}

.fisholg-modal-footer .fisholg-portal-btn {
	flex: 1 !important;
	border-radius: 999px !important;
}

.fisholg-modal-footer .fisholg-portal-btn-ghost {
	background: transparent !important;
	color: var(--on-surface-variant) !important;
	border: 1.5px solid rgba(0, 28, 109, 0.18) !important;
	box-shadow: none !important;
}

.fisholg-modal-footer .fisholg-portal-btn-primary {
	background: var(--primary-container) !important;
	color: var(--on-primary) !important;
	box-shadow: 0 8px 24px rgba(0, 46, 160, 0.22) !important;
}

.fisholg-modal-message {
	margin: 0;
	font-size: 0.85rem;
	line-height: 1.5;
}

.fisholg-modal-message.is-error {
	color: var(--error);
}

.fisholg-modal-message.is-success {
	color: var(--secondary);
}

.fisholg-menu-inline-supply-message {
	margin: 0;
	font-size: 0.78rem;
	line-height: 1.45;
	color: var(--on-surface-variant);
}

.fisholg-menu-inline-supply-message.is-error {
	color: var(--error);
}

.fisholg-menu-inline-supply-message.is-success {
	color: var(--secondary);
}

.fisholg-portal-actions-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

@media (max-width: 1200px) {
	.fisholg-portal-dashboard-grid,
	.fisholg-menu-supplies-grid,
	.fisholg-menu-portal-days-grid,
	.fisholg-menu-portal-comments-grid {
		grid-template-columns: 1fr;
	}

	.fisholg-menu-editor-day-card .fisholg-menu-portal-day-fields {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.fisholg-portal-insights-grid,
	.fisholg-menu-portal-comment-body {
		grid-template-columns: 1fr;
	}

	.fisholg-menu-feedback-service-list,
	.fisholg-portal-meta-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1024px) {
	.fisholg-portal-sidebar {
		position: static;
		width: 100%;
		height: auto;
	}

	.fisholg-portal-layout {
		flex-direction: column;
	}

	.fisholg-portal-main {
		margin-left: 0;
	}

	.fisholg-portal-header,
	.fisholg-portal-stats {
		grid-template-columns: 1fr;
	}

	.fisholg-portal-section-head-offers {
		grid-template-columns: 1fr;
	}

	.fisholg-menu-editor-toolbar,
	.fisholg-portal-offer-card {
		grid-template-columns: 1fr;
	}

	.fisholg-portal-actions,
	.fisholg-portal-badges {
		align-items: flex-start;
		justify-content: flex-start;
	}

	.fisholg-portal-stat-card {
		border-right: 0;
		border-bottom: 1px solid rgba(0, 28, 109, 0.07);
	}

	.fisholg-portal-stat-card:last-child {
		border-bottom: 0;
	}

	.fisholg-portal-login-card {
		grid-template-columns: 1fr;
	}

	.fisholg-portal-login-card::before,
	.fisholg-portal-login-card::after {
		display: none;
	}

	.fisholg-portal-login-copy {
		grid-column: auto;
		background: linear-gradient(148deg, var(--primary) 0%, #003a8c 45%, var(--secondary) 100%);
	}

	.fisholg-portal-login-card .success-message,
	.fisholg-portal-login-card .error-message,
	.fisholg-portal-form {
		grid-column: auto;
	}

	.fisholg-portal-form {
		padding-top: 24px;
	}
}

@media (max-width: 767px) {
	.fisholg-portal-section-head-offers {
		padding: 24px;
	}

	.fisholg-portal-content {
		padding: 20px 16px 32px;
	}

	.fisholg-portal-header {
		padding: 36px 24px 42px;
	}

	.fisholg-portal-kpi-row,
	.fisholg-portal-metric-item,
	.fisholg-menu-portal-day-head,
	.fisholg-menu-portal-comment-topbar,
	.fisholg-menu-portal-comment-header,
	.fisholg-portal-section-head {
		flex-direction: column;
		align-items: flex-start;
	}

	.fisholg-menu-portal-comment-status-form {
		width: 100%;
		justify-content: stretch;
	}

	.fisholg-menu-portal-comment-status-select,
	.fisholg-menu-portal-comment-status-form .fisholg-portal-btn {
		width: 100%;
	}

	.fisholg-menu-portal-day-stats {
		grid-template-columns: 1fr;
	}

	.fisholg-portal-filter-panel {
		align-items: stretch;
	}

	.fisholg-portal-btn,
	.fisholg-portal-filter-group,
	.fisholg-portal-filter-group-wide,
	.fisholg-portal-filter-group-reset {
		width: 100%;
	}

	.fisholg-menu-editor-toolbar,
	.fisholg-menu-feedback-service-list,
	.fisholg-menu-editor-service-grid,
	.fisholg-menu-editor-service-grid-snack,
	.fisholg-portal-meta-grid {
		grid-template-columns: 1fr;
	}

	.fisholg-portal-filter-select,
	.fisholg-portal-nav-back {
		width: 100%;
	}

	.fisholg-portal-offer-card {
		padding: 22px 20px;
	}

	.fisholg-portal-section-head-offers .fisholg-portal-btn,
	.fisholg-menu-feedback-actions {
		width: 100%;
	}
}


/* Custom Select Container */
.fisholg-custom-select-wrap {
	position: relative;
	width: 100%;
}

.fisholg-custom-select-wrap.is-disabled {
	pointer-events: none !important;
	opacity: 0.8;
}

/* Custom Select Trigger Button */
.fisholg-custom-select-trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 13px 0 11px;
	border: none;
	border-bottom: 2px solid rgba(0, 28, 109, 0.18) !important;
	border-radius: 0 !important;
	background: transparent !important;
	color: var(--on-surface) !important;
	font-family: var(--font-body) !important;
	font-size: 1rem !important;
	text-align: left;
	cursor: pointer;
	transition: border-color 0.25s ease;
	box-shadow: none !important;
}

.fisholg-custom-select-trigger:focus {
	outline: none;
	border-bottom-color: var(--secondary-fixed-dim) !important;
}

.fisholg-custom-select-trigger:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	pointer-events: none;
}

.fisholg-custom-select-arrow {
	font-size: 1.25rem;
	color: #444653;
	transition: transform 0.2s ease;
	user-select: none;
}

/* Arrow rotation when dropdown is open */
.fisholg-custom-select-wrap.is-open .fisholg-custom-select-arrow {
	transform: rotate(180deg);
}

/* Dropdown Container */
.fisholg-custom-select-dropdown {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 100;
	margin-top: 4px;
	background: var(--surface-container-lowest);
	border: 1px solid rgba(0, 28, 109, 0.1);
	border-radius: 16px;
	box-shadow: 0 12px 32px rgba(0, 28, 109, 0.15);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
	max-height: 280px;
	overflow-y: auto;
}

/* Scrollbar styling for the dropdown */
.fisholg-custom-select-dropdown::-webkit-scrollbar {
	width: 8px;
}
.fisholg-custom-select-dropdown::-webkit-scrollbar-track {
	background: transparent;
}
.fisholg-custom-select-dropdown::-webkit-scrollbar-thumb {
	background: rgba(0, 28, 109, 0.15);
	border-radius: 99px;
}
.fisholg-custom-select-dropdown::-webkit-scrollbar-thumb:hover {
	background: rgba(0, 28, 109, 0.25);
}

.fisholg-custom-select-wrap.is-open .fisholg-custom-select-dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* Options List */
.fisholg-custom-select-options {
	list-style: none;
	padding: 8px 0;
	margin: 0;
}

/* Option Item */
.fisholg-custom-select-option {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 16px;
	color: var(--on-surface);
	font-family: var(--font-body);
	font-size: 0.95rem;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
	position: relative;
	min-height: 44px;
}

.fisholg-custom-select-option:hover {
	background-color: rgba(0, 28, 109, 0.05) !important;
	color: var(--primary) !important;
}

.fisholg-custom-select-option.is-selected {
	background-color: rgba(0, 28, 109, 0.08);
	color: var(--primary);
	font-weight: 600;
}

.fisholg-custom-select-option.add-new {
	border-bottom: 1px solid rgba(0, 28, 109, 0.08);
	color: var(--primary);
	font-weight: 600;
	margin-bottom: 4px;
	padding-bottom: 12px;
}

.fisholg-custom-select-option.add-new:hover {
	background-color: rgba(0, 46, 160, 0.08) !important;
}

/* Actions Wrapper Inside Option */
.fisholg-custom-option-actions {
	display: flex;
	align-items: center;
	gap: 6px;
	opacity: 0;
	visibility: hidden;
	transform: translateX(10px);
	transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
}

.fisholg-custom-select-option:hover .fisholg-custom-option-actions {
	opacity: 1;
	visibility: visible;
	transform: translateX(0);
}

/* Action button inside option */
.fisholg-custom-action-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border: 1px solid rgba(0, 28, 109, 0.14) !important;
	border-radius: 8px !important;
	background: var(--surface-container-lowest) !important;
	cursor: pointer;
	transition: all 0.2s ease;
	padding: 0;
	box-shadow: none !important;
}

.fisholg-custom-action-btn .material-symbols-outlined {
	font-size: 1rem;
	font-variation-settings: 'FILL' 0, 'wght' 400;
}

.fisholg-custom-action-btn.edit-btn {
	color: var(--primary) !important;
}

.fisholg-custom-action-btn.edit-btn:hover {
	background: rgba(0, 28, 109, 0.08) !important;
	border-color: var(--primary) !important;
	transform: scale(1.1);
}

.fisholg-custom-action-btn.delete-btn {
	color: var(--error) !important;
}

.fisholg-custom-action-btn.delete-btn:hover {
	background: rgba(186, 26, 26, 0.08) !important;
	border-color: var(--error) !important;
	transform: scale(1.1);
}

/* Week Card Premium Redesign */
.fisholg-db-week-card {
	position: relative;
	border-radius: 20px;
	background: var(--surface-container-lowest);
	border: 1px solid rgba(0, 28, 109, 0.06);
	box-shadow: 0 8px 24px rgba(0, 28, 109, 0.04);
	overflow: hidden;
	transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
	margin-bottom: 14px;
}

.fisholg-db-week-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 16px 40px rgba(0, 28, 109, 0.09);
	border-color: rgba(0, 28, 109, 0.12);
}

.fisholg-db-week-card.is-active {
	border-left: 5px solid var(--secondary-fixed-dim);
	box-shadow: 0 18px 42px rgba(0, 28, 109, 0.12);
}

.fisholg-db-week-card-accent {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: rgba(0, 28, 109, 0.05);
}

.fisholg-db-week-card.is-active .fisholg-db-week-card-accent {
	background: linear-gradient(90deg, var(--secondary-fixed-dim), var(--primary-container));
}

.fisholg-db-week-card-grid {
	display: grid;
	grid-template-columns: 260px 120px 240px 1fr;
	gap: 20px;
	align-items: center;
	padding: 24px 32px;
}

@media (max-width: 1200px) {
	.fisholg-db-week-card-grid {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 24px;
	}
}

.fisholg-db-week-dates {
	display: flex;
	align-items: center;
	gap: 16px;
}

.fisholg-db-week-dates .material-symbols-outlined {
	font-size: 2rem;
	color: var(--primary);
	background: rgba(0, 46, 160, 0.06);
	padding: 10px;
	border-radius: 12px;
}

.fisholg-db-week-dates h3 {
	margin: 0 0 2px;
	font-family: var(--font-headline);
	font-size: 1.15rem;
	font-weight: 800;
	color: var(--on-surface);
}

.fisholg-db-week-year {
	font-size: 0.8rem;
	color: var(--on-surface-variant);
	font-weight: 600;
}

.fisholg-db-week-status {
	display: flex;
	align-items: center;
}

.fisholg-db-week-meta-label {
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--on-surface-variant);
	margin-bottom: 6px;
}

.fisholg-db-week-progress-row {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.fisholg-db-week-progress-row strong {
	font-size: 0.9rem;
	color: var(--on-surface);
}

.fisholg-db-week-progress-bar {
	height: 6px;
	width: 120px;
	background: rgba(0, 28, 109, 0.08);
	border-radius: 999px;
	overflow: hidden;
}

.fisholg-db-week-progress-fill {
	height: 100%;
	background: var(--primary);
	border-radius: 999px;
}

.fisholg-db-week-stats {
	display: flex;
	align-items: center;
	gap: 24px;
}

.fisholg-db-week-stat-item {
	display: flex;
	align-items: center;
	gap: 8px;
}

.fisholg-db-week-stat-item .material-symbols-outlined {
	font-size: 1.3rem;
	color: var(--on-surface-variant);
}

.fisholg-db-week-stat-item strong {
	display: block;
	font-size: 1.1rem;
	font-weight: 800;
	color: var(--on-surface);
	line-height: 1;
}

.fisholg-db-week-stat-item span {
	font-size: 0.72rem;
	color: var(--on-surface-variant);
}

.fisholg-db-week-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: flex-end;
}

@media (max-width: 1200px) {
	.fisholg-db-week-actions {
		justify-content: flex-start;
	}
}

.fisholg-db-week-action-btn {
	min-height: 38px;
	height: 38px;
	padding: 0 10px;
	border-radius: 12px;
	font-size: 0.78rem;
	font-weight: 700;
	gap: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	overflow: hidden;
	text-transform: none;
	letter-spacing: normal;
}

.fisholg-db-week-action-btn span:not(.material-symbols-outlined) {
	opacity: 0;
	max-width: 0;
	transition: opacity 0.2s ease, max-width 0.2s ease, margin 0.2s ease;
	display: inline-block;
	overflow: hidden;
	white-space: nowrap;
}

.fisholg-db-week-action-btn:hover {
	padding: 0 14px;
	gap: 6px;
}

.fisholg-db-week-action-btn:hover span:not(.material-symbols-outlined) {
	opacity: 1;
	max-width: 120px;
}

.fisholg-db-week-action-btn .material-symbols-outlined {
	font-size: 1.15rem;
}

/* ==========================================================================
   DASHBOARD v2 STYLES
   ========================================================================== */

.fisholg-dash-container {
	display: grid;
	gap: 24px;
	width: 100%;
}

/* Filters Panel */
.fisholg-dash-filters-panel {
	display: grid;
	gap: 20px;
}

.fisholg-dash-filters-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
}

.fisholg-dash-filter-group {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.fisholg-dash-filter-title {
	font-family: var(--font-headline);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--on-surface-variant);
}

.fisholg-dash-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.fisholg-dash-filter-note {
	margin: 4px 0 0;
	color: var(--on-surface-variant);
	font-size: 0.82rem;
	line-height: 1.45;
}

.fisholg-dash-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 14px;
	border-radius: 99px;
	font-size: 0.78rem;
	font-weight: 600;
	text-decoration: none;
	background: var(--surface-container-low);
	color: var(--on-surface-variant);
	border: 1px solid var(--outline-variant);
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.fisholg-dash-pill:hover {
	background: var(--surface-container-highest);
	color: var(--primary);
	border-color: var(--primary);
	transform: translateY(-1px);
}

.fisholg-dash-pill.is-active {
	background: var(--primary);
	color: var(--on-primary);
	border-color: var(--primary);
	box-shadow: 0 4px 10px rgba(0, 28, 109, 0.15);
}

/* Custom Date Form */
.fisholg-dash-custom-date-form {
	padding-top: 16px;
	border-top: 1px solid rgba(0, 28, 109, 0.08);
	animation: slideDown 0.3s ease;
}

.fisholg-dash-date-inputs {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 16px;
}

.fisholg-dash-date-inputs .fisholg-portal-field {
	flex: 1;
	min-width: 160px;
	margin-bottom: 0;
}

.fisholg-dash-date-submit {
	margin-bottom: 0;
}

/* KPI Grid */
.fisholg-dash-kpi-row {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 20px;
	width: 100%;
}

.fisholg-dash-kpi {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 24px;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.fisholg-dash-kpi:hover {
	transform: translateY(-2px);
	box-shadow: 0 25px 55px rgba(0, 28, 109, 0.12);
}

.fisholg-dash-kpi-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 14px;
	flex-shrink: 0;
}

.fisholg-dash-kpi-icon .material-symbols-outlined {
	font-size: 1.6rem;
}

.fisholg-dash-kpi-icon.is-ratings {
	background: rgba(0, 110, 24, 0.08);
	color: var(--secondary);
}

.fisholg-dash-kpi-icon.is-average {
	background: rgba(0, 46, 160, 0.08);
	color: var(--primary-container);
}

.fisholg-dash-kpi-icon.is-comments {
	background: rgba(0, 28, 109, 0.08);
	color: var(--primary);
}

.fisholg-dash-kpi-icon.is-pending {
	background: rgba(186, 26, 26, 0.08);
	color: var(--error);
}

.fisholg-dash-kpi-copy {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.fisholg-dash-kpi-copy span {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--on-surface-variant);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.fisholg-dash-kpi-copy strong {
	font-family: var(--font-headline);
	font-size: 1.8rem;
	font-weight: 800;
	color: var(--on-surface);
	line-height: 1.1;
}

.fisholg-dash-kpi-copy strong.is-average {
	color: var(--primary);
}

/* Row 2: Trend & Service Averages */
.fisholg-dash-row-trends {
	display: grid;
	gap: 24px;
}

.fisholg-dash-row-trends.has-sidebar {
	grid-template-columns: 2.2fr 1fr;
}

.fisholg-dash-row-trends.is-full-width {
	grid-template-columns: 1fr;
}

.fisholg-dash-trend-chart-container {
	min-height: 380px;
	display: flex;
	flex-direction: column;
}

.fisholg-dash-trend-chart-container h3,
.fisholg-dash-service-bars h3,
.fisholg-dash-ranking-card h3,
.fisholg-dash-activity h3 {
	margin: 0 0 20px 0;
	font-size: 1.05rem;
	font-weight: 800;
	font-family: var(--font-headline);
	text-transform: uppercase;
	letter-spacing: 0.02em;
	color: var(--primary);
	border-bottom: 1px solid rgba(0, 28, 109, 0.05);
	padding-bottom: 12px;
}

.fisholg-dash-chart-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	color: var(--on-surface-variant);
	font-size: 0.88rem;
}

/* Service Averages Bars */
.fisholg-dash-service-bars {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.fisholg-dash-service-bar-item {
	display: grid;
	gap: 8px;
	transition: opacity 0.3s ease;
}

.fisholg-dash-service-bar-item.is-disabled {
	opacity: 0.4;
}

.fisholg-dash-service-bar-label {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.fisholg-dash-service-bar-label span {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--on-surface);
}

.fisholg-dash-service-bar-label strong {
	font-family: var(--font-headline);
	font-size: 0.95rem;
	font-weight: 800;
	color: var(--primary);
}

.fisholg-dash-service-bar-bg {
	height: 12px;
	background: var(--surface-container-low);
	border-radius: 99px;
	overflow: hidden;
	border: 1px solid rgba(0, 28, 109, 0.05);
}

.fisholg-dash-service-bar-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--primary) 0%, var(--primary-container) 100%);
	border-radius: 99px;
	width: 0%;
	transition: width 1.2s cubic-bezier(0.1, 0.8, 0.25, 1);
}

.fisholg-dash-service-bar-item.is-disabled .fisholg-dash-service-bar-fill {
	background: var(--outline-variant);
}

/* Ranking Grid */
.fisholg-dash-ranking-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 24px;
}

.fisholg-dash-ranking-title {
	display: flex;
	align-items: center;
	gap: 10px;
}

.fisholg-dash-ranking-title .material-symbols-outlined {
	font-size: 1.3rem;
}

.fisholg-dash-ranking-card.is-best .fisholg-dash-ranking-title .material-symbols-outlined {
	color: var(--secondary);
}

.fisholg-dash-ranking-card.is-worst .fisholg-dash-ranking-title .material-symbols-outlined {
	color: var(--error);
}

.fisholg-dash-ranking-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 12px;
}

.fisholg-dash-ranking-list li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 16px;
	border-radius: 12px;
	background: var(--surface-container-low);
	border: 1px solid rgba(0, 28, 109, 0.04);
	transition: transform 0.15s ease;
}

.fisholg-dash-ranking-list li:hover {
	transform: translateX(4px);
}

.fisholg-dash-supply-name {
	font-size: 0.86rem;
	font-weight: 700;
	color: var(--on-surface);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 60%;
}

.fisholg-dash-supply-meta {
	display: flex;
	align-items: center;
	gap: 12px;
}

.fisholg-dash-rating-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	border-radius: 8px;
	font-family: var(--font-headline);
	font-size: 0.8rem;
	font-weight: 700;
}

.fisholg-dash-rating-badge .material-symbols-outlined {
	font-size: 1rem;
	font-variation-settings: 'FILL' 1;
}

.fisholg-dash-rating-badge.is-best {
	background: rgba(0, 110, 24, 0.1);
	color: var(--secondary);
}

.fisholg-dash-rating-badge.is-worst {
	background: rgba(186, 26, 26, 0.1);
	color: var(--error);
}

.fisholg-dash-supply-count {
	font-size: 0.72rem;
	color: var(--on-surface-variant);
	white-space: nowrap;
}

/* Recent Activity */
.fisholg-dash-activity-list {
	display: grid;
	gap: 12px;
}

.fisholg-dash-activity-item {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 16px 20px;
	border-radius: 14px;
	background: var(--surface-container-low);
	border: 1px solid rgba(0, 28, 109, 0.04);
	border-left: 4px solid var(--outline-variant);
	transition: transform 0.15s ease;
}

.fisholg-dash-activity-item:hover {
	transform: translateY(-1px);
}

.fisholg-dash-activity-item.is-rating {
	border-left-color: var(--secondary);
}

.fisholg-dash-activity-item.is-comment {
	border-left-color: var(--primary);
}

.fisholg-dash-activity-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.fisholg-dash-activity-badge {
	font-family: var(--font-headline);
	font-size: 0.64rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 2px 8px;
	border-radius: 4px;
}

.fisholg-dash-activity-badge.is-rating {
	background: rgba(0, 110, 24, 0.08);
	color: var(--secondary);
}

.fisholg-dash-activity-badge.is-comment {
	background: rgba(0, 28, 109, 0.08);
	color: var(--primary);
}

.fisholg-dash-activity-time {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.72rem;
	color: var(--on-surface-variant);
}

.fisholg-dash-activity-time .material-symbols-outlined {
	font-size: 0.9rem;
}

.fisholg-dash-activity-body {
	font-size: 0.85rem;
	line-height: 1.5;
	color: var(--on-surface);
}

.fisholg-dash-activity-service-date {
	display: block;
	font-size: 0.78rem;
	color: var(--on-surface-variant);
	margin-bottom: 4px;
}

.fisholg-dash-activity-stars {
	font-family: var(--font-headline);
	font-size: 0.82rem;
	color: var(--on-surface);
}

.fisholg-dash-activity-stars strong {
	color: var(--primary);
}

.fisholg-dash-activity-author {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 6px;
	font-size: 0.8rem;
}

.fisholg-dash-activity-comment-status {
	font-size: 0.66rem;
	font-weight: 700;
	padding: 1px 6px;
	border-radius: 4px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.fisholg-dash-activity-comment-status.is-attended {
	background: rgba(0, 110, 24, 0.08);
	color: var(--secondary);
}

.fisholg-dash-activity-comment-status.is-not_attended {
	background: rgba(186, 26, 26, 0.08);
	color: var(--error);
}

.fisholg-dash-activity-text {
	margin: 0;
	color: var(--on-surface-variant);
	font-style: italic;
}

/* Animations */
@keyframes slideDown {
	from {
		opacity: 0;
		transform: translateY(-8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Responsive adjustments */
@media (max-width: 992px) {
	.fisholg-dash-row-trends.has-sidebar {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.fisholg-dash-filters-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.fisholg-dash-date-inputs {
		flex-direction: column;
		align-items: stretch;
	}
	.fisholg-dash-date-inputs .fisholg-portal-field {
		width: 100%;
	}
	.fisholg-dash-date-submit button {
		width: 100%;
	}
}

/* Comment cards actions styling - AJAX v0.6.28 */
.fisholg-comment-status-action-form {
	background: transparent !important;
	background-color: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 !important;
	margin: 0 !important;
	width: auto !important;
	display: inline-flex !important;
}

.fisholg-portal-btn-success {
	background-color: var(--secondary) !important;
	color: #ffffff !important;
}

.fisholg-portal-btn-success:hover {
	background-color: #005a12 !important;
	color: #ffffff !important;
}

.fisholg-portal-btn-warning {
	background-color: var(--error) !important;
	color: #ffffff !important;
}

.fisholg-portal-btn-warning:hover {
	background-color: #a01515 !important;
	color: #ffffff !important;
}

#fisholg-comments-cards-container {
	transition: opacity 0.25s ease;
}

#fisholg-comments-cards-container.is-loading {
	opacity: 0.5;
	pointer-events: none;
}

/* ==========================================================================
   PREMIUM WEEK FEEDBACK REPORT STYLES
   ========================================================================== */

.fisholg-portal-feedback-layout-premium {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 24px;
	width: 100%;
	margin-top: 20px;
}

@media (max-width: 1024px) {
	.fisholg-portal-feedback-layout-premium {
		grid-template-columns: 1fr;
	}
}

.fisholg-premium-report-card {
	background: var(--surface-container-lowest);
	border: 1px solid rgba(0, 46, 160, 0.06);
	border-radius: 24px;
	box-shadow: 0 10px 30px rgba(0, 28, 109, 0.03);
	padding: 28px;
	margin-bottom: 24px;
}

.fisholg-premium-report-card h2 {
	font-size: 1.15rem;
	font-weight: 800;
	color: var(--primary);
	margin: 0 0 20px;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Main Score Card */
.main-score-card {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 255, 0.98));
	text-align: center;
}

.fisholg-main-score-value h3 {
	font-size: 4rem;
	font-weight: 900;
	color: var(--primary);
	margin: 0;
	line-height: 1;
}

.fisholg-score-stars-row {
	display: flex;
	justify-content: center;
	gap: 4px;
	margin: 10px 0 12px;
	color: #ffb800;
}

.fisholg-score-stars-row .material-symbols-outlined {
	font-size: 2rem;
}

.fisholg-score-stars-row .material-symbols-outlined.filled {
	font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 48;
}

.fisholg-main-score-value p {
	font-size: 0.88rem;
	color: var(--on-surface-variant);
	margin: 0 0 24px;
}

.fisholg-main-score-footer {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	border-top: 1px solid rgba(0, 46, 160, 0.08);
	padding-top: 20px;
}

.score-meta-item {
	display: flex;
	align-items: center;
	gap: 10px;
	text-align: left;
}

.score-meta-item .material-symbols-outlined {
	font-size: 2rem;
	color: var(--primary);
	opacity: 0.8;
}

.score-meta-item div strong {
	display: block;
	font-size: 1.2rem;
	font-weight: 800;
	color: var(--on-surface);
	line-height: 1.1;
}

.score-meta-item div span {
	font-size: 0.75rem;
	color: var(--on-surface-variant);
}

/* Service Breakdown */
.fisholg-service-score-list {
	display: grid;
	gap: 20px;
}

.fisholg-service-score-item {
	display: grid;
	gap: 8px;
}

.fisholg-service-score-item .service-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.fisholg-service-score-item .service-header strong {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--on-surface);
}

.fisholg-service-score-item .service-header span {
	font-size: 0.9rem;
	font-weight: 800;
	color: var(--primary);
}

.service-rating-bar {
	height: 8px;
	background: rgba(0, 28, 109, 0.05);
	border-radius: 4px;
	overflow: hidden;
}

.service-rating-bar .fill {
	height: 100%;
	background: var(--primary);
	border-radius: 4px;
}

/* Days Timeline */
.fisholg-report-timeline {
	display: grid;
	gap: 24px;
	position: relative;
}

.timeline-day-item {
	padding: 20px;
	border-radius: 16px;
	background: rgba(0, 28, 109, 0.02);
	border: 1px solid rgba(0, 28, 109, 0.04);
	display: grid;
	gap: 14px;
}

.timeline-day-item.is-holiday {
	background: rgba(186, 26, 26, 0.02);
	border-color: rgba(186, 26, 26, 0.06);
}

.timeline-day-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.timeline-day-header .day-title strong {
	display: block;
	font-size: 1.05rem;
	font-weight: 800;
	color: var(--on-surface);
}

.timeline-day-header .day-title span {
	font-size: 0.8rem;
	color: var(--on-surface-variant);
}

.holiday-badge-premium {
	background: rgba(186, 26, 26, 0.1);
	color: var(--error);
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 8px;
	letter-spacing: 0.05em;
}

.day-stats-badge {
	background: rgba(0, 28, 109, 0.06);
	color: var(--primary);
	font-size: 0.75rem;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 8px;
}

.timeline-day-content {
	display: grid;
	gap: 10px;
	border-top: 1px solid rgba(0, 28, 109, 0.05);
	padding-top: 12px;
}

.timeline-service-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	font-size: 0.88rem;
}

.timeline-service-row .service-info {
	display: flex;
	align-items: center;
	gap: 8px;
	overflow: hidden;
}

.timeline-service-row .service-label {
	font-size: 0.68rem;
	font-weight: 800;
	text-transform: uppercase;
	padding: 2px 6px;
	border-radius: 6px;
	letter-spacing: 0.02em;
	flex-shrink: 0;
}

.timeline-service-row .service-label.normal {
	background: #edf4ff;
	color: var(--primary);
}

.timeline-service-row .service-label.diet {
	background: #eefbee;
	color: #1b7a2e;
}

.timeline-service-row .service-label.snack {
	background: #fbf0ee;
	color: #b54728;
}

.timeline-service-row .service-detail {
	color: var(--on-surface);
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
}

.timeline-service-row .service-score-badge {
	background: var(--surface-container-lowest);
	border: 1px solid rgba(0, 28, 109, 0.08);
	font-weight: 800;
	color: var(--primary);
	padding: 2px 8px;
	border-radius: 6px;
	font-size: 0.8rem;
	flex-shrink: 0;
}

/* Comments Inbox */
.no-comments-premium {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 40px 20px;
	color: var(--on-surface-variant);
}

.no-comments-premium .material-symbols-outlined {
	font-size: 3rem;
	opacity: 0.4;
	margin-bottom: 12px;
}

.no-comments-premium p {
	font-size: 0.9rem;
	margin: 0;
}

.premium-comments-inbox-list {
	display: grid;
	gap: 16px;
}

.premium-comment-inbox-item {
	padding: 20px;
	border-radius: 18px;
	background: rgba(0, 28, 109, 0.02);
	border: 1px solid rgba(0, 28, 109, 0.04);
	display: flex;
	flex-direction: column;
	gap: 12px;
	position: relative;
}

.premium-comment-inbox-item.is-attended {
	border-left: 4px solid var(--secondary);
}

.premium-comment-inbox-item.is-pending {
	border-left: 4px solid var(--error);
}

.comment-item-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 12px;
}

.comment-item-header .user-meta strong {
	display: block;
	font-size: 0.95rem;
	color: var(--on-surface);
}

.comment-item-header .user-meta span {
	font-size: 0.75rem;
	color: var(--on-surface-variant);
}

.comment-item-header .comment-date {
	font-size: 0.75rem;
	color: var(--on-surface-variant);
}

.comment-item-body p {
	margin: 0 0 10px;
	font-size: 0.88rem;
	line-height: 1.6;
	color: var(--on-surface);
}

.comment-services-row {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.comment-service-tag {
	background: var(--surface-container-lowest);
	border: 1px solid rgba(0, 28, 109, 0.08);
	color: var(--on-surface-variant);
	font-size: 0.72rem;
	font-weight: 600;
	padding: 2px 8px;
	border-radius: 6px;
}

.comment-item-actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 4px;
	border-top: 1px dashed rgba(0, 28, 109, 0.06);
	padding-top: 12px;
}

.fisholg-comment-action-btn-premium {
	min-height: 32px !important;
	height: 32px !important;
	padding: 0 12px !important;
	font-size: 0.72rem !important;
	border-radius: 8px !important;
	gap: 4px !important;
}

.fisholg-comment-action-btn-premium .material-symbols-outlined {
	font-size: 1rem !important;
}




