/* ============================================================
   LN MODE — FULL NEON DESIGN SYSTEM
   Aggressive 45° helmet cuts
   ============================================================ */

/* ============= */
/* TOKENS / CORE */
/* ============= */

:root {
    --ln-bg: #050505;
    --ln-bg-panel: #0a0a0a;
    --ln-bg-elevated: #111;

    --ln-neon: #DFFE2E;
    --ln-neon-soft: #D8F26C;
    --ln-neon-glow: rgba(223, 255, 0, 0.35);
    --ln-success: #2ecc71;

    --ln-text: #f7f7f7;
    --ln-text-dim: #cfcfcf;
    --ln-text-placeholder: #999999;

    --ln-easy: #7bff85;
    --ln-medium: #ffe66d;
    --ln-hard: #ff7b5e;

    --ln-border: rgba(255,255,255,0.08);
    --ln-border-strong: rgba(255,255,255,0.14);

    --ln-radius: 14px;
    --ln-space-1: 6px;
    --ln-space-2: 10px;
    --ln-space-3: 14px;
    --ln-space-4: 20px;

    --ln-speed-trans: cubic-bezier(.25,.7,.35,1);
}


/* ===================== */
/* GLOBAL RESET / BODY   */
/* ===================== */

body.ln-body {
    background: var(--ln-bg);
    margin: 0;
    padding: 0;
    font-family: "Space Grotesk", sans-serif;
    color: var(--ln-text);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;

    /* Stage lighting gradient */
    background:
        radial-gradient(circle at 80% 0%, rgba(223,255,0,0.06), transparent 55%),
        radial-gradient(circle at 20% 100%, rgba(223,255,0,0.05), transparent 50%),
        var(--ln-bg);
}


/* ======================== */
/* 45° CUT UTILITY CLASSES  */
/* ======================== */

.ln-cut-45 {
    clip-path: polygon(0 0, calc(100% - 22px) 0, 100% 22px, 100% 100%, 22px 100%, 0 calc(100% - 22px));
}

.ln-cut-frame-45 {
    position: relative;
    clip-path: polygon(0 0, calc(100% - 22px) 0, 100% 22px, 100% 100%, 22px 100%, 0 calc(100% - 22px));
}

.ln-cut-frame-45::before {
    content: "";
    position: absolute;
    inset: 0;
    border: 1.6px solid var(--ln-border);
    pointer-events: none;
    border-radius: 0;
    clip-path: inherit;
}


/* ======================== */
/* HEADER                   */
/* ======================== */

.ln-header {
    background: var(--ln-bg-elevated);
    padding: var(--ln-space-3) var(--ln-space-4);
    margin-bottom: var(--ln-space-3);
}

.ln-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ln-app-title {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.5px;
    color: var(--ln-neon);
}


/* LANG SWITCH */
.ln-lang-switch {
    display: flex;
    gap: 6px;
}

.ln-lang-btn {
    background: transparent;
    border: 1px solid var(--ln-border-strong);
    color: var(--ln-text);
    padding: 6px 12px;
    font-size: 13px;
    cursor: pointer;
    border-radius: var(--ln-radius);
    transition: background 150ms var(--ln-speed-trans), border 150ms;
}
.ln-lang-btn:hover {
    background: rgba(223,255,0,0.12);
    border-color: var(--ln-neon);
}

/* HEADER RIGHT AREA (NAV + LANG) */
.ln-header-right {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 16px;
}

/* TOP NAV LINKS */
.ln-main-nav {
    display: flex;
    gap: 12px;
}

.ln-nav-link {
    font-size: 12px;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--ln-muted);
    padding: 4px 8px;
    border-radius: 999px;
    border: 1px solid transparent;
}

.ln-nav-link:hover {
    color: #fff;
    border-color: var(--ln-border-strong);
}

/* LANG SWITCH DROPDOWN */
.ln-lang-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.ln-lang-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--ln-radius);
    border: 1px solid var(--ln-border-strong);
    background: transparent;
    color: var(--ln-text);
    cursor: pointer;
    font-size: 13px;
}

.ln-lang-caret {
    font-size: 10px;
    opacity: 0.7;
}

.ln-lang-menu {
    position: absolute;
    right: 0;
    top: 100%;
    margin-top: 4px;
    background: var(--ln-bg-elevated, #050608);
    border-radius: var(--ln-radius);
    border: 1px solid var(--ln-border-strong);
    padding: 4px;
    display: none;
    flex-direction: column;
    min-width: 80px;
    z-index: 400;
}

.ln-lang-switch.open .ln-lang-menu {
    display: flex;
}

.ln-lang-menu .ln-lang-btn {
    width: 100%;
    text-align: left;
    padding: 6px 10px;
}

/* ======================== */
/* MAIN ROOT / VIEWS        */
/* ======================== */

.ln-view {
    display: none;
    padding: var(--ln-space-3);
}
.ln-view.active {
    display: block;
}

.ln-section-title {
    font-size: 28px;
    font-weight: 700;
    margin: 0 0 12px;
    letter-spacing: 0.6px;
    color: #fff;
    text-shadow: 0 0 10px rgba(223,255,0,0.25);
}

@media (max-width: 768px) {
    .ln-section-title {
        font-size: 22px;
        margin-bottom: 10px;
    }
}

@media (max-width: 520px) {
    .ln-section-title {
        font-size: 20px;
        margin-bottom: 8px;
    }
}


/* ======================== */
/* GRID VIEW                */
/* ======================== */

.ln-grid-header {
    background: var(--ln-bg-panel);
    padding: var(--ln-space-3);
    margin-bottom: var(--ln-space-3);
}

.ln-closed-banner {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin: 8px 0 12px;
    padding: 11px 18px;
    border: 1px solid #cbe300;
    border-radius: 999px;
    background: rgba(203, 227, 0, 0.08);
    color: #cbe300;
    font-size: 0.9rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    line-height: 1.2;
    font-weight: 700;
    text-align: center;
    min-width: 0;
}

.ln-stats {
    margin-top: var(--ln-space-2);
    display: flex;
    gap: 18px;
    align-items: center;
    justify-content: space-between;
    font-size: 13px;
    color: var(--ln-text-dim);
    flex-wrap: wrap;
}
.ln-stats-left {
    display: flex;
    gap: 18px;
    align-items: center;
    flex-wrap: wrap;
}
.ln-stats-left-banner {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
}
.ln-stats-actions {
    display: flex;
    gap: 10px;
    margin-left: auto;
    align-items: center;
}
.ln-stats-actions > div {
    display: flex;
    gap: 10px;
    align-items: center;
}
.ln-closed-banner {
    margin-right: 10px;
}


/* GRID */
.ln-grid-container {
    background: var(--ln-bg-panel);
    padding: var(--ln-space-3);
}

.ln-grid-3x3 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--ln-space-3);
}

