:root {
    --color-body-bg: #f0f0f0;
    --color-text: #2c3e50;
    --color-header-footer-bg: #2c3e50;
    --color-nav-bg: #34495e;
    --color-nav-button-bg: #2c3e50;
    --color-nav-button-active-bg: #3498db;
    --color-nav-button-text: #ffffff;
    --color-card-bg: #ffffff;
    --color-card-shadow: rgba(0, 0, 0, 0.1);
    --color-link: #3498db;
    --color-link-hover: #2980b9;
    --color-weather-item-bg: #ecf0f1;
    --color-heading: #2c3e50;
    --color-weather-value: #3498db;
    --color-table-border: #ddd;
    --color-table-header-bg: #34495e;
    --color-table-odd-row: #ffffff;
    --color-table-even-row: #f8f9fa;
    --color-table-row-hover: #dcdcdc;
    --color-theme-control-bg: #ffffff;
    --color-theme-control-text: #2c3e50;
    --color-theme-control-border: #aeb6bf;
    --hc-text-color: #2c3e50;
    --hc-muted-text-color: #5f6f7f;
    --hc-grid-color: #d7e0e8;
    --hc-tooltip-bg: rgba(255, 255, 255, 0.96);
    --hc-tooltip-text: #2c3e50;
}

html[data-theme='dark'] {
    --color-body-bg: #1b2228;
    --color-text: #dbe6ee;
    --color-header-footer-bg: #10161b;
    --color-nav-bg: #1f2b35;
    --color-nav-button-bg: #2a3a46;
    --color-nav-button-active-bg: #3f8fc3;
    --color-nav-button-text: #eef3f7;
    --color-card-bg: #222d36;
    --color-card-shadow: rgba(0, 0, 0, 0.35);
    --color-link: #73b6df;
    --color-link-hover: #98ccec;
    --color-weather-item-bg: #2a3742;
    --color-heading: #dce8f1;
    --color-weather-value: #73b6df;
    --color-table-border: #41515f;
    --color-table-header-bg: #25323d;
    --color-table-odd-row: #222d36;
    --color-table-even-row: #26343f;
    --color-table-row-hover: #31424f;
    --color-theme-control-bg: #25323d;
    --color-theme-control-text: #eef3f7;
    --color-theme-control-border: #4c5f6f;
    --hc-text-color: #dbe6ee;
    --hc-muted-text-color: #afbfcc;
    --hc-grid-color: #41515f;
    --hc-tooltip-bg: rgba(18, 25, 32, 0.95);
    --hc-tooltip-text: #eef3f7;
}

html[data-theme='winter'] {
    --color-body-bg: #edf4fb;
    --color-header-footer-bg: #2e4f72;
    --color-nav-bg: #3f6995;
    --color-nav-button-bg: #4f7fae;
    --color-nav-button-active-bg: #6cb0eb;
    --color-nav-button-text: #ffffff;
    --color-card-bg: #ffffff;
    --color-card-shadow: rgba(33, 64, 94, 0.14);
    --color-link: #2d78b5;
    --color-link-hover: #1f5f90;
    --color-weather-item-bg: #e0ebf7;
    --color-heading: #244865;
    --color-weather-value: #2d78b5;
    --color-table-border: #b4c9de;
    --color-table-header-bg: #3f6995;
    --color-table-odd-row: #ffffff;
    --color-table-even-row: #eef4f9;
    --color-table-row-hover: #dde8f2;
    --color-theme-control-bg: #f7fbff;
    --color-theme-control-text: #244865;
    --color-theme-control-border: #8faecc;
    --hc-text-color: #244865;
    --hc-muted-text-color: #557b9d;
    --hc-grid-color: #b4c9de;
    --hc-tooltip-bg: rgba(247, 251, 255, 0.96);
    --hc-tooltip-text: #2f4b63;
}

