:root {
    color-scheme: light;
    --font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
    --font-size-base: 16px;
    --font-size-sm: 14px;
    --font-weight-normal: 400;
    --font-weight-bold: 700;
    --spacing-xs: 6px;
    --spacing-sm: 8px;
    --spacing-md: 12px;
    --spacing-lg: 16px;
    --spacing-xl: 24px;
    --spacing-2xl: 32px;
    --spacing-3xl: 40px;
    --border-width: 1px;
    --border-radius-md: 8px;
    --border-radius-lg: 12px;
    --transition-fast: 180ms ease;

    --color-bg: #f6f3ec;
    --color-bg-light: #ffffff;
    --color-border: #d5cfbf;
    --color-border-light: #e6e0d3;
    --color-text: #2d261d;
    --color-text-secondary: #675f54;
    --color-primary: #0a5d70;
    --color-primary-dark: #08495a;
    --color-success: #0e7c43;
    --color-error: #9b1c1c;
    --color-info: #18406b;

    --bg: var(--color-bg);
    --paper: var(--color-bg-light);
    --ink: var(--color-text);
    --muted: var(--color-text-secondary);
    --accent: var(--color-primary);
    --accent-dark: var(--color-primary-dark);
    --line: var(--color-border);
    --line-soft: var(--color-border-light);
    --success: var(--color-success);
    --error: var(--color-error);
    --shadow: 0 10px 28px rgba(0, 0, 0, 0.06);
}

* {
    box-sizing: border-box;
}

body {
    margin: var(--spacing-3xl);
    font-family: var(--font-family);
    color: var(--color-text);
    background:
        radial-gradient(circle at top left, #fff8e7 0%, transparent 35%),
        radial-gradient(circle at bottom right, #d8edf2 0%, transparent 45%),
        var(--color-bg);
}

a {
    color: inherit;
}

.container {
    width: 100%;
    margin: 0;
}

.main-nav {
    display: flex;
    gap: var(--spacing-sm);
    margin: calc(var(--spacing-3xl) * -1) calc(var(--spacing-3xl) * -1) var(--spacing-xl);
    padding: var(--spacing-lg) var(--spacing-xl);
    flex-wrap: wrap;
    background: var(--color-primary);
    border-bottom: var(--border-width) solid var(--color-primary-dark);
}

.main-nav a {
    text-decoration: none;
    border: var(--border-width) solid transparent;
    border-radius: var(--border-radius-md);
    padding: var(--spacing-sm) var(--spacing-lg);
    color: #fff;
    transition: background-color var(--transition-fast);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-normal);
}

.main-nav a:hover {
    background: rgba(255, 255, 255, 0.18);
}

.main-nav a.active {
    background: rgba(255, 255, 255, 0.28);
    border-color: rgba(255, 255, 255, 0.35);
    font-weight: var(--font-weight-bold);
}

.main-nav-semester {
    margin-left: auto;
    align-self: center;
    color: rgba(255, 255, 255, 0.95);
    font-weight: var(--font-weight-bold);
    white-space: nowrap;
}

.main-nav-meta {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-md);
    color: rgba(255, 255, 255, 0.95);
    flex-wrap: wrap;
}

.main-nav-label {
    font-weight: var(--font-weight-bold);
}

.logout-form {
    margin: 0;
}

.logout-btn {
    background: rgba(255, 255, 255, 0.16);
    border: var(--border-width) solid rgba(255, 255, 255, 0.25);
    padding: 8px 14px;
}

.logout-btn:hover {
    filter: none;
    background: rgba(255, 255, 255, 0.22);
    transform: none;
}

.page-title {
    margin: 0 0 var(--spacing-md);
    font-size: 1.8rem;
}

.intro {
    margin: 0 0 var(--spacing-xl);
    color: var(--color-text-secondary);
}

.layout {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--spacing-lg);
    align-items: start;
}

.layout.admin {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
}

.stack {
    display: grid;
    gap: var(--spacing-lg);
}

.card {
    background: var(--color-bg-light);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-xl);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.06);
}

.card h2 {
    margin-top: 0;
    margin-bottom: var(--spacing-sm);
}

.card h3 {
    margin-top: 0;
    margin-bottom: var(--spacing-xs);
}

.muted {
    margin-top: 0;
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}

.empty-state {
    padding: var(--spacing-lg);
    border: var(--border-width) dashed var(--color-border);
    border-radius: var(--border-radius-md);
    color: var(--color-text-secondary);
    background: rgba(255, 255, 255, 0.55);
}

.message {
    margin: 0 0 var(--spacing-xl);
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--border-radius-md);
    border: var(--border-width) solid;
}

.message-info {
    background: #edf5ff;
    border-color: #c5d6ef;
    color: var(--color-info);
}

.message-error {
    background: #fff0ef;
    border-color: #ffc9c4;
    color: var(--color-error);
}

.message-success {
    background: #effbf4;
    border-color: #bee8cd;
    color: var(--color-success);
}

.message-running {
    background: #edf5ff;
    border-color: #c5d6ef;
    color: #18406b;
}

.form-grid {
    display: grid;
    gap: var(--spacing-md);
}

.form-grid label {
    display: grid;
    gap: var(--spacing-xs);
    font-weight: var(--font-weight-bold);
}

input[type="text"],
input[type="password"],
select,
textarea {
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--border-radius-md);
    padding: 10px 12px;
    font: inherit;
    color: var(--color-text);
    background: #fff;
    width: 100%;
}

button {
    border: 0;
    border-radius: var(--border-radius-md);
    background: var(--color-primary);
    color: #fff;
    font: inherit;
    font-weight: var(--font-weight-bold);
    padding: 10px 16px;
    cursor: pointer;
    transition: transform var(--transition-fast), filter var(--transition-fast);
}

button:hover {
    transform: translateY(-1px);
    filter: brightness(1.05);
}

.secondary-btn,
button.secondary {
    background: #52636a;
}

button.run-stop-btn {
    background: #9b1c1c;
}

button.run-stop-btn:hover {
    filter: brightness(1.08);
}

@media (max-width: 900px) {
    body {
        margin: var(--spacing-lg);
    }

    .main-nav {
        margin: calc(var(--spacing-lg) * -1) calc(var(--spacing-lg) * -1) var(--spacing-lg);
        padding: var(--spacing-md) var(--spacing-lg);
    }

    .main-nav-semester {
        width: 100%;
        margin-left: 0;
    }

    .main-nav-meta {
        width: 100%;
        margin-left: 0;
        justify-content: space-between;
    }

    .layout,
    .layout.admin {
        grid-template-columns: 1fr;
    }
}
