@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap');

/* Glosträningsportal - CSS */

/* === CSS VARIABLES === */
:root {
    /* Light mode colors - Modern cyan/blue theme inspired by index2.php */
    --bg-primary: #ffffff;
    --bg-secondary: #f8fafc;
    --bg-tertiary: #f1f5f9;
    --text-primary: #212529;
    --text-secondary: #495057;
    --text-muted: #6c757d;
    --border-color: #e5e7eb;
    --accent-primary: #0ea5e9;
    --accent-secondary: #06b6d4;
    --shadow: rgba(0, 0, 0, 0.08);
    --shadow-hover: rgba(14, 165, 233, 0.15);
    --header-bg: linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%);
    --body-bg: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 50%, #f0f9ff 100%);
    --hover-bg: rgba(14, 165, 233, 0.1);
    --card-bg: #ffffff;
    --hero-bg: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
}

[data-theme="dark"] {
    /* Dark mode colors - Inspired by index3.php */
    --bg-primary: #1e293b; /* slate-800 */
    --bg-secondary: #0f172a; /* slate-900 */
    --bg-tertiary: #1e293b; /* slate-800 */
    --text-primary: #f1f5f9; /* slate-100 */
    --text-secondary: #cbd5e1; /* slate-300 */
    --text-muted: #94a3b8; /* slate-400 */
    --border-color: #334155; /* slate-700 */
    --accent-primary: #0ea5e9; /* sky-500 */
    --accent-secondary: #06b6d4; /* cyan-500 */
    --shadow: rgba(0, 0, 0, 0.4);
    --shadow-hover: rgba(14, 165, 233, 0.25);
    --header-bg: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    --body-bg: linear-gradient(135deg, #1e293b 0%, #0f172a 50%, #1e293b 100%);
    --hover-bg: rgba(14, 165, 233, 0.15);
    --card-bg: #0f172a; /* slate-900 - mörkare cards */
    --hero-bg: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
}

/* === DARK MODE FIXES FOR LEGACY INLINE STYLES ===
   Många äldre/inline-stylade boxar använder ljusa bakgrunder som gör text oläsbar i dark mode.
   Vi override:ar dem här med !important (viktigt: slår även inline styles utan !important).
*/
[data-theme="dark"] [style*="background: white"],
[data-theme="dark"] [style*="background:white"],
[data-theme="dark"] [style*="background: #fff"],
[data-theme="dark"] [style*="background:#fff"] {
    background: var(--card-bg) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}

[data-theme="dark"] [style*="background: #f9f9f9"],
[data-theme="dark"] [style*="background:#f9f9f9"],
[data-theme="dark"] [style*="background: #f5f5f5"],
[data-theme="dark"] [style*="background:#f5f5f5"],
[data-theme="dark"] [style*="background: #f8f9fa"],
[data-theme="dark"] [style*="background:#f8f9fa"],
[data-theme="dark"] [style*="background: #e9ecef"],
[data-theme="dark"] [style*="background:#e9ecef"],
[data-theme="dark"] [style*="background: #e7f3ff"],
[data-theme="dark"] [style*="background:#e7f3ff"],
[data-theme="dark"] [style*="background: #e3f2fd"],
[data-theme="dark"] [style*="background:#e3f2fd"] {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}

[data-theme="dark"] [style*="background: #fff3cd"],
[data-theme="dark"] [style*="background:#fff3cd"] {
    background: rgba(255, 193, 7, 0.18) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] [style*="border-left: 4px solid #ffc107"],
[data-theme="dark"] [style*="border-left:4px solid #ffc107"] {
    border-left-color: #ffc107 !important;
}

[data-theme="dark"] [style*="border-bottom: 1px solid #eee"],
[data-theme="dark"] [style*="border-bottom:1px solid #eee"],
[data-theme="dark"] [style*="border: 1px solid #ddd"],
[data-theme="dark"] [style*="border:1px solid #ddd"] {
    border-color: var(--border-color) !important;
}

[data-theme="dark"] [style*="color: #666"],
[data-theme="dark"] [style*="color:#666"],
[data-theme="dark"] [style*="color: #856404"],
[data-theme="dark"] [style*="color:#856404"],
[data-theme="dark"] [style*="color: #333"],
[data-theme="dark"] [style*="color:#333"] {
    color: var(--text-secondary) !important;
}

[data-theme="dark"] [style*="background: #e5e7eb"],
[data-theme="dark"] [style*="background:#e5e7eb"] {
    background: var(--border-color) !important;
}

/* Admin: klasser från <style>-block (site_settings, changelog m.fl.) */
[data-theme="dark"] .settings-card,
[data-theme="dark"] .settings-section.settings-card {
    background: var(--card-bg) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}

[data-theme="dark"] .changelog-item {
    background: var(--card-bg) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}

[data-theme="dark"] .form-section {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}

[data-theme="dark"] .changelog-item .status-badge.status-kommande {
    background: rgba(59, 130, 246, 0.3) !important;
    color: #93c5fd !important;
}

[data-theme="dark"] .changelog-item .status-badge.status-pågående {
    background: rgba(245, 158, 11, 0.3) !important;
    color: #fcd34d !important;
}

[data-theme="dark"] .changelog-item .status-badge.status-klar {
    background: rgba(34, 197, 94, 0.25) !important;
    color: #86efac !important;
}

/* === RESET & GRUNDLÄGGANDE === */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    overflow-y: auto; /* Visa scrollbar endast när innehållet är längre än viewport */
    scrollbar-gutter: stable; /* Reservera plats för scrollbar även när den inte behövs */
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    line-height: 1.6;
    color: var(--text-primary);
    background: var(--body-bg);
    min-height: 100vh;
    padding: 20px;
    overflow-x: hidden; /* Förhindra horisontell scroll */
    transition: background 0.3s ease, color 0.3s ease;
}

/* Grundfärger för länkar */
a {
    color: var(--accent-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

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

a:visited {
    color: var(--accent-primary);
}

/* Behåll knapp- och "button-länk"-färg även när de är besökta */
.btn:visited {
    color: inherit;
}

.btn-primary:visited {
    color: white;
}

.btn-secondary:visited {
    color: #e5e7eb;
}

.btn-success:visited,
.btn-warning:visited,
.btn-danger:visited {
    color: white;
}

/* Dark mode - se till att länkar syns tydligt på mörk bakgrund */
[data-theme="dark"] a,
[data-theme="dark"] a:visited {
    color: #38bdf8; /* ljusare cyan/blå för bättre kontrast */
}

[data-theme="dark"] a:hover {
    color: #e0f2fe; /* nästan vit/blå vid hover */
}

/* Inline code */
code {
    background: var(--bg-tertiary);
    color: var(--text-primary);
    padding: 2px 8px;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.95em;
}

[data-theme="dark"] code {
    background: #1e293b; /* lite ljusare än --card-bg för kontrast */
    color: var(--text-primary);
    border-color: var(--border-color);
}

.container {
    max-width: 1600px;
    margin: 0 auto;
    background: var(--bg-primary);
    border-radius: 20px;
    box-shadow: 0 4px 24px var(--shadow);
    overflow: hidden;
    transition: background 0.3s ease, box-shadow 0.3s ease;
}

/* === HEADER === */
header {
    background: var(--header-bg);
    color: white;
    padding: 24px 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    gap: 20px;
    transition: background 0.3s ease;
}

header h1 {
    font-size: 1.8rem;
    font-weight: 800;
    letter-spacing: -0.5px;
}

/* Dark mode toggle switch */
.theme-toggle-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.theme-toggle-label {
    color: white;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}

.theme-toggle-switch {
    position: relative;
    width: 50px;
    height: 26px;
    appearance: none;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 13px;
    cursor: pointer;
    transition: all 0.3s ease;
    outline: none;
    flex-shrink: 0;
}

.theme-toggle-switch::before {
    content: '';
    position: absolute;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: white;
    top: 2px;
    left: 2px;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.theme-toggle-switch:checked {
    background: rgba(255, 255, 255, 0.5);
}

.theme-toggle-switch:checked::before {
    left: 26px;
}

.theme-toggle-switch:hover {
    background: rgba(255, 255, 255, 0.4);
}

.theme-toggle-switch:checked:hover {
    background: rgba(255, 255, 255, 0.6);
}

@media (max-width: 768px) {
    .theme-toggle-label {
        display: none;
    }
}


header h1 a {
    color: white !important;
    text-decoration: none;
}

header h1 a:visited {
    color: white !important;
}

header nav {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: nowrap;
    flex-shrink: 1;
    min-width: 0;
}

header nav > * {
    flex-shrink: 0;
}

header nav .nav-dropdown-content {
    flex-shrink: 0 !important;
}

header nav > a,
header nav > span {
    color: white;
    text-decoration: none;
    padding: 6px 10px;
    border-radius: 6px;
    transition: background 0.3s;
    font-size: 0.9rem;
    white-space: nowrap;
    flex-shrink: 1;
}

header nav .nav-dropdown {
    flex-shrink: 0;
}

header nav > a:hover {
    background: rgba(255, 255, 255, 0.2);
    color: white !important;
}

header nav .btn-load {
    background: rgba(255, 255, 255, 0.3);
    font-weight: 600;
}

/* === MAIN CONTENT === */
main {
    padding: 60px 40px;
    background: var(--bg-primary);
    color: var(--text-primary);
    transition: background 0.3s ease, color 0.3s ease;
}

@media (max-width: 768px) {
    main {
        padding: 40px 24px;
    }
}

/* === HERO SECTION === */
.hero {
    text-align: center;
    padding: 80px 40px;
    background: var(--hero-bg);
    border-radius: 16px;
    margin-bottom: 60px;
    transition: background 0.3s ease;
}

.hero h2 {
    font-size: 3rem;
    font-weight: 800;
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 16px;
    letter-spacing: -1px;
}

.hero p {
    font-size: 1.25rem;
    color: var(--text-secondary);
    line-height: 1.7;
    max-width: 600px;
    margin: 0 auto;
}

.hero-search {
    display: flex;
    gap: 12px;
    justify-content: center;
    align-items: center;
    margin-top: 28px;
    flex-wrap: wrap;
}

.hero-search input {
    padding: 12px 18px;
    font-size: 1rem;
    border: 2px solid var(--border-color);
    border-radius: 8px;
    min-width: 220px;
    max-width: 320px;
}

.hero-search input:focus {
    outline: none;
    border-color: var(--accent-primary);
}

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

@media (max-width: 768px) {
    .hero {
        padding: 60px 24px;
    }
    
    .hero h2 {
        font-size: 2rem;
    }
    
    .hero-search {
        flex-direction: column;
    }
    
    .hero-search input {
        min-width: 100%;
        max-width: 100%;
    }
}

/* === FORMULÄR === */
.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.form-group input[type="text"],
.form-group input[type="password"],
.form-group input[type="email"],
.form-group select {
    width: 100%;
    padding: 14px 18px;
    border: 1.5px solid var(--border-color);
    border-radius: 10px;
    font-size: 1rem;
    transition: all 0.3s ease;
    background: var(--bg-primary);
    color: var(--text-primary);
}

.form-group textarea {
    width: 100%;
    padding: 14px 18px;
    border: 1.5px solid var(--border-color);
    border-radius: 10px;
    font-size: 1rem;
    transition: all 0.3s ease;
    resize: vertical;
    min-height: 120px;
    background: var(--bg-primary);
    color: var(--text-primary);
    font-family: inherit;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group select:focus,
[data-theme="dark"] .form-group textarea:focus {
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.2);
}

.form-group small {
    display: block;
    margin-top: 5px;
    color: var(--text-muted);
    font-size: 0.85rem;
}

/* === GLOSRADER === */
.glosor-container {
    background: var(--card-bg);
    padding: 32px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    margin-top: 32px;
    transition: background 0.3s ease, border-color 0.3s ease;
}

[data-theme="dark"] .glosor-container {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.glosor-container h4 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 20px;
}

#glosorList {
    margin-bottom: 15px;
}

.glos-row {
    display: grid;
    grid-template-columns: 40px 1fr 1fr 40px;
    gap: 10px;
    margin-bottom: 10px;
    align-items: center;
}

.glos-number {
    font-weight: 600;
    color: var(--text-secondary);
    text-align: center;
}

.glos-row input {
    padding: 10px;
    border: 1.5px solid var(--border-color);
    border-radius: 8px;
    font-size: 0.95rem;
    background: var(--bg-primary);
    color: var(--text-primary);
    transition: all 0.3s ease;
}

.glos-row input:focus {
    outline: none;
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

[data-theme="dark"] .glos-row input:focus {
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.2);
}

.btn-remove {
    width: 40px;
    height: 40px;
    border: none;
    background: #dc3545;
    color: white;
    border-radius: 10px;
    cursor: pointer;
    font-size: 1.2rem;
    font-weight: bold;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.btn-remove:hover {
    background: #c82333;
    transform: scale(1.1);
}

/* === KNAPPAR === */
.btn {
    display: inline-block;
    padding: 12px 24px;
    border: none;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.3s;
    text-align: center;
}

.btn-primary {
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    color: white;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(14, 165, 233, 0.4);
}

[data-theme="dark"] .btn-primary {
    background: linear-gradient(135deg, #0284c7 0%, #0891b2 100%);
    color: white;
    box-shadow: 0 4px 12px rgba(56, 189, 248, 0.3);
}

[data-theme="dark"] .btn-primary:hover {
    background: linear-gradient(135deg, #0369a1 0%, #0e7490 100%);
    box-shadow: 0 6px 20px rgba(56, 189, 248, 0.4);
}

/* Säkerställ att btn-small btn-primary är läsbar i mörkt läge */
[data-theme="dark"] .btn-small.btn-primary {
    background: linear-gradient(135deg, #0284c7 0%, #0891b2 100%);
    color: white !important;
    font-weight: 600;
}

[data-theme="dark"] .btn-small.btn-primary:hover {
    background: linear-gradient(135deg, #0369a1 0%, #0e7490 100%);
    color: white !important;
}

.btn-secondary {
    background: #475569;
    color: #e5e7eb;
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
}

.btn-secondary:hover {
    background: #334155;
    transform: translateY(-2px);
}

[data-theme="dark"] .btn-secondary {
    background: #070d18;
    color: #e5e7eb;
}

[data-theme="dark"] .btn-secondary:hover {
    background: #334155;
}

.btn-success {
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
    color: white;
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
    box-shadow: 0 4px 12px rgba(34, 197, 94, 0.3);
}

.btn-success:hover {
    background: #16a34a;
    box-shadow: 0 6px 20px rgba(34, 197, 94, 0.4);
}

.btn-warning {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    color: white;
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
}

.btn-warning:hover {
    background: #d97706;
}

.btn-danger {
    background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%);
    color: white;
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
}

.btn-danger:hover {
    background: #b91c1c;
}

/* Snabbval-knappar i lärar-dashboard */
.quick-actions .btn {
    /* Ljust läge: platt blå knapp, ingen gradient */
    background: #2563eb;
    color: #ffffff;
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}

.quick-actions .btn:hover {
    background: #1d4ed8;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(37, 99, 235, 0.35);
}

[data-theme="dark"] .quick-actions .btn {
    /* Mörkt läge: använd samma stil som andra knappar i lärar-dashboard (ingen gradient) */
    background: #070d18;
    color: #e5e7eb;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.6);
}

[data-theme="dark"] .quick-actions .btn:hover {
    background: #111827;
    box-shadow: 0 6px 20px rgba(15, 23, 42, 0.9);
}

.btn-large {
    padding: 15px 30px;
    font-size: 1.1rem;
}

.btn-delete {
    padding: 6px 12px;
    background: #e74c3c;
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.9rem;
}

.btn-delete:hover {
    background: #c0392b;
}

/* === ALERTS === */
.alert {
    padding: 16px 20px;
    border-radius: 12px;
    margin-bottom: 24px;
    border-left: 4px solid;
    font-size: 0.95rem;
    line-height: 1.6;
}

.alert-error {
    background: #fef2f2;
    color: #991b1b;
    border-left-color: #dc2626;
}

[data-theme="dark"] .alert-error {
    background: rgba(220, 38, 38, 0.15);
    color: #fca5a5;
    border-left-color: #dc2626;
}

.alert-success {
    background: #f0fdf4;
    color: #166534;
    border-left-color: #22c55e;
}

[data-theme="dark"] .alert-success {
    background: rgba(34, 197, 94, 0.15);
    color: #86efac;
    border-left-color: #22c55e;
}

.alert-info {
    background: #eff6ff;
    color: #1e40af;
    border-left-color: #3b82f6;
}

[data-theme="dark"] .alert-info {
    background: rgba(59, 130, 246, 0.15);
    color: #93c5fd;
    border-left-color: #3b82f6;
}

/* === AUTH FORMS === */
.auth-form {
    max-width: 500px;
    margin: 0 auto;
    padding: 48px;
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    transition: background 0.3s ease;
    box-shadow: 0 4px 12px var(--shadow);
}

[data-theme="dark"] .auth-form {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.auth-form h2 {
    text-align: center;
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 32px;
    letter-spacing: -0.5px;
}

.text-center {
    text-align: center;
    margin-top: 20px;
}

/* === SUCCESS MESSAGE === */
.success-message {
    text-align: center;
    padding: 40px;
}

.success-message h2 {
    color: #27ae60;
    margin-bottom: 20px;
    font-size: 2rem;
}

.code-display {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    padding: 20px;
    border-radius: 12px;
    margin: 20px 0;
    font-size: 2rem;
    font-weight: bold;
    letter-spacing: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    flex-wrap: wrap;
}

.btn-copy {
    padding: 8px 16px;
    background: rgba(255, 255, 255, 0.3);
    border: 2px solid white;
    color: white;
    border-radius: 6px;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 600;
    transition: all 0.3s;
}

.btn-copy:hover {
    background: white;
    color: #667eea;
}

.action-buttons {
    display: flex;
    gap: 15px;
    justify-content: center;
    margin-top: 30px;
    flex-wrap: wrap;
}

/* === TEST VIEW === */
.test-view {
    max-width: 1000px;
    margin: 0 auto;
}

.test-header {
    text-align: center;
    margin-bottom: 40px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border-color);
    transition: border-color 0.3s ease;
}

.test-header h2 {
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 16px;
    letter-spacing: -0.5px;
}

.test-comment {
    background: #fefce8;
    padding: 20px;
    border-radius: 12px;
    margin: 20px 0;
    border-left: 4px solid #eab308;
    transition: background 0.3s ease;
}

.test-comment p {
    margin: 0;
    color: #713f12;
    font-style: italic;
    line-height: 1.6;
}

[data-theme="dark"] .test-comment {
    background: rgba(234, 179, 8, 0.15);
    color: #fde047;
}

[data-theme="dark"] .test-comment p {
    color: #fde047;
}

.test-info {
    display: flex;
    gap: 15px;
    justify-content: center;
    flex-wrap: wrap;
}

.language-badge,
.code-badge,
.word-count,
.language-code {
    display: inline-block;
    padding: 6px 12px;
    background: var(--hover-bg);
    color: var(--accent-primary);
    border-radius: 6px;
    font-size: 0.9rem;
    font-weight: 600;
    transition: background 0.3s ease, color 0.3s ease;
}

/* === TABELLER === */
.glosor-table,
.tests-table,
.practice-table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
}

/* Gradient på hela första raden */
.glosor-table thead tr,
.tests-table thead tr,
.practice-table thead tr,
.glosor-table tr:first-child,
.tests-table tr:first-child,
.practice-table tr:first-child {
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
}

[data-theme="dark"] .glosor-table thead tr,
[data-theme="dark"] .tests-table thead tr,
[data-theme="dark"] .practice-table thead tr,
[data-theme="dark"] .glosor-table tr:first-child,
[data-theme="dark"] .tests-table tr:first-child,
[data-theme="dark"] .practice-table tr:first-child {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
}

.glosor-table th,
.tests-table th,
.practice-table th {
    background: transparent;
    color: white;
    padding: 12px;
    text-align: left;
    font-weight: 600;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .glosor-table th,
[data-theme="dark"] .tests-table th,
[data-theme="dark"] .practice-table th {
    background: transparent;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
}

.glosor-table td,
.tests-table td,
.practice-table td {
    padding: 12px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-primary);
    color: var(--text-primary);
    transition: background 0.3s ease, color 0.3s ease;
}

[data-theme="dark"] .glosor-table td,
[data-theme="dark"] .tests-table td,
[data-theme="dark"] .practice-table td {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.glosor-table tbody tr:hover,
.tests-table tbody tr:hover {
    background: var(--hover-bg);
}

[data-theme="dark"] .glosor-table tbody tr:hover,
[data-theme="dark"] .tests-table tbody tr:hover {
    background: rgba(14, 165, 233, 0.1);
}

.glosor-table tr:last-child td,
.tests-table tr:last-child td,
.practice-table tr:last-child td {
    border-bottom: none;
}

.tests-table a {
    color: var(--accent-primary);
    text-decoration: none;
    font-weight: 600;
}

.tests-table a:hover {
    text-decoration: underline;
}

/* === PRACTICE VIEW === */
.practice-view {
    max-width: 1000px;
    margin: 0 auto;
}

.practice-header {
    text-align: center;
    margin-bottom: 40px;
}

.practice-header h2 {
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 16px;
    letter-spacing: -0.5px;
}

/* Val av träningsläge (Gloslista / Flashcards / Matchning) */
.practice-mode-choice {
    margin-bottom: 40px;
}

.practice-mode-choice h3 {
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 20px;
    text-align: center;
}

.practice-mode-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    max-width: 720px;
    margin: 0 auto;
}

.practice-mode-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 28px 20px;
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    border: 2px solid var(--border-color);
    border-radius: 16px;
    cursor: pointer;
    transition: all 0.25s ease;
    text-align: center;
    font-family: inherit;
}

.practice-mode-card:hover:not(:disabled) {
    border-color: var(--accent-primary);
    background: var(--hover-bg);
    transform: translateY(-4px);
    box-shadow: 0 8px 24px var(--shadow-hover);
}

.practice-mode-card:focus-visible {
    outline: 2px solid var(--accent-primary);
    outline-offset: 2px;
}

.practice-mode-card-coming {
    cursor: not-allowed;
    opacity: 0.85;
}

.practice-mode-card-coming .practice-mode-desc {
    color: var(--text-muted);
}

.practice-mode-badge-coming {
    display: inline-block;
    margin-left: 0.35em;
    padding: 2px 8px;
    font-size: 0.7em;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    background: var(--gp6-amber-light, rgba(245, 158, 11, 0.2));
    color: var(--gp6-amber, #d97706);
    border-radius: 6px;
}
[data-theme="dark"] .practice-mode-badge-coming {
    background: rgba(245, 158, 11, 0.25);
    color: #fbbf24;
}

.practice-mode-card.disabled,
.practice-mode-card:disabled {
    cursor: not-allowed;
    opacity: 0.7;
    pointer-events: none;
}

.practice-mode-card.disabled:hover,
.practice-mode-card:disabled:hover {
    border-color: var(--border-color);
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    transform: none;
    box-shadow: none;
}

.practice-mode-card.disabled .practice-mode-desc,
.practice-mode-card:disabled .practice-mode-desc {
    color: var(--text-tertiary);
}

.practice-mode-icon {
    font-size: 2.5rem;
    line-height: 1;
}

.practice-mode-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary);
}

.practice-mode-desc {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.35;
}

.practice-mode-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--accent-primary);
    color: #fff;
}

.practice-mode-section {
    margin-bottom: 24px;
}

.btn-back-to-modes {
    display: inline-block;
    margin-bottom: 16px;
    font-size: 0.95rem;
    color: var(--accent-primary);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    text-decoration: none;
    transition: color 0.2s;
}

.btn-back-to-modes:hover {
    text-decoration: underline;
    color: var(--accent-secondary);
}

/* Flashcards: kortvy med flip-effekt */
.flashcards-view .flashcard-container {
    position: relative;
    perspective: 1200px;
    margin: 0 auto 24px;
    max-width: 420px;
}

.flashcard-audio-btn {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 10;
    width: 44px;
    height: 44px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-primary);
    border: 1px solid rgba(14, 165, 233, 0.5);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.flashcard-audio-btn:hover {
    background: var(--accent-secondary);
    transform: scale(1.05);
}

.flashcard-audio-btn:active {
    transform: scale(0.98);
}

[data-theme="dark"] .flashcard-audio-btn {
    background: var(--accent-primary);
    border-color: rgba(14, 165, 233, 0.4);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .flashcard-audio-btn:hover {
    background: var(--accent-secondary);
}

.flashcard {
    position: relative;
    width: 100%;
    aspect-ratio: 4/3;
    cursor: pointer;
    border: none;
    background: transparent;
    padding: 0;
    font-family: inherit;
}

.flashcard .flashcard-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    transform-style: preserve-3d;
}

.flashcard.flipped .flashcard-inner {
    transform: rotateY(180deg);
}

.flashcard .flashcard-front,
.flashcard .flashcard-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px;
    border-radius: 16px;
    box-shadow: 0 4px 20px var(--shadow);
}

