/* ==========================================================================
   Олимпиадын глобал theme - бүх DOMjudge хуудсанд хэрэглэгдэнэ
   ========================================================================== */

:root {
    --mn-orange: #f5891f;
    --mn-orange-light: #ffa94d;
    --mn-orange-dark: #d96d10;
    --mn-orange-soft: #fef3e2;
    --mn-brown: #3d2817;
    --mn-brown-dark: #1f140b;
    --mn-cream: #fdf8f1;
    --mn-cream-2: #f7eedf;
    --mn-gold: #f4b526;
    --mn-text: #2c1810;
    --mn-text-soft: #6b5949;
    --mn-border: #ece3d2;
    --mn-success: #16a34a;
    --mn-danger:  #dc2626;
    --btn-primary-bg: var(--mn-orange);
}

body {
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    background: var(--mn-cream) !important;
    color: var(--mn-text);
}

/* ==========================================================================
   NAVBAR
   ========================================================================== */

.navbar,
.navbar.navbar-light,
.navbar.bg-light,
.navbar.navbar-light.bg-light,
.navbar.navbar-dark,
.navbar.bg-dark,
.navbar.navbar-dark.bg-dark {
    background: linear-gradient(120deg, #fffaf0 0%, #fef5e7 100%) !important;
    border: none !important;
    box-shadow: 0 4px 18px -10px rgba(217,109,16,0.25);
    padding: 0.7rem 1.4rem !important;
    border-bottom: 2px solid var(--mn-orange) !important;
    min-height: 64px;
    backdrop-filter: blur(8px);
}

/* Override navbar-dark default white text */
.navbar.navbar-dark .nav-link,
.navbar.navbar-dark .navbar-brand,
.navbar.navbar-dark .navbar-text {
    color: var(--mn-brown) !important;
}
.navbar-dark .navbar-toggler-icon {
    filter: invert(0.4) sepia(1) hue-rotate(-10deg) saturate(5) brightness(0.85);
}

/* Push body content below fixed navbar */
body {
    padding-top: 76px !important;
}
.navbar.fixed-top + main,
body > .container-fluid {
    padding-top: 0;
}
body.static {
    padding-top: 0 !important;
}

/* Navbar buttons (Register / Login / Scoreboard / Problemset etc.) */
.navbar .btn,
.navbar button.btn {
    background: rgba(255,255,255,0.85) !important;
    border: 1.5px solid var(--mn-border) !important;
    color: var(--mn-brown) !important;
    border-radius: 999px !important;
    padding: 0.45rem 1.1rem !important;
    font-weight: 600;
    font-size: 13.5px;
    transition: all 0.2s ease;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04) !important;
    margin-left: 6px;
}
.navbar .btn:hover,
.navbar button.btn:hover {
    background: var(--mn-orange) !important;
    border-color: var(--mn-orange) !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 14px -4px rgba(245,137,31,0.4) !important;
}
/* Active scoreboard button in jury navbar */
.navbar .btn.active,
.navbar button.btn.active,
.navbar .btn-primary {
    background: linear-gradient(135deg, var(--mn-orange) 0%, var(--mn-orange-dark) 100%) !important;
    border-color: var(--mn-orange-dark) !important;
    color: #fff !important;
    box-shadow: 0 6px 14px -6px rgba(245,137,31,0.5) !important;
}

/* Register button - cream pill */
.navbar .btn-info,
.navbar a.btn-info,
.navbar a[href*="/register"].btn {
    background: #ffffff !important;
    border: 1.5px solid var(--mn-border) !important;
    color: var(--mn-brown) !important;
    font-weight: 600 !important;
    border-radius: 999px !important;
    padding: 0.4rem 1.1rem !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04) !important;
    transition: all 0.2s ease;
}
.navbar .btn-info:hover,
.navbar a[href*="/register"].btn:hover {
    background: var(--mn-gold) !important;
    color: var(--mn-brown-dark) !important;
    border-color: var(--mn-gold) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 14px -4px rgba(244,181,38,0.4) !important;
}

