/* ═══════════════════════════════════════════════════════════════
   LEARN CATALAN — Duolingo-style Language Learning SPA
   Dark cinematic aesthetic · GRXHUB design system
   ═══════════════════════════════════════════════════════════════ */


/* ───────────────────────────────────────────────────────────────
   1. APP VARIABLES
   ─────────────────────────────────────────────────────────────── */
:root {
    --cat-terracotta: #E8734A;
    --cat-terracotta-glow: rgba(232, 115, 74, 0.3);
    --cat-gold: #F4C654;
    --cat-gold-glow: rgba(244, 198, 84, 0.3);
    --cat-success: #4ade94;
    --cat-error: #ff6b6b;
    --cat-help: #60a5fa;
    --cat-help-glow: rgba(96, 165, 250, 0.3);
    --cat-heart: #ff6b9d;
    --cat-star: #F4C654;
    --cat-card-bg: rgba(22, 23, 29, 0.8);
}


/* ───────────────────────────────────────────────────────────────
   2. APP SHELL
   ─────────────────────────────────────────────────────────────── */
.cat-app {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    padding-top: var(--header-height);
    color: var(--text-primary);
    font-family: var(--font-body);
    position: relative;
    overflow-x: hidden;
}

.cat-app ~ footer,
.cat-app ~ .site-footer {
    display: none;
}


/* ───────────────────────────────────────────────────────────────
   3. VIEW CONTAINERS
   ─────────────────────────────────────────────────────────────── */
.cat-view-map {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-2xl) var(--space-md) var(--space-lg);
    min-height: calc(100vh - var(--header-height));
}

.cat-view-unit {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-2xl) var(--space-md) var(--space-3xl);
    min-height: calc(100vh - var(--header-height));
    max-width: 640px;
    margin: 0 auto;
    width: 100%;
}

.cat-app.cat-view-lesson {
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100vh;
    height: 100dvh;
    padding-top: 0;
    min-height: 0;
    overflow: hidden;
}

.cat-view-complete {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - var(--header-height));
    padding: var(--space-lg);
    position: relative;
    overflow: hidden;
}

.cat-view-stats {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-2xl) var(--space-md) var(--space-lg);
    min-height: calc(100vh - var(--header-height));
}


/* ───────────────────────────────────────────────────────────────
   4. STATS BAR (inline bar above content)
   ─────────────────────────────────────────────────────────────── */
.cat-stats-bar {
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: var(--space-sm) var(--space-md);
    background: rgba(22, 23, 29, 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: var(--border-thin) solid var(--border-subtle);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-lg);
    width: 100%;
    max-width: 480px;
}

.cat-stat {
    display: flex;
    align-items: center;
    gap: 6px;
}

.cat-stat-val {
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.cat-stat-xp svg { color: var(--cat-gold); }
.cat-stat-hearts svg { color: var(--cat-heart); }
.cat-stat-streak svg { color: var(--cat-terracotta); }


/* ───────────────────────────────────────────────────────────────
   5. MAP VIEW — Unit Cards
   ─────────────────────────────────────────────────────────────── */
.cat-map-units {
    width: 100%;
    max-width: 600px;
}

.cat-map-section {
    margin-bottom: var(--space-xl);
}

.cat-map-cefr-header {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-sm);
    border-bottom: 2px solid var(--border-default);
}

.cat-unit-card {
    position: relative;
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background: var(--cat-card-bg);
    border: var(--border-thin) solid var(--border-default);
    border-left: var(--border-thick) solid var(--cat-terracotta);
    border-radius: var(--radius-md);
    cursor: pointer;
    margin-bottom: var(--space-md);
    transition: transform var(--transition-fast),
                box-shadow var(--transition-fast),
                border-color var(--transition-fast);
}

.cat-unit-card:hover {
    transform: var(--hover-lift);
    box-shadow: var(--shadow-md);
    border-color: var(--border-hover);
    border-left-color: var(--cat-terracotta);
}

.cat-unit-card--locked {
    opacity: 0.45;
    cursor: not-allowed;
    border-left-color: var(--text-muted);
    pointer-events: none;
}

/* ───────────────────────────────────────────────────────────────
   6. UNIT VIEW — Header, Progress, Lesson List
   ─────────────────────────────────────────────────────────────── */
.cat-unit-header {
    margin-bottom: var(--space-lg);
    max-width: 560px;
}

.cat-view-unit > .cat-unit-header {
    text-align: center;
}

.cat-unit-card .cat-unit-header {
    flex: 1;
    min-width: 0;
}

.cat-unit-header .cat-cefr-badge {
    margin-bottom: var(--space-sm);
}

