/**
 * Forecast by Soren public styles.
 *
 * All selectors stay scoped to shortcode root classes so client sites can safely
 * override variables without the plugin leaking styles into the page builder.
 */

.forecast-bar,
.forecast-widget {
	--forecast-color-background: #f3ebe0;
	--forecast-color-background-dark: #3c5149;
	--forecast-color-text: #362616;
	--forecast-color-text-dark: #f3ebe0;
	--forecast-color-accent: #b55f28;
	--forecast-font-heading: "Playfair Display", Georgia, serif;
	--forecast-font-size-heading: 3rem;
	--forecast-font-body: Montserrat, Arial, sans-serif;
	--forecast-font-size-body: 1.1rem;
	--forecast-font-label: Manrope, Montserrat, Arial, sans-serif;
	--forecast-font-size-label: 0.78rem;
	--forecast-bar-font-size: 0.95rem;
	--forecast-bar-icon-size: 1.55rem;
	--forecast-space-xs: 0.35rem;
	--forecast-space-sm: 0.65rem;
	--forecast-space-md: 1rem;
	--forecast-space-lg: 1.5rem;
	--forecast-space-xl: 2.25rem;
	--forecast-icon-size-current: clamp(7rem, 18vw, 11rem);
	--forecast-icon-size-day: 3.35rem;
	--forecast-radius: 8px;
	--forecast-border-color: rgba(54, 38, 22, 0.16);
	box-sizing: border-box;
	color: var(--forecast-color-text);
	font-family: var(--forecast-font-body);
}

.forecast-bar *,
.forecast-bar *::before,
.forecast-bar *::after,
.forecast-widget *,
.forecast-widget *::before,
.forecast-widget *::after {
	box-sizing: inherit;
}

.forecast-bar {
	--forecast-bar-background: transparent;
	--forecast-bar-icon-color: var(--forecast-color-accent);
	--forecast-bar-text-color: var(--forecast-color-text);
	--forecast-bar-font: var(--forecast-font-body);
	align-items: center;
	background: var(--forecast-bar-background);
	color: var(--forecast-bar-text-color);
	display: inline-flex;
	font-family: var(--forecast-bar-font);
	font-size: var(--forecast-bar-font-size);
	font-weight: 600;
	gap: 0.35rem;
	line-height: 1;
	min-height: 1.75rem;
	text-decoration: none;
	vertical-align: middle;
	white-space: nowrap;
}

.forecast-bar:hover,
.forecast-bar:focus {
	color: var(--forecast-bar-text-color);
	text-decoration: none;
}

.forecast-bar:focus-visible {
	outline: 2px solid var(--forecast-color-accent);
	outline-offset: 3px;
}

.forecast-bar__icon {
	color: var(--forecast-bar-icon-color);
	display: inline-flex;
	flex: 0 0 auto;
	height: var(--forecast-bar-icon-size);
	width: var(--forecast-bar-icon-size);
}

.forecast-bar__icon svg,
.forecast-icon {
	display: block;
	height: 100%;
	overflow: visible;
	width: 100%;
}

.forecast-bar__temp,
.forecast-bar__text {
	color: currentColor;
	display: inline-block;
}

.forecast-bar--unavailable {
	font-size: 0.85rem;
}

.forecast-widget {
	background: var(--forecast-color-background);
	border: 0;
	border-radius: 0;
	color: var(--forecast-color-text);
	padding: clamp(1.5rem, 4vw, 3rem);
	width: 100%;
}

.forecast-widget--dark {
	background: var(--forecast-color-background-dark);
	color: var(--forecast-color-text-dark);
}

.forecast-widget__header {
	margin: 0 0 var(--forecast-space-xl);
}

.forecast-widget__eyebrow {
	color: var(--forecast-color-accent);
	font-family: var(--forecast-font-label);
	font-size: var(--forecast-font-size-label);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.2;
	margin: 0 0 var(--forecast-space-xs);
	text-transform: uppercase;
}

.forecast-widget__title {
	color: inherit;
	font-family: var(--forecast-font-heading);
	font-size: var(--forecast-font-size-heading);
	font-weight: 700;
	line-height: 1.05;
	margin: 0;
}

