/* Sommwise — Wine Education Platform
 * Plum-anchored, Sotto-family-warm.
 * Design language: deep plum hero accent, cream backgrounds, Playfair + Inter.
 * CMS/WSET students need calm authority — restrained, editorial, study-room quiet.
 */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');

/* Kill Blazor's focus rectangles on non-interactive elements */
[_bl_] { outline: none !important; }
h1, h2, h3, h4, h5, h6, p, div, section, span {
    outline: none !important;
}

:root {
    /* ─────────────────────────────────────────────────────
       Sommwise design tokens (sw-*) — the new polish layer
       ───────────────────────────────────────────────────── */
    --sw-bg: #fdfbf7;
    --sw-bg-elevated: #ffffff;
    --sw-bg-warm: #f5f1e8;
    --sw-bg-plum-tint: #f3eef3;
    --sw-ink: #2a2228;
    --sw-ink-muted: #6a6066;
    --sw-ink-subtle: #9a9096;
    --sw-line: rgba(74, 44, 75, 0.14);
    --sw-line-strong: rgba(74, 44, 75, 0.32);
    --sw-plum: #4a2c4b;
    --sw-plum-dark: #321b34;
    --sw-plum-tint: #6e4670;
    --sw-gold: #b8985c;
    --sw-alert: #b44646;
    --sw-success: #4a8c5e;
    --sw-serif: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
    --sw-sans: 'Inter', system-ui, -apple-system, sans-serif;
    --sw-space-1: 0.25rem;
    --sw-space-2: 0.5rem;
    --sw-space-3: 0.75rem;
    --sw-space-4: 1rem;
    --sw-space-6: 1.5rem;
    --sw-space-8: 2rem;
    --sw-space-12: 3rem;
    --sw-space-16: 4rem;
    --sw-radius-sm: 4px;
    --sw-radius: 6px;
    --sw-radius-lg: 12px;
    --sw-shadow-sm: 0 1px 2px rgba(42, 34, 40, 0.04);
    --sw-shadow: 0 2px 8px rgba(42, 34, 40, 0.06);
    --sw-shadow-lg: 0 8px 24px rgba(42, 34, 40, 0.08);
    --sw-ease: cubic-bezier(0.4, 0, 0.2, 1);
    --sw-duration: 180ms;

    /* ─────────────────────────────────────────────────────
       Legacy --sommwise-* aliases — remapped to the plum
       palette. Every existing rule inherits the polish.
       ───────────────────────────────────────────────────── */
    --sommwise-primary: var(--sw-plum);
    --sommwise-primary-light: var(--sw-plum-tint);
    --sommwise-primary-dark: var(--sw-plum-dark);

    --sommwise-accent: var(--sw-plum);
    --sommwise-accent-light: var(--sw-plum-tint);

    --sommwise-bg: var(--sw-bg);
    --sommwise-bg-alt: var(--sw-bg-warm);
    --sommwise-surface: var(--sw-bg-elevated);

    --sommwise-text: var(--sw-ink);
    --sommwise-text-dark: var(--sw-ink);
    --sommwise-text-muted: var(--sw-ink-muted);

    --sommwise-border: var(--sw-line);
    --sommwise-border-medium: var(--sw-line-strong);

    --sommwise-gold: var(--sw-gold);

    --sommwise-transition: var(--sw-duration) var(--sw-ease);
    --sommwise-shadow-sm: var(--sw-shadow-sm);
    --sommwise-shadow-md: var(--sw-shadow);
    --sommwise-shadow-hover: var(--sw-shadow-lg);
    --sommwise-radius: var(--sw-radius);
    --sommwise-radius-sm: var(--sw-radius-sm);
}

/* Shared card base */
.sommwise-card {
    background: var(--sommwise-surface);
    border-radius: var(--sommwise-radius);
    box-shadow: var(--sommwise-shadow-sm);
    transition: transform var(--sommwise-transition), box-shadow var(--sommwise-transition);
}
.sommwise-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sommwise-shadow-hover);
}

body {
    font-family: var(--sw-sans);
    font-weight: 400;
    background-color: var(--sw-bg);
    color: var(--sw-ink);
    margin: 0;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.65;
}

.sommwise-app {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Navbar */
.navbar {
    background: white;
    border-bottom: 1px solid var(--sommwise-border);
    padding: 0.75rem 0;
}

.navbar-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-family: 'Zilla Slab', serif;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: -0.5px;
    color: var(--sommwise-primary-dark) !important;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.navbar-brand:hover {
    opacity: 0.8;
}

.navbar-brand-icon {
    width: 32px;
    height: 32px;
    object-fit: contain;
}

.navbar-brand-text {
    font-style: normal;
}

.nav-link {
    font-family: 'Zilla Slab', serif;
    font-size: 0.95rem;
    font-weight: 400;
    color: var(--sommwise-text-muted) !important;
    padding: 0.5rem 1rem !important;
    transition: color 0.2s ease;
}

.nav-link:hover {
    color: var(--sommwise-primary) !important;
}

.nav-link.active {
    color: var(--sommwise-primary) !important;
    font-weight: 500;
}

/* Nav Progress Bar */
.nav-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0;
    background: linear-gradient(90deg, var(--sommwise-accent), var(--sommwise-accent-light));
    z-index: 9999;
    opacity: 0;
    transition: width 0.3s ease, opacity 0.2s ease;
}

.nav-progress-active {
    opacity: 1;
    width: 80%;
    transition: width 8s cubic-bezier(0.1, 0.05, 0, 1), opacity 0.2s ease;
}

.nav-progress-complete {
    width: 100% !important;
    opacity: 0;
    transition: width 0.3s ease, opacity 0.4s ease 0.3s;
}

/* Hero Section - Warm white, no dark background */
.hero-section {
    padding: 5rem 0 4rem;
    background: var(--sommwise-bg);
    border-bottom: 1px solid var(--sommwise-border);
}

.hero-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 3.2rem;
    font-weight: 300;
    font-style: italic;
    letter-spacing: -1px;
    line-height: 1.15;
    margin-bottom: 1.25rem;
    color: var(--sommwise-primary-dark);
}

.hero-subtitle {
    font-size: 1.15rem;
    font-weight: 300;
    color: var(--sommwise-text-muted);
    max-width: 540px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Newsletter Form */
.newsletter-input-group {
    display: flex;
    gap: 0;
    max-width: 460px;
    margin: 0 auto;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--sommwise-border-medium);
    background: white;
}

.newsletter-input-group .form-control {
    border: none;
    padding: 0.875rem 1.25rem;
    font-size: 0.95rem;
    font-family: 'Zilla Slab', serif;
    background: transparent;
    color: var(--sommwise-text);
    flex: 1;
}

.newsletter-input-group .form-control:focus {
    box-shadow: none;
    outline: none;
}

.newsletter-input-group .btn-primary {
    border: none;
    border-radius: 0;
    padding: 0.875rem 1.5rem;
    font-family: 'Zilla Slab', serif;
    font-weight: 500;
    font-size: 0.95rem;
    white-space: nowrap;
}

.hero-fine-print {
    display: block;
    margin-top: 0.75rem;
    color: var(--sommwise-text-muted);
    font-size: 0.8rem;
    font-style: italic;
}

/* Features Section */
.features-section {
    background: white;
}

.feature-card {
    background: var(--sommwise-bg);
    border: 1px solid var(--sommwise-border);
    border-radius: var(--sommwise-radius);
    padding: 2rem;
    height: 100%;
    text-align: center;
    box-shadow: var(--sommwise-shadow-sm);
    transition: transform var(--sommwise-transition), box-shadow var(--sommwise-transition);
}

.feature-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sommwise-shadow-hover);
}

.feature-icon {
    font-size: 2rem;
    color: var(--sommwise-accent);
    margin-bottom: 1rem;
}

.feature-icon i {
    display: inline-block;
}

.feature-card h3 {
    font-family: 'Zilla Slab', serif;
    font-size: 1.15rem;
    font-weight: 500;
    margin-bottom: 0.75rem;
    color: var(--sommwise-text-dark);
}

.feature-card p {
    color: var(--sommwise-text-muted);
    font-size: 0.9rem;
    line-height: 1.5;
    margin: 0;
}

/* CTA Section */
.cta-section {
    background: var(--sommwise-bg);
}

.cta-text {
    font-size: 1rem;
    font-style: italic;
    color: var(--sommwise-text-muted);
    margin: 0;
}

/* Alert overrides */
.alert-success {
    background: rgba(61, 90, 108, 0.1);
    border-color: var(--sommwise-accent);
    color: var(--sommwise-primary-dark);
}

/* Groups Browse Page */
.groups-browse {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.groups-hero {
    background: linear-gradient(135deg,
        #2d4452 0%,
        #3d5a6c 100%);
    padding: 4rem 0 3rem;
}

.groups-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 3rem;
    font-weight: 400;
    font-style: italic;
    margin-bottom: 1rem;
    color: white;
}

.groups-subtitle {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.8);
    max-width: 600px;
}

.filters-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.5rem;
}

.filters-card .form-control,
.filters-card .form-select {
    background: var(--sommwise-bg);
    border-color: var(--sommwise-border-medium);
    color: var(--sommwise-text);
}

.filters-card .form-control:focus,
.filters-card .form-select:focus {
    background: var(--sommwise-surface);
    border-color: var(--sommwise-accent);
    color: var(--sommwise-text);
    box-shadow: 0 0 0 0.2rem rgba(61, 90, 108, 0.15);
}

.filters-card .form-control::placeholder {
    color: var(--sommwise-text-muted);
}

/* Study Group Card */
.study-group-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: var(--sommwise-radius);
    overflow: hidden;
    box-shadow: var(--sommwise-shadow-sm);
    transition: transform var(--sommwise-transition), box-shadow var(--sommwise-transition), border-color var(--sommwise-transition);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.study-group-card:hover {
    transform: translateY(-2px);
    border-color: var(--sommwise-accent);
    box-shadow: var(--sommwise-shadow-hover);
}

.group-card-image {
    width: 100%;
    height: 200px;
    overflow: hidden;
    background: var(--sommwise-bg-alt);
}

.group-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.group-card-placeholder {
    width: 100%;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #2d4452 0%, #3d5a6c 100%);
}

.group-card-placeholder i {
    font-size: 4rem;
    color: rgba(255, 255, 255, 0.4);
}

.group-card-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.group-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
}

.group-card-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--sommwise-text-dark);
    margin: 0;
    line-height: 1.3;
}

.group-card-location {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-accent);
    font-size: 0.9rem;
    margin-bottom: 0.75rem;
}

.group-card-location i {
    font-size: 1rem;
}

.group-card-description {
    color: var(--sommwise-text-muted);
    font-size: 0.95rem;
    line-height: 1.5;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.group-card-details {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.group-card-detail {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
}

.group-card-detail i {
    color: var(--sommwise-accent);
    font-size: 1rem;
}

.group-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid var(--sommwise-border);
}

.group-card-members {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-text-muted);
    font-size: 0.9rem;
}

.group-card-members i {
    color: var(--sommwise-accent);
}

/* Responsive */
@media (max-width: 768px) {
    .hero-section {
        padding: 3.5rem 0 3rem;
    }

    .hero-title {
        font-size: 2.2rem;
    }

    .hero-subtitle {
        font-size: 1rem;
    }

    .newsletter-input-group {
        flex-direction: column;
        border-radius: 8px;
    }

    .newsletter-input-group .form-control,
    .newsletter-input-group .btn {
        border-radius: 0 !important;
    }

    .groups-title {
        font-size: 2rem;
    }

    .groups-hero {
        padding: 2.5rem 0 2rem;
    }
}

/* Group Details Page */
.group-details {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.group-details-hero {
    background: linear-gradient(135deg, #2d4452 0%, #3d5a6c 100%);
    padding: 4rem 0;
}

.group-logo {
    width: 100px;
    height: 100px;
    object-fit: contain;
    border-radius: 12px;
    background: white;
    padding: 0.5rem;
}

.group-details-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 2.5rem;
    font-weight: 400;
    font-style: italic;
    color: white;
    margin-bottom: 0.5rem;
}

.group-details-location {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.1rem;
    margin-bottom: 1rem;
}

.group-details-location i {
    font-size: 1.2rem;
}

.group-details-description {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.6;
    max-width: 800px;
}

.group-details-sidebar {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.5rem;
}

.group-stat {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--sommwise-border);
}

.group-stat i {
    font-size: 2rem;
    color: var(--sommwise-accent);
}

.stat-value {
    font-size: 2rem;
    font-weight: 600;
    color: var(--sommwise-text-dark);
    line-height: 1;
}

.stat-label {
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.group-section {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 2rem;
    margin-bottom: 1.5rem;
}

.section-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--sommwise-text-dark);
    margin-bottom: 1.5rem;
}

.group-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
}

.info-item {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.info-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.info-label i {
    color: var(--sommwise-accent);
}

.info-value {
    font-size: 1.1rem;
    color: var(--sommwise-text-dark);
    font-weight: 500;
}

.house-rules {
    color: var(--sommwise-text-muted);
    line-height: 1.6;
}

.events-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.event-item {
    display: flex;
    gap: 1rem;
    padding: 1rem;
    background: var(--sommwise-bg-alt);
    border-radius: 8px;
    border: 1px solid var(--sommwise-border);
}

.event-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background: var(--sommwise-accent);
    border-radius: 8px;
    flex-shrink: 0;
}

.event-day {
    font-size: 1.5rem;
    font-weight: 600;
    color: white;
    line-height: 1;
}

.event-month {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.9);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.event-details h4 {
    font-size: 1.1rem;
    color: var(--sommwise-text-dark);
    margin-bottom: 0.25rem;
}

.event-details p {
    font-size: 0.9rem;
    color: var(--sommwise-text-muted);
    margin: 0;
}

