/* ============================================
   Hvide Sande Vejrstation - Modern Design
   ============================================ */

/* CSS Variables */
:root {
	/* Colors */
	--color-primary: #1e3a5f;
	--color-primary-dark: #0f2744;
	--color-accent: #3b82f6;
	--color-accent-light: #60a5fa;
	--color-text: #1f2937;
	--color-text-light: #6b7280;
	--color-text-muted: #9ca3af;
	--color-white: #ffffff;
	--color-link: #2563eb;
	--color-link-hover: #1d4ed8;
	
	/* Card Colors */
	--card-bg: rgba(255, 255, 255, 0.85);
	--card-bg-solid: #ffffff;
	--card-border: rgba(255, 255, 255, 0.3);
	--card-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
	
	/* Banner Colors */
	--banner-bg: #1a365d;
	--banner-text: #ffffff;
	
	/* Spacing */
	--spacing-xs: 0.25rem;
	--spacing-sm: 0.5rem;
	--spacing-md: 1rem;
	--spacing-lg: 1.5rem;
	--spacing-xl: 2rem;
	--spacing-2xl: 3rem;
	
	/* Border Radius */
	--radius-sm: 4px;
	--radius-md: 8px;
	--radius-lg: 12px;
	--radius-xl: 16px;
	
	/* Font */
	--font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	--font-size-xs: 0.75rem;
	--font-size-sm: 0.875rem;
	--font-size-base: 1rem;
	--font-size-lg: 1.125rem;
	--font-size-xl: 1.25rem;
	--font-size-2xl: 1.5rem;
	--font-size-3xl: 2rem;
	
	/* Container */
	--container-max: 1200px;
}

/* Reset & Base */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 16px;
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	line-height: 1.6;
	color: var(--color-text);
	min-height: 100vh;
	
	/* Sky/Cloud Background */
	background: linear-gradient(180deg, 
		#87ceeb 0%, 
		#b0d4e8 20%,
		#c9dde8 40%,
		#d4e4eb 60%,
		#a8c4d4 80%,
		#7ba3b8 100%
	);
	background-attachment: fixed;
	
	/* Cloud overlay effect */
	position: relative;
}

body::before {
	content: '';
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: 
		radial-gradient(ellipse 80% 50% at 20% 40%, rgba(255,255,255,0.4) 0%, transparent 50%),
		radial-gradient(ellipse 60% 40% at 70% 30%, rgba(255,255,255,0.3) 0%, transparent 50%),
		radial-gradient(ellipse 90% 60% at 40% 70%, rgba(255,255,255,0.25) 0%, transparent 50%),
		radial-gradient(ellipse 70% 50% at 80% 80%, rgba(255,255,255,0.2) 0%, transparent 50%);
	pointer-events: none;
	z-index: 0;
}

/* ============================================
   Navigation
   ============================================ */
nav {
	position: relative;
	z-index: 100;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--spacing-sm) var(--spacing-xl);
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

nav a {
	color: var(--color-text);
	text-decoration: none;
	font-size: var(--font-size-sm);
	font-weight: 400;
	transition: color 0.2s ease;
}

nav a:hover {
	color: var(--color-accent);
}

nav a.active {
	font-weight: 600;
	color: var(--color-primary);
}

#languages, #locations {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
}

#languages span, #locations span {
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
}

#sluice-flow {
	color: var(--color-accent);
	font-weight: 500;
}

/* ============================================
   Header
   ============================================ */
header {
	position: relative;
	z-index: 10;
	text-align: center;
	padding: var(--spacing-xl) var(--spacing-md);
}

header h1 {
	font-size: clamp(1.8rem, 4vw, var(--font-size-3xl));
	font-weight: 300;
	color: var(--color-primary-dark);
	letter-spacing: 0.02em;
}

header h1 span {
	font-weight: 600;
	letter-spacing: 0.1em;
}

/* ============================================
   Main Content
   ============================================ */
main {
	position: relative;
	z-index: 10;
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--spacing-lg) var(--spacing-2xl);
}

/* Action Buttons */
.action-buttons {
	display: flex;
	justify-content: center;
	gap: var(--spacing-sm);
	margin-bottom: var(--spacing-xl);
	flex-wrap: wrap;
}