.cat-unit-header h1,
.cat-unit-header h3,
.cat-unit-title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    margin: 0 0 var(--space-xs);
    line-height: 1.3;
    color: var(--text-primary);
}

.cat-unit-card .cat-unit-title {
    font-size: var(--text-base);
    margin: 0 0 2px;
}

.cat-unit-card .cat-unit-desc {
    font-size: var(--text-xs);
    display: block;
}

.cat-unit-desc {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    margin: 0;
    line-height: 1.5;
}

/* Progress section (unit view) */
.cat-view-unit > .cat-unit-progress {
    width: 100%;
    max-width: 560px;
    margin-bottom: var(--space-lg);
}

/* Progress (inside unit card) */
.cat-unit-card .cat-unit-progress {
    width: 60px;
    flex-shrink: 0;
}

.cat-unit-progress__meta {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-xs);
    color: var(--text-muted);
    margin-bottom: 6px;
}

/* Lesson list (vertical card rows) */
.cat-lesson-list {
    width: 100%;
    max-width: 560px;
    display: flex;
    flex-direction: column;
    gap: 1px;
    background: var(--border-subtle);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: var(--border-thin) solid var(--border-subtle);
}

.cat-lesson-row {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background: var(--bg-secondary);
    border: none;
    cursor: pointer;
    text-align: left;
    width: 100%;
    font-family: var(--font-body);
    color: var(--text-primary);
    transition: background var(--transition-fast);
}

.cat-lesson-row:hover {
    background: var(--bg-tertiary);
}

.cat-lesson-row__num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: var(--radius-full);
    background: var(--bg-elevated);
    border: var(--border-thin) solid var(--border-default);
    font-family: var(--font-display);
    font-size: var(--text-sm);
    font-weight: 700;
    flex-shrink: 0;
    color: var(--text-secondary);
}

.cat-lesson-row__title {
    flex: 1;
    font-size: var(--text-sm);
    font-weight: 500;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cat-lesson-row__stars {
    display: flex;
    gap: 2px;
    flex-shrink: 0;
    font-size: 0.8rem;
}

.cat-lesson-row__status {
    flex-shrink: 0;
    font-size: var(--text-sm);
    color: var(--text-muted);
}

.cat-lesson-row__arrow {
    flex-shrink: 0;
    font-size: 1.25rem;
    color: var(--text-muted);
    font-weight: 300;
}

/* Row states */
.cat-lesson-row--available {
    background: var(--bg-secondary);
}

.cat-lesson-row--available .cat-lesson-row__num {
    background: rgba(232, 115, 74, 0.12);
    border-color: var(--cat-terracotta);
    color: var(--cat-terracotta);
}

.cat-lesson-row--available .cat-lesson-row__arrow {
    color: var(--cat-terracotta);
}

.cat-lesson-row--completed .cat-lesson-row__num {
    background: rgba(74, 222, 148, 0.12);
    border-color: var(--cat-success);
    color: var(--cat-success);
}

.cat-lesson-row--locked {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

.cat-lesson-row--locked .cat-lesson-row__title {
    color: var(--text-muted);
}


/* ───────────────────────────────────────────────────────────────
   7. LESSON VIEW — Top Bar
   ─────────────────────────────────────────────────────────────── */
.cat-lesson-top,
.cat-lesson-topbar {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    width: 100%;
    background: var(--bg-primary);
    border-bottom: var(--border-thin) solid var(--border-subtle);
    flex-shrink: 0;
}

.cat-lesson-close {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    font-size: 1.25rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background var(--transition-fast),
                color var(--transition-fast);
}

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

.cat-lesson-settings {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    font-size: 1.1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background var(--transition-fast),
                color var(--transition-fast);
}

.cat-lesson-settings:hover {
    background: var(--bg-elevated);
    color: var(--text-primary);
}

.cat-lesson-help {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid var(--cat-help);
    background: transparent;
    color: var(--cat-help);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background var(--transition-fast),
                color var(--transition-fast);
}

.cat-lesson-help:hover {
    background: var(--cat-help);
    color: #fff;
}

.cat-lesson-help--used {
    opacity: 0.3;
    pointer-events: none;
}

.cat-lesson-progress {
    flex: 1;
    height: 8px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-full);
    overflow: hidden;
}

.cat-lesson-progress__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--cat-terracotta), var(--cat-gold));
    border-radius: var(--radius-full);
    transition: width 0.4s var(--ease-smooth);
}

.cat-lesson-hearts {
    display: none;
}

