/* Eval Dashboard custom styles */

/* === Animation tokens === */
:root {
    --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
    --dur-fast: 150ms;
    --dur-normal: 200ms;
    --dur-slow: 300ms;
}
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Modal overlay + panel */
.modal-overlay {
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--dur-normal) var(--ease-out-quart);
}
.modal-overlay.is-open {
    opacity: 1;
    pointer-events: auto;
}
.modal-panel {
    opacity: 0;
    transform: scale(0.96) translateY(6px);
    transition: opacity var(--dur-normal) var(--ease-out-quart),
                transform var(--dur-normal) var(--ease-out-quart);
}
.modal-overlay.is-open .modal-panel {
    opacity: 1;
    transform: scale(1) translateY(0);
}

/* Dropdown fade-scale */
.dropdown-animate {
    opacity: 0;
    transform: scale(0.95) translateY(-4px);
    transform-origin: top left;
    transition: opacity var(--dur-fast) var(--ease-out-quart),
                transform var(--dur-fast) var(--ease-out-quart);
    pointer-events: none;
}
.dropdown-animate.is-open {
    opacity: 1;
    transform: scale(1) translateY(0);
    pointer-events: auto;
}

/* Compare bar slide-up */
.compare-bar-animate {
    transform: translateY(100%);
    opacity: 0;
    transition: transform var(--dur-slow) var(--ease-out-quart),
                opacity var(--dur-normal) var(--ease-out-quart);
}
.compare-bar-animate.is-visible {
    transform: translateY(0);
    opacity: 1;
}

/* HTMX swap fade-in */
.htmx-swap-fade {
    animation: htmxFadeIn var(--dur-normal) var(--ease-out-quart);
}
@keyframes htmxFadeIn {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Form input focus transition */
input, textarea, select {
    transition: border-color var(--dur-fast) var(--ease-out-quart),
                box-shadow var(--dur-fast) var(--ease-out-quart);
}

/* Button press feedback */
.btn-press {
    transition: transform var(--dur-fast) var(--ease-out-quart);
}
.btn-press:active {
    transform: scale(0.97);
}

/* HTMX indicator */
.htmx-indicator {
    display: none;
}
.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator {
    display: inline-flex;
}

/* Fade in animation */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
.animate-fade-in {
    animation: fadeIn var(--dur-slow) var(--ease-out-quart);
}

/* SSE pulse animation for live updates */
@keyframes ssePulse {
    0% { box-shadow: 0 0 0 0 rgba(20, 184, 166, 0.4); }
    70% { box-shadow: 0 0 0 6px rgba(20, 184, 166, 0); }
    100% { box-shadow: 0 0 0 0 rgba(20, 184, 166, 0); }
}
.sse-live {
    animation: ssePulse 2s infinite;
}

/* Pivot table styles */
.pivot-table th,
.pivot-table td {
    white-space: nowrap;
}
.pivot-table td.font-mono {
    font-feature-settings: 'tnum' on;
}

/* Sticky first column in pivot table */
.pivot-table td:first-child,
.pivot-table th:first-child {
    position: sticky;
    left: 0;
    z-index: 5;
}

/* Toast animations */
@keyframes slideIn {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}
@keyframes slideOut {
    from { transform: translateX(0); opacity: 1; }
    to { transform: translateX(100%); opacity: 0; }
}
.toast-enter {
    animation: slideIn var(--dur-slow) var(--ease-out-quart);
}
.toast-exit {
    animation: slideOut var(--dur-slow) var(--ease-out-quart) forwards;
}

/* Status dot glow */
.status-running {
    box-shadow: 0 0 6px rgba(59, 130, 246, 0.5);
}

/* Line clamp utility */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Custom scrollbar — thin & minimal */
::-webkit-scrollbar {
    width: 4px;
    height: 4px;
}
::-webkit-scrollbar-track {
    background: transparent;
}
::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.12);
    border-radius: 9999px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.22);
}
.dark ::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
}
.dark ::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.2);
}