.ln-grid-cell {
    background: #111;
    border: 1px solid var(--ln-border);
    min-height: 96px;
    min-width: 0;
    padding: var(--ln-space-3);
    text-align: left;
    cursor: pointer;
    position: relative;
    color: var(--ln-text); /* ⬅️ force base text color */
    transition:
        transform 140ms var(--ln-speed-trans),
        border 150ms ease-out;
}

.ln-grid-cell:hover {
    border-color: var(--ln-neon);
    transform: translateY(-2px);
}

.ln-grid-cell.pop {
    animation: ln-pop 0.22s var(--ln-speed-trans);
}

@keyframes ln-pop {
    0%   { transform: scale(0.85); }
    50%  { transform: scale(1.04); }
    100% { transform: scale(1.00); }
}


/* CELL CONTENT 
.ln-grid-label {
    font-size: 12px;
    color: var(--ln-neon);
    margin-bottom: 4px;
}*/

.ln-grid-label {
    padding: 2px 8px;
    font-size: 12px;
    background: rgba(223,255,0,0.08);
    color: var(--ln-neon);
    border: 1px solid rgba(223,255,0,0.2);
}

.ln-grid-text {
    font-size: 18px;
    line-height: 1.45;
    font-weight: 500;
    letter-spacing: 0.2px;
    color:#fff;
    margin-bottom: 6px;
}