.stats-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.stat-item {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.stat-item i {
    font-size: 1.5rem;
    color: var(--sommwise-accent);
}

@media (max-width: 992px) {
    .group-details-hero {
        padding: 2.5rem 0;
    }

    .group-details-title {
        font-size: 2rem;
    }

    .group-details-sidebar {
        margin-top: 2rem;
    }
}

/* Flashcard Study Interface */
.study-interface {
    min-height: 100vh;
    background: var(--sommwise-bg-alt);
    display: flex;
    flex-direction: column;
}

.study-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.study-complete {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sommwise-bg);
}

.complete-icon {
    font-size: 6rem;
    color: var(--sommwise-accent);
    margin-bottom: 2rem;
}

.session-stats {
    display: flex;
    justify-content: center;
    gap: 3rem;
    margin-top: 2rem;
}

.session-stats .stat {
    text-align: center;
}

.session-stats .stat-value {
    font-size: 3rem;
    font-weight: 600;
    color: var(--sommwise-accent);
}

.session-stats .stat-label {
    font-size: 0.9rem;
    color: var(--sommwise-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Study Progress Bar */
.study-progress {
    background: var(--sommwise-surface);
    padding: 1.5rem 0;
    border-bottom: 1px solid var(--sommwise-border);
}

.progress-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
}

.progress-text {
    font-size: 0.9rem;
    color: var(--sommwise-text-muted);
    font-weight: 500;
}

.deck-name {
    font-size: 1rem;
    color: var(--sommwise-text-dark);
    font-weight: 500;
}

.study-progress .progress {
    height: 6px;
    background: var(--sommwise-bg-alt);
    border-radius: 3px;
}

.study-progress .progress-bar {
    background: linear-gradient(90deg, var(--sommwise-accent), var(--sommwise-accent-light));
    border-radius: 3px;
    transition: width 0.3s ease;
}

/* Flashcard Container */
.flashcard-container {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    perspective: 1000px;
}

.flashcard {
    position: relative;
    width: 100%;
    max-width: 600px;
    min-height: 400px;
    cursor: pointer;
    transform-style: preserve-3d;
    transition: transform 0.6s cubic-bezier(0.4, 0.0, 0.2, 1);
}

.flashcard.animating {
    pointer-events: none;
}

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

.flashcard-face {
    position: absolute;
    width: 100%;
    min-height: 400px;
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border-medium);
    border-radius: 16px;
    padding: 3rem 2rem;
    backface-visibility: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

.flashcard-front {
    transform: rotateY(0deg);
}

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

.card-content {
    width: 100%;
    text-align: center;
}

.card-image {
    margin-bottom: 2rem;
}

.card-image img {
    max-width: 100%;
    max-height: 200px;
    border-radius: 8px;
    object-fit: contain;
}

.card-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--sommwise-accent);
    margin-bottom: 1rem;
    font-weight: 700;
}

.card-main-text {
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
    line-height: 1.4;
    margin-bottom: 1.5rem;
}

.card-hint {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    background: rgba(61, 90, 108, 0.08);
    border: 1px solid rgba(61, 90, 108, 0.2);
    border-radius: 8px;
    padding: 1rem;
    margin-top: 1.5rem;
    font-size: 0.95rem;
    color: var(--sommwise-primary);
}

.card-hint i {
    font-size: 1.2rem;
}

.card-explanation {
    background: rgba(61, 90, 108, 0.06);
    border-radius: 8px;
    padding: 1rem;
    margin-top: 1.5rem;
    font-size: 0.95rem;
    color: var(--sommwise-text-muted);
    text-align: left;
}

.hint-button {
    margin-top: 1rem;
    color: var(--sommwise-accent) !important;
    border-color: var(--sommwise-accent) !important;
}

.entity-link {
    margin-top: 1rem;
    color: var(--sommwise-accent) !important;
    border-color: var(--sommwise-accent) !important;
}

.flip-instruction {
    margin-top: 2rem;
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.flip-instruction i {
    font-size: 1rem;
}

/* Rating Buttons */
.rating-buttons {
    background: var(--sommwise-surface);
    padding: 2rem 0;
    border-top: 1px solid var(--sommwise-border);
}

.rating-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.rating-btn {
    background: var(--sommwise-bg-alt);
    border: 2px solid var(--sommwise-border-medium);
    border-radius: 12px;
    padding: 1.5rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    transition: all 0.2s ease;
    color: var(--sommwise-text);
}

.rating-btn:hover {
    transform: translateY(-4px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
}

.rating-icon {
    font-size: 2rem;
}

.rating-label {
    font-size: 1rem;
    font-weight: 600;
}

.rating-time {
    font-size: 0.75rem;
    color: var(--sommwise-text-muted);
}

/* Rating button colors */
.rating-again {
    border-color: rgba(231, 76, 60, 0.3);
}

.rating-again:hover {
    border-color: #e74c3c;
    background: rgba(231, 76, 60, 0.06);
}

.rating-again .rating-icon {
    color: #e74c3c;
}

.rating-hard {
    border-color: rgba(243, 156, 18, 0.3);
}

.rating-hard:hover {
    border-color: #f39c12;
    background: rgba(243, 156, 18, 0.06);
}

.rating-hard .rating-icon {
    color: #f39c12;
}

.rating-good {
    border-color: rgba(61, 90, 108, 0.3);
}

.rating-good:hover {
    border-color: var(--sommwise-accent);
    background: rgba(61, 90, 108, 0.06);
}

.rating-good .rating-icon {
    color: var(--sommwise-accent);
}

.rating-easy {
    border-color: rgba(39, 174, 96, 0.3);
}

.rating-easy:hover {
    border-color: #27ae60;
    background: rgba(39, 174, 96, 0.06);
}

.rating-easy .rating-icon {
    color: #27ae60;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .flashcard-container {
        padding: 1rem;
    }

    .flashcard {
        min-height: 350px;
    }

    .flashcard-face {
        min-height: 350px;
        padding: 2rem 1.5rem;
    }

    .card-main-text {
        font-size: 1.25rem;
    }

    .rating-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .deck-name {
        display: none;
    }
}

@media (max-width: 480px) {
    .flashcard {
        min-height: 300px;
    }

    .flashcard-face {
        min-height: 300px;
        padding: 1.5rem 1rem;
    }

    .card-main-text {
        font-size: 1.1rem;
    }

    .rating-btn {
        padding: 1rem 0.5rem;
    }

    .rating-label {
        font-size: 0.9rem;
    }

    .rating-time {
        font-size: 0.7rem;
    }
}

/* Flashcards Browse Page */
.flashcards-browse {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.flashcards-hero {
    background: linear-gradient(135deg, #2d4452 0%, #3d5a6c 100%);
    padding: 4rem 0 3rem;
}

.flashcards-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 3rem;
    font-weight: 400;
    font-style: italic;
    margin-bottom: 1rem;
    color: white;
}

.flashcards-subtitle {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.8);
    max-width: 600px;
}

/* Deck Card */
.deck-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: var(--sommwise-radius);
    overflow: hidden;
    box-shadow: var(--sommwise-shadow-sm);
    transition: transform var(--sommwise-transition), box-shadow var(--sommwise-transition);
    height: 100%;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

.deck-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sommwise-shadow-hover);
}

.deck-card-image {
    width: 100%;
    height: 180px;
    overflow: hidden;
    background: var(--sommwise-bg-alt);
}

.deck-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.deck-card-placeholder {
    width: 100%;
    height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #2d4452 0%, #3d5a6c 100%);
}

.deck-card-placeholder i {
    font-size: 3.5rem;
    color: rgba(255, 255, 255, 0.4);
}

.deck-card-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.deck-card-header {
    margin-bottom: 0.75rem;
}

.deck-card-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--sommwise-text-dark);
    margin: 0;
    line-height: 1.3;
}

.deck-card-cert {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-gold);
    font-size: 0.85rem;
    font-weight: 500;
    margin-bottom: 0.75rem;
}

.deck-card-cert i {
    font-size: 1rem;
}

.deck-card-description {
    color: var(--sommwise-text-muted);
    font-size: 0.95rem;
    line-height: 1.5;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.deck-card-details {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.deck-card-detail {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
}

.deck-card-detail i {
    color: var(--sommwise-accent);
    font-size: 1rem;
}

.deck-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid var(--sommwise-border);
}

.deck-card-stats {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-text-muted);
    font-size: 0.9rem;
}

.deck-card-stats i {
    color: var(--sommwise-accent);
}

.deck-card-rating {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--sommwise-gold);
    font-weight: 500;
}

.deck-card-rating i {
    font-size: 1rem;
}

/* Deck Details Page */
.deck-details {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.deck-details-hero {
    background: linear-gradient(135deg, #2d4452 0%, #3d5a6c 100%);
    padding: 4rem 0;
}

.breadcrumb {
    background: transparent;
    padding: 0;
    margin: 0;
}

.breadcrumb-item a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
}

.breadcrumb-item a:hover {
    color: white;
}

.breadcrumb-item.active {
    color: rgba(255, 255, 255, 0.5);
}

.deck-details-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 2.5rem;
    font-weight: 400;
    font-style: italic;
    color: white;
    margin-bottom: 0.5rem;
}

.deck-details-cert {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-gold);
    font-size: 1.1rem;
    font-weight: 500;
    margin-bottom: 1rem;
}

.deck-details-cert i {
    font-size: 1.2rem;
}

.deck-details-cert .cert-chip {
    display: inline-block;
    padding: 0.2rem 0.65rem;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    color: var(--sw-gold, var(--sommwise-gold)) !important;
    font-size: 0.7rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.13em !important;
    line-height: 1.4;
    text-transform: uppercase;
}

.deck-details-description {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.6;
    max-width: 800px;
}

.deck-details-sidebar {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.5rem;
}

.deck-stat {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--sommwise-border);
}

.deck-stat i {
    font-size: 2rem;
    color: var(--sommwise-accent);
}

.user-progress-summary h6 {
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sommwise-text-muted);
    margin-bottom: 0.75rem;
}

.deck-section {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 2rem;
    margin-bottom: 1.5rem;
}

.deck-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
}

.card-preview-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.card-preview-item {
    background: var(--sommwise-bg-alt);
    border: 1px solid var(--sommwise-border);
    border-radius: 8px;
    padding: 1rem;
}

.card-preview-question {
    color: var(--sommwise-text-dark);
    margin-bottom: 0.5rem;
}

.card-preview-answer {
    color: var(--sommwise-text-muted);
    font-size: 0.95rem;
}

/* Progress Page */
.progress-page {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.progress-hero {
    background: linear-gradient(135deg, #2d4452 0%, #3d5a6c 100%);
    padding: 4rem 0 3rem;
}

.progress-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 3rem;
    font-weight: 400;
    font-style: italic;
    margin-bottom: 1rem;
    color: white;
}

.progress-subtitle {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.8);
    max-width: 600px;
}

.stat-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 2rem;
    text-align: center;
}

.stat-card .stat-icon {
    font-size: 2.5rem;
    color: var(--sommwise-accent);
    margin-bottom: 1rem;
}

.progress-section {
    margin-bottom: 3rem;
}

.due-cards-by-deck {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.due-deck-item {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.due-deck-info h5 {
    color: var(--sommwise-text-dark);
    margin-bottom: 0.25rem;
}

.deck-progress-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.deck-progress-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.5rem;
    cursor: pointer;
    transition: all 0.3s ease;
}

.deck-progress-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.deck-progress-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.deck-progress-name {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--sommwise-text-dark);
    margin-bottom: 0.25rem;
}

.deck-progress-cert {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-gold);
    font-size: 0.9rem;
    margin: 0;
}

.deck-progress-stats {
    display: flex;
    gap: 0.5rem;
}

.deck-progress-bar-container {
    margin-bottom: 1rem;
}

.deck-progress-details {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.progress-detail-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-text-muted);
    font-size: 0.9rem;
}

.progress-detail-item i {
    color: var(--sommwise-accent);
}

/* Flashcard Pages Responsive */
@media (max-width: 768px) {
    .flashcards-title,
    .progress-title {
        font-size: 2rem;
    }

    .flashcards-hero,
    .progress-hero,
    .deck-details-hero {
        padding: 2.5rem 0 2rem;
    }

    .deck-details-title {
        font-size: 2rem;
    }

    .deck-details-sidebar {
        margin-top: 2rem;
    }

    .due-deck-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .due-deck-item .btn {
        width: 100%;
    }

    .deck-progress-header {
        flex-direction: column;
        gap: 0.75rem;
    }
}

/* Blind Tasting Interface */
.tasting-interface {
    min-height: 100vh;
    background: var(--sommwise-bg-alt);
    display: flex;
    flex-direction: column;
}

.tasting-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: var(--sommwise-bg);
}

/* Tasting Progress Bar */
.tasting-progress {
    background: var(--sommwise-surface);
    padding: 1.5rem 0;
    border-bottom: 1px solid var(--sommwise-border);
}

.tasting-label {
    font-size: 1rem;
    color: var(--sommwise-text-dark);
    font-weight: 500;
}

/* Tasting Grid Section */
.tasting-container {
    flex: 1;
    padding: 3rem 0;
}

.tasting-grid-section {
    max-width: 900px;
    margin: 0 auto;
}

.section-header {
    text-align: center;
    margin-bottom: 3rem;
}

.section-icon {
    font-size: 4rem;
    color: var(--sommwise-accent);
    margin-bottom: 1rem;
}

.section-icon i {
    display: inline-block;
}

.section-header h2 {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 2.5rem;
    font-weight: 400;
    font-style: italic;
    color: var(--sommwise-text-dark);
    margin-bottom: 0.5rem;
}

.section-description {
    font-size: 1.1rem;
    color: var(--sommwise-text-muted);
}

/* Tasting Grid */
.tasting-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    margin-bottom: 3rem;
}

.grid-item {
    display: flex;
    flex-direction: column;
}

.grid-item.full-width {
    grid-column: 1 / -1;
}

