/* ============================================================
   BRIDGEWISE STATUS — Premium Light Theme
   Concept: "Financial Intelligence Dashboard"
   — Clean white surface, deep blue structure, 
     electric accents, confident typography
   ============================================================ */

/* ── Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── Token system ── */
:root {
  --bw-blue:        #2B6CEF;
  --bw-blue-deep:   #1A50CC;
  --bw-blue-light:  #EEF4FF;
  --bw-blue-glow:   rgba(43,108,239,0.15);
  --bw-navy:        #060E1F;
  --bw-ink:         #0F1C3A;
  --bw-ink-mid:     #364062;
  --bw-ink-soft:    #7385A8;
  --bw-surface:     #FFFFFF;
  --bw-surface-2:   #F6F8FD;
  --bw-surface-3:   #EDF2FF;
  --bw-border:      #D8E3F8;
  --bw-border-soft: #EBF0FA;
  --bw-green:       #0EA062;
  --bw-green-bg:    #F0FBF5;
  --bw-yellow:      #D48D0A;
  --bw-red:         #DC3545;
  --bw-cyan:        #88CCFC;
  --radius-card:    20px;
  --radius-row:     12px;
  --shadow-card:    0 1px 3px rgba(15,28,58,0.06), 0 8px 32px rgba(43,108,239,0.08), 0 0 0 1px var(--bw-border);
  --shadow-lifted:  0 4px 20px rgba(43,108,239,0.14), 0 1px 4px rgba(15,28,58,0.08), 0 0 0 1px var(--bw-border);
}

/* ══════════════════════════════════════════
   GLOBAL FONT
   — explicitly exclude .fa / FontAwesome so
     icon glyphs (+ □ ✓ etc.) still render
   ══════════════════════════════════════════ */
*:not(.fa):not([class*="fa-"]):not([class*="icon"]) {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif !important;
}
code, pre, .legend-item-uptime-value,
span[id^="uptime-percent"] {
  font-family: 'JetBrains Mono', monospace !important;
}
/* Ensure FontAwesome pseudo-elements keep their font */
.fa::before,
[class*="fa-"]::before {
  font-family: FontAwesome !important;
}

/* ══════════════════════════════════════════
   BODY — light with structural gradient
   ══════════════════════════════════════════ */
body {
  background-color: #F2F6FF !important;
  background-image:
    radial-gradient(ellipse 70% 45% at 0% 0%, rgba(43,108,239,0.10) 0%, transparent 55%),
    radial-gradient(ellipse 50% 35% at 100% 100%, rgba(136,204,252,0.14) 0%, transparent 55%),
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 47px,
      rgba(43,108,239,0.025) 47px,
      rgba(43,108,239,0.025) 48px
    ),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 47px,
      rgba(43,108,239,0.025) 47px,
      rgba(43,108,239,0.025) 48px
    ) !important;
  background-attachment: fixed !important;
  min-height: 100vh !important;
  color: var(--bw-ink) !important;
}

/* ══════════════════════════════════════════
   MASTHEAD — top bar, no sticky
   ══════════════════════════════════════════ */
.masthead-container {
  background: rgba(255,255,255,0.96) !important;
  border-bottom: 1px solid var(--bw-border-soft) !important;
}
.masthead {
  max-width: 900px !important;
  margin: 0 auto !important;
  padding: 18px 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  box-sizing: border-box !important;
}
/* Constrain the updates dropdown to stay inside the masthead flow */
.updates-dropdown-container {
  position: relative !important;
  top: auto !important;
}

/* ── Bridgewise title (it's h3 > a.color-primary) ── */
.masthead h3 a.color-primary {
  font-size: 22px !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  color: var(--bw-ink) !important;
  text-decoration: none !important;
  background: linear-gradient(135deg, var(--bw-ink) 0%, var(--bw-blue) 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

/* ── Subscribe button ── */
#show-updates-dropdown {
  background: var(--bw-blue) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 11px 22px !important;
  box-shadow: 0 2px 12px rgba(43,108,239,0.4), inset 0 1px 0 rgba(255,255,255,0.2) !important;
  transition: all 0.18s ease !important;
}
#show-updates-dropdown:hover {
  background: var(--bw-blue-deep) !important;
  box-shadow: 0 4px 20px rgba(43,108,239,0.5) !important;
  transform: translateY(-1px) !important;
  color: #fff !important;
}

