/* Global box-sizing reset for proper width calculations */
*,
*::before,
*::after {
	box-sizing: border-box;
}

/* Fluid base font size and line height */
body {
	font-size: clamp(0.9rem, 0.25rem + 1vw, 1rem);
	line-height: 1.5;
}

/* Headings scale down on small screens */
h1 {
	font-size: clamp(1.5rem, 1.1rem + 2vw, 2rem);
}
h2 {
	font-size: clamp(1.25rem, 1rem + 1.5vw, 1.75rem);
}
h3 {
	font-size: clamp(1.1rem, 0.95rem + 1vw, 1.5rem);
}
h4 {
	font-size: clamp(1rem, 0.9rem + 0.7vw, 1.25rem);
}
h5 {
	font-size: clamp(0.95rem, 0.85rem + 0.5vw, 1.1rem);
}
h6 {
	font-size: clamp(0.9rem, 0.8rem + 0.4vw, 1rem);
}

/* Small/muted/helper text */
.small,
.text-muted,
.form-text {
	font-size: clamp(0.8rem, 0.7rem + 0.3vw, 0.9rem);
}

/* Top nav links scale */
header nav a {
	font-size: clamp(0.9rem, 0.75rem + 0.4vw, 1rem);
}

/* Optional: slightly reduce card text on very small screens */
@media (max-width: 576px) {
	.card {
		font-size: 0.95em;
	}
}

/* Global dark theme */
:root {
	color-scheme: dark;
	--bg: #0f1115;
	--panel: #161a22;
	--muted: #1d2330;
	--text: #e6e9ef;
	--text-dim: #a6adbb;
	--primary: #4ea1ff;
	--primary-600: #2f7fe0;
	--accent: #7bd88f;
	--danger: #ff6b6b;
	--border: #2a3040;
	--focus: #3a7afe66;
}

html,
body {
	height: 100%;
	margin: 0;
	background: var(--bg);
	color: var(--text);
	font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif;
	overflow-x: hidden; /* Prevent horizontal scrollbar */
}

/* Prevent horizontal overflow on main content */
main.container {
	max-width: 100%;
	overflow-x: hidden;
}

/* Tab content overflow control */
.tab-content,
.tab-pane {
	max-width: 100%;
	overflow-x: hidden;
}

/* Header/Nav */
header {
	background: var(--panel);
	border-bottom: 1px solid var(--border);
}

/* Bootstrap navbar overrides for dark theme */
header .navbar {
	padding: 0.5rem 0;
}
/* Auth nav items - visibility controlled by JS after auth check */
/* Inline styles set display:none initially; JS reveals the appropriate set */
header .navbar-brand {
	color: var(--text);
	font-size: 1.1rem;
}
header .navbar-brand:hover {
	color: var(--primary);
}
header .navbar-nav .nav-link {
	color: var(--text-dim);
	padding: 0.5rem 0.75rem;
	border-radius: 0.375rem;
	transition: color 0.15s, background 0.15s;
}
header .navbar-nav .nav-link:hover {
	color: var(--text);
	background: var(--muted);
}
header .navbar-nav .nav-link.active {
	color: var(--primary);
	background: transparent;
}

/* Mobile hamburger styling */
header .navbar-toggler {
	border-color: var(--border);
	padding: 0.25rem 0.5rem;
}
header .navbar-toggler:focus {
	box-shadow: 0 0 0 0.2rem var(--focus);
}
header .navbar-toggler-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23a6adbb' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Collapse menu background on mobile */
@media (max-width: 767.98px) {
	header .navbar-collapse {
		background: var(--panel);
		margin-top: 0.5rem;
		padding: 0.5rem;
		border-radius: 0.5rem;
		border: 1px solid var(--border);
	}
	header .navbar-nav {
		gap: 0.25rem;
	}
}

/* Legacy nav support (non-SSR pages) */
header nav:not(.navbar) {
	display: flex;
	gap: 1rem;
	padding: 0.75rem 1rem;
}
header nav:not(.navbar) a {
	color: var(--text-dim);
	text-decoration: none;
	padding: 0.25rem 0.5rem;
	border-radius: 0.375rem;
}
header nav:not(.navbar) a:hover {
	color: var(--text);
	background: var(--muted);
}

