html {
    scrollbar-gutter: stable;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

:root {
    --flp-max: 1180px;
    --flp-gutter: 16px;
}

.ui-modern {
    --flp-bg: #f4f1ea;
    --flp-card: #e6e0d6;
    --flp-surface-secondary: #ddd5c7;
    --flp-text: #1f1f1f;
    --flp-text-secondary: #4a4a4a;
    --flp-muted: #6f6a61;
    --flp-border: #cfc4b4;
    --flp-primary-action: #2f4f4f;
    --flp-primary-action-hover: #243c3c;
    --flp-secondary-action: #6b5e4a;
    --flp-secondary-action-hover: #5a4f3e;
    --flp-status-active: #4a6c6f;
    --flp-status-planned: #8a8174;
    --flp-status-followup: #c18f59;
    --flp-status-disabled: #7a7a7a;
    background: var(--flp-bg);
    color: var(--flp-text);
    font-family: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
    margin: 0;
}

.ui-modern a { color: inherit; }

.flp-inner {
    width: 100%;
    max-width: var(--flp-max);
    margin: 0 auto;
    padding-inline: var(--flp-gutter);
}

.ui-modern .flp-global-topbar {
    width: 100%;
    background: #ffffff;
    border-bottom: 1px solid #e6e2da;
}

.ui-modern .flp-global-topbar .flp-inner {
    padding-block: 10px;
}

.ui-modern .flp-brand {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    border: 1px solid #1f4b44;
    border-radius: 999px;
    overflow: hidden;
    background: #e7dfd2;
    line-height: 1;
}

.ui-modern .flp-brand__flp {
    background: #1f4b44;
    color: #fff;
    font-weight: 900;
    padding: 9px 14px;
    font-size: 18px;
    border-top-left-radius: 999px;
    border-bottom-left-radius: 999px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.ui-modern .flp-brand__name {
    color: #1f4b44;
    font-weight: 800;
    padding: 9px 14px 9px 12px;
    font-size: 14px;
    letter-spacing: .06em;
    white-space: nowrap;
}

.ui-modern .flp-brand:hover { filter: brightness(0.98); }

.ui-modern .flp-brand:hover,
.ui-modern .flp-brand:focus,
.ui-modern .flp-brand:active {
    text-decoration: none;
}

.ui-modern .flp-brand:focus {
    outline: 2px solid rgba(31, 75, 68, 0.25);
    outline-offset: 3px;
}

.ui-modern .flp-subbar {
    width: 100%;
    background: transparent;
}

.ui-modern .flp-subbar .flp-inner {
    padding-block-start: 10px;
    padding-block-end: 0;
}

.ui-modern .flp-subbar__grid {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 18px;
}

.ui-modern .flp-subbar__left {
    min-width: 124px;
}

.ui-modern .flp-subbar__nav {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.ui-modern .flp-subbar__right {
    display: flex;
    align-items: center;
    justify-self: end;
    gap: 10px;
}

.ui-modern .flp-user-meta-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.ui-modern .flp-school-name {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--flp-primary-action);
    line-height: 1.1;
}

.ui-modern .flp-back-button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 999px;
    border: 2px solid var(--flp-primary-action);
    background: transparent;
    color: var(--flp-primary-action);
    font-size: 0.9rem;
    font-weight: 700;
    cursor: pointer;
}

.ui-modern .flp-back-button:hover {
    background: var(--flp-primary-action);
    color: #fff;
}


.ui-modern .flp-nav-link,
.ui-modern .flp-button,
.ui-modern button,
.ui-modern input[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.95rem;
    background: transparent;
    border: 2px solid var(--flp-primary-action);
    color: var(--flp-primary-action);
    cursor: pointer;
}

.ui-modern .flp-nav-link:hover,
.ui-modern .flp-button:hover,
.ui-modern button:hover,
.ui-modern input[type="submit"]:hover {
    background: var(--flp-primary-action);
    color: #fff;
}

.ui-modern .flp-main {
    padding: 18px 0 72px;
}

.ui-modern .flp-main--auth .flp-inner {
    display: flex;
    justify-content: center;
    padding-block-start: 26px;
}

.ui-modern .flp-container,
.ui-modern .flp-vehicles { margin: 0; }

.ui-modern .flp-card,
.ui-modern .flp-main .flp-inner > form,
.ui-modern .flp-main .flp-inner > table,
.ui-modern .flp-main .flp-inner > ul,
.ui-modern .validation-errors,
.ui-modern .flash {
    background: var(--flp-card);
    border-radius: 20px;
    border: 1px solid var(--flp-border);
    box-shadow: 0 10px 24px rgba(31, 31, 31, 0.08);
    padding: 18px 20px;
    margin-bottom: 16px;
}

.ui-modern h1,
.ui-modern h2,
.ui-modern h3,
.ui-modern p { margin-top: 0; }
.ui-modern .flp-eyebrow { margin: 0 0 4px; font-size: .76rem; letter-spacing: .08em; text-transform: uppercase; color: var(--flp-muted); }
.ui-modern .flp-lead,
.ui-modern .flp-subtitle { color: var(--flp-text-secondary); }

.ui-modern .flp-page-header { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 16px; }
.ui-modern .flp-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.ui-modern .flp-routine-buttons { display: flex; gap: 10px; flex-wrap: wrap; margin: 10px 0 16px; }
.ui-modern .flp-routine-button-active {
    background: var(--flp-primary-action);
    color: #fff;
}
.ui-modern .flp-routine-config {
    background: var(--flp-card);
    border-radius: 20px;
    border: 1px solid var(--flp-border);
    box-shadow: 0 10px 24px rgba(31, 31, 31, 0.08);
    padding: 18px 20px;
    margin-bottom: 16px;
}
.ui-modern .flp-routine-config-layout {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr);
    gap: 20px;
    align-items: start;
}
.ui-modern .flp-routine-config-settings {
    display: grid;
    gap: 12px;
}
.ui-modern .routine-info {
    background: color-mix(in srgb, var(--flp-surface-secondary) 70%, white);
    border: 1px solid color-mix(in srgb, var(--flp-status-active) 35%, white);
    border-radius: 16px;
    padding: 16px 18px;
    box-shadow: 0 4px 14px rgba(31, 31, 31, 0.06);
    line-height: 1.5;
}
.ui-modern .routine-info h3 {
    margin: 0 0 12px;
}
.ui-modern .routine-info p {
    margin: 0 0 10px;
}
.ui-modern .routine-info ul {
    margin: 0 0 10px 18px;
    padding: 0;
}
@media (max-width: 820px) {
    .ui-modern .flp-routine-config-layout {
        grid-template-columns: 1fr;
    }
}
.ui-modern .flp-button--primary { background: var(--flp-primary-action); color: #fff; }
.ui-modern .flp-button--primary:hover { background: var(--flp-primary-action-hover); }
.ui-modern .flp-button--ghost { border-color: var(--flp-secondary-action); color: var(--flp-secondary-action); }
.ui-modern .flp-button--ghost:hover { background: var(--flp-secondary-action); color: #fff; }
.ui-modern .flp-button--compact {
    padding: 8px 14px;
    font-size: 0.88rem;
}

.ui-modern .flp-badge { display: inline-flex; padding: 4px 10px; border-radius: 999px; background: var(--flp-surface-secondary); border: 1px solid var(--flp-border); font-size: .82rem; }
.ui-modern .flp-status-aktiv { background: color-mix(in srgb, var(--flp-status-active) 16%, white); border-color: color-mix(in srgb, var(--flp-status-active) 36%, white); color: var(--flp-status-active); }
.ui-modern .flp-status-midlertidig_ute,
.ui-modern .flp-status-ute_av_drift { background: color-mix(in srgb, var(--flp-status-followup) 18%, white); border-color: color-mix(in srgb, var(--flp-status-followup) 38%, white); color: var(--flp-status-followup); }


.ui-modern .flp-chip-toggle-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ui-modern .flp-chip-toggle {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.ui-modern .flp-chip-toggle input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.ui-modern .flp-chip-toggle span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 52px;
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, #7f8c99 70%, white);
    background: color-mix(in srgb, #d7dfe7 65%, white);
    color: #2f3b47;
    font-weight: 700;
    cursor: pointer;
    user-select: none;
}

.ui-modern .flp-chip-toggle input:checked + span,
.ui-modern .flp-chip-toggle.is-checked span {
    border-color: color-mix(in srgb, #2e7d32 68%, white);
    background: color-mix(in srgb, #2e7d32 34%, white);
    color: #0f4d17;
}

.ui-modern .flp-chip-toggle input:focus-visible + span {
    outline: 2px solid color-mix(in srgb, #2e7d32 48%, white);
    outline-offset: 2px;
}

.ui-modern .flp-chip-toggle--readonly span {
    cursor: default;
}

.ui-modern .flp-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.ui-modern .flp-muted-text {
    color: var(--flp-muted);
    font-size: 0.9rem;
}

.ui-modern .flp-badge--class {
    background: color-mix(in srgb, var(--flp-primary-action) 18%, white);
    border-color: color-mix(in srgb, var(--flp-primary-action) 40%, white);
    color: var(--flp-primary-action);
    font-weight: 700;
}

.ui-modern .flp-badge--success {
    background: color-mix(in srgb, #2e7d32 20%, white);
    border-color: color-mix(in srgb, #2e7d32 38%, white);
    color: #1b5e20;
    font-weight: 700;
}

.ui-modern .flp-badge--warning {
    background: color-mix(in srgb, #d59a00 24%, white);
    border-color: color-mix(in srgb, #d59a00 40%, white);
    color: #7a5500;
    font-weight: 700;
}

.ui-modern .flp-badge--neutral {
    background: color-mix(in srgb, var(--flp-muted) 20%, white);
    border-color: color-mix(in srgb, var(--flp-muted) 34%, white);
    color: var(--flp-text-secondary);
}

.ui-modern .flp-table--teachers td,
.ui-modern .flp-table--teachers th {
    vertical-align: middle;
}

.ui-modern table,
.ui-modern .flp-table {
    width: 100%;
    border-collapse: collapse;
    overflow: hidden;
}
.ui-modern th,
.ui-modern td,
.ui-modern .flp-table th,
.ui-modern .flp-table td {
    text-align: left;
    padding: 10px 8px;
    border-bottom: 1px solid var(--flp-border);
    vertical-align: top;
}
.ui-modern th,
.ui-modern .flp-table th { font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; color: var(--flp-text-secondary); }
.ui-modern .flp-table-actions { text-align: right; }

.ui-modern .flp-row-highlight { background: color-mix(in srgb, var(--flp-status-followup) 20%, white); }


.ui-modern .flp-table--upcoming-tasks tbody tr:nth-child(even) {
    background: color-mix(in srgb, var(--flp-surface-secondary) 24%, transparent);
}

.ui-modern input,
.ui-modern select,
.ui-modern textarea,
.ui-modern .flp-input {
    border-radius: 12px;
    border: 1px solid var(--flp-border);
    background: var(--flp-bg);
    color: var(--flp-text);
    padding: 10px 12px;
    font: inherit;
    width: 100%;
    max-width: 420px;
    box-sizing: border-box;
}
.ui-modern label,
.ui-modern .flp-field { display: grid; gap: 6px; font-weight: 600; color: var(--flp-text-secondary); margin-bottom: 12px; }

.ui-modern .flp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.ui-modern .flp-grid--checks { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
.ui-modern .flp-field--full { grid-column: 1 / -1; }

.ui-modern .flp-card--compact {
    padding: 12px 16px;
}

.ui-modern .flp-yearwheel-controls {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px 12px;
    align-items: end;
}

.ui-modern .flp-yearwheel-controls label {
    margin-bottom: 0;
}

.ui-modern .flp-yearwheel-controls button {
    width: fit-content;
}
.ui-modern .flp-form-actions,
.ui-modern .flp-actions-row,
.ui-modern .flp-action-bar { display: flex; gap: 10px; flex-wrap: wrap; }

.ui-modern .flp-module-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
}
.ui-modern .flp-module-card {
    border-radius: 20px;
    border: 2px solid transparent;
    padding: 20px;
}
.ui-modern .flp-module-card--green { background: var(--flp-card); }
.ui-modern .flp-module-card--purple { background: var(--flp-surface-secondary); }
.ui-modern .flp-module-card--pink { background: color-mix(in srgb, var(--flp-secondary-action) 20%, var(--flp-bg)); }
.ui-modern .flp-shortcuts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
    list-style: none;
    padding: 0;
    margin: 0;
}
.ui-modern .flp-shortcuts a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--flp-card);
    border-radius: 999px;
    padding: 12px 16px;
    border: 2px solid color-mix(in srgb, var(--flp-primary-action) 28%, white);
    text-decoration: none;
    font-weight: 700;
}


.ui-modern .flp-login-card {
    width: min(100%, 380px);
    max-width: 540px;
    background: var(--flp-card);
    border: 1px solid var(--flp-border);
    border-radius: 24px;
    box-shadow: 0 16px 34px rgba(31, 31, 31, 0.12);
    padding: 24px;
}

.ui-modern .login-form button[type="submit"] {
    margin-top: 16px;
}
.ui-modern .flp-alert { background: color-mix(in srgb, var(--flp-status-followup) 16%, white); border: 1px solid color-mix(in srgb, var(--flp-status-followup) 42%, white); color: #6b4e2f; border-radius: 12px; padding: 10px 12px; }

@media (max-width: 900px) {
    .ui-modern .flp-module-grid { grid-template-columns: 1fr; }

    .ui-modern .flp-brand__name {
        font-size: 0.78rem;
        letter-spacing: 0.03em;
    }

    .ui-modern .flp-subbar__grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .ui-modern .flp-subbar__left {
        min-width: 0;
    }

    .ui-modern .flp-subbar__right .flp-school-name {
        display: none;
    }
}

.ui-modern .flp-report-filter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    align-items: end;
}

.ui-modern .flp-report-filter-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.ui-modern .flp-table-wrap {
    overflow-x: auto;
}