/* Login button - orange CTA */
.navbar a[href="/login"].btn,
.navbar a[href="/login"].btn-info {
    background: linear-gradient(135deg, var(--mn-orange) 0%, var(--mn-orange-dark) 100%) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 6px 14px -6px rgba(245,137,31,0.55) !important;
}
.navbar a[href="/login"].btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px -6px rgba(245,137,31,0.65) !important;
}

/* Top right clock / timer */
.navbar #timeleft,
.navbar #contesttimer,
.navbar .navbar-text {
    color: var(--mn-orange-dark) !important;
    font-weight: 700 !important;
    font-size: 14px;
    background: linear-gradient(135deg, #fff7ec 0%, #fdebd0 100%);
    padding: 6px 14px;
    border-radius: 999px;
    border: 1.5px solid var(--mn-orange);
    margin-left: 8px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    box-shadow: 0 4px 10px -4px rgba(245,137,31,0.3);
}

.navbar i.fa-clock,
.navbar .loading-indicator {
    color: var(--mn-orange-dark) !important;
}

/* User dropdown menu in navbar */
.navbar .dropdown-toggle {
    color: var(--mn-brown) !important;
    font-weight: 600;
}
.navbar-text {
    color: var(--mn-orange-dark) !important;
}

.navbar-brand {
    font-weight: 800 !important;
    color: var(--mn-brown-dark) !important;
    letter-spacing: 0.3px;
    font-size: 1.2rem !important;
    background: linear-gradient(135deg, var(--mn-orange-dark) 0%, var(--mn-orange) 50%, var(--mn-gold) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.navbar .nav-link {
    color: var(--mn-brown) !important;
    font-weight: 600;
    transition: all 0.2s ease;
    padding: 0.5rem 0.9rem !important;
    border-radius: 8px;
}
.navbar .nav-link:hover {
    color: var(--mn-orange-dark) !important;
    background: rgba(245,137,31,0.08);
}
.navbar .nav-link.active {
    color: var(--mn-orange-dark) !important;
    font-weight: 700;
    background: rgba(245,137,31,0.12);
}
.navbar .nav-link i { color: var(--mn-orange-dark); }
.navbar .nav-link.active i { color: var(--mn-orange-dark); }

/* Top progress bar (loading-strip below navbar) */
.bg-warning,
.progress-bar.bg-warning {
    background: linear-gradient(90deg, var(--mn-orange) 0%, var(--mn-gold) 100%) !important;
}

/* ==========================================================================
   SCOREBOARD BUTTONS / NAV ICONS
   ========================================================================== */

.btn {
    border-radius: 10px !important;
    font-weight: 600;
    padding: 0.5rem 1rem;
    transition: all 0.2s ease;
}

.btn-primary {
    background: linear-gradient(135deg, var(--mn-orange) 0%, var(--mn-orange-dark) 100%) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 6px 14px -6px rgba(245,137,31,0.5) !important;
}
.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 18px -6px rgba(245,137,31,0.6) !important;
}

.btn-secondary {
    background: #ffffff !important;
    color: var(--mn-brown) !important;
    border: 1.5px solid var(--mn-border) !important;
}
.btn-secondary:hover {
    background: var(--mn-orange-soft) !important;
    border-color: var(--mn-orange) !important;
    color: var(--mn-orange-dark) !important;
}

.btn-success {
    background: linear-gradient(135deg, var(--mn-gold) 0%, #c89014 100%) !important;
    border: none !important;
    color: #2c1810 !important;
}

.btn-danger {
    background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%) !important;
    border: none !important;
}

.btn-info {
    background: linear-gradient(135deg, #38bdf8 0%, #0284c7 100%) !important;
    border: none !important;
    color: #fff !important;
}

.btn-outline-primary {
    color: var(--mn-orange-dark) !important;
    border: 1.5px solid var(--mn-orange) !important;
    background: transparent !important;
}
.btn-outline-primary:hover {
    background: var(--mn-orange) !important;
    color: #fff !important;
}

/* Scoreboard pill (active state) */
.navbar .nav-link.active,
.navbar a.nav-link.active,
nav.navbar .nav-link.active {
    background: linear-gradient(135deg, var(--mn-orange) 0%, var(--mn-orange-dark) 100%) !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    border-radius: 999px !important;
    padding: 0.5rem 1.1rem !important;
    box-shadow: 0 6px 14px -6px rgba(245,137,31,0.5);
}
.navbar .nav-link.active i,
.navbar a.nav-link.active i,
nav.navbar .nav-link.active i {
    color: #ffffff !important;
    margin-right: 4px;
}

/* ==========================================================================
   CONTEST HEADER (the dark bar showing current contest name)
   ========================================================================== */

.bg-dark, .bg-secondary {
    background: linear-gradient(120deg, var(--mn-brown) 0%, var(--mn-brown-dark) 100%) !important;
}

/* The contest title strip just below the navbar */
.text-bg-dark,
[class*="text-bg-dark"] {
    background: linear-gradient(120deg, var(--mn-brown) 0%, var(--mn-brown-dark) 100%) !important;
    color: #fff !important;
    border-bottom: 3px solid var(--mn-orange) !important;
    font-weight: 700;
    letter-spacing: 0.4px;
    padding: 14px 18px !important;
    box-shadow: 0 4px 12px -6px rgba(0,0,0,0.2);
}

.text-bg-dark *,
[class*="text-bg-dark"] * {
    color: #fff !important;
}

/* Override "muted" text inside the dark contest bar (e.g., started/ends time) */
.text-bg-dark .text-muted,
[class*="text-bg-dark"] .text-muted {
    color: #ffd49a !important;
    opacity: 0.95;
    font-weight: 600;
}

/* ==========================================================================
   CARDS / PANELS
   ========================================================================== */

.card {
    border: 1px solid var(--mn-border) !important;
    border-radius: 14px !important;
    box-shadow: 0 4px 18px -8px rgba(61,40,23,0.12) !important;
    overflow: hidden;
    background: #fff;
}
.card-header {
    background: linear-gradient(120deg, #fffaf0 0%, #fef0d4 100%) !important;
    border-bottom: 3px solid var(--mn-orange) !important;
    color: var(--mn-brown-dark) !important;
    font-weight: 700 !important;
    padding: 18px 26px !important;
    font-size: 16px !important;
    letter-spacing: 0.3px;
}
.card-header *,
.card-header span,
.card-header div {
    color: var(--mn-brown-dark) !important;
}
.card-header span[style*="font-weight: bold"] {
    font-size: 22px !important;
    color: var(--mn-brown-dark) !important;
    background: linear-gradient(135deg, var(--mn-orange-dark) 0%, var(--mn-orange) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
/* Contest timer (started/ends) */
.card-header #contesttimer {
    color: var(--mn-orange-dark) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    background: #ffffff;
    padding: 8px 16px;
    border-radius: 999px;
    border: 1.5px solid var(--mn-orange);
    display: inline-block;
    box-shadow: 0 4px 10px -4px rgba(245,137,31,0.25);
}

.modal-content {
    border: none !important;
    border-radius: 18px !important;
    overflow: hidden;
    box-shadow: 0 30px 60px -20px rgba(61,40,23,0.3);
}
.modal-header {
    background: linear-gradient(120deg, var(--mn-brown) 0%, var(--mn-brown-dark) 100%) !important;
    color: #fff;
    border-bottom: 2px solid var(--mn-orange);
}
.modal-header .btn-close { filter: invert(1) brightness(2); }

/* ==========================================================================
   TABLES (scoreboard, problemset)
   ========================================================================== */

.table {
    border-collapse: separate !important;
    border-spacing: 0;
    background: #fff;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 8px 30px -14px rgba(61,40,23,0.18);
}

/* ==========================================================================
   SCOREBOARD - full width, large, branded
   ========================================================================== */

table.scoreboard,
table.scoreboard.desktop-scoreboard,
table.scoreboard.mobile-scoreboard {
    width: 100% !important;
    max-width: 1500px !important;
    margin: 8px auto 24px !important;
    border-collapse: separate !important;
    border-spacing: 0;
    background: #ffffff;
    border-radius: 18px !important;
    overflow: hidden;
    box-shadow:
        0 24px 60px -20px rgba(217,109,16,0.25),
        0 8px 24px -12px rgba(61,40,23,0.12),
        0 0 0 1px rgba(245,137,31,0.12);
    border: none !important;
    font-size: 15px;
}

table.scoreboard.center {
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Disable sticky header to avoid overlap with rank 1 */
table.scoreboard thead th,
table.scoreboard tr.scoreheader th {
    position: static !important;
    top: auto !important;
}

/* Scoreboard header row — LIGHT theme */
table.scoreboard thead th,
table.scoreboard tr.scoreheader th {
    background: linear-gradient(135deg, #fff7eb 0%, #fef0d4 50%, #fceac0 100%) !important;
    color: var(--mn-brown-dark) !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    font-size: 13px !important;
    padding: 18px 10px !important;
    border: none !important;
    border-bottom: 3px solid var(--mn-orange) !important;
    text-align: center;
    line-height: 1.3;
}
table.scoreboard thead th a,
table.scoreboard thead th span,
table.scoreboard tr.scoreheader th a,
table.scoreboard tr.scoreheader th span {
    color: var(--mn-brown-dark) !important;
}

/* Problem column letter circles (A, B, C, etc.) — light theme */
table.scoreboard thead th .badge,
table.scoreboard thead th .problem-badge,
table.scoreboard thead th a {
    background: #ffffff !important;
    color: var(--mn-orange-dark) !important;
    border: 2px solid var(--mn-orange) !important;
    border-radius: 999px !important;
    padding: 6px 14px !important;
    font-weight: 800 !important;
    font-size: 14px !important;
    display: inline-block;
    min-width: 38px;
    text-align: center;
    box-shadow: 0 2px 6px rgba(245,137,31,0.2);
}

/* Body rows */
table.scoreboard tbody tr {
    transition: background 0.25s ease;
    border-bottom: 2px solid #f1e6d0 !important;
    will-change: transform;
}
table.scoreboard tbody tr td {
    border-bottom: 1.5px solid #f4ecdc !important;
}
table.scoreboard tbody tr:nth-of-type(even) {
    background: #fefaf3 !important;
}
table.scoreboard tbody tr:hover {
    background: linear-gradient(90deg, #fef3e2 0%, #fffaf0 100%) !important;
    box-shadow: inset 0 0 0 1.5px rgba(245,137,31,0.3);
}

/* Animated rank-change effects */
table.scoreboard tbody tr.olympiad-moved-up {
    animation: olympiadRiseUp 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}
table.scoreboard tbody tr.olympiad-moved-down {
    animation: olympiadSlideDown 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}
table.scoreboard tbody tr.olympiad-score-changed {
    animation: olympiadFlash 1.4s ease;
}

@keyframes olympiadRiseUp {
    0% {
        background: linear-gradient(90deg, #d1fae5 0%, #fff 60%) !important;
        box-shadow: inset 0 0 0 2px #10b981, 0 -8px 20px -8px rgba(16,185,129,0.5);
        transform: translateY(8px);
    }
    50% {
        transform: translateY(-2px);
    }
    100% {
        transform: translateY(0);
    }
}

@keyframes olympiadSlideDown {
    0% {
        background: linear-gradient(90deg, #fee2e2 0%, #fff 60%) !important;
        box-shadow: inset 0 0 0 2px #ef4444, 0 8px 20px -8px rgba(239,68,68,0.4);
        transform: translateY(-8px);
    }
    100% {
        transform: translateY(0);
    }
}

@keyframes olympiadFlash {
    0% {
        background: linear-gradient(90deg, #fef3e2 0%, #fff7ec 100%) !important;
        box-shadow: inset 0 0 0 2px var(--mn-orange);
    }
    100% {}
}

/* Score cell flash on update */
table.scoreboard tbody td.olympiad-cell-updated > * {
    animation: olympiadCellPop 0.8s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes olympiadCellPop {
    0% { transform: scale(0.5); opacity: 0; }
    60% { transform: scale(1.1); }
    100% { transform: scale(1); opacity: 1; }
}

table.scoreboard tbody td {
    padding: 14px 10px !important;
    border: none !important;
    vertical-align: middle;
    color: var(--mn-text);
    font-weight: 600;
}

/* RANK column - bold, prominent */
table.scoreboard tbody td.scorenc,
table.scoreboard tbody td:first-child {
    font-size: 18px !important;
    font-weight: 800 !important;
    color: var(--mn-text) !important;
    width: 60px;
    text-align: center;
}

/* No medal styling — keep all ranks consistent */

/* Force category-divider rows (sortorderswitch) to render normally */
table.scoreboard tbody tr.sortorderswitch {
    display: table-row !important;
    visibility: visible !important;
    height: auto !important;
    border-top: 2px solid var(--mn-orange) !important;
}
table.scoreboard tbody tr.sortorderswitch td {
    display: table-cell !important;
    visibility: visible !important;
    padding: 14px 10px !important;
}

/* Team name cell */
table.scoreboard tbody td.scoretn,
table.scoreboard tbody td:nth-child(3) {
    text-align: right;
    padding-right: 18px !important;
}
table.scoreboard tbody .teamname,
table.scoreboard tbody td a {
    font-weight: 800 !important;
    color: var(--mn-text) !important;
    font-size: 15.5px;
    text-decoration: none;
}
table.scoreboard tbody .univ,
table.scoreboard tbody .univ small {
    color: var(--mn-text-soft) !important;
    font-size: 12px !important;
    font-weight: 500;
    display: block;
}

/* Score column */
table.scoreboard tbody .scorenc,
table.scoreboard tbody td.scoreSolved {
    background: linear-gradient(135deg, var(--mn-orange-soft) 0%, #fefaf3 100%) !important;
    font-weight: 800 !important;
    color: var(--mn-orange-dark) !important;
    font-size: 18px !important;
}

/* Problem cells - score correct/incorrect (target the div inside td.score_cell) */
table.scoreboard tbody td.score_cell {
    padding: 10px 6px !important;
    overflow: visible !important;
    position: relative;
}
table.scoreboard tbody td.score_cell > a,
table.scoreboard tbody td.score_cell > div {
    display: block;
    border-radius: 8px;
    overflow: visible;
    position: relative;
}
table.scoreboard tbody .score_correct {
    background: linear-gradient(135deg, #86efac 0%, #4ade80 100%) !important;
    color: #14532d !important;
    text-align: center;
    font-weight: 800 !important;
    font-size: 16px !important;
    padding: 10px 4px !important;
    border-radius: 8px;
    box-shadow: 0 4px 10px -4px rgba(74,222,128,0.4);
}
/* First solver — DEEP EMERALD green (green family, distinctly darker than solved) */
table.scoreboard tbody div.score_correct.score_first,
table.scoreboard tbody .score_correct.score_first {
    background: linear-gradient(135deg, #047857 0%, #065f46 50%, #022c22 100%) !important;
    background-color: #065f46 !important;
    color: #ffffff !important;
    text-align: center;
    font-weight: 800 !important;
    font-size: 16px !important;
    padding: 10px 4px 10px 4px !important;
    border-radius: 8px;
    box-shadow: 0 6px 16px -4px rgba(6,95,70,0.55),
                0 0 0 2px rgba(255,215,0,0.6) inset;
    position: relative;
    overflow: visible !important;
    text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}

/* Mazaalai bear "First Solver" — sits at TOP CENTER, half above / half below cell edge */
table.scoreboard tbody .score_correct.score_first::before {
    content: '';
    position: absolute;
    top: -18px;                 /* half of icon height above cell */
    left: 50%;
    width: 36px;
    height: 36px;
    margin-left: -18px;         /* center horizontally */
    background: url("/images/olympiad/bear.svg") center/contain no-repeat;
    transform-origin: 50% 50%;
    z-index: 5;
    pointer-events: none;
    filter: drop-shadow(0 3px 5px rgba(0,0,0,0.3));
    animation:
      olympiadBearDrop 0.6s cubic-bezier(0.34, 1.56, 0.64, 1),
      olympiadBearBob 3s ease-in-out 0.6s infinite;
}

@keyframes olympiadBearBob {
    0%, 100% { transform: translateY(0) rotate(-3deg); }
    50%      { transform: translateY(-2px) rotate(3deg); }
}

@keyframes olympiadBearDrop {
    0%   { transform: translateY(-30px) scale(0.4); opacity: 0; }
    60%  { transform: translateY(2px) scale(1.1); opacity: 1; }
    100% { transform: translateY(0) scale(1); opacity: 1; }
}

/* Stronger swing on hover */
table.scoreboard tbody td.score_cell:hover .score_correct.score_first::before {
    animation: olympiadBearWiggle 0.9s ease;
}

@keyframes olympiadBearWiggle {
    0%, 100% { transform: rotate(0); }
    20%      { transform: rotate(-22deg); }
    40%      { transform: rotate(16deg); }
    60%      { transform: rotate(-12deg); }
    80%      { transform: rotate(7deg); }
}

/* Tooltip on hover */
table.scoreboard tbody .score_correct.score_first {
    cursor: help;
}
table.scoreboard tbody .score_correct.score_first::after {
    content: 'Анх бодсон!';
    position: absolute;
    bottom: calc(100% + 14px);
    left: 50%;
    transform: translateX(-50%) scale(0);
    background: var(--mn-brown-dark);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 6px;
    white-space: nowrap;
    pointer-events: none;
    transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
    z-index: 10;
}
table.scoreboard tbody td.score_cell:hover .score_correct.score_first::after {
    transform: translateX(-50%) scale(1);
}

@keyframes olympiadBearPop {
    0% { transform: scale(0) rotate(-180deg); opacity: 0; }
    100% { transform: scale(1) rotate(0); opacity: 1; }
}

/* Bouncing idle animation on hover */
table.scoreboard tbody td.score_cell:hover .score_correct.score_first::before {
    animation: olympiadBearWiggle 0.6s ease;
}

@keyframes olympiadBearWiggle {
    0%, 100% { transform: rotate(0); }
    25% { transform: rotate(-12deg) scale(1.1); }
    75% { transform: rotate(12deg) scale(1.1); }
}
table.scoreboard tbody .score_incorrect {
    background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%) !important;
    color: #fff !important;
    text-align: center;
    font-weight: 700;
    font-size: 13px;
    padding: 10px 4px !important;
    border-radius: 8px;
    box-shadow: 0 4px 10px -4px rgba(185,28,28,0.4);
}
table.scoreboard tbody .score_pending {
    background: linear-gradient(135deg, var(--mn-gold) 0%, #c89014 100%) !important;
    color: var(--mn-brown-dark) !important;
    text-align: center;
    font-weight: 800;
    padding: 10px 4px !important;
    border-radius: 8px;
}
table.scoreboard tbody .score_neutral {
    background: transparent !important;
}

/* Tries text inside score cells */
table.scoreboard tbody .score_correct span,
table.scoreboard tbody .score_correct_first span,
table.scoreboard tbody .score_first span,
table.scoreboard tbody .score_incorrect span {
    display: block;
    font-size: 11px;
    font-weight: 600;
    opacity: 0.95;
    margin-top: 2px;
}

/* Flag column */
table.scoreboard tbody td img.countryflag {
    border-radius: 4px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
    width: 28px;
    height: auto;
}

/* Heart icon for favorites */
table.scoreboard tbody td .fa-heart,
table.scoreboard tbody td i.fas,
table.scoreboard tbody td i.far {
    color: #ddd;
    transition: color 0.2s ease;
}
table.scoreboard tbody td .fa-heart:hover,
table.scoreboard tbody td .heartfav .fa-heart {
    color: var(--mn-orange) !important;
}

/* Score legend table — distinct from main scoreboard */
table.scoreboard.scorelegend {
    margin: 16px auto 24px !important;
    width: auto !important;
    max-width: 240px !important;
    border-collapse: separate !important;
    border-spacing: 0 6px !important;
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    padding: 12px;
}
table.scoreboard.scorelegend thead th {
    background: transparent !important;
    color: var(--mn-brown) !important;
    border: none !important;
    text-align: center;
    padding: 8px 12px !important;
    font-size: 13px !important;
}

/* Each legend row = colored pill */
table.scoreboard.scorelegend tbody tr {
    background: transparent !important;
    border: none !important;
}
table.scoreboard.scorelegend tbody tr td {
    padding: 12px 18px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-align: center;
    border-radius: 10px !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 4px 10px -4px rgba(0,0,0,0.15);
    position: relative;
    overflow: visible;
}

/* Legend color overrides (target tr-level classes) */
table.scoreboard.scorelegend tbody tr.score_correct.score_first td {
    background: linear-gradient(135deg, #047857 0%, #065f46 50%, #022c22 100%) !important;
    color: #fff !important;
}
table.scoreboard.scorelegend tbody tr.score_correct td {
    background: linear-gradient(135deg, #86efac 0%, #4ade80 100%) !important;
    color: #14532d !important;
}
table.scoreboard.scorelegend tbody tr.score_incorrect td {
    background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%) !important;
    color: #fff !important;
}
table.scoreboard.scorelegend tbody tr.score_pending td {
    background: linear-gradient(135deg, var(--mn-gold) 0%, #c89014 100%) !important;
    color: var(--mn-brown-dark) !important;
}
table.scoreboard.scorelegend tbody tr.score_neutral td {
    background: #ffffff !important;
    color: var(--mn-brown) !important;
    border: 1.5px solid var(--mn-border) !important;
    box-shadow: none !important;
}

/* Legend "Solved first" — bear at top center */
table.scoreboard.scorelegend tbody tr.score_correct.score_first td::before {
    content: '';
    position: absolute;
    top: -16px;
    left: 50%;
    margin-left: -16px;
    width: 32px;
    height: 32px;
    background: url("/images/olympiad/bear.svg") center/contain no-repeat;
    filter: drop-shadow(0 3px 5px rgba(0,0,0,0.3));
    z-index: 5;
}
table.scoreboard.scorelegend tbody tr.score_correct.score_first td::after,
table.scoreboard.scorelegend tbody tr.score_correct.score_first::after {
    display: none !important;
}

.table thead th, .table > thead {
    background: linear-gradient(120deg, var(--mn-brown-dark) 0%, var(--mn-brown) 100%) !important;
    color: #fff !important;
    font-weight: 700 !important;
    border-bottom: 2px solid var(--mn-orange) !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-size: 12px;
    border-top: none !important;
}
.table thead th {
    padding: 14px 10px !important;
    color: #fff !important;
}

.table tbody tr {
    transition: background 0.15s ease;
}
.table tbody tr:hover {
    background: var(--mn-orange-soft) !important;
}
.table tbody tr:hover td {
    background: transparent !important;
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
    background: rgba(254,243,226,0.35);
}

/* Scoreboard team name cell */
.table tbody td .teamname {
    font-weight: 700;
    color: var(--mn-text);
    font-size: 14px;
}
.table tbody td .univ {
    color: var(--mn-text-soft);
    font-size: 11px;
}

/* Rank column - make it stand out */
.table tbody td.scorerank,
.table tbody td:first-child {
    font-weight: 800;
    font-size: 16px;
    color: var(--mn-orange-dark);
}

/* Top 3 rank highlight */
.table tbody tr:nth-child(1) td.scorerank,
.table tbody tr:nth-child(1) td:first-child { color: var(--mn-orange) !important; font-size: 18px; }
.table tbody tr:nth-child(2) td.scorerank,
.table tbody tr:nth-child(2) td:first-child { color: #b87333 !important; }
.table tbody tr:nth-child(3) td.scorerank,
.table tbody tr:nth-child(3) td:first-child { color: #8b6f47 !important; }

/* Scoreboard rank cell */
.scorerank, .scoresolv {
    font-weight: 800 !important;
}

/* Solved cell colors (override default green/red) */
.score_correct {
    background: linear-gradient(135deg, #22c55e 0%, #15803d 100%) !important;
    color: #fff !important;
    font-weight: 700;
}
.score_incorrect {
    background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%) !important;
    color: #fff !important;
}
.score_pending {
    background: linear-gradient(135deg, var(--mn-gold) 0%, #c89014 100%) !important;
    color: #2c1810 !important;
}
.score_first {
    background: linear-gradient(135deg, var(--mn-orange) 0%, var(--mn-orange-dark) 100%) !important;
    color: #fff !important;
    font-weight: 800;
}

/* ==========================================================================
   FORMS (also for jury submission filters etc.)
   ========================================================================== */

.form-control, .form-select {
    border: 1.5px solid var(--mn-border) !important;
    border-radius: 10px !important;
    padding: 0.55rem 0.85rem;
    transition: all 0.2s ease;
}
.form-control:focus, .form-select:focus {
    border-color: var(--mn-orange) !important;
    box-shadow: 0 0 0 4px rgba(245,137,31,0.18) !important;
    outline: none !important;
}
.form-label {
    color: var(--mn-text);
    font-weight: 600;
    font-size: 13px;
}

/* ==========================================================================
   ALERTS
   ========================================================================== */

.alert {
    border-radius: 12px !important;
    border: none !important;
    padding: 12px 16px !important;
    font-size: 14px;
    border-left: 4px solid;
}
.alert-danger    { background: #fee2e2 !important; color: #991b1b !important; border-left-color: var(--mn-danger) !important; }
.alert-success   { background: #d1fae5 !important; color: #065f46 !important; border-left-color: var(--mn-success) !important; }
.alert-warning   { background: #fef3c7 !important; color: #92400e !important; border-left-color: var(--mn-orange) !important; }
.alert-info      { background: #dbeafe !important; color: #1e40af !important; border-left-color: #3b82f6 !important; }

/* ==========================================================================
   BANNER on public page - large, prominent
   ========================================================================== */

img.banner {
    border-radius: 18px;
    box-shadow:
        0 24px 50px -16px rgba(245,137,31,0.45),
        0 0 0 1px rgba(245,137,31,0.12);
    width: calc(100% - 32px);
    max-width: none;
    height: auto;
    margin: 18px 16px 26px !important;
    display: block;
}

/* Banner container that DOMjudge wraps the img in */
.scoreboard-banner,
.banner-wrapper {
    width: 100%;
    text-align: center;
    padding: 0 24px;
}

/* ==========================================================================
   LINKS
   ========================================================================== */

a {
    color: var(--mn-orange-dark);
    text-decoration: none;
    transition: color 0.2s ease;
}
a:hover {
    color: var(--mn-orange);
    text-decoration: underline;
}

/* Don't underline navbar links */
.navbar a, .nav-link, .navbar-brand {
    text-decoration: none !important;
}

/* ==========================================================================
   BADGES / PILLS
   ========================================================================== */

.badge {
    border-radius: 999px !important;
    padding: 0.35em 0.75em !important;
    font-weight: 600 !important;
    letter-spacing: 0.3px;
}
.badge.bg-primary {
    background: linear-gradient(135deg, var(--mn-orange) 0%, var(--mn-orange-dark) 100%) !important;
}
.badge.bg-success {
    background: linear-gradient(135deg, var(--mn-success) 0%, #15803d 100%) !important;
}
.badge.bg-danger {
    background: linear-gradient(135deg, var(--mn-danger) 0%, #991b1b 100%) !important;
}
.badge.bg-warning {
    background: linear-gradient(135deg, var(--mn-gold) 0%, #c89014 100%) !important;
    color: #2c1810 !important;
}
.badge.bg-secondary {
    background: linear-gradient(135deg, var(--mn-text-soft) 0%, var(--mn-brown) 100%) !important;
}

/* ==========================================================================
   PROGRESS / TIMER
   ========================================================================== */

.progress {
    height: 8px !important;
    border-radius: 999px !important;
    background: var(--mn-cream-2) !important;
    overflow: hidden;
}
.progress-bar {
    background: linear-gradient(90deg, var(--mn-orange) 0%, var(--mn-gold) 100%) !important;
    border-radius: 999px;
}

/* Contest countdown timer (sometimes in red) */
.text-danger {
    color: var(--mn-orange-dark) !important;
}

/* ==========================================================================
   SCROLLBAR (webkit)
   ========================================================================== */

*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: var(--mn-cream); }
*::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--mn-orange-light), var(--mn-orange-dark));
    border-radius: 999px;
    border: 2px solid var(--mn-cream);
}
*::-webkit-scrollbar-thumb:hover { background: var(--mn-orange-dark); }