.flashcard .flashcard-front {
    background: linear-gradient(145deg, var(--accent-primary), var(--accent-secondary));
    color: #fff;
}

[data-theme="dark"] .flashcard .flashcard-front {
    background: linear-gradient(145deg, #1e3a5f 0%, #0f172a 100%);
    color: #e2e8f0;
    border: 1px solid #334155;
}

.flashcard .flashcard-front-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    width: 100%;
    padding: 16px;
    box-sizing: border-box;
}

.flashcard .flashcard-front .flashcard-text {
    flex: 0 0 auto;
}

.flashcard-hint-btn {
    flex: 0 0 auto;
    padding: 8px 16px;
    font-size: 0.9rem;
    font-weight: 500;
    color: inherit;
    background: rgba(255, 255, 255, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

.flashcard-hint-btn:hover {
    background: rgba(255, 255, 255, 0.35);
    border-color: rgba(255, 255, 255, 0.6);
}

[data-theme="dark"] .flashcard-hint-btn {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
}

[data-theme="dark"] .flashcard-hint-btn:hover {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.35);
}

.flashcard-hint-text {
    font-size: 0.95rem;
    font-weight: 500;
    opacity: 0.95;
    min-height: 1.4em;
}

.flashcard .flashcard-back {
    background: linear-gradient(145deg, var(--bg-primary), var(--bg-secondary));
    border: 2px solid var(--border-color);
    color: var(--text-primary);
    transform: rotateY(180deg);
}

.flashcard .flashcard-text {
    font-size: clamp(1.25rem, 4vw, 1.75rem);
    font-weight: 600;
    text-align: center;
    line-height: 1.4;
    word-break: break-word;
}

.flashcard-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-bottom: 20px;
}

.flashcard-counter {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-secondary);
    min-width: 60px;
    text-align: center;
}

.flashcard-actions {
    text-align: center;
}

.coming-soon-box {
    text-align: center;
    padding: 48px 24px;
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    max-width: 400px;
    margin: 0 auto;
}

.coming-soon-box .coming-soon-badge {
    display: inline-block;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--accent-primary);
    color: #fff;
    margin-bottom: 16px;
}

.coming-soon-box h3 {
    font-size: 1.5rem;
    color: var(--text-primary);
    margin-bottom: 8px;
}

.coming-soon-box p {
    color: var(--text-secondary);
    margin: 0;
}

.practice-settings {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 40px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    margin-bottom: 40px;
    transition: background 0.3s ease;
}

[data-theme="dark"] .practice-settings {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.practice-settings h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 24px;
    letter-spacing: -0.5px;
}

.radio-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.radio-group label {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    padding: 10px;
    border-radius: 6px;
    transition: background 0.3s;
}

.radio-group label:hover {
    background: var(--hover-bg);
}

.radio-group input[type="radio"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
}

/* Matchning – modernt tvåkolumnsläge med linjer mellan ord */
.match-section {
    margin-top: 24px;
}

.match-intro {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 24px 28px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    margin-bottom: 24px;
}

.match-intro h3 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.match-intro p {
    margin: 4px 0;
    color: var(--text-secondary);
}

.match-board {
    position: relative;
    margin-top: 10px;
    padding: 32px 80px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    background: var(--bg-primary);
    overflow: hidden;
}

.match-columns {
    display: flex;
    justify-content: space-between;
    gap: 120px;
    position: relative;
    z-index: 2; /* ovanpå linjerna i bakgrunden */
}

.match-column {
    flex: 0 0 42%;
}

.match-column h4 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 10px;
    color: var(--text-primary);
    text-align: center;
}

.match-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.match-item {
    display: block;
    width: 100%;
    padding: 18px 42px 10px 42px; /* extra utrymme för RÄTT/FEL-badge */
    border-radius: 999px;
    text-align: left;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
    font-size: 0.95rem;
    transition: all 0.2s ease;
    position: relative;
    z-index: 3;
}

.match-item-left {
    text-align: right;
}

.match-item:hover {
    background: var(--hover-bg);
    border-color: var(--accent-primary);
}

.match-item.selected {
    box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.4);
    border-color: var(--accent-primary);
}

.match-item.paired {
    opacity: 0.9;
}

.match-item.match-correct {
    border-color: #22c55e;
    background: rgba(34, 197, 94, 0.08);
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.3);
}

.match-item.match-wrong {
    border-color: #ef4444;
    background: rgba(239, 68, 68, 0.08);
    box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.3);
}

.match-status-label {
    position: absolute;
    top: 4px;
    transform: none;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 999px;
    letter-spacing: 0.05em;
}

.match-status-correct {
    background: #22c55e;
    color: #ffffff;
}

.match-status-wrong {
    background: #ef4444;
    color: #ffffff;
}

.match-status-left {
    left: 14px;
}

.match-status-right {
    right: 14px;
}

.match-lines-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
}

.match-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin-top: 24px;
}

.match-hint-text {
    margin-top: 8px;
    font-size: 0.95rem;
    color: var(--text-secondary);
}

@media (max-width: 1024px) {
    .match-board {
        padding: 24px 32px;
    }
    .match-columns {
        gap: 48px;
        flex-direction: row;
    }
}

@media (max-width: 768px) {
    .match-columns {
        grid-template-columns: 1fr;
        gap: 16px;
        flex-direction: column;
    }

    .match-item-left {
        text-align: left;
    }
    /* På mobil är linjer svåra att följa – fokusera på färgade rutor istället */
    .match-lines-layer {
        display: none;
    }
}

/* === HANGMAN / GUBBEN STYLES === */

.hangman-section {
    margin-top: 24px;
}

.hangman-intro {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 24px 28px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    margin-bottom: 24px;
}

.hangman-intro h3 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.hangman-intro p {
    margin: 4px 0;
    color: var(--text-secondary);
}

.hangman-game {
    margin-top: 24px;
}

.hangman-settings {
    background: var(--bg-secondary);
    padding: 24px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    margin-bottom: 24px;
}

.hangman-settings .form-group {
    margin-bottom: 20px;
}

.hangman-settings label {
    display: block;
    font-weight: 600;
    margin-bottom: 12px;
    color: var(--text-primary);
}

.hangman-settings .radio-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hangman-settings .radio-group label {
    display: flex;
    align-items: center;
    font-weight: normal;
    cursor: pointer;
    padding: 8px 12px;
    border-radius: 8px;
    transition: background 0.2s ease;
}

.hangman-settings .radio-group label:hover {
    background: var(--hover-bg);
}

.hangman-settings .radio-group input[type="radio"] {
    margin-right: 8px;
    cursor: pointer;
}

.hangman-play-area {
    background: var(--bg-secondary);
    padding: 24px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
}

.hangman-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    margin-bottom: 32px;
}

.hangman-word-display {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 8px;
    text-align: center;
    padding: 20px;
    background: var(--bg-primary);
    border-radius: 12px;
    border: 2px solid var(--border-color);
    min-height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
}

.hangman-letter {
    display: inline-block;
    min-width: 24px;
    color: var(--text-primary);
}

.hangman-letter.hangman-blank {
    color: var(--text-tertiary);
}

.hangman-drawing {
    width: 100%;
    max-width: 300px;
    height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hangman-svg {
    width: 100%;
    height: 100%;
}

.hangman-alphabet {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    margin-bottom: 24px;
    min-height: 60px;
    padding: 12px;
    background: var(--bg-primary);
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.hangman-letter-btn {
    padding: 12px 16px;
    font-size: 1.1rem;
    font-weight: 600;
    background: var(--bg-primary);
    border: 2px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 48px;
}

.hangman-letter-btn:hover:not(:disabled) {
    background: var(--hover-bg);
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.hangman-letter-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.hangman-letter-btn.guessed {
    background: var(--bg-tertiary);
    border-color: var(--text-tertiary);
}

.hangman-info {
    text-align: center;
    margin-bottom: 24px;
    padding: 16px;
    background: var(--bg-primary);
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.hangman-info p {
    margin: 8px 0;
    color: var(--text-primary);
}

.hangman-info strong {
    color: var(--accent-primary);
    font-size: 1.2rem;
}

.hangman-hint {
    font-style: italic;
    color: var(--text-secondary);
    margin-top: 8px;
}

.hangman-actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

@media (max-width: 768px) {
    .hangman-word-display {
        font-size: 1.5rem;
        letter-spacing: 4px;
        padding: 16px;
    }
    
    .hangman-drawing {
        max-width: 250px;
        height: 250px;
    }
    
    .hangman-letter-btn {
        padding: 10px 14px;
        font-size: 1rem;
        min-width: 44px;
    }
}

/* === MEMORY STYLES === */

.memory-section {
    margin-top: 24px;
}

.memory-intro {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 24px 28px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    margin-bottom: 24px;
}

.memory-intro h3 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.memory-intro p {
    margin: 4px 0;
    color: var(--text-secondary);
}

.memory-game {
    margin-top: 24px;
}

.memory-settings {
    background: var(--bg-secondary);
    padding: 24px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    margin-bottom: 24px;
}

.memory-settings .form-group {
    margin-bottom: 20px;
}

.memory-settings label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--text-primary);
}

.memory-settings .form-control {
    width: 100%;
    padding: 10px 12px;
    font-size: 1rem;
    border: 2px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-primary);
    color: var(--text-primary);
    margin-bottom: 8px;
}

.memory-settings .form-control:focus {
    outline: none;
    border-color: var(--accent-primary);
}

.memory-settings .form-text {
    display: block;
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-top: 4px;
}

.memory-play-area {
    display: none;
}

.memory-stats {
    text-align: center;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
    margin-bottom: 24px;
}

.memory-stats p {
    margin: 0;
    font-size: 1.1rem;
    color: var(--text-primary);
}

.memory-stats strong {
    color: var(--accent-primary);
}

.memory-board {
    display: grid;
    gap: 12px;
    margin-bottom: 24px;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
}

.memory-card {
    aspect-ratio: 1;
    cursor: pointer;
    perspective: 1000px;
}

.memory-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.6s;
    transform-style: preserve-3d;
}

.memory-card.flipped .memory-card-inner {
    transform: rotateY(180deg);
}

.memory-card-front,
.memory-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: 2px solid var(--border-color);
    font-weight: 600;
    font-size: 1rem;
    padding: 12px;
    text-align: center;
    word-wrap: break-word;
    overflow: hidden;
}

.memory-card-front {
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    color: #ffffff;
    font-size: 2rem;
}

.memory-card-back {
    background: var(--bg-primary) !important;
    color: var(--text-primary) !important;
    transform: rotateY(180deg);
    z-index: 2;
    visibility: visible !important;
    opacity: 1 !important;
}

.memory-card.flipped .memory-card-back {
    visibility: visible !important;
    opacity: 1 !important;
    color: var(--text-primary) !important;
}

.memory-card.found .memory-card-inner {
    transform: rotateY(180deg);
}

.memory-card.found .memory-card-back {
    background: rgba(34, 197, 94, 0.2);
    border-color: #22c55e;
}

.memory-actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

@media (max-width: 768px) {
    .memory-board {
        gap: 8px;
        padding: 12px;
    }
    
    .memory-card-front,
    .memory-card-back {
        font-size: 0.9rem;
        padding: 8px;
    }
    
    .memory-card-front {
        font-size: 1.5rem;
    }
}

.score-display {
    text-align: center;
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 24px;
    padding: 24px;
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    border-radius: 12px;
    border: 1px solid var(--border-color);
    transition: background 0.3s ease;
}

.gloslista-question-cell {
    position: relative;
}

.gloslista-question-cell strong {
    margin-right: 8px;
}

.gloslista-audio-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    margin-right: 8px;
    vertical-align: middle;
    background: var(--accent-primary);
    border: 1px solid rgba(14, 165, 233, 0.5);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
}

.gloslista-audio-btn:hover {
    background: var(--accent-secondary);
    transform: scale(1.05);
}

.gloslista-audio-btn:active {
    transform: scale(0.98);
}

[data-theme="dark"] .gloslista-audio-btn {
    background: var(--accent-primary);
    border-color: rgba(14, 165, 233, 0.4);
}

[data-theme="dark"] .gloslista-audio-btn:hover {
    background: var(--accent-secondary);
}

.answer-input {
    width: 100%;
    padding: 12px 16px;
    border: 1.5px solid var(--border-color);
    border-radius: 10px;
    font-size: 1rem;
    background: var(--bg-primary);
    color: var(--text-primary);
    transition: all 0.3s ease;
}

.answer-input:focus {
    outline: none;
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

[data-theme="dark"] .answer-input:focus {
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.2);
}

.answer-input:disabled {
    background: var(--bg-secondary);
    opacity: 0.7;
}

.score-cell {
    font-weight: bold;
    font-size: 1.1rem;
}

.score-perfect {
    color: #27ae60;
}

.score-partial {
    color: #f39c12;
}

.score-wrong {
    color: #e74c3c;
}

.correct-answer {
    margin-top: 5px;
    color: #27ae60;
    font-size: 0.9rem;
    font-weight: 600;
}

.practice-actions {
    display: flex;
    gap: 15px;
    justify-content: center;
    margin-top: 30px;
}

.results-summary {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 40px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    text-align: center;
    margin: 32px 0;
    transition: background 0.3s ease;
}

.results-summary p {
    font-size: 1.2rem;
    margin: 10px 0;
}

/* === PROFILE === */
.profile-view {
    max-width: 1400px;
    margin: 0 auto;
    padding: 40px;
}

.profile-info {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 32px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    margin-bottom: 40px;
    transition: background 0.3s ease;
}

[data-theme="dark"] .profile-info {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.profile-info p {
    margin: 12px 0;
    font-size: 1rem;
    line-height: 1.7;
}

.class-name-link {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;
    color: var(--gp6-accent-primary, var(--accent-primary));
    cursor: pointer;
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 3px;
}
.class-name-link:hover {
    text-decoration-style: solid;
}

.profile-settings {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 40px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    margin-bottom: 40px;
    transition: background 0.3s ease;
}

[data-theme="dark"] .profile-settings {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.profile-settings h3 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 24px;
    letter-spacing: -0.5px;
}

.settings-sections {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.settings-section {
    background: var(--card-bg);
    padding: 28px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    transition: background 0.3s ease, border-color 0.3s ease;
    margin-bottom: 24px;
}

.settings-section h4 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 20px;
    color: var(--text-primary);
}

.inline-form {
    margin: 0;
}

.form-group-inline {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.form-group-inline input {
    flex: 1;
    min-width: 200px;
    padding: 10px;
    border: 2px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-primary);
    color: var(--text-primary);
    transition: border-color 0.3s, background 0.3s ease, color 0.3s ease;
}

.form-message {
    display: none;
    margin-top: 10px;
    padding: 10px;
    border-radius: 6px;
}

.form-message-success {
    background: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.form-message-error {
    background: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

.my-tests h3 {
    color: var(--accent-primary);
    margin-bottom: 20px;
}

/* === LOAD TEST === */
.load-test-form {
    max-width: 600px;
    margin: 0 auto;
    padding: 48px;
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    transition: background 0.3s ease;
    box-shadow: 0 4px 12px var(--shadow);
}

.load-test-form h2 {
    text-align: center;
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 16px;
    letter-spacing: -0.5px;
}

.load-test-form p {
    text-align: center;
    font-size: 1.1rem;
    margin-bottom: 32px;
    color: var(--text-secondary);
    line-height: 1.7;
}

/* === CREATE TEST SECTION === */
.create-test-section {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 48px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    transition: background 0.3s ease;
}

.create-test-section h3 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 12px;
    letter-spacing: -0.5px;
}

@media (max-width: 768px) {
    .create-test-section {
        padding: 32px 24px;
    }
}

/* === FOOTER === */
footer {
    text-align: center;
    padding: 20px;
    background: var(--bg-secondary);
    color: var(--text-secondary);
    border-top: 1px solid var(--border-color);
    transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* === RESPONSIV DESIGN === */

/* Large screens - if navigation is too long, make it more compact */
@media (max-width: 1200px) {
    header nav a,
    header nav span {
        font-size: 0.85rem;
        padding: 5px 8px;
    }
    
    header h1 {
        font-size: 1.4rem;
    }
    
    header nav {
        gap: 10px;
    }
}

/* Tablet */
@media (max-width: 768px) {
    header {
        flex-direction: column;
        text-align: center;
        flex-wrap: wrap;
    }
    
    header nav {
        justify-content: center;
        flex-wrap: wrap;
        gap: 8px;
    }
    
    header nav a,
    header nav span {
        font-size: 0.8rem;
        padding: 5px 8px;
    }
    
    .hero h2 {
        font-size: 1.8rem;
    }
    
    .glos-row {
        grid-template-columns: 30px 1fr 1fr 35px;
        gap: 8px;
    }
    
    .action-buttons {
        flex-direction: column;
    }
    
    .action-buttons .btn {
        width: 100%;
    }
    
    .tests-table {
        font-size: 0.9rem;
    }
    
    .tests-table th,
    .tests-table td {
        padding: 8px;
    }
}

/* Mobil */
@media (max-width: 480px) {
    body {
        padding: 10px;
    }
    
    .container {
        border-radius: 8px;
    }
    
    main {
        padding: 20px;
    }
    
    header {
        padding: 15px 20px;
    }
    
    header h1 {
        font-size: 1.5rem;
    }
    
    header nav {
        width: 100%;
        flex-direction: column;
        gap: 10px;
    }
    
    header nav a {
        width: 100%;
        text-align: center;
    }
    
    .hero {
        padding: 30px 15px;
    }
    
    .hero h2 {
        font-size: 1.5rem;
    }
    
    .hero p {
        font-size: 1rem;
    }
    
    .glos-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    
    .glos-number {
        text-align: left;
    }
    
    .btn-remove {
        width: 100%;
        border-radius: 6px;
    }
    
    .code-display {
        font-size: 1.5rem;
    }
    
    .practice-settings {
        padding: 20px;
    }
    
    .practice-actions {
        flex-direction: column;
    }
    
    .practice-actions .btn {
        width: 100%;
    }
    
    .tests-table {
        display: block;
        overflow-x: auto;
    }
    
    .form-group input,
    .form-group select {
        font-size: 16px; /* Förhindra zoom på iOS */
    }
}

/* === LÄRARE/ELEV/ADMIN === */
.teacher-dashboard,
.student-dashboard,
.admin-dashboard,
.teacher-view,
.student-view,
.admin-view,
.test-view,
.edit-test-view {
    max-width: 1500px;
    margin: 0 auto;
    padding: 40px;
}

/* Mina glostest – sektionsramar */
.myglostest-section-box {
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 24px;
    background: var(--card-bg, #fff);
}
[data-theme="dark"] .myglostest-section-box {
    border-color: var(--border-color);
    background: var(--card-bg);
}
.myglostest-section-box h3 { margin-top: 0; margin-bottom: 8px; }
.myglostest-section-box > .gp6-text-secondary { margin-bottom: 16px; }

.myglostest-page-header {
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 24px;
    background: var(--card-bg, #fff);
}
[data-theme="dark"] .myglostest-page-header {
    border-color: var(--border-color);
    background: var(--card-bg);
}
.myglostest-page-header h2 { margin-top: 0; margin-bottom: 8px; }

.stats-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin-bottom: 30px;
}

.stat-card {
    background: var(--card-bg);
    color: var(--text-primary);
    padding: 40px;
    border-radius: 16px;
    text-align: center;
    box-shadow: 0 4px 16px rgba(14, 165, 233, 0.3);
    transition: transform 0.3s ease;
}

.stat-card:hover {
    transform: translateY(-4px);
}

.stat-card h3 {
    font-size: 3rem;
    margin-bottom: 10px;
}

.stat-card p {
    font-size: 1.1rem;
    margin-bottom: 15px;
}

.stat-card a {
    display: block;
    text-decoration: none;
    color: inherit;
}

.stat-card a:hover {
    opacity: 0.9;
}

.stat-card small {
    font-size: 0.85rem;
    opacity: 0.9;
}

.alert-info {
    background: #d1ecf1;
    color: #0c5460;
    border-left: 4px solid #17a2b8;
}

.teacher-options {
    margin: 20px 0;
    padding: 20px;
    background: #fff3cd;
    border-radius: 8px;
    border: 2px solid #ffc107;
    transition: background 0.3s ease, border-color 0.3s ease;
}

[data-theme="dark"] .teacher-options {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.teacher-options h4 {
    color: #856404;
    margin-bottom: 15px;
}

[data-theme="dark"] .teacher-options h4 {
    color: var(--text-primary);
}

/* Redigera klass – rutor för kontaktbehörighet och elever */
.edit-class-panel {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 24px;
    background: var(--bg-secondary);
}

.edit-class-panel h4 {
    margin-top: 0;
    margin-bottom: 8px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border-color);
}

.edit-class-panel .form-hint {
    margin-bottom: 16px;
    color: var(--text-secondary);
    font-size: 0.95em;
}

/* Skeleton loaders för senaste glostest */
.recent-tests-skeleton .skeleton-card,
.recent-tests-member-skeleton .skeleton-card {
    pointer-events: none;
}

.skeleton-line {
    background: linear-gradient(90deg, var(--border-color) 25%, var(--bg-tertiary) 50%, var(--border-color) 75%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.2s ease-in-out infinite;
    border-radius: 4px;
}

.skeleton-title {
    height: 18px;
    width: 80%;
    margin: 0 auto 8px;
}

.skeleton-subtitle {
    height: 12px;
    width: 50%;
    margin: 0 auto 16px;
}

.skeleton-code {
    height: 32px;
    width: 90px;
    margin: 0 auto;
}

.skeleton-member-title {
    height: 14px;
    width: 90%;
    margin-bottom: 6px;
}

.skeleton-member-code {
    height: 12px;
    width: 60%;
}

@keyframes skeleton-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.recent-tests-content.recent-tests-loaded,
.recent-tests-member-content.recent-tests-loaded {
    display: grid !important;
    animation: fadeIn 0.3s ease-out;
}

.recent-tests-skeleton.recent-tests-hidden,
.recent-tests-member-skeleton.recent-tests-hidden {
    display: none !important;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.recent-tests-section {
    margin-bottom: 60px;
}

.recent-tests-section h3 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 12px;
    letter-spacing: -0.5px;
}

.recent-tests-section > p {
    font-size: 1.1rem;
    color: var(--text-secondary);
    margin-bottom: 32px;
}

.recent-tests-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin: 0 auto;
}

@media (max-width: 1100px) {
    .recent-tests-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.recent-test-card {
    background: var(--card-bg);
    padding: 24px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    text-align: center;
    transition: all 0.3s ease;
    cursor: pointer;
}

[data-theme="dark"] .recent-test-card {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.recent-test-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px var(--shadow-hover);
    border-color: var(--accent-primary);
}

[data-theme="dark"] .recent-test-card:hover {
    background: #1e293b;
    box-shadow: 0 8px 24px rgba(14, 165, 233, 0.25);
}

.recent-test-card h4 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 8px;
}

.recent-test-card .test-language {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.test-code-link {
    display: inline-block;
    padding: 10px 20px;
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    color: white;
    text-decoration: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.95rem;
    transition: all 0.3s ease;
}

.test-code-link:visited {
    color: white;
}

.test-code-link:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
}

/* Kompakta senaste glostest för inloggade medlemmar */
.recent-tests-member-section {
    margin: 28px 0;
}

.recent-tests-member-section .recent-tests-member-title {
    margin-bottom: 12px;
    font-size: 1.1rem;
}

.recent-tests-member-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    grid-template-rows: repeat(2, auto);
    gap: 10px;
    max-width: 100%;
}
.recent-test-member-card {
    display: block;
    padding: 10px 12px;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
    transition: background 0.2s, border-color 0.2s;
}

.recent-test-member-card:hover {
    background: var(--hover-bg) !important;
    border-color: var(--accent-primary) !important;
}

.recent-test-member-title {
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.25;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.recent-test-member-code {
    font-size: 0.75rem;
    font-family: monospace;
    color: var(--text-secondary);
}
@media (max-width: 900px) {
    .recent-tests-member-grid {
        grid-template-columns: repeat(6, minmax(90px, 1fr));
        overflow-x: auto;
        padding-bottom: 8px;
    }
}
/* Mobil: 2 kort i bredd, 4 rader (8 kort synliga) */
@media (max-width: 600px) {
    .recent-tests-member-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(4, auto);
        overflow-x: visible;
        padding-bottom: 0;
    }
    .recent-tests-member-grid .recent-test-member-card:nth-child(n+9) {
        display: none;
    }
}

[data-theme="dark"] .test-code-link,
[data-theme="dark"] .test-code-link:visited {
    background: #0e7490;
    color: #fff;
}

[data-theme="dark"] .test-code-link:hover {
    background: #0d9488;
    color: #fff;
    box-shadow: 0 4px 12px rgba(13, 148, 136, 0.4);
}

.info-text {
    background: var(--card-bg);
    padding: 24px;
    border-radius: 12px;
    border-left: 4px solid var(--accent-primary);
    margin-bottom: 32px;
    transition: background 0.3s ease;
    border: 1px solid var(--border-color);
}

[data-theme="dark"] .info-text {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.info-text p {
    font-size: 1rem;
    color: var(--text-secondary);
    line-height: 1.7;
    margin-bottom: 12px;
}

.info-text p:last-child {
    margin-bottom: 0;
}

.info-text strong {
    color: var(--accent-primary);
}

.section-divider {
    border: none;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--border-color), transparent);
    margin: 60px 0;
    transition: background 0.3s ease;
}

.quick-actions,
.recent-classes {
    margin-bottom: 30px;
}

.quick-actions h3,
.recent-classes h3 {
    color: var(--accent-primary);
    margin-bottom: 20px;
}

.class-grid,
.test-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}

.class-card {
    background: var(--card-bg);
    padding: 28px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
}

.class-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px var(--shadow-hover);
    border-color: var(--accent-primary);
}