html[data-theme='lente'] {
    --color-body-bg: #eef8ea;
    --color-header-footer-bg: #2f6a36;
    --color-nav-bg: #3f8a46;
    --color-nav-button-bg: #52a45a;
    --color-nav-button-active-bg: #7dcd57;
    --color-nav-button-text: #ffffff;
    --color-card-bg: #ffffff;
    --color-card-shadow: rgba(50, 90, 54, 0.14);
    --color-link: #31873a;
    --color-link-hover: #23652b;
    --color-weather-item-bg: #dff0d2;
    --color-heading: #245e2c;
    --color-weather-value: #31873a;
    --color-table-border: #b8d3ad;
    --color-table-header-bg: #3f8a46;
    --color-table-odd-row: #ffffff;
    --color-table-even-row: #edf6e7;
    --color-table-row-hover: #dcead2;
    --color-theme-control-bg: #f8fcf4;
    --color-theme-control-text: #245e2c;
    --color-theme-control-border: #90bb84;
    --hc-text-color: #245e2c;
    --hc-muted-text-color: #4b8351;
    --hc-grid-color: #b8d3ad;
    --hc-tooltip-bg: rgba(248, 252, 244, 0.96);
    --hc-tooltip-text: #345e38;
}

html[data-theme='zomer'] {
    --color-body-bg: #fff4e7;
    --color-header-footer-bg: #c65310;
    --color-nav-bg: #de721f;
    --color-nav-button-bg: #ea8a35;
    --color-nav-button-active-bg: #f7b84a;
    --color-nav-button-text: #fffdf8;
    --color-card-bg: #ffffff;
    --color-card-shadow: rgba(148, 88, 35, 0.16);
    --color-link: #c85a11;
    --color-link-hover: #9b430c;
    --color-weather-item-bg: #ffe4c2;
    --color-heading: #8a3d0b;
    --color-weather-value: #c85a11;
    --color-table-border: #dbbc96;
    --color-table-header-bg: #de721f;
    --color-table-odd-row: #ffffff;
    --color-table-even-row: #fff2e2;
    --color-table-row-hover: #ffe6cc;
    --color-theme-control-bg: #fffaf3;
    --color-theme-control-text: #8a3d0b;
    --color-theme-control-border: #d09d6e;
    --hc-text-color: #8a3d0b;
    --hc-muted-text-color: #aa6f3f;
    --hc-grid-color: #dbbc96;
    --hc-tooltip-bg: rgba(255, 250, 243, 0.96);
    --hc-tooltip-text: #8c4a1c;
}

html[data-theme='herfst'] {
    --color-body-bg: #f6efe6;
    --color-header-footer-bg: #6f321f;
    --color-nav-bg: #8a452b;
    --color-nav-button-bg: #a15534;
    --color-nav-button-active-bg: #c7793f;
    --color-nav-button-text: #fff6ef;
    --color-card-bg: #fffdf9;
    --color-card-shadow: rgba(90, 54, 36, 0.16);
    --color-link: #94441b;
    --color-link-hover: #6d2f12;
    --color-weather-item-bg: #efdcc7;
    --color-heading: #5d2617;
    --color-weather-value: #94441b;
    --color-table-border: #d1b69d;
    --color-table-header-bg: #8a452b;
    --color-table-odd-row: #fffdf9;
    --color-table-even-row: #faefe5;
    --color-table-row-hover: #f1dfcf;
    --color-theme-control-bg: #fffbf6;
    --color-theme-control-text: #5d2617;
    --color-theme-control-border: #b69275;
    --hc-text-color: #5d2617;
    --hc-muted-text-color: #8f6048;
    --hc-grid-color: #d1b69d;
    --hc-tooltip-bg: rgba(255, 251, 246, 0.96);
    --hc-tooltip-text: #5f3724;
}

body {
    font-family: Arial, Helvetica, sans-serif;
    margin: 0;
    padding: 0;
    background-color: var(--color-body-bg);
    color: var(--color-text);
}

header,footer {
    background-color: var(--color-header-footer-bg);
    color: var(--color-nav-button-text);
    padding: 20px;
    text-align: center;
}

.navigation {
    background-color: var(--color-nav-bg);
    padding: 15px;
    text-align: center;
    box-shadow: 0 2px 4px var(--color-card-shadow);
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
}