.ln-grid-points {
    font-size: 12px;
    margin-top: 6px;
    opacity: 0.8;
    color: var(--ln-text-dim);
}
/* Make grid cell content stack like picker cards */
.ln-grid-cell {
    position: relative;
    display: flex;
}
.ln-grid-cell .ln-grid-cell-content {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.ln-grid-cell.filled {
    border-color: var(--ln-neon);
    box-shadow: 0 0 14px var(--ln-neon-glow);
    background: var(--ln-neon-soft);
}

.ln-grid-cell.true-resolved {
    border-color: var(--ln-success, #2ecc71);
    box-shadow: 0 0 14px color-mix(in srgb, var(--ln-success, #2ecc71) 60%, transparent);
    background: var(--ln-success, #2ecc71);
}

.ln-grid-cell.true-resolved .ln-grid-text,
.ln-grid-cell.true-resolved .ln-grid-label,
.ln-grid-cell.true-resolved .ln-grid-points,
.ln-grid-cell.true-resolved .ln-category-chip {
    color: #041007;
}

.ln-grid-cell.true-resolved .ln-category-chip {
    background: color-mix(in srgb, var(--ln-success, #2ecc71) 15%, transparent);
    border-color: color-mix(in srgb, var(--ln-success, #2ecc71) 35%, transparent);
}

.ln-grid-cell.filled .ln-grid-label {
    padding: 2px 8px;
    font-size: 12px;
    background: rgba(0, 0, 0, 0.08);
    color: var(--ln-bg);
    border: 1px solid rgba(0, 0, 0, 0.2);
}

.ln-grid-cell.filled .ln-grid-text {
    color: var(--ln-bg);   /* or any color you want */
    margin-bottom: 4px;
}

/* View-only hover/shadow suppression */
.ln-app-root.view-only .ln-grid-cell,
.ln-app-root.view-only .ln-grid-cell:hover {
    box-shadow: none;
    transform: none;
}

/* View-only hover suppression */
.ln-app-root.view-only .ln-grid-cell:hover {
    border-color: var(--ln-border);
    transform: none;
}

/* Picker locked (submissions closed) */
.picker-locked .ln-pred-card {
    cursor: default;
}
.picker-locked .ln-pred-card.selected:not(.true-resolved) {
    background: #000;
    border: 1px solid var(--ln-neon);
    box-shadow: none;
    color: var(--ln-neon);
}
.picker-locked .ln-pred-card.selected:not(.true-resolved) .ln-category-chip {
    background: rgba(223,255,0,0.12);
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}
.picker-locked .ln-pred-card.selected:not(.true-resolved) .ln-pred-text,
.picker-locked .ln-pred-card.selected:not(.true-resolved) .ln-points {
    color: var(--ln-neon);
}
.picker-locked .ln-pred-card.true-resolved {
    background: var(--ln-success, #2ecc71);
    border-color: var(--ln-neon);
    box-shadow: none;
    color: #041007;
}
.picker-locked .ln-pred-card .ln-checkmark-badge {
    display: none;
}
.picker-locked .ln-pred-card.true-resolved .ln-pred-text,
.picker-locked .ln-pred-card.true-resolved .ln-points {
    color: #041007;
}
.picker-locked .ln-pred-card.true-resolved .ln-category-chip {
    background: rgba(0,0,0,0.08);
    border-color: color-mix(in srgb, var(--ln-success, #2ecc71) 40%, transparent);
    color: #041007;
}
.picker-locked .ln-pred-card.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    opacity: 1;
    transform: scale(1);
    border: 2px solid var(--ln-success, #2ecc71);
    display: inline-block;
}
.picker-locked .ln-pred-card:hover {
    transform: none;
    box-shadow: none;
}
/* View-only: submissions open (read-only) */
.ln-app-root.view-only-open .ln-grid-cell.filled {
    background: #000;
    border-color: var(--ln-neon);
    box-shadow: none;
}
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-cell-content,
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-cell-content * {
    color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-points {
    color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-text,
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-points,
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-label {
    color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-category-chip {
    background: rgba(223,255,0,0.12);
    color: var(--ln-neon);
    border-color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.true-resolved {
    background: #000;
    border-color: var(--ln-neon);
    box-shadow: none;
}
.ln-app-root.view-only-open .ln-grid-cell.true-resolved .ln-checkmark-badge {
    background: #000;
    color: var(--ln-neon);
    border: 1px solid var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.true-resolved .ln-grid-cell-content,
.ln-app-root.view-only-open .ln-grid-cell.true-resolved .ln-grid-cell-content * {
    color: var(--ln-neon);
}

/* View-only: submissions closed */
.ln-app-root.view-only-closed .ln-grid-cell.filled {
    background: #000;
    border-color: var(--ln-neon);
    box-shadow: none;
}
.ln-app-root.view-only-closed .ln-grid-cell.filled:not(.true-resolved) .ln-grid-cell-content,
.ln-app-root.view-only-closed .ln-grid-cell.filled:not(.true-resolved) .ln-grid-cell-content * {
    color: var(--ln-neon);
}
.ln-app-root.view-only-closed .ln-grid-cell.filled .ln-grid-text,
.ln-app-root.view-only-closed .ln-grid-cell.filled .ln-grid-points,
.ln-app-root.view-only-closed .ln-grid-cell.filled .ln-grid-label {
    color: var(--ln-neon);
}
.ln-app-root.view-only-closed .ln-grid-cell.filled .ln-category-chip {
    background: rgba(223,255,0,0.12);
    color: var(--ln-neon);
    border-color: var(--ln-neon);
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved {
    background: var(--ln-success, #2ecc71);
    border-color: var(--ln-success, #2ecc71);
    box-shadow: none;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-cell-content,
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-cell-content * {
    color: #041007;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-text,
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-points,
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-label {
    color: #041007;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-category-chip {
    background: rgba(0,0,0,0.08);
    color: #041007;
    border-color: color-mix(in srgb, var(--ln-success, #2ecc71) 40%, transparent);
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    border: 2px solid var(--ln-success, #2ecc71);
}

/* Hide submit area in view-only states */
.ln-app-root.view-only .ln-submit-area {
    display: none;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    border: 2px solid var(--ln-success, #2ecc71);
}
.ln-app-root.view-only .ln-grid-cell.true-resolved {
    border-color: var(--ln-success, #2ecc71);
    background: var(--ln-success, #2ecc71);
}
.ln-app-root.view-only .ln-grid-cell.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    border: 2px solid var(--ln-success, #2ecc71);
}


/* same chip styling when a grid cell is filled */
.ln-grid-cell.filled .ln-category-chip {
    background: rgba(0, 0, 0, 0.08);
    color: var(--ln-bg);
    border: 1px solid rgba(0, 0, 0, 0.2);
}
.ln-app-root.view-only .ln-grid-cell.filled {
    background: #000;
    border-color: var(--ln-neon);
    box-shadow: none;
}
.ln-app-root.view-only .ln-grid-cell.filled .ln-grid-text,
.ln-app-root.view-only .ln-grid-cell.filled .ln-grid-points,
.ln-app-root.view-only .ln-grid-cell.filled .ln-grid-label {
    color: #fff;
}
.ln-app-root.view-only .ln-grid-cell.filled .ln-category-chip {
    background: rgba(223,255,0,0.12);
    color: #fff;
    border-color: var(--ln-neon);
}

/* ======================== */
/* SUBMIT AREA              */
/* ======================== */
.ln-submit-area {
    background: var(--ln-bg-panel);
    padding: var(--ln-space-3);
    margin-top: var(--ln-space-3);
    display: flex;
    flex-direction: column;
    gap: var(--ln-space-3);
}

.ln-input {
    padding: 12px 14px;
    border-radius: var(--ln-radius);
    border: 1px solid #fff;
    background: var(--ln-bg-elevated);
    color: var(--ln-text);
    font-size: 14px;
    font-style: normal;
}
.ln-input::placeholder {
    font-style: italic;
    color: var(--ln-text-placeholder);
}
.ln-input-label {
    font-size: 13px;
    color: var(--ln-text-dim);
    text-align: left;
    width: 100%;
}

.ln-submit-btn {
    padding: 14px 18px;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.2px;
    text-transform: uppercase;
    color: #000;
    background: linear-gradient(135deg, var(--ln-neon), var(--ln-neon-soft));
    border: none;
    cursor: pointer;
    transition: transform 120ms var(--ln-speed-trans), box-shadow 160ms;
}
.ln-submit-btn:disabled {
    cursor: not-allowed;
    background: #3a3f51;
    color: #777;
    box-shadow: none;
    transform: none;
    border: 1px solid #555;
}

.ln-submit-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 0 20px var(--ln-neon-glow);
}

.ln-submission-status {
    margin-top: var(--ln-space-3);
    padding: var(--ln-space-3);
    background: var(--ln-bg-panel);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--ln-space-3);
    flex-wrap: wrap;
}
.ln-submission-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--ln-text-dim);
}
.ln-submission-left {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: flex-start;
}
.ln-share-actions {
    display: flex;
    gap: var(--ln-space-2);
    flex-wrap: wrap;
    align-items: center;
}
.ln-share-actions button {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-width: 0;
    white-space: normal;
    text-align: center;
}
.ln-status-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--ln-neon);
    box-shadow: 0 0 8px var(--ln-neon-glow);
    display: inline-block;
}
.ln-edit-btn {
    background: transparent;
    border: 1px solid var(--ln-border);
    color: var(--ln-text);
    padding: 10px 14px;
    cursor: pointer;
    font-weight: 600;
    transition: border 150ms, color 150ms, transform 120ms;
}
.ln-edit-btn:hover {
    border-color: var(--ln-neon);
    color: var(--ln-neon);
    transform: translateY(-1px);
}

.ln-btn-compact {
    padding: 10px 14px;
    font-size: 13px;
    min-width: auto;
}



/* ======================== */
/* PICKER VIEW              */
/* ======================== */

.ln-picker-header {
    background: var(--ln-bg-panel);
    padding: var(--ln-space-3);
    margin-bottom: var(--ln-space-3);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--ln-space-3);
}

.ln-picker-header-left {
    display: flex;
    flex-direction: column;
    gap: var(--ln-space-2);
}

.ln-back-btn {
    background: transparent;
    border: 1px solid var(--ln-border);
    color: var(--ln-text);
    padding: 8px 12px;
    cursor: pointer;
    transition: border 150ms, color 150ms;
    margin-bottom: var(--ln-space-2);
}
.ln-back-btn:hover {
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}

.ln-picker-stats {
    margin-top: 0;
    flex-shrink: 0;
}


/* DIFFICULTY TITLES */
.ln-difficulty-title {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 var(--ln-space-2) 0;
    font-size: 16px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ln-difficulty-title .dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}
.ln-difficulty-title.easy .dot { background: var(--ln-easy); }
.ln-difficulty-title.medium .dot { background: var(--ln-medium); }
.ln-difficulty-title.hard .dot { background: var(--ln-hard); }


/* PREDICTION CARDS */
.ln-pred-section {
    padding: var(--ln-space-3);
    border-radius: 14px;
    border: 1px solid var(--ln-border);
    margin-bottom: var(--ln-space-3);
}
.ln-pred-section.easy {
    background: rgba(123, 255, 133, 0.08);
    border-color: rgba(123, 255, 133, 0.25);
}
.ln-pred-section.medium {
    background: rgba(255, 230, 109, 0.08);
    border-color: rgba(255, 230, 109, 0.25);
}
.ln-pred-section.hard {
    background: rgba(255, 123, 94, 0.08);
    border-color: rgba(255, 123, 94, 0.25);
}
.ln-pred-section#predictions-easy {
    background: rgba(123, 255, 133, 0.08);
    border-color: rgba(123, 255, 133, 0.25);
}
.ln-pred-section#predictions-medium {
    background: rgba(255, 230, 109, 0.08);
    border-color: rgba(255, 230, 109, 0.25);
}
.ln-pred-section#predictions-hard {
    background: rgba(255, 123, 94, 0.08);
    border-color: rgba(255, 123, 94, 0.25);
}
.ln-pred-list {
    display: flex;
    flex-direction: column;
    gap: var(--ln-space-3);
    margin-bottom: 0;
    padding: 0;
    background: transparent;
}

.ln-picker-sticky {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(9,9,9,0.94);
    backdrop-filter: blur(6px);
    padding: 10px 14px;
    border-bottom: 1px solid rgba(203,227,0,0.15);
    margin-bottom: var(--ln-space-2);
}
.ln-picker-row1,
.ln-picker-row2 {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.ln-picker-left {
    display: flex;
    align-items: center;
    gap: 16px;
    width: 100%;
    justify-content: space-between;
}
.ln-picker-progress-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
}
.ln-picker-row2 {
    justify-content: flex-start;
    flex-wrap: nowrap;
}
.ln-picker-select {
    background: #0a0a0a;
    border: 1px solid rgba(203,227,0,0.4);
    color: #fff;
    border-radius: 10px;
    padding: 8px 8px;
    font-size: 14px;
    min-width: 0;
    flex: 1 1 40%;
    max-width: 45%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23cbe300' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 10px 6px;
    padding-right: 28px;
}
.ln-picker-select:focus {
    outline: 1px solid var(--ln-neon);
    box-shadow: 0 0 0 2px rgba(203,227,0,0.15);
}
.ln-progress-tracker {
    display: grid;
    grid-template-columns: repeat(9, 1fr);
    gap: 6px;
    width: 200px;
}
.ln-progress-slot {
    height: 18px;
    border: 1px solid #cbe300;
    border-radius: 4px;
    background: transparent;
    transition: background 120ms ease, box-shadow 120ms ease;
}
.ln-progress-slot.filled {
    background: #cbe300;
    box-shadow: 0 0 8px rgba(203,227,0,0.5);
}
.ln-progress-count {
    font-weight: 700;
    color: #cbe300;
    font-size: 14px;
}
.ln-btn-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(255,255,255,0.2);
    color: #ffffff;
    border-radius: 10px;
    padding: 8px 10px;
    font-weight: 600;
    cursor: pointer;
}
.ln-btn-back img {
    width: 18px;
    height: 18px;
    filter: brightness(0) invert(1);
}
.ln-btn-back:hover {
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}

@media (min-width: 900px) {
    .ln-picker-sticky {
        padding: 12px 16px;
    }
    .ln-picker-row1,
    .ln-picker-row2 {
        flex-wrap: nowrap;
    }
    .ln-picker-left {
        width: auto;
    }
    .ln-picker-progress-wrap {
        margin-left: auto;
    }
    .ln-picker-row2 {
        margin-top: 8px;
        justify-content: flex-start;
        gap: 10px;
    }
    .ln-picker-select {
        flex: 0 0 auto;
        max-width: none;
        min-width: 140px;
        padding: 8px 10px;
    }
}

@media (max-width: 899px) {
    .ln-picker-row2 {
        gap: 12px;
        margin-top: 10px;
    }
    .ln-picker-select {
        flex: 1 1 40%;
        max-width: 45%;
    }
}
.ln-empty-hint {
    color: var(--ln-text-dim);
    font-size: 14px;
    text-align: center;
    padding: 10px 6px;
}

.ln-view.ln-picker-view {
    visibility: hidden;
    height: 0;
    overflow: hidden;
}
.ln-view.ln-picker-view.active,
.ln-view.ln-picker-view.visible {
    visibility: visible;
    height: auto;
    overflow: visible;
}
.ln-picker-footer {
    padding: 0 var(--ln-space-3) var(--ln-space-3);
    display: flex;
    justify-content: flex-start;
}

.ln-pred-card {
    background: #101010;
    padding: var(--ln-space-3);
    cursor: pointer;
    position: relative;
    transition: transform 150ms var(--ln-speed-trans), box-shadow 150ms;
    font-family: "Inter", "Space Grotesk", sans-serif;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* Draw the border on a clipped pseudo-element */
.ln-pred-card.ln-cut-45::before {
    content: "";
    position: absolute;
    inset: 0;
    border: 1px solid var(--ln-border);
    pointer-events: none;
    clip-path: inherit;
    transition: border-color 150ms var(--ln-speed-trans), box-shadow 150ms;
}


.ln-pred-card:hover {
    transform: translateY(-2px);
}

/* Neon outline follows the 45° cut */
.ln-pred-card.ln-cut-45:hover::before,
.ln-pred-card.ln-cut-45.selected::before {
    border-color: var(--ln-neon);
    box-shadow: 0 0 18px var(--ln-neon-glow);
}

.ln-pred-card.selected {
    box-shadow: 0 0 18px var(--ln-neon-glow);
    background: var(--ln-neon-soft);
    color:var(--ln-bg);
}

.ln-pred-card.true-resolved.selected {
    box-shadow: 0 0 18px color-mix(in srgb, var(--ln-success, #2ecc71) 60%, transparent);
    background: var(--ln-success, #2ecc71);
    color: #041007;
}

.ln-pred-card.true-resolved {
    border-color: var(--ln-success, #2ecc71);
    box-shadow: 0 0 18px color-mix(in srgb, var(--ln-success, #2ecc71) 60%, transparent);
    background: var(--ln-success, #2ecc71);
    color: #041007;
}


/* =========== */
/* META ROW    */
/* =========== */

.ln-pred-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0;
    margin-bottom: 0;
}
.ln-pred-meta.bottom {
    margin-top: auto;
}

.ln-category-chip {
    padding: 2px 8px;
    font-size: 12px;
    background: rgba(223,255,0,0.08);
    color: var(--ln-neon);
    border: 1px solid rgba(223,255,0,0.2);
}

.ln-pred-card.selected .ln-category-chip {
    padding: 2px 8px;
    font-size: 12px;
    background: rgba(0, 0, 0, 0.08);
    color: var(--ln-bg);
    border: 1px solid rgba(0, 0, 0, 0.2);
}

.ln-points {
    font-size: 12px;
    opacity: 0.9;
}


/* PRED TEXT */
.ln-pred-text {
    margin-top: 0;
    font-size: 18px;
    line-height: 1.45;
    margin-bottom: 6px;
}


/* CHECKMARK BADGE */
.ln-checkmark-badge {
    position: absolute;
    top: 6px;
    right: 6px;
    background: var(--ln-neon);
    color: var(--ln-success);
    font-weight: 700;
    font-size: 13px;
    padding: 4px 8px;
    border-radius: var(--ln-radius);
    opacity: 0;
    transform: scale(0.6);
    transition: opacity 150ms, transform 150ms;
}

.ln-pred-card.selected .ln-checkmark-badge {
    opacity: 1;
    transform: scale(1);
}

.ln-pred-card.true-resolved .ln-checkmark-badge {
    background: #2ecc71;
    color: #041007;
    opacity: 1;
    transform: scale(1);
}
.ln-pred-card.true-resolved .ln-category-chip {
    background: color-mix(in srgb, var(--ln-success, #2ecc71) 15%, transparent);
    border-color: color-mix(in srgb, var(--ln-success, #2ecc71) 35%, transparent);
    color: #041007;
}
.ln-pred-card.true-resolved .ln-pred-text,
.ln-pred-card.true-resolved .ln-points {
    color: #041007;
}
.ln-app-root.view-only .ln-grid-cell:hover {
    border-color: var(--ln-border);
    transform: none;
}

.ln-share-preview {
    position: absolute;
    left: -9999px;
    top: -9999px;
}
.ln-share-card {
    width: 1080px;
    height: 1350px;
    background: #0a0a0a;
    color: #f7f7f7;
    padding: 32px;
    font-family: "Space Grotesk", sans-serif;
    box-shadow: 0 0 16px rgba(0,0,0,0.4);
    display: flex;
    flex-direction: column;
}
.ln-share-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}
.ln-share-title {
    font-size: 34px;
    font-weight: 700;
    color: var(--ln-neon);
}
.ln-share-subtitle {
    font-size: 34px;
    color: #cfcfcf;
}
.ln-share-brand {
    display: flex;
    align-items: center;
    gap: 10px;
}
.ln-share-logo {
    height: 28px;
    width: auto;
}
.ln-share-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 1fr;
    gap: 12px;
    flex: 1;
    margin-bottom: 18px;
}
.ln-share-cell {
    background: #111;
    border: 1px solid var(--ln-border);
    min-height: 0;
    padding: 24px;
    color: #f7f7f7;
    display: flex;
    flex-direction: column;
    gap: 16px;
    font-size: 28px;
}
.ln-share-cell.true {
    border-color: var(--ln-success, #2ecc71);
    background: var(--ln-success, #2ecc71);
    color: #041007;
}
.ln-share-cell.open-state {
    border-color: var(--ln-neon);
    background: #000;
    color: var(--ln-neon);
}
.ln-share-cell .ln-share-meta {
    display: flex;
    justify-content: space-between;
    font-size: 20px;
}
.ln-share-cell > div:last-child {
    font-size: 32px;
    line-height: 1.35;
}
.ln-share-footer {
    display: flex;
    justify-content: flex-end;
    gap: 6px;
    font-size: 14px;
    color: #cfcfcf;
}
.ln-share-score-value {
    font-weight: 700;
    color: var(--ln-neon);
}

.ln-debug-trash {
    border-radius: 50%;
    border: 1px solid var(--ln-border);
    background: rgba(255,255,255,0.08);
    color: var(--ln-text);
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    width: 32px;
    height: 32px;
    margin-top: 4px;
}

.ln-picker-view .ln-picker-view-mode {
    cursor: default;
}

/* Leaderboard page styles */
.leaderboard-page {
    color: var(--ln-text);
}
.leaderboard-page header {
    margin: 6px 0 18px;
    padding-left: 18px;
}
.leaderboard-page .position-banner {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin: 12px auto 10px;
    padding: 11px 18px;
    width: auto;
    border: 1px solid #cbe300;
    border-radius: 999px;
    background: rgba(203, 227, 0, 0.08);
    color: #cbe300;
    font-size: 0.9rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    line-height: 1.2;
    font-weight: 700;
    text-align: center;
    opacity: 0;
    animation: fadeInBanner 0.3s ease forwards;
}
.leaderboard-page h1 {
    margin: 0 0 6px;
    font-size: 2rem;
    letter-spacing: -0.3px;
    color: var(--ln-text);
}
.leaderboard-page .subtitle {
    color: var(--ln-text-dim);
    font-size: 0.96rem;
}
.leaderboard-page .panel {
    position: relative;
    background: #111;
    border-radius: 14px;
    border: 1px solid var(--ln-border-strong);
    padding: 10px 18px 16px;
    box-shadow: 0 18px 48px rgba(0,0,0,0.52), inset 0 0 0 1px rgba(223,255,0,0.06);
    overflow: hidden;
}
.leaderboard-page .panel::after {
    content: none;
}
.leaderboard-page .panel h2 {
    position: relative;
    margin: 0 0 8px;
    font-size: 0.92rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--ln-neon);
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.leaderboard-page .panel h2::after {
    content: "";
    display: block;
    height: 1px;
    width: 88px;
    background: linear-gradient(90deg, var(--ln-neon), transparent);
    opacity: 0.85;
}
.leaderboard-page .panel small {
    color: var(--ln-text-dim);
    font-size: 0.84rem;
}
.leaderboard-page table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin-top: 14px;
    font-size: 0.94rem;
    background: #000;
    border: 1px solid var(--ln-neon);
    border-radius: 12px;
    overflow: hidden;
}
.leaderboard-page thead th {
    background: var(--ln-neon);
    color: #000;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-weight: 700;
    padding: 12px 14px;
    border-bottom: 2px solid #000;
}
.leaderboard-page td {
    padding: 12px 14px;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    text-align: left;
    background: #090909;
}
.leaderboard-page tr:nth-child(even) td {
    background: #0c0c0c;
}
.leaderboard-page tbody tr:hover td {
    background: inherit;
    box-shadow: none;
    border-bottom-color: rgba(255,255,255,0.05);
}
.leaderboard-page .rank-cell { font-weight: 700; font-size: 0.94rem; color: var(--ln-text); }
.leaderboard-page .nickname-cell { font-weight: 600; color: var(--ln-text); }
.leaderboard-page .points-cell { font-weight: 800; color: var(--ln-neon); }
.leaderboard-page .time-cell { color: #9ca0ae; font-size: 0.9rem; }
.leaderboard-page .status {
    font-size: 0.85rem;
    color: var(--ln-text-dim);
    margin-top: 10px;
}
.leaderboard-page .status.error { color: #ff6b6b; }
.leaderboard-page .status.ok { color: var(--ln-success); }
.leaderboard-page .my-row {
    background: var(--ln-success, #2ecc71) !important;
    box-shadow: inset 0 0 0 2px var(--ln-success, #2ecc71), 0 0 18px color-mix(in srgb, var(--ln-success, #2ecc71) 60%, transparent);
}
.leaderboard-page .my-row td {
    background: transparent !important;
    border: none !important;
    color: #041007;
}
.leaderboard-page .my-row .points-cell { color: #041007; font-weight: 800; }
.leaderboard-page .my-row .rank-cell,
.leaderboard-page .my-row .nickname-cell { color: #041007; }
.leaderboard-page .my-row .nickname-cell::after {
    content: ' • you';
    color: #2ecc71;
    font-weight: 700;
    margin-left: 6px;
}

/* Picker locked (submissions closed) */
.picker-locked .ln-pred-card {
    cursor: default;
}
.picker-locked .ln-pred-card.selected:not(.true-resolved) {
    background: #000;
    border: 1px solid var(--ln-neon);
    box-shadow: none;
    color: var(--ln-neon);
}
.picker-locked .ln-pred-card.selected:not(.true-resolved) .ln-category-chip {
    background: rgba(223,255,0,0.12);
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}
.picker-locked .ln-pred-card.selected:not(.true-resolved) .ln-pred-text,
.picker-locked .ln-pred-card.selected:not(.true-resolved) .ln-points {
    color: var(--ln-neon);
}
.picker-locked .ln-pred-card.true-resolved {
    background: var(--ln-success, #2ecc71);
    border-color: var(--ln-success, #2ecc71);
    box-shadow: none;
    color: #041007;
}
.picker-locked .ln-pred-card.true-resolved.selected {
    background: var(--ln-neon);
    border: 1px solid var(--ln-neon);
}
.picker-locked .ln-pred-card .ln-checkmark-badge {
    display: none;
}
.picker-locked .ln-pred-card.true-resolved .ln-checkmark-badge {
    display: inline-block;
}
.picker-locked .ln-pred-card.true-resolved .ln-pred-text,
.picker-locked .ln-pred-card.true-resolved .ln-points {
    color: #041007;
}
.picker-locked .ln-pred-card.true-resolved .ln-category-chip {
    background: rgba(0,0,0,0.08);
    border-color: color-mix(in srgb, var(--ln-success, #2ecc71) 40%, transparent);
    color: #041007;
}
.picker-locked .ln-pred-card.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    opacity: 1;
    transform: scale(1);
    border: 2px solid var(--ln-success, #2ecc71);
}
.picker-locked .ln-pred-card:hover {
    transform: none;
    box-shadow: none;
}

/* Show the checkmark in filled grid cells */
.ln-grid-cell.filled .ln-checkmark-badge {
    opacity: 1;
    transform: scale(1);
}

/* ======================================== */
/* RESPONSIVE                               */
/* ======================================== */

@media (min-width: 600px) {
    .ln-grid-3x3 {
        gap: var(--ln-space-4);
    }
    .ln-pred-list {
        grid-template-columns: 1fr 1fr;
        display: grid;
        gap: var(--ln-space-4);
    }
}

@media (max-width: 600px) {
    .ln-grid-container {
        padding: 0;
    }
    .ln-grid-3x3 {
        gap: var(--ln-space-2);
        grid-template-columns: 1fr;
    }
    .ln-grid-container.ln-cut-frame-45::before {
        display: none;
    }
}

/* ============================================================
   View-only overrides (placed late to win cascade)
   ============================================================ */
.ln-app-root.view-only .ln-grid-cell,
.ln-app-root.view-only .ln-grid-cell:hover {
    box-shadow: none;
    transform: none;
}

.ln-app-root.view-only-open .ln-grid-cell.filled {
    background: #000;
    border-color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-cell-content,
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-grid-cell-content * {
    color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.filled .ln-category-chip {
    background: rgba(223,255,0,0.12);
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.true-resolved {
    background: #000;
    border-color: var(--ln-neon);
    box-shadow: none;
}
.ln-app-root.view-only-open .ln-grid-cell.true-resolved .ln-grid-cell-content,
.ln-app-root.view-only-open .ln-grid-cell.true-resolved .ln-grid-cell-content * {
    color: var(--ln-neon);
}
.ln-app-root.view-only-open .ln-grid-cell.true-resolved .ln-checkmark-badge {
    background: #000;
    color: var(--ln-neon);
    border: 1px solid var(--ln-neon);
}

.ln-app-root.view-only-closed .ln-grid-cell.filled {
    background: #000;
    border-color: var(--ln-neon);
}
.ln-app-root.view-only-closed .ln-grid-cell.filled:not(.true-resolved) .ln-grid-cell-content,
.ln-app-root.view-only-closed .ln-grid-cell.filled:not(.true-resolved) .ln-grid-cell-content * {
    color: var(--ln-neon);
}
.ln-app-root.view-only-closed .ln-grid-cell.filled:not(.true-resolved) .ln-category-chip {
    background: rgba(223,255,0,0.12);
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved {
    background: var(--ln-success, #2ecc71);
    border-color: var(--ln-success, #2ecc71);
    box-shadow: none;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-cell-content,
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-cell-content * {
    color: #041007;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-category-chip {
    background: rgba(0,0,0,0.08);
    border-color: color-mix(in srgb, var(--ln-success, #2ecc71) 40%, transparent);
    color: #041007;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    border: 2px solid var(--ln-success, #2ecc71);
}
/* ========================= */
/* CONFIRMATION SCREEN       */
/* ========================= */

.ln-confirm-view {
    /* still uses .ln-view for display:none/active */
    padding: 30px;
    text-align: center;
}
.ln-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.65);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 200;
}
.ln-modal-backdrop.open {
    display: flex;
}
.ln-error-card {
    background: var(--ln-bg-panel);
    border: 1px solid var(--ln-border-strong);
    box-shadow: 0 18px 40px rgba(0,0,0,0.45);
    border-radius: 12px;
    padding: 16px;
    width: min(420px, 90vw);
    color: var(--ln-text);
}
.ln-error-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}
.ln-error-title {
    font-weight: 700;
    font-size: 16px;
}
.ln-error-close {
    border: 1px solid var(--ln-border-strong);
    background: transparent;
    color: var(--ln-text);
    border-radius: 8px;
    padding: 6px 10px;
    cursor: pointer;
}
.ln-error-close:hover {
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}
.ln-error-body {
    font-size: 14px;
    line-height: 1.5;
    color: var(--ln-text);
}
.ln-back-to-grid {
    position: absolute;
    top: 12px;
    left: 12px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(0,0,0,0.4);
    color: #fff;
    padding: 8px 10px;
    border-radius: 10px;
    cursor: pointer;
}
.ln-back-to-grid .ln-back-ico {
    width: 14px;
    height: 14px;
}
.ln-back-to-grid:hover {
    border-color: var(--ln-neon);
    color: var(--ln-neon);
}

.ln-confirm-box {
    background: var(--ln-bg-panel);
    position: relative;
    padding: 56px 24px 24px;
    margin: 40px auto 0 auto;
    max-width: 520px;
    box-shadow: 0 0 30px rgba(223,255,0,0.12);
}

.ln-confirm-text {
    margin-top: 12px;
    font-size: 15px;
    color: var(--ln-text-dim);
}
.ln-confirm-beta {
    color: var(--ln-neon);
    font-weight: 600;
}
.ln-confirm-grid {
    display: flex;
    flex-direction: column;
    gap: 22px;
}
.ln-confirm-block {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: center;
}
.ln-confirm-share {
    margin-top: 12px;
}
.ln-confirm-share-btn {
    min-width: 280px;
    padding: 18px 22px;
    font-size: 16px;
    letter-spacing: 0.04em;
    justify-content: center;
    width: 100%;
    max-width: 360px;
}
.ln-link-cta {
    background: none;
    border: none;
    color: var(--ln-neon);
    text-decoration: none;
    cursor: pointer;
    font-weight: 700;
    font-size: 13px;
}
.ln-confirm-secondary-actions {
    gap: 10px;
    margin-top: 16px;
    margin-bottom: 28px;
}
.ln-confirm-secondary {
    gap: 10px;
    align-items: center;
    text-align: center;
}
.ln-feedback-strip {
    margin-top: 28px;
    padding: 16px 14px;
    border: 1px solid var(--ln-border-strong);
    background: rgba(255,255,255,0.02);
    border-radius: 12px;
    cursor: pointer;
}
.ln-feedback-strip-inner {
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}
.ln-feedback-email {
    margin-top: 10px;
    justify-content: flex-start;
}
.ln-feedback-email-copy {
    gap: 8px;
}
.ln-feedback-badge {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid var(--ln-neon);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(223,255,0,0.08);
}
.ln-feedback-ico {
    width: 18px;
    height: 18px;
    filter: none;
}
.ln-feedback-copy {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: flex-start;
}
.ln-feedback-prompt {
    color: var(--ln-text);
    font-weight: 700;
    font-size: 15px;
}
.ln-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    border: 1px solid var(--ln-border-strong);
    color: var(--ln-text);
    background: rgba(255,255,255,0.02);
    text-decoration: none;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ln-btn-outline,
.ln-link-cta {
    width: 100%;
    max-width: 360px;
}
.ln-link-cta-strong {
    width: auto;
    max-width: none;
}
.ln-link-cta-strong {
    color: var(--ln-neon);
    text-decoration: none;
    font-weight: 700;
}
.ln-link-cta-strong:hover {
    text-decoration: underline;
}
.ln-feedback-link {
    color: var(--ln-neon);
    text-decoration: none;
    font-weight: 700;
    font-size: 16px;
    cursor: pointer;
}
.ln-feedback-link .ln-btn-ico {
    filter: invert(79%) sepia(88%) saturate(643%) hue-rotate(38deg) brightness(104%) contrast(102%);
}
.ln-feedback-link:hover {
    text-decoration: underline;
}
.ln-updates-form {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: center;
}
.ln-updates-form label {
    font-size: 13px;
    color: var(--ln-text-dim);
}
.ln-updates-controls {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
}
.ln-updates-inline {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: center;
}
.ln-input-compact {
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid #fff;
    background: var(--ln-bg);
    color: var(--ln-text);
    min-width: 220px;
}
.ln-btn-icon {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.ln-btn-ico {
    width: 16px;
    height: 16px;
    display: inline-block;
}
.ln-btn-ico-left {
    margin-right: 6px;
    vertical-align: -2px;
}
.ln-notify-btn .ln-btn-ico {
    filter: invert(1) brightness(1.6);
}

/* Buttons container */
.ln-confirm-actions {
    margin-top: 28px;
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: center;
}

/* Base button styles for confirmation links */
.ln-btn-primary,
.ln-btn-secondary {
    display: block;
    padding: 12px 16px;
    text-decoration: none;
    text-align: center;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 14px;
}

@media (max-width: 520px) {
    .ln-btn-primary,
    .ln-btn-secondary {
        font-size: 20px;
    }
    #fillRandomBtn,
    #fillRandomAllBtn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    #backToGrid {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    .ln-share-actions button {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    .ln-btn-ico {
        width: 25px;
        height: 25px;
        flex-shrink: 0;
        align-self: center;
        vertical-align: -3px;
    }
    .ln-btn-ico-left {
        margin-right: 8px;
        margin-left: 12px;
    }
}


/* Primary = neon gradient (LN style) */
.ln-btn-primary {
    background: linear-gradient(135deg, var(--ln-neon), var(--ln-neon-soft));
    color: #000;
    border: none;
    cursor: pointer;
    transition: transform 120ms var(--ln-speed-trans), box-shadow 160ms;
}

.ln-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 0 18px var(--ln-neon-glow);
}

/* Secondary = outline */
.ln-btn-secondary {
    border: 1px solid var(--ln-neon);
    color: var(--ln-text);
    background: transparent;
    cursor: pointer;
    transition: border 120ms, color 120ms, transform 120ms var(--ln-speed-trans);
}

.ln-btn-secondary:hover {
    border-color: var(--ln-neon);
    color: var(--ln-neon);
    transform: translateY(-1px);
}

/* Slightly nicer layout on wider screens */
@media (min-width: 600px) {
    .ln-confirm-actions {
        flex-direction: row;
        justify-content: center;
    }
}

/* Force dark points text when a grid cell is filled */
.ln-grid-cell.filled .ln-grid-points,
.ln-grid-cell.filled .ln-points {
    color: rgba(0, 0, 0, 0.8);
}

.trace-logo {
    width: auto;
    height: 32px;
    margin-right: 8px;
    vertical-align: -3px;
    display: inline-block;
}

/* Make header a stacking context above the rest of the page */
.ln-header {
    position: relative;
    z-index: 20;
}

/* Make sure the right side (nav + lang) sits above content too */
.ln-header-inner {
    position: relative;
    z-index: 20;
}

/* Dropdown container + menu */
.ln-lang-dropdown {
    position: relative;
}

.ln-lang-menu {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    z-index: 30; /* higher than header and main content */
}

/* ——————————————————————— */
/* FIX TRACE LOGO VISIBILITY */
/* ——————————————————————— */

.ln-app-title {
    overflow: visible !important;
    line-height: normal !important;
}

.ln-app-title img.trace-logo {
    display: inline-block !important;
    width: 32px;
    height: auto;
    margin-right: 6px;
    vertical-align: baseline;
}

/* INTRO MODAL -------------------------------------------------- */

.ln-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200; /* above header / content */
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s ease-out;
}

.ln-modal-backdrop.is-visible {
    opacity: 1;
    pointer-events: auto;
}
.ln-modal-backdrop.open {
    opacity: 1;
    pointer-events: auto;
}

.ln-modal {
    max-width: 480px;
    width: calc(100% - 32px);
    background: var(--ln-bg-elevated);
    border-radius: 18px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8);
    padding: var(--ln-space-4);
}

.ln-modal-text {
    font-size: 14px;
    line-height: 1.5;
    color: var(--ln-muted);
    margin: 0 0 0.6rem;
}

.ln-modal-text:last-of-type {
    margin-bottom: var(--ln-space-3);
}

.ln-modal-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.ln-modal-checkbox {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--ln-muted);
}

.ln-modal-checkbox input[type="checkbox"] {
    transform: scale(1.05);
}

/* Modal layout */
.ln-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

/* Let the dropdown sit nicely on the right in the modal */
.ln-lang-switch--modal {
    margin-left: auto;
}

/* Optional: make sure menu appears above modal body */
.ln-lang-switch--modal .ln-lang-menu {
    z-index: 2100; /* higher than modal backdrop if needed */
}

/* Final overrides to ensure view-only closed/locked styles win */
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved {
    background: var(--ln-success, #2ecc71);
    box-shadow: none;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-cell-content,
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-grid-cell-content * {
    color: #041007;
}
.ln-app-root.view-only-closed .ln-grid-cell.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    border: 2px solid var(--ln-success, #2ecc71);
    opacity: 1;
    transform: scale(1);
}

.picker-locked .ln-pred-card.true-resolved {
    background: var(--ln-success, #2ecc71);
    border-color: var(--ln-neon);
    box-shadow: none;
    color: var(--ln-success);
}
.picker-locked .ln-pred-card.true-resolved.selected {
    background: var(--ln-neon);
    color: #000;
}
.picker-locked .ln-pred-card.true-resolved .ln-checkmark-badge {
    background: var(--ln-success, #2ecc71);
    color: #000;
    border: 2px solid var(--ln-success, #2ecc71);
    opacity: 1;
    transform: scale(1);
    display: inline-block;
}

/* Final picker locked overrides to ensure true picks are green with yellow border */
.picker-locked .ln-pred-card.true-resolved {
    background: #000;
    border: 1px solid var(--ln-success, #2ecc71);
    color: var(--ln-success, #2ecc71);
}
.picker-locked .ln-pred-card.true-resolved.selected {
    background: var(--ln-success, #2ecc71);
    border: 1px solid var(--ln-success, #2ecc71);
    color: #041007;
}
.picker-locked .ln-pred-card.true-resolved::before,
.picker-locked .ln-pred-card.true-resolved.selected::before {
    border-color: var(--ln-success, #2ecc71);
}
.picker-locked .ln-pred-card.true-resolved .ln-category-chip {
    background: rgba(0,0,0,0.08);
    border-color: color-mix(in srgb, var(--ln-success, #2ecc71) 40%, transparent);
    color: var(--ln-success, #2ecc71);
}
.picker-locked .ln-pred-card.true-resolved.selected .ln-category-chip {
    color: #041007;
}
.picker-locked .ln-pred-card.true-resolved:not(.selected) .ln-pred-text,
.picker-locked .ln-pred-card.true-resolved:not(.selected) .ln-pred-points {
    color: var(--ln-success, #2ecc71);
}
.picker-locked .ln-pred-card.true-resolved.selected .ln-pred-text,
.picker-locked .ln-pred-card.true-resolved.selected .ln-pred-points {
    color: #041007;
}

/* Leaderboard page styles */
.leaderboard-page .panel {
    background: linear-gradient(145deg, #10131a, #171b24);
    border-radius: 16px;
    border: 1px solid var(--ln-border);
    padding: 16px 18px 20px;
    box-shadow: 0 18px 40px rgba(0,0,0,0.45);
}
.leaderboard-page .panel h2 {
    margin: 0 0 8px;
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #e4e7ff;
}
.leaderboard-page .panel small {
    color: #9aa0b5;
    font-size: 0.8rem;
}
.leaderboard-page table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 16px;
    font-size: 0.9rem;
}
.leaderboard-page thead {
    background: rgba(255,255,255,0.02);
}
.leaderboard-page th,
.leaderboard-page td {
    padding: 8px 10px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    text-align: left;
}
.leaderboard-page th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #9aa0b5;
}
.leaderboard-page tr:nth-child(even) td {
    background: rgba(0,0,0,0.14);
}
.leaderboard-page tr:hover td {
    background: transparent;
}
.leaderboard-page .rank-cell { font-weight: 700; font-size: 0.9rem; }
.leaderboard-page .nickname-cell { font-weight: 500; }
.leaderboard-page .points-cell { font-weight: 600; }
.leaderboard-page .status {
    font-size: 0.85rem;
    color: #9aa0b5;
    margin-top: 10px;
}
.leaderboard-page .status.error { color: #ff6b6b; }
.leaderboard-page .status.ok { color: #2ecc71; }
.leaderboard-page .my-row td {
    background: rgba(46, 204, 113, 0.14) !important;
    border-bottom-color: rgba(46, 204, 113, 0.35);
}
.leaderboard-page .my-row .nickname-cell::after {
    content: ' • you';
    color: #2ecc71;
    font-weight: 700;
    margin-left: 6px;
}