.test-card {
    background: var(--card-bg);
    padding: 28px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
}

.test-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px var(--shadow-hover);
    border-color: var(--accent-primary);
}

.class-card h4,
.test-card h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 12px;
}

.card-actions {
    display: flex;
    gap: 10px;
    margin-top: 15px;
}

.btn-small {
    padding: 6px 12px;
    font-size: 0.9rem;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    background: var(--bg-primary);
}

.data-table th,
.data-table td {
    padding: 12px;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-primary);
    color: var(--text-primary);
    transition: background 0.3s ease, color 0.3s ease;
}

.data-table thead tr {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
}

.data-table th {
    background: transparent;
    color: var(--text-primary);
    font-weight: 600;
}

[data-theme="dark"] .data-table thead tr {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
}

[data-theme="dark"] .data-table th {
    background: transparent;
    color: #e5e7eb;
}

.th-sort {
    color: inherit;
    text-decoration: none;
    display: inline-block;
    padding: 2px 4px;
    border-radius: 4px;
}
.th-sort:hover {
    background: rgba(0,0,0,0.06);
}
.th-sort.active { font-weight: 700; }
[data-theme="dark"] .th-sort:hover { background: rgba(255,255,255,0.08); }

/* Ikonknappar i tabell-åtgärder */
.actions-cell { white-space: nowrap; }
.actions-cell .btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    margin: 0 2px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s;
}
.actions-cell .btn-icon:hover {
    background: var(--hover-bg);
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}
.actions-cell .btn-icon-delete:hover {
    border-color: #dc2626;
    color: #dc2626;
    background: rgba(220, 38, 38, 0.1);
}
.actions-cell .btn-icon-inactive {
    opacity: 0.6;
}
.actions-cell .btn-icon-inactive:hover {
    opacity: 1;
}

.data-table tr:hover {
    background: var(--hover-bg);
}

/* Mobil-responsiv tabell med horisontell scroll */
.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 20px 0;
}

.table-responsive .data-table {
    margin: 0;
    min-width: 600px; /* Säkerställ att tabellen har en minimibredd */
}

/* Touch-vänliga scroll-indikatorer för mobil */
@media (max-width: 768px) {
    .table-responsive {
        position: relative;
    }
    
    .table-responsive::after {
        content: "← Swipea för att se fler kolumner →";
        position: absolute;
        bottom: -25px;
        left: 50%;
        transform: translateX(-50%);
        font-size: 0.8rem;
        color: #666;
        background: rgba(255, 255, 255, 0.9);
        padding: 5px 10px;
        border-radius: 15px;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
        white-space: nowrap;
    }
}

/* === COOKIE CONSENT BANNER === */
.cookie-consent-banner {
    position: fixed;
    bottom: 20px;
    right: 20px;
    left: 20px;
    max-width: 600px;
    margin: 0 auto;
    background: white;
    color: #333;
    padding: 20px;
    z-index: 10000;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    border-radius: 12px;
    border: 1px solid #e9ecef;
}

.cookie-consent-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
}

.cookie-consent-text {
    flex: 1;
    min-width: 250px;
}

.cookie-consent-text h4 {
    margin: 0 0 8px 0;
    font-size: 1rem;
    font-weight: 600;
    color: #2c3e50;
}

.cookie-consent-text p {
    margin: 0 0 8px 0;
    font-size: 0.9rem;
    line-height: 1.4;
    color: #666;
}

.cookie-consent-text p:last-child {
    margin-bottom: 0;
}

.cookie-link {
    color: #667eea !important;
    text-decoration: underline !important;
    font-weight: 500;
}

.cookie-link:hover {
    color: #5a67d8 !important;
}

.cookie-consent-buttons {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
}

.btn-cookie-accept-all,
.btn-cookie-necessary {
    padding: 8px 16px;
    border: none;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

/* === OMRÖSTNINGS-POPUP (diskret) === */
.poll-popup-container {
    position: fixed;
    bottom: 24px;
    right: 24px;
    max-width: 340px;
    z-index: 9999;
}

.poll-popup {
    background: var(--card-bg);
    color: var(--text-color);
    padding: 16px;
    border-radius: 10px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
    border: 1px solid var(--border-color);
    position: relative;
}

.poll-popup-close {
    position: absolute;
    top: 8px;
    right: 10px;
    background: none;
    border: none;
    font-size: 1.4rem;
    line-height: 1;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    width: 24px;
    height: 24px;
}

.poll-popup-close:hover {
    color: var(--text-color);
}

.poll-popup-title {
    margin: 0 24px 12px 0;
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.3;
}

.poll-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 12px;
}

.poll-option-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
    cursor: pointer;
}

.poll-text-wrapper,
.poll-comment-wrapper {
    margin-bottom: 12px;
}

.poll-text-wrapper label,
.poll-comment-wrapper label {
    display: block;
    font-size: 0.85rem;
    margin-bottom: 4px;
    color: var(--text-secondary);
}

.poll-text-wrapper input,
.poll-comment-wrapper textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-size: 0.9rem;
    background: var(--bg-color);
    color: var(--text-color);
}

.poll-popup-actions {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}

@media (max-width: 480px) {
    .poll-popup-container {
        bottom: 16px;
        right: 16px;
        left: 16px;
        max-width: none;
    }
}

/* Se till att toppmenyn alltid är vit, även för besökta länkar och i dark mode */
header nav > a:visited,
header nav > span:visited {
    color: white !important;
}

header nav > a:link {
    color: white !important;
}

[data-theme="dark"] header nav > a,
[data-theme="dark"] header nav > a:visited,
[data-theme="dark"] header nav > span,
[data-theme="dark"] header nav > span:visited {
    color: white;
}

.btn-cookie-accept-all {
    background: #28a745;
    color: white;
}

.btn-cookie-accept-all:hover {
    background: #218838;
    transform: translateY(-1px);
}

.btn-cookie-necessary {
    background: #6c757d;
    color: white;
}

.btn-cookie-necessary:hover {
    background: #5a6268;
    transform: translateY(-1px);
}

/* Mobil responsivitet för cookie banner */
@media (max-width: 768px) {
    .cookie-consent-banner {
        bottom: 15px;
        right: 15px;
        left: 15px;
        padding: 15px;
    }
    
    .cookie-consent-content {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    
    .cookie-consent-text {
        min-width: auto;
        text-align: center;
    }
    
    .cookie-consent-buttons {
        justify-content: center;
        flex-wrap: wrap;
    }
    
    .btn-cookie-accept-all,
    .btn-cookie-necessary {
        flex: 1;
        min-width: 100px;
    }
}

@media (max-width: 480px) {
    .cookie-consent-banner {
        bottom: 10px;
        right: 10px;
        left: 10px;
        padding: 12px;
    }
    
    .cookie-consent-text h4 {
        font-size: 0.95rem;
    }
    
    .cookie-consent-text p {
        font-size: 0.8rem;
    }
    
    .btn-cookie-accept-all,
    .btn-cookie-necessary {
        padding: 6px 12px;
        font-size: 0.8rem;
    }
}

/* === GDPR PAGE STYLES === */
.gdpr-page {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
}

.gdpr-intro {
    text-align: center;
    margin-bottom: 40px;
    padding: 30px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-radius: 12px;
    border-left: 4px solid #667eea;
    transition: background 0.3s ease;
}

[data-theme="dark"] .gdpr-intro {
    background: var(--card-bg);
    border-left-color: var(--accent-primary);
    border: 1px solid var(--border-color);
}

.gdpr-intro .lead {
    font-size: 1.2rem;
    color: #495057;
    margin: 0;
    font-weight: 500;
}

[data-theme="dark"] .gdpr-intro .lead {
    color: var(--text-primary);
}

.gdpr-content {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.gdpr-section {
    background: white;
    padding: 25px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    border-left: 4px solid #28a745;
}

.gdpr-section h3 {
    color: #2c3e50;
    margin-bottom: 15px;
    font-size: 1.3rem;
    font-weight: 600;
}

.gdpr-section h4 {
    color: #34495e;
    margin: 15px 0 8px 0;
    font-size: 1.1rem;
    font-weight: 600;
}

.gdpr-section p {
    color: #555;
    line-height: 1.6;
    margin-bottom: 12px;
}

.gdpr-section ul {
    margin: 10px 0;
    padding-left: 20px;
}

.gdpr-section li {
    color: #555;
    margin-bottom: 6px;
    line-height: 1.5;
}

.cookie-types {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.cookie-type {
    background: #f8f9fa;
    padding: 20px;
    border-radius: 8px;
    border: 1px solid #e9ecef;
}

.cookie-type h4 {
    color: #495057;
    margin-bottom: 10px;
}

.cookie-duration {
    background: #e3f2fd;
    padding: 15px;
    border-radius: 6px;
    border-left: 4px solid #2196f3;
}

.user-rights {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 15px;
}

.right-item {
    background: #f8f9fa;
    padding: 15px;
    border-radius: 6px;
    border-left: 3px solid #17a2b8;
}

.right-item h4 {
    color: #17a2b8;
    margin-bottom: 8px;
    font-size: 1rem;
}

.contact-info {
    background: #fff3cd;
    padding: 15px;
    border-radius: 6px;
    border-left: 4px solid #ffc107;
}

.contact-info p {
    margin: 8px 0;
}

.contact-info a {
    color: #856404;
    font-weight: 500;
}

.contact-info a:hover {
    text-decoration: underline;
}

/* Mobil responsivitet för GDPR-sidan */
@media (max-width: 768px) {
    .gdpr-page {
        padding: 15px;
    }
    
    .gdpr-intro {
        padding: 20px 15px;
    }
    
    .gdpr-section {
        padding: 20px 15px;
    }
    
    .user-rights {
        grid-template-columns: 1fr;
    }
    
    .cookie-types {
        gap: 15px;
    }
    
    .cookie-type {
        padding: 15px;
    }
}

.badge {
    display: inline-block;
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 600;
    letter-spacing: 0.3px;
}

.badge-success {
    background: #d1fae5;
    color: #065f46;
}

[data-theme="dark"] .badge-success {
    background: rgba(34, 197, 94, 0.2);
    color: #86efac;
}

.badge-inactive {
    background: #fee2e2;
    color: #991b1b;
}

[data-theme="dark"] .badge-inactive {
    background: rgba(220, 38, 38, 0.2);
    color: #fca5a5;
}

.filter-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.tab {
    padding: 12px 24px;
    background: var(--card-bg);
    border: 1.5px solid var(--border-color);
    border-radius: 10px;
    text-decoration: none;
    color: var(--text-primary);
    font-weight: 500;
    transition: all 0.3s ease;
}

.tab:hover {
    background: var(--hover-bg);
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.tab.active {
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    color: white;
    border-color: var(--accent-primary);
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
}

.modal {
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal-content {
    background-color: var(--card-bg);
    /* Mer centrerad modal (inte "kant i kant" längst ner) */
    margin: 5vh auto;
    padding: 40px;
    border-radius: 16px;
    max-width: 600px;
    max-height: 90vh;
    overflow: auto;
    position: relative;
    transition: background 0.3s ease;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    border: 1px solid var(--border-color);
}

[data-theme="dark"] .modal-content {
    background-color: var(--card-bg);
    border-color: var(--border-color);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

.close {
    position: absolute;
    right: 20px;
    top: 20px;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    color: var(--text-muted);
    transition: color 0.3s ease;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
}

.close:hover {
    color: var(--text-primary);
    background: var(--hover-bg);
}

.danger-zone {
    margin-top: 40px;
    padding: 20px;
    background: #ffe6e6;
    border: 2px solid #e74c3c;
    border-radius: 8px;
}

.danger-zone h3 {
    color: #c0392b;
    margin-bottom: 15px;
}

.text-success {
    color: #27ae60;
    font-weight: bold;
}

.text-warning {
    color: #f39c12;
    font-weight: bold;
}

.text-danger {
    color: #e74c3c;
    font-weight: bold;
}

.form-section,
.filter-section,
.results-section {
    background: var(--bg-secondary);
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 20px;
    transition: background 0.3s ease;
}

/* === ABOUT PAGES === */
.about-page {
    max-width: 1200px;
    margin: 0 auto;
}

.about-intro {
    text-align: center;
    margin: 40px 0;
}

.about-intro .lead {
    font-size: 1.5rem;
    color: var(--text-primary);
    font-weight: 500;
    line-height: 1.7;
    max-width: 800px;
    margin: 0 auto;
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 25px;
    margin: 40px 0;
}

.feature-card {
    background: var(--card-bg);
    padding: 36px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    text-align: center;
    transition: all 0.3s ease;
}

[data-theme="dark"] .feature-card {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.feature-card:hover {
    border-color: var(--accent-primary);
    transform: translateY(-6px);
    box-shadow: 0 12px 32px var(--shadow-hover);
}

[data-theme="dark"] .feature-card:hover {
    background: #1e293b;
    box-shadow: 0 12px 32px rgba(14, 165, 233, 0.25);
}

.feature-icon {
    font-size: 3rem;
    margin-bottom: 15px;
    display: block;
}

.feature-icon-inline {
    font-size: 1.5rem;
    margin-right: 10px;
}

.feature-card h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: -0.5px;
}

.feature-card p {
    color: var(--text-secondary);
    line-height: 1.7;
    font-size: 1rem;
}

.benefits-section {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 60px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    margin: 60px 0;
    transition: background 0.3s ease;
}

[data-theme="dark"] .benefits-section {
    background: var(--card-bg);
    border-color: var(--border-color);
}

[data-theme="dark"] .benefits-section {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.benefits-section h2 {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--text-primary);
    text-align: center;
    margin-bottom: 40px;
    letter-spacing: -1px;
}

.benefits-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
}

.benefit-item {
    background: var(--card-bg);
    padding: 28px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
}

.benefit-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px var(--shadow-hover);
    border-color: var(--accent-primary);
}

.benefit-item h4 {
    font-size: 1.25rem;
    font-weight: 600;
    color: #22c55e;
    margin-bottom: 12px;
}

.benefit-item p {
    color: var(--text-secondary);
    line-height: 1.7;
    font-size: 1rem;
}

.how-it-works {
    margin: 40px 0;
}

.how-it-works h2 {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--text-primary);
    text-align: center;
    margin-bottom: 40px;
    letter-spacing: -1px;
}

.steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 25px;
}

.step {
    text-align: center;
}

.step-number {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    font-weight: 800;
    margin: 0 auto 20px;
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
}

.step h4 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 12px;
}

.step p {
    color: var(--text-secondary);
    font-size: 1rem;
    line-height: 1.7;
}

.cta-section {
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    color: white;
    padding: 80px 60px;
    border-radius: 20px;
    text-align: center;
    margin: 60px 0;
    box-shadow: 0 8px 32px rgba(14, 165, 233, 0.3);
}

.cta-section h2 {
    font-size: 2.5rem;
    font-weight: 800;
    margin-bottom: 20px;
    letter-spacing: -1px;
}

.cta-section p {
    font-size: 1.25rem;
    margin-bottom: 32px;
    opacity: 0.95;
    line-height: 1.7;
}

/* === FOOTER === */
.site-footer {
    background: var(--footer-bg, #2c3e50);
    color: var(--footer-text, white);
    padding: 40px 30px 20px;
    margin-top: 50px;
}

[data-theme="dark"] .site-footer {
    --footer-bg: #0f172a;
    --footer-text: #f1f5f9;
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto 30px;
}

.footer-section h4 {
    color: var(--footer-heading, white);
    margin-bottom: 15px;
}

[data-theme="dark"] .footer-section h4 {
    --footer-heading: #f1f5f9;
}

.footer-section p {
    color: var(--footer-muted, #bdc3c7);
    margin: 0;
}

.footer-section p {
    margin: 5px 0;
}

[data-theme="dark"] .footer-section p {
    --footer-muted: #94a3b8;
}

.footer-link {
    color: var(--footer-link, #bdc3c7);
    text-decoration: none;
}

.footer-link:hover {
    color: var(--footer-link-hover, white) !important;
}

[data-theme="dark"] .footer-link {
    --footer-link: #94a3b8;
    --footer-link-hover: #f1f5f9;
}

.footer-section a {
    transition: color 0.3s;
}

.footer-section a:hover {
    color: var(--footer-link-hover, white) !important;
}

.social-share {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all 0.3s;
}

.share-btn:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-2px);
}

.share-btn.facebook:hover {
    background: #1877f2;
}

.share-btn.twitter:hover {
    background: #1da1f2;
}

.share-btn.email:hover {
    background: #ea4335;
}

.share-btn.whatsapp:hover {
    background: #25d366;
}

.share-btn.copy:hover {
    background: #667eea;
}

.footer-bottom {
    text-align: center;
    padding-top: 20px;
    border-top: 1px solid var(--footer-border, rgba(255, 255, 255, 0.1));
    color: var(--footer-muted, #bdc3c7);
}

[data-theme="dark"] .footer-bottom {
    --footer-border: rgba(255, 255, 255, 0.08);
}

.alert-link {
    color: inherit;
    text-decoration: underline;
    font-weight: 600;
}

/* === SORTABLE TABLE === */
th.sortable {
    cursor: pointer;
    user-select: none;
    position: relative;
    padding-right: 25px;
}

th.sortable:hover {
    background: linear-gradient(135deg, #5568d3 0%, #6a3e8f 100%);
}

.sort-icon {
    position: absolute;
    right: 8px;
    opacity: 0.3;
    transition: opacity 0.3s;
}

/* === CLASS ASSIGNMENT IN PROFILE === */
.class-assignment {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 4px 0;
}

.btn-toggle-small {
    padding: 4px 8px;
    font-size: 0.8rem;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-weight: 600;
    transition: all 0.3s;
}

.btn-toggle-small.active {
    background: #d4edda;
    color: #155724;
}

.btn-toggle-small.inactive {
    background: #f8d7da;
    color: #721c24;
}

.btn-toggle-small:hover {
    opacity: 0.8;
    transform: scale(1.05);
}

/* === STATISTIK/DIAGRAM === */
.stats-overview {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin: 30px 0;
}

.stat-box {
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%);
    color: white;
    padding: 32px;
    border-radius: 16px;
    text-align: center;
    box-shadow: 0 4px 16px rgba(14, 165, 233, 0.3);
    transition: transform 0.3s ease;
}

.stat-box:hover {
    transform: translateY(-4px);
}

.stat-box h3 {
    font-size: 2.5rem;
    margin-bottom: 5px;
}

.stat-box p {
    font-size: 1rem;
    opacity: 0.9;
}

.chart-section {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    padding: 40px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    margin: 32px 0;
    transition: background 0.3s ease;
}

[data-theme="dark"] .chart-section {
    background: var(--card-bg);
    border-color: var(--border-color);
}

.chart-section h3 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 24px;
    letter-spacing: -0.5px;
}

.chart-stats {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.chart-stats span {
    color: var(--text-secondary);
}

.chart-stats strong {
    color: var(--text-primary);
}

/* === RESPONSIVE MOBIL EXTRA === */
@media (max-width: 768px) {
    .recent-tests-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }
    
    /* Visa bara 6 test på mobil (dölj de sista 2) */
    .recent-tests-grid .recent-test-card:nth-child(n+7) {
        display: none;
    }
    
    .stats-overview {
        grid-template-columns: 1fr;
    }
    
    .features-grid {
        grid-template-columns: 1fr;
    }
    
    .class-assignment {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .footer-content {
        grid-template-columns: 1fr;
        text-align: center;
    }
    
    .social-share {
        justify-content: center;
    }
}

/* === PRINT === */
@media print {
    header nav,
    .action-buttons,
    .practice-settings,
    .practice-actions,
    footer,
    .danger-zone {
        display: none;
    }
    
    body {
        background: white;
    }
    
    .container {
        box-shadow: none;
    }
}

/* === GLOSPROV FORM === */
.glosprov-form {
    background: var(--bg-primary);
    padding: 30px;
    border-radius: 12px;
    box-shadow: 0 2px 4px var(--shadow);
    margin-bottom: 30px;
    transition: background 0.3s ease, box-shadow 0.3s ease;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-bottom: 15px;
}

.glosprov-form .form-group {
    margin-bottom: 20px;
}

.glosprov-form .form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: var(--text-primary);
    font-size: 15px;
}

.glosprov-form .form-group input[type="text"],
.glosprov-form .form-group input[type="number"],
.glosprov-form .form-group input[type="date"],
.glosprov-form .form-group input[type="time"],
.glosprov-form .form-group select {
    width: 100%;
    padding: 14px 18px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 16px;
    transition: all 0.3s ease;
    background: var(--bg-primary);
    color: var(--text-primary);
}

.glosprov-form .form-group input[type="text"]:focus,
.glosprov-form .form-group input[type="number"]:focus,
.glosprov-form .form-group input[type="date"]:focus,
.glosprov-form .form-group input[type="time"]:focus,
.glosprov-form .form-group select:focus {
    outline: none;
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.glosprov-form .radio-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 15px;
    background: var(--bg-secondary);
    border-radius: 10px;
    transition: background 0.3s ease;
}

.glosprov-form .radio-group label {
    display: flex;
    align-items: center;
    font-weight: normal;
    padding: 10px;
    border-radius: 8px;
    transition: background 0.2s ease;
    cursor: pointer;
}

.glosprov-form .radio-group label:hover {
    background: var(--hover-bg);
}

.glosprov-form .radio-group input[type="radio"] {
    margin-right: 10px;
    width: 18px;
    height: 18px;
    cursor: pointer;
}

.info-box {
    background: var(--hover-bg);
    padding: 15px;
    border-radius: 5px;
    margin-bottom: 20px;
    border-left: 4px solid var(--accent-primary);
    transition: background 0.3s ease;
}

.info-icon {
    position: relative;
    display: inline-block;
    margin-left: 8px;
    cursor: help;
    font-size: 16px;
    color: var(--accent-primary);
    vertical-align: middle;
}

.info-icon:hover::after {
    content: attr(data-title);
    position: absolute;
    left: 50%;
    bottom: 100%;
    transform: translateX(-50%);
    margin-bottom: 8px;
    padding: 12px 16px;
    background: #333;
    color: white;
    border-radius: 6px;
    white-space: normal;
    width: 300px;
    font-size: 14px;
    line-height: 1.4;
    z-index: 1000;
    box-shadow: 0 4px 6px rgba(0,0,0,0.2);
    pointer-events: none;
}

.info-icon:hover::before {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 100%;
    transform: translateX(-50%);
    margin-bottom: 2px;
    border: 6px solid transparent;
    border-top-color: #333;
    z-index: 1001;
    pointer-events: none;
}

.warning-box {
    background: #fff3cd;
    padding: 15px;
    border-radius: 5px;
    margin-bottom: 20px;
    border-left: 4px solid #ffc107;
}

[data-theme="dark"] .warning-box {
    background: rgba(255, 193, 7, 0.2);
    color: #ffd43b;
}

/* Tree-view för testval */
#testTreeView {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.tree-folder {
    margin-bottom: 5px;
}

.tree-folder-header {
    padding: 8px;
    cursor: pointer;
    border-radius: 4px;
    transition: background 0.2s;
    user-select: none;
}

.tree-folder-header:hover {
    background: var(--hover-bg) !important;
}

.tree-icon {
    margin-right: 6px;
    font-size: 1.1em;
}

.tree-folder-content {
    margin-left: 20px;
    margin-top: 5px;
}

.tree-test {
    padding: 6px 8px;
    margin: 2px 0;
    border-radius: 4px;
    cursor: pointer;
    transition: background 0.2s;
    display: flex;
    align-items: center;
}

.tree-test:hover {
    background: #e7f3ff !important;
}

.tree-test input[type="radio"] {
    margin-right: 8px;
    cursor: pointer;
}

.tree-test label {
    cursor: pointer;
    margin: 0;
    flex: 1;
}

/* Navigation dropdown */
header nav .nav-dropdown {
    position: relative;
    display: inline-block;
    flex-shrink: 0;
}

header nav .nav-dropdown-toggle {
    cursor: pointer;
    display: inline-block;
    color: white !important;
    font-family: inherit !important;
    font-size: 0.9rem !important;
    font-weight: normal !important;
    text-decoration: none !important;
    padding: 6px 10px !important;
    border-radius: 6px !important;
    transition: background 0.3s !important;
    white-space: nowrap !important;
}

header nav .nav-dropdown-toggle:hover {
    opacity: 0.8;
    color: white !important;
    background: rgba(255, 255, 255, 0.2) !important;
}

header nav .nav-dropdown-content {
    display: none !important;
    position: absolute !important;
    background: white !important;
    min-width: 200px;
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
    z-index: 1000;
    border-radius: 4px;
    padding: 5px 0;
    margin-top: 0 !important;
    padding-top: 8px !important;
    top: 100% !important;
    left: 0 !important;
    flex: none !important;
    flex-direction: column !important;
    width: auto !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

header nav .nav-dropdown-content a {
    display: block !important;
    padding: 10px 15px;
    text-decoration: none;
    color: #333 !important;
    border-bottom: 1px solid #eee;
    transition: background 0.2s;
    white-space: nowrap;
}

header nav .nav-dropdown-content a:last-child {
    border-bottom: none;
}

header nav .nav-dropdown-content a:hover {
    background: #f5f5f5;
    color: #333 !important;
}

header nav .nav-dropdown:hover .nav-dropdown-content,
header nav .nav-dropdown-content:hover {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

/* === FEATURES COMPARISON TABLE === */
.checkmark {
    color: #28a745;
    font-weight: bold;
    font-size: 1.2em;
}

.cross {
    color: #dc3545;
    font-weight: bold;
    font-size: 1.2em;
}

/* === GLOBAL HOVER-EFFEKT FÖR LÅNGA TABELLER === */
/* Hover-effekt för alla data-table tabeller som kan bli långa */
.data-table tbody tr {
    transition: background-color 0.2s ease;
}

.data-table tbody tr:hover,
.data-table tbody tr:first-child:hover {
    background-color: #f1f5f9 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .data-table tbody tr:hover,
[data-theme="dark"] .data-table tbody tr:first-child:hover {
    background-color: #334155 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.data-table tbody tr:hover td,
.data-table tbody tr:first-child:hover td {
    background-color: transparent !important;
}

/* Fixa länkfärg i ljust läge vid hover */
.data-table tbody tr:hover a,
.data-table tbody tr:first-child:hover a {
    color: #2563eb !important;
}

[data-theme="dark"] .data-table tbody tr:hover a,
[data-theme="dark"] .data-table tbody tr:first-child:hover a {
    color: #60a5fa !important;
}

/* Ikonknappar ska bara byta färg vid hover på ikonen, inte på raden */
.data-table tbody tr:hover .actions-cell .btn-icon,
.data-table tbody tr:first-child:hover .actions-cell .btn-icon {
    color: var(--text-primary) !important;
}
[data-theme="dark"] .data-table tbody tr:hover .actions-cell .btn-icon,
[data-theme="dark"] .data-table tbody tr:first-child:hover .actions-cell .btn-icon {
    color: var(--text-primary) !important;
}



/* === Design v6 (gp6) - tidigare index6.css === */

:root {
    /* Ljust läge: vanliga färger (cyan/blå som style.css) */
    --gp6-bg: #f8fafc;
    --gp6-bg-warm: #f1f5f9;
    --gp6-bg-card: #ffffff;
    --gp6-primary: #0ea5e9;
    --gp6-primary-light: #06b6d4;
    --gp6-accent: #0ea5e9;
    --gp6-accent-light: #06b6d4;
    --gp6-slate: #212529;
    --gp6-slate-light: #495057;
    --gp6-slate-muted: #6c757d;
    --gp6-border: #e5e7eb;
    --gp6-shadow: 0 4px 20px rgba(14, 165, 233, 0.08);
    --gp6-shadow-hover: 0 12px 40px rgba(14, 165, 233, 0.12);
    --gp6-radius: 20px;
    --gp6-radius-sm: 12px;
    --gp6-sidebar-width: 260px;
}

[data-theme="dark"] {
    --gp6-bg: #0f172a;
    --gp6-bg-warm: #1e293b;
    --gp6-bg-card: #1e293b;
    --gp6-primary: #818cf8;
    --gp6-primary-light: #a5b4fc;
    --gp6-accent: #fbbf24;
    --gp6-accent-light: #fcd34d;
    --gp6-slate: #f1f5f9;
    --gp6-slate-light: #cbd5e1;
    --gp6-slate-muted: #94a3b8;
    --gp6-border: #334155;
    --gp6-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    --gp6-shadow-hover: 0 12px 40px rgba(129, 140, 248, 0.2);
}

/* === LAYOUT === */
body.gp6-body,
body.gp6-body * {
    box-sizing: border-box;
}

body.gp6-body {
    font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    background: var(--gp6-bg);
    color: var(--gp6-slate);
    line-height: 1.6;
    min-height: 100vh;
    padding: 0;
    margin: 0;
    overflow-x: hidden;
}

.gp6-layout {
    display: flex;
    min-height: 100vh;
}

/* === SIDOMENY – Experiment: flytande, rundad, kollapsbar === */
.gp6-sidebar {
    position: fixed;
    top: 16px;
    left: 16px;
    bottom: 16px;
    width: calc(var(--gp6-sidebar-width) - 8px);
    max-height: calc(100vh - 32px);
    background: var(--gp6-bg-card);
    border-radius: var(--gp6-radius);
    border: 1px solid var(--gp6-border);
    box-shadow: var(--gp6-shadow);
    display: flex;
    flex-direction: column;
    z-index: 100;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.35s, width 0.35s;
}

.gp6-sidebar.collapsed {
    transform: translateX(calc(-100% - 24px));
}

.gp6-sidebar-toggle {
    position: absolute;
    top: 50%;
    right: -14px;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 50%;
    background: var(--gp6-primary);
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    line-height: 1;
    box-shadow: var(--gp6-shadow);
    z-index: 10;
    transition: background 0.2s, transform 0.2s;
}

.gp6-sidebar-toggle:hover {
    background: var(--gp6-primary-light);
    transform: translateY(-50%) scale(1.1);
}

.gp6-sidebar-expand {
    position: fixed;
    top: 50%;
    left: 16px;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 10px;
    background: var(--gp6-primary);
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1;
    box-shadow: var(--gp6-shadow);
    z-index: 99;
    transition: background 0.2s, transform 0.2s;
}

.gp6-sidebar-expand:hover {
    background: var(--gp6-primary-light);
    transform: translateY(-50%) scale(1.05);
}

.gp6-sidebar-header {
    padding: 20px 20px 16px;
    border-bottom: 1px solid var(--gp6-border);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.gp6-sidebar-clock {
    font-family: ui-monospace, 'Cascadia Code', 'Source Code Pro', monospace;
    font-size: 0.85rem;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--gp6-slate-muted);
    margin-top: 10px;
    letter-spacing: 0.05em;
}

.gp6-sidebar-footer .gp6-sidebar-userinfo {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--gp6-slate-light);
    margin-bottom: 12px;
    line-height: 1.5;
    width: 100%;
    text-align: center;
}

.gp6-logo {
    font-family: 'Outfit', sans-serif;
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--gp6-primary);
    text-decoration: none;
    letter-spacing: -0.5px;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: color 0.2s ease;
}

.gp6-logo:hover {
    color: var(--gp6-accent);
}

.gp6-logo-icon {
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}

.gp6-logo-text {
    white-space: nowrap;
}

.gp6-nav {
    flex: 1;
    padding: 16px 12px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--gp6-border) transparent;
}

[data-theme="dark"] .gp6-nav {
    scrollbar-color: rgba(255, 255, 255, 0.15) transparent;
}

.gp6-nav::-webkit-scrollbar {
    width: 8px;
}

.gp6-nav::-webkit-scrollbar-track {
    background: transparent;
}

.gp6-nav::-webkit-scrollbar-thumb {
    background: var(--gp6-border);
    border-radius: 4px;
}

.gp6-nav::-webkit-scrollbar-thumb:hover {
    background: var(--gp6-slate-muted);
}

[data-theme="dark"] .gp6-nav::-webkit-scrollbar-track {
    background: transparent;
}

[data-theme="dark"] .gp6-nav::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.15);
    border-radius: 4px;
}