/* Firefox thin scrollbar */
* {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.12) transparent;
}
.dark * {
    scrollbar-color: rgba(255, 255, 255, 0.1) transparent;
}

/* Leaderboard row + column hover highlight — filter-only, no background overrides */

/* Row: subtle darken + saturation to make heatmap pop without replacing colors */
.leaderboard-table tr.row-highlight td {
    filter: brightness(0.91) saturate(1.5);
}
/* Sticky cells must NOT get filter — it creates a new stacking context and breaks position:sticky */
.leaderboard-table tr.row-highlight td.sticky {
    filter: none;
}
.dark .leaderboard-table tr.row-highlight td {
    filter: brightness(0.85) saturate(1.8);
}
.dark .leaderboard-table tr.row-highlight td.sticky {
    filter: none;
}

/* Column: stronger saturation boost */
.leaderboard-table td.col-highlight {
    filter: saturate(4.0) contrast(1.2) brightness(0.96);
}
/* Red cells are nearly white (red-50/70) so need a much stronger boost */
.leaderboard-table td.col-highlight.bg-red-50\/70 {
    filter: saturate(12.0) contrast(1.5) brightness(0.88);
}
.dark .leaderboard-table td.col-highlight {
    filter: saturate(2.5) contrast(1.1);
}

/* Intersection: cell at hovered row + hovered col — combine both effects */
.leaderboard-table tr.row-highlight td.col-highlight {
    filter: saturate(5.0) contrast(1.3) brightness(0.88);
}
.leaderboard-table tr.row-highlight td.col-highlight.bg-red-50\/70 {
    filter: saturate(14.0) contrast(1.6) brightness(0.82);
}
.dark .leaderboard-table tr.row-highlight td.col-highlight {
    filter: saturate(3.5) contrast(1.2) brightness(0.82);
}

/* Audio player seek bar */
.audio-seek {
    -webkit-appearance: none;
    appearance: none;
    height: 4px;
    border-radius: 2px;
    background: linear-gradient(to right, rgb(13 148 136) 0%, rgb(209 213 219) 0%);
    outline: none;
}
.dark .audio-seek {
    background: linear-gradient(to right, rgb(45 212 191) 0%, rgb(75 85 99) 0%);
}
.audio-seek::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgb(13 148 136);
    cursor: pointer;
}
.audio-seek::-moz-range-thumb {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgb(13 148 136);
    cursor: pointer;
    border: none;
}
.dark .audio-seek::-webkit-slider-thumb,
.dark .audio-seek::-moz-range-thumb {
    background: rgb(45 212 191);
}
.seek-tooltip {
    position: absolute;
    bottom: 100%;
    margin-bottom: 6px;
    transform: translateX(-50%);
    background: rgb(17 24 39);
    color: #fff;
    font-size: 0.7rem;
    font-family: ui-monospace, monospace;
    padding: 2px 6px;
    border-radius: 4px;
    pointer-events: none;
    white-space: nowrap;
}
.dark .seek-tooltip {
    background: rgb(55 65 81);
}

/* Preset sidebar active state */
.preset-item-active {
    background-color: rgb(240 253 250);
    border-left-color: rgb(13 148 136) !important;
}
.dark .preset-item-active {
    background-color: rgba(13, 148, 136, 0.1);
    border-left-color: rgb(45 212 191) !important;
}

.provider-card:hover {
    border-color: rgb(94 234 212);
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
}
.dark .provider-card:hover {
    border-color: rgba(45, 212, 191, 0.5);
}

/* Diffcheck highlight classes */
.diff-del {
    background: rgb(254 226 226);
    color: rgb(153 27 27);
    border-radius: 2px;
    padding: 0 1px;
}
.dark .diff-del {
    background: rgba(127, 29, 29, 0.3);
    color: rgb(254 202 202);
}
.diff-ins {
    background: rgb(209 250 229);
    color: rgb(6 95 70);
    border-radius: 2px;
    padding: 0 1px;
}
.dark .diff-ins {
    background: rgba(6, 78, 59, 0.3);
    color: rgb(167 243 208);
}