.grid-label {
    font-size: 0.9rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sommwise-text-dark);
    margin-bottom: 0.75rem;
}

/* Option Buttons */
.option-group {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.option-btn {
    flex: 1;
    min-width: 100px;
    background: var(--sommwise-surface);
    border: 2px solid var(--sommwise-border-medium);
    border-radius: 8px;
    padding: 0.75rem 1rem;
    color: var(--sommwise-text);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.option-btn:hover {
    border-color: var(--sommwise-accent);
    background: rgba(61, 90, 108, 0.04);
}

.option-btn.active {
    border-color: var(--sommwise-accent);
    background: var(--sommwise-accent);
    color: white;
}

/* Checkbox Group */
.checkbox-group {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-text);
    cursor: pointer;
    user-select: none;
}

.checkbox-label input[type="checkbox"] {
    width: 20px;
    height: 20px;
    cursor: pointer;
}

/* Aroma Categories */
.aroma-categories {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

.category-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.category-label {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--sommwise-accent);
}

/* Form Controls */
.tasting-grid .form-control,
.tasting-grid .form-select {
    background: var(--sommwise-surface);
    border-color: var(--sommwise-border-medium);
    color: var(--sommwise-text);
}

.tasting-grid .form-control:focus,
.tasting-grid .form-select:focus {
    background: var(--sommwise-surface);
    border-color: var(--sommwise-accent);
    color: var(--sommwise-text);
    box-shadow: 0 0 0 0.2rem rgba(61, 90, 108, 0.15);
}

.tasting-grid .form-control::placeholder {
    color: var(--sommwise-text-muted);
}

/* Grid Actions */
.grid-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding-top: 2rem;
    border-top: 1px solid var(--sommwise-border);
}

.grid-actions button {
    min-width: 150px;
}

/* Reveal Section */
.tasting-reveal {
    max-width: 800px;
    margin: 0 auto;
}

.reveal-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border-medium);
    border-radius: 16px;
    padding: 3rem;
    text-align: center;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
}

.reveal-header {
    margin-bottom: 2rem;
}

.reveal-icon {
    font-size: 5rem;
    color: var(--sommwise-accent);
    margin-bottom: 1rem;
}

.reveal-icon i {
    display: inline-block;
}

.reveal-header h2 {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 2.5rem;
    font-weight: 400;
    font-style: italic;
    color: var(--sommwise-text-dark);
}

.reveal-wine {
    margin-bottom: 3rem;
}

.reveal-wine h3 {
    font-size: 2rem;
    color: var(--sommwise-text-dark);
    margin-bottom: 1rem;
}

.reveal-details {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    color: var(--sommwise-text-muted);
}

.reveal-details p {
    margin: 0;
    font-size: 1.1rem;
}

.reveal-accuracy {
    margin-bottom: 3rem;
    padding: 2rem;
    background: rgba(61, 90, 108, 0.06);
    border-radius: 12px;
}

.accuracy-score {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.score-value {
    font-size: 5rem;
    font-weight: 600;
    color: var(--sommwise-accent);
    line-height: 1;
}

.score-label {
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--sommwise-text-muted);
    margin-top: 0.5rem;
}

.reveal-comparison {
    margin-bottom: 3rem;
    text-align: left;
}

.reveal-comparison h4 {
    font-size: 1.5rem;
    color: var(--sommwise-text-dark);
    margin-bottom: 1.5rem;
    text-align: center;
}

.comparison-grid {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.comparison-item {
    background: var(--sommwise-bg-alt);
    border-radius: 8px;
    padding: 1.5rem;
}

.comparison-label {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sommwise-text-muted);
    margin-bottom: 0.75rem;
}

.comparison-values {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.2rem;
}

.comparison-values .predicted {
    color: var(--sommwise-text-muted);
    font-style: italic;
}

.comparison-values i {
    color: var(--sommwise-accent);
}

.comparison-values .actual {
    color: var(--sommwise-text-dark);
    font-weight: 500;
}

.reveal-actions {
    display: flex;
    justify-content: center;
    gap: 1rem;
}

/* Responsive - Mobile */
@media (max-width: 768px) {
    .tasting-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .grid-item.full-width {
        grid-column: 1;
    }

    .section-icon {
        font-size: 3rem;
    }

    .section-header h2 {
        font-size: 2rem;
    }

    .option-btn {
        min-width: 80px;
        padding: 0.6rem 0.75rem;
        font-size: 0.9rem;
    }

    .grid-actions {
        flex-direction: column-reverse;
    }

    .grid-actions button {
        width: 100%;
    }

    .reveal-card {
        padding: 2rem 1.5rem;
    }

    .reveal-header h2 {
        font-size: 1.75rem;
    }

    .reveal-wine h3 {
        font-size: 1.5rem;
    }

    .score-value {
        font-size: 4rem;
    }

    .comparison-values {
        font-size: 1rem;
    }

    .reveal-actions {
        flex-direction: column;
    }

    .reveal-actions .btn {
        width: 100%;
    }

    .aroma-categories {
        grid-template-columns: 1fr;
    }
}

/* Tastings Browse Page */
.tastings-browse {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.tastings-hero {
    background: linear-gradient(135deg, #2d4452 0%, #3d5a6c 100%);
    padding: 4rem 0 3rem;
}

.tastings-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 3rem;
    font-weight: 400;
    font-style: italic;
    margin-bottom: 1rem;
    color: white;
}

.tastings-subtitle {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.8);
    max-width: 600px;
    margin: 0 auto;
}

.empty-state {
    max-width: 500px;
    margin: 0 auto;
}

.empty-icon {
    font-size: 5rem;
    color: var(--sommwise-accent);
    opacity: 0.3;
    margin-bottom: 1.5rem;
}

.empty-state h3 {
    color: var(--sommwise-text-dark);
    margin-bottom: 0.75rem;
}

/* Tasting Card */
.tasting-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.5rem;
    cursor: pointer;
    transition: all 0.3s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.tasting-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.tasting-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--sommwise-border);
}

.tasting-date {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-text-muted);
    font-size: 0.9rem;
}

.tasting-date i {
    color: var(--sommwise-accent);
}

.tasting-score {
    text-align: center;
    margin-bottom: 1.5rem;
}

.score-circle {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sommwise-accent), var(--sommwise-accent-light));
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 0.75rem;
}

.score-circle .score-value {
    font-size: 2rem;
    font-weight: 600;
    color: white;
}

.tasting-predictions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.prediction-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.prediction-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sommwise-text-muted);
}

.prediction-value {
    font-size: 1rem;
    color: var(--sommwise-text-dark);
    font-weight: 500;
}

.tasting-card-footer {
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid var(--sommwise-border);
}

.tasting-status {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--sommwise-accent);
    font-size: 0.9rem;
}

.tasting-status i {
    font-size: 1.1rem;
}

/* Responsive - Tastings Browse */
@media (max-width: 768px) {
    .tastings-title {
        font-size: 2rem;
    }

    .tastings-hero {
        padding: 2.5rem 0 2rem;
    }

    .empty-icon {
        font-size: 3.5rem;
    }
}

/* Footer - Sommwise (matching Sotto/Vinelog style) */
.footer-sommwise {
    background: white;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    padding: 3rem 0 1.5rem;
    margin-top: auto;
}

.footer-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    margin-bottom: 2rem;
}

.footer-brand {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.sotto-arch-container {
    margin-bottom: 0.5rem;
}

.sotto-arch {
    height: 32px;
    opacity: 0.7;
}

.footer-sotto-brands {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.footer-sotto-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none;
    padding: 0.5rem 0.75rem;
    border-radius: var(--sommwise-radius-sm);
    transition: background var(--sommwise-transition);
}

.footer-sotto-brand:hover {
    background: var(--sommwise-bg-alt);
}

.footer-sotto-brand.active {
    background: var(--sommwise-bg-alt);
}

.footer-sotto-brand img {
    width: 28px;
    height: 28px;
    object-fit: contain;
}

.footer-sotto-brand-info {
    display: flex;
    flex-direction: column;
}

.footer-sotto-brand-name {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
}

.footer-sotto-brand-name.vinelog {
    color: #7d2f70;
}

.footer-sotto-brand-name.ensalle {
    color: #c9884a;
}

.footer-sotto-brand-name.sommwise {
    color: var(--sommwise-primary);
}

.footer-sotto-brand-tagline {
    font-size: 0.75rem;
    color: var(--sommwise-text-muted);
    font-style: italic;
}

.footer-links-section {
    display: flex;
    flex-direction: column;
}

.footer-links-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
}

.footer-links-col h6 {
    font-family: 'Zilla Slab', serif;
    font-size: 0.8rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sommwise-text-dark);
    margin-bottom: 0.75rem;
}

.footer-links-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.footer-links-col a {
    color: var(--sommwise-text-muted);
    text-decoration: none;
    font-size: 0.85rem;
    transition: color var(--sommwise-transition);
}

.footer-links-col a:hover {
    color: var(--sommwise-primary);
}

.footer-bottom-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.footer-copyright {
    color: var(--sommwise-text-muted);
    font-size: 0.8rem;
    margin: 0;
}

.footer-copyright a {
    color: var(--sommwise-primary);
    text-decoration: none;
    transition: color var(--sommwise-transition);
}

.footer-copyright a:hover {
    color: var(--sommwise-primary-dark);
}

.footer-note {
    color: var(--sommwise-text-muted);
    font-size: 0.8rem;
    font-style: italic;
    margin: 0;
}

@media (max-width: 768px) {
    .footer-content {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }

    .footer-bottom-bar {
        flex-direction: column;
        gap: 0.5rem;
        text-align: center;
    }
}

/* Button overrides for Sommwise accent */
.btn-primary {
    background-color: var(--sommwise-accent);
    border-color: var(--sommwise-accent);
}

.btn-primary:hover {
    background-color: var(--sommwise-accent-light);
    border-color: var(--sommwise-accent-light);
}

.btn-outline-primary {
    color: var(--sommwise-accent);
    border-color: var(--sommwise-accent);
}

.btn-outline-primary:hover {
    background-color: var(--sommwise-accent);
    border-color: var(--sommwise-accent);
    color: white;
}

.text-primary {
    color: var(--sommwise-accent) !important;
}

/* Loading Indicator */
.sommwise-loading {
    width: 100%;
    padding: 3rem 0;
}
.sommwise-loading-bar {
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--sommwise-accent), var(--sommwise-accent-light), transparent);
    animation: sommwise-loading-slide 1.5s ease-in-out infinite;
    border-radius: 2px;
    width: 40%;
    margin: 0 auto;
}
@keyframes sommwise-loading-slide {
    0% { transform: translateX(-100%); opacity: 0.5; }
    50% { transform: translateX(60%); opacity: 1; }
    100% { transform: translateX(200%); opacity: 0.5; }
}

/* ==========================================================================
   Auth Pages - Sommwise
   ========================================================================== */

/* Page Container */
/* ─── Sotto ID Auth Pages ──────────────────── */

.auth-page {
    min-height: 100vh;
    background: #ffffff;
    display: flex;
    flex-direction: column;
}

.auth-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.5rem 1rem;
}

.auth-bg-pattern { display: none; }

.auth-content {
    width: 100%;
    max-width: 420px;
}

/* Sotto Brand Header */
.sotto-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}

.sotto-arch {
    height: 52px;
    width: auto;
    opacity: 0.7;
}

.sotto-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.25rem;
    font-weight: 400;
    color: #1a1a2e;
    letter-spacing: -0.02em;
}

/* App Family Logos (footer-style) */
.sotto-brands {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
    margin-top: 1.5rem;
}

.sotto-brands-label {
    width: 100%;
    text-align: center;
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.7rem;
    color: #b0aca6;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0;
}

.sotto-brand-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    text-decoration: none;
    opacity: 0.55;
    transition: opacity 0.2s ease;
}

.sotto-brand-link:hover {
    opacity: 1;
}

.sotto-brand-icon {
    height: 30px;
    width: auto;
    object-fit: contain;
}

.sotto-brand-name {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 0.75rem;
    color: #8a8378;
}

/* Main Card (shaded) */
.auth-card {
    background: #f0ede8;
    border: none;
    border-radius: 12px;
    padding: 2rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.auth-card-header {
    text-align: center;
    margin-bottom: 1.5rem;
}

.auth-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.75rem;
    font-weight: 400;
    color: #1a1a2e;
    margin: 0 0 0.5rem 0;
    letter-spacing: -0.02em;
}

.auth-subtitle {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.875rem;
    color: #8a8378;
    margin: 0;
}

/* Form */
.auth-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.auth-field {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.auth-label {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    color: #1a1a2e;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.auth-input {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.9375rem;
    padding: 0.875rem 1rem;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 8px;
    background: #ffffff;
    color: #1a1a2e;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    width: 100%;
}

.auth-input::placeholder {
    color: #b0aca6;
}

.auth-input:focus {
    outline: none;
    border-color: #8a8378;
    box-shadow: 0 0 0 3px rgba(138, 131, 120, 0.12);
}

.auth-field-error {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.8125rem;
    color: #c0392b;
}

.auth-validation-summary {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.875rem;
    color: #c0392b;
    background: rgba(192, 57, 43, 0.08);
    padding: 0.75rem 1rem;
    border-radius: 8px;
    margin-bottom: 0.5rem;
}

.auth-validation-summary:empty {
    display: none;
}

/* Options */
.auth-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.25rem 0;
}

.auth-checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.875rem;
    color: #1a1a2e;
    cursor: pointer;
    user-select: none;
}

.auth-checkbox {
    width: 18px;
    height: 18px;
    accent-color: #1a1a2e;
    cursor: pointer;
}

.auth-link {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.875rem;
    color: #8a8378;
    text-decoration: none;
    transition: color 0.15s ease;
}

.auth-link:hover {
    color: #1a1a2e;
    text-decoration: underline;
}