[data-theme="dark"] .gp6-nav::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.25);
}

.gp6-nav-section {
    margin-bottom: 20px;
}

.gp6-nav-section:last-child {
    margin-bottom: 0;
}

.gp6-nav-label {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--gp6-slate-muted);
    padding: 0 10px 6px;
    text-align: center;
}

.gp6-nav-divider {
    border: 0;
    height: 1px;
    margin: 14px 12px;
    background: linear-gradient(90deg, transparent, var(--gp6-border) 15%, var(--gp6-border) 85%, transparent);
    opacity: 0.9;
}

[data-theme="dark"] .gp6-nav-divider {
    background: linear-gradient(90deg, transparent, var(--gp6-border) 15%, var(--gp6-border) 85%, transparent);
}

.gp6-nav-divider-dashed {
    background: none;
    border-top: 1px dashed var(--gp6-border);
}

.gp6-account-label {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 4px 6px;
}

.gp6-account-label .gp6-nav-username {
    text-transform: none;
    font-weight: 600;
    font-size: 0.75rem;
    color: var(--gp6-slate-light);
    overflow-wrap: break-word;
    word-break: break-word;
}

.gp6-nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 10px;
    text-decoration: none;
    color: var(--gp6-slate-light);
    font-weight: 600;
    font-size: 0.9rem;
    transition: all 0.2s ease;
    margin-bottom: 2px;
    border: 1px solid transparent;
}

.gp6-nav-link:hover {
    color: var(--gp6-primary);
    background: rgba(79, 70, 229, 0.08);
}

.gp6-nav-link.gp6-nav-active {
    color: white;
    background: linear-gradient(135deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
}

.gp6-nav-link.gp6-nav-cta {
    color: var(--gp6-slate-light);
    background: transparent;
}

.gp6-nav-link.gp6-nav-cta:hover {
    color: var(--gp6-primary);
    background: rgba(79, 70, 229, 0.08);
}

.gp6-nav-icon {
    width: 20px;
    text-align: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.material-symbols-outlined {
    font-family: 'Material Symbols Outlined';
    font-weight: normal;
    font-style: normal;
    font-size: inherit;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    word-wrap: normal;
    direction: ltr;
    font-feature-settings: 'liga';
    -webkit-font-feature-settings: 'liga';
    -webkit-font-smoothing: antialiased;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.gp6-icon-inline {
    font-size: 1.1em;
    vertical-align: -0.15em;
}

.gp6-nav-notif-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.gp6-nav-notif-badge {
    position: absolute;
    top: -6px;
    right: -8px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    font-size: 0.7rem;
    font-weight: 700;
    line-height: 16px;
    text-align: center;
    color: white;
    background: #ef4444;
    border-radius: 10px;
}

.gp6-nav-msg-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    margin-left: 6px;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1;
    color: white;
    background: var(--gp6-accent-primary, #4f46e5);
    border-radius: 10px;
}

.gp6-sidebar-footer {
    padding: 20px 16px;
    border-top: 1px solid var(--gp6-border);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

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

.gp6-theme-label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: var(--gp6-radius-sm);
    background: var(--gp6-bg-warm);
    color: var(--gp6-slate-light);
    cursor: pointer;
    transition: all 0.2s;
}

.gp6-theme-label:hover {
    background: rgba(79, 70, 229, 0.1);
    color: var(--gp6-primary);
}

.gp6-theme-label .theme-toggle-switch { flex-shrink: 0; }
.gp6-theme-text {
    font-weight: 600;
    font-size: 0.9rem;
}

/* Slider-färger: tydlig spår och tumme i både ljust och mörkt läge */
.gp6-theme-label .theme-toggle-switch {
    background: var(--gp6-border);
    border: 2px solid var(--gp6-slate-muted);
}
.gp6-theme-label .theme-toggle-switch:hover {
    background: var(--gp6-slate-muted);
}
.gp6-theme-label .theme-toggle-switch:checked {
    background: rgba(99, 102, 241, 0.4);
    border-color: var(--gp6-primary);
}
.gp6-theme-label .theme-toggle-switch:checked:hover {
    background: rgba(99, 102, 241, 0.5);
}

/* Sol/måne-ikon i slide-knappen */
.gp6-theme-label .theme-toggle-switch::before {
    content: '\2600';
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    color: #b45309;
    background: #fef3c7;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.gp6-theme-label .theme-toggle-switch:checked::before {
    content: '\263E';
    color: #c4b5fd;
    background: #312e81;
    box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

.gp6-logout-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--gp6-radius-sm);
    background: var(--gp6-bg-warm);
    color: var(--gp6-slate-light);
    transition: all 0.2s;
}
.gp6-logout-btn:hover {
    background: rgba(239, 68, 68, 0.15);
    color: #ef4444;
}

.gp6-sidebar-notif-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--gp6-radius-sm);
    background: var(--gp6-bg-warm);
    color: var(--gp6-slate-light);
    text-decoration: none;
    transition: all 0.2s;
}

.gp6-sidebar-notif-btn:hover,
.gp6-sidebar-notif-btn.active {
    background: rgba(79, 70, 229, 0.1);
    color: var(--gp6-primary);
}

/* === MAIN === */
.gp6-main {
    flex: 1;
    margin-left: calc(var(--gp6-sidebar-width) + 24px);
    min-width: 0;
    display: flex;
    flex-direction: column;
    transition: margin-left 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.gp6-sidebar.collapsed ~ .gp6-main {
    margin-left: 24px;
}

.gp6-content {
    flex: 1;
    padding: 20px 32px 48px;
    max-width: 1500px;
    margin: 0 auto;
    width: 100%;
}

/* Mobil */
.gp6-menu-toggle {
    display: none;
    position: fixed;
    top: 20px;
    left: 20px;
    z-index: 1001;
    width: 48px;
    height: 48px;
    border: none;
    background: var(--gp6-bg-card);
    border-radius: 14px;
    cursor: pointer;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    box-shadow: var(--gp6-shadow);
}

.gp6-menu-toggle span {
    width: 22px;
    height: 2.5px;
    background: var(--gp6-primary);
    border-radius: 2px;
    transition: all 0.3s ease;
}

.gp6-menu-toggle.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.gp6-menu-toggle.active span:nth-child(2) { opacity: 0; }

.gp6-menu-toggle.active span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

.gp6-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 99;
    opacity: 0;
    transition: opacity 0.3s;
}

.gp6-sidebar-overlay.open {
    display: block;
    opacity: 1;
}

/* När uppdateringsbanner är aktiv – sänk meny-knappen så den inte täcks */
body.update-banner-active .gp6-menu-toggle {
    top: 60px;
}

@media (max-width: 900px) {
    .gp6-menu-toggle { display: flex; }
    .gp6-sidebar-toggle,
    .gp6-sidebar-expand { display: none !important; }
    .gp6-sidebar {
        top: 0;
        left: 0;
        bottom: 0;
        width: var(--gp6-sidebar-width);
        max-height: none;
        border-radius: 0;
        transform: translateX(-100%);
        box-shadow: 8px 0 40px rgba(0, 0, 0, 0.15);
    }
    .gp6-sidebar.open { transform: translateX(0); }
    .gp6-sidebar.collapsed { transform: translateX(-100%); }
    .gp6-main { margin-left: 0; }
    .gp6-sidebar.collapsed ~ .gp6-main { margin-left: 0; }
    .gp6-content { padding: 60px 16px 32px; }
    .gp6-hero { padding: 36px 16px 40px; margin-bottom: 32px; }
}

@media (max-width: 480px) {
    .gp6-content { padding: 56px 12px 24px; }
    .gp6-hero { padding: 28px 12px 32px; margin-bottom: 24px; }
}

/* === HERO – Ny stil === */
.gp6-hero {
    text-align: center;
    padding: 48px 24px 56px;
    position: relative;
    background: linear-gradient(180deg, rgba(79, 70, 229, 0.04) 0%, transparent 100%);
    border-radius: var(--gp6-radius);
    margin-bottom: 40px;
}

.gp6-hero-badge {
    display: inline-block;
    font-size: 0.8rem;
    font-weight: 700;
    padding: 6px 14px;
    background: linear-gradient(135deg, var(--gp6-accent) 0%, var(--gp6-accent-light) 100%);
    color: #1e293b;
    border-radius: 999px;
    margin-bottom: 20px;
    letter-spacing: 0.5px;
}

.gp6-hero h1 {
    font-family: 'Outfit', sans-serif;
    font-size: clamp(2rem, 4.5vw, 2.75rem);
    font-weight: 800;
    color: var(--gp6-slate);
    line-height: 1.2;
    margin-bottom: 16px;
    letter-spacing: -0.5px;
}

.gp6-hero h1 span {
    background: linear-gradient(135deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.gp6-hero p {
    font-size: 1.1rem;
    color: var(--gp6-slate-light);
    max-width: 500px;
    margin: 0 auto 24px;
    line-height: 1.7;
}

.gp6-hero-search {
    display: flex;
    gap: 12px;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    max-width: 440px;
    margin: 0 auto;
}

/* Gäster: dölj hero-search på desktop (bento-grid sökruta finns där) */
.gp6-hero-search-guest {
    display: none;
}

.gp6-hero-search input {
    flex: 1;
    min-width: 180px;
    padding: 14px 18px;
    font-size: 1rem;
    border: 2px solid var(--gp6-border);
    border-radius: var(--gp6-radius-sm);
    background: var(--gp6-bg-card);
    color: var(--gp6-slate);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.gp6-hero-search input:focus {
    outline: none;
    border-color: var(--gp6-primary);
    box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12);
}

@media (max-width: 768px) {
    /* Gäster: visa hero-search på mobil */
    .gp6-hero-search-guest {
        display: flex;
    }
}

@media (max-width: 600px) {
    .gp6-hero-search {
        flex-direction: column;
    }
    .gp6-hero-search input {
        min-width: 100%;
        width: 100%;
    }
    .gp6-hero-search .gp6-btn {
        width: 100%;
    }
}

.gp6-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 24px;
    line-height: 1.25;
    font-weight: 700;
    font-size: 0.95rem;
    border: none;
    border-radius: var(--gp6-radius-sm);
    cursor: pointer;
    text-decoration: none;
    transition: all 0.25s ease;
    box-sizing: border-box;
}

.gp6-btn-small {
    padding: 6px 14px;
    font-size: 0.875rem;
}

.gp6-btn-primary {
    background: linear-gradient(135deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
    color: #fff !important;
    box-shadow: 0 0 14px rgba(79, 70, 229, 0.3);
}

.gp6-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 2px 20px rgba(79, 70, 229, 0.45);
    color: #fff !important;
}

.gp6-btn-secondary {
    background: var(--gp6-bg-warm);
    color: #0c4a6e;
}

.gp6-btn-secondary:hover {
    background: #0369a1;
    color: #fff !important;
}

/* Mörkt tema – tydlig kontrast för alla knappar */
[data-theme="dark"] .gp6-btn-primary {
    background: linear-gradient(135deg, #6366f1 0%, #818cf8 100%);
    color: #fff !important;
}

[data-theme="dark"] .gp6-btn-primary:hover {
    background: #4f46e5;
    color: #fff !important;
}

[data-theme="dark"] .gp6-btn-secondary {
    background: var(--gp6-border);
    color: var(--gp6-slate) !important;
}

[data-theme="dark"] .gp6-btn-secondary:hover {
    background: var(--gp6-primary);
    color: #fff !important;
}

/* === GENERISK SIDINNEHÅLL (about, login, osv) === */
.gp6-page-content {
    padding: 36px 0;
}

.gp6-page-content .auth-form {
    max-width: 600px;
    margin: 0 auto;
}

.gp6-page-content .about-page {
    max-width: 1000px;
    margin: 0 auto;
}

.gp6-page-content .about-page .about-info-section {
    margin: 40px 0;
}

.gp6-page-content .about-page .about-info-section h2 {
    font-family: 'Outfit', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--gp6-slate);
    margin-bottom: 16px;
}

.gp6-page-content .about-page .about-info-section p {
    line-height: 1.8;
    margin-bottom: 20px;
    color: var(--gp6-slate-light);
}

.gp6-page-content .about-page .about-info-section ul {
    list-style: disc;
    padding-left: 1.5em;
    line-height: 2;
}

.gp6-page-content .about-page .about-info-section ul li {
    margin: 12px 0;
}

.gp6-page-content .about-page .cta-section .action-buttons {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

.gp6-page-content .about-page .cta-section .gp6-btn-secondary {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.5);
    color: white;
}

.gp6-page-content .about-page .cta-section .gp6-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.3);
    border-color: white;
}