.btn {
	display: inline-block;
	padding: var(--spacing-sm) var(--spacing-lg);
	border-radius: var(--radius-sm);
	font-size: var(--font-size-sm);
	font-weight: 500;
	text-decoration: none;
	transition: all 0.2s ease;
	cursor: pointer;
}

.btn-primary {
	background: var(--color-accent);
	color: var(--color-white);
	box-shadow: 0 2px 8px rgba(59, 130, 246, 0.3);
}

.btn-primary:hover {
	background: var(--color-link-hover);
	box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
	transform: translateY(-1px);
}

.btn-secondary {
	background: rgba(255, 255, 255, 0.7);
	color: var(--color-text);
	border: 1px solid rgba(0, 0, 0, 0.1);
}

.btn-secondary:hover {
	background: var(--color-white);
	border-color: var(--color-accent);
	color: var(--color-accent);
}

/* ============================================
   Banner Rows
   ============================================ */
.banner-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-lg);
	margin-bottom: var(--spacing-xl);
}

.banner-slot {
	border-radius: var(--radius-md);
	overflow: hidden;
	min-height: 80px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.banner-cta {
	background: var(--banner-bg);
	color: var(--banner-text);
	text-align: center;
	padding: var(--spacing-lg);
	flex-direction: column;
}

.banner-cta p {
	margin: 0;
	font-size: var(--font-size-sm);
}

.banner-cta p:first-child {
	font-weight: 500;
}

.banner-cta p:last-child {
	font-size: var(--font-size-xs);
	opacity: 0.9;
}

.banner-image {
	background: var(--color-white);
	padding: var(--spacing-sm);
}

.banner-image img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* Banner Rotator (multiple banners per slot) */
.banner-rotator {
	position: relative;
}

.banner-slide {
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.8s ease-in-out;
}

.banner-slide.active {
	opacity: 1;
	position: relative;
}

.banner-slide a {
	display: block;
	width: 100%;
}

.banner-slide img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* ============================================
   Weather Cards
   ============================================ */
.weather-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-lg);
	margin-bottom: var(--spacing-xl);
}

.weather-card {
	background: var(--card-bg);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-radius: var(--radius-lg);
	border: 1px solid var(--card-border);
	box-shadow: var(--card-shadow);
	overflow: hidden;
}

.card-header {
	display: grid;
	grid-template-columns: auto 1fr auto 1fr;
	align-items: center;
	gap: var(--spacing-md);
	padding: var(--spacing-md) var(--spacing-lg);
	background: rgba(255, 255, 255, 0.5);
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.card-header.single {
	grid-template-columns: auto 1fr;
}

.card-header h2 {
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.card-summary {
	display: flex;
	align-items: baseline;
	gap: var(--spacing-xs);
}

.card-summary .value {
	font-size: var(--font-size-xl);
	font-weight: 600;
	color: var(--color-text);
}

.card-summary .unit {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	font-weight: 400;
}

.card-body {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-lg);
	padding: var(--spacing-lg);
}

.data-section {
	min-width: 0;
}

.data-section.full {
	grid-column: 1 / -1;
}

.data-section h3 {
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
	margin-bottom: var(--spacing-sm);
	padding-bottom: var(--spacing-xs);
	border-bottom: 2px solid var(--color-accent);
	display: inline-block;
}

.data-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--spacing-xs) 0;
	font-size: var(--font-size-sm);
}

.data-row .label {
	color: var(--color-text-light);
}

.data-row .value {
	font-weight: 500;
	color: var(--color-text);
}

.data-row .value small {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	margin-left: var(--spacing-xs);
}

.data-row .value.status {
	color: var(--color-accent);
	font-weight: 600;
}