/* Scrollbar-hide for horizontal scroll containers */
.leaderboard-tabs::-webkit-scrollbar,
.diffcheck-pills::-webkit-scrollbar { display: none; }
.leaderboard-tabs,
.diffcheck-pills { -ms-overflow-style: none; scrollbar-width: none; }

/* Touch-friendly targets on coarse-pointer (touch) devices */
@media (pointer: coarse) {
    .leaderboard-table td, .leaderboard-table th { min-height: 44px; }
    input[type="date"] { min-height: 44px; }
}

/* Styled tooltips — driven by #global-tooltip JS in base.html */

/* ==========================================================================
   DARK MODE v2 — Near-Black Palette Override Layer
   Loaded after Tailwind CDN, wins by source order.
   Light mode is completely untouched.
   ========================================================================== */

/* --- Fonts (both modes) --- */
body {
    font-family: 'Plus Jakarta Sans', ui-sans-serif, system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, h4,
.font-display {
    font-family: 'Sora', ui-sans-serif, system-ui, sans-serif;
}

/* --- Background palette remap ---
   Tailwind dark:bg-gray-* → near-black scale */
.dark .dark\:bg-gray-900   { background-color: #0e0e0e !important; }
.dark .dark\:bg-gray-950   { background-color: #0e0e0e !important; }
.dark .dark\:bg-gray-800   { background-color: #131313 !important; }
.dark .dark\:bg-gray-700   { background-color: #1a1919 !important; }
.dark .dark\:bg-gray-600   { background-color: #262626 !important; }
.dark .dark\:bg-gray-500   { background-color: #2c2c2c !important; }
.dark .dark\:bg-gray-200   { background-color: #2c2c2c !important; }
.dark .dark\:bg-\[\#1a2332\] { background-color: #131313 !important; }

/* Slate scale (used by public snapshot pages) */
.dark .dark\:bg-slate-950  { background-color: #0e0e0e !important; }
.dark .dark\:bg-slate-900  { background-color: #0e0e0e !important; }
.dark .dark\:bg-slate-800  { background-color: #131313 !important; }
.dark .dark\:bg-slate-700  { background-color: #1a1919 !important; }
.dark .dark\:border-slate-700 { border-color: #1f1f1f !important; }
.dark .dark\:border-slate-600 { border-color: #2a2a2a !important; }
.dark .dark\:text-slate-100 { color: #e8e4e0 !important; }
.dark .dark\:text-slate-200 { color: #d4d0cc !important; }
.dark .dark\:text-slate-300 { color: #b0aca8 !important; }
.dark .dark\:text-slate-400 { color: #8a8684 !important; }

/* Body itself */
.dark body { background-color: #0e0e0e; }

/* --- Hover background remap --- */
.dark .dark\:hover\:bg-gray-800:hover { background-color: #1a1919 !important; }
.dark .dark\:hover\:bg-gray-700:hover { background-color: #222222 !important; }
.dark .dark\:hover\:bg-gray-600:hover { background-color: #2c2c2c !important; }

/* --- Border remap --- */
.dark .dark\:border-gray-700 { border-color: #1f1f1f !important; }
.dark .dark\:border-gray-600 { border-color: #2a2a2a !important; }
.dark .dark\:border-gray-500 { border-color: #333333 !important; }

/* --- Divide remap --- */
.dark .dark\:divide-gray-700 > :not([hidden]) ~ :not([hidden]) { border-color: #1f1f1f !important; }
.dark .dark\:divide-gray-600 > :not([hidden]) ~ :not([hidden]) { border-color: #2a2a2a !important; }

/* --- Text warmth: cool grays → warm neutrals --- */
.dark .dark\:text-gray-100 { color: #e8e4e0 !important; }
.dark .dark\:text-gray-200 { color: #d4d0cc !important; }
.dark .dark\:text-gray-300 { color: #b0aca8 !important; }
.dark .dark\:text-gray-400 { color: #8a8684 !important; }
.dark .dark\:text-gray-500 { color: #6b6866 !important; }
.dark body { color: #e8e4e0; }

/* --- Ring / focus remap --- */
.dark .dark\:ring-gray-700 { --tw-ring-color: #1f1f1f !important; }
.dark .dark\:ring-gray-600 { --tw-ring-color: #2a2a2a !important; }

/* --- Placeholder remap --- */
.dark .dark\:placeholder-gray-400::placeholder { color: #6b6866 !important; }

/* --- Nav glass effect --- */
.dark #main-nav {
    background: rgba(19, 19, 19, 0.82) !important;
    backdrop-filter: blur(20px) saturate(1.3);
    -webkit-backdrop-filter: blur(20px) saturate(1.3);
    box-shadow: 0 1px 0 rgba(255,255,255,0.04), 0 4px 40px rgba(20,184,166,0.04);
    border-bottom-color: rgba(255,255,255,0.06) !important;
}
/* Mobile menu panel */
.dark #mobile-menu-panel {
    background: #131313 !important;
}

/* --- Glass panel utility --- */
.dark .glass-panel {
    background: rgba(26, 25, 25, 0.65) !important;
    backdrop-filter: blur(16px) saturate(1.2);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
    border: 1px solid rgba(255,255,255,0.06);
    box-shadow: 0 1px 2px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.03);
}

/* --- Teal glow utility --- */
.dark .glow-teal {
    box-shadow: 0 0 20px rgba(20,184,166,0.08), 0 0 60px rgba(20,184,166,0.03);
}

/* --- Harmonize existing dark rules with new palette --- */

/* Tooltip */
.dark #global-tooltip {
    background: #262626 !important;
    border: 1px solid rgba(255,255,255,0.08);
}

/* Scrollbar thumb */
.dark ::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.08);
}
.dark ::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.15);
}

/* Seek tooltip */
.dark .seek-tooltip {
    background: #262626;
    border: 1px solid rgba(255,255,255,0.08);
}

/* Admin dropdown */
.dark #admin-dropdown > div {
    background: #1a1919 !important;
    border-color: rgba(255,255,255,0.06) !important;
}

/* Preset sidebar active state */
.dark .preset-item-active {
    background-color: rgba(20, 184, 166, 0.08);
}

/* Provider card hover */
.dark .provider-card:hover {
    border-color: rgba(45, 212, 191, 0.3);
    box-shadow: 0 0 16px rgba(20,184,166,0.06);
}

/* Audio seek bar dark */
.dark .audio-seek {
    background: linear-gradient(to right, rgb(45 212 191) 0%, #2c2c2c 0%);
}

/* --- Subtle transition for dark mode toggle --- */
body, #main-nav, #mobile-menu-panel {
    transition: background-color var(--dur-slow) var(--ease-out-quart), color var(--dur-fast) var(--ease-out-quart);
}

/* --- Input fields: deeper dark --- */
.dark input, .dark textarea, .dark select {
    background-color: #131313;
    border-color: #1f1f1f;
}
.dark input:focus, .dark textarea:focus, .dark select:focus {
    border-color: rgba(20,184,166,0.5);
    box-shadow: 0 0 0 2px rgba(20,184,166,0.12);
}

/* --- Tables --- */
.dark .dark\:bg-gray-800\/50 { background-color: rgba(19,19,19,0.5) !important; }

/* --- Active nav tab in dark --- */
.dark .dark\:bg-gray-700.border-b-2 {
    background-color: rgba(20,184,166,0.1) !important;
}

/* --- Card-like containers: subtle border glow on hover --- */
.dark .dark\:bg-gray-700:hover {
    box-shadow: 0 0 0 1px rgba(255,255,255,0.04);
}