/* ── Links ── */
a { color: var(--bw-blue) !important; }
a:hover { color: var(--bw-blue-deep) !important; }

/* ── Kill all focus boxes ── */
*:focus, *:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* ══════════════════════════════════════════
   CONTAINER
   ══════════════════════════════════════════ */
.container {
  max-width: 900px !important;
  padding-top: 36px !important;
  padding-bottom: 72px !important;
}

/* ══════════════════════════════════════════
   STATUS BANNER — .page-status.status-none
   ══════════════════════════════════════════ */
.page-status {
  border-radius: var(--radius-card) !important;
  padding: 28px 36px !important;
  margin-bottom: 32px !important;
  position: relative !important;
  overflow: hidden !important;
}

/* ── Operational ── */
.page-status.status-none {
  background: linear-gradient(135deg, #063B22 0%, #0A5730 50%, #0D6E3A 100%) !important;
  box-shadow:
    0 0 0 1px rgba(14,160,98,0.4),
    0 12px 48px rgba(14,160,98,0.18),
    0 2px 8px rgba(0,0,0,0.12) !important;
}
/* Shimmer sweep */
.page-status.status-none::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important; left: -100% !important;
  width: 60% !important; height: 100% !important;
  background: linear-gradient(
    105deg,
    transparent 30%,
    rgba(255,255,255,0.07) 50%,
    transparent 70%
  ) !important;
  animation: shimmer 4s ease-in-out infinite !important;
  pointer-events: none !important;
}
@keyframes shimmer {
  0%   { left: -100%; }
  60%  { left: 150%; }
  100% { left: 150%; }
}
/* Decorative circle glow */
.page-status.status-none::after {
  content: "" !important;
  position: absolute !important;
  right: -60px !important;
  top: -60px !important;
  width: 220px !important;
  height: 220px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(74,222,128,0.18) 0%, transparent 70%) !important;
  pointer-events: none !important;
}
.page-status.status-none h2.status {
  color: #FFFFFF !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  letter-spacing: -0.025em !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  position: relative !important;
  z-index: 1 !important;
}
/* Animated green dot */
.page-status.status-none h2.status::before {
  content: "" !important;
  flex-shrink: 0 !important;
  display: inline-block !important;
  width: 12px !important;
  height: 12px !important;
  border-radius: 50% !important;
  background: #4ADE80 !important;
  box-shadow: 0 0 0 4px rgba(74,222,128,0.25) !important;
  animation: pulse-dot 2.4s cubic-bezier(0.4,0,0.6,1) infinite !important;
}
@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 4px rgba(74,222,128,0.25); }
  50%       { box-shadow: 0 0 0 7px rgba(74,222,128,0.10), 0 0 16px rgba(74,222,128,0.4); }
}
.page-status.status-none .last-updated-stamp {
  color: rgba(255,255,255,0.45) !important;
  font-size: 11px !important;
  margin-top: 6px !important;
  position: relative !important;
  z-index: 1 !important;
}