.data-row.highlight {
	margin-top: var(--spacing-sm);
	padding-top: var(--spacing-sm);
	border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.data-row.highlight .label {
	color: var(--color-link);
}

.data-row.spacer {
	height: var(--spacing-md);
}

.data-row.link .label {
	color: var(--color-link);
	cursor: pointer;
}

.data-row.link .label:hover {
	text-decoration: underline;
}

.data-section-divider {
	height: 1px;
	background: rgba(0, 0, 0, 0.08);
	margin: var(--spacing-md) 0;
}

.prognose-text {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	font-style: italic;
	margin-bottom: var(--spacing-md);
}

/* Tide Table */
.tide-table {
	width: 100%;
}

.tide-header {
	display: flex;
	justify-content: space-between;
	font-size: var(--font-size-xs);
	font-weight: 600;
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding-bottom: var(--spacing-sm);
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
	margin-bottom: var(--spacing-sm);
}

/* Card Footer */
.card-footer {
	padding: var(--spacing-md) var(--spacing-lg);
	background: rgba(0, 0, 0, 0.02);
	border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.card-footer .note {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	margin-bottom: var(--spacing-xs);
}

.card-footer .timestamp {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	font-weight: 500;
}

/* ============================================
   Footer
   ============================================ */
footer {
	position: relative;
	z-index: 10;
	padding: var(--spacing-lg);
	text-align: center;
	margin-top: var(--spacing-2xl);
}

.footer-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
	max-width: var(--container-max);
	margin: 0 auto;
	padding: var(--spacing-md) var(--spacing-lg);
	background: rgba(255, 255, 255, 0.2);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-radius: var(--radius-md);
}

.footer-content p {
	font-size: var(--font-size-sm);
	color: var(--color-text);
}

.footer-content a {
	font-size: var(--font-size-sm);
	color: var(--color-link);
	text-decoration: none;
}

.footer-content a:hover {
	text-decoration: underline;
}

/* ============================================
   History / Article pages
   ============================================ */

.historie-article {
	max-width: 760px;
	margin: 0 auto var(--spacing-xl);
	background: var(--card-bg-solid);
	border-radius: var(--radius-lg);
	padding: var(--spacing-xl);
	box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.historie-article h2 {
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--spacing-sm);
}

.historie-article h3 {
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--color-text);
	margin: var(--spacing-lg) 0 var(--spacing-xs);
}

.historie-article p {
	line-height: 1.75;
	color: var(--color-text);
	margin-bottom: var(--spacing-md);
}

.historie-article section {
	margin-bottom: var(--spacing-lg);
}

.historie-figure {
	margin: var(--spacing-lg) 0;
	text-align: center;
}

.historie-figure img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-md);
	box-shadow: 0 4px 16px rgba(0,0,0,0.12);
}

.historie-figure figcaption {
	font-size: 0.85rem;
	color: var(--color-text-light);
	margin-top: var(--spacing-xs);
	font-style: italic;
}

.historie-nav {
	margin-top: var(--spacing-xl);
	padding-top: var(--spacing-md);
	border-top: 1px solid rgba(0,0,0,0.1);
}

.historie-nav a {
	color: var(--color-link);
	text-decoration: none;
	font-weight: 500;
}

.historie-nav a:hover {
	text-decoration: underline;
}

/* History index nav */
.historie-index-nav ul {
	list-style: none;
	padding: 0;
	margin: var(--spacing-lg) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
}

.historie-index-nav li a {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: var(--spacing-md) var(--spacing-lg);
	background: #f9fafb;
	border: 1px solid rgba(0,0,0,0.1);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s;
}

.historie-index-nav li a:hover {
	background: #eff6ff;
	border-color: var(--color-accent);
}

.historie-index-nav li a strong {
	color: var(--color-text);
	font-size: 1rem;
}

.historie-index-nav li a span {
	color: var(--color-text-light);
	font-size: 0.88rem;
	line-height: 1.5;
}



/* ============================================
   Responsive Design
   ============================================ */

/* Tablet */
@media (max-width: 1024px) {
	:root {
		--spacing-lg: 1.25rem;
		--spacing-xl: 1.5rem;
	}
	
	.weather-grid {
		gap: var(--spacing-md);
	}
	
	.card-header {
		grid-template-columns: 1fr 1fr;
		gap: var(--spacing-sm);
	}
	
	.card-header h2 {
		font-size: var(--font-size-xs);
	}
	
	.card-summary .value {
		font-size: var(--font-size-lg);
	}
}

/* Tablet Portrait */
@media (max-width: 768px) {
	nav {
		flex-direction: column;
		gap: var(--spacing-sm);
		padding: var(--spacing-sm) var(--spacing-md);
	}
	
	#languages, #locations {
		flex-wrap: wrap;
		justify-content: center;
	}
	
	header h1 {
		font-size: 1.5rem;
	}
	
	.action-buttons {
		flex-direction: column;
		align-items: center;
	}
	
	.btn {
		width: 100%;
		max-width: 300px;
		text-align: center;
	}
	
	.weather-grid {
		grid-template-columns: 1fr;
	}
	
	.banner-row {
		grid-template-columns: 1fr;
	}
	
	.card-body {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}
	
	.card-header {
		grid-template-columns: 1fr 1fr;
	}
	
	.card-header.single {
		grid-template-columns: 1fr auto;
	}
}