.cat-lesson-pct {
    flex-shrink: 0;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-secondary);
    min-width: 3ch;
    text-align: right;
}


/* ───────────────────────────────────────────────────────────────
   8. EXERCISE AREA
   ─────────────────────────────────────────────────────────────── */
.cat-exercise-area {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-md);
    flex: 1;
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
    overflow-y: auto;
    min-height: 0;
}

.cat-prompt-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.cat-prompt-wrap .cat-prompt {
    margin-bottom: 0;
}

.cat-prompt {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    text-align: center;
    line-height: 1.5;
    margin-bottom: var(--space-sm);
}

.cat-prompt-speaker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(232, 115, 74, 0.15);
    border: var(--border-thin) solid var(--cat-terracotta);
    color: var(--cat-terracotta);
    cursor: pointer;
    transition: transform var(--transition-fast),
                background var(--transition-fast);
}

.cat-prompt-speaker:hover {
    transform: scale(1.1);
    background: rgba(232, 115, 74, 0.25);
}

.cat-prompt-speaker svg {
    width: 22px;
    height: 22px;
}


/* ───────────────────────────────────────────────────────────────
   9. EXERCISE: MULTIPLE CHOICE
   ─────────────────────────────────────────────────────────────── */
.cat-options-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
    width: 100%;
}

.cat-option-card {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80px;
    padding: var(--space-md);
    background: var(--cat-card-bg);
    border: var(--border-medium) solid var(--border-default);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 1rem;
    font-weight: 500;
    color: var(--text-primary);
    text-align: center;
    line-height: 1.4;
    transition: transform var(--transition-fast),
                border-color var(--transition-fast),
                box-shadow var(--transition-fast),
                background var(--transition-fast);
}

.cat-option-card:hover {
    transform: translateY(-3px);
    border-color: var(--border-hover);
    box-shadow: var(--shadow-sm);
}

.cat-option-card.cat-selected {
    border-color: var(--cat-terracotta);
    background: rgba(232, 115, 74, 0.08);
    box-shadow: 0 0 16px var(--cat-terracotta-glow);
}

.cat-option-card.cat-answer-correct {
    border-color: var(--cat-success);
    background: rgba(74, 222, 148, 0.1);
    box-shadow: 0 0 16px rgba(74, 222, 148, 0.3);
}

.cat-option-card.cat-answer-wrong {
    border-color: var(--cat-error);
    background: rgba(255, 107, 107, 0.1);
    box-shadow: 0 0 16px rgba(255, 107, 107, 0.3);
}

.cat-option-card.cat-answer-partial {
    border-color: var(--cat-gold);
    background: rgba(244, 198, 84, 0.1);
    box-shadow: 0 0 16px var(--cat-gold-glow);
}

.cat-option-card.cat-answer-help {
    border-color: var(--cat-help);
    background: rgba(96, 165, 250, 0.1);
    box-shadow: 0 0 16px var(--cat-help-glow);
}


/* ───────────────────────────────────────────────────────────────
   10. EXERCISE: FILL IN BLANK
   ─────────────────────────────────────────────────────────────── */
.cat-fib-sentence {
    font-size: var(--text-xl);
    line-height: 1.8;
    margin-bottom: var(--space-lg);
    text-align: center;
    width: 100%;
}

.cat-fib-input {
    display: block;
    width: 100%;
    max-width: 400px;
    margin: 0 auto var(--space-md);
    padding: var(--space-md);
    background: var(--bg-elevated);
    border: var(--border-medium) solid var(--border-default);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-family: var(--font-body);
    font-size: var(--text-lg);
    text-align: center;
    outline: none;
    transition: border-color var(--transition-fast),
                box-shadow var(--transition-fast);
}

.cat-fib-input:focus {
    border-color: var(--cat-terracotta);
    box-shadow: 0 0 12px var(--cat-terracotta-glow);
}

.cat-fib-input.cat-answer-help {
    border-color: var(--cat-help);
    box-shadow: 0 0 12px var(--cat-help-glow);
    color: var(--cat-help);
}

.cat-fib-hint {
    font-size: var(--text-sm);
    color: var(--text-muted);
    text-align: center;
    margin-top: var(--space-xs);
}


/* ───────────────────────────────────────────────────────────────
   11. EXERCISE: WORD ORDER & TRANSLATION (shared)
   ─────────────────────────────────────────────────────────────── */
.cat-word-target {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    min-height: 56px;
    padding: var(--space-md);
    border: 2px dashed var(--border-hover);
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.02);
    width: 100%;
    align-items: center;
}

.cat-word-target-placeholder {
    color: var(--text-muted);
    font-style: italic;
    font-size: 0.875rem;
}