/* Admin-tabeller utan sidscroll */
.admin-table-fit { overflow-x: visible; max-width: 100%; }
.admin-table-fit .data-table { table-layout: fixed; width: 100%; min-width: 0; }
.admin-table-fit .data-table th,
.admin-table-fit .data-table td { overflow-wrap: break-word; word-wrap: break-word; }
.admin-table-fit .data-table .gp6-btn-small { white-space: nowrap; font-size: 0.85rem; padding: 6px 10px; }

/* På mobil: låt admin-tabeller scrolla i sidled */
@media (max-width: 768px) {
    .admin-table-fit { overflow-x: auto; }
    .admin-table-fit .data-table { table-layout: auto; min-width: 600px; }
}

.gp6-page-content .form-group {
    margin-bottom: 20px;
}

.gp6-page-content .form-group > label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--gp6-slate);
}

/* Radio-knappar i linje med text (t.ex. Vad ska visas? i ordlista) */
.gp6-page-content .form-group .radio-group label {
    display: flex;
    align-items: center;
    font-weight: normal;
}

/* Checkbox- och radiobuttons i linje med text (t.ex. admin/polls.php, index.php) */
.gp6-page-content .form-group label:has(input[type="checkbox"]),
.gp6-page-content .form-group label:has(input[type="radio"]) {
    display: flex !important;
    align-items: center;
    gap: 8px;
    font-weight: normal;
    margin-bottom: 0;
}

/* Övriga sidor med form-group (admin etc) */
.form-group label:has(input[type="checkbox"]),
.form-group label:has(input[type="radio"]) {
    display: flex !important;
    align-items: center;
    gap: 8px;
    font-weight: normal;
}

.gp6-page-content .form-group input:not([type="checkbox"]):not([type="radio"]),
.gp6-page-content .form-group select,
.gp6-page-content .form-group textarea {
    width: 100%;
    padding: 14px 18px;
    border: 2px solid var(--gp6-border);
    border-radius: var(--gp6-radius-sm);
    font-size: 1rem;
    background: var(--gp6-bg-card);
    color: var(--gp6-slate);
}

/* Checkbox/radio i gp6-page-content .form-group – normal storlek */
.gp6-page-content .form-group input[type="checkbox"],
.gp6-page-content .form-group input[type="radio"] {
    width: auto;
    min-width: 18px;
    height: 18px;
    margin: 0;
    flex-shrink: 0;
}

.gp6-page-content .alert {
    padding: 14px 18px;
    border-radius: var(--gp6-radius-sm);
    margin-bottom: 20px;
}

.gp6-page-content .alert-error {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #dc2626;
}

.gp6-page-content .load-test-view,
.gp6-page-content .profile-view,
.gp6-page-content .gdpr-page {
    max-width: 1200px;
    margin: 0 auto;
}

.gp6-page-content .test-card {
    background: var(--gp6-bg-card);
    border: 1px solid var(--gp6-border);
    border-radius: var(--gp6-radius-sm);
    padding: 20px;
}

.gp6-page-content .test-card:hover {
    border-color: var(--gp6-primary);
}

/* Notifications: yttre ram med rundade hörn, samma utökade bredd som ändringar/svåra ord */
body.page-notifications .gp6-page-content .member-view {
    max-width: 1500px;
    margin: 0 auto;
    background: var(--gp6-bg-card) !important;
    border: 1px solid var(--gp6-border) !important;
    border-radius: var(--gp6-radius) !important;
    padding: 24px;
    overflow: hidden;
}

/* Medlemssidor, elevsidor & laddning av test: gemensam ram/kortkänsla */
.gp6-page-content .member-view,
.gp6-page-content .student-view,
.gp6-page-content .load-test-view {
    max-width: 1500px;
    margin: 0 auto;
    background: var(--gp6-bg-card);
    border: 1px solid var(--gp6-border);
    border-radius: var(--gp6-radius);
    padding: 24px;
    overflow: hidden;
}

/* Läraresidor (elever, klasser): samma ram som övriga sidor */
.gp6-page-content .teacher-view {
    max-width: 1500px;
    margin: 0 auto;
    background: var(--gp6-bg-card);
    border: 1px solid var(--gp6-border);
    border-radius: var(--gp6-radius);
    padding: 24px;
    overflow: hidden;
}

/* Meddelanden-sidan: använd full bredd av innehållsytan (som .gp6-content, 1500px) */
body.page-messages .gp6-page-content {
    max-width: 100%;
}
body.page-messages .gp6-page-content .member-view {
    max-width: 100%;
}

/* Visa meddelande (view_message.php): samma bredd som meddelandelistan */
body.page-view-message .gp6-page-content {
    max-width: 100%;
}
body.page-view-message .gp6-page-content .member-view {
    max-width: 100%;
}

/* Svåra ord-vyn: lite bredare ram så korten får mer plats */
.gp6-page-content .member-view.difficult-words-view {
    max-width: 1400px;
}

/* Admin – användarlista: bredare vy utan max-width-begränsning */
body.page-admin-users .gp6-content {
    max-width: none;
}
body.page-admin-users .admin-view {
    max-width: none;
}
body.page-admin-users .admin-table-fit {
    overflow-x: auto;
}
body.page-admin-users .admin-users-table {
    table-layout: auto;
    width: 100%;
    min-width: 1100px;
}

/* Admin – tests + glosprov: samma bredare vy */
body.page-admin-tests .gp6-content,
body.page-admin-glosprov .gp6-content {
    max-width: none;
}
body.page-admin-tests .admin-view,
body.page-admin-glosprov .admin-view {
    max-width: none;
}
body.page-admin-tests .admin-table-fit,
body.page-admin-glosprov .admin-table-fit {
    overflow-x: auto;
}
body.page-admin-tests .admin-table-fit .data-table,
body.page-admin-glosprov .admin-table-fit .data-table {
    table-layout: auto;
    width: 100%;
}

/* Admin – användarlista som kort med ram */
.admin-view .admin-users-card {
    background: var(--gp6-bg-card, #fff);
    border: 1px solid var(--gp6-border, #e5e7eb);
    border-radius: var(--gp6-radius, 12px);
    padding: 20px;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}

.admin-view .admin-users-table td:nth-child(6),
.admin-view .admin-users-table th:nth-child(6),
.admin-view .admin-users-table td:nth-child(7),
.admin-view .admin-users-table th:nth-child(7) {
    white-space: nowrap;
}

.admin-users-lastlogin,
.admin-users-ip {
    font-size: 0.85rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.admin-users-ip {
    max-width: 120px;
    display: inline-block;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: bottom;
}

/* === SENASTE GLOSTEST – Bento-grid + horisontell scroll === */
.gp6-section {
    padding: 36px 0;
}


.gp6-section-title {
    font-family: 'Outfit', sans-serif;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--gp6-slate);
    margin: 0;
}

.gp6-section-hint {
    font-size: 0.9rem;
    color: var(--gp6-slate-muted);
}

/* Dölj "Sök ↓" och "↓ Senaste glostest" på mobil */
@media (max-width: 768px) {
    .gp6-recent-header {
        display: none !important;
    }
}

.gp6-section-title.gp6-section-hint {
    font-family: inherit;
    font-weight: 400;
    font-size: 0.9rem;
    color: var(--gp6-slate-muted);
}

/* Bento-grid: första kortet större (2x2), resten i grid */
.gp6-bento-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: minmax(140px, auto) minmax(140px, auto);
    grid-auto-rows: minmax(140px, auto);
    gap: 16px;
}

/* Stor sökruta – första kortet i bento-grid, fyller 2x2, samma radhöjd som kort */
.gp6-bento-search {
    grid-column: span 2;
    grid-row: span 2;
    min-height: 100%;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.06) 0%, rgba(6, 182, 212, 0.06) 100%);
    border: 1px solid var(--gp6-border);
    border-radius: var(--gp6-radius-sm);
    padding: 28px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-self: stretch;
}

[data-theme="dark"] .gp6-bento-search {
    background: linear-gradient(135deg, rgba(129, 140, 248, 0.08) 0%, rgba(165, 180, 252, 0.06) 100%);
}

.gp6-search-title {
    font-family: 'Outfit', sans-serif;
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--gp6-slate);
    margin-bottom: 8px;
}

.gp6-search-desc {
    font-size: 0.95rem;
    color: var(--gp6-slate-light);
    margin-bottom: 20px;
}

.gp6-search-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.gp6-search-form input {
    width: 100%;
}

.gp6-search-form input {
    padding: 14px 18px;
    font-size: 1rem;
    border: 2px solid var(--gp6-border);
    border-radius: var(--gp6-radius-sm);
    background: var(--gp6-bg-card);
    color: var(--gp6-slate);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.gp6-search-form input:focus {
    outline: none;
    border-color: var(--gp6-primary);
    box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.12);
}

.gp6-search-form input::placeholder {
    color: var(--gp6-slate-muted);
}

@media (max-width: 600px) {
    .gp6-search-form .gp6-btn {
        width: 100%;
    }
}

.gp6-recent-header,
.gp6-section-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.gp6-bento-card {
    background: var(--gp6-bg-card);
    border-radius: var(--gp6-radius-sm);
    padding: 24px;
    border: 1px solid var(--gp6-border);
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    min-height: 160px;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.gp6-bento-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
    opacity: 0;
    transition: opacity 0.2s;
}

.gp6-bento-card[data-lang="engelska"]::before { background: #3b82f6; }
.gp6-bento-card[data-lang="spanska"]::before { background: #f59e0b; }
.gp6-bento-card[data-lang="tyska"]::before { background: #6b7280; }
.gp6-bento-card[data-lang="franska"]::before { background: #8b5cf6; }

.gp6-bento-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--gp6-shadow-hover);
    border-color: var(--gp6-primary);
}

.gp6-bento-card:hover::before {
    opacity: 1;
}

.gp6-bento-lang {
    font-size: 2rem;
    margin-bottom: 12px;
    line-height: 1;
}


.gp6-bento-title {
    font-family: 'Outfit', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--gp6-slate);
    margin-bottom: 8px;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.gp6-bento-meta {
    font-size: 0.8rem;
    color: var(--gp6-slate-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: auto;
}

.gp6-bento-code {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 12px;
    padding: 10px 16px;
    background: linear-gradient(135deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
    color: white;
    font-weight: 700;
    font-size: 0.95rem;
    border-radius: 10px;
    width: fit-content;
    transition: transform 0.2s;
}

.gp6-bento-card:hover .gp6-bento-code {
    transform: scale(1.03);
}


/* Medlem: 2 rader x 5 kort, ingen scroll – endast PC */
.gp6-member-cards-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: repeat(2, auto);
    gap: 12px;
}

.gp6-member-card {
    min-height: 120px;
    padding: 16px;
}

.gp6-member-card .gp6-bento-title {
    font-size: 0.95rem;
    margin-bottom: 6px;
}

.gp6-member-card .gp6-bento-meta {
    font-size: 0.7rem;
}

.gp6-member-card .gp6-bento-code {
    font-size: 0.85rem;
    padding: 8px 12px;
    margin-top: 8px;
}

.gp6-member-cards-grid.gp6-skeleton-grid .gp6-skeleton-card.gp6-member-card {
    min-height: 120px;
    padding: 16px;
}

@media (max-width: 900px) {
    .gp6-member-cards-grid {
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: auto;
    }
}

@media (max-width: 600px) {
    .gp6-member-cards-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(4, minmax(140px, 1fr));
        gap: 12px;
    }
    .gp6-member-cards-grid .gp6-member-card:nth-child(n+9) {
        display: none;
    }
}

@media (max-width: 900px) {
    .gp6-member-card {
        min-height: 130px;
        height: 130px;
    }
    .gp6-member-card .gp6-bento-title {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
}

/* Horisontell scroll – för gäster (ej medlem) */
.gp6-scroll-strip {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    padding-bottom: 12px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}

.gp6-scroll-strip::-webkit-scrollbar {
    height: 6px;
}

.gp6-scroll-strip::-webkit-scrollbar-track {
    background: var(--gp6-bg-warm);
    border-radius: 3px;
}

.gp6-scroll-strip::-webkit-scrollbar-thumb {
    background: var(--gp6-border);
    border-radius: 3px;
}

.gp6-scroll-card {
    flex: 0 0 220px;
    min-width: 220px;
    min-height: 160px;
    scroll-snap-align: start;
}

@media (max-width: 600px) {
    /* Desktop bento-grid: sök + 7 kort (sök tar 2 kolumner rad 1, 7 kort på rad 2-4) */
    .gp6-bento-grid:not(.gp6-guest-grid) .gp6-bento-card:nth-child(n+9) {
        display: none;
    }
    /* 2x4 grid medlem: visa 8 kort */
    .gp6-member-cards-grid .gp6-member-card:nth-child(n+9) {
        display: none;
    }
    /* 2x4 grid gäster: visa 8 kort (samma som medlemmar) */
    .gp6-guest-grid .gp6-bento-card:nth-child(n+9) {
        display: none;
    }
    .gp6-scroll-card {
        flex: 0 0 180px;
        min-width: 180px;
    }
    .gp6-scroll-strip .gp6-scroll-card:nth-child(n+7) {
        display: none;
    }
}

@media (max-width: 480px) {
    .gp6-create-header { padding: 20px 16px; }
    .gp6-form-step { padding: 20px 16px; }
    .gp6-form-submit { padding: 20px 16px; }
    .gp6-glosor-box { padding: 16px 12px; }
    .gp6-section { padding: 24px 0; }
    .gp6-bento-card { max-width: 200px; }
    .gp6-scroll-card {
        flex: 0 0 160px;
        min-width: 160px;
    }
}

/* Skeleton loaders för senaste glostest */
.gp6-skeleton-card {
    background: var(--gp6-bg-card);
    border-radius: var(--gp6-radius-sm);
    padding: 24px;
    border: 1px solid var(--gp6-border);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 160px;
    gap: 12px;
}
.gp6-skeleton-lang {
    width: 40px;
    height: 32px;
    border-radius: 6px;
    background: linear-gradient(90deg, var(--gp6-border) 25%, var(--gp6-bg-warm) 50%, var(--gp6-border) 75%);
    background-size: 200% 100%;
    animation: gp6-skeleton-shimmer 1.2s ease-in-out infinite;
}
.gp6-skeleton-title {
    height: 18px;
    width: 85%;
    max-width: 140px;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--gp6-border) 25%, var(--gp6-bg-warm) 50%, var(--gp6-border) 75%);
    background-size: 200% 100%;
    animation: gp6-skeleton-shimmer 1.2s ease-in-out infinite;
}
.gp6-skeleton-meta {
    height: 12px;
    width: 50%;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--gp6-border) 25%, var(--gp6-bg-warm) 50%, var(--gp6-border) 75%);
    background-size: 200% 100%;
    animation: gp6-skeleton-shimmer 1.2s ease-in-out infinite;
}
.gp6-skeleton-code {
    height: 28px;
    width: 72px;
    border-radius: 8px;
    background: linear-gradient(90deg, var(--gp6-border) 25%, var(--gp6-bg-warm) 50%, var(--gp6-border) 75%);
    background-size: 200% 100%;
    animation: gp6-skeleton-shimmer 1.2s ease-in-out infinite;
}
@keyframes gp6-skeleton-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

@media (max-width: 768px) {
    /* 2x4 grid på mobil: 2 kolumner, 4 rader */
    .gp6-bento-grid,
    .gp6-member-cards-grid,
    .gp6-guest-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(4, minmax(140px, 1fr));
        grid-auto-rows: minmax(140px, 1fr);
        gap: 12px;
    }
    /* Gäster: dölj sök-ruta på mobil och använd member-card layout */
    .gp6-guest-grid .gp6-bento-search {
        display: none;
    }
    /* Gäster skeleton: dölj även sök-ruta i skeleton på mobil */
    #recentTestsSectionGuest .gp6-bento-search {
        display: none;
    }
    /* Gäster: använd member-card styling på mobil */
    .gp6-guest-grid .gp6-bento-card {
        min-height: 120px;
        padding: 16px;
    }
    .gp6-guest-grid .gp6-bento-title {
        font-size: 0.95rem;
        margin-bottom: 6px;
    }
    .gp6-guest-grid .gp6-bento-meta {
        font-size: 0.7rem;
    }
    .gp6-guest-grid .gp6-bento-code {
        font-size: 0.85rem;
        padding: 8px 12px;
        margin-top: 8px;
    }
    .gp6-bento-card,
    .gp6-member-card {
        text-align: center;
        min-height: 140px;
        height: 100%;
        max-height: 180px;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
    }
    .gp6-bento-title {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-align: center;
        flex: 0 1 auto;
        min-height: 2.6em;
    }
    .gp6-bento-title,
    .gp6-bento-meta,
    .gp6-bento-code {
        text-align: center;
    }
    .gp6-bento-meta {
        flex: 0 0 auto;
    }
    .gp6-bento-code {
        align-self: center;
        margin-top: auto;
    }
    .gp6-bento-search {
        grid-column: span 2;
        grid-row: span 1;
        min-height: auto;
    }
    .gp6-bento-grid .gp6-skeleton-card,
    .gp6-member-cards-grid .gp6-skeleton-card {
        min-height: 140px;
        height: 100%;
    }
    .gp6-scroll-card {
        flex: 0 0 220px;
    }
    .gp6-create-header {
        padding: 24px 20px;
    }
    .gp6-form-step {
        flex-direction: column;
        padding: 24px 20px;
    }
    .gp6-form-submit {
        padding: 24px 20px;
    }
    .gp6-form-group input:not([type="checkbox"]):not([type="radio"]),
    .gp6-form-group select,
    .gp6-form-group textarea {
        font-size: 16px; /* Förhindra zoom på iOS */
    }
    .gp6-glosor-box {
        padding: 20px 16px;
    }
    .gp6-glosor-box .glos-row input {
        font-size: 16px;
    }
}

@media (max-width: 600px) {
    .gp6-checkbox-label {
        flex-wrap: wrap;
        word-break: break-word;
    }
    .gp6-checkbox-label input[type="checkbox"] {
        flex-shrink: 0;
    }
}

/* === DIVIDER === */
.gp6-divider {
    height: 1px;
    background: linear-gradient(to right, transparent, var(--gp6-border), transparent);
    margin: 40px 0;
    border: none;
}

/* === SKAPA GLOSTEST – Stegvis design === */
.gp6-create-section {
    background: var(--gp6-bg-card);
    border-radius: var(--gp6-radius);
    padding: 0;
    border: 1px solid var(--gp6-border);
    overflow: hidden;
}

.gp6-create-header {
    background: linear-gradient(135deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
    color: white;
    padding: 32px 40px;
}

[data-theme="dark"] .gp6-create-header {
    background: linear-gradient(135deg, #1e3a5f 0%, #0f172a 100%);
    border-bottom: 1px solid var(--gp6-border);
}

.gp6-create-badge {
    display: inline-block;
    font-size: 0.8rem;
    font-weight: 700;
    margin-bottom: 8px;
    opacity: 0.95;
}

.gp6-create-header h3 {
    font-family: 'Outfit', sans-serif;
    font-size: 1.75rem;
    font-weight: 800;
    margin: 0 0 8px 0;
    letter-spacing: -0.5px;
}

.gp6-create-intro {
    font-size: 0.95rem;
    margin: 0;
    opacity: 0.9;
}

.gp6-form-step {
    padding: 28px 40px;
    border-bottom: 1px solid var(--gp6-border);
}

.gp6-form-step:last-of-type,
.gp6-form-step-no-border {
    border-bottom: none;
}

.gp6-form-step-optional {
    background: var(--gp6-bg-warm);
}

.gp6-form-step-content {
    flex: 1;
    min-width: 0;
}

.gp6-form-step-title {
    font-family: 'Outfit', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--gp6-slate);
    margin-bottom: 16px;
}

.gp6-checkbox-label {
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    font-weight: 500;
}

.gp6-teacher-options {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px dashed var(--gp6-border);
}

.gp6-form-submit {
    padding: 28px 40px;
    background: var(--gp6-bg-warm);
    border-top: 1px solid var(--gp6-border);
}

.gp6-form-submit .g-recaptcha {
    margin-bottom: 20px;
}

.gp6-glosor-box .g-recaptcha {
    margin-bottom: 0;
}

.gp6-btn-submit {
    padding: 14px 24px;
    font-size: 0.95rem;
}

.gp6-form-group {
    margin-bottom: 20px;
}

.gp6-form-group label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--gp6-slate);
}

/* Checkbox-labels i gp6-form-group ska ha flex för att checkboxen ska ligga i linje med texten */
.gp6-form-group label.gp6-checkbox-label,
.gp6-form-group label:has(input[type="checkbox"]),
.gp6-form-group label:has(input[type="radio"]) {
    display: flex !important;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.gp6-form-group input:not([type="checkbox"]):not([type="radio"]),
.gp6-form-group select,
.gp6-form-group textarea {
    width: 100%;
    padding: 14px 18px;
    border: 2px solid var(--gp6-border);
    border-radius: var(--gp6-radius-sm);
    font-size: 1rem;
    background: var(--gp6-bg-card);
    color: var(--gp6-slate);
    transition: border-color 0.2s;
}

.gp6-form-group input:not([type="checkbox"]):not([type="radio"]):focus,
.gp6-form-group select:focus,
.gp6-form-group textarea:focus {
    outline: none;
    border-color: var(--gp6-primary);
}

/* Checkbox/radio i gp6-form-group – normal storlek, i linje med text */
.gp6-form-group input[type="checkbox"],
.gp6-form-group input[type="radio"] {
    width: auto;
    min-width: 18px;
    height: 18px;
    margin: 0;
    flex-shrink: 0;
}

.gp6-glosor-box {
    background: var(--gp6-bg-card);
    padding: 28px;
    border-radius: var(--gp6-radius-sm);
    border: 1px solid var(--gp6-border);
    margin-top: 24px;
}

.gp6-glosor-box h4 {
    font-family: 'Outfit', sans-serif;
    font-size: 1.15rem;
    margin-bottom: 16px;
}

.gp6-glosor-box .glos-row {
    display: grid;
    grid-template-columns: 40px 1fr 1fr 40px;
    gap: 10px;
    margin-bottom: 10px;
    align-items: center;
}

.gp6-glosor-box .glos-row input {
    padding: 10px 14px;
    border: 2px solid var(--gp6-border);
    border-radius: 8px;
    font-size: 0.95rem;
    background: var(--gp6-bg-card);
    color: var(--gp6-slate);
}

.gp6-glosor-box .glos-row input:focus {
    outline: none;
    border-color: var(--gp6-primary);
}

.gp6-glosor-box .glos-number {
    font-weight: 600;
    color: var(--gp6-slate-light);
    text-align: center;
}

.gp6-glosor-box .btn-remove {
    width: 40px;
    height: 40px;
    border: none;
    background: var(--gp6-primary);
    color: white;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1.2rem;
    font-weight: bold;
    transition: background 0.2s;
    flex-shrink: 0;
}

.gp6-glosor-box .btn-remove:hover {
    background: var(--gp6-accent);
}

.gp6-add-btn { margin-top: 16px; }

/* Se till att knapparna i glos-rutan staplas under varandra utan att bli bredare */
.gp6-glosor-box .gp6-btn {
    display: flex;           /* block-level flex, radbryter automatiskt */
    justify-content: center; /* behåll centrerad text i knappen */
}

@media (max-width: 768px) {
    .gp6-glosor-box .glos-row {
        grid-template-columns: 30px 1fr 1fr 35px;
        gap: 8px;
    }
}

@media (max-width: 600px) {
    .gp6-glosor-box .glos-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .gp6-glosor-box .glos-number {
        text-align: left;
    }
    .gp6-glosor-box .btn-remove {
        width: 100%;
        border-radius: 6px;
    }
}

/* === FOOTER === */
.gp6-footer {
    margin-top: 48px;
    padding: 32px 24px 24px;
    background: linear-gradient(135deg, var(--gp6-primary) 0%, var(--gp6-primary-light) 100%);
    color: rgba(255, 255, 255, 0.95);
    border-radius: var(--gp6-radius);
}

[data-theme="dark"] .gp6-footer {
    background: linear-gradient(135deg, #1e3a5f 0%, #0f172a 100%);
    border-top: 1px solid var(--gp6-border);
}

.gp6-footer-content {
    max-width: 1500px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 28px;
    margin-bottom: 28px;
}

.gp6-footer-dela {
    text-align: center;
}

.gp6-footer-dela .social-share {
    justify-content: center;
}

.gp6-footer h4 {
    font-family: 'Outfit', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 12px;
    color: white;
}

.gp6-footer a {
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s;
}

.gp6-footer a:hover {
    color: white;
}

.gp6-footer .social-share {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.gp6-footer .share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all 0.3s;
}

.gp6-footer .share-btn:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-2px);
}

