/* Academy page styles - extracted from inline <style>. References brand-tokens.css variables. */

/* ═══════════════════════════════════════════════
   FANTASY ACADEMY -- LIGHT THEME (site-consistent)
   ═══════════════════════════════════════════════ */

#academy-main {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    background: var(--brand-bg);
    min-height: 100vh;
    color: var(--tp-text);
}

#academy-main h1, #academy-main h2, #academy-main h3, #academy-main h4 {
    font-family: 'Inter', sans-serif;
    color: var(--tp-ink);
}

/* ─── HERO ─── */
.ac-hero {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    padding: 56px 24px 64px;
    text-align: center;
    background: linear-gradient(135deg, #0e2240 0%, #1e3a5f 60%, #1a3a5c 100%);
    color: #fff;
}

.ac-hero::before {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 80px;
    background: linear-gradient(to top, var(--brand-bg), transparent);
    z-index: 2;
    pointer-events: none;
}

.ac-hero-kicker {
    position: relative;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--tp-cyan);
    margin-bottom: 14px;
}

.ac-hero-kicker::before {
    content: '';
    display: block;
    width: 24px;
    height: 2px;
    background: var(--tp-cyan);
    border-radius: 1px;
}

.ac-hero h1 {
    font-family: 'Inter', sans-serif;
    font-size: 44px;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin-bottom: 14px;
    position: relative;
    z-index: 3;
    color: #fff;
    text-transform: uppercase;
}

.ac-hero h1 em {
    font-style: normal;
    color: var(--tp-cyan);
}

.ac-hero .sub {
    font-size: 15px;
    font-weight: 400;
    color: rgba(255,255,255,0.60);
    max-width: 560px;
    margin: 0 auto;
    position: relative;
    z-index: 3;
    line-height: 1.7;
}

/* ─── TRACK SELECTOR ─── */
.ac-track-shell {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px 24px;
}

.ac-track-panel {
    background: #fff;
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-xl);
    padding: 24px 28px;
    box-shadow: var(--tp-shadow-lg);
    transform: translateY(-28px);
    position: relative;
    z-index: 4;
}

.ac-track-panel h2 {
    font-size: 18px;
    font-weight: 700;
    color: var(--tp-ink);
    margin-bottom: 4px;
}

.ac-track-panel .sub-head {
    font-size: 14px;
    color: var(--tp-muted);
    margin-bottom: 16px;
    line-height: 1.6;
}

.ac-track-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
}

.ac-track-card {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    background: var(--tp-surface, #f8fafc);
    padding: 14px;
    cursor: pointer;
    text-align: left;
    transition: all 0.2s var(--tp-ease);
    position: relative;
    overflow: hidden;
}

.ac-track-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: transparent;
    transition: background 0.2s ease;
}

.ac-track-card:hover {
    border-color: rgba(37,99,235,0.3);
    background: #fff;
    transform: translateY(-2px);
    box-shadow: var(--tp-shadow-card-hover);
}

.ac-track-card:hover::before {
    background: var(--tp-blue);
}

.ac-track-card.active {
    border-color: var(--tp-blue);
    background: #fff;
    box-shadow: 0 4px 16px rgba(37,99,235,0.12), 0 0 0 1px rgba(37,99,235,0.15);
}

.ac-track-card.active::before {
    background: linear-gradient(90deg, var(--tp-blue), var(--tp-cyan));
}

.ac-track-card strong {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--tp-ink);
    margin-bottom: 4px;
}

.ac-track-card span {
    display: block;
    font-size: 12px;
    color: var(--tp-muted);
    line-height: 1.5;
}