.cat-word-bank {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    padding: var(--space-md);
    width: 100%;
    justify-content: center;
}

.cat-chip {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    background: var(--cat-card-bg);
    border: var(--border-thin) solid var(--border-default);
    border-radius: var(--radius-full);
    cursor: pointer;
    font-size: 0.938rem;
    font-weight: 500;
    color: var(--text-primary);
    user-select: none;
    transition: transform var(--transition-fast),
                border-color var(--transition-fast),
                background var(--transition-fast),
                opacity var(--transition-fast);
}

.cat-chip:hover {
    border-color: var(--cat-terracotta);
    transform: translateY(-2px);
}

.cat-chip--placed {
    background: rgba(232, 115, 74, 0.1);
    border-color: var(--cat-terracotta);
}

.cat-chip--placed.cat-answer-correct {
    border-color: var(--cat-success);
    background: rgba(74, 222, 148, 0.1);
}

.cat-chip--placed.cat-answer-wrong {
    border-color: var(--cat-error);
    background: rgba(255, 107, 107, 0.1);
}

.cat-chip--placed.cat-answer-help {
    border-color: var(--cat-help);
    background: rgba(96, 165, 250, 0.1);
}

.cat-chip--used {
    opacity: 0.3;
    pointer-events: none;
}


/* ───────────────────────────────────────────────────────────────
   12. EXERCISE: MATCHING
   ─────────────────────────────────────────────────────────────── */
.cat-match-wrapper {
    display: flex;
    gap: var(--space-lg);
    width: 100%;
}

.cat-match-col,
.cat-match-left,
.cat-match-right {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    flex: 1;
}

.cat-match-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: var(--space-sm) var(--space-md);
    background: var(--cat-card-bg);
    border: var(--border-medium) solid var(--border-default);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.938rem;
    font-weight: 500;
    color: var(--text-primary);
    text-align: center;
    transition: border-color var(--transition-fast),
                background var(--transition-fast),
                transform var(--transition-fast);
}

.cat-match-btn:hover {
    border-color: var(--border-hover);
    transform: translateY(-2px);
}

.cat-match-btn.cat-selected {
    border-color: var(--cat-terracotta);
    background: rgba(232, 115, 74, 0.08);
    box-shadow: 0 0 12px var(--cat-terracotta-glow);
}

.cat-match-btn.cat-match-success {
    border-color: var(--cat-success);
    background: rgba(74, 222, 148, 0.08);
    opacity: 0.7;
    pointer-events: none;
}

.cat-match-btn.cat-answer-help {
    border-color: var(--cat-help);
    background: rgba(96, 165, 250, 0.08);
    box-shadow: 0 0 12px var(--cat-help-glow);
}

.cat-match-btn.cat-shake {
    animation: shake 0.4s ease;
    border-color: var(--cat-error);
}


/* ───────────────────────────────────────────────────────────────
   13. EXERCISE: LISTENING
   ─────────────────────────────────────────────────────────────── */
.cat-listen-speaker {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.cat-listen-btn {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(232, 115, 74, 0.15);
    border: var(--border-thin) solid var(--cat-terracotta);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cat-terracotta);
    transition: transform var(--transition-fast),
                background var(--transition-fast),
                box-shadow var(--transition-fast);
}

.cat-listen-btn:hover {
    transform: scale(1.08);
    background: rgba(232, 115, 74, 0.25);
    box-shadow: 0 4px 16px var(--cat-terracotta-glow);
}

.cat-listen-btn:active {
    transform: scale(0.95);
}




/* ───────────────────────────────────────────────────────────────
   16. FEEDBACK BAR
   ─────────────────────────────────────────────────────────────── */
.cat-feedback-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-md) var(--space-lg);
    display: flex;
    align-items: center;
    gap: var(--space-md);
    font-weight: 600;
    font-size: 1rem;
    z-index: var(--z-fixed);
    transform: translateY(0);
    transition: transform 0.3s var(--ease-smooth),
                opacity 0.3s var(--ease-smooth);
}

.cat-feedback-bar--hidden {
    transform: translateY(100%);
    opacity: 0;
    pointer-events: none;
}

.cat-feedback-bar--correct {
    background: var(--cat-success);
    color: #0a3d1a;
}

.cat-feedback-bar--wrong {
    background: var(--cat-error);
    color: #3d0a0a;
}

.cat-feedback-bar--partial {
    background: var(--cat-gold);
    color: #3d2e0a;
}

.cat-feedback-bar--help {
    background: var(--cat-help);
    color: #0a1e3d;
}