.gp6-footer .share-btn.facebook:hover {
    background: #1877f2;
}

.gp6-footer .share-btn.twitter:hover {
    background: #1da1f2;
}

.gp6-footer .share-btn.email:hover {
    background: #ea4335;
}

.gp6-footer .share-btn.whatsapp:hover {
    background: #25d366;
}

.gp6-footer .share-btn.copy:hover {
    background: #667eea;
}

.gp6-share-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}
.gp6-share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    background-color: rgba(255,255,255,0.2);
    color: white;
    text-decoration: none;
    transition: background-color 0.2s;
    background-size: 20px 20px;
    background-position: center;
    background-repeat: no-repeat;
}
.gp6-share-btn:hover {
    background-color: rgba(255,255,255,0.35);
}
.gp6-share-fb { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M24 12.073c0-6.627-5.373-12-12-12S0 5.446 0 12.073c0 5.99 4.388 10.954 10.125 11.854v-8.385H7.078v-3.47h3.047V9.43c0-3.007 1.792-4.669 4.533-4.669 1.312 0 2.686.235 2.686.235v2.953H15.83c-1.491 0-1.956.925-1.956 1.874v2.25h3.328l-.532 3.47h-2.796v8.385C19.612 23.027 24 18.062 24 12.073z'/%3E%3C/svg%3E"); }
.gp6-share-tw { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z'/%3E%3C/svg%3E"); }
.gp6-share-email { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E"); }
.gp6-share-wa { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347'/%3E%3C/svg%3E"); }
.gp6-share-copy { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71'/%3E%3Cpath d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71'/%3E%3C/svg%3E"); border: none; cursor: pointer; font-family: inherit; }
.gp6-share-copy.copied { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E"); }

.gp6-footer-bottom {
    text-align: center;
    padding-top: 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.8);
}

@media (max-width: 700px) {
    .gp6-footer-content {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .gp6-footer-dela .social-share {
        justify-content: center;
    }
}

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

/* === COOKIE CONSENT BANNER (gp6) === */
.cookie-consent-banner {
    position: fixed;
    bottom: 20px;
    left: 20px;
    right: 20px;
    max-width: 600px;
    margin: 0 auto;
    background: var(--gp6-bg-card);
    color: var(--gp6-slate);
    padding: 20px;
    z-index: 10000;
    box-shadow: var(--gp6-shadow-hover);
    border-radius: var(--gp6-radius-sm);
    border: 1px solid var(--gp6-border);
}

.cookie-consent-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
}

.cookie-consent-text {
    flex: 1;
    min-width: 250px;
}

.cookie-consent-text h4 {
    margin: 0 0 8px 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--gp6-slate);
}

.cookie-consent-text p {
    margin: 0 0 8px 0;
    font-size: 0.9rem;
    line-height: 1.4;
    color: var(--gp6-slate-light);
}

.cookie-consent-text p:last-child {
    margin-bottom: 0;
}

.cookie-link {
    color: var(--gp6-primary) !important;
    text-decoration: underline !important;
    font-weight: 500;
}

.cookie-link:hover {
    color: var(--gp6-primary-light) !important;
}

.cookie-consent-buttons {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
}

.btn-cookie-accept-all,
.btn-cookie-necessary {
    padding: 8px 16px;
    border: none;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.btn-cookie-accept-all {
    background: #28a745;
    color: white;
}

.btn-cookie-accept-all:hover {
    background: #218838;
    transform: translateY(-1px);
}

.btn-cookie-necessary {
    background: #6c757d;
    color: white;
}

.btn-cookie-necessary:hover {
    background: #5a6268;
    transform: translateY(-1px);
}

@media (max-width: 768px) {
    .cookie-consent-banner {
        bottom: 15px;
        left: 15px;
        right: 15px;
        padding: 15px;
    }
    .cookie-consent-content {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    .cookie-consent-text {
        min-width: auto;
        text-align: center;
    }
    .cookie-consent-buttons {
        justify-content: center;
        flex-wrap: wrap;
    }
    .btn-cookie-accept-all,
    .btn-cookie-necessary {
        flex: 1;
        min-width: 100px;
    }
}

@media (max-width: 480px) {
    .cookie-consent-banner {
        bottom: 10px;
        left: 10px;
        right: 10px;
        padding: 12px;
    }
    .cookie-consent-text h4 {
        font-size: 0.95rem;
    }
    .cookie-consent-text p {
        font-size: 0.8rem;
    }
    .btn-cookie-accept-all,
    .btn-cookie-necessary {
        padding: 6px 12px;
        font-size: 0.8rem;
    }
}

/* === SESSION TIMEOUT (gp6) === */
.gp6-page-content .timeout-container {
    max-width: 600px;
    margin: 2rem auto;
    padding: 2.5rem;
    text-align: center;
    background: var(--gp6-bg-card);
    border-radius: var(--gp6-radius-sm);
    box-shadow: var(--gp6-shadow);
    border: 1px solid var(--gp6-border);
}
.gp6-page-content .timeout-icon {
    font-size: 64px;
    margin-bottom: 1.25rem;
    opacity: 0.9;
}
.gp6-page-content .timeout-title {
    color: var(--gp6-slate);
    margin-bottom: 1.25rem;
    font-size: 1.75rem;
}
.gp6-page-content .timeout-message {
    color: var(--gp6-slate-light);
    margin-bottom: 1.75rem;
    font-size: 1rem;
    line-height: 1.6;
}
.gp6-page-content .timeout-actions {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}
.gp6-page-content .timeout-actions .btn-timeout {
    padding: 12px 24px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease;
    display: inline-block;
}
.gp6-page-content .timeout-actions .btn-timeout.btn-primary {
    background: var(--gp6-primary);
    color: white !important;
}
.gp6-page-content .timeout-actions .btn-timeout.btn-primary:hover {
    filter: brightness(1.1);
    color: white !important;
}
.gp6-page-content .timeout-actions .btn-timeout.btn-secondary {
    background: var(--gp6-bg-warm);
    color: var(--gp6-slate) !important;
    border: 1px solid var(--gp6-border);
}
.gp6-page-content .timeout-actions .btn-timeout.btn-secondary:hover {
    background: var(--gp6-border);
    color: var(--gp6-slate) !important;
}
@media (max-width: 600px) {
    .gp6-page-content .timeout-container {
        margin: 1.25rem;
        padding: 1.5rem 1.25rem;
    }
    .gp6-page-content .timeout-actions {
        flex-direction: column;
        align-items: center;
    }
    .gp6-page-content .timeout-actions .btn-timeout {
        width: 100%;
        max-width: 200px;
    }
}

/* Ändringar-sidan (medlem/lärare) */
.andringar-list-section {
    margin-top: 1.5em;
}
.andringar-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.andringar-item {
    border: 1px solid var(--gp6-border);
    border-radius: var(--gp6-radius-sm, 8px);
    margin-bottom: 10px;
    overflow: hidden;
    cursor: pointer;
}
.andringar-item.andringar-unread {
    border-left: 4px solid var(--gp6-accent-primary, #4f46e5);
}
.andringar-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 16px;
    padding: 12px 16px;
}
.andringar-date {
    font-size: 0.9em;
    color: var(--gp6-slate-muted, #64748b);
}
.andringar-title {
    font-weight: 600;
    flex: 1;
    min-width: 0;
}
.andringar-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.8em;
    font-weight: 500;
}
.andringar-badge-medlemmar { background: #dbeafe; color: #1e40af; }
.andringar-badge-elever { background: #fef3c7; color: #92400e; }
.andringar-badge-larare { background: #d1fae5; color: #065f46; }
.andringar-badge-generellt { background: #e5e7eb; color: #374151; }
.andringar-olast {
    font-size: 0.85em;
    color: var(--gp6-accent-primary, #4f46e5);
    font-weight: 500;
}
.andringar-detail {
    padding: 12px 16px;
    border-top: 1px solid var(--gp6-border);
    background: var(--gp6-bg-secondary, #f8fafc);
}
.andringar-comment {
    white-space: pre-wrap;
    margin-bottom: 10px;
    color: inherit;
}
[data-theme="dark"] .andringar-detail {
    background: var(--gp6-bg-warm, #1e293b);
}
[data-theme="dark"] .andringar-comment {
    color: var(--gp6-slate, #f1f5f9);
}
.andringar-image img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
}
.andringar-class-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 20px;
}
.andringar-class-checkboxes label.checkbox-inline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
}
.form-section.andringar-form-section,
.admin-view .form-section {
    background: var(--gp6-bg-secondary, #f8fafc);
    padding: 20px;
    border-radius: var(--gp6-radius-sm, 8px);
    margin-bottom: 24px;
}
.profile-checkbox-label { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; }
.form-hint { font-size: 0.9em; color: var(--gp6-slate-muted); margin-top: 6px; }

/* ========== Testbank (teacher/test_bank.php) ========== */
.test-bank-container {
    display: flex;
    gap: 30px;
}

.tree-view {
    flex: 1;
    background: var(--card-bg);
    padding: 20px;
    border-radius: 5px;
    max-height: 600px;
    overflow-y: auto;
    border: 1px solid var(--border-color);
}

.tree-item {
    padding: 8px 5px;
    margin: 2px 0;
    cursor: pointer;
    border-radius: 3px;
    transition: background 0.2s;
}

.tree-item:hover {
    background: var(--hover-bg);
}

.tree-folder {
    margin-bottom: 10px;
}

.tree-test {
    margin-left: 0;
}

.tree-view .folder-icon,
.tree-view .test-icon {
    margin-right: 5px;
}

.test-count {
    color: var(--text-muted);
    font-size: 0.9em;
}

.test-title {
    font-weight: 500;
}

.test-code {
    color: var(--text-muted);
    font-size: 0.9em;
}

.test-tags-inline {
    margin-left: 10px;
}

.tag-badge-small {
    display: inline-block;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 0.75em;
    color: white;
    margin-right: 3px;
}

.btn-manage {
    margin-left: 10px;
    padding: 4px 10px;
    background: #667eea;
    color: white !important;
    border: none;
    border-radius: 3px;
    cursor: pointer;
    font-size: 0.85em;
}

.btn-manage:hover {
    background: #5568d3;
    color: white !important;
}

[data-theme="dark"] .btn-manage {
    color: white !important;
}

[data-theme="dark"] .btn-manage:hover {
    color: white !important;
}

.unassigned-section {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 2px solid var(--border-color);
}

.unassigned-section h3 {
    margin-bottom: 15px;
}

/* Testbank modal (wrapper .test-bank-modals finns runt modalen i test_bank.php) */
.test-bank-modals .modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
}

.test-bank-modals .modal-content {
    background-color: var(--card-bg);
    margin: 5% auto;
    padding: 30px;
    border-radius: 8px;
    width: 90%;
    max-width: 600px;
    max-height: 80vh;
    overflow-y: auto;
    border: 1px solid var(--border-color);
}

.test-bank-modals .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 2px solid var(--border-color);
}

.test-bank-modals .modal-header h3 {
    margin: 0;
}

.test-bank-modals .close {
    color: #aaa;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    border: none;
    background: none;
}

.test-bank-modals .close:hover {
    color: #000;
}

.test-bank-modals .modal-section {
    margin-bottom: 25px;
}

.test-bank-modals .modal-section h4 {
    margin-bottom: 10px;
    color: #667eea;
}

.test-bank-modals .current-assignments {
    margin-bottom: 15px;
}

.test-bank-modals .assignment-item {
    display: inline-block;
    padding: 5px 10px;
    margin: 5px 5px 5px 0;
    background: var(--bg-secondary);
    border-radius: 4px;
    font-size: 0.9em;
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

.test-bank-modals .assignment-item .remove-btn {
    margin-left: 8px;
    color: #d32f2f;
    cursor: pointer;
    font-weight: bold;
}

.test-bank-modals .assignment-item .remove-btn:hover {
    color: #b71c1c;
}

.test-bank-modals .modal .form-group {
    margin-bottom: 15px;
}

.test-bank-modals .modal .form-group label {
    display: block;
    margin-bottom: 5px;
    font-weight: 500;
}

.test-bank-modals .modal .form-group select {
    width: 100%;
    padding: 8px;
    border: 1px solid var(--border-color);
    border-radius: 4px;
    background: var(--bg-primary);
    color: var(--text-primary);
}

.test-bank-modals .btn-add {
    padding: 8px 15px;
    background: #667eea;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

.test-bank-modals .btn-add:hover {
    background: #5568d3;
}

.teacher-view .alert {
    padding: 10px;
    margin-bottom: 15px;
    border-radius: 4px;
}

.teacher-view .alert-success {
    background: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.teacher-view .alert-error {
    background: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

.teacher-view .alert-warning {
    background: #fff3cd;
    color: #856404;
    border: 1px solid #ffeeba;
}

.action-buttons-top {
    margin-bottom: 20px;
}

.action-buttons-top a {
    margin-right: 10px;
}

/* ========== Tilldela test – söklista (teacher/assign_test.php) ========== */
.assign-test-search-input {
    width: 100%;
    max-width: 400px;
    padding: 10px 12px;
    border: 1px solid var(--border-color, #ddd);
    border-radius: 6px;
    font-size: 1rem;
    margin-bottom: 10px;
}

.assign-test-list-container {
    border: 1px solid var(--border-color, #ddd);
    border-radius: 6px;
    background: var(--card-bg, #fff);
    max-height: 320px;
    overflow-y: auto;
    position: relative;
}

.assign-test-list-placeholder,
.assign-test-list-loading,
.assign-test-list-empty {
    padding: 16px;
    color: var(--text-muted, #666);
    font-size: 0.95em;
}

.assign-test-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.assign-test-list-item {
    padding: 10px 14px;
    border-bottom: 1px solid var(--border-color, #eee);
    cursor: pointer;
    transition: background 0.15s;
}

.assign-test-list-item:last-child {
    border-bottom: none;
}

.assign-test-list-item:hover {
    background: var(--hover-bg, #f0f4ff);
}

.assign-test-list-item.selected {
    background: var(--gp6-indigo-light, #e0e7ff);
    font-weight: 500;
}

.assign-test-list-title {
    font-weight: 500;
}

.assign-test-list-code {
    color: var(--text-muted, #666);
    font-size: 0.9em;
    margin-left: 4px;
}

.assign-test-list-imported {
    color: #28a745;
    font-size: 0.85em;
    font-weight: normal;
    margin-left: 6px;
}

.assign-test-selected-label {
    margin-top: 10px;
    padding: 8px 12px;
    background: var(--bg-secondary, #f5f5f5);
    border-radius: 6px;
    font-size: 0.95em;
}

.assign-test-tree .assign-tree-test.selected {
    background: var(--gp6-indigo-light, #e0e7ff) !important;
    font-weight: 500;
}

.assign-test-tree .assign-tree-folder-header:hover {
    background: #dee2e6 !important;
}

/* === Orm (Snake) träningsläge === */
.snake-section .snake-intro {
    margin-bottom: 1rem;
}
.snake-section .snake-intro h3 {
    margin-top: 0;
}
.snake-section .snake-intro p {
    color: var(--text-secondary, #555);
    max-width: 42em;
}
.snake-game-wrap {
    margin-top: 1rem;
}
.snake-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 0.75rem;
    flex-wrap: wrap;
}
.snake-play-area .snake-score {
    margin: 0;
    font-size: 1.1rem;
}
.snake-pause-btn {
    flex-shrink: 0;
}
.snake-game-row {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}
@media (min-width: 640px) {
    .snake-game-row {
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
    }
    .snake-game-row .snake-controls {
        margin-top: 0;
    }
}
.snake-game-container {
    max-width: 100%;
    display: inline-block;
    flex-shrink: 0;
    border: 2px solid var(--border-color, #ddd);
    border-radius: 8px;
    overflow: hidden;
    background: #1a1a2e;
}
.snake-canvas {
    display: block;
    max-width: 100%;
    height: auto;
}
.snake-controls {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin-top: 12px;
}
.snake-controls-row {
    display: flex;
    align-items: center;
    gap: 8px;
}
.snake-btn {
    width: 48px;
    height: 48px;
    font-size: 1.25rem;
    border-radius: 8px;
    border: 1px solid var(--border-color, #ccc);
    background: var(--bg-secondary, #f0f0f0);
    color: var(--text-color, #333);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}
.snake-btn:hover,
.snake-btn:focus {
    background: var(--gp6-cyan-light, #e0f2fe);
    outline: none;
}
[data-theme="dark"] .snake-btn {
    background: var(--bg-tertiary);
    border-color: var(--border-color);
}
[data-theme="dark"] .snake-btn:hover,
[data-theme="dark"] .snake-btn:focus {
    background: var(--gp6-indigo-light, rgba(99, 102, 241, 0.2));
}
.snake-btn-placeholder {
    display: inline-block;
    width: 48px;
    height: 48px;
}
.snake-game-over {
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-secondary, #f9f9f9);
}
.snake-game-over p {
    margin-top: 0;
}
.snake-game-over-actions {
    display: flex;
    gap: 10px;
    margin-top: 12px;
    flex-wrap: wrap;
}
.snake-completion {
    margin-top: 1rem;
    padding: 1.25rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-secondary, #f9f9f9);
}
.snake-completion-title {
    margin-top: 0;
    font-size: 1.2rem;
}
.snake-completion p {
    margin: 0.5rem 0;
}
.snake-completion-actions {
    display: flex;
    gap: 10px;
    margin-top: 1rem;
    flex-wrap: wrap;
}
.snake-game-with-pause {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.snake-controls-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.snake-controls-wrap .snake-controls {
    margin-top: 0;
}
.snake-controls-wrap .snake-pause-btn {
    margin-top: 4px;
}
@media (min-width: 640px) {
    .snake-game-with-pause {
        flex-direction: row;
        align-items: center;
        gap: 12px;
    }
}
.snake-play-area .snake-mistakes {
    margin: 0;
    font-size: 1rem;
}
.snake-pause-choice-modal {
    z-index: 10001;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: auto;
}
.snake-pause-choice-modal .modal-content {
    max-width: 360px;
}
.snake-pause-choice-actions {
    display: flex;
    gap: 10px;
    margin-top: 1rem;
    flex-wrap: wrap;
}
.snake-glosa-modal {
    z-index: 10000;
    pointer-events: auto;
}
.snake-glosa-modal .snake-glosa-modal-content {
    max-width: 400px;
    pointer-events: auto;
    background: var(--card-bg, var(--bg-color, #fff));
    padding: 0;
    border-radius: 12px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}
[data-theme="dark"] .snake-glosa-modal .snake-glosa-modal-content {
    background: var(--card-bg, #1e293b);
}
.snake-glosa-prompt {
    margin-bottom: 1rem;
    font-size: 1.1rem;
}
.snake-wrong-answer {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}
.snake-compare-row {
    margin: 0 0 0.5rem 0;
    font-size: 1rem;
    line-height: 1.7;
}
.snake-compare-row strong {
    margin-right: 0.35em;
}
.snake-letter-compare,
.snake-letter-compare-correct {
    font-family: ui-monospace, "Consolas", monospace;
    font-size: 1.1rem;
    word-break: break-all;
    letter-spacing: 0.02em;
}
.snake-diff-pair {
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
    margin: 0 1px;
    padding: 2px 4px;
    border-radius: 4px;
    background: rgba(220, 38, 38, 0.12);
    border: 1px solid rgba(220, 38, 38, 0.4);
}
.snake-diff-pair .snake-user-char {
    color: #b91c1c;
    font-weight: 700;
    text-decoration: line-through;
}
.snake-diff-arrow {
    margin: 0 4px;
    color: #64748b;
    font-size: 0.9em;
}
.snake-diff-pair .snake-right-char {
    color: #15803d;
    font-weight: 700;
}
.snake-ok-letter {
    color: var(--text-color);
}
.snake-right-char-standalone {
    color: #15803d;
    font-weight: 700;
    background: rgba(22, 163, 74, 0.12);
    padding: 1px 3px;
    border-radius: 3px;
}
[data-theme="dark"] .snake-diff-pair {
    background: rgba(220, 38, 38, 0.2);
    border-color: rgba(220, 38, 38, 0.5);
}
[data-theme="dark"] .snake-diff-pair .snake-user-char {
    color: #fca5a5;
}
[data-theme="dark"] .snake-diff-pair .snake-right-char {
    color: #86efac;
}
[data-theme="dark"] .snake-right-char-standalone {
    color: #86efac;
    background: rgba(34, 197, 94, 0.2);
}
@media (max-width: 480px) {
    .snake-btn {
        width: 56px;
        height: 56px;
        font-size: 1.35rem;
    }
    .snake-btn-placeholder {
        width: 56px;
        height: 56px;
    }
}

/* ========== Teacher statistics page (ljust och mörkt tema) ========== */
.stats-page {
    --stats-card-bg: var(--card-bg);
    --stats-text: var(--text-primary);
    --stats-muted: var(--text-secondary, #64748b);
    --stats-border: var(--border-color);
}
.stats-page .stats-header-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 24px;
}
.stats-page .stats-title-block h2 {
    margin: 0 0 4px 0;
    font-size: 1.75rem;
    color: var(--stats-text);
}
.stats-page .stats-date {
    font-size: 0.9rem;
    color: var(--stats-muted);
    display: flex;
    align-items: center;
    gap: 6px;
}
.stats-page .stats-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}
.stats-page .stats-filters select {
    padding: 8px 12px;
    border-radius: 8px;
    border: 1px solid var(--stats-border);
    background: var(--stats-card-bg);
    color: var(--stats-text);
    min-width: 140px;
}
.stats-page .stats-mini-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.stats-page .stats-mini {
    background: var(--stats-card-bg);
    border: 1px solid var(--stats-border);
    border-radius: 10px;
    padding: 12px 16px;
    min-width: 140px;
}
.stats-page .stats-mini .stats-mini-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--stats-muted);
    margin-bottom: 4px;
}
.stats-page .stats-mini .stats-mini-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--stats-text);
}
.stats-page .stats-mini .stats-mini-sub {
    font-size: 0.8rem;
    color: #22c55e;
}
.stats-page .stats-mini-clickable {
    cursor: pointer;
    border: 1px solid var(--stats-border);
    text-align: left;
    font: inherit;
    width: 100%;
    min-width: 140px;
}
.stats-page .stats-mini-clickable:hover {
    border-color: var(--gp6-primary, #0ea5e9);
    background: var(--stats-border);
}
.stats-page .stats-active-modal {
    border-radius: 12px;
    border: 1px solid var(--stats-border);
    padding: 0;
    max-width: 90vw;
    width: 480px;
    background: var(--stats-card-bg);
    color: var(--stats-text);
}
.stats-page .stats-active-modal::backdrop {
    background: rgba(0, 0, 0, 0.4);
}
.stats-active-modal-inner {
    padding: 20px;
}
.stats-active-modal-inner h3 {
    margin: 0 0 16px 0;
    font-size: 1.1rem;
}
.stats-active-modal-lists {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}
@media (max-width: 520px) {
    .stats-active-modal-lists {
        grid-template-columns: 1fr;
    }
}
.stats-active-modal .stats-active-list h4 {
    margin: 0 0 8px 0;
    font-size: 0.9rem;
    color: var(--stats-muted);
}
.stats-active-modal .stats-active-list ul {
    margin: 0;
    padding-left: 20px;
    max-height: 200px;
    overflow-y: auto;
}
.stats-active-modal .stats-active-list li {
    margin: 4px 0;
    font-size: 0.9rem;
}
.stats-active-modal .stats-active-list li.stats-active-empty {
    font-style: italic;
    color: var(--stats-muted);
}
.stats-page .stats-cards-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 20px;
    margin-bottom: 28px;
}
.stats-page .stats-card {
    background: var(--stats-card-bg);
    border: 1px solid var(--stats-border);
    border-radius: 12px;
    padding: 20px;
}
.stats-page .stats-card h3 {
    margin: 0 0 12px 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--stats-text);
}
.stats-page .stats-card-inner {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.stats-page .stats-circle-wrap {
    position: relative;
    flex-shrink: 0;
    width: 80px;
    height: 80px;
}
.stats-page .stats-circle-fill {
    position: absolute;
    inset: 0;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: conic-gradient(var(--stats-circle-color) 0deg var(--stats-circle-deg), var(--stats-border) var(--stats-circle-deg) 360deg);
}
.stats-page .stats-circle-inner {
    position: absolute;
    inset: 8px;
    border-radius: 50%;
    background: var(--stats-card-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
}
.stats-page .stats-circle-inner.green {
    color: #22c55e;
}
.stats-page .stats-circle-inner.red {
    color: #ef4444;
}
.stats-page .stats-card-body .stats-big-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--stats-text);
}
.stats-page .stats-card-body .stats-big-sub {
    font-size: 0.85rem;
    color: var(--stats-muted);
    margin-top: 4px;
}
.stats-page .stats-export-card .stats-export-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 12px;
}
.stats-page .stats-export-btns a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 8px;
    border: 1px solid var(--stats-border);
    background: var(--stats-card-bg);
    color: var(--stats-text);
    text-decoration: none;
    font-size: 0.9rem;
    transition: background 0.15s, border-color 0.15s;
}
.stats-page .stats-export-btns a:hover {
    background: var(--stats-border);
}
.stats-page .stats-table-wrap {
    overflow-x: auto;
    margin-bottom: 16px;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--stats-border);
}
.stats-page .stats-table {
    width: 100%;
    border-collapse: collapse;
}
.stats-page .stats-table th {
    text-align: left;
    padding: 12px 14px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--stats-muted);
    border-bottom: 1px solid var(--stats-border);
    background: var(--stats-card-bg);
}
.stats-page .stats-table th:first-child {
    border-top-left-radius: 12px;
}
.stats-page .stats-table th:last-child {
    border-top-right-radius: 12px;
}
.stats-page .stats-table tbody tr:last-child td:first-child {
    border-bottom-left-radius: 12px;
}
.stats-page .stats-table tbody tr:last-child td:last-child {
    border-bottom-right-radius: 12px;
}
.stats-page .stats-th-sort {
    color: var(--stats-muted);
    text-decoration: none;
    display: inline-block;
    transition: color 0.15s;
}
.stats-page .stats-th-sort:hover {
    color: var(--stats-text);
}
.stats-page .stats-th-sort.is-active {
    color: var(--gp6-primary, #0ea5e9);
    font-weight: 600;
}
.stats-page .stats-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--stats-border);
    color: var(--stats-text);
    vertical-align: middle;
}
.stats-page .stats-table tbody tr:hover {
    background: var(--stats-border);
}

/* När tabellen ligger inuti ett stats-kort kan de inre hörnen se dubbelt rundade ut.
   Nollställ därför cellernas egna radier och låt behållaren sköta hörn. */
.stats-page .stats-card .stats-table th:first-child,
.stats-page .stats-card .stats-table th:last-child,
.stats-page .stats-card .stats-table tbody tr:last-child td:first-child,
.stats-page .stats-card .stats-table tbody tr:last-child td:last-child {
    border-radius: 0;
}
.stats-page .stats-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--gp6-primary, #0ea5e9);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 600;
    margin-right: 10px;
    vertical-align: middle;
}
.stats-page .stats-name {
    vertical-align: middle;
}
.stats-page .stats-completed {
    color: #22c55e;
    font-weight: 600;
}
.stats-page .stats-aborted {
    color: #ef4444;
    font-weight: 600;
}
.stats-page .stats-score-bar {
    height: 6px;
    background: var(--stats-border);
    border-radius: 3px;
    width: 60px;
    display: inline-block;
    margin-left: 6px;
    overflow: hidden;
    vertical-align: middle;
}
.stats-page .stats-score-fill {
    height: 100%;
    border-radius: 3px;
}
.stats-page .stats-score-fill.high {
    background: #22c55e;
}
.stats-page .stats-score-fill.mid {
    background: #f59e0b;
}
.stats-page .stats-score-fill.low {
    background: #8b5cf6;
}
.stats-page .stats-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    font-size: 0.9rem;
    color: var(--stats-muted);
}
.stats-page .stats-pagination a {
    color: var(--gp6-primary, #0ea5e9);
    text-decoration: none;
    padding: 6px 10px;
    border-radius: 6px;
}
.stats-page .stats-pagination a:hover {
    background: var(--stats-border);
    color: var(--stats-text);
}
.stats-page .students-not-completed {
    margin-top: 28px;
    padding: 20px;
    border-radius: 12px;
    border-left: 4px solid #eab308;
    background: var(--stats-card-bg);
    border: 1px solid var(--stats-border);
}
.stats-page .students-not-completed h3 {
    margin: 0 0 12px 0;
    font-size: 1rem;
    color: var(--stats-text);
}
.stats-page .students-not-completed ul {
    margin: 0;
    padding-left: 20px;
}
.stats-page .students-not-completed li {
    margin: 6px 0;
    color: var(--stats-text);
}
.stats-page .students-not-completed a {
    color: var(--gp6-primary);
}
/* Member statistics: empty state, section title, chart card */
.stats-page .stats-empty-state {
    padding: 32px 24px;
    text-align: center;
    background: var(--stats-card-bg);
    border: 1px solid var(--stats-border);
    border-radius: 12px;
}
.stats-page .stats-empty-state p {
    margin: 0 0 16px 0;
    color: var(--stats-text);
}
.stats-page .stats-section-title {
    margin: 28px 0 12px 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--stats-text);
}
.stats-page .stats-chart-card {
    margin-bottom: 24px;
}
.stats-page .stats-chart-canvas {
    position: relative;
    max-height: 300px;
    min-height: 200px;
}

/* ========== Teacher word statistics (Ordnivåstatistik) ========== */
.word-stats-page {
    --ws-bg: var(--card-bg);
    --ws-text: var(--text-primary);
    --ws-muted: var(--text-secondary, #64748b);
    --ws-border: var(--border-color);
}
.word-stats-header {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: flex-start;
    margin-bottom: 24px;
}
.word-stats-back {
    flex: 0 0 100%;
}
.word-stats-back-link {
    color: var(--ws-muted);
    text-decoration: none;
    font-size: 0.95rem;
}
.word-stats-back-link:hover {
    color: var(--gp6-primary);
}
.word-stats-title-row {
    flex: 1;
    min-width: 200px;
}
.word-stats-title-row h2 {
    margin: 0 0 8px 0;
    font-size: 1.75rem;
    color: var(--ws-text);
}
.word-stats-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.word-stats-tag {
    display: inline-block;
    padding: 6px 12px;
    border-radius: 9999px;
    font-size: 0.85rem;
    background: var(--ws-border);
    color: var(--ws-text);
}
.word-stats-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.word-stats-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.word-stats-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin-bottom: 28px;
}
.word-stats-summary-card {
    background: var(--ws-bg);
    border: 1px solid var(--ws-border);
    border-radius: 12px;
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 14px;
}
.word-stats-summary-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}
.word-stats-summary-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ws-muted);
    margin-bottom: 2px;
}
.word-stats-summary-value {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--ws-text);
}
.word-stats-accuracy-ring {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: radial-gradient(circle at center, var(--ws-bg) 68%, transparent 70%),
                conic-gradient(var(--gp6-primary, #0ea5e9) 0deg var(--word-acc-deg), var(--ws-border) var(--word-acc-deg) 360deg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--ws-text);
}
.word-stats-detail-section {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}
.word-stats-detail-section h3 {
    margin: 0;
    font-size: 1.1rem;
    color: var(--ws-text);
}
.word-stats-search-form {
    display: flex;
}
.word-stats-search-input {
    padding: 8px 12px;
    border-radius: 8px;
    border: 1px solid var(--ws-border);
    background: var(--ws-bg);
    color: var(--ws-text);
    min-width: 200px;
    font-size: 0.95rem;
}
.word-stats-search-input::placeholder {
    color: var(--ws-muted);
}
.word-stats-table-wrap {
    overflow-x: auto;
    border-radius: 12px;
    border: 1px solid var(--ws-border);
    margin-bottom: 20px;
}
.word-stats-table {
    width: 100%;
    border-collapse: collapse;
}
.word-stats-table th {
    text-align: left;
    padding: 12px 14px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ws-muted);
    border-bottom: 1px solid var(--ws-border);
    background: var(--ws-bg);
}
.word-stats-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--ws-border);
    color: var(--ws-text);
    vertical-align: middle;
}
.word-stats-table tbody tr:hover {
    background: var(--ws-border);
}
.word-stats-th {
    color: var(--ws-muted);
    text-decoration: none;
    display: inline-block;
}
.word-stats-th:hover {
    color: var(--ws-text);
}
.word-stats-th.is-active {
    color: var(--gp6-primary);
    font-weight: 600;
}
.word-stats-cell-word strong {
    display: block;
    font-size: 1rem;
}
.word-stats-cell-word .word-stats-translation {
    display: block;
    font-size: 0.85rem;
    color: var(--ws-muted);
    margin-top: 2px;
}
.word-stats-correct { color: #22c55e; font-weight: 600; }
.word-stats-partial { color: #f59e0b; font-weight: 600; }
.word-stats-wrong { color: #ef4444; font-weight: 600; }
.word-stats-acc-bar {
    display: inline-block;
    height: 6px;
    background: var(--ws-border);
    border-radius: 3px;
    width: 64px;
    margin-left: 8px;
    overflow: hidden;
    vertical-align: middle;
}
.word-stats-acc-fill {
    height: 100%;
    border-radius: 3px;
    display: block;
}
.word-stats-acc-fill.high { background: #22c55e; }
.word-stats-acc-fill.mid { background: #f59e0b; }
.word-stats-acc-fill.low { background: #ef4444; }
.word-stats-diff {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 9999px;
    font-size: 0.8rem;
    font-weight: 600;
}
.word-stats-diff-diff-none { background: var(--ws-border); color: var(--ws-text); }
.word-stats-diff-diff-easy { background: #dcfce7; color: #166534; }
[data-theme="dark"] .word-stats-diff-diff-easy { background: #166534; color: #dcfce7; }
.word-stats-diff-diff-medium { background: #fef3c7; color: #92400e; }
[data-theme="dark"] .word-stats-diff-diff-medium { background: #92400e; color: #fef3c7; }
.word-stats-diff-diff-hard { background: #fed7aa; color: #c2410c; }
[data-theme="dark"] .word-stats-diff-diff-hard { background: #c2410c; color: #fed7aa; }
.word-stats-diff-diff-very-hard { background: #fecaca; color: #b91c1c; }
[data-theme="dark"] .word-stats-diff-diff-very-hard { background: #b91c1c; color: #fecaca; }
.word-stats-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    font-size: 0.9rem;
    color: var(--ws-muted);
}
.word-stats-pagination-btns {
    display: flex;
    align-items: center;
    gap: 6px;
}
.word-stats-page-current {
    padding: 6px 12px;
    border-radius: 8px;
    font-weight: 600;
    background: var(--gp6-primary);
    color: #fff;
}

/* ========== Teacher dashboard (Lärar-Dashboard) ========== */
.teacher-dashboard {
    --td-bg: var(--card-bg);
    --td-text: var(--text-primary);
    --td-muted: var(--text-secondary, #64748b);
    --td-border: var(--border-color);
}
.teacher-dashboard .td-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 28px;
}
.teacher-dashboard .td-title {
    margin: 0 0 4px 0;
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--td-text);
}
.teacher-dashboard .td-subtitle {
    margin: 0;
    font-size: 0.95rem;
    color: var(--td-muted);
}
.teacher-dashboard .td-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.teacher-dashboard .td-btn {
    white-space: nowrap;
}
.teacher-dashboard .td-summary-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 28px;
}
.teacher-dashboard .td-summary-card {
    background: var(--td-bg);
    border: 1px solid var(--td-border);
    border-radius: 16px;
    padding: 24px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
[data-theme="dark"] .teacher-dashboard .td-summary-card {
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.teacher-dashboard .td-summary-icon {
    position: absolute;
    top: 16px;
    right: 16px;
    font-size: 1.5rem;
    opacity: 0.8;
}
.teacher-dashboard .td-summary-number {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--td-text);
    line-height: 1.1;
    margin-bottom: 4px;
}
.teacher-dashboard .td-summary-label {
    font-size: 0.9rem;
    color: var(--td-muted);
    margin-bottom: 16px;
}
.teacher-dashboard .td-summary-btn {
    width: 100%;
    text-align: center;
    justify-content: center;
    border-radius: 10px;
    padding: 10px 16px;
    font-size: 0.9rem;
}
.teacher-dashboard .td-quick-actions {
    margin-bottom: 28px;
}
.teacher-dashboard .td-quick-title {
    margin: 0 0 16px 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--td-text);
}
.teacher-dashboard .td-quick-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
}
.teacher-dashboard .td-quick-column {
    background: var(--td-bg);
    border: 1px solid var(--td-border);
    border-radius: 12px;
    padding: 20px;
}
.teacher-dashboard .td-quick-col-title {
    margin: 0 0 14px 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--td-text);
    display: flex;
    align-items: center;
    gap: 8px;
}
.teacher-dashboard .td-quick-col-icon {
    font-size: 1.2rem;
}
.teacher-dashboard .td-quick-btns {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.teacher-dashboard .td-quick-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border-radius: 10px;
    padding: 10px 14px;
    font-size: 0.95rem;
}
.teacher-dashboard .td-quick-btn.gp6-btn-primary {
    color: #fff;
}
.teacher-dashboard .td-quick-btn.gp6-btn-primary:hover {
    color: #fff;
    opacity: 0.95;
}
.teacher-dashboard .td-latest-changes {
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--td-border);
}
.teacher-dashboard .td-latest-title {
    margin: 0 0 8px 0;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: var(--td-muted);
}
.teacher-dashboard .td-my-tests-card {
    background: var(--td-bg);
    border: 1px solid var(--td-border);
    border-radius: 12px;
    padding: 24px;
    margin-top: 24px;
}
.teacher-dashboard .td-my-tests-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}
.teacher-dashboard .td-my-tests-title {
    margin: 0;
    font-size: 1.25rem;
    color: var(--td-text);
}
.teacher-dashboard .td-my-tests-toolbar {
    display: flex;
    align-items: center;
    gap: 10px;
}
.teacher-dashboard .td-filter-label {
    font-size: 0.9rem;
    color: var(--td-muted);
}
.teacher-dashboard .td-filter-select {
    padding: 8px 12px;
    border-radius: 8px;
    border: 1px solid var(--td-border);
    background: var(--td-bg);
    color: var(--td-text);
    font-size: 0.95rem;
}
.teacher-dashboard .td-my-tests-empty {
    margin: 0;
    color: var(--td-muted);
}
.teacher-dashboard .td-my-tests-table-wrap {
    overflow-x: auto;
    border-radius: 12px;
    border: 1px solid var(--td-border);
}
.teacher-dashboard .td-my-tests-table {
    width: 100%;
    border-collapse: collapse;
}
.teacher-dashboard .td-my-tests-table th {
    text-align: left;
    padding: 12px 14px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--td-muted);
    border-bottom: 1px solid var(--td-border);
    background: var(--td-bg);
}
.teacher-dashboard .td-my-tests-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--td-border);
    color: var(--td-text);
}
.teacher-dashboard .td-my-tests-table tbody tr:hover {
    background: var(--td-border);
}
.teacher-dashboard .td-th-sort {
    color: var(--td-muted);
    text-decoration: none;
}
.teacher-dashboard .td-th-sort:hover {
    color: var(--td-text);
}
.teacher-dashboard .td-th-sort.is-active {
    color: var(--gp6-primary);
    font-weight: 600;
}
/* Senast tilldelade glostester (behållen styling) */
.teacher-dashboard .recent-assignments-card {
    background: var(--td-bg);
    border: 1px solid var(--td-border);
    border-radius: 12px;
    padding: 24px;
    margin-top: 24px;
}
.teacher-dashboard .recent-assignments-card h3 {
    margin: 0 0 16px 0;
    font-size: 1.25rem;
    color: var(--td-text);
}
.teacher-dashboard .recent-assignments-card .recent-assignments-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 12px;
}
.teacher-dashboard .recent-assignments-card .recent-assignments-header h3 a {
    color: inherit;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: color 0.2s ease;
}
.teacher-dashboard .recent-assignments-card .recent-assignments-header h3 a::after {
    content: '→';
    font-size: 0.85em;
    opacity: 0.45;
    transition: opacity 0.2s ease, transform 0.2s ease;
    display: inline-block;
}
.teacher-dashboard .recent-assignments-card .recent-assignments-header h3 a:hover {
    color: var(--gp6-primary);
}
.teacher-dashboard .recent-assignments-card .recent-assignments-header h3 a:hover::after {
    opacity: 1;
    transform: translateX(3px);
}
.teacher-dashboard .recent-assignments-card .gp6-completion-bar {
    height: 8px;
    background: var(--td-border);
    border-radius: 4px;
    overflow: hidden;
    margin-top: 6px;
    min-width: 80px;
}
.teacher-dashboard .recent-assignments-card .gp6-completion-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.2s ease;
}
.teacher-dashboard .recent-assignments-card .gp6-completion-fill.high { background: #22c55e; }
.teacher-dashboard .recent-assignments-card .gp6-completion-fill.mid { background: #3b82f6; }
.teacher-dashboard .recent-assignments-card .gp6-completion-fill.low { background: #93c5fd; }
.teacher-dashboard .recent-assignments-card .class-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 500;
}
.teacher-dashboard .recent-assignments-card .assignments-pagination {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 16px;
    flex-wrap: wrap;
}
.teacher-dashboard .recent-assignments-card .assignments-pagination a,
.teacher-dashboard .recent-assignments-card .assignments-pagination span {
    padding: 6px 12px;
    border-radius: 6px;
    text-decoration: none;
    font-size: 0.9rem;
}
.teacher-dashboard .recent-assignments-card .assignments-pagination a:hover {
    background: var(--td-border);
}
.teacher-dashboard .recent-assignments-card .assignments-pagination .current {
    font-weight: 600;
}

/* === ÅTERANVÄNDBARA SIDKOMPONENTER (flyttat från sid-specifika <style>) === */

/* ---- Gemensam knapp-ikon i tabeller (actions-cell) ---- */
.actions-cell,
.actions-cell-messages { white-space: nowrap; }
.actions-cell .btn-icon,
.actions-cell-messages .btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    margin: 0 2px;
    border: 1px solid var(--gp6-border, var(--border-color));
    border-radius: 6px;
    background: var(--gp6-bg-warm, var(--bg-secondary));
    color: var(--gp6-slate, var(--text-primary));
    cursor: pointer;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s;
}
.actions-cell .btn-icon:hover,
.actions-cell-messages .btn-icon:hover {
    background: var(--hover-bg);
    border-color: var(--gp6-primary, var(--accent-primary));
    color: var(--gp6-primary, var(--accent-primary));
}
.actions-cell .btn-icon-delete:hover,
.actions-cell-messages .btn-icon-delete:hover {
    border-color: #dc2626;
    color: #dc2626;
    background: rgba(220, 38, 38, 0.1);
}
.actions-cell .btn-icon-placeholder { visibility: hidden; pointer-events: none; }

/* ---- Sorterbara tabellrubriker ---- */
.sortable-stats .th-sort,
.sortable-messages .th-sort,
.sortable-my-glosor .th-sort,
.th-sort { color: inherit; text-decoration: none; display: inline-block; padding: 2px 4px; border-radius: 4px; }
.sortable-stats .th-sort:hover,
.sortable-messages .th-sort:hover,
.sortable-my-glosor .th-sort:hover,
.th-sort:hover { background: rgba(0,0,0,0.06); }
.sortable-stats .th-sort.active,
.sortable-stats .th-sort.is-active,
.sortable-messages .th-sort.active,
.sortable-my-glosor .th-sort.active,
.th-sort.active { font-weight: bold; }
.stats-th-sort { color: inherit; text-decoration: none; display: inline-block; padding: 2px 4px; border-radius: 4px; }
.stats-th-sort:hover { background: rgba(0,0,0,0.06); }
.stats-th-sort.is-active { font-weight: bold; }
[data-theme="dark"] .sortable-stats .th-sort:hover,
[data-theme="dark"] .sortable-messages .th-sort:hover,
[data-theme="dark"] .sortable-my-glosor .th-sort:hover { background: rgba(255,255,255,0.08); }
.sortable-my-glosor th { padding: 10px 8px; white-space: normal; line-height: 1.3; min-width: 0; }
.sortable-my-glosor td { padding: 10px 8px; }
.member-view .tests-section .data-table { table-layout: auto; width: 100%; min-width: 800px; }
.member-view .tests-section .data-table .th-bibliotek { min-width: 115px; }

/* ---- Inställningskort (admin) ---- */
.settings-card { background: var(--gp6-bg-card, #fff); padding: 20px; border-radius: 8px; box-shadow: 0 1px 3px rgba(0,0,0,.07); }
.settings-section { background: var(--gp6-bg-card, #fff); border: 1px solid var(--gp6-border, #ddd); border-radius: 8px; padding: 20px; }
[data-theme="dark"] .settings-card,
[data-theme="dark"] .settings-section { background: var(--card-bg); border-color: var(--border-color); }

/* ---- Label med hjälpknapp ---- */
.label-with-help { display: flex; align-items: center; gap: 0.5em; flex-wrap: wrap; }
.label-with-help .btn-help { flex-shrink: 0; }
.modal-content.separator-help-modal { max-width: 480px; }
.modal-content.separator-help-modal pre { margin: 0.5em 0 1em; overflow-x: auto; }

/* ---- Notiser ---- */
.notifications-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.notifications-item {
    border: 1px solid var(--gp6-border);
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    background: var(--gp6-bg-card, #fff);
    transition: box-shadow 0.15s;
}
.notifications-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.08); }
.notifications-item.notifications-unread { border-left: 4px solid var(--gp6-accent-primary, #4f46e5); }
.notifications-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
}
.notifications-icon { font-size: 1.25em; flex-shrink: 0; line-height: 1; }
.notifications-info { flex: 1; min-width: 0; overflow: hidden; }
.notifications-title { display: block; font-weight: 600; color: var(--gp6-text-primary); overflow-wrap: break-word; }
.notifications-date { display: block; font-size: 0.82em; color: var(--gp6-slate-muted, #64748b); margin-top: 3px; }
.notifications-olast {
    flex-shrink: 0;
    font-size: 0.72em;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    padding: 3px 9px;
    border-radius: 999px;
    background: var(--gp6-accent-primary, #4f46e5);
    color: #fff;
}
.notifications-chevron {
    flex-shrink: 0;
    color: var(--gp6-slate-muted, #94a3b8);
    font-size: 1.1em;
    font-style: normal;
    transition: transform 0.2s;
    user-select: none;
}
.notifications-item[data-open="1"] .notifications-chevron { transform: rotate(90deg); }
.notifications-detail {
    padding: 14px 16px;
    border-top: 1px solid var(--gp6-border);
    background: var(--gp6-bg-secondary, #f8fafc);
}
.notifications-message {
    color: var(--gp6-text-primary);
    line-height: 1.65;
    margin-bottom: 14px;
}
.notifications-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
[data-theme="dark"] .notifications-item { background: var(--gp6-bg-card, #1e293b); }
[data-theme="dark"] .notifications-detail { background: var(--gp6-bg-warm, #162032); }
[data-theme="dark"] .notifications-message { color: var(--gp6-slate-light, #cbd5e1); }

/* ---- Notiser (legacy full-kort) ---- */
.notification-item {
    background: var(--gp6-bg-card, #fff);
    border: 1px solid var(--gp6-border, #e5e7eb);
    border-radius: var(--gp6-radius-sm, 12px);
    padding: 15px;
    margin-bottom: 15px;
    position: relative;
    overflow: hidden;
}
.notification-item.unread { border-left: 4px solid #667eea; background: #f8f9ff; }
.notification-item.read { opacity: 0.7; }
.notification-header { display: flex; justify-content: space-between; align-items: start; margin-bottom: 10px; }
.notification-title { font-weight: bold; font-size: 1.1em; color: var(--gp6-slate, #333); }
.notification-time { color: var(--gp6-slate-muted, #999); font-size: 0.9em; }
.notification-message { color: var(--gp6-slate-light, #666); margin-bottom: 10px; }
.notification-actions { display: flex; gap: 10px; }
.notification-badge {
    position: absolute; top: 10px; right: 10px;
    background: #667eea; color: white; border-radius: 50%;
    width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; font-size: 0.8em;
}
[data-theme="dark"] .notification-item { background: var(--gp6-bg-card); border-color: var(--gp6-border); color: var(--gp6-slate); }
[data-theme="dark"] .notification-item.unread { background: rgba(102, 126, 234, 0.1); border-left-color: #667eea; }
[data-theme="dark"] .notification-item.read { opacity: 0.8; }
[data-theme="dark"] .notification-title { color: var(--gp6-slate); }
[data-theme="dark"] .notification-time { color: var(--gp6-slate-muted); }
[data-theme="dark"] .notification-message { color: var(--gp6-slate-muted); }
.notification-actions .btn,
.notification-actions a.btn,
.notification-actions button.btn {
    border-radius: var(--gp6-radius-sm, 8px); min-height: 34px; box-sizing: border-box;
    display: inline-flex; align-items: center; justify-content: center; padding-top: 6px; padding-bottom: 6px; line-height: 1.2;
}

/* ---- Glosor-menyn och kort ---- */
.glosor-menu { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; margin-top: 30px; }
.glosor-card {
    background: var(--gp6-bg-card, #fff);
    border: 1px solid var(--gp6-border, #ddd);
    border-radius: var(--gp6-radius-sm, 5px);
    padding: 25px;
    text-align: center;
    transition: transform 0.2s, box-shadow 0.2s;
}
.glosor-card:hover { transform: translateY(-5px); box-shadow: var(--gp6-shadow-hover, 0 5px 15px rgba(0,0,0,0.1)); border-color: var(--gp6-primary); }
.glosor-card h3 { margin: 0 0 15px 0; color: var(--gp6-primary, #667eea); }
.glosor-card p { color: var(--gp6-slate-light, #666); margin-bottom: 20px; }
.glosor-card .icon { font-size: 3em; margin-bottom: 15px; }
.glosor-card .btn-primary { background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-secondary) 100%); color: white !important; }
.glosor-card .btn-primary:hover { color: white !important; }
[data-theme="dark"] .glosor-card .btn-primary { background: linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%); color: white !important; }
[data-theme="dark"] .glosor-card { background: var(--card-bg); border-color: var(--border-color); }
[data-theme="dark"] .glosor-card:hover { box-shadow: 0 5px 15px rgba(0,0,0,0.4); }
[data-theme="dark"] .glosor-card h3 { color: var(--accent-primary, #0ea5e9); }

/* ---- Resultat-sammanfattning ---- */
.result-summary {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 30px;
    margin-bottom: 30px;
    text-align: center;
}
.result-score { font-size: 3rem; font-weight: 700; margin: 20px 0; }
.result-passed { color: #22c55e; }
.result-failed { color: #ef4444; }
.wrong-words-section { margin-top: 30px; }
.wrong-word-item {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
}
.wrong-word-item .word-pair { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.wrong-word-item .correct-answer { color: #22c55e; font-weight: 600; }
.wrong-word-item .wrong-answer { color: #ef4444; text-decoration: line-through; }
[data-theme="dark"] .wrong-word-item,
[data-theme="dark"] .result-summary { background: var(--card-bg, #1f2937); border-color: var(--border-color, #374151); }

/* ---- Changelog ---- */
.changelog-section { margin-bottom: 40px; }
.changelog-section h3 { margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid var(--gp6-border, #e5e7eb); }
.changelog-item {
    border: 1px solid var(--gp6-border, #ddd);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 15px;
    background: var(--gp6-bg-card, #fff);
    transition: box-shadow 0.2s;
}
.changelog-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.changelog-item.kommande { border-left: 4px solid #3b82f6; }
.changelog-item.pågående { border-left: 4px solid #f59e0b; }
.changelog-item.klar { border-left: 4px solid #22c55e; }
.changelog-header { display: flex; justify-content: space-between; align-items: start; margin-bottom: 10px; }
.changelog-title { font-size: 1.2em; font-weight: bold; margin: 0; display: flex; align-items: center; gap: 10px; }
.changelog-date { font-size: 0.9em; color: var(--gp6-slate-muted, #666); }
.changelog-description { margin: 10px 0; color: var(--gp6-slate, #333); line-height: 1.6; }
.checkmark { color: #22c55e; font-size: 1.3em; }
.changelog-section .progress-bar { background: var(--gp6-border, #e5e7eb); height: 10px; border-radius: 5px; overflow: hidden; margin: 10px 0; }
.changelog-section .progress-fill { height: 100%; transition: width 0.3s; }
.changelog-section .progress-fill.pågående { background: #f59e0b; }
.changelog-section .progress-fill.kommande { background: #3b82f6; }
.changelog-section .progress-text { font-size: 0.9em; color: var(--gp6-slate-muted, #666); margin-top: 5px; }
.status-badge { display: inline-block; padding: 4px 12px; border-radius: 12px; font-size: 0.85em; font-weight: bold; }
.status-kommande { background: #dbeafe; color: #1e40af; }
.status-pågående { background: #fef3c7; color: #92400e; }
.status-klar { background: #d1fae5; color: #065f46; }
[data-theme="dark"] .changelog-item { background: var(--card-bg); border-color: var(--border-color); color: var(--text-primary); }
[data-theme="dark"] .changelog-description { color: var(--text-secondary); }

/* ---- Omröstningar ---- */
.poll-card { background: var(--card-bg); padding: 20px; border-radius: 8px; border: 1px solid var(--border-color); margin-bottom: 16px; }
.poll-results { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border-color); }
.poll-result-bar { height: 24px; background: var(--border-color); border-radius: 4px; overflow: hidden; margin-bottom: 8px; }
.poll-result-fill { height: 100%; background: #4CAF50; }
.poll-option-row { display: flex; gap: 8px; margin-bottom: 8px; align-items: center; }
.poll-option-row input[type="text"] { flex: 1; }
.poll-actions { display: flex; gap: 6px; flex-shrink: 0; align-items: center; }
.poll-actions .btn-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 34px; height: 34px; padding: 0; margin: 0;
    border: 1px solid var(--border-color); border-radius: 6px;
    background: var(--bg-secondary); color: var(--text-primary);
    cursor: pointer; text-decoration: none; transition: background 0.2s, border-color 0.2s, color 0.2s;
    font: inherit;
}
.poll-actions .btn-icon:hover { background: var(--hover-bg); border-color: var(--accent-primary); color: var(--accent-primary); }
.poll-actions .btn-icon.btn-icon-delete:hover { border-color: #dc2626; color: #dc2626; background: rgba(220, 38, 38, 0.1); }
.poll-actions .btn-icon.btn-icon-active { color: #16a34a; }
.poll-actions .btn-icon.btn-icon-active:hover { color: #15803d; }
.poll-actions .btn-icon.btn-icon-inactive { color: #6b7280; opacity: 0.8; }
.poll-actions .btn-icon.btn-icon-inactive:hover { color: #4b5563; opacity: 1; }
.poll-result-row.clickable { cursor: pointer; transition: background 0.2s; }
.poll-result-row.clickable:hover { background: rgba(0,0,0,0.04); }
[data-theme="dark"] .poll-result-row.clickable:hover { background: rgba(255,255,255,0.06); }
.poll-detail-modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); }
.poll-detail-modal.show { display: flex; align-items: center; justify-content: center; }
.poll-detail-content { background: var(--card-bg); padding: 24px; border-radius: 8px; max-width: 500px; width: 90%; max-height: 80vh; overflow-y: auto; }
.poll-detail-content h4 { margin-top: 0; }
.poll-detail-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.poll-detail-table th, .poll-detail-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border-color); }
.poll-detail-table th { font-weight: 600; }
.poll-actions form { display: inline; }

/* ---- Testresultat-sektion ---- */
.test-results-section {
    background: var(--bg-secondary, #f9f9f9);
    border-radius: 8px;
}
[data-theme="dark"] .test-results-section { background: var(--card-bg); border: 1px solid var(--border-color); }

/* ---- Share-ikoner ---- */
.share-icons .social-share { display: flex; gap: 10px; flex-wrap: wrap; }
.share-icons .share-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; border-radius: 8px;
    background: rgba(14, 165, 233, 0.1); color: #0ea5e9;
    text-decoration: none; border: 1px solid rgba(14, 165, 233, 0.2); cursor: pointer; transition: all 0.3s;
}
.share-icons .share-btn:hover { background: rgba(14, 165, 233, 0.2); transform: translateY(-2px); }
.share-icons .share-btn.facebook:hover { background: #1877f2; color: white; border-color: #1877f2; }
.share-icons .share-btn.twitter:hover { background: #1da1f2; color: white; border-color: #1da1f2; }
.share-icons .share-btn.email:hover { background: #ea4335; color: white; border-color: #ea4335; }
.share-icons .share-btn.whatsapp:hover { background: #25d366; color: white; border-color: #25d366; }
.share-icons .share-btn.copy:hover { background: #667eea; color: white; border-color: #667eea; }
.share-icons .share-btn.qr-modal-trigger:hover { background: #0d9488; color: white; border-color: #0d9488; }
.share-icons .share-btn.print-study-mode-btn:hover { background: #f59e0b; color: white; border-color: #f59e0b; }
.share-icons .share-btn.report-test-btn:hover { background: #ef4444; color: white; border-color: #ef4444; }
.share-icons .share-btn.import-test-btn:hover { background: #22c55e; color: white; border-color: #22c55e; }
.share-icons .share-btn.import-test-btn.imported { background: rgba(34, 197, 94, 0.2); color: #22c55e; }
.share-icons .share-btn.import-test-btn.imported:hover { background: #22c55e; color: white; }

/* ---- Modal (practice, QR m.fl.) ---- */
.modal { position: fixed; left: 0; top: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); display: flex; align-items: center; justify-content: center; z-index: 9999; }
.modal-content { background: var(--bg-primary, var(--card-bg)); border-radius: 12px; box-shadow: 0 4px 20px rgba(0,0,0,0.2); max-width: 90%; }
.modal-header { display: flex; justify-content: space-between; align-items: center; padding: 20px; border-bottom: 1px solid var(--border-color); }
.modal-close { font-size: 28px; cursor: pointer; line-height: 1; }
.modal-close:hover { color: #000; }
[data-theme="dark"] .modal-close:hover { color: #fff; }
.modal-body { padding: 20px; }
.modal-footer { padding: 20px; border-top: 1px solid var(--border-color); }

/* ---- Svåra ord ---- */
/* Kompakt, Tailwind-inspirerad layout för "Mina svåra ord" */
.difficulty-section {
    margin-bottom: 30px;
}

.difficulty-header {
    padding: 12px 16px;
    border-radius: var(--gp6-radius-sm, 8px);
    margin-bottom: 16px;
    font-weight: 700;
    color: var(--text-primary);
    display: flex;
    align-items: center;
}

/* Statusfärger för svårighetsnivåer */
.difficulty-very-hard {
    --difficulty-bg: #ffebee;
    --difficulty-border: #f44336;
}

.difficulty-hard {
    --difficulty-bg: #fff3e0;
    --difficulty-border: #ff9800;
}

.difficulty-medium {
    --difficulty-bg: #fffde7;
    --difficulty-border: #ffc107;
}

.difficulty-easy {
    --difficulty-bg: #e8f5e9;
    --difficulty-border: #4caf50;
}

.difficulty-review {
    --difficulty-bg: #e3f2fd;
    --difficulty-border: #2196f3;
}

.difficulty-header.difficulty-very-hard,
.difficulty-header.difficulty-hard,
.difficulty-header.difficulty-medium,
.difficulty-header.difficulty-easy,
.difficulty-header.difficulty-review {
    background: var(--difficulty-bg);
    border-left: 4px solid var(--difficulty-border);
}

[data-theme="dark"] .difficulty-header.difficulty-very-hard {
    --difficulty-bg: rgba(244, 67, 54, 0.15);
}

[data-theme="dark"] .difficulty-header.difficulty-hard {
    --difficulty-bg: rgba(255, 152, 0, 0.15);
}

[data-theme="dark"] .difficulty-header.difficulty-medium {
    --difficulty-bg: rgba(255, 193, 7, 0.15);
}

[data-theme="dark"] .difficulty-header.difficulty-easy {
    --difficulty-bg: rgba(76, 175, 80, 0.15);
}

[data-theme="dark"] .difficulty-header.difficulty-review {
    --difficulty-bg: rgba(33, 150, 243, 0.15);
}

.word-item {
    background: var(--gp6-bg-card, #ffffff);
    padding: 16px 18px;
    margin-bottom: 12px;
    border-radius: var(--gp6-radius-sm, 8px);
    border: 1px solid var(--gp6-border, #ddd);
    color: var(--text-primary);
    display: flex;
    flex-direction: column;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.word-item:hover {
    border-color: var(--accent-primary);
    box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
    transform: translateY(-1px);
}

[data-theme="dark"] .word-item {
    background: var(--card-bg);
    border-color: var(--border-color);
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.8);
}

.word-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    margin-top: 10px;
    font-size: 0.9em;
    color: var(--gp6-slate-muted, #666666);
}

[data-theme="dark"] .word-stats {
    color: var(--text-secondary);
}

.word-stats span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.word-actions {
    margin-top: 12px;
    padding-top: 8px;
}

.difficulty-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 16px;
}

.difficulty-grid .word-item {
    margin-bottom: 0;
}

@media (max-width: 640px) {
    .difficulty-grid {
        grid-template-columns: 1fr;
    }
}

/* ---- Taggar ---- */
.tag-item {
    display: inline-block; margin: 10px; padding: 15px;
    background: var(--bg-secondary, #f9f9f9); border-radius: 5px; border: 1px solid var(--border-color, #ddd);
}
.tag-preview { display: inline-block; padding: 5px 10px; border-radius: 3px; color: white; margin-left: 10px; }
[data-theme="dark"] .tag-item { background: var(--bg-secondary); border-color: var(--border-color); }

/* ---- Mappar ---- */
.folder-item {
    margin: 10px 0; padding: 10px;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-left: 3px solid #667eea;
}
.folder-item.level-1 { margin-left: 20px; }
.folder-item.level-2 { margin-left: 40px; }
.folder-item.level-3 { margin-left: 60px; }

/* ---- Testbibliotek ---- */
.test-card {
    border: 1px solid var(--gp6-border, #ddd);
    border-radius: 5px;
    padding: 20px;
    margin-bottom: 20px;
    background: var(--gp6-bg-card, white);
}
[data-theme="dark"] .test-card { background: var(--card-bg); border-color: var(--border-color); }
.test-card-header { display: flex; justify-content: space-between; align-items: start; margin-bottom: 15px; }
.test-stats { display: flex; gap: 15px; color: var(--gp6-slate-muted, #666); font-size: 0.9em; }
.favorite-btn { background: none; border: none; font-size: 1.5em; cursor: pointer; padding: 5px; }
.favorite-btn.active { color: #f44336; }
[data-theme="dark"] .filter-section { background: var(--bg-secondary) !important; }

/* ---- Admin tabeller ---- */
.admin-view .admin-table-fit .data-table { min-width: 960px; }
.admin-view .admin-table-fit .data-table th:nth-child(5),
.admin-view .admin-table-fit .data-table td:nth-child(5) { min-width: 110px; white-space: nowrap; }
.admin-view .admin-table-fit .data-table th:nth-child(6),
.admin-view .admin-table-fit .data-table td:nth-child(6) { width: 2.8em; min-width: 2.8em; text-align: center; }
.admin-view .admin-table-fit .data-table th:nth-child(7),
.admin-view .admin-table-fit .data-table td:nth-child(7) { width: 2.8em; min-width: 2.8em; text-align: center; }
.admin-view .admin-table-fit .data-table .perform-count-link { text-decoration: none; font-weight: 600; }
.admin-view .admin-table-fit .data-table .perform-count-link:hover { text-decoration: underline; }
.admin-view .admin-table-fit .data-table { min-width: 900px; }
.admin-view .stats-table-wrapper { overflow-x: visible; max-width: 100%; }
.admin-view .stats-table-wrapper .sortable-stats { table-layout: fixed; width: 100%; min-width: 960px; }
.admin-view .stats-table-wrapper .sortable-stats th,
.admin-view .stats-table-wrapper .sortable-stats td { overflow-wrap: break-word; word-wrap: break-word; }
.admin-view .stats-table-wrapper .sortable-stats .gp6-btn-small { white-space: nowrap; font-size: 0.85rem; padding: 6px 10px; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(1),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(1) { width: 3%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(2),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(2) { width: 18%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(3),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(3) { width: 8%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(4),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(4) { width: 9%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(5),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(5) { width: 9%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(6),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(6) { width: 9%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(7),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(7) { width: 12%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(8),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(8) { width: 11%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(9),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(9) { width: 18%; }
.admin-view .stats-table-wrapper .sortable-stats th:nth-child(10),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(10) { width: 9%; }
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(7),
.admin-view .stats-table-wrapper .sortable-stats td:nth-child(8) { white-space: normal; font-size: 0.9rem; }
@media (max-width: 768px) {
    .admin-view .stats-table-wrapper { overflow-x: auto; }
    .admin-view .stats-table-wrapper .sortable-stats { table-layout: auto; min-width: 800px; }
}
.unread-message { font-weight: 600; }

/* ===== Profilsida – fliksystem ===== */
.profile-main-tabs {
    display: flex;
    border-bottom: 2px solid var(--border-color);
    margin-bottom: 28px;
    gap: 0;
}

.profile-tab-btn {
    padding: 10px 22px;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    color: var(--text-secondary);
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    transition: color 0.15s ease, border-color 0.15s ease;
    white-space: nowrap;
}

.profile-tab-btn:hover {
    color: var(--text-primary);
}

.profile-tab-btn.active {
    color: var(--accent-primary);
    border-bottom-color: var(--accent-primary);
}

.profile-tab-panel {
    display: none;
}

.profile-tab-panel.active {
    display: block;
}

/* ===== Standardinställningar – layout med sidnav ===== */
.defaults-layout {
    display: grid;
    grid-template-columns: 148px 1fr;
    gap: 0;
    margin-top: 20px;
}

.defaults-subnav {
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-top: 2px;
}

.defaults-subnav-btn {
    padding: 9px 14px 9px 10px;
    background: none;
    border: none;
    border-left: 3px solid transparent;
    text-align: left;
    color: var(--text-secondary);
    font-size: 0.92rem;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    transition: color 0.15s, background 0.15s, border-color 0.15s;
    border-radius: 3px 0 0 3px;
}

.defaults-subnav-btn:hover {
    color: var(--text-primary);
    background: var(--hover-bg);
}

.defaults-subnav-btn.active {
    color: var(--accent-primary);
    border-left-color: var(--accent-primary);
    background: var(--hover-bg);
}

.defaults-content {
    padding-left: 24px;
    min-width: 0;
}

.defaults-subtab-panel {
    display: none;
}

.defaults-subtab-panel.active {
    display: block;
}

.defaults-fields {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.defaults-field-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.defaults-field-row label {
    min-width: 200px;
    color: var(--text-primary);
    font-size: 0.92rem;
}

.defaults-field-row input[type="number"] {
    width: 170px;
    padding: 7px 10px;
    border: 1.5px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-primary);
    color: var(--text-primary);
    font-family: inherit;
    font-size: 0.92rem;
}

.defaults-save-row {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

@media (max-width: 640px) {
    .profile-main-tabs {
        overflow-x: auto;
    }

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

    .defaults-subnav {
        flex-direction: row;
        border-right: none;
        border-bottom: 1px solid var(--border-color);
        margin-bottom: 16px;
        padding-top: 0;
        overflow-x: auto;
    }

    .defaults-subnav-btn {
        border-left: none;
        border-bottom: 3px solid transparent;
        border-radius: 0;
        white-space: nowrap;
        padding: 8px 14px;
    }

    .defaults-subnav-btn.active {
        border-left: none;
        border-bottom-color: var(--accent-primary);
    }

    .defaults-content {
        padding-left: 0;
    }
}

/* ── Elev – ingen klass-banner ──────────────────────────── */
.gp6-no-class-banner {
    display: flex;
    align-items: center;
    gap: 16px;
    background: var(--gp6-card-bg, var(--card-bg));
    border: 2px solid var(--gp6-accent-primary, var(--accent-primary));
    border-radius: 14px;
    padding: 20px 24px;
    flex-wrap: wrap;
}

.gp6-no-class-icon {
    flex-shrink: 0;
    color: var(--gp6-accent-primary, var(--accent-primary));
    display: flex;
    align-items: center;
}

.gp6-no-class-content {
    flex: 1;
    min-width: 180px;
}

.gp6-no-class-content strong {
    display: block;
    font-size: 1.05rem;
    margin-bottom: 4px;
}

.gp6-no-class-content p {
    margin: 0;
    color: var(--gp6-text-secondary, var(--text-secondary));
    font-size: 0.95rem;
}

@media (max-width: 540px) {
    .gp6-no-class-banner {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
}