/* ── Degraded ── */
.page-status.status-minor {
  background: linear-gradient(135deg, #3D2000 0%, #5C3200 100%) !important;
  box-shadow: 0 0 0 1px rgba(212,141,10,0.4), 0 12px 48px rgba(212,141,10,0.16) !important;
}
.page-status.status-minor h2 { color: #FCD34D !important; font-size: 22px !important; font-weight: 800 !important; margin: 0 !important; }

/* ── Critical ── */
.page-status.status-critical {
  background: linear-gradient(135deg, #3B0A0A 0%, #5A1010 100%) !important;
  box-shadow: 0 0 0 1px rgba(220,53,69,0.4), 0 12px 48px rgba(220,53,69,0.16) !important;
}
.page-status.status-critical h2 { color: #FCA5A5 !important; font-size: 22px !important; font-weight: 800 !important; margin: 0 !important; }

/* ══════════════════════════════════════════
   UPTIME LABEL ROW
   ══════════════════════════════════════════ */
.components-uptime-link {
  color: var(--bw-ink-soft) !important;
  font-size: 12px !important;
}
.components-uptime-link a {
  color: var(--bw-blue) !important;
  font-weight: 600 !important;
}

/* ══════════════════════════════════════════
   COMPONENT SECTION CARD
   ══════════════════════════════════════════ */
.components-section {
  background: var(--bw-surface) !important;
  border-radius: var(--radius-card) !important;
  overflow: hidden !important;
  margin-bottom: 20px !important;
  box-shadow: var(--shadow-card) !important;
  border: none !important;
}

/* ── Group container (the outer .component-container.is-group) ── */
.component-container.is-group {
  position: relative !important;
}
/* Bold left accent line on each group */
.component-container.is-group::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 4px !important;
  background: linear-gradient(180deg, var(--bw-blue) 0%, #88CCFC 100%) !important;
  border-radius: 0 4px 4px 0 !important;
}
/* Separate groups with a faint line */
.component-container.is-group + .component-container.is-group {
  border-top: 1px solid var(--bw-border-soft) !important;
}

/* ══════════════════════════════════════════
   COMPONENT ROWS
   ══════════════════════════════════════════ */
.component-inner-container {
  padding: 18px 24px 18px 28px !important;
  border-top: 1px solid var(--bw-border-soft) !important;
  transition: background 0.14s ease, transform 0.1s ease !important;
  background: transparent !important;
  position: relative !important;
}
.component-inner-container:first-child {
  border-top: none !important;
}
.component-inner-container:hover {
  background: var(--bw-blue-light) !important;
}
.component-inner-container:hover span.name {
  color: var(--bw-blue) !important;
}

/* ── Component name ── */
.component-inner-container span.name {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--bw-ink) !important;
  letter-spacing: -0.01em !important;
  transition: color 0.14s !important;
}

/* ── Group parent name (bigger, bolder) ── */
.component-inner-container[data-js-hook="component-group-opener"] span.name {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--bw-ink) !important;
}

/* ── EXPAND ICON — all SP class combinations ── */
.group-parent-indicator,
span.fa.group-parent-indicator,
.fa.group-parent-indicator.color-secondary,
.component-inner-container .fa.group-parent-indicator {
  color: var(--bw-blue) !important;
  opacity: 0.75 !important;
  transition: opacity 0.15s !important;
  font-size: 15px !important;
}
.component-inner-container:hover .group-parent-indicator {
  opacity: 1 !important;
}
/* SP's .color-secondary rule was killing the icon — override everywhere in rows */
.component-inner-container .color-secondary,
.component-inner-container span.color-secondary {
  color: var(--bw-blue) !important;
}

/* ── Status text ── */
.component-inner-container span.component-status {
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  padding: 3px 10px !important;
  border-radius: 20px !important;
}
/* Operational */
.component-inner-container.status-green span.component-status {
  color: var(--bw-green) !important;
  background: var(--bw-green-bg) !important;
}
/* Degraded */
.component-inner-container.status-yellow span.component-status {
  color: #925E00 !important;
  background: #FFF8E6 !important;
}
/* Partial outage */
.component-inner-container.status-orange span.component-status {
  color: #B84A00 !important;
  background: #FFF2E8 !important;
}
/* Major outage */
.component-inner-container.status-red span.component-status {
  color: #A8000F !important;
  background: #FFF0F1 !important;
}
/* Maintenance */
.component-inner-container.status-blue span.component-status {
  color: #1144B8 !important;
  background: #EEF4FF !important;
}

/* ── Expand button (fa icon button) ── */
button.tool.icon-indicator {
  outline: none !important;
  box-shadow: none !important;
  border: none !important;
  background: none !important;
  color: var(--bw-blue) !important;
  opacity: 0.7 !important;
  transition: opacity 0.15s !important;
  font-size: 14px !important;
}
button.tool.icon-indicator:hover { opacity: 1 !important; }
button.tool.icon-indicator:focus { outline: none !important; box-shadow: none !important; }

/* ══════════════════════════════════════════
   UPTIME BARS — all fill values addressed
   ══════════════════════════════════════════ */

/* Default (should never show as raw) */
.uptime-day {
  fill: var(--bw-blue) !important;
  opacity: 0.8 !important;
}
.uptime-day:hover { opacity: 1 !important; }

/* ── OPERATIONAL days: #1e8542 / #2fcc66 → vivid Bridgewise blue ── */
.uptime-day[fill="#1e8542"],
.uptime-day[fill="#2fcc66"] {
  fill: #2B6CEF !important;
  opacity: 0.85 !important;
}

/* ── NO DATA days: #b3bac5 → clearly different: very light blue-grey ── */
/* This is the key fix: must look obviously "empty/unknown" vs the blue bars */
.uptime-day[fill="#b3bac5"] {
  fill: #DDE5F5 !important;
  opacity: 1 !important;
}

/* ── Major outage: vivid red ── */
.uptime-day[fill="#de2f1b"],
.uptime-day[fill="#cc0000"],
.uptime-day[fill="#e8473f"],
.uptime-day[fill="#e74c3c"] {
  fill: #F03E3E !important;
  opacity: 1 !important;
}

/* ── Partial outage: amber ── */
.uptime-day[fill="#f1a900"],
.uptime-day[fill="#f0a500"],
.uptime-day[fill="#b35e14"],
.uptime-day[fill="#f39c12"] {
  fill: #F59E0B !important;
  opacity: 1 !important;
}

/* ── Maintenance: purple-blue ── */
.uptime-day[fill="#207ab6"] {
  fill: #6C8EE8 !important;
  opacity: 0.9 !important;
}

/* ══════════════════════════════════════════
   UPTIME LEGEND
   ══════════════════════════════════════════ */
.layout-content.status .shared-partial.uptime-90-days-wrapper .legend .legend-item {
  color: var(--bw-ink-soft) !important;
  opacity: 1 !important;
}
.layout-content.status .shared-partial.uptime-90-days-wrapper .legend .legend-item.light {
  color: var(--bw-border) !important;
  opacity: 1 !important;
}
.legend-item { font-size: 11px !important; color: var(--bw-ink-soft) !important; }
.legend-item.light { color: #B0BDD8 !important; }
.legend-item-uptime-value {
  color: var(--bw-ink) !important;
  font-weight: 600 !important;
  font-size: 11px !important;
}
.legend .spacer {
  background: var(--bw-border) !important;
  opacity: 1 !important;
}
/* Override SP's grey color rule on legend */
.layout-content.status .shared-partial.uptime-90-days-wrapper .legend .spacer {
  background: var(--bw-border) !important;
  opacity: 1 !important;
}

/* ══════════════════════════════════════════
   CHILD COMPONENT CONTAINER
   ══════════════════════════════════════════ */
.child-components-container {
  background: var(--bw-surface-2) !important;
}
.child-components-container .component-inner-container {
  padding-left: 44px !important;
}
.child-components-container .component-inner-container:hover {
  background: var(--bw-blue-light) !important;
}

/* ══════════════════════════════════════════
   PAST INCIDENTS
   ══════════════════════════════════════════ */
.incidents-list h2 {
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--bw-ink-soft) !important;
  border-bottom: 2px solid var(--bw-border) !important;
  padding-bottom: 14px !important;
  margin-bottom: 20px !important;
}
.status-day .date {
  font-weight: 700 !important;
  font-size: 13px !important;
  color: var(--bw-ink-mid) !important;
  border-bottom: 1px solid var(--bw-border-soft) !important;
  padding-bottom: 8px !important;
  margin-bottom: 12px !important;
}
.no-incidents p {
  color: var(--bw-ink-soft) !important;
  font-size: 13px !important;
  font-style: italic !important;
}
.incidents-list .incident {
  background: var(--bw-surface) !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 14px !important;
  padding: 20px 24px !important;
  margin-bottom: 12px !important;
  box-shadow: 0 2px 8px rgba(43,108,239,0.05) !important;
}
.incident-title a {
  color: var(--bw-ink) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
}
.incident-title a:hover { color: var(--bw-blue) !important; }

/* ══════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════ */
.page-footer {
  color: var(--bw-ink-soft) !important;
  font-size: 12px !important;
  border-top: 1px solid var(--bw-border) !important;
  margin-top: 48px !important;
  padding-top: 24px !important;
}
.page-footer a {
  color: var(--bw-ink-soft) !important;
}
.page-footer a:hover { color: var(--bw-blue) !important; }

/* ══════════════════════════════════════════
   STATUS LEGEND ROW
   ══════════════════════════════════════════ */
.component-statuses-legend {
  border-top: 1px solid var(--bw-border-soft) !important;
  padding: 14px 24px !important;
  background: var(--bw-surface-2) !important;
  gap: 20px !important;
}
.component-statuses-legend .legend-item {
  font-size: 11px !important;
  color: var(--bw-ink-mid) !important;
  font-weight: 500 !important;
}

/* ══════════════════════════════════════════
   TOOLTIP — complete overhaul
   ══════════════════════════════════════════ */
#uptime-tooltip .tooltip-box {
  background: #0F1C3A !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 12px !important;
  box-shadow: 0 16px 48px rgba(0,0,0,0.28), 0 4px 12px rgba(0,0,0,0.16) !important;
  min-width: 220px !important;
}
/* Date */
#uptime-tooltip .tooltip-box .tooltip-content .date {
  color: rgba(255,255,255,0.45) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
}
/* Outage field rows */
#uptime-tooltip .tooltip-box .outage-field {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.08) !important;
  border-radius: 8px !important;
  padding: 8px 10px !important;
  margin-top: 8px !important;
}
/* Label text: "Partial outage" / "Major outage" */
#uptime-tooltip .tooltip-box .outage-field .label {
  color: rgba(255,255,255,0.85) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}