.cat-feedback-bar .cat-feedback-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}

.cat-btn--next {
    background: rgba(0, 0, 0, 0.15);
    color: inherit;
    padding: 8px 24px;
    border-radius: var(--radius-md);
    border: 2px solid rgba(0, 0, 0, 0.2);
    font-weight: 600;
    cursor: pointer;
    flex-shrink: 0;
    transition: background var(--transition-fast);
}

.cat-btn--next:hover {
    background: rgba(0, 0, 0, 0.25);
}

.cat-feedback-msg {
    flex: 1;
}

.cat-feedback-answer {
    font-weight: 400;
    opacity: 0.9;
    font-size: 0.875rem;
    margin-top: 2px;
}

.cat-feedback-body {
    flex: 1;
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
}

.cat-feedback-explanation {
    font-weight: 400;
    font-size: 0.875rem;
    opacity: 0.85;
    margin-top: 4px;
    line-height: 1.4;
}


/* ───────────────────────────────────────────────────────────────
   17. BUTTONS
   ─────────────────────────────────────────────────────────────── */
.cat-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 32px;
    border-radius: var(--radius-md);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    border: none;
    color: white;
    transition: transform var(--transition-fast),
                box-shadow var(--transition-fast),
                opacity var(--transition-fast),
                background var(--transition-fast);
}

.cat-btn:hover {
    transform: translateY(-2px);
}

.cat-btn--check {
    width: 100%;
    max-width: 400px;
    padding: 14px 32px;
    background: linear-gradient(135deg, var(--cat-terracotta), #d45f3a);
    border-radius: var(--radius-lg);
    font-size: 1.125rem;
}

.cat-btn--check:hover {
    box-shadow: 0 8px 24px var(--cat-terracotta-glow);
}

.cat-btn--check:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.cat-btn--primary {
    background: linear-gradient(135deg, var(--cat-terracotta), #d45f3a);
}

.cat-btn--secondary {
    background: var(--bg-elevated);
    border: var(--border-thin) solid var(--border-default);
    color: var(--text-primary);
}

.cat-btn--back {
    background: transparent;
    border: none;
    color: var(--text-muted);
    padding: var(--space-xs) 0;
    font-size: var(--text-sm);
    margin-bottom: var(--space-lg);
    align-self: flex-start;
    gap: var(--space-xs);
}

.cat-btn--back:hover {
    color: var(--text-primary);
    transform: none;
}

.cat-btn--stats {
    background: transparent;
    border: var(--border-thin) solid var(--border-default);
    color: var(--text-secondary);
    padding: 10px 24px;
    margin-top: var(--space-xl);
}

.cat-btn--continue {
    margin-top: var(--space-lg);
}


/* ───────────────────────────────────────────────────────────────
   18. HEARTS
   ─────────────────────────────────────────────────────────────── */
.cat-heart {
    font-size: 1.125rem;
    transition: transform var(--transition-fast);
}

.cat-heart--filled {
    color: var(--cat-heart);
}

.cat-heart--empty {
    color: var(--text-disabled, var(--text-muted));
    opacity: 0.4;
}


/* ───────────────────────────────────────────────────────────────
   19. STARS
   ─────────────────────────────────────────────────────────────── */
.cat-star {
    display: inline-block;
    transition: transform 0.3s var(--ease-bounce);
}

.cat-star--filled {
    color: var(--cat-star);
}

.cat-star--empty {
    color: var(--text-disabled, var(--text-muted));
    opacity: 0.3;
}

.cat-star--large {
    font-size: 2.5rem;
}


/* ───────────────────────────────────────────────────────────────
   20. PROGRESS BARS
   ─────────────────────────────────────────────────────────────── */
.cat-progress-bar {
    position: relative;
    width: 100%;
    height: 6px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-full);
    overflow: hidden;
}

.cat-progress-bar__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--cat-terracotta), var(--cat-gold));
    border-radius: var(--radius-full);
    transition: width 0.4s var(--ease-smooth);
}

.cat-progress-bar--small {
    height: 4px;
    flex: 1;
    min-width: 60px;
}

.cat-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--cat-terracotta), var(--cat-gold));
    border-radius: var(--radius-full);
    transition: width 0.4s var(--ease-smooth);
}


/* ───────────────────────────────────────────────────────────────
   21. CEFR BADGE
   ─────────────────────────────────────────────────────────────── */
.cat-cefr-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--radius-full);
    font-size: 0.75rem;
    font-weight: 700;
    color: white;
    letter-spacing: 0.5px;
}


/* ───────────────────────────────────────────────────────────────
   22. SPEECH BUBBLE
   ─────────────────────────────────────────────────────────────── */