/* Main content area */
#pageContent {
	padding: 1rem;
}

/* Panels, cards, containers */
.card,
.panel,
.container,
.list-group,
.modal-content,
.dropdown-menu {
	background: var(--panel) !important;
	color: var(--text) !important;
	border-color: var(--border) !important;
}

/* Forms */
input,
select,
textarea {
	background: #0f1320 !important;
	color: var(--text) !important;
	border: 1px solid var(--border) !important;
}
input::placeholder,
textarea::placeholder {
	color: var(--text-dim);
}
input:focus,
select:focus,
textarea:focus {
	outline: none;
	border-color: var(--primary) !important;
	box-shadow: 0 0 0 0.2rem var(--focus) !important;
}

/* Buttons */
button,
.btn {
	background: var(--primary);
	color: #0b0e14;
	border: 1px solid var(--primary-600);
}
button:hover,
.btn:hover {
	background: var(--primary-600);
}
button:disabled,
.btn:disabled {
	background: #2a3346;
	color: #8b93a3;
	border-color: #2a3346;
}

/* Headings and text */
h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--text);
}
p,
label,
small,
span {
	color: var(--text-dim);
}

/* Utility: force bright text (override muted span default) */
.text-bright {
	color: var(--text) !important;
}

/* Tables */
table {
	color: var(--text);
}
thead {
	background: var(--muted);
}
tbody tr {
	border-color: var(--border);
}
tbody tr:nth-child(even) {
	background: #131826;
}

/* Links */
a {
	color: var(--primary);
}
a:hover {
	color: var(--accent);
}

/* Utility */
.muted {
	color: var(--text-dim);
}
.bordered {
	border: 1px solid var(--border);
}
.panel-pad {
	padding: 1rem;
}

/* Plots/containers placeholders */
#plot,
#forcastScorePlot,
#pdfForcastPlot,
#dataTablesDiv {
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 0.5rem;
	padding: 0.75rem;
	margin-top: 1rem;
	min-height: 120px;
}
/* Plots/containers */
#plot,
#forcastScorePlot,
#pdfForcastPlot,
#dataTablesDiv {
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 0.5rem;
	padding: 0.75rem;
	margin-top: 1rem;
}

/* Give charts enough vertical space */
#plot {
	min-height: 420px;
	height: 60vh;
}
#forcastScorePlot {
	min-height: 360px;
	height: 45vh;
}
#pdfForcastPlot {
	min-height: 300px;
	height: 45vh;
}

/* Support bootstrap dark tweaks */
.form-control,
.form-select,
.form-check-input {
	background-color: #0f1320;
	color: var(--text);
	border-color: var(--border);
}
.form-check-input:checked {
	background-color: var(--primary);
	border-color: var(--primary);
}

/* Scrollbar (webkit) */
*::-webkit-scrollbar {
	width: 10px;
	height: 10px;
}
*::-webkit-scrollbar-track {
	background: #0c0f15;
}
*::-webkit-scrollbar-thumb {
	background: #2a3040;
	border-radius: 6px;
}
*::-webkit-scrollbar-thumb:hover {
	background: #364057;
}

/* DataTables Dark Theme */
.dataTables_wrapper {
	background: var(--panel) !important;
	color: var(--text) !important;
}

table.dataTable {
	background-color: var(--panel) !important;
	color: var(--text) !important;
	border-collapse: collapse !important;
}

table.dataTable thead th {
	background-color: var(--muted) !important;
	color: var(--text) !important;
	border-bottom: 1px solid var(--border) !important;
}

table.dataTable tbody td {
	background-color: var(--panel) !important;
	color: var(--text) !important;
	border-top: 1px solid var(--border) !important;
}

table.dataTable tbody tr:nth-child(even) td {
	background-color: var(--muted) !important;
}

table.dataTable tbody tr:hover td {
	background-color: var(--bg) !important;
}

.dataTables_length label,
.dataTables_filter label,
.dataTables_info,
.dataTables_paginate {
	color: var(--text) !important;
}

