<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>FREE-MAD Dashboard</title>
  <!-- Self-hosted vendor assets to avoid CDN dependency -->
  <script src="/static/vendor/tailwindcdn.js"></script>
  <script src="/static/vendor/chart.umd.min.js" defer></script>
  <script src="/static/vendor/htmx-1.9.12.min.js" defer></script>
  <style>
    body.dark { background-color: #0f172a; color: #e2e8f0; }
    body.dark .bg-white { background-color: #1f2937; color: #e2e8f0; }
    body.dark .text-slate-600 { color: #cbd5f5; }
    body.dark .text-slate-500 { color: #94a3b8; }
  </style>
</head>
<body class="bg-slate-50 text-slate-900">
  <a href="#main" class="sr-only focus:not-sr-only focus:absolute focus:top-2 focus:left-2 bg-white text-slate-800 px-3 py-2 rounded shadow">Skip to main content</a>
  <header class="bg-white border-b border-slate-200">
    <div class="max-w-6xl mx-auto px-4 py-4 flex items-center justify-between">
      <h1 class="text-xl font-semibold">FREE-MAD Dashboard</h1>
      <nav class="text-sm text-slate-600">
        <a href="/" class="hover:underline">Runs</a>
        <button id="themeToggle" class="ml-4 px-2 py-1 border border-slate-300 rounded text-xs" type="button">Toggle theme</button>
      </nav>
    </div>
  </header>

  <main id="main" class="max-w-6xl mx-auto px-4 py-6">
    {% block content %}{% endblock %}
  </main>

  <footer class="max-w-6xl mx-auto px-4 py-6 text-xs text-slate-500">
    Built for local analysis of FREE-MAD transcripts.
  </footer>

  <!-- Lightweight tooltip system for inline ⓘ help -->
  <script>
    document.addEventListener('DOMContentLoaded', () => {
      const storedTheme = localStorage.getItem('mad-theme');
      if (storedTheme === 'dark') {
        document.body.classList.add('dark');
      }
      const toggle = document.getElementById('themeToggle');
      toggle?.addEventListener('click', () => {
        document.body.classList.toggle('dark');
        localStorage.setItem('mad-theme', document.body.classList.contains('dark') ? 'dark' : 'light');
      });
      const tip = document.createElement('div');
      tip.id = 'mad-tooltip';
      tip.className = 'fixed z-50 hidden px-2 py-1 text-xs bg-slate-800 text-white rounded shadow ring-1 ring-black/20 max-w-[22rem]';
      document.body.appendChild(tip);
      const pad = 10;
      const show = (ev, text) => { tip.textContent = text; tip.classList.remove('hidden'); move(ev); };
      const move = (ev) => { tip.style.left = (ev.clientX + pad) + 'px'; tip.style.top = (ev.clientY + pad) + 'px'; };
      const hide = () => tip.classList.add('hidden');
      const bind = (el) => {
        const text = el.getAttribute('data-tip') || el.getAttribute('title');
        if (!text) return;
        el.setAttribute('title',''); // suppress native tooltip
        el.addEventListener('mouseenter', (e)=>show(e, text));
        el.addEventListener('mousemove', move);
        el.addEventListener('mouseleave', hide);
        el.addEventListener('focus', (e)=>show(e, text));
        el.addEventListener('blur', hide);
      };
      document.querySelectorAll('.tip').forEach(bind);
    });
  </script>
</body>
</html>