.cat-mascot-speech {
    margin: 0 0 var(--space-xl);
    width: 100%;
    max-width: 480px;
}

.cat-speech-bubble {
    position: relative;
    background: var(--cat-card-bg);
    border: var(--border-thin) solid var(--border-default);
    border-radius: var(--radius-lg);
    padding: var(--space-md);
    color: var(--text-secondary);
    font-size: 0.875rem;
    line-height: 1.5;
}


/* ───────────────────────────────────────────────────────────────
   23. COMPLETION VIEW
   ─────────────────────────────────────────────────────────────── */
.cat-complete {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-md);
    text-align: center;
    z-index: 1;
}

.cat-complete-title,
.cat-comp-title {
    font-size: 2rem;
    font-weight: 900;
    background: linear-gradient(135deg, var(--cat-terracotta), var(--cat-gold));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-align: center;
}

.cat-complete-stars,
.cat-comp-stars {
    display: flex;
    gap: var(--space-md);
    justify-content: center;
    margin: var(--space-lg) 0;
}

.cat-complete-stat,
.cat-comp-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
}

.cat-complete-stat__value,
.cat-comp-stat-val {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-primary);
}

.cat-complete-stat__label,
.cat-comp-stat-label {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cat-complete-bonus,
.cat-comp-perfect {
    color: var(--cat-gold);
    font-weight: 700;
    font-size: 1.125rem;
    text-align: center;
    margin-top: var(--space-md);
}

.cat-xp-count {
    color: var(--cat-gold);
}

/* ───────────────────────────────────────────────────────────────
   24. HEARTS OVERLAY (no hearts modal)
   ─────────────────────────────────────────────────────────────── */
.cat-hearts-overlay {
    position: fixed;
    inset: 0;
    background: rgba(5, 5, 7, 0.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-modal);
}

.cat-hearts-overlay__card {
    background: var(--bg-secondary);
    border: var(--border-thin) solid var(--border-default);
    border-radius: var(--radius-xl);
    padding: var(--space-2xl) var(--space-xl);
    text-align: center;
    max-width: 360px;
    width: 90%;
}

.cat-hearts-overlay__card h2 {
    color: var(--text-primary);
    margin: var(--space-md) 0 var(--space-sm);
}

.cat-hearts-overlay__card p {
    color: var(--text-secondary);
}

.cat-hearts-overlay__icon {
    font-size: 3rem;
}

.cat-hearts-overlay__actions {
    display: flex;
    gap: var(--space-md);
    justify-content: center;
    margin-top: var(--space-lg);
}


/* ───────────────────────────────────────────────────────────────
   25. STATS PAGE
   ─────────────────────────────────────────────────────────────── */
.cat-stats-section {
    background: var(--cat-card-bg);
    border: var(--border-thin) solid var(--border-default);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    width: 100%;
    max-width: 600px;
    margin-bottom: var(--space-lg);
}

.cat-stats-heading {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--space-md);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.cat-stats-xp {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.cat-stats-flame {
    font-size: 1.25rem;
}

.cat-stats-totals {
    display: flex;
    gap: var(--space-lg);
    justify-content: center;
}

.cat-stats-total {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
}

.cat-stats-total__value {
    font-size: 2rem;
    font-weight: 800;
    color: var(--cat-terracotta);
}

.cat-stats-total__label {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
}

.cat-stats-hearts {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-sm);
}

.cat-stats-refill {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: var(--space-sm);
}

.cat-stats-units {
    display: flex;
    flex-direction: column;
}

.cat-stats-unit-row {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) 0;
    border-bottom: var(--border-thin) solid var(--border-subtle);
}

.cat-stats-unit-row:last-child {
    border-bottom: none;
}

.cat-stats-unit-name {
    flex: 1;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.cat-stats-unit-progress {
    font-size: 0.75rem;
    color: var(--text-muted);
    min-width: 40px;
    text-align: right;
}

.cat-stats-unit-stars {
    font-size: 0.75rem;
}


/* ───────────────────────────────────────────────────────────────
   26. FLOATING XP & CONFETTI
   ─────────────────────────────────────────────────────────────── */
.cat-floating-xp {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--cat-gold);
    font-weight: 800;
    font-size: 1.5rem;
    pointer-events: none;
    z-index: var(--z-tooltip);
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
    opacity: 1;
    transition: opacity 0.8s, transform 0.8s var(--ease-out);
}

.cat-floating-xp--animate {
    opacity: 0;
    transform: translate(-50%, calc(-50% - 60px));
}