/* Primary Button */
.auth-btn-primary {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.9375rem;
    font-weight: 500;
    padding: 0.875rem 1.5rem;
    background: #1a1a2e;
    color: #f5f5f0;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: background-color 0.15s ease, transform 0.1s ease;
    width: 100%;
    margin-top: 0.5rem;
}

.auth-btn-primary:hover {
    background: #2d2d44;
}

.auth-btn-primary:active {
    transform: translateY(1px);
}

.auth-btn-primary:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(26, 26, 46, 0.2);
}

/* Secondary Button */
.auth-btn-secondary {
    display: block;
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.9375rem;
    font-weight: 500;
    padding: 0.75rem 1.5rem;
    background: transparent;
    color: #1a1a2e;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 8px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s ease;
    width: 100%;
}

.auth-btn-secondary:hover {
    background: rgba(0, 0, 0, 0.04);
    border-color: #1a1a2e;
}

/* Divider */
.auth-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 1.25rem 0;
}

.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(0, 0, 0, 0.1);
}

.auth-divider span {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.75rem;
    color: #8a8378;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Alternate Actions */
.auth-alternate-actions {
    text-align: center;
}

.auth-alt-text {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.875rem;
    color: #8a8378;
    margin: 0 0 0.75rem 0;
}

.auth-terms {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.75rem;
    color: #8a8378;
    text-align: center;
    margin: 1rem 0 0 0;
    line-height: 1.5;
}

/* Footer */
.auth-footer {
    text-align: center;
    padding: 1.5rem 1rem;
    margin-top: auto;
}

.auth-footer p {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.75rem;
    color: #b0aca6;
    margin: 0;
    line-height: 1.6;
}

.auth-footer a {
    color: #8a8378;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.auth-footer a:hover {
    color: #1a1a2e;
}

/* Alert styling */
.auth-card .alert {
    font-family: 'Inter', -apple-system, sans-serif;
    font-size: 0.875rem;
    border-radius: 8px;
    border: none;
}

.auth-card .alert-danger {
    background: rgba(192, 57, 43, 0.1);
    color: #c0392b;
}

/* Responsive */
@media (max-width: 576px) {
    .auth-container {
        padding: 1.5rem 1rem;
    }

    .sotto-brands {
        gap: 1.5rem;
    }

    .auth-card {
        padding: 1.75rem 1.25rem;
    }

    .auth-title {
        font-size: 1.5rem;
    }

    .auth-options {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }
}

/* Hero CTA Buttons */
.hero-cta-buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

.hero-welcome {
    font-family: 'Zilla Slab', serif;
    font-size: 1.1rem;
    color: var(--sommwise-text-muted);
    margin-bottom: 1rem;
}

/* Navbar user display */
.nav-user-display {
    font-weight: 500;
    color: var(--sommwise-text-dark) !important;
}

/* ============================================
   COURSES — Programs, Course Detail, My Courses
   ============================================ */

/* Shared Course Buttons */
.btn-sommwise {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.75rem;
    font-family: 'Zilla Slab', serif;
    font-size: 0.95rem;
    font-weight: 500;
    color: white;
    background: var(--sommwise-primary);
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.25s ease;
    text-decoration: none;
}

.btn-sommwise:hover {
    background: var(--sommwise-primary-dark);
    color: white;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(45, 68, 82, 0.25);
}

.btn-sommwise:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.btn-sommwise-lg {
    padding: 1rem 2.25rem;
    font-size: 1.05rem;
}

.btn-sommwise-sm {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-family: 'Zilla Slab', serif;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--sommwise-primary);
    transition: color 0.2s ease;
}

.btn-sommwise-sm:hover {
    color: var(--sommwise-primary-dark);
}

.btn-sommwise-outline {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1.5rem;
    font-family: 'Zilla Slab', serif;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--sommwise-primary);
    background: transparent;
    border: 1.5px solid var(--sommwise-primary);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.25s ease;
    text-decoration: none;
}

.btn-sommwise-outline:hover {
    background: var(--sommwise-primary);
    color: white;
    transform: translateY(-1px);
}

/* Difficulty Badges */
.difficulty-badge {
    display: inline-block;
    font-family: 'Zilla Slab', serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    padding: 0.25rem 0.65rem;
    border-radius: 4px;
    line-height: 1;
}

.difficulty-beginner {
    background: rgba(76, 148, 85, 0.12);
    color: #3d7a44;
}

.difficulty-intermediate {
    background: rgba(184, 150, 63, 0.15);
    color: #8a6f2a;
}

.difficulty-advanced {
    background: rgba(168, 72, 52, 0.12);
    color: #a04030;
}

.program-cert-badge {
    display: inline-block;
    font-family: 'Zilla Slab', serif;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    padding: 0.25rem 0.6rem;
    border-radius: 4px;
    background: rgba(61, 90, 108, 0.1);
    color: var(--sommwise-primary);
}

/* Progress Ring */
.progress-ring {
    width: 48px;
    height: 48px;
    transform: rotate(-90deg);
}

.progress-ring-lg {
    width: 72px;
    height: 72px;
}

.progress-ring-bg {
    fill: none;
    stroke: var(--sommwise-border-medium);
    stroke-width: 3;
}

.progress-ring-fill {
    fill: none;
    stroke: var(--sommwise-gold);
    stroke-width: 3;
    stroke-linecap: round;
    transition: stroke-dasharray 0.6s ease;
}

.my-course-progress-ring,
.active-course-progress,
.enrollment-progress-container {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.progress-ring-text {
    position: absolute;
    font-family: 'Zilla Slab', serif;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--sommwise-text-dark);
    /* counter-rotate since ring is rotated */
    transform: rotate(90deg);
}

.progress-ring-text-lg {
    font-size: 0.95rem;
}

/* Section titles */
.section-title-sm {
    font-family: 'Zilla Slab', serif;
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--sommwise-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin-bottom: 1.25rem;
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 1.25rem;
}

.section-link {
    font-family: 'Zilla Slab', serif;
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--sommwise-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.section-link:hover {
    color: var(--sommwise-primary-dark);
}

.section-description {
    font-size: 1rem;
    color: var(--sommwise-text-muted);
    max-width: 640px;
    line-height: 1.6;
    margin-bottom: 2rem;
}

/* ---- Programs Page (/courses) ---- */

.courses-page {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.courses-hero {
    background: linear-gradient(145deg, #2d4452 0%, #3d5a6c 55%, #4a6b7d 100%);
    padding: 5rem 0 4rem;
    text-align: center;
}

.courses-hero-eyebrow {
    font-family: 'Zilla Slab', serif;
    font-size: 0.8rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--sommwise-gold);
    margin-bottom: 0.75rem;
}

.courses-hero-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 3rem;
    font-weight: 300;
    font-style: italic;
    color: white;
    margin-bottom: 1rem;
    letter-spacing: -0.5px;
}

.courses-hero-subtitle {
    font-size: 1.05rem;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.75);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.65;
}

/* Active Courses Row */
.active-courses-row {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1rem;
}

.active-course-card {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    cursor: pointer;
    transition: all 0.3s ease;
}

.active-course-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.07);
    border-color: var(--sommwise-accent);
}

.active-course-info {
    flex: 1;
    min-width: 0;
}

.active-course-name {
    font-family: 'Zilla Slab', serif;
    font-size: 1rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
    margin: 0 0 0.35rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.active-course-module {
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
    margin: 0 0 0.5rem;
}

/* Programs Grid */
.programs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 1.5rem;
}

.program-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

.program-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    border-color: var(--sommwise-accent);
}

.program-card-accent {
    height: 3px;
    background: linear-gradient(90deg, var(--sommwise-gold), var(--sommwise-accent));
}

.program-card-body {
    padding: 1.75rem;
}

.program-card-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.85rem;
    flex-wrap: wrap;
}

.program-name {
    font-family: 'Zilla Slab', serif;
    font-size: 1.2rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
    margin: 0 0 0.5rem;
    line-height: 1.35;
}

.program-description {
    font-size: 0.9rem;
    color: var(--sommwise-text-muted);
    line-height: 1.55;
    margin: 0 0 0.65rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.program-level {
    font-size: 0.85rem;
    color: var(--sommwise-text);
    margin: 0 0 0.75rem;
}

.program-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: 0.82rem;
    color: var(--sommwise-text-muted);
}

.program-meta i {
    color: var(--sommwise-accent);
}

/* Program Expanded Course List */
.program-courses-panel {
    border-top: 1px solid var(--sommwise-border);
}

.program-courses-divider {
    height: 0;
}

.program-course-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.75rem;
    cursor: pointer;
    transition: background 0.2s ease;
    border-bottom: 1px solid rgba(0, 0, 0, 0.04);
}

.program-course-item:last-child {
    border-bottom: none;
}

.program-course-item:hover {
    background: var(--sommwise-bg-alt);
}

.program-course-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--sommwise-bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--sommwise-primary);
    font-size: 1rem;
}

.program-course-info {
    flex: 1;
    min-width: 0;
}

.program-course-info h4 {
    font-family: 'Zilla Slab', serif;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
    margin: 0 0 0.2rem;
}

.program-course-info p {
    font-size: 0.82rem;
    color: var(--sommwise-text-muted);
    margin: 0 0 0.25rem;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.program-course-meta {
    font-size: 0.78rem;
    color: var(--sommwise-text-muted);
}

.program-course-arrow {
    color: var(--sommwise-text-muted);
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.program-course-item:hover .program-course-arrow {
    transform: translateX(3px);
    color: var(--sommwise-primary);
}

/* ---- Course Detail Page ---- */

.course-detail-page {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.course-header {
    background: linear-gradient(145deg, #2d4452 0%, #3d5a6c 55%, #4a6b7d 100%);
    padding: 2.5rem 0 3rem;
}

.breadcrumb-sommwise {
    background: transparent;
    padding: 0;
    margin-bottom: 1.5rem;
    font-size: 0.85rem;
}

.breadcrumb-sommwise .breadcrumb-item a {
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    transition: color 0.2s ease;
}

.breadcrumb-sommwise .breadcrumb-item a:hover {
    color: rgba(255, 255, 255, 0.9);
}

.breadcrumb-sommwise .breadcrumb-item.active {
    color: rgba(255, 255, 255, 0.45);
}

.breadcrumb-sommwise .breadcrumb-item + .breadcrumb-item::before {
    color: rgba(255, 255, 255, 0.3);
}

.course-header-content {
    display: flex;
    gap: 3rem;
    align-items: flex-start;
}

.course-header-text {
    flex: 1;
}

.course-header-badges {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.course-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 2.4rem;
    font-weight: 400;
    color: white;
    margin: 0 0 0.75rem;
    line-height: 1.2;
    letter-spacing: -0.3px;
}

.course-description {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.6;
    margin: 0 0 1.25rem;
    max-width: 600px;
}

.course-meta {
    display: flex;
    gap: 1.5rem;
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.6);
    flex-wrap: wrap;
}

.course-meta i {
    color: var(--sommwise-gold);
}

.course-header-action {
    flex-shrink: 0;
    padding-top: 1rem;
}

/* Enrollment Card */
.enrollment-card {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 12px;
    padding: 1.75rem;
    text-align: center;
    min-width: 180px;
}

.enrollment-card .progress-ring-bg {
    stroke: rgba(255, 255, 255, 0.15);
}

.enrollment-card .progress-ring-fill {
    stroke: var(--sommwise-gold);
}

.enrollment-card .progress-ring-text {
    color: white;
}

.enrollment-status {
    font-family: 'Zilla Slab', serif;
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.8);
    margin: 1rem 0 0;
}

/* Module Cards */
.modules-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    max-width: 800px;
}

.module-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    overflow: hidden;
    transition: border-color 0.2s ease;
}

.module-card.module-expanded {
    border-color: var(--sommwise-border-medium);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.module-header {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 1.25rem 1.5rem;
    cursor: pointer;
    transition: background 0.2s ease;
}

.module-header:hover {
    background: var(--sommwise-bg-alt);
}

.module-number {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--sommwise-bg-alt);
    border: 1.5px solid var(--sommwise-border-medium);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Zilla Slab', serif;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--sommwise-primary);
    flex-shrink: 0;
}

.module-expanded .module-number {
    background: var(--sommwise-primary);
    border-color: var(--sommwise-primary);
    color: white;
}

.module-info {
    flex: 1;
    min-width: 0;
}

.module-name {
    font-family: 'Zilla Slab', serif;
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
    margin: 0 0 0.2rem;
}

.module-description {
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
    margin: 0 0 0.3rem;
    line-height: 1.4;
}

.module-item-count {
    font-size: 0.78rem;
    color: var(--sommwise-text-muted);
}

.module-toggle {
    color: var(--sommwise-text-muted);
    font-size: 1rem;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

/* Module Items */
.module-items {
    border-top: 1px solid var(--sommwise-border);
    animation: moduleSlideDown 0.25s ease;
}

@keyframes moduleSlideDown {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.module-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.5rem 1rem 2.75rem;
    cursor: pointer;
    transition: background 0.15s ease;
    border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}

.module-item:last-child {
    border-bottom: none;
}

.module-item:hover {
    background: var(--sommwise-bg-alt);
}

.module-item-optional {
    opacity: 0.7;
}

.module-item-icon {
    width: 32px;
    height: 32px;
    border-radius: 6px;
    background: var(--sommwise-bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--sommwise-accent);
    font-size: 0.9rem;
}

.module-item-content {
    flex: 1;
    min-width: 0;
}

.module-item-title {
    font-family: 'Zilla Slab', serif;
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
    margin: 0 0 0.15rem;
}

.module-item-description {
    font-size: 0.82rem;
    color: var(--sommwise-text-muted);
    margin: 0 0 0.3rem;
    line-height: 1.4;
}

.module-item-meta {
    display: flex;
    gap: 0.75rem;
    font-size: 0.75rem;
    color: var(--sommwise-text-muted);
}

.item-type-label {
    font-weight: 500;
    color: var(--sommwise-accent);
}

.item-optional-badge {
    font-style: italic;
}

.module-item-arrow {
    color: var(--sommwise-text-muted);
    opacity: 0;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.module-item:hover .module-item-arrow {
    opacity: 1;
    transform: translateX(2px);
    color: var(--sommwise-primary);
}

/* ---- My Courses Page ---- */

.my-courses-page {
    min-height: 100vh;
    background: var(--sommwise-bg);
}

.my-courses-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 2.5rem;
    flex-wrap: wrap;
    gap: 1rem;
}

.my-courses-title {
    font-family: 'Zilla Slab', Georgia, serif;
    font-size: 2.2rem;
    font-weight: 400;
    color: var(--sommwise-text-dark);
    margin: 0 0 0.35rem;
}

.my-courses-subtitle {
    font-size: 1rem;
    color: var(--sommwise-text-muted);
    margin: 0;
}

.my-courses-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.25rem;
}

