/* ============================================================
   SENTIO — UI Polish Layer
   Drop-in on top of base.css / dashboard.css / virtual.css
   Add to all 3 HTML pages:
   <link rel="stylesheet" href="/css/polish.css">
   ============================================================ */

/* ── SMOOTHER TRANSITIONS EVERYWHERE ── */
*,
*::before,
*::after {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── PANELS — lift on hover ── */
.panel {
  transition: border-color 0.2s, box-shadow 0.2s;
}
.panel:hover {
  border-color:  var(--border-bright);
  box-shadow:    0 0 0 1px var(--border-bright);
}

/* ── TABLE ROWS — smoother hover + left accent ── */
.sentio-table tbody tr {
  transition: background 0.12s;
  border-left: 2px solid transparent;
}
.sentio-table tbody tr:hover td {
  background:   var(--bg-hover);
}
.sentio-table tbody tr:hover {
  border-left-color: var(--accent-blue);
}

/* ── DASHBOARD TABS — icon pop on active ── */
.dash-tab {
  transition: color 0.15s, border-color 0.15s;
}
.dash-tab svg {
  transition: transform 0.2s, opacity 0.2s;
  opacity: 0.5;
}
.dash-tab:hover svg  { opacity: 0.8;  transform: translateY(-1px); }
.dash-tab.active svg { opacity: 1;    transform: translateY(-1px); }

/* ── VIRTUAL TABS — same ── */
.tab {
  transition: color 0.15s, border-color 0.15s;
}
.tab svg {
  transition: transform 0.2s, opacity 0.2s;
  opacity: 0.5;
}
.tab:hover svg  { opacity: 0.8;  transform: translateY(-1px); }
.tab.active svg { opacity: 1;    transform: translateY(-1px); }

/* ── LEARN TABS — same ── */
.learn-tab svg {
  transition: transform 0.2s, opacity 0.2s;
  opacity: 0.5;
}
.learn-tab:hover svg  { opacity: 0.8;  transform: translateY(-1px); }
.learn-tab.active svg { opacity: 1;    transform: translateY(-1px); }

/* ── BOTTOM NAV — scale icon on active ── */
.bottom-nav-item svg {
  transition: transform 0.2s, opacity 0.2s;
  opacity: 0.45;
}
.bottom-nav-item:hover svg  { opacity: 0.7;  transform: scale(1.1); }
.bottom-nav-item.active-dashboard svg,
.bottom-nav-item.active-virtual svg,
.bottom-nav-item.active-learn svg { opacity: 1; transform: scale(1.15); }

/* ── NAV LINKS (topbar) — icon nudge ── */
.nav-link svg {
  transition: transform 0.2s, opacity 0.2s;
  opacity: 0.6;
}
.nav-link:hover svg { opacity: 1; transform: translateX(1px); }
.nav-link[class*="active"] svg { opacity: 1; }

/* ── BUTTONS — scale press effect ── */
.btn,
.btn-buy,
.btn-sell,
.complete-btn,
.quiz-submit {
  transition: opacity 0.15s, transform 0.1s;
}
.btn:active,
.btn-buy:active,
.btn-sell:active,
.complete-btn:active,
.quiz-submit:active {
  transform: scale(0.97);
}

/* ── PATH CARDS — slide up on hover ── */
.path-card {
  transition: border-color 0.15s, transform 0.18s, box-shadow 0.18s;
}
.path-card:not(.locked):hover {
  transform:    translateY(-2px);
  box-shadow:   0 4px 20px rgba(0, 0, 0, 0.4);
  border-color: var(--accent-purple);
}
.path-card.done:not(.locked):hover {
  border-color: var(--accent-green);
}

/* ── BADGE CARDS — glow on earned ── */
.badge-card {
  transition: transform 0.18s, box-shadow 0.18s, border-color 0.15s;
}
.badge-card.earned:hover {
  transform:  translateY(-2px);
  box-shadow: 0 0 16px rgba(255, 179, 0, 0.15);
}

/* ── ALERT ITEMS ── */
.alert-item {
  transition: background 0.12s, border-left-color 0.12s;
  border-left: 2px solid transparent;
}
.alert-item:hover { border-left-color: var(--accent-amber); }

/* ── LEADERBOARD ROWS ── */
.lb-row {
  transition: background 0.12s, border-left-color 0.12s;
  border-left: 2px solid transparent;
}
.lb-row:hover { border-left-color: var(--accent-blue); }

/* ── TAB PANEL ENTRANCE — snappier ── */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0);   }
}
.tab-panel.active  { animation: fadeIn 0.22s cubic-bezier(0.4, 0, 0.2, 1); }
.learn-view.active { animation: fadeIn 0.22s cubic-bezier(0.4, 0, 0.2, 1); }

/* ── SCORE RING — pulse on load ── */
@keyframes ringPop {
  0%   { transform: scale(0.92); opacity: 0; }
  60%  { transform: scale(1.03); }
  100% { transform: scale(1);    opacity: 1; }
}
.score-ring-wrap {
  animation: ringPop 0.5s cubic-bezier(0.4, 0, 0.2, 1) both;
}

/* ── MARKET PILL — breathing glow ── */
@keyframes pillGlow {
  0%, 100% { box-shadow: 0 0 0 0 transparent; }
  50%       { box-shadow: 0 0 8px 1px currentColor; }
}
.market-pill {
  animation: pillGlow 3s ease-in-out infinite;
}

/* ── STATUS DOT — softer pulse ── */
.status-dot {
  box-shadow: 0 0 0 0 var(--accent-green);
  animation:  statusPing 2s ease-in-out infinite;
}
@keyframes statusPing {
  0%   { box-shadow: 0 0 0 0   rgba(0, 230, 118, 0.5); }
  70%  { box-shadow: 0 0 0 6px rgba(0, 230, 118, 0);   }
  100% { box-shadow: 0 0 0 0   rgba(0, 230, 118, 0);   }
}

/* ── SHIMMER — slightly warmer ── */
.shimmer {
  background: linear-gradient(
    90deg,
    var(--bg-card)  25%,
    var(--bg-hover) 50%,
    var(--bg-card)  75%
  );
  background-size: 300% 100%;
  animation: shimmer 1.8s ease-in-out infinite;
}

/* ── TOAST — slide from bottom with bounce ── */
#toast {
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── XP POPUP — smoother float ── */
@keyframes fadeUp {
  0%   { opacity: 1; transform: translateY(0)     scale(1);    }
  20%  { opacity: 1; transform: translateY(-8px)  scale(1.05); }
  100% { opacity: 0; transform: translateY(-48px) scale(0.9);  }
}

/* ── QUIZ OPTIONS — scale check on correct ── */
.quiz-opt {
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
}
.quiz-opt:hover:not(.correct):not(.wrong) {
  transform: translateX(2px);
}
.quiz-opt.correct {
  animation: correctPop 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes correctPop {
  0%   { transform: scale(1);    }
  50%  { transform: scale(1.02); }
  100% { transform: scale(1);    }
}

/* ── BREADTH RING — animate stroke on update ── */
#breadth-ring {
  transition: stroke-dashoffset 1.2s cubic-bezier(0.4, 0, 0.2, 1),
              stroke 0.6s ease;
}

/* ── SCROLLBAR — slightly more visible ── */
::-webkit-scrollbar-thumb {
  background:    var(--border-bright);
  border-radius: 4px;
  transition:    background 0.2s;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--text-dim);
}