/* Hours and minutes values */
#uptime-tooltip .tooltip-box .outage-field .value-hrs,
#uptime-tooltip .tooltip-box .outage-field .value-mins {
  color: #ffffff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}
/* The colored icon dot inside the label (SP renders via color) */
#uptime-tooltip .tooltip-box .outage-field .label i.component-status {
  display: inline-block !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: currentColor !important;
  margin-right: 6px !important;
  vertical-align: middle !important;
}
/* Incident count rows for groups */
#uptime-tooltip .outage-count {
  color: rgba(255,255,255,0.75) !important;
  font-size: 12px !important;
}
#uptime-tooltip .outage-count .count {
  color: #ffffff !important;
  font-weight: 700 !important;
}
/* No-outage and no-data messages */
#uptime-tooltip .tooltip-box .no-outages-msg,
#uptime-tooltip .tooltip-box .no-data-msg {
  color: rgba(255,255,255,0.55) !important;
  font-size: 12px !important;
  font-style: italic !important;
}
/* Related events section */
#uptime-tooltip .tooltip-box .related-events #related-event-header {
  color: rgba(255,255,255,0.35) !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
}
#uptime-tooltip .tooltip-box .related-events .related-event-link {
  color: #88CCFC !important;
  font-size: 12px !important;
}
/* Pointer arrow */
#uptime-tooltip .pointer-container .pointer-smaller {
  border-bottom-color: #0F1C3A !important;
}
#uptime-tooltip .pointer-container .pointer-larger {
  border-bottom-color: rgba(255,255,255,0.12) !important;
}

/* ══════════════════════════════════════════
   SUBSCRIBE MODAL DROPDOWN
   ══════════════════════════════════════════ */
.updates-dropdown {
  border-radius: 16px !important;
  border: 1px solid var(--bw-border) !important;
  box-shadow: 0 20px 60px rgba(43,108,239,0.15), 0 4px 16px rgba(0,0,0,0.08) !important;
}

/* ══════════════════════════════════════════
   ANIMATIONS — page load fade-in
   ══════════════════════════════════════════ */
.page-status {
  animation: fadeUp 0.5s ease both !important;
}
.components-section {
  animation: fadeUp 0.5s ease both !important;
}
.components-section:nth-child(2) { animation-delay: 0.06s !important; }
.components-section:nth-child(3) { animation-delay: 0.12s !important; }
.components-section:nth-child(4) { animation-delay: 0.18s !important; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}