.my-course-card {
    background: var(--sommwise-surface);
    border: 1px solid var(--sommwise-border);
    border-radius: 12px;
    padding: 1.5rem;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
}

.my-course-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.07);
    border-color: var(--sommwise-accent);
}

.my-course-completed {
    opacity: 0.85;
}

.my-course-completed:hover {
    opacity: 1;
}

.my-course-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.my-course-name {
    font-family: 'Zilla Slab', serif;
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--sommwise-text-dark);
    margin: 0 0 0.5rem;
    line-height: 1.35;
}

.my-course-current {
    font-size: 0.85rem;
    color: var(--sommwise-text-muted);
    margin: 0 0 auto;
    padding-bottom: 1rem;
}

.my-course-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    padding-top: 0.75rem;
    border-top: 1px solid var(--sommwise-border);
}

.my-course-date {
    font-size: 0.8rem;
    color: var(--sommwise-text-muted);
}

/* ---- Course Page Responsive ---- */

@media (max-width: 768px) {
    .courses-hero {
        padding: 3.5rem 0 2.5rem;
    }

    .courses-hero-title {
        font-size: 2.2rem;
    }

    .course-header {
        padding: 2rem 0;
    }

    .course-header-content {
        flex-direction: column;
        gap: 1.5rem;
    }

    .course-title {
        font-size: 1.8rem;
    }

    .course-header-action {
        padding-top: 0;
        width: 100%;
    }

    .enrollment-card {
        display: flex;
        align-items: center;
        gap: 1.25rem;
        text-align: left;
    }

    .enrollment-status {
        margin: 0;
    }

    .programs-grid {
        grid-template-columns: 1fr;
    }

    .my-courses-header {
        flex-direction: column;
        gap: 0.75rem;
    }

    .my-courses-title {
        font-size: 1.8rem;
    }

    .my-courses-grid {
        grid-template-columns: 1fr;
    }

    .active-courses-row {
        grid-template-columns: 1fr;
    }

    .modules-list {
        max-width: 100%;
    }

    .module-item {
        padding-left: 1.5rem;
    }
}

/* Sotto ID activation — Progress page stat card variant */
.stat-card-conversion {
    background: linear-gradient(135deg, rgba(74, 122, 138, 0.06), rgba(61, 90, 108, 0.10));
    border-color: rgba(74, 122, 138, 0.22);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
}

.stat-card-conversion .stat-card-label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.10em;
    color: var(--sommwise-accent);
    font-weight: 700;
}

.stat-card-conversion .stat-card-value .active-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: rgba(40, 120, 80, 0.14);
    color: #2f8a5c;
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.9rem;
}

.stat-card-conversion .stat-card-value .muted {
    color: #6a7a82;
    font-size: 0.78rem;
}

/* StudyHero — Sotto ID activation hint */
.study-hero-conversion-hint {
    margin-top: 1.25rem;
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.85);
}

.study-hero-conversion-hint .hint-link {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
    font-weight: 600;
    margin-left: 0.35rem;
}

.study-hero-conversion-hint .hint-link:hover {
    color: #fff;
    text-decoration: none;
}

/* Study completion screen — conversion card spacing */
.study-complete-conversion {
    max-width: 540px;
    margin: 2rem auto 0;
    text-align: left;
}

/* ----------------------------------------------------------------------
   Sprint 4 — Mobile study UX
   Phone-first overrides for the surfaces where students actually study.
   Desktop styles above are untouched; everything here is scoped to
   <=640px viewports unless noted otherwise.
   ---------------------------------------------------------------------- */

/* Keyboard hint row (desktop only — hidden on phones via media query). */
.study-hotkey-hint {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    font-size: 0.8rem;
    color: var(--sommwise-text-muted);
    background: transparent;
    letter-spacing: 0.02em;
}

.study-hotkey-hint .hint-sep {
    opacity: 0.5;
}

@media (max-width: 640px) {
    /* Hide the keyboard hint on touch devices — irrelevant and adds clutter. */
    .study-hotkey-hint {
        display: none;
    }

    /* Card body should DOMINATE the phone screen — at least 60vh tall. */
    .flashcard,
    .flashcard-face {
        min-height: 60vh;
    }

    .flashcard-container {
        padding: 0.75rem;
    }

    .flashcard-face {
        padding: 1.75rem 1.25rem;
    }

    /* Rating buttons: stack 2x2, min 56px tall, big touch targets. */
    .rating-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }

    .rating-btn {
        min-height: 56px;
        padding: 0.9rem 0.5rem;
    }

    .rating-buttons {
        padding: 1rem 0 1.25rem;
    }

    .rating-icon {
        font-size: 1.5rem;
    }

    .rating-label {
        font-size: 0.95rem;
    }

    /* Browse — single column with prominent imagery. */
    .flashcards-browse .row.g-4 > [class*="col-"] {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .deck-card-image,
    .deck-card-placeholder {
        height: 220px;
    }

    .deck-card-placeholder i {
        font-size: 4.5rem;
    }

    .deck-card-title {
        font-size: 1.35rem;
    }

    .deck-card-body {
        padding: 1.25rem;
    }

    /* Filters card collapses to stacked controls. */
    .filters-card .row > [class*="col-"] {
        min-width: 100%;
    }
}

/* Very small phones — pull the card back so rating buttons fit. */
@media (max-width: 380px) {

    .flashcard,
    .flashcard-face {
        min-height: 52vh;
    }
}

/* ═══════════════════════════════════════════════════════════════════
   SOMMWISE — POLISH LAYER
   Plum-anchored, Sotto-family-warm. Refines existing surfaces.
   Order matters: tokens first, then primitives, then page overrides.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Type primitives ─────────────────────────────────────────────── */
.sw-display,
.sw-h1,
.sw-h2,
.sw-h3 {
    font-family: var(--sw-serif);
    color: var(--sw-ink);
    font-weight: 500;
    letter-spacing: -0.015em;
    line-height: 1.15;
    margin: 0 0 var(--sw-space-4);
}

.sw-display {
    font-size: clamp(2.25rem, 4.5vw, 3.5rem);
    font-weight: 500;
    line-height: 1.1;
    letter-spacing: -0.02em;
}

.sw-h1 { font-size: clamp(1.75rem, 3vw, 2.25rem); }
.sw-h2 { font-size: 1.5rem; line-height: 1.25; }
.sw-h3 { font-size: 1.25rem; line-height: 1.3; }

.sw-eyebrow {
    font-family: var(--sw-sans);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--sw-ink-muted);
    display: inline-block;
    margin: 0 0 var(--sw-space-3);
}

.sw-quiet {
    color: var(--sw-ink-muted);
    font-size: 0.92rem;
}

.sw-divider {
    height: 1px;
    background: var(--sw-line);
    border: 0;
    margin: var(--sw-space-8) 0;
}

/* ── Component primitives ────────────────────────────────────────── */
.sw-card {
    background: var(--sw-bg-elevated);
    border: 1px solid var(--sw-line);
    border-radius: var(--sw-radius);
    padding: var(--sw-space-6);
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease);
}

.sw-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sw-shadow-lg);
    border-color: var(--sw-line-strong);
}

.sw-card-soft {
    background: var(--sw-bg-elevated);
    border: 0;
    border-radius: var(--sw-radius);
    padding: var(--sw-space-6);
    box-shadow: var(--sw-shadow-sm);
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease);
}

.sw-card-soft:hover {
    transform: translateY(-2px);
    box-shadow: var(--sw-shadow);
}

.sw-section {
    padding: clamp(3rem, 6vw, 6rem) 0;
}

.sw-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    background: var(--sw-plum);
    color: #fdfbf7;
    border: 1px solid var(--sw-plum);
    border-radius: var(--sw-radius);
    padding: 0.7rem 1.5rem;
    font-family: var(--sw-serif);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    text-decoration: none;
    cursor: pointer;
    transition: transform var(--sw-duration) var(--sw-ease),
                background var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease);
}

.sw-button:hover {
    background: var(--sw-plum-dark);
    border-color: var(--sw-plum-dark);
    color: #fdfbf7;
    transform: translateY(-1px);
    box-shadow: var(--sw-shadow);
}

.sw-button-ghost {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    background: transparent;
    color: var(--sw-plum);
    border: 1px solid var(--sw-line-strong);
    border-radius: var(--sw-radius);
    padding: 0.7rem 1.5rem;
    font-family: var(--sw-serif);
    font-size: 1rem;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: all var(--sw-duration) var(--sw-ease);
}

.sw-button-ghost:hover {
    border-color: var(--sw-plum);
    color: var(--sw-plum-dark);
    background: var(--sw-bg-plum-tint);
}

.sw-input,
.sw-input:focus {
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--sw-line-strong);
    border-radius: 0;
    padding: 0.6rem 0;
    font-family: var(--sw-sans);
    font-size: 1rem;
    color: var(--sw-ink);
    box-shadow: none;
    outline: none;
    transition: border-color var(--sw-duration) var(--sw-ease);
}

.sw-input:focus {
    border-bottom-color: var(--sw-plum);
}

/* ── Body typography overrides ───────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--sw-serif);
    color: var(--sw-ink);
    font-weight: 500;
    letter-spacing: -0.012em;
    line-height: 1.2;
}

p {
    color: var(--sw-ink);
    line-height: 1.65;
}

.lead {
    font-family: var(--sw-sans);
    font-size: 1.1rem;
    font-weight: 400;
    color: var(--sw-ink-muted);
    line-height: 1.55;
}

a {
    color: var(--sw-plum);
    transition: color var(--sw-duration) var(--sw-ease);
}

a:hover {
    color: var(--sw-plum-dark);
}

::selection {
    background: rgba(74, 44, 75, 0.18);
    color: var(--sw-ink);
}

/* ── Navbar refinement ───────────────────────────────────────────── */
.navbar {
    background: var(--sw-bg);
    border-bottom: 1px solid var(--sw-line);
    padding: 1rem 0;
}

.navbar-brand {
    font-family: var(--sw-serif) !important;
    font-size: 1.55rem !important;
    font-weight: 400 !important;
    letter-spacing: 0.04em !important;
    color: var(--sw-ink) !important;
    text-transform: lowercase;
}

.navbar-brand-text {
    font-style: normal;
}

.navbar-brand-icon {
    width: 30px;
    height: 30px;
}

.navbar .nav-link {
    font-family: var(--sw-sans) !important;
    font-size: 0.78rem !important;
    font-weight: 500 !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    color: var(--sw-ink-muted) !important;
    padding: 0.5rem 1rem !important;
    position: relative;
    transition: color var(--sw-duration) var(--sw-ease);
}

.navbar .nav-link:hover {
    color: var(--sw-plum) !important;
}

.navbar .nav-link.active {
    color: var(--sw-plum-dark) !important;
    font-weight: 600 !important;
}

.navbar .nav-link.active::after {
    content: '';
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 0.25rem;
    height: 1px;
    background: var(--sw-plum);
    opacity: 0.6;
}

.nav-user-display {
    font-family: var(--sw-serif) !important;
    font-style: italic;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: var(--sw-ink-muted) !important;
}

.nav-progress-bar {
    background: linear-gradient(90deg, var(--sw-plum), var(--sw-plum-tint));
    height: 2px;
}

/* ── Buttons / Bootstrap overrides ───────────────────────────────── */
.btn-primary,
.btn-sommwise {
    background: var(--sw-plum) !important;
    border-color: var(--sw-plum) !important;
    color: #fdfbf7 !important;
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    letter-spacing: 0.01em !important;
    border-radius: var(--sw-radius) !important;
    padding: 0.65rem 1.4rem !important;
    transition: transform var(--sw-duration) var(--sw-ease),
                background var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease) !important;
}

.btn-primary:hover,
.btn-sommwise:hover {
    background: var(--sw-plum-dark) !important;
    border-color: var(--sw-plum-dark) !important;
    transform: translateY(-1px);
    box-shadow: var(--sw-shadow);
}

.btn-outline-primary,
.btn-sommwise-outline {
    background: transparent !important;
    border-color: var(--sw-line-strong) !important;
    color: var(--sw-plum) !important;
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    border-radius: var(--sw-radius) !important;
    padding: 0.65rem 1.4rem !important;
}

.btn-outline-primary:hover,
.btn-sommwise-outline:hover {
    background: var(--sw-bg-plum-tint) !important;
    border-color: var(--sw-plum) !important;
    color: var(--sw-plum-dark) !important;
}

.btn-light {
    background: #fdfbf7 !important;
    border-color: #fdfbf7 !important;
    color: var(--sw-plum) !important;
    font-family: var(--sw-serif) !important;
}

.btn-light:hover {
    background: #fff !important;
    color: var(--sw-plum-dark) !important;
}

/* ── Hero (StudyHero unauth landing) ─────────────────────────────── */
.hero-section {
    background: var(--sw-bg);
    padding: 6rem 0 5rem;
    border-bottom: 1px solid var(--sw-line);
}