.ac-track-card small {
    display: block;
    margin-top: 8px;
    font-size: 10px;
    font-weight: 800;
    color: var(--tp-blue);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* ─── MAIN LAYOUT ─── */
.ac-shell {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px 40px;
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 20px;
    align-items: start;
}

.ac-prediction-shell {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px 48px;
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 20px;
    align-items: start;
}

/* ─── PANELS ─── */
.panel {
    background: #fff;
    border: 1px solid rgba(15,23,42,0.06);
    border-radius: var(--tp-r-xl);
    padding: 24px 28px;
    box-shadow: var(--tp-shadow-md);
    transition: box-shadow 0.25s ease;
}

.panel:hover {
    box-shadow: var(--tp-shadow-lg);
}

.panel h2 {
    font-size: 20px;
    font-weight: 800;
    color: var(--tp-ink);
    margin-bottom: 4px;
    letter-spacing: -0.02em;
}

.panel .sub-head {
    font-size: 13px;
    color: var(--tp-muted);
    margin-bottom: 18px;
    line-height: 1.6;
}

/* ─── LESSON LIBRARY ─── */
.learning-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.academy-search { display: grid; gap: 10px; margin-bottom: 16px; }

.academy-search input {
    width: 100%;
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    padding: 12px 16px;
    min-height: 48px;
    font-size: 14px;
    color: var(--tp-ink);
    background: #fff;
    font-family: 'Inter', sans-serif;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.academy-search input::placeholder { color: var(--tp-soft); }

.academy-search input:focus {
    border-color: var(--tp-blue-glow);
    outline: none;
    box-shadow: 0 0 0 3px rgba(96,165,250,0.12);
}

.academy-search-examples { display: flex; flex-wrap: wrap; gap: 6px; }

.academy-search-chip {
    border: 1px solid var(--tp-border);
    border-radius: 999px;
    background: var(--tp-surface, #f8fafc);
    color: var(--tp-muted);
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.15s ease;
}

.academy-search-chip:hover {
    border-color: var(--tp-blue);
    color: var(--tp-blue);
    background: #eff6ff;
}

.learning-paths, .lesson-category-pills { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }

.lesson-path-btn, .lesson-pill {
    border: 1px solid var(--tp-border);
    border-radius: 999px;
    background: var(--tp-surface, #f8fafc);
    color: var(--tp-muted);
    padding: 9px 14px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.15s ease;
}

.lesson-path-btn small, .lesson-pill small {
    display: block;
    font-size: 10px;
    font-weight: 600;
    color: var(--tp-soft);
}

.lesson-path-btn:hover, .lesson-pill:hover {
    border-color: #93c5fd;
    color: var(--tp-blue);
    background: #eff6ff;
}

.lesson-path-btn.active, .lesson-pill.active {
    background: var(--tp-navy, var(--brand-navy));
    border-color: var(--tp-navy, var(--brand-navy));
    color: #fff;
    box-shadow: 0 6px 16px -6px rgba(14,34,64,0.5);
}

.lesson-path-btn.active small, .lesson-pill.active small {
    color: rgba(255,255,255,0.6);
}

.lesson-group { margin-bottom: 16px; }

.lesson-group-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
}

.lesson-group-head h3 {
    font-size: 11px;
    font-weight: 800;
    color: var(--tp-soft);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.lesson-group-count { font-size: 11px; color: var(--tp-soft); font-weight: 700; }

.lesson-card {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    padding: 14px;
    cursor: pointer;
    transition: all 0.2s ease;
    background: #fff;
    text-align: left;
}

.lesson-card:hover {
    border-color: rgba(37,99,235,0.25);
    background: #fafbff;
    transform: translateY(-1px);
    box-shadow: var(--tp-shadow-card-hover);
}

.lesson-card.active {
    border-color: var(--tp-blue);
    background: #f0f6ff;
    box-shadow: 0 0 0 2px rgba(37,99,235,0.1), var(--tp-shadow-md);
}

.lesson-card .lesson-cat {
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
}

.lesson-card h3 {
    font-size: 13px;
    font-weight: 600;
    color: var(--tp-ink);
    line-height: 1.4;
}

/* ─── LESSON DETAIL ─── */
.lesson-detail {
    margin-top: 16px;
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-lg);
    padding: 20px;
    background: var(--tp-surface, #f8fafc);
}

.lesson-detail-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.lesson-detail-cat {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: var(--tp-surface, #f1f5f9);
    color: var(--tp-text);
    border: 1px solid var(--tp-border);
}

.lesson-detail h3 {
    font-size: 18px;
    font-weight: 700;
    color: var(--tp-ink);
    margin-bottom: 8px;
}

.lesson-body {
    font-size: 14px;
    color: var(--tp-text);
    line-height: 1.7;
    margin-bottom: 14px;
}

.lesson-helper-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; }

.lesson-helper {
    border-radius: var(--tp-r-md);
    padding: 12px;
    border: 1px solid var(--tp-border);
    background: #fff;
    font-size: 13px;
    line-height: 1.55;
    color: var(--tp-text);
}

.lesson-helper strong {
    display: block;
    margin-bottom: 4px;
    color: var(--tp-ink);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.lesson-takeaway {
    font-size: 13px;
    color: #b45309;
    background: #fef3c7;
    border: 1px solid #fde68a;
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 10px;
    line-height: 1.55;
}

.lesson-fantasy {
    font-size: 13px;
    color: #15803d;
    background: #dcfce7;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 12px;
    line-height: 1.55;
}

.lesson-gpt {
    padding: 12px;
    border-radius: var(--tp-r-md);
    background: #fff;
    border: 1px solid var(--tp-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.lesson-gpt p { margin: 0; font-size: 13px; color: var(--tp-muted); font-weight: 600; }

.lesson-gpt a {
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    text-decoration: none;
    background: var(--tp-blue);
    border: none;
    border-radius: 999px;
    padding: 9px 16px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    transition: all 0.15s ease;
    box-shadow: 0 4px 14px rgba(37,99,235,0.18);
}

.lesson-gpt a:hover {
    background: var(--tp-blue-hover, #1d4ed8);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(37,99,235,0.25);
}

.lesson-tools { margin-top: 12px; }
.lesson-tools-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }

.lesson-tool-link {
    border: 1px solid var(--tp-border);
    background: #fff;
    color: var(--tp-text);
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.15s ease;
}

.lesson-tool-link:hover {
    border-color: var(--tp-blue);
    color: var(--tp-blue);
    background: #eff6ff;
}

.lesson-reads { margin-top: 12px; }
.lesson-read-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }

.lesson-read-link {
    border: 1px solid rgba(37,99,235,0.2);
    background: #eff6ff;
    color: var(--tp-blue);
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 800;
    text-decoration: none;
}

.lesson-community { margin-top: 12px; }
.lesson-community-list { display: grid; gap: 10px; }

.lesson-community-card {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-lg);
    background: #fff;
    padding: 14px;
}

.lesson-community-kicker {
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tp-blue);
    margin-bottom: 6px;
}

.lesson-community-card h4 {
    font-size: 14px;
    font-weight: 700;
    color: var(--tp-ink);
    margin-bottom: 6px;
}

.lesson-community-card p {
    font-size: 13px;
    color: var(--tp-muted);
    line-height: 1.55;
    margin: 0 0 10px;
}

.lesson-community-meta { font-size: 11px; color: var(--tp-soft); }

.lesson-community-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }

.lesson-community-btn, .lesson-community-actions a {
    border: 1px solid var(--tp-border);
    background: var(--tp-surface, #f8fafc);
    color: var(--tp-text);
    border-radius: 999px;
    padding: 7px 12px;
    font-size: 11px;
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s ease;
}

.lesson-community-actions a {
    color: var(--tp-blue);
    border-color: rgba(37,99,235,0.2);
    background: #eff6ff;
}

.lesson-related { margin-top: 12px; }
.lesson-related-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }

.lesson-related-btn {
    border: 1px solid var(--tp-border);
    background: #fff;
    color: var(--tp-muted);
    border-radius: 999px;
    padding: 7px 12px;
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.15s ease;
}

.lesson-related-btn:hover {
    border-color: #93c5fd;
    color: var(--tp-blue);
}

.lesson-empty {
    padding: 24px;
    border: 1px dashed var(--tp-border);
    border-radius: var(--tp-r-md);
    color: var(--tp-soft);
    background: var(--tp-surface, #f8fafc);
}

/* ─── COMMUNITY TIPS (SUGGESTIONS) ─── */
.roadmap-summary {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 14px;
}

.roadmap-stat {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    background: var(--tp-surface, #f8fafc);
    padding: 14px;
}

.roadmap-stat strong {
    display: block;
    font-size: 22px;
    font-weight: 800;
    line-height: 1;
    color: var(--tp-ink);
    margin-bottom: 4px;
}

.roadmap-stat span {
    font-size: 10px;
    color: var(--tp-soft);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.roadmap-rail {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 16px;
}

.roadmap-card {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-lg);
    background: #fff;
    padding: 14px;
}

.roadmap-card h3 {
    font-size: 13px;
    font-weight: 800;
    color: var(--tp-ink);
    margin-bottom: 6px;
}

.roadmap-card p {
    font-size: 12px;
    color: var(--tp-soft);
    margin: 0 0 10px;
    line-height: 1.55;
}

.roadmap-list { display: grid; gap: 6px; }

.roadmap-item {
    border-radius: 8px;
    padding: 10px;
    background: var(--tp-surface, #f8fafc);
    border: 1px solid var(--tp-border);
}

.roadmap-item strong {
    display: block;
    font-size: 12px;
    color: var(--tp-ink);
    margin-bottom: 3px;
}

.roadmap-item span { font-size: 11px; color: var(--tp-soft); }

.roadmap-action {
    margin-top: 10px;
    width: 100%;
    border: 1px solid var(--tp-border);
    background: #fff;
    color: var(--tp-text);
    border-radius: 999px;
    min-height: 40px;
    padding: 8px 12px;
    font-size: 11px;
    font-weight: 800;
    cursor: pointer;
    transition: all 0.15s ease;
}

.roadmap-action:hover {
    border-color: var(--tp-blue);
    color: var(--tp-blue);
    background: #eff6ff;
}

/* ─── AUTH NOTES ─── */
.auth-note {
    border-radius: var(--tp-r-md);
    padding: 12px 14px;
    font-size: 13px;
    margin-bottom: 14px;
    line-height: 1.55;
}

.auth-ok {
    background: #dcfce7;
    border: 1px solid #bbf7d0;
    color: #15803d;
}

.auth-login {
    background: #fef3c7;
    border: 1px solid #fde68a;
    color: #b45309;
}

.auth-note a {
    font-weight: 700;
    text-decoration: none;
    color: inherit;
}

.auth-note a:hover { text-decoration: underline; }

/* ─── FORMS ─── */
.sg-form { display: grid; gap: 8px; margin-bottom: 16px; }

.sg-form input, .sg-form select, .sg-form textarea {
    width: 100%;
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    padding: 12px 14px;
    min-height: 44px;
    font-size: 14px;
    color: var(--tp-ink);
    background: #fff;
    font-family: 'Inter', sans-serif;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.sg-form input::placeholder, .sg-form textarea::placeholder { color: var(--tp-soft); }

.sg-form input:focus, .sg-form select:focus, .sg-form textarea:focus {
    border-color: var(--tp-blue-glow);
    box-shadow: 0 0 0 3px rgba(96,165,250,0.12);
}

.sg-form select { color: var(--tp-muted); }
.sg-form select option { background: #fff; color: var(--tp-ink); }

.sg-form button {
    border: none;
    border-radius: var(--tp-r-md);
    background: var(--tp-navy, var(--brand-navy));
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    padding: 12px;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 4px 12px rgba(14,34,64,0.2);
    font-family: 'Inter', sans-serif;
}

.sg-form button:hover {
    background: var(--tp-navy-mid, #162d50);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(14,34,64,0.3);
}

#submit-flash, #prediction-flash {
    display: none;
    background: #dcfce7;
    color: #15803d;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 10px;
    border: 1px solid #bbf7d0;
}

/* ─── TOOLBAR / FILTERS ─── */
.sg-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    gap: 8px;
    flex-wrap: wrap;
}

.sg-toolbar-group { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.sg-toolbar select, .sg-toolbar input {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    padding: 9px 14px;
    min-height: 44px;
    font-size: 13px;
    color: var(--tp-text);
    font-family: 'Inter', sans-serif;
    background: #fff;
    outline: none;
    transition: border-color 0.15s ease;
}

.sg-toolbar select option { background: #fff; color: var(--tp-ink); }
.sg-toolbar input::placeholder { color: var(--tp-soft); }

.sg-toolbar select:focus, .sg-toolbar input:focus {
    border-color: var(--tp-blue-glow);
}

.sg-toolbar input { min-width: 140px; flex: 1; }

.status-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 14px; }

.status-tab {
    border: 1px solid var(--tp-border);
    border-radius: 999px;
    background: var(--tp-surface, #f8fafc);
    color: var(--tp-muted);
    padding: 7px 12px;
    font-size: 11px;
    font-weight: 800;
    cursor: pointer;
    transition: all 0.15s ease;
}

.status-tab:hover {
    border-color: #93c5fd;
    color: var(--tp-blue);
}

.status-tab.active {
    background: var(--tp-navy, var(--brand-navy));
    border-color: var(--tp-navy, var(--brand-navy));
    color: #fff;
    box-shadow: 0 4px 12px -4px rgba(14,34,64,0.5);
}

.reviewer-panel {
    display: none;
    border: 1px solid rgba(37,99,235,0.2);
    background: #eff6ff;
    border-radius: var(--tp-r-md);
    padding: 14px;
    margin-bottom: 14px;
}

.reviewer-panel strong { color: var(--tp-blue); }
.reviewer-panel p { margin: 0 0 10px; font-size: 13px; color: var(--tp-text); }

.section-label {
    font-size: 11px;
    font-weight: 800;
    color: var(--tp-soft);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 16px 0 8px;
}

/* ─── SUGGESTION CARDS ─── */
.sg-card {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-lg);
    padding: 16px;
    margin-bottom: 10px;
    background: #fff;
    transition: all 0.2s ease;
}

.sg-card:hover {
    box-shadow: var(--tp-shadow-card-hover);
    transform: translateY(-1px);
    border-color: rgba(37,99,235,0.15);
}

.sg-card.is-focused {
    border-color: var(--tp-blue);
    box-shadow: 0 0 0 3px rgba(37,99,235,0.08), var(--tp-shadow-md);
}

.sg-card.is-hidden, .sg-card.is-rejected {
    background: var(--tp-surface, #f8fafc);
    border-style: dashed;
    opacity: 0.6;
}

.medal-gold { border-color: #eab308 !important; background: #fefce8 !important; }
.medal-silver { border-color: var(--brand-text-soft) !important; }
.medal-bronze { border-color: #d97706 !important; background: #fffbeb !important; }

.sg-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 6px;
}

.sg-title-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

.sg-title-row h4 {
    font-size: 15px;
    font-weight: 700;
    color: var(--tp-ink);
    margin: 0;
    line-height: 1.3;
}

.medal { font-size: 18px; }

.sg-rank {
    font-size: 11px;
    font-weight: 800;
    color: var(--tp-blue);
    background: #eff6ff;
    padding: 2px 6px;
    border-radius: 4px;
}

.sg-status {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.status-open { background: var(--tp-surface, #f1f5f9); color: var(--tp-muted); }
.status-reviewing { background: #fef3c7; color: #b45309; }
.status-planned { background: #eff6ff; color: var(--tp-blue); }
.status-shipped { background: #dcfce7; color: #15803d; }
.status-hidden { background: var(--tp-surface, #f1f5f9); color: var(--tp-soft); }
.status-rejected { background: #fee2e2; color: #b91c1c; }

.sg-meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 4px;
    font-size: 11px;
    color: var(--tp-soft);
}

.sg-id {
    font-weight: 700;
    color: var(--tp-blue);
    background: #eff6ff;
    padding: 1px 6px;
    border-radius: 4px;
    font-family: var(--font-mono);
    font-size: 10px;
}

.sg-cat {
    background: var(--tp-surface, #f1f5f9);
    padding: 1px 6px;
    border-radius: 4px;
    font-weight: 600;
    color: var(--tp-muted);
}

.sg-body {
    font-size: 13px;
    color: var(--tp-text);
    line-height: 1.55;
    margin-bottom: 10px;
}

.sg-progress {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}

.sg-step { display: flex; align-items: center; gap: 6px; min-width: 0; }

.sg-step-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--tp-soft);
    flex: 0 0 auto;
}

.sg-step-label {
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tp-soft);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sg-step.active .sg-step-dot {
    background: var(--tp-blue);
    box-shadow: 0 0 0 3px rgba(37,99,235,0.12);
}

.sg-step.active .sg-step-label { color: var(--tp-blue); }

.sg-step.complete .sg-step-dot { background: #22c55e; }
.sg-step.complete .sg-step-label { color: #15803d; }

.sg-footer { display: flex; justify-content: space-between; align-items: center; }

.sg-author { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--tp-soft); }

.sg-avatar {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--tp-navy, #0e2240), var(--tp-blue));
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.vote-btn {
    border: 1px solid var(--tp-border);
    background: #fff;
    color: var(--tp-muted);
    border-radius: 999px;
    padding: 8px 14px;
    min-height: 44px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    font-family: 'Inter', sans-serif;
}

.vote-btn:hover:not(:disabled) {
    border-color: var(--tp-blue);
    color: var(--tp-blue);
    background: #eff6ff;
}

.vote-btn.voted {
    border-color: var(--tp-blue);
    color: var(--tp-blue);
    background: #eff6ff;
}

.vote-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.sg-note {
    margin-top: 8px;
    font-size: 12px;
    color: var(--tp-soft);
    background: var(--tp-surface, #f8fafc);
    border: 1px solid var(--tp-border);
    border-radius: 8px;
    padding: 8px 10px;
}

.sg-academy-link {
    margin-top: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 12px;
    color: var(--tp-text);
    background: #eff6ff;
    border: 1px solid rgba(37,99,235,0.15);
    border-radius: var(--tp-r-md);
    padding: 10px 12px;
}

.sg-academy-link strong { color: var(--tp-blue); }

.sg-academy-btn {
    border: 1px solid rgba(37,99,235,0.2);
    background: #fff;
    color: var(--tp-blue);
    border-radius: 999px;
    padding: 7px 12px;
    font-size: 11px;
    font-weight: 800;
    cursor: pointer;
}

.sg-moderation {
    display: grid;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--tp-border);
}

.sg-moderation-row { display: flex; gap: 8px; flex-wrap: wrap; }

.sg-moderation input, .sg-moderation select {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    padding: 10px 14px;
    min-height: 44px;
    font-size: 13px;
    color: var(--tp-text);
    background: #fff;
    font-family: 'Inter', sans-serif;
    outline: none;
}

.sg-moderation input { flex: 1 1 280px; min-width: 220px; }
.sg-moderation input::placeholder { color: var(--tp-soft); }
.sg-moderation select option { background: #fff; color: var(--tp-ink); }

.mod-btn {
    border: none;
    border-radius: var(--tp-r-md);
    background: var(--tp-navy, var(--brand-navy));
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    padding: 10px 16px;
    min-height: 44px;
    cursor: pointer;
    transition: background 0.15s ease;
    font-family: 'Inter', sans-serif;
}

.mod-btn:hover { background: var(--tp-navy-mid, #162d50); }

.sg-empty { padding: 24px; color: var(--tp-soft); text-align: center; }

/* ─── PREDICTIONS ─── */
.prediction-card {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-lg);
    background: #fff;
    padding: 16px;
    margin-bottom: 10px;
}

.prediction-card.is-resolved { background: var(--tp-surface, #f8fafc); }
.prediction-card.is-voided { background: var(--tp-surface, #f8fafc); border-style: dashed; opacity: 0.6; }

.prediction-top {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: flex-start;
    margin-bottom: 8px;
}

.prediction-top h4 {
    font-size: 15px;
    font-weight: 800;
    color: var(--tp-ink);
    margin: 0;
}

.prediction-meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 6px;
    font-size: 11px;
    color: var(--tp-soft);
}

.prediction-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.prediction-status-open { background: var(--tp-surface, #f1f5f9); color: var(--tp-muted); }
.prediction-status-resolved { background: #dcfce7; color: #15803d; }
.prediction-status-voided { background: var(--tp-surface, #f1f5f9); color: var(--tp-soft); }
.prediction-outcome-hit { background: #dcfce7; color: #15803d; }
.prediction-outcome-partial { background: #fef3c7; color: #b45309; }
.prediction-outcome-miss { background: #fee2e2; color: #b91c1c; }
.prediction-outcome-void { background: var(--tp-surface, #f1f5f9); color: var(--tp-soft); }
.prediction-confidence { background: #eff6ff; color: var(--tp-blue); }

.prediction-body {
    font-size: 13px;
    color: var(--tp-text);
    line-height: 1.55;
    margin-bottom: 10px;
}

.prediction-resolution {
    margin-top: 10px;
    font-size: 12px;
    color: var(--tp-muted);
    background: var(--tp-surface, #f8fafc);
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    padding: 10px 12px;
}

.prediction-moderation {
    display: grid;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--tp-border);
}

.prediction-moderation-row { display: flex; gap: 8px; flex-wrap: wrap; }

.prediction-moderation textarea, .prediction-moderation select {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-md);
    padding: 10px 14px;
    min-height: 44px;
    font-size: 13px;
    color: var(--tp-text);
    background: #fff;
    font-family: 'Inter', sans-serif;
    outline: none;
}

.prediction-moderation textarea { width: 100%; min-height: 84px; resize: vertical; }
.prediction-moderation select option { background: #fff; color: var(--tp-ink); }

/* ─── LEADERBOARD ─── */
.leaderboard-list { display: grid; gap: 8px; }

.leaderboard-item {
    border: 1px solid var(--tp-border);
    border-radius: var(--tp-r-lg);
    background: #fff;
    padding: 14px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.leaderboard-rank {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--tp-surface, #f1f5f9);
    color: var(--tp-muted);
    font-size: 13px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.leaderboard-rank.rank-1 { background: linear-gradient(135deg, #ca8a04, #eab308); color: #fff; }
.leaderboard-rank.rank-2 { background: linear-gradient(135deg, #475569, #64748b); color: #fff; }
.leaderboard-rank.rank-3 { background: linear-gradient(135deg, #92400e, #b45309); color: #fff; }

.leaderboard-main { min-width: 0; flex: 1; }

.leaderboard-main strong {
    display: block;
    font-size: 14px;
    color: var(--tp-ink);
    margin-bottom: 4px;
}

.leaderboard-tier {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: #eff6ff;
    color: var(--tp-blue);
    margin-bottom: 8px;
}

.leaderboard-stats {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 11px;
    color: var(--tp-soft);
}

.leaderboard-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 14px;
}

.leaderboard-empty {
    padding: 24px;
    color: var(--tp-soft);
    text-align: center;
    border: 1px dashed var(--tp-border);
    border-radius: var(--tp-r-lg);
    background: var(--tp-surface, #f8fafc);
}

/* ─── RESPONSIVE ─── */
@media (max-width: 1200px) {
    .ac-shell, .ac-prediction-shell { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .ac-hero { padding: 36px 16px 56px; }
    .ac-hero h1 { font-size: 28px; }
    .ac-hero-kicker { font-size: 10px; }
    .ac-track-shell { padding: 0 12px 12px; }
    .ac-track-grid { grid-template-columns: 1fr 1fr; }
    .ac-shell, .ac-prediction-shell { padding: 8px 12px 36px; gap: 14px; }
    .learning-grid { grid-template-columns: 1fr; }
    .lesson-helper-grid { grid-template-columns: 1fr; }
    .roadmap-summary, .roadmap-rail, .leaderboard-summary { grid-template-columns: 1fr 1fr; }

    .lesson-card { padding: 14px; min-height: 44px; }
    .lesson-card h3 { font-size: 14px; }

    .sg-form input, .sg-form select, .sg-form textarea { font-size: 16px; padding: 14px 16px; }
    .sg-form button { padding: 14px 20px; min-height: 48px; font-size: 15px; }

    .sg-toolbar { flex-direction: column; align-items: stretch; }
    .sg-toolbar-group { width: 100%; }
    .sg-toolbar input { min-width: 100%; width: 100%; }
    .sg-toolbar select { width: 100%; }
    .status-tabs { flex-direction: column; }
    .status-tab { width: 100%; text-align: left; }
    .academy-search-examples { flex-direction: column; }
    .academy-search-chip { width: 100%; text-align: left; }
    .learning-paths, .lesson-category-pills { flex-direction: column; }
    .lesson-path-btn, .lesson-pill { width: 100%; text-align: left; }
    .vote-btn { padding: 12px 18px; font-size: 13px; }
    .sg-progress { grid-template-columns: 1fr 1fr; }
    .sg-moderation input, .sg-moderation select { font-size: 16px; }
    .sg-moderation-row { flex-direction: column; }
    .sg-moderation input { flex: none; width: 100%; min-width: 100%; }
    .mod-btn { width: 100%; text-align: center; justify-content: center; display: flex; align-items: center; }
    .prediction-moderation-row { flex-direction: column; }
    .prediction-moderation textarea, .prediction-moderation select { font-size: 16px; }
    .lesson-gpt a { min-height: 44px; display: inline-flex; align-items: center; padding: 10px 14px; }
    .panel { padding: 16px; }
    .ac-track-panel { padding: 16px; }
}

@media (max-width: 480px) {
    .ac-hero h1 { font-size: 24px; }
    .ac-hero .sub { font-size: 14px; }
    .ac-track-grid { grid-template-columns: 1fr; }
    .roadmap-summary, .roadmap-rail, .leaderboard-summary { grid-template-columns: 1fr; }
    .panel { padding: 14px; border-radius: 16px; }
    .lesson-detail { padding: 14px; }
    .sg-card { padding: 14px; }
}

/* ─── REDUCED MOTION ─── */
@media (prefers-reduced-motion: reduce) {
    .ac-track-card:hover, .sg-card:hover, .lesson-card:hover, .vote-btn:hover,
    .sg-form button:hover, .roadmap-action:hover {
        transform: none;
    }
    .tp-hero-orb { animation: none; }
    .tp-hero-anim { animation: none; opacity: 1; transform: none; }
}