.dataTables_filter input,
.dataTables_length select {
	background-color: var(--bg) !important;
	color: var(--text) !important;
	border: 1px solid var(--border) !important;
}

.paginate_button {
	background: var(--panel) !important;
	color: var(--text) !important;
	border: 1px solid var(--border) !important;
}

.paginate_button.current {
	background: var(--primary) !important;
	color: #0b0e14 !important;
}

/* Bootstrap List Group (dark) */
.list-group {
	background: var(--panel) !important;
	border: 1px solid var(--border) !important;
	color: var(--text) !important;
}

.list-group.list-group-flush {
	border: 0 !important;
	border-radius: 0 !important;
}

.list-group-item {
	background: var(--panel) !important;
	color: var(--text) !important;
	border-color: var(--border) !important;
}

.list-group-item + .list-group-item {
	border-top-color: var(--border) !important;
}

.list-group-item-action:hover,
.list-group-item-action:focus {
	background: var(--muted) !important;
	color: var(--text) !important;
}

.list-group-item.active {
	background: var(--primary) !important;
	border-color: var(--primary-600) !important;
	color: #0b0e14 !important;
}

.list-group-item.disabled,
.list-group-item:disabled {
	background: #0f1320 !important;
	color: var(--text-dim) !important;
}

/* Flush variant keeps only bottom borders between items */
.list-group-flush > .list-group-item {
	border-width: 0 0 1px !important;
	border-color: var(--border) !important;
}

.list-group-flush > .list-group-item:last-child {
	border-bottom-width: 0 !important;
}

/* Summary fixed-width dots to prevent layout shift */
[data-role="summary"] [data-dots] {
	display: inline-block;
	width: 3ch; /* room for '...' */
	text-align: left;
}

/* Optional: faint separators */
.summary-sep {
	opacity: 0.4;
}

/* Summary alignment grid */
[data-role="summary"].summary-grid {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.35rem 0.75rem; /* row gap, column gap */
}

/* Head: keep symbol + price on one line, with fixed-width inner columns for alignment */
.summary-group-head {
	display: inline-flex;
	flex-wrap: nowrap;
	align-items: baseline;
	white-space: nowrap;
}
.col-symbol,
.col-sep,
.col-value,
.col-change,
.col-changePct,
.col-forecast,
.col-macro {
	display: inline-block;
}
.col-symbol {
	width: var(--col-symbol, auto);
}
.col-sep {
	width: var(--col-sep, 1.25ch);
	text-align: center;
}
.col-value {
	width: var(--col-value, auto);
}
.col-change {
	width: var(--col-change, auto);
}
.col-changePct {
	width: var(--col-changePct, auto);
}
.col-forecast {
	width: auto;
	max-width: 100%;
}
.col-macro {
	width: auto;
	max-width: 100%;
}