.hero-title {
    font-family: var(--sw-serif);
    font-size: clamp(2.5rem, 5vw, 3.6rem);
    font-weight: 500;
    font-style: normal;
    letter-spacing: -0.018em;
    line-height: 1.1;
    color: var(--sw-ink);
}

.hero-subtitle {
    font-family: var(--sw-sans);
    font-size: 1.1rem;
    color: var(--sw-ink-muted);
    font-weight: 400;
}

/* ── StudyHero (authed welcome) ──────────────────────────────────── */
.study-hero {
    background: var(--sw-bg) !important;
    background-image:
        radial-gradient(ellipse at top right, rgba(74, 44, 75, 0.05), transparent 60%),
        radial-gradient(ellipse at bottom left, rgba(184, 152, 92, 0.04), transparent 50%) !important;
    color: var(--sw-ink) !important;
    padding: 5rem 0 4rem !important;
    border-bottom: 1px solid var(--sw-line);
}

.study-hero-title {
    font-family: var(--sw-serif) !important;
    font-size: clamp(2rem, 4vw, 2.75rem) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.015em !important;
    line-height: 1.15 !important;
}

.study-hero-subtitle {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    opacity: 1 !important;
    font-size: 1.08rem !important;
    line-height: 1.55 !important;
}

.study-hero-cta {
    background: var(--sw-plum) !important;
    border-color: var(--sw-plum) !important;
    color: #fdfbf7 !important;
}

.study-hero-cta:hover {
    background: var(--sw-plum-dark) !important;
    border-color: var(--sw-plum-dark) !important;
}

.btn-outline-light {
    background: transparent !important;
    border-color: var(--sw-line-strong) !important;
    color: var(--sw-plum) !important;
}

.btn-outline-light:hover {
    background: var(--sw-bg-plum-tint) !important;
    color: var(--sw-plum-dark) !important;
}

.study-hero-conversion-hint {
    color: var(--sw-ink-muted) !important;
    font-family: var(--sw-sans);
    font-size: 0.93rem;
    margin-top: 1.5rem !important;
}

.study-hero-conversion-hint .hint-link {
    color: var(--sw-plum) !important;
    font-weight: 600;
    text-decoration: none;
    border-bottom: 1px solid currentColor;
    padding-bottom: 1px;
}

/* ── StudyProgress stat cards ───────────────────────────────────── */
.study-progress-section {
    background: var(--sw-bg) !important;
    padding: 4rem 0 !important;
    border-bottom: 1px solid var(--sw-line);
}

.study-progress-title {
    font-family: var(--sw-serif) !important;
    font-size: 1.55rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    margin-bottom: 2rem !important;
    letter-spacing: -0.01em;
    position: relative;
    padding-bottom: 0.75rem;
}

.study-progress-title::before {
    content: 'Your study';
    display: block;
    font-family: var(--sw-sans);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--sw-ink-muted);
    margin-bottom: 0.4rem;
}

.progress-stat-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
    padding: 1.5rem 1.25rem !important;
    text-align: left !important;
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease) !important;
}

.progress-stat-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.progress-stat-icon {
    color: var(--sw-plum) !important;
    font-size: 1.1rem !important;
    margin-bottom: 0.5rem !important;
    opacity: 0.55;
}

.progress-stat-value {
    font-family: var(--sw-serif) !important;
    font-size: 2.4rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    line-height: 1 !important;
    letter-spacing: -0.02em;
}

.progress-stat-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    font-weight: 600 !important;
    color: var(--sw-ink-muted) !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    margin-top: 0.5rem !important;
}

/* ── FeaturedDecks section ───────────────────────────────────────── */
.featured-decks {
    background: var(--sw-bg) !important;
    padding: 4rem 0 6rem !important;
}

.featured-decks-header {
    margin-bottom: 2.5rem !important;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--sw-line);
    align-items: baseline !important;
}

.featured-decks-title {
    font-family: var(--sw-serif) !important;
    font-size: 1.7rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.01em;
}

.featured-decks-link {
    font-family: var(--sw-sans) !important;
    font-size: 0.78rem !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-weight: 600 !important;
    color: var(--sw-plum) !important;
}

.featured-decks-link:hover {
    color: var(--sw-plum-dark) !important;
}

.featured-deck-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
    padding: 1.75rem 1.5rem !important;
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease) !important;
}

.featured-deck-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.featured-deck-icon {
    width: 36px !important;
    height: 36px !important;
    background: var(--sw-bg-plum-tint) !important;
    color: var(--sw-plum) !important;
    border-radius: var(--sw-radius-sm) !important;
    font-size: 1rem !important;
    margin-bottom: 1.25rem !important;
}

.featured-deck-name {
    font-family: var(--sw-serif) !important;
    font-size: 1.2rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    line-height: 1.25 !important;
    letter-spacing: -0.005em;
}

.featured-deck-cert {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-weight: 600 !important;
    color: var(--sw-gold) !important;
}

.featured-deck-desc {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 0.92rem !important;
}

.featured-deck-meta {
    border-top: 1px solid var(--sw-line) !important;
    color: var(--sw-ink-subtle) !important;
    font-size: 0.78rem !important;
    padding-top: 1rem !important;
}

/* ── Flashcard browse / deck grid ────────────────────────────────── */
.flashcards-hero,
.tastings-hero,
.groups-hero,
.progress-hero,
.courses-hero,
.my-courses-header {
    background: var(--sw-bg) !important;
    padding: 4rem 0 3rem !important;
    border-bottom: 1px solid var(--sw-line);
}

.flashcards-title,
.tastings-title,
.groups-title,
.progress-title,
.my-courses-title {
    font-family: var(--sw-serif) !important;
    font-size: clamp(2rem, 4vw, 2.75rem) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.015em !important;
    line-height: 1.1 !important;
}

.flashcards-subtitle,
.tastings-subtitle,
.groups-subtitle,
.progress-subtitle,
.my-courses-subtitle {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 1.05rem !important;
    line-height: 1.55 !important;
    max-width: 580px;
}

.courses-hero-eyebrow {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.18em !important;
    color: var(--sw-ink-muted) !important;
    font-weight: 600 !important;
    margin-bottom: 0.75rem !important;
}

.courses-hero-title {
    font-family: var(--sw-serif) !important;
    font-size: clamp(2rem, 4.5vw, 3rem) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.015em !important;
    line-height: 1.1 !important;
}

.courses-hero-subtitle {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 1.08rem !important;
}

/* Deck cards (Browse) */
.deck-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease) !important;
}

.deck-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.deck-card-placeholder {
    background: var(--sw-bg-warm) !important;
    color: var(--sw-plum-tint) !important;
}

.deck-card-title,
.deck-progress-name,
.deck-details-title {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.005em;
}

.deck-card-cert,
.deck-progress-cert,
.deck-details-cert {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-weight: 600 !important;
    color: var(--sw-gold) !important;
}

.deck-card-description {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
}

.deck-card-details,
.deck-card-footer,
.deck-progress-details {
    color: var(--sw-ink-subtle) !important;
    font-family: var(--sw-sans) !important;
}

/* ═════════════════════════════════════════════════════════════════
   STUDY.RAZOR — KEYSTONE. Users spend most time here.
   ═════════════════════════════════════════════════════════════════ */
.study-interface {
    background: var(--sw-bg) !important;
    background-image:
        radial-gradient(ellipse 60% 40% at 50% 0%, rgba(74, 44, 75, 0.04), transparent 70%);
}

/* Progress bar at top of study session */
.study-progress {
    background: var(--sw-bg) !important;
    padding: 1.25rem 0 !important;
    border-bottom: 1px solid var(--sw-line) !important;
}

.progress-text {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-weight: 600 !important;
    color: var(--sw-ink-muted) !important;
}

.deck-name {
    font-family: var(--sw-serif) !important;
    font-style: italic;
    color: var(--sw-ink) !important;
    font-weight: 400 !important;
}

.study-progress .progress {
    height: 3px !important;
    background: rgba(74, 44, 75, 0.08) !important;
    border-radius: 0 !important;
}

.study-progress .progress-bar {
    background: var(--sw-plum) !important;
    border-radius: 0 !important;
    transition: width 0.4s var(--sw-ease) !important;
}

/* The flashcard itself — bigger, calmer, serious */
.flashcard-container {
    padding: 3rem 1rem 2rem !important;
    perspective: 1600px;
}

.flashcard {
    max-width: 720px !important;
    min-height: 440px !important;
    /* Sprint 4 JS requires .flashcard + data-swipe-zone — preserved */
}

.flashcard-face {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius-lg) !important;
    box-shadow: 0 8px 32px rgba(42, 34, 40, 0.06), 0 2px 6px rgba(42, 34, 40, 0.03) !important;
    padding: 4rem 3rem !important;
    min-height: 440px !important;
}

.flashcard-back {
    background:
        linear-gradient(180deg, rgba(243, 238, 243, 0.4), transparent 30%),
        var(--sw-bg-elevated) !important;
    border-color: rgba(74, 44, 75, 0.22) !important;
}

.flashcard {
    transition: transform 0.55s cubic-bezier(0.34, 0.05, 0.16, 1) !important;
}

.card-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.2em !important;
    font-weight: 600 !important;
    color: var(--sw-plum) !important;
    opacity: 0.7;
    margin-bottom: 1.75rem !important;
}

.flashcard-back .card-label {
    color: var(--sw-plum) !important;
    opacity: 0.85;
}

.card-main-text {
    font-family: var(--sw-serif) !important;
    font-size: clamp(1.5rem, 2.5vw, 2rem) !important;
    font-weight: 400 !important;
    color: var(--sw-ink) !important;
    line-height: 1.3 !important;
    letter-spacing: -0.01em;
    max-width: 30ch;
    margin-left: auto !important;
    margin-right: auto !important;
}

.flashcard-back .card-main-text {
    font-weight: 500 !important;
    color: var(--sw-plum-dark) !important;
}

.card-hint {
    background: var(--sw-bg-warm) !important;
    border: 1px solid rgba(184, 152, 92, 0.25) !important;
    border-radius: var(--sw-radius) !important;
    color: var(--sw-ink) !important;
    font-family: var(--sw-sans) !important;
    font-size: 0.92rem !important;
    line-height: 1.55 !important;
    padding: 0.85rem 1.1rem !important;
}

.card-hint i {
    color: var(--sw-gold) !important;
}

.card-explanation {
    background: var(--sw-bg-plum-tint) !important;
    border-left: 2px solid var(--sw-plum) !important;
    border-radius: 0 !important;
    color: var(--sw-ink) !important;
    font-family: var(--sw-sans) !important;
    font-size: 0.95rem !important;
    line-height: 1.6 !important;
    padding: 1rem 1.25rem !important;
    text-align: left !important;
    margin-top: 1.75rem !important;
}

.card-explanation strong {
    color: var(--sw-plum-dark);
    font-family: var(--sw-serif);
    font-weight: 600;
    font-style: italic;
    margin-right: 0.25rem;
}

.flip-instruction {
    font-family: var(--sw-sans) !important;
    font-size: 0.75rem !important;
    text-transform: uppercase;
    letter-spacing: 0.16em !important;
    color: var(--sw-ink-subtle) !important;
    margin-top: 2.5rem !important;
}

.hint-button,
.entity-link {
    background: transparent !important;
    border: 1px solid var(--sw-line-strong) !important;
    color: var(--sw-plum) !important;
    font-family: var(--sw-sans) !important;
    font-size: 0.82rem !important;
    border-radius: var(--sw-radius) !important;
    padding: 0.5rem 1rem !important;
    transition: all var(--sw-duration) var(--sw-ease);
}

.hint-button:hover,
.entity-link:hover {
    background: var(--sw-bg-plum-tint) !important;
    border-color: var(--sw-plum) !important;
    color: var(--sw-plum-dark) !important;
}

/* Hotkey hint row — CMS instruction sheet feel */
.study-hotkey-hint {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.14em !important;
    color: var(--sw-ink-subtle) !important;
    text-align: center;
    padding: 0.5rem 1rem 1rem !important;
    display: flex;
    justify-content: center;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.study-hotkey-hint .hint-sep {
    color: var(--sw-line-strong) !important;
}

/* Rating buttons — visual weight differs by severity */
.rating-buttons {
    background: var(--sw-bg) !important;
    border-top: 1px solid var(--sw-line) !important;
    padding: 1.75rem 0 2.25rem !important;
}

.rating-grid {
    max-width: 720px;
    margin: 0 auto;
    gap: 0.75rem !important;
}

.rating-btn {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    padding: 1.1rem 0.75rem !important;
    min-height: 56px;
    transition: transform var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease),
                background var(--sw-duration) var(--sw-ease) !important;
    box-shadow: none !important;
}

.rating-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow) !important;
}

.rating-icon {
    font-size: 1.4rem !important;
}

.rating-label {
    font-family: var(--sw-serif) !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.005em;
}

.rating-time {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--sw-ink-subtle) !important;
}

/* Severity gradient — Again muted, Easy plum-accent */
.rating-again {
    border-color: var(--sw-line) !important;
}
.rating-again .rating-icon { color: var(--sw-ink-subtle) !important; }
.rating-again .rating-label { color: var(--sw-ink-muted) !important; }
.rating-again:hover {
    border-color: var(--sw-line-strong) !important;
    background: rgba(106, 96, 102, 0.04) !important;
}

.rating-hard {
    border-color: var(--sw-line) !important;
}
.rating-hard .rating-icon { color: var(--sw-gold) !important; opacity: 0.85; }
.rating-hard:hover {
    border-color: rgba(184, 152, 92, 0.6) !important;
    background: rgba(184, 152, 92, 0.06) !important;
}

.rating-good {
    border-color: rgba(74, 44, 75, 0.18) !important;
}
.rating-good .rating-icon { color: var(--sw-plum-tint) !important; }
.rating-good:hover {
    border-color: var(--sw-plum-tint) !important;
    background: rgba(74, 44, 75, 0.04) !important;
}