.cat-confetti-piece {
    position: fixed;
    width: 8px;
    height: 8px;
    border-radius: 2px;
    pointer-events: none;
    z-index: var(--z-tooltip);
    animation: confetti-fall var(--duration, 2s) var(--delay, 0s) ease-out forwards;
    left: var(--x, 50vw);
    top: -10px;
}

.cat-confetti-piece:nth-child(odd) {
    border-radius: var(--radius-full);
}


/* ───────────────────────────────────────────────────────────────
   27. KEYFRAMES
   ─────────────────────────────────────────────────────────────── */
@keyframes pulse {
    0%, 100% {
        box-shadow: 0 0 8px var(--cat-terracotta-glow);
    }
    50% {
        box-shadow: 0 0 24px var(--cat-terracotta-glow),
                    0 0 48px rgba(232, 115, 74, 0.1);
    }
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    10%, 50%, 90% { transform: translateX(-4px); }
    30%, 70% { transform: translateX(4px); }
}

@keyframes confetti-fall {
    0% { transform: translateY(0) rotate(0deg); opacity: 1; }
    100% { transform: translateY(100vh) rotate(var(--rotation, 720deg)); opacity: 0; }
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

.cat-shake {
    animation: shake 0.4s ease;
}


/* ───────────────────────────────────────────────────────────────
   28. RESPONSIVE
   ─────────────────────────────────────────────────────────────── */

/* — Mobile (< 480px) — */
@media (max-width: 480px) {
    .cat-options-grid {
        grid-template-columns: 1fr;
    }

    .cat-match-wrapper {
        flex-direction: column;
    }

    .cat-prompt {
        font-size: 1.1rem;
    }

    .cat-complete-stars,
    .cat-comp-stars {
        font-size: 2rem;
        gap: var(--space-sm);
    }

    .cat-lesson-row {
        padding: var(--space-sm) var(--space-md);
    }

    .cat-unit-header h1,
    .cat-unit-title {
        font-size: var(--text-xl);
    }
}

/* — Small tablets (480px+) — */
@media (min-width: 480px) {
    .cat-prompt {
        font-size: 1.35rem;
    }
}

/* — Tablets (768px+) — */
@media (min-width: 768px) {
    .cat-option-card {
        min-height: 96px;
    }

    .cat-prompt {
        font-size: 1.5rem;
    }

    .cat-lesson-row {
        padding: var(--space-md) var(--space-xl);
    }

    .cat-lesson-row__num {
        width: 40px;
        height: 40px;
    }

    .cat-lesson-row__title {
        font-size: var(--text-base);
    }
}

/* — Desktop (1024px+) — */
@media (min-width: 1024px) {
    .cat-view-map {
        padding-top: var(--space-3xl);
    }

    .cat-option-card {
        min-height: 96px;
        font-size: var(--text-lg);
    }

    .cat-listen-btn {
        width: 64px;
        height: 64px;
    }

}


/* ───────────────────────────────────────────────────────────────
   29. ACCESSIBILITY & UTILITIES
   ─────────────────────────────────────────────────────────────── */

/* Focus visible */
.cat-app *:focus-visible {
    outline: 2px solid var(--cat-terracotta);
    outline-offset: 2px;
}

/* Scrollbar */
.cat-app ::-webkit-scrollbar { width: 6px; }
.cat-app ::-webkit-scrollbar-track { background: transparent; }
.cat-app ::-webkit-scrollbar-thumb {
    background: var(--border-default);
    border-radius: var(--radius-full);
}
.cat-app ::-webkit-scrollbar-thumb:hover {
    background: var(--border-hover);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .cat-app *,
    .cat-app *::before,
    .cat-app *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .cat-lesson-row--available .cat-lesson-row__num {
        animation: none;
    }
}

/* Close button utility */
.cat-close-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 1.25rem;
    padding: var(--space-xs);
    transition: color var(--transition-fast);
}

.cat-close-btn:hover {
    color: var(--text-primary);
}


/* ───────────────────────────────────────────────────────────────
   30. SETTINGS BUTTON & MODAL
   ─────────────────────────────────────────────────────────────── */

/* Floating gear button */
.cat-settings-btn {
    position: fixed;
    bottom: var(--space-lg);
    right: var(--space-lg);
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    border: var(--border-thin) solid var(--border-default);
    background: var(--bg-secondary);
    color: var(--text-muted);
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: var(--z-fixed);
    transition: color var(--transition-fast),
                border-color var(--transition-fast),
                background var(--transition-fast),
                transform var(--transition-fast),
                bottom var(--transition-base);
    backdrop-filter: blur(8px);
}