/* Mobile */
@media (max-width: 480px) {
	:root {
		--spacing-md: 0.75rem;
		--spacing-lg: 1rem;
	}
	
	main {
		padding: 0 var(--spacing-md) var(--spacing-xl);
	}
	
	.weather-card {
		border-radius: var(--radius-md);
	}
	
	.card-header {
		padding: var(--spacing-sm) var(--spacing-md);
	}
	
	.card-body {
		padding: var(--spacing-md);
	}
	
	.data-row {
		font-size: var(--font-size-xs);
	}
	
	.footer-content {
		flex-direction: column;
		gap: var(--spacing-sm);
	}
}

/* ============================================
   Screen Pages (Standalone Dashboard Displays)
   ============================================ */

/* Override body background for screen pages */
.screen-body {
	background: #f4f6f8;
	min-height: 100vh;
}

/* Top Nav Bar */
.screen-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: var(--color-primary);
	color: var(--color-white);
	padding: 0.4rem 1rem;
	gap: 1rem;
	position: sticky;
	top: 0;
	z-index: 100;
}

/* Screen Dropdown */
.screen-dropdown-wrap {
	position: relative;
}

.screen-dropdown-btn {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	background: transparent;
	border: 1px solid rgba(255,255,255,0.3);
	color: var(--color-white);
	font-size: var(--font-size-sm);
	font-family: var(--font-family);
	font-weight: 500;
	padding: 0.35rem 0.75rem;
	border-radius: var(--radius-sm);
	cursor: pointer;
	white-space: nowrap;
	transition: background 0.15s;
}

.screen-dropdown-btn:hover,
.screen-dropdown-btn[aria-expanded="true"] {
	background: rgba(255,255,255,0.15);
}

.screen-dropdown-menu {
	display: none;
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	min-width: 270px;
	background: var(--color-white);
	border: 1px solid rgba(0,0,0,0.1);
	border-radius: var(--radius-md);
	box-shadow: 0 4px 16px rgba(0,0,0,0.12);
	list-style: none;
	padding: 0.3rem 0;
	z-index: 200;
	margin: 0;
}

.screen-dropdown-menu.open {
	display: block;
}

.screen-dropdown-menu li a {
	display: block;
	padding: 0.55rem 1rem;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	text-decoration: none;
	font-weight: 400;
	transition: background 0.1s;
}

.screen-dropdown-menu li a:hover {
	background: #f0f5ff;
	color: var(--color-primary);
}

.screen-dropdown-menu li a.active {
	font-weight: 600;
	color: var(--color-primary);
}

.screen-nav-size {
	flex-shrink: 0;
}

.size-toggle-link {
	font-size: var(--font-size-xs);
	color: rgba(255,255,255,0.8);
	text-decoration: none;
	border: 1px solid rgba(255,255,255,0.3);
	padding: 0.2rem 0.6rem;
	border-radius: var(--radius-sm);
	transition: background 0.1s;
}

.size-toggle-link:hover {
	background: rgba(255,255,255,0.15);
	color: var(--color-white);
}

/* Screen Wrapper */
.screen-wrap {
	max-width: 960px;
	margin: 0 auto;
	padding: 0.5rem 0.75rem 1rem;
}

.screen-wrap .image-banner {
	overflow: hidden;
}

.screen-wrap .image-banner img {
	width: 100%;
	height: auto;
	margin-bottom: 0.75rem;
}

/* Port Banner */
.screen-banner {
	background: var(--color-primary);
	color: var(--color-white);
	text-align: center;
	padding: 0.5rem 1rem;
	border-radius: var(--radius-sm);
	margin-bottom: 0.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	font-size: 1.1rem;
}

.screen-banner strong {
	font-weight: 700;
	letter-spacing: 0.04em;
}

.screen-banner span {
	font-weight: 300;
	opacity: 0.85;
	font-size: 0.9em;
}

/* Data Grid */
.dash-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 4px;
	margin-bottom: 4px;
}

.dash-cell {
	background: var(--color-white);
	border: 1px solid rgba(0,0,0,0.07);
	border-radius: var(--radius-sm);
	padding: 0.4rem 0.5rem 0.5rem;
	text-align: center;
	min-width: 0;
}