.rating-easy {
    border-color: var(--sw-plum) !important;
    background: var(--sw-bg-plum-tint) !important;
}
.rating-easy .rating-icon { color: var(--sw-plum) !important; }
.rating-easy .rating-label { color: var(--sw-plum-dark) !important; font-weight: 600 !important; }
.rating-easy:hover {
    background: rgba(74, 44, 75, 0.08) !important;
    border-color: var(--sw-plum-dark) !important;
}

/* Feedback link below rating */
.rating-buttons .btn-link {
    font-family: var(--sw-sans) !important;
    font-size: 0.78rem !important;
    color: var(--sw-ink-subtle) !important;
    text-decoration: none !important;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 500 !important;
}

.rating-buttons .btn-link:hover {
    color: var(--sw-plum) !important;
}

/* "All Done!" graduation screen */
.study-complete {
    background: var(--sw-bg) !important;
    background-image:
        radial-gradient(ellipse 60% 50% at 50% 30%, rgba(74, 44, 75, 0.05), transparent 70%);
}

.complete-icon {
    color: var(--sw-plum) !important;
    font-size: 3.5rem !important;
    opacity: 0.85;
    margin-bottom: 1.5rem !important;
}

.study-complete h1 {
    font-family: var(--sw-serif) !important;
    font-size: clamp(2rem, 4vw, 2.75rem) !important;
    font-weight: 500 !important;
    font-style: italic;
    color: var(--sw-ink) !important;
    letter-spacing: -0.015em;
}

.study-complete .lead {
    color: var(--sw-ink-muted) !important;
}

.session-stats .stat-value {
    font-family: var(--sw-serif) !important;
    color: var(--sw-plum) !important;
    font-weight: 500 !important;
}

.session-stats .stat-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.16em !important;
    color: var(--sw-ink-muted) !important;
}

.study-complete-conversion {
    max-width: 580px;
    margin: 2.5rem auto 0;
    text-align: left;
}

/* ═════════════════════════════════════════════════════════════════
   PROGRESS PAGE — stat tile re-treatment, plus the Diner Profile tile
   ═════════════════════════════════════════════════════════════════ */
.stat-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
    padding: 1.5rem 1.25rem !important;
    text-align: left !important;
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease) !important;
}

.stat-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.stat-card .stat-icon {
    color: var(--sw-plum) !important;
    font-size: 1rem !important;
    opacity: 0.5;
}

.stat-card .stat-value {
    font-family: var(--sw-serif) !important;
    font-size: 2.4rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    line-height: 1 !important;
    letter-spacing: -0.02em;
    margin-top: 0.5rem;
}

.stat-card .stat-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.14em !important;
    font-weight: 600 !important;
    color: var(--sw-ink-muted) !important;
    margin-top: 0.5rem;
}

/* The 5th tile — Diner Profile / Activate Sotto ID — special treatment */
.stat-card-conversion {
    background: var(--sw-bg-plum-tint) !important;
    border-color: rgba(74, 44, 75, 0.22) !important;
    position: relative;
    overflow: hidden;
}

.stat-card-conversion::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at top right, rgba(74, 44, 75, 0.08), transparent 60%);
    pointer-events: none;
}

.stat-card-conversion .stat-icon {
    color: var(--sw-plum) !important;
    opacity: 0.8 !important;
}

.stat-card-conversion .stat-card-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.14em !important;
    font-weight: 600 !important;
    color: var(--sw-plum) !important;
}

.stat-card-conversion .stat-card-value {
    font-family: var(--sw-serif) !important;
    color: var(--sw-plum-dark) !important;
    margin-top: 0.4rem;
}

.stat-card-conversion .active-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(74, 140, 94, 0.12);
    color: var(--sw-success);
    border: 1px solid rgba(74, 140, 94, 0.25);
    border-radius: 999px;
    padding: 0.25rem 0.7rem;
    font-family: var(--sw-sans);
    font-size: 0.78rem;
    font-weight: 600;
}

.stat-card-conversion .btn-sommwise-sm {
    animation: sw-pulse-plum 2.4s var(--sw-ease) infinite;
    font-family: var(--sw-serif) !important;
    padding: 0.4rem 1.1rem !important;
    font-size: 0.92rem !important;
}

@keyframes sw-pulse-plum {
    0%, 100% { box-shadow: 0 0 0 0 rgba(74, 44, 75, 0.32); }
    50%      { box-shadow: 0 0 0 8px rgba(74, 44, 75, 0); }
}

.section-title {
    font-family: var(--sw-serif) !important;
    font-size: 1.4rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.01em;
}

.section-title i {
    color: var(--sw-plum) !important;
    opacity: 0.55;
    margin-right: 0.5rem;
}

/* Deck progress card */
.deck-progress-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
}

.deck-progress-card:hover {
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.due-deck-item {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    padding: 1.25rem 1.5rem !important;
}

.due-deck-item h5 {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
}

/* Badges in progress */
.badge.bg-success {
    background: rgba(74, 140, 94, 0.14) !important;
    color: var(--sw-success) !important;
    font-family: var(--sw-sans) !important;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.7rem;
    padding: 0.35rem 0.7rem;
    border-radius: var(--sw-radius-sm);
}

.badge.bg-warning {
    background: rgba(184, 152, 92, 0.18) !important;
    color: #8a6c3a !important;
    font-family: var(--sw-sans) !important;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.7rem;
    padding: 0.35rem 0.7rem;
    border-radius: var(--sw-radius-sm);
}

/* ═════════════════════════════════════════════════════════════════
   COURSES — Programs, MyCourses, CourseDetail
   ═════════════════════════════════════════════════════════════════ */
.program-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease) !important;
    overflow: hidden;
}

.program-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.program-card-accent {
    background: linear-gradient(180deg, var(--sw-plum), var(--sw-plum-tint)) !important;
}

.program-name {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.005em;
}

.program-description {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
}

.program-cert-badge {
    background: var(--sw-bg-warm) !important;
    color: var(--sw-gold) !important;
    border: 1px solid rgba(184, 152, 92, 0.3);
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    border-radius: var(--sw-radius-sm);
    padding: 0.3rem 0.65rem;
}

.difficulty-badge {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    border-radius: var(--sw-radius-sm);
    padding: 0.3rem 0.65rem;
}

.difficulty-beginner {
    background: rgba(74, 140, 94, 0.1) !important;
    color: var(--sw-success) !important;
    border: 1px solid rgba(74, 140, 94, 0.22);
}

.difficulty-intermediate {
    background: var(--sw-bg-warm) !important;
    color: #8a6c3a !important;
    border: 1px solid rgba(184, 152, 92, 0.3);
}

.difficulty-advanced {
    background: var(--sw-bg-plum-tint) !important;
    color: var(--sw-plum-dark) !important;
    border: 1px solid rgba(74, 44, 75, 0.22);
}

/* CourseDetail — module tree, curriculum feel */
.module-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
    overflow: hidden;
}

.module-card.module-expanded {
    border-color: var(--sw-line-strong) !important;
}

.module-header {
    padding: 1.5rem !important;
    border-bottom: 1px solid transparent;
}

.module-expanded .module-header {
    border-bottom-color: var(--sw-line);
}

.module-number {
    font-family: var(--sw-serif) !important;
    font-size: 1.4rem !important;
    font-weight: 500 !important;
    color: var(--sw-plum) !important;
    font-style: italic;
    width: 2.5rem;
    text-align: center;
}

.module-name {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    font-size: 1.15rem !important;
    letter-spacing: -0.005em;
}

.module-description {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 0.92rem !important;
}

.module-item-count {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    color: var(--sw-ink-subtle) !important;
    font-weight: 600 !important;
}

.module-items {
    padding-left: 4rem !important;
    background: var(--sw-bg) !important;
}

.module-item {
    border-bottom: 1px solid var(--sw-line);
    padding: 1rem 1.25rem !important;
    transition: background var(--sw-duration) var(--sw-ease);
}

.module-item:last-child {
    border-bottom: 0;
}

.module-item:hover {
    background: var(--sw-bg-warm) !important;
}

.module-item-title {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    font-size: 1rem !important;
}

.module-item-icon {
    color: var(--sw-plum) !important;
    opacity: 0.6;
}

.module-item-icon.bi-check-circle-fill,
.module-item-icon.bi-check-circle {
    color: var(--sw-plum) !important;
    opacity: 0.85;
}

.module-item-icon.bi-lock,
.module-item-icon.bi-lock-fill {
    color: var(--sw-gold) !important;
}

.item-type-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--sw-ink-subtle) !important;
    font-weight: 600 !important;
}

.module-item-optional {
    opacity: 0.65;
}

/* My courses */
.my-course-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
}

.my-course-card:hover {
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.my-course-completed {
    border-color: rgba(74, 140, 94, 0.3) !important;
    background: linear-gradient(180deg, rgba(74, 140, 94, 0.04), var(--sw-bg-elevated) 40%) !important;
}

.my-course-name {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
}

.active-course-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    transition: transform var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease),
                border-color var(--sw-duration) var(--sw-ease) !important;
}

.active-course-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.active-course-name {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
}

/* Progress ring colors */
.progress-ring-bg {
    stroke: var(--sw-line) !important;
}

.progress-ring-fill {
    stroke: var(--sw-plum) !important;
}

.progress-ring-text,
.progress-ring-text-lg {
    fill: var(--sw-plum-dark);
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
}

.course-title {
    font-family: var(--sw-serif) !important;
    font-size: clamp(1.75rem, 3.5vw, 2.4rem) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.015em !important;
    line-height: 1.15 !important;
}

.course-description {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
}

.enrollment-card {
    background: var(--sw-bg-warm) !important;
    border: 1px solid rgba(184, 152, 92, 0.25) !important;
    border-radius: var(--sw-radius) !important;
}

/* ═════════════════════════════════════════════════════════════════
   TASTINGS — Blind, Browse
   ═════════════════════════════════════════════════════════════════ */
.tasting-progress {
    background: var(--sw-bg) !important;
    padding: 1.25rem 0 !important;
    border-bottom: 1px solid var(--sw-line) !important;
}

.tasting-label {
    font-family: var(--sw-serif) !important;
    font-style: italic;
    color: var(--sw-ink) !important;
    font-weight: 400 !important;
}

.tasting-progress .progress {
    height: 3px !important;
    background: rgba(74, 44, 75, 0.08) !important;
    border-radius: 0 !important;
}

.tasting-progress .progress-bar {
    background: var(--sw-plum) !important;
    border-radius: 0 !important;
}

.section-header {
    background: transparent !important;
    border-bottom: 1px solid var(--sw-line);
    padding-bottom: 1rem;
    margin-bottom: 2rem;
}

.section-icon {
    color: var(--sw-plum) !important;
    background: var(--sw-bg-plum-tint) !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: var(--sw-radius-sm) !important;
}

.section-description {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 0.95rem !important;
}

.grid-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.14em !important;
    font-weight: 600 !important;
    color: var(--sw-ink-muted) !important;
    margin-bottom: 0.75rem !important;
}

.option-btn {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    color: var(--sw-ink) !important;
    font-family: var(--sw-sans) !important;
    font-weight: 500 !important;
    font-size: 0.92rem !important;
    padding: 0.55rem 1rem !important;
    transition: all var(--sw-duration) var(--sw-ease);
}

.option-btn:hover {
    border-color: var(--sw-plum-tint) !important;
    color: var(--sw-plum) !important;
}

.option-btn.active {
    background: var(--sw-plum) !important;
    border-color: var(--sw-plum) !important;
    color: #fdfbf7 !important;
}

.checkbox-label {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink) !important;
    font-size: 0.92rem !important;
}

.category-label {
    font-family: var(--sw-serif) !important;
    font-style: italic;
    color: var(--sw-plum) !important;
    font-weight: 500 !important;
}

/* Reveal */
.reveal-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius-lg) !important;
    box-shadow: var(--sw-shadow-lg) !important;
}

.reveal-icon {
    background: var(--sw-bg-plum-tint) !important;
    color: var(--sw-plum) !important;
    border-radius: 999px;
}

.reveal-wine,
.reveal-wine h2,
.reveal-wine h3 {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.01em;
}

.reveal-details {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
}

.accuracy-score {
    background: var(--sw-bg-plum-tint) !important;
    border-radius: var(--sw-radius) !important;
}

.score-value {
    font-family: var(--sw-serif) !important;
    color: var(--sw-plum-dark) !important;
    font-weight: 500 !important;
}

.score-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.14em !important;
    color: var(--sw-plum) !important;
    font-weight: 600 !important;
}

.comparison-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-weight: 600 !important;
    color: var(--sw-ink-muted) !important;
}

.comparison-values {
    font-family: var(--sw-serif) !important;
    color: var(--sw-ink) !important;
}

/* Tasting card (Browse) */
.tasting-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
}

.tasting-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.score-circle {
    background: var(--sw-plum) !important;
    color: #fdfbf7 !important;
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
}

/* ═════════════════════════════════════════════════════════════════
   KNOWLEDGE — Article, Browse
   ═════════════════════════════════════════════════════════════════ */
.article-content {
    font-family: var(--sw-sans);
    font-size: 1.05rem;
    line-height: 1.75;
    color: var(--sw-ink);
    max-width: 640px;
    margin: 0 auto;
}

.article-content h1,
.article-content h2,
.article-content h3,
.article-content h4 {
    font-family: var(--sw-serif);
    font-weight: 500;
    color: var(--sw-ink);
    letter-spacing: -0.01em;
    margin-top: 2.5rem;
    margin-bottom: 0.85rem;
    line-height: 1.2;
}

.article-content h1 { font-size: 1.85rem; }
.article-content h2 {
    font-size: 1.5rem;
    border-bottom: 1px solid var(--sw-line);
    padding-bottom: 0.4rem;
}
.article-content h3 { font-size: 1.2rem; font-style: italic; color: var(--sw-plum-dark); }