.forecast-widget__current {
	align-items: center;
	display: grid;
	gap: clamp(1.25rem, 4vw, 3rem);
	grid-template-columns: minmax(0, 1fr) var(--forecast-icon-size-current);
	margin-bottom: var(--forecast-space-xl);
}

.forecast-widget__current-icon {
	align-items: center;
	aspect-ratio: 1;
	background: transparent;
	border: 0;
	color: var(--forecast-color-accent);
	display: flex;
	justify-content: center;
	min-width: 0;
	order: 2;
	padding: 0;
}

.forecast-widget__current-icon img,
.forecast-widget__day-icon img {
	display: block;
	height: auto;
	max-width: 100%;
}

.forecast-widget__current-icon svg,
.forecast-widget__day-icon svg {
	color: var(--forecast-color-accent);
	height: 100%;
	stroke: currentColor;
	width: 100%;
}

.forecast-widget__current-copy {
	min-width: 0;
	order: 1;
}

.forecast-widget__current-temp {
	color: inherit;
	font-family: var(--forecast-font-body);
	font-size: clamp(4rem, 10vw, 6.75rem);
	font-weight: 700;
	line-height: 0.95;
	margin: 0;
}

.forecast-widget__current-desc {
	color: inherit;
	font-size: var(--forecast-font-size-body);
	font-weight: 600;
	line-height: 1.35;
	margin: var(--forecast-space-sm) 0 0;
}

.forecast-widget__wind {
	color: inherit;
	font-size: 0.95rem;
	line-height: 1.4;
	margin: var(--forecast-space-sm) 0 0;
	opacity: 0.86;
}

.forecast-widget__wind span {
	color: var(--forecast-color-accent);
	font-family: var(--forecast-font-label);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0;
	margin-right: 0.35rem;
	text-transform: uppercase;
}

.forecast-widget__daily {
	border-top: 1px solid var(--forecast-border-color);
	display: grid;
	gap: clamp(0.75rem, 1.8vw, 1.25rem);
	grid-template-columns: repeat(7, minmax(0, 1fr));
	padding-top: var(--forecast-space-lg);
}

.forecast-widget--dark .forecast-widget__daily {
	border-top-color: rgba(243, 235, 224, 0.2);
}

.forecast-widget__day {
	background: transparent;
	border: 0;
	border-radius: 0;
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
	margin: 0;
	min-width: 0;
	padding: 0;
}

.forecast-widget__day-name {
	color: inherit;
	font-family: var(--forecast-font-label);
	font-size: var(--forecast-font-size-label);
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.2;
	margin: 0;
	text-transform: uppercase;
}

.forecast-widget__day-icon {
	align-items: center;
	color: var(--forecast-color-accent);
	display: flex;
	height: var(--forecast-icon-size-day);
	justify-content: flex-start;
	width: var(--forecast-icon-size-day);
}

.forecast-weather-icon {
	color: var(--forecast-color-accent);
	display: inline-flex;
	height: 100%;
	width: 100%;
}

.forecast-widget__temps {
	color: inherit;
	display: flex;
	flex-wrap: wrap;
	font-size: 0.9rem;
	gap: 0.25rem 0.5rem;
	line-height: 1.35;
	margin: 0;
}

.forecast-widget__temps strong {
	color: var(--forecast-color-accent);
	font-family: var(--forecast-font-label);
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
}

.forecast-widget__day-desc {
	color: inherit;
	font-size: var(--forecast-font-size-body);
	line-height: 1.35;
	margin: 0;
	opacity: 0.88;
}

.forecast-widget__unavailable {
	font-family: var(--forecast-font-body);
	font-weight: 600;
	margin: 0;
}

@media (max-width: 900px) {
	.forecast-widget__daily {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.forecast-widget__current {
		align-items: flex-start;
		grid-template-columns: minmax(0, 1fr) clamp(5rem, 28vw, 7rem);
	}

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

@media (max-width: 420px) {
	.forecast-widget__daily {
		grid-template-columns: 1fr;
	}
}
