@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
  --dacs-dark: #0a1628;
  --dacs-text: #111827;
  --dacs-text-secondary: #4b5563;
  --dacs-text-tertiary: #9ca3af;
  --dacs-border: #e5e7eb;
  --dacs-bg: #ffffff;
  --dacs-bg-alt: #f8fafb;
  --dacs-bg-subtle: #f1f5f4;
  --dacs-accent: #0f766e;
  --dacs-accent-hover: #0d6560;
  --dacs-danger: #ef4444;
  --dacs-radius: 3px;
}

/* ============================================================
   Force light theme (Gatus uses Tailwind's `dark:` prefix via
   prefers-color-scheme — we disable it wholesale below).
   ============================================================ */
html, body, #app {
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
  background: var(--dacs-bg-alt) !important;
  color: var(--dacs-text) !important;
  color-scheme: light !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Neutralize all dark-mode Tailwind utility classes (escaped colon in CSS) */
.dark\:bg-gray-700,
.dark\:bg-gray-800,
.dark\:bg-gray-900,
[class*="dark:bg-"] {
  background-color: var(--dacs-bg) !important;
}
.dark\:text-white,
.dark\:text-gray-100,
.dark\:text-gray-200,
.dark\:text-gray-300,
[class*="dark:text-"] {
  color: var(--dacs-text) !important;
}
.dark\:border-gray-600,
.dark\:border-gray-700,
.dark\:border-gray-800,
[class*="dark:border-"] {
  border-color: var(--dacs-border) !important;
}

/* Same overrides wrapped in media query — wins against any inline dark vars */
@media (prefers-color-scheme: dark) {
  html, body, #app {
    background: var(--dacs-bg-alt) !important;
    color: var(--dacs-text) !important;
  }
  [class*="bg-gray-"], [class*="bg-slate-"], [class*="bg-zinc-"] {
    background-color: var(--dacs-bg) !important;
    color: var(--dacs-text) !important;
  }
}

/* ============================================================
   Headings + typography
   ============================================================ */
#app h1, #app h2, #app h3, #app h4, #app h5 {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  color: var(--dacs-text) !important;
  letter-spacing: -0.02em !important;
}

/* Group titles: Gatus renders each group name as an <h5> — uppercase,
   small, tertiary. Do NOT cascade to endpoint rows. */
#app h5 {
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  color: var(--dacs-text-tertiary) !important;
}

/* ============================================================
   HEADER — white, subtle bottom border (mirrors .nav.scrolled)
   ============================================================ */
#app > div:first-child,
#app > header {
  background: var(--dacs-bg) !important;
  color: var(--dacs-text) !important;
  border-bottom: 1px solid var(--dacs-border) !important;
  box-shadow: 0 1px 2px rgba(10, 22, 40, 0.04);
}
#app > div:first-child h1,
#app > header h1 {
  color: var(--dacs-text) !important;
  font-weight: 700 !important;
}
#app > div:first-child a,
#app > header a {
  color: var(--dacs-text-secondary) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  transition: color 0.2s;
}
#app > div:first-child a:hover,
#app > header a:hover {
  color: var(--dacs-accent) !important;
}
#app > div:first-child img,
#app > header img {
  height: 28px !important;
  width: auto !important;
}

/* ============================================================
   CARDS — sharp DACS radius, subtle border, no heavy shadow
   ============================================================ */
.rounded, .rounded-md, .rounded-lg, .rounded-xl, .rounded-2xl {
  border-radius: var(--dacs-radius) !important;
}
.bg-white, .shadow, .shadow-md, .shadow-lg, .shadow-xl {
  background: var(--dacs-bg) !important;
  border: 1px solid var(--dacs-border) !important;
  box-shadow: 0 1px 2px rgba(10, 22, 40, 0.03) !important;
}

/* ============================================================
   Accent — DACS teal replaces Gatus blue/indigo
   ============================================================ */
.text-blue-500, .text-blue-600, .text-blue-700,
.text-indigo-500, .text-indigo-600, .text-indigo-700 {
  color: var(--dacs-accent) !important;
}
.bg-blue-500, .bg-blue-600, .bg-blue-700,
.bg-indigo-500, .bg-indigo-600, .bg-indigo-700 {
  background: var(--dacs-accent) !important;
}
.border-blue-500, .border-blue-600,
.border-indigo-500, .border-indigo-600 {
  border-color: var(--dacs-accent) !important;
}
a { color: var(--dacs-accent); }
a:hover { color: var(--dacs-accent-hover); }

/* ============================================================
   Hover rows — subtle pale teal, never dark
   ============================================================ */
[class*="hover:bg-"]:hover,
.hover\:bg-gray-50:hover,
.hover\:bg-gray-100:hover,
.hover\:bg-gray-700:hover,
.hover\:bg-gray-800:hover,
tr:hover, li:hover {
  background: var(--dacs-bg-subtle) !important;
  color: var(--dacs-text) !important;
}

/* ============================================================
   Status chips (kept green/red — easy to scan)
   ============================================================ */
.bg-green-400, .bg-green-500, .bg-green-600, .bg-green-700 {
  background: #10b981 !important;
}
.bg-red-400, .bg-red-500, .bg-red-600, .bg-red-700 {
  background: var(--dacs-danger) !important;
}
.bg-yellow-400, .bg-yellow-500, .bg-yellow-600 {
  background: #f59e0b !important;
}

/* Secondary text (hostnames, "N seconds ago", response times) */
.text-gray-400, .text-gray-500 { color: var(--dacs-text-tertiary) !important; }
.text-gray-600, .text-gray-700 { color: var(--dacs-text-secondary) !important; }

/* ============================================================
   STATUSPAGE-STYLE BARS — thin vertical bars, stretched to fill row
   ============================================================ */
.status-over-time {
  display: flex !important;
  flex-direction: row !important;
  width: 100% !important;
  gap: 3px !important;
  align-items: stretch !important;
}
.status-over-time .status {
  flex: 1 1 0 !important;
  min-width: 4px !important;
  max-width: 14px !important;
  height: 34px !important;
  border-radius: 2px !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  font-size: 0 !important;      /* hide any text/icon inside */
  line-height: 0 !important;
  transition: transform 0.1s ease;
}
.status-over-time .status:hover {
  transform: scaleY(1.15);
}
.status-over-time .status > * {
  display: none !important;
}

/* Empty slot (no data yet) — pale dashed placeholder */
.status-over-time .status.border-dashed {
  background: transparent !important;
  border: 1px dashed var(--dacs-border) !important;
}
/* Success — pure green bar, no border, no icon */
.status-over-time .status-success,
.status-over-time .status.bg-success {
  background: #10b981 !important;
  border: none !important;
}
/* Failure — pure red bar */
.status-over-time .status-failure,
.status-over-time .status.bg-red-600 {
  background: var(--dacs-danger) !important;
  border: none !important;
}

/* ============================================================
   Footer — discreet
   ============================================================ */
footer {
  background: transparent !important;
  color: var(--dacs-text-tertiary) !important;
  border-top: 1px solid var(--dacs-border);
  font-size: 0.8125rem;
  margin-top: 4rem;
}