/* Groups: keep each as a solid block when wrapping */
.summary-group-news,
.summary-group-forecast,
.summary-group-macro {
	white-space: nowrap; /* Keep news handling as before */
}
.summary-group-forecast,
.summary-group-macro {
	white-space: normal;
	flex: 0 1 auto;
	min-width: 0;
	overflow-wrap: anywhere;
}
.summary-group-news {
	flex: 1 1 240px; /* grow to fill, but allow wrap when narrow */
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Visual separators between groups (no hard-coded bullets in HTML) */
[data-role="summary"].summary-grid .summary-group + .summary-group::before {
	content: "•";
	opacity: 0.35;
	margin: 0 0.5rem;
	color: var(--text-dim);
}

/* Numeric alignment and tabular figures */
[data-summary-item="value"] [data-value],
[data-summary-item="change"] [data-value],
[data-summary-item="changePct"] [data-value] {
	display: inline-block;
	text-align: right;
	font-variant-numeric: tabular-nums;
}

/* Dim small near-zero percent/amount changes to reduce color noise */
[data-summary-item="changePct"] [data-value][data-sign="zero-like"],
[data-summary-item="change"] [data-value][data-sign="zero-like"] {
	color: var(--text-dim) !important;
}

/* Dim labels, keep values prominent */
[data-label="forecast"],
[data-label="macro"] {
	color: var(--text-dim);
	opacity: 0.85;
	margin-right: 0.25rem;
}

/* News: subtle fade mask on the right to indicate truncation */
.summary-group-news {
	position: relative;
}
.summary-group-news::after {
	content: "";
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	width: 2.5ch;
	background: linear-gradient(90deg, rgba(0, 0, 0, 0), var(--panel));
	pointer-events: none;
}

/* Responsive summary grouping */
.summary-line {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
}

.summary-group {
	display: inline-flex;
	align-items: baseline;
	gap: 0.5rem;
	flex: 0 0 auto; /* groups are atomic */
	white-space: nowrap; /* keep group on one line */
}

/* Dot separator inserted before every group except the first */
.summary-group + .summary-group::before {
	content: "•";
	margin: 0 0.5rem;
	opacity: 0.4;
}

/* Keep symbol + price from splitting */
.summary-group-head {
	white-space: nowrap;
}

/* Let news flex to fill available space and truncate neatly */
.summary-group-news {
	flex: 1 1 240px;
	min-width: 180px;
}
.summary-group-news [data-summary-item="news-headline"] {
	min-width: 0;
}
.summary-group-news [data-summary-item="news-headline"] [data-value] {
	display: inline-block;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Map success/danger to theme colors */
.text-success {
	color: var(--accent) !important;
}
.text-danger {
	color: var(--danger) !important;
}

/* If you prefer an attribute hook instead of Bootstrap classes */
[data-summary-item="change"] [data-value][data-sign="pos"],
[data-summary-item="changePct"] [data-value][data-sign="pos"] {
	color: var(--accent) !important;
}

[data-summary-item="change"] [data-value][data-sign="neg"],
[data-summary-item="changePct"] [data-value][data-sign="neg"] {
	color: var(--danger) !important;
}

/* News headline severity coloring */
[data-summary-item="news-headline"] [data-value][data-severity="neg3"] {
	color: #ff2d2d; /* bold strong red */
	font-weight: 700;
}
[data-summary-item="news-headline"] [data-value][data-severity="neg2"] {
	color: #ff4d4d; /* strong red */
}
[data-summary-item="news-headline"] [data-value][data-severity="neg1"] {
	color: #ff6b6b; /* red */
}
[data-summary-item="news-headline"] [data-value][data-severity="neutral"] {
	color: var(--text-dim);
}
[data-summary-item="news-headline"] [data-value][data-severity="pos1"] {
	color: #7bd88f; /* green */
}
[data-summary-item="news-headline"] [data-value][data-severity="pos1"] {
	color: #7bd88f; /* light green */
}
[data-summary-item="news-headline"] [data-value][data-severity="pos2"] {
	color: #2fd26e; /* strong green */
}
[data-summary-item="news-headline"] [data-value][data-severity="pos3"] {
	color: #19e37d; /* bold strong green */
	font-weight: 700;
}

/* Compact chevron toggle icon */
.chevron-toggle {
	display: inline-grid;
	place-items: center;
	width: 28px;
	height: 28px;
	padding: 0;
}
.chevron-toggle svg {
	transition: transform 0.2s ease;
}
.symbol-widget[data-state="expanded"] .chevron-toggle svg {
	transform: rotate(180deg);
}

/* Symbol search dropdown styling */
.symbol-search-dropdown {
	position: fixed; /* Changed from absolute to fixed for better visibility */
	z-index: 9999; /* Very high z-index to ensure visibility above all content */
	background: var(--panel) !important;
	border: 1px solid var(--border) !important;
	border-radius: 0.375rem;
	max-height: 300px;
	overflow-y: auto;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
	min-width: 320px; /* Ensure dropdown is wide enough for symbol names */
	padding-bottom: 0.5rem; /* Add padding at bottom for scrolling */
}

.symbol-search-dropdown .dropdown-item {
	padding: 0.5rem 0.75rem;
	color: var(--text) !important;
	background: transparent;
	border: none;
	width: 100%;
	text-align: left;
	cursor: pointer;
	font-size: 0.875rem;
	white-space: nowrap; /* Prevent text wrapping */
	overflow: hidden;
	text-overflow: ellipsis;
}

.symbol-search-dropdown .dropdown-item:hover,
.symbol-search-dropdown .dropdown-item:focus {
	background: var(--muted) !important;
	color: var(--text) !important;
}

/* End of file */

/* -------------------------------------------------- */
/* Initialization Progress Bar Styling (symbol widget) */
/* -------------------------------------------------- */
.symbol-widget .summary-group-progress .progress {
	background: var(--muted);
	border: 1px solid var(--border);
	border-radius: 4px;
	overflow: hidden;
	position: relative;
}
.symbol-widget .summary-group-progress .progress-bar {
	background: linear-gradient(90deg, var(--primary), var(--accent));
	color: #0b0e14;
	font-size: 0.65rem;
	font-weight: 600;
	line-height: 16px;
	text-align: center;
	transition: width 0.4s ease, background-position 0.6s ease;
	background-size: 200% 100%;
}
.symbol-widget .summary-group-progress[data-complete-count] .progress-bar {
	background: linear-gradient(90deg, var(--accent), var(--primary));
}
.symbol-widget .summary-group-progress .progress-bar[aria-valuenow="0"] {
	color: var(--text-dim);
}

/* Phase-specific hue shift (optional visual cue) */
.symbol-widget .summary-group-progress[data-phase="calcSimilarDates"] .progress-bar {
	background: linear-gradient(90deg, #4ea1ff, #7bd88f);
}
.symbol-widget .summary-group-progress[data-phase="calcLatestForecast"] .progress-bar {
	background: linear-gradient(90deg, #ffb347, #7bd88f);
}
.symbol-widget .summary-group-progress[data-phase="calcHistoricalForecasts"] .progress-bar {
	background: linear-gradient(90deg, #ff6b6b, #7bd88f);
}
.symbol-widget .summary-group-progress[data-phase="complete"] .progress-bar {
	background: linear-gradient(90deg, #7bd88f, #4ea1ff);
}

/* -------------------------------------------------- */
/* Mobile-First Responsive Widget Layout              */
/* -------------------------------------------------- */

/* Prevent horizontal overflow on all screen sizes */
.symbol-widget {
	max-width: 100%;
	overflow-x: hidden;
	width: 100%;
}

.symbol-widget .card-header {
	max-width: 100%;
	overflow: hidden;
	width: 100%;
}

.symbol-widget .card-body {
	max-width: 100%;
	overflow-x: hidden;
	width: 100%;
}

/* Chart wrapper containers */
.symbol-widget .card-body > .border {
	max-width: 100%;
	overflow: hidden;
	width: 100%;
}

.symbol-widget .card-body .w-100 {
	max-width: 100% !important;
	width: 100% !important;
}

/* Summary grid responsive layout */
.summary-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem 0.5rem;
	max-width: 100%;
	overflow: hidden;
}

/* Mobile: Stack summary groups vertically */
@media (max-width: 575.98px) {
	.symbol-widget .card-header {
		padding: 0.5rem;
	}

	.symbol-widget .card-header > .d-flex {
		flex-direction: column;
		align-items: flex-start !important;
		gap: 0.5rem;
		width: 100%;
	}

	/* Summary row stacks vertically on mobile */
	.summary-grid,
	[data-role="summary"].summary-grid {
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 0.35rem !important;
		max-width: 100% !important;
	}

	/* Remove bullet separators on mobile stack */
	.summary-group + .summary-group::before,
	[data-role="summary"].summary-grid .summary-group + .summary-group::before {
		display: none !important;
	}

	/* Allow ALL groups to wrap internally - override all nowrap rules */
	.summary-group,
	.summary-group-head,
	.summary-group-price,
	.summary-group-news,
	.summary-group-forecast,
	.summary-group-macro,
	.summary-group-progress {
		white-space: normal !important;
		flex-wrap: wrap !important;
		max-width: 100% !important;
		flex: 1 1 auto !important;
		min-width: 0 !important;
	}

	/* News headline full width */
	.summary-group-news {
		width: 100% !important;
	}

	/* Forecast and macro full width and wrap content */
	.summary-group-forecast,
	.summary-group-macro {
		width: 100% !important;
	}

	/* Inner items in forecast/macro can wrap */
	.summary-group-forecast > span,
	.summary-group-macro > span,
	[data-summary-item="f3m"],
	[data-summary-item="macro-sentiment"],
	[data-summary-item="macro-target"] {
		white-space: normal !important;
		display: inline !important;
	}

	/* Column width overrides - no fixed widths on mobile */
	.col-symbol,
	.col-sep,
	.col-value,
	.col-change,
	.col-changePct,
	.col-forecast,
	.col-macro,
	.col-news,
	.col-progress {
		width: auto !important;
		max-width: 100% !important;
	}

	/* Progress bar full width */
	.summary-group-progress {
		width: 100% !important;
	}

	.summary-group-progress .progress {
		width: 100% !important;
		max-width: 200px;
	}

	/* Toggle button stays top right */
	.symbol-widget .card-header > .d-flex:last-child {
		position: absolute;
		top: 0.5rem;
		right: 0.5rem;
	}

	.symbol-widget .card-header {
		position: relative;
		padding-right: 3rem;
	}

	/* Charts responsive sizing */
	.symbol-widget .card-body .border {
		padding: 0.5rem !important;
	}

	#forcstDiv,
	#histPerfDiv,
	#histPerfPdfDiv {
		min-height: 200px !important;
		height: 250px !important;
	}

	/* Form controls in expanded view */
	.symbol-widget .card-body .form-select {
		width: 100% !important;
		max-width: 100% !important;
		margin-left: 0 !important;
	}

	.symbol-widget .card-body .d-flex.flex-wrap {
		flex-direction: column;
		gap: 0.5rem !important;
	}

	.symbol-widget .card-body label {
		margin-left: 0 !important;
	}
}

/* Tablet: Compact but still horizontal */
@media (min-width: 576px) and (max-width: 991.98px) {
	.summary-grid {
		gap: 0.25rem 0.4rem;
	}

	.summary-group-news {
		flex: 1 1 180px;
		min-width: 120px;
	}

	.summary-group-forecast,
	.summary-group-macro {
		font-size: 0.85em;
	}
}

/* Ensure Plotly charts don't overflow */
.js-plotly-plot,
.plotly {
	max-width: 100% !important;
	width: 100% !important;
}

.js-plotly-plot .main-svg {
	max-width: 100%;
}

/* Chart container wrappers */
#forcstDiv,
#grokDiv,
#histPerfDiv,
#histPerfPdfDiv,
#histPerfPlot,
#histPerfPdfPlot {
	max-width: 100% !important;
	width: 100% !important;
}

/* Mobile container padding and chart fixes */
@media (max-width: 575.98px) {
	/* Ensure container has equal padding */
	main.container {
		padding-left: 0.75rem !important;
		padding-right: 0.75rem !important;
	}

	/* Card full width with proper margins */
	.symbol-widget.card {
		margin-left: 0;
		margin-right: 0;
		border-radius: 0.25rem;
	}

	/* Card body proper padding */
	.symbol-widget .card-body {
		padding: 0.5rem !important;
	}

	/* Chart containers fill available width */
	.symbol-widget .card-body .border {
		overflow: hidden;
	}

	.symbol-widget .card-body .border > div {
		width: 100% !important;
		max-width: 100% !important;
	}

	/* Force Plotly to respect container on mobile */
	.js-plotly-plot {
		width: 100% !important;
	}

	.js-plotly-plot .plotly {
		width: 100% !important;
	}

	.js-plotly-plot .svg-container {
		width: 100% !important;
	}

	.js-plotly-plot .main-svg {
		width: 100% !important;
	}
}

/* ===== Widget Loading Skeleton ===== */
/* Shows animated placeholder while widgets initialize */
.widget-loading-placeholder {
	min-height: 120px;
	background: linear-gradient(90deg, var(--muted) 25%, var(--panel) 50%, var(--muted) 75%);
	background-size: 200% 100%;
	animation: shimmer 1.5s infinite;
	border-radius: 0.5rem;
}

@keyframes shimmer {
	0% {
		background-position: 200% 0;
	}
	100% {
		background-position: -200% 0;
	}
}
