body {
    margin: 0 auto;
	font-family: system-ui, sans-serif;
	background: var(--color-bg-primary);
	color: var(--color-text-primary);
	display: flex;
    flex-direction: column;
	justify-content: center;
	align-items: center;
	height: auto;
	min-height: 100vh;
	line-height: 1.6;
}

:root {
    --color-bg-primary: #0f172a;
    --color-text-primary: white;
    --color-bg-card: #1e293b;
    --color-bg-suggestions: #1e293b;
    --color-dot-default: #64748b;
    --color-dot-good: #22c55e;
    --color-dot-ok: #f59e0b;
    --color-dot-bad: #ef4444;
    --color-text-ideal: #94a3b8;
    --color-bg-forecast-good: #145e32;
    --color-text-forecast-good: white;
    --color-bg-forecast-ok: #b95c24;
    --color-text-forecast-ok: white;
    --color-bg-forecast-bad: #982525;
    --color-text-forecast-bad: white;
    --color-bg-suggestion-hover: #334155;
}

.app {
	width: auto;
	max-width: 1000px;
	gap: 1.5rem;
	display: flex;
	flex-direction: column;
	padding-bottom: 2rem;
    padding-left: 1rem;
    padding-right: 1rem;
    @media (max-width: 480px) {
       max-width: 480px;
    }
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

h1 {
    font-size: 1.7rem;
	text-align: center;
	margin-bottom: 0.5rem;
}

h2 {
    font-size: 1.3rem;
	margin-top: 0;
	margin-bottom: 1rem;
    @media (max-width: 480px) {
        font-size: 1.1rem;
    }
}

.location {
	display: flex;
	gap: 0.5rem;
	align-items: center;
}

input {
	flex: 1;
	min-width: 0;
	border-radius: 6px;
	border: none;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 0.7rem;
    padding-bottom: 0.7rem;
    display: inline-block;
    font-size: 1.1rem;
    @media (max-width: 480px) {
        padding-left: 0.8rem;
        padding-right: 0.8rem;
    }
}

button.btn {
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 0.7rem;
    padding-bottom: 0.7rem;
    font-size: 1.1rem;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	&.btn-primary {
		background-color: green;
		color: white;
        &:hover {
            background-color: #166534;
        }
	}
}

.card {
	background: var(--color-bg-card);
	padding: 2rem;
	border-radius: 12px;
    @media (max-width: 480px) {
        padding: 1.5rem;
    }
}

.conditions {
    display: grid;
    gap: 0.8rem;
	margin-top: 1rem;
	font-size: 0.8rem;
    @media (max-width: 480px) {
        gap: 0.5rem;
    }
    > div {
        display: flex;
        align-items: center;
        gap: 0.5rem;
    }

    .ideal {
        color: var(--color-text-ideal);
        font-size: 0.8rem;
        margin-left: auto;
    }
}

.dot {
	width: 0.8rem;
	height: 0.8rem;
	border-radius: 50%;
	display: inline-block;
    margin-right: 0.5rem;
	background: var(--color-dot-default);

    &.good {
        background: var(--color-dot-good);
    }
    &.ok {
        background: var(--color-dot-ok);
    }
    &.bad {
        background: var(--color-dot-bad);
    }
}

.result {
	margin-bottom: 2rem;
	text-align: center;
	h2 {
		outline: solid 1px white;
		line-height: 1;
		border-radius: 10px;
		display: inline-block;
		padding-left: 1.5rem;
		padding-right: 1.5rem;
		padding-top: 0.7rem;
		padding-bottom: 0.7rem;
		margin-bottom: 0;
	}
}

.forecastRow {
	display: flex;
	justify-content: space-between;
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    font-size: 0.9rem;
    .forecastScore {
        padding: 0.2rem 0.5rem;
        border-radius: 6px;
    }

    .forecast-good {
        background: var(--color-bg-forecast-good);
        color: var(--color-text-forecast-good);
        span {
            color: inherit;
        }
    }

    .forecast-ok {
        background: var(--color-bg-forecast-ok);
        color: var(--color-text-forecast-ok);
        span {
            color: inherit;
        }
    }

    .forecast-bad {
        background: var(--color-bg-forecast-bad);
        color: var(--color-text-forecast-bad);
        span {
            color: inherit;
        }
    }

    .forecastDay {
        text-transform: capitalize;
    }

    .forecastScore {
        font-weight: bold;
    }
}

.search-wrapper {
    display: flex;
	position: relative;
	width: auto;
    input {
        flex: 1;
        min-width: 0;
        width: 100%;
    }
}

.suggestions {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--color-bg-suggestions);
	border-radius: 6px;
	margin-top: 4px;
	z-index: 10;
	overflow: hidden;
    &.visible {
        outline: solid 1px rgba(255, 255, 255, 0.2);
    }

    .suggestion {
        padding: 8px 10px;
        cursor: pointer;
        &:hover {
            background: var(--color-bg-suggestion-hover);
        }
    }

}

.forecast {
    align-self: stretch;
    h2 {
        margin-bottom: 1.5rem;
    }
}

.forecastList {
    display: grid;
    gap: 0.7rem;
}

.cards-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    width: 100%;
    
    @media (min-width: 768px) {
        flex-direction: row;
        align-items: flex-start;
    }
    .card {
        flex: 1;
        min-width: 0;
        &.forecast {
            @media (min-width: 768px) {
                min-width: 280px;
            }
        }
    }
}

footer {
    margin-top: auto;
    padding: 1rem;
    text-align: center;
    color: var(--color-text-ideal);
    font-size: 0.9rem;
    a {
        color: var(--color-text-ideal);
        text-decoration: none;
        &:hover {
            text-decoration: underline;
        }
    }
}