.consent-banner-visible .cat-settings-btn {
    bottom: calc(var(--space-lg) + var(--consent-banner-h, 0px));
}

.cat-settings-btn:hover {
    color: var(--text-primary);
    border-color: var(--border-hover);
    background: var(--bg-tertiary);
    transform: rotate(30deg);
}

/* Modal overlay */
.cat-settings-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s var(--ease-smooth);
    pointer-events: none;
}

.cat-settings-overlay--visible {
    opacity: 1;
    pointer-events: auto;
}

.cat-settings-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
}

/* Dialog */
.cat-settings-modal {
    position: relative;
    width: 90%;
    max-width: 380px;
    background: var(--bg-secondary);
    border: var(--border-thin) solid var(--border-default);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transform: translateY(12px) scale(0.97);
    transition: transform 0.3s var(--ease-smooth);
}

.cat-settings-overlay--visible .cat-settings-modal {
    transform: translateY(0) scale(1);
}

.cat-settings-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-md) var(--space-lg);
    border-bottom: var(--border-thin) solid var(--border-subtle);
}

.cat-settings-title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
}

.cat-settings-close {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    transition: color var(--transition-fast);
}

.cat-settings-close:hover {
    color: var(--text-primary);
}

.cat-settings-body {
    padding: var(--space-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.cat-settings-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.cat-settings-label {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    font-weight: 500;
}

/* Language selector cards */
.cat-settings-langs {
    display: flex;
    gap: var(--space-sm);
}

.cat-settings-lang {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-md);
    border-radius: var(--radius-md);
    border: var(--border-medium) solid var(--border-subtle);
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    cursor: pointer;
    transition: border-color var(--transition-fast),
                color var(--transition-fast),
                background var(--transition-fast);
}

.cat-settings-lang:hover {
    border-color: var(--border-hover);
    color: var(--text-primary);
}

.cat-settings-lang--active {
    border-color: var(--cat-terracotta);
    color: var(--text-primary);
    background: color-mix(in srgb, var(--cat-terracotta) 8%, var(--bg-tertiary));
}

.cat-settings-lang__flag {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: 600;
    letter-spacing: 0.05em;
    opacity: 0.7;
}

.cat-settings-lang--active .cat-settings-lang__flag {
    color: var(--cat-terracotta);
    opacity: 1;
}

.cat-settings-lang__name {
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 500;
}

/* Toggle switch */
.cat-settings-toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.cat-settings-toggle {
    position: relative;
    width: 44px;
    height: 24px;
    border-radius: var(--radius-full);
    border: none;
    background: var(--bg-elevated);
    cursor: pointer;
    padding: 2px;
    transition: background var(--transition-fast);
}

.cat-settings-toggle--on {
    background: var(--cat-terracotta);
}

.cat-settings-toggle__knob {
    display: block;
    width: 20px;
    height: 20px;
    border-radius: var(--radius-full);
    background: var(--text-primary);
    transition: transform var(--transition-fast);
}

.cat-settings-toggle--on .cat-settings-toggle__knob {
    transform: translateX(20px);
}

/* Reset progress */
.cat-settings-group--danger {
    margin-top: var(--space-sm);
    padding-top: var(--space-lg);
    border-top: var(--border-thin) solid var(--border-subtle);
}

.cat-settings-reset {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    border: var(--border-thin) solid color-mix(in srgb, #e74c3c 40%, transparent);
    background: color-mix(in srgb, #e74c3c 8%, var(--bg-tertiary));
    color: #e74c3c;
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition-fast), border-color var(--transition-fast);
}

.cat-settings-reset:hover {
    background: color-mix(in srgb, #e74c3c 15%, var(--bg-tertiary));
    border-color: #e74c3c;
}

/* Reset confirmation view */
.cat-settings-confirm-msg {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: 1.5;
    text-align: center;
    padding: var(--space-md) 0;
}

.cat-settings-confirm-actions {
    display: flex;
    gap: var(--space-sm);
}

.cat-settings-confirm-cancel {
    flex: 1;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    border: var(--border-thin) solid var(--border-default);
    background: var(--bg-tertiary);
    color: var(--text-primary);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 500;
    cursor: pointer;
    transition: background var(--transition-fast), border-color var(--transition-fast);
}

.cat-settings-confirm-cancel:hover {
    background: var(--bg-elevated);
    border-color: var(--border-hover);
}

.cat-settings-confirm-yes {
    flex: 1;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    border: none;
    background: #e74c3c;
    color: #fff;
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition-fast);
}

.cat-settings-confirm-yes:hover {
    background: #c0392b;
}