.cell-label {
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-primary);
	margin-bottom: 2px;
	line-height: 1.3;
}

.cell-body {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 0.2rem;
}

.cell-value {
	font-size: 1.7rem;
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.1;
}

.cell-unit {
	font-size: 0.75rem;
	color: var(--color-text-light);
	font-weight: 400;
	line-height: 1.2;
}

.cell-small {
	font-size: 0.78rem;
	color: var(--color-text);
	line-height: 1.5;
	text-align: center;
}

.cell-small a {
	color: var(--color-link);
	text-decoration: none;
}

.cell-small a:hover {
	text-decoration: underline;
}

/* Section Header Bar */
.dash-section-header {
	background: var(--color-primary-dark);
	color: var(--color-white);
	font-size: 0.72rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 0.3rem 0.6rem;
	border-radius: var(--radius-sm);
	margin: 6px 0 4px;
}

/* Taller cells for tidal/links content */
.dash-cell-tidevand,
.dash-cell-links {
	min-height: 70px;
	display: flex;
	flex-direction: column;
}

.dash-cell-tidevand .cell-body,
.dash-cell-links .cell-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;
	text-align: left;
	padding-top: 4px;
}

/* Screen Footer */
.screen-footer {
	text-align: center;
	font-size: 0.72rem;
	color: var(--color-text-muted);
	padding: 0.5rem 0 0.75rem;
	max-width: 960px;
	margin: 0 auto;
}

/* Large mode — ?size=large adds this class to <body> */
.screen-body.large .cell-value {
	font-size: 2.5rem;
}

.screen-body.large .cell-label {
	font-size: 0.8rem;
}

.screen-body.large .cell-unit {
	font-size: 0.9rem;
}

.screen-body.large .screen-banner {
	font-size: 1.4rem;
	padding: 0.75rem 1rem;
}

.screen-body.large .dash-cell {
	padding: 0.6rem 0.5rem 0.7rem;
}

/* Responsive */
@media (max-width: 768px) {
	.dash-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.dash-grid {
		grid-template-columns: 1fr 1fr;
		gap: 3px;
	}
	.cell-value {
		font-size: 1.4rem;
	}
}

/* ============================================
   DMI Chart Grid (vandstand / vandstand-flow screens)
   ============================================ */
.dmi-charts {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4px;
	margin-bottom: 4px;
}
.dmi-chart-item .cell-label {
	background: var(--color-primary-dark);
	color: var(--color-white);
	padding: 4px 8px;
	font-size: var(--font-size-xs);
	font-weight: 500;
	margin: 0;
}
.dmi-charts img {
	width: 100%;
	height: auto;
	display: block;
	background: #f5f5f5;
}
@media (max-width: 600px) {
	.dmi-charts {
		grid-template-columns: 1fr;
	}
}

/* ============================================
   Site Nav – Screens Dropdown
   ============================================ */
.site-screens-dropdown {
	position: relative;
	display: inline-block;
}
.site-screens-dropdown-btn {
	background: none;
	border: none;
	color: inherit;
	font: inherit;
	cursor: pointer;
	padding: 0;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	text-decoration: none;
}
.site-screens-dropdown-btn svg {
	flex-shrink: 0;
}
.site-screens-dropdown-menu {
	display: none;
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	left: auto;
	background: var(--card-bg-solid, #fff);
	border: 1px solid rgba(0,0,0,.1);
	border-radius: var(--radius-sm, 4px);
	box-shadow: 0 4px 16px rgba(0,0,0,.12);
	list-style: none;
	margin: 0;
	padding: 4px 0;
	min-width: 220px;
	z-index: 200;
	white-space: nowrap;
}
.site-screens-dropdown-menu.open {
	display: block;
}
.site-screens-dropdown-menu li {
	margin: 0;
}
.site-screens-dropdown-menu a {
	display: block;
	padding: 8px 14px;
	color: var(--color-text, #333);
	text-decoration: none;
	font-size: .875rem;
}
.site-screens-dropdown-menu a:hover {
	background: var(--color-primary, #0057a6);
	color: #fff;
}

/* ============================================
   Utility Classes
   ============================================ */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Animation for data updates */
@keyframes pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.7; }
}

.updating {
	animation: pulse 1s ease-in-out infinite;
}