.nav-button {
    display: inline-block;
    background-color: var(--color-nav-button-bg);
    color: var(--color-nav-button-text);
    padding: 10px 20px;
    margin: 0 10px;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    transition: background-color 0.3s;
}

.nav-button:visited {
    color: var(--color-nav-button-text);
}

.nav-button:hover {
    background-color: var(--color-nav-button-bg);
}

.nav-button.active {
    background-color: var(--color-nav-button-active-bg);
}

@media (max-width: 768px) {
    .navigation {
        padding: 15px 10px;
        text-align: center;
        white-space: normal;
    }

    .nav-button {
        margin: 5px 10px;
    }

}

main {
    max-width: 1200px;
    margin: 20px auto;
    padding: 20px;
}

@media (max-width: 768px) {
    main {
        margin: 0;
        padding: 0;
    }
}

.card {
    background: var(--color-card-bg);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 20px;
    box-shadow: 0 2px 4px var(--color-card-shadow);
}

@media (max-width: 768px) {
    .card {
        border-radius: 0;
        margin-left: 0;
        margin-right: 0;
    }
}

a {
    color: var(--color-link);
    text-decoration: none;
    transition: color 0.3s;
}

a:visited {
    color: var(--color-link);
}

a:hover {
    color: var(--color-link-hover);
    text-decoration: underline;
}

.weather-item {
    background: var(--color-weather-item-bg);
    padding: 15px;
    border-radius: 5px;
}

.weather-item h3 {
    margin: 0 0 10px 0;
    color: var(--color-heading);
    font-size: 14px;
}

.weather-item .weather-value i {
    font-size: x-large;
    color: var(--color-heading);
}

.weather-value {
    font-size: 24px;
    font-weight: bold;
    color: var(--color-weather-value);
}


.grid-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
    margin-top: 20px;
}

.grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-top: 20px;
}

.grid-4 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
    margin-top: 20px;
}

.highcharts-height {
    height: 300px;
}

@media (max-width: 768px) {

    .highcharts-height {
        height: 240px;
    }

    .grid-2,
    .grid-3,
    .grid-4 {
        grid-template-columns: 1fr;
    }
}

img {
    max-width: 100%;
    display: block;
    margin: 0 auto;
    border-radius: 5px;
}

.table-responsive {
    overflow-x: auto;
    border-radius: 5px;
}

table {
    width: 100%;
    border-collapse: collapse;
    min-width: 600px;
    background-color: var(--color-table-odd-row);
}

th,
td {
    padding: 12px 15px;
    text-align: left;
    border-bottom: 1px solid var(--color-table-border);
}

tr {
    background-color: var(--color-table-odd-row);
}

th {
    background-color: var(--color-table-header-bg);
    color: var(--color-nav-button-text);
    text-transform: uppercase;
    font-size: 14px;
    letter-spacing: 0.03em;
}

tr:nth-child(even) {
    background-color: var(--color-table-even-row);
}

tr:hover {
    background-color: var(--color-table-row-hover);
}

.pagination {
    text-align: center;
}

.pagination a {
    padding: 20px;
}

.footer-content {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}

.theme-selector {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
}

.theme-selector label {
    font-weight: bold;
}

.theme-selector select {
    background-color: var(--color-theme-control-bg);
    color: var(--color-theme-control-text);
    border: 1px solid var(--color-theme-control-border);
    border-radius: 4px;
    padding: 5px 8px;
    font-size: 14px;
}

.webcam-slider-wrap {
    margin-top: 15px;
}

.webcam-slider-wrap input[type="range"] {
    width: 100%;
}

.webcam-slider-wrap p {
    margin: 8px 0 0;
}

.media-switch {
    display: flex;
    gap: 10px;
    margin-bottom: 12px;
}

.media-switch-button {
    background-color: var(--color-nav-button-bg);
    color: var(--color-nav-button-text);
    border: none;
    border-radius: 5px;
    padding: 8px 14px;
    cursor: pointer;
}

.media-switch-button.active {
    background-color: var(--color-nav-button-active-bg);
}

.media-pane {
    display: none;
}

.media-pane.active {
    display: block;
}

.timelapse-video {
    width: 100%;
    border-radius: 5px;
}