.article-content p {
    margin-bottom: 1.25rem;
}

.article-content a {
    color: var(--sw-plum);
    border-bottom: 1px solid rgba(74, 44, 75, 0.3);
    text-decoration: none;
    transition: border-color var(--sw-duration) var(--sw-ease);
}

.article-content a:hover {
    color: var(--sw-plum-dark);
    border-bottom-color: var(--sw-plum-dark);
}

.article-content blockquote {
    border-left: 2px solid var(--sw-plum);
    padding: 0.25rem 0 0.25rem 1.5rem;
    margin: 2rem 0;
    font-family: var(--sw-serif);
    font-style: italic;
    color: var(--sw-ink-muted);
    font-size: 1.15rem;
}

.article-content ul,
.article-content ol {
    margin-bottom: 1.25rem;
    padding-left: 1.5rem;
}

.article-content li {
    margin-bottom: 0.5rem;
}

.article-content code {
    font-family: 'SF Mono', Monaco, monospace;
    font-size: 0.9em;
    background: var(--sw-bg-warm);
    padding: 0.1em 0.35em;
    border-radius: 3px;
    color: var(--sw-plum-dark);
}

/* Fenced code blocks — Markdig wraps them in <pre><code>. Reset the inline
   bg/padding from `.article-content code` so the block reads as a block. */
.article-content pre {
    background: var(--sw-bg-warm);
    border: 1px solid var(--sw-line);
    border-radius: var(--sw-radius-sm);
    padding: 1rem 1.15rem;
    margin: 1.25rem 0;
    overflow-x: auto;
    line-height: 1.5;
}

.article-content pre code {
    background: transparent;
    padding: 0;
    color: var(--sw-ink);
    font-size: 0.95em;
}

.article-content strong {
    color: var(--sw-ink);
    font-weight: 600;
}

.article-content em {
    color: var(--sw-ink-muted);
}

.article-content table {
    width: 100%;
    margin: 1.5rem 0;
    border-collapse: collapse;
    font-size: 0.95em;
}

.article-content th,
.article-content td {
    text-align: left;
    padding: 0.55rem 0.85rem;
    border-bottom: 1px solid var(--sw-line);
}

.article-content th {
    font-family: var(--sw-serif);
    font-weight: 500;
    color: var(--sw-ink);
    background: var(--sw-bg-warm);
}

.article-content hr {
    border: 0;
    border-top: 1px solid var(--sw-line);
    margin: 2.5rem auto;
    max-width: 4rem;
}

/* Article header card override */
article.card,
.knowledge-article .card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius-lg) !important;
    box-shadow: var(--sw-shadow-sm) !important;
}

article.card .display-5 {
    font-family: var(--sw-serif);
    font-weight: 500;
    color: var(--sw-ink);
    letter-spacing: -0.018em;
    line-height: 1.1;
    font-size: clamp(2rem, 4vw, 2.75rem) !important;
}

article.card .lead {
    font-family: var(--sw-sans);
    color: var(--sw-ink-muted);
    font-size: 1.1rem;
    line-height: 1.55;
}

/* Knowledge Browse cards */
.card {
    border-color: var(--sw-line);
    border-radius: var(--sw-radius);
}

.card-title {
    font-family: var(--sw-serif);
    font-weight: 500;
    color: var(--sw-ink);
    letter-spacing: -0.005em;
}

.card-header {
    background: var(--sw-bg-warm);
    border-bottom: 1px solid var(--sw-line);
    font-family: var(--sw-serif);
    font-weight: 500;
}

.badge.bg-primary {
    background: var(--sw-plum) !important;
    font-family: var(--sw-sans);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.7rem;
    padding: 0.35rem 0.7rem;
    border-radius: var(--sw-radius-sm);
}

.badge.bg-secondary {
    background: var(--sw-ink-muted) !important;
    font-family: var(--sw-sans);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.7rem;
    padding: 0.35rem 0.7rem;
    border-radius: var(--sw-radius-sm);
}

.badge.bg-info {
    background: var(--sw-bg-warm) !important;
    color: var(--sw-gold) !important;
    border: 1px solid rgba(184, 152, 92, 0.3);
    font-family: var(--sw-sans);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.7rem;
    padding: 0.35rem 0.7rem;
    border-radius: var(--sw-radius-sm);
}

.breadcrumb {
    font-family: var(--sw-sans);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--sw-ink-muted);
}

.breadcrumb a {
    color: var(--sw-ink-muted);
}

.breadcrumb a:hover {
    color: var(--sw-plum);
}

.breadcrumb-item.active {
    color: var(--sw-plum-dark);
    font-weight: 600;
}

/* ═════════════════════════════════════════════════════════════════
   ENSALLE CONVERSION CARD — deliberate offer, not a banner
   ═════════════════════════════════════════════════════════════════ */
.ensalle-conversion-card {
    background: var(--sw-bg-plum-tint) !important;
    border: 1px solid rgba(74, 44, 75, 0.22) !important;
    border-radius: var(--sw-radius-lg) !important;
    padding: 2rem !important;
    position: relative;
    overflow: hidden;
}

.ensalle-conversion-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at top right, rgba(74, 44, 75, 0.08), transparent 60%),
        radial-gradient(ellipse at bottom left, rgba(184, 152, 92, 0.06), transparent 50%);
    pointer-events: none;
}

.ensalle-conversion-card > * {
    position: relative;
}

.ensalle-conversion-card-activated {
    background: linear-gradient(135deg, rgba(74, 140, 94, 0.06), rgba(74, 140, 94, 0.12)) !important;
    border-color: rgba(74, 140, 94, 0.3) !important;
}

.ensalle-card-eyebrow {
    font-family: var(--sw-sans) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.16em !important;
    font-weight: 600 !important;
    color: var(--sw-plum) !important;
}

.ensalle-card-eyebrow-success {
    color: var(--sw-success) !important;
}

.ensalle-card-headline {
    font-family: var(--sw-serif) !important;
    font-size: 1.55rem !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.012em !important;
    line-height: 1.2 !important;
    margin-top: 0.5rem !important;
}

.ensalle-card-pitch {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
}

.ensalle-card-signals {
    background: rgba(74, 44, 75, 0.08) !important;
    color: var(--sw-plum-dark) !important;
    font-family: var(--sw-sans) !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    border: 1px solid rgba(74, 44, 75, 0.15);
}

.ensalle-card-signals .bi {
    color: var(--sw-plum) !important;
}

.ensalle-card-confirmed .ensalle-card-headline {
    color: var(--sw-success) !important;
}

/* ═════════════════════════════════════════════════════════════════
   ALERTS / FORMS / FOOTER
   ═════════════════════════════════════════════════════════════════ */
.alert {
    border-radius: var(--sw-radius);
    font-family: var(--sw-sans);
    border: 1px solid transparent;
}

.alert-info {
    background: var(--sw-bg-plum-tint);
    color: var(--sw-plum-dark);
    border-color: rgba(74, 44, 75, 0.2);
}

.alert-warning {
    background: var(--sw-bg-warm);
    color: #8a6c3a;
    border-color: rgba(184, 152, 92, 0.3);
}

.form-label {
    font-family: var(--sw-sans);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-weight: 600;
    color: var(--sw-ink-muted);
    margin-bottom: 0.5rem;
}

.form-control,
.form-select {
    background: var(--sw-bg-elevated);
    border: 1px solid var(--sw-line-strong);
    border-radius: var(--sw-radius);
    color: var(--sw-ink);
    font-family: var(--sw-sans);
    padding: 0.6rem 0.85rem;
    transition: border-color var(--sw-duration) var(--sw-ease),
                box-shadow var(--sw-duration) var(--sw-ease);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--sw-plum);
    box-shadow: 0 0 0 3px rgba(74, 44, 75, 0.1);
    outline: none;
}

/* Footer */
.footer-sommwise {
    background: var(--sw-bg) !important;
    border-top: 1px solid var(--sw-line) !important;
    padding: 4rem 0 2rem !important;
}

.footer-sotto-brand {
    border-radius: var(--sw-radius);
    transition: background var(--sw-duration) var(--sw-ease);
}

.footer-sotto-brand:hover {
    background: var(--sw-bg-warm);
}

.footer-sotto-brand.active {
    background: var(--sw-bg-plum-tint);
}

.footer-sotto-brand-name {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    letter-spacing: -0.005em;
}

.footer-sotto-brand-name.sommwise {
    color: var(--sw-plum) !important;
}

.footer-sotto-brand-tagline {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 0.82rem !important;
}

.footer-links-col h6 {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.14em !important;
    font-weight: 600 !important;
    color: var(--sw-ink-muted) !important;
}

.footer-links-col a {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink) !important;
    font-size: 0.92rem !important;
}

.footer-links-col a:hover {
    color: var(--sw-plum) !important;
}

.footer-copyright,
.footer-note {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
    font-size: 0.82rem !important;
}

.footer-copyright a {
    color: var(--sw-plum);
}

/* ═════════════════════════════════════════════════════════════════
   EMPTY / LOADING — small serif italic, minimal icon
   ═════════════════════════════════════════════════════════════════ */
.empty-state {
    background: var(--sw-bg) !important;
    padding: 4rem 2rem !important;
    text-align: center;
}

.empty-icon {
    color: var(--sw-line-strong) !important;
    font-size: 2.5rem !important;
    margin-bottom: 1rem !important;
    opacity: 0.5;
}

.empty-state h2,
.empty-state h3 {
    font-family: var(--sw-serif) !important;
    font-style: italic;
    font-weight: 400 !important;
    color: var(--sw-ink-muted) !important;
    font-size: 1.25rem !important;
}

.empty-state p {
    color: var(--sw-ink-subtle);
    font-size: 0.95rem;
}

.featured-decks-empty p,
.featured-decks-empty .text-muted {
    font-family: var(--sw-serif) !important;
    font-style: italic;
    color: var(--sw-ink-muted) !important;
    font-size: 1.05rem !important;
}

.featured-decks-empty .bi {
    color: var(--sw-line-strong) !important;
    opacity: 0.5;
}

/* Skeleton loading shapes (Bootstrap placeholder) */
.placeholder-glow .placeholder {
    background: var(--sw-bg-warm);
    border-radius: var(--sw-radius-sm);
    opacity: 0.7;
}

/* Per-page skeleton card shells — match the visual weight of the real card
   so layout doesn't jump on swap. */
.deck-card-skeleton,
.tasting-card-skeleton,
.group-card-skeleton {
    background: var(--sw-bg);
    border: 1px solid var(--sw-line);
    border-radius: var(--sw-radius);
    padding: 1.25rem 1.5rem;
    height: 100%;
}

/* ═════════════════════════════════════════════════════════════════
   AUTH PAGES — quietly restyle to plum
   ═════════════════════════════════════════════════════════════════ */
.auth-title,
.sotto-title {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
    letter-spacing: -0.01em !important;
}

.auth-subtitle {
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink-muted) !important;
}

.auth-input {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line-strong) !important;
    border-radius: var(--sw-radius) !important;
    font-family: var(--sw-sans) !important;
    color: var(--sw-ink) !important;
}

.auth-input:focus {
    border-color: var(--sw-plum) !important;
    box-shadow: 0 0 0 3px rgba(74, 44, 75, 0.1) !important;
}

.auth-label {
    font-family: var(--sw-sans) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-weight: 600 !important;
    color: var(--sw-ink-muted) !important;
}

.auth-link {
    color: var(--sw-plum) !important;
}

.auth-btn-primary {
    background: var(--sw-plum) !important;
    border-color: var(--sw-plum) !important;
    color: #fdfbf7 !important;
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    border-radius: var(--sw-radius) !important;
}

.auth-btn-primary:hover {
    background: var(--sw-plum-dark) !important;
    border-color: var(--sw-plum-dark) !important;
}

/* ═════════════════════════════════════════════════════════════════
   GROUPS — light polish
   ═════════════════════════════════════════════════════════════════ */
.study-group-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
}

.study-group-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--sw-shadow-lg) !important;
    border-color: var(--sw-line-strong) !important;
}

.group-card-title,
.group-details-title {
    font-family: var(--sw-serif) !important;
    font-weight: 500 !important;
    color: var(--sw-ink) !important;
}

.group-card-placeholder {
    background: var(--sw-bg-warm) !important;
    color: var(--sw-plum-tint) !important;
}

/* Filters card */
.filters-card {
    background: var(--sw-bg-elevated) !important;
    border: 1px solid var(--sw-line) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: none !important;
}

/* ═════════════════════════════════════════════════════════════════
   MOBILE — re-target the keystone refinements
   ═════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .flashcard-container {
        padding: 1.5rem 1rem !important;
    }

    .flashcard-face {
        padding: 2.5rem 1.5rem !important;
        border-radius: var(--sw-radius) !important;
    }

    .card-main-text {
        font-size: 1.35rem !important;
    }

    .rating-grid {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 0.5rem !important;
    }

    .rating-btn {
        padding: 0.85rem 0.5rem !important;
    }

    .rating-label {
        font-size: 0.85rem !important;
    }

    .rating-time {
        font-size: 0.65rem !important;
        letter-spacing: 0.1em !important;
    }

    .study-hero {
        padding: 3.5rem 0 2.5rem !important;
    }

    .stat-card .stat-value,
    .progress-stat-value {
        font-size: 1.9rem !important;
    }
}

@media (max-width: 480px) {
    .rating-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .flashcard-face {
        padding: 2rem 1.25rem !important;
    }

    .card-main-text {
        font-size: 1.2rem !important;
    }
}

/* ---- Blazor FocusOnNavigate suppression ----------------------------------
 * Same as Ensalle — suppresses the h1 focus ring painted by Blazor's
 * <FocusOnNavigate Selector="h1" /> on every nav. Vinelog already does this.
 */
h1:focus,
h1:focus-visible {
    outline: none;
}
