/* Critical: ensure [hidden] attribute always hides elements even when a CSS class sets display explicitly */
[hidden] { display: none !important; }

/* ═══════════════════════════════════════════════════════════════════
   CONNECT QUEST — INFRASTRUCTURE STATUS PAGE
   status.connectquest.co.in  ·  assets/style.css

   Aesthetic: Bright Corporate — Clean, Professional, Trustworthy
   Fonts: Outfit (display) + IBM Plex Mono (data)
   Brand: CQ Green #0f9d58 on cream background
   ═══════════════════════════════════════════════════════════════════ */

/* ── Custom properties ──────────────────────────────────────────── */
:root {
  /* Backgrounds - Bright Cream Corporate */
  --bg-root:      #faf7f2;  /* Warm cream base */
  --bg-base:      #ffffff;   /* Clean white */
  --bg-surface:   #ffffff;   /* Pure white */
  --bg-elevated:  #f5f0e8;   /* Soft cream */
  --bg-card:      #ffffff;   /* White */
  --bg-input:     #ffffff;

  /* Borders - Soft and subtle */
  --bd:           rgba(0,0,0,0.08);
  --bd-strong:    rgba(0,0,0,0.15);
  --bd-focus:     rgba(15,157,88,0.4);

  /* Text - Dark for contrast on cream */
  --tx:           #1e1e1e;   /* Near black */
  --tx-2:         #4a4a4a;   /* Dark gray */
  --tx-3:         #6b6b6b;   /* Medium gray */
  --tx-4:         #909090;   /* Light gray */

  /* CQ Brand Green */
  --green:        #0f9d58;   /* Primary green */
  --green-br:     #2dbd6e;   /* Brighter green */
  --green-dk:     #0b7a3e;   /* Dark green */
  --green-glow:   rgba(15,157,88,0.15);
  --green-dim:    rgba(15,157,88,0.06);

  /* Status colours - Vibrant and prominent */
  --up:           #0f9d58;   /* Green - Operational */
  --up-dim:       rgba(15,157,88,0.08);
  --up-glow:      rgba(15,157,88,0.2);
  
  --down:         #dc2626;   /* Red - Outage */
  --down-dim:     rgba(220,38,38,0.06);
  --down-glow:    rgba(220,38,38,0.15);
  
  --warn:         #f97316;   /* Orange - Degraded/Partial */
  --warn-dim:     rgba(249,115,22,0.06);
  --warn-glow:    rgba(249,115,22,0.15);
  
  --pause:        #6b7280;   /* Gray - Maintenance */
  --pause-dim:    rgba(107,114,128,0.06);

  /* Typography */
  --f-display:    'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-mono:       'IBM Plex Mono', 'SF Mono', monospace;

  /* Radii */
  --r-sm:         6px;
  --r-md:         8px;
  --r-lg:         12px;
  --r-xl:         16px;

  /* Shadows - Soft for corporate look */
  --shadow-sm:    0 2px 4px rgba(0,0,0,0.02);
  --shadow-md:    0 4px 8px rgba(0,0,0,0.04);
  --shadow-lg:    0 8px 16px rgba(0,0,0,0.06);

  /* Transitions */
  --t:            0.15s ease;
  --t-slow:       0.3s ease;
}

/* ── Reset ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family:    var(--f-display);
  background:     var(--bg-root);
  color:          var(--tx);
  min-height:     100vh;
  line-height:    1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x:     hidden;
}

/* Subtle corporate pattern */
body::before {
  content:          '';
  position:         fixed;
  inset:            0;
  background-image: radial-gradient(circle at 25px 25px, rgba(0,0,0,0.02) 1px, transparent 1px);
  background-size:  50px 50px;
  pointer-events:   none;
  z-index:          0;
}

/* ══════════════════════════════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════════════════════════════ */
.wrap {
  max-width: 1200px;
  margin:    0 auto;
  padding:   0 24px;
  position:  relative;
  z-index:   1;
}

/* ══════════════════════════════════════════════════════════════════
   TOPBAR
   ══════════════════════════════════════════════════════════════════ */
.topbar {
  position:        sticky;
  top:             0;
  z-index:         500;
  background:      rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom:   1px solid var(--bd);
  box-shadow:      var(--shadow-sm);
}
.topbar-inner {
  height:          64px;
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             24px;
}

/* Brand */
.topbar-brand {
  display:         flex;
  align-items:     center;
  gap:             16px;
  text-decoration: none;
  flex-shrink:     0;
}
.brand-logo {
  height:          32px;
  width:           auto;
  display:         block;
}
.brand-logo-fallback {
  font-size:       18px;
  font-weight:     800;
  color:           var(--green);
  letter-spacing:  -.02em;
  display:         none;
}
.brand-sep {
  width:           1px;
  height:          24px;
  background:      var(--bd-strong);
  flex-shrink:     0;
}
.brand-label {
  font-size:       14px;
  font-weight:     500;
  color:           var(--tx-2);
  letter-spacing:  .01em;
}

/* Status pill in topbar */
.topbar-status {
  display:         flex;
  align-items:     center;
  gap:             12px;
  flex:            1;
  justify-content: center;
}
.pulse-wrap {
  position:        relative;
  width:           14px;
  height:          14px;
  flex-shrink:     0;
}
.pulse-dot {
  position:        absolute;
  inset:           2px;
  border-radius:   50%;
  background:      var(--tx-3);
  transition:      background 0.4s;
  z-index:         1;
}
.pulse-dot.is-up   { background: var(--up); }
.pulse-dot.is-down { background: var(--down); }
.pulse-dot.is-warn { background: var(--warn); }
.pulse-ring {
  position:        absolute;
  inset:           0;
  border-radius:   50%;
  border:          2px solid;
  opacity:         0;
  animation:       pulse-anim 2s ease-out infinite;
}
.pulse-dot.is-up + .pulse-ring   { border-color: var(--up); }
.pulse-dot.is-down + .pulse-ring { border-color: var(--down); }
.pulse-dot.is-warn + .pulse-ring { border-color: var(--warn); }

@keyframes pulse-anim {
  0%   { transform: scale(.6);  opacity: .8; }
  100% { transform: scale(2.2); opacity: 0;  }
}
.topbar-status-text {
  font-size:       14px;
  font-weight:     600;
  color:           var(--tx-2);
  transition:      color var(--t);
}
.topbar-status-text.is-up   { color: var(--up); }
.topbar-status-text.is-down { color: var(--down); }
.topbar-status-text.is-warn { color: var(--warn); }

/* Topbar right */
.topbar-right {
  display:         flex;
  align-items:     center;
  gap:             16px;
  flex-shrink:     0;
}
.countdown-chip {
  font-family:     var(--f-mono);
  font-size:       12px;
  color:           var(--tx-2);
  background:      var(--bg-elevated);
  border:          1px solid var(--bd);
  border-radius:   20px;
  padding:         6px 14px;
  white-space:     nowrap;
  font-weight:     500;
}
.countdown-chip b { color: var(--tx); }

.btn-refresh {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  font-family:     var(--f-display);
  font-size:       13px;
  font-weight:     500;
  color:           var(--tx-2);
  background:      var(--bg-elevated);
  border:          1px solid var(--bd);
  border-radius:   var(--r-sm);
  padding:         8px 16px;
  cursor:          pointer;
  transition:      var(--t);
  white-space:     nowrap;
}
.btn-refresh:hover {
  color:           var(--green);
  border-color:    var(--green);
  background:      var(--green-dim);
}
.btn-refresh.spinning svg { animation: spin .5s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════════════════
   HERO BANNER
   ══════════════════════════════════════════════════════════════════ */
.hero {
  position:        relative;
  overflow:        hidden;
  padding:         64px 0 60px;
  background:      var(--bg-base);
  border-bottom:   1px solid var(--bd);
  transition:      background 0.6s;
}
.hero[data-state="ok"] {
  background: linear-gradient(135deg, #ffffff 0%, #f0f7f2 100%);
  border-bottom: 2px solid var(--up);
}
.hero[data-state="partial"] {
  background: linear-gradient(135deg, #ffffff 0%, #fff4e6 100%);
  border-bottom: 2px solid var(--warn);
}
.hero[data-state="major"] {
  background: linear-gradient(135deg, #ffffff 0%, #ffeaea 100%);
  border-bottom: 2px solid var(--down);
}

/* Subtle pattern overlay */
.hero-grain {
  position:        absolute;
  inset:           0;
  pointer-events:  none;
  opacity:         .3;
  background-image: radial-gradient(circle at 1px 1px, rgba(0,0,0,0.02) 1px, transparent 0);
  background-size: 20px 20px;
}

.hero-inner {
  position:        relative;
  z-index:         1;
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  text-align:      center;
  gap:             16px;
}

.hero-icon {
  width:           80px;
  height:          80px;
  border-radius:   50%;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       32px;
  background:      var(--bg-base);
  border:          2px solid;
  transition:      all 0.5s;
  margin-bottom:   8px;
  box-shadow:      var(--shadow-lg);
}
.hero-icon.is-up {
  border-color:    var(--up);
  background:      linear-gradient(135deg, #ffffff, #f0f9f4);
  color:           var(--up);
}
.hero-icon.is-warn {
  border-color:    var(--warn);
  background:      linear-gradient(135deg, #ffffff, #fff7ed);
  color:           var(--warn);
}
.hero-icon.is-down {
  border-color:    var(--down);
  background:      linear-gradient(135deg, #ffffff, #fef2f2);
  color:           var(--down);
}

.hero-title {
  font-size:       clamp(28px, 5vw, 42px);
  font-weight:     700;
  letter-spacing:  -.02em;
  color:           var(--tx);
  line-height:     1.2;
}
.hero-sub {
  font-size:       16px;
  color:           var(--tx-2);
  max-width:       600px;
}
.hero-meta {
  font-family:     var(--f-mono);
  font-size:       12px;
  color:           var(--tx-3);
  margin-top:      8px;
}
.hero-meta b { color: var(--tx); }

/* ══════════════════════════════════════════════════════════════════
   METRICS STRIP
   ══════════════════════════════════════════════════════════════════ */
.metrics-strip {
  background:      var(--bg-base);
  border-bottom:   1px solid var(--bd);
  position:        relative;
  z-index:         1;
  box-shadow:      var(--shadow-sm);
}
.metrics-row {
  display:         flex;
  overflow-x:      auto;
  scrollbar-width: none;
}
.metrics-row::-webkit-scrollbar { display: none; }

.metric {
  flex:            1;
  min-width:       120px;
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  padding:         24px 16px;
  border-right:    1px solid var(--bd);
  gap:             8px;
  transition:      background var(--t);
}
.metric:last-child { border-right: none; }
.metric:hover      { background: var(--bg-elevated); }

.metric-val {
  font-family:     var(--f-mono);
  font-size:       30px;
  font-weight:     700;
  color:           var(--tx);
  line-height:     1;
  letter-spacing:  -.02em;
}
.metric-key {
  font-size:       12px;
  font-weight:     600;
  color:           var(--tx-3);
  text-transform:  uppercase;
  letter-spacing:  .05em;
}
.metric.m-up   .metric-val { color: var(--up); }
.metric.m-down .metric-val { color: var(--down); }
.metric.m-warn .metric-val { color: var(--warn); }

/* ══════════════════════════════════════════════════════════════════
   MAIN CONTENT
   ══════════════════════════════════════════════════════════════════ */
.main-content {
  padding:         48px 0 80px;
  display:         flex;
  flex-direction:  column;
  gap:             32px;
  position:        relative;
  z-index:         1;
}

/* Section heading */
.section-head {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             16px;
  margin-bottom:   20px;
}
.section-title {
  font-size:       14px;
  font-weight:     700;
  color:           var(--tx-2);
  text-transform:  uppercase;
  letter-spacing:  .08em;
  display:         flex;
  align-items:     center;
  gap:             10px;
}
.section-title svg { opacity: .8; }

/* ── Error block ── */
.error-block {
  background:      var(--bg-surface);
  border:          1px solid var(--bd);
  border-radius:   var(--r-lg);
  padding:         80px 40px;
  text-align:      center;
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             16px;
  box-shadow:      var(--shadow-lg);
}
.error-block h3  { font-size: 20px; font-weight: 700; color: var(--down); }
.error-block p   { font-size: 15px; color: var(--tx-2); max-width: 420px; }
.btn-primary {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  font-family:     var(--f-display);
  font-size:       14px;
  font-weight:     600;
  color:           #ffffff;
  background:      var(--green);
  border:          none;
  border-radius:   var(--r-sm);
  padding:         12px 28px;
  cursor:          pointer;
  transition:      all var(--t);
  margin-top:      8px;
  box-shadow:      0 4px 12px var(--green-dim);
}
.btn-primary:hover { 
  background:      var(--green-br);
  transform:       translateY(-2px);
  box-shadow:      0 6px 16px var(--green-dim);
}

/* ── Skeleton ── */
.skeleton {
  background:      var(--bg-surface);
  border:          1px solid var(--bd);
  border-radius:   var(--r-lg);
  overflow:        hidden;
  box-shadow:      var(--shadow-md);
}
.skel-header {
  height:          48px;
  background:      var(--bg-elevated);
  border-bottom:   1px solid var(--bd);
}
.skel-row {
  height:          60px;
  border-bottom:   1px solid var(--bd);
  background:      linear-gradient(90deg, var(--bg-surface) 25%, var(--bg-elevated) 50%, var(--bg-surface) 75%);
  background-size: 400% 100%;
  animation:       shimmer 1.8s ease infinite;
}
.skel-row:last-child { border-bottom: none; }
@keyframes shimmer {
  0%   { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

/* ══════════════════════════════════════════════════════════════════
   SERVICES TABLE
   ══════════════════════════════════════════════════════════════════ */
.services-block {
  background:      var(--bg-surface);
  border:          1px solid var(--bd);
  border-radius:   var(--r-lg);
  overflow:        hidden;
  box-shadow:      var(--shadow-lg);
}

.tbl-header {
  display:         grid;
  grid-template-columns: 1fr 140px 90px 90px 90px;
  align-items:     center;
  gap:             12px;
  padding:         16px 24px;
  background:      var(--bg-elevated);
  border-bottom:   1px solid var(--bd);
  font-size:       12px;
  font-weight:     700;
  color:           var(--tx-2);
  text-transform:  uppercase;
  letter-spacing:  .06em;
}

.service-row {
  display:         grid;
  grid-template-columns: 1fr 140px 90px 90px 90px;
  align-items:     center;
  gap:             12px;
  padding:         0 24px;
  border-bottom:   1px solid var(--bd);
  cursor:          pointer;
  transition:      background var(--t);
  position:        relative;
  overflow:        hidden;
}
.service-row:last-child { border-bottom: none; }
.service-row:hover      { background: var(--bg-elevated); }
.service-row.is-active  { background: var(--green-dim); }

/* Left accent stripe - more prominent */
.service-row::before {
  content:         '';
  position:        absolute;
  left:            0; top: 0; bottom: 0;
  width:           4px;
  border-radius:   0 2px 2px 0;
  background:      transparent;
  transition:      background var(--t);
}
.service-row.st-up::before   { background: var(--up); }
.service-row.st-down::before { background: var(--down); }
.service-row.st-warn::before { background: var(--warn); }

.row-inner {
  padding:         18px 0;
}
.row-name {
  font-size:       15px;
  font-weight:     600;
  color:           var(--tx);
  white-space:     nowrap;
  overflow:        hidden;
  text-overflow:   ellipsis;
}
.row-name::after {
  content: ' →';
  font-size: 13px;
  color: #9ca3af;
  opacity: 0;
  transition: opacity 0.15s;
  margin-left: 4px;
}
.service-row:hover .row-name::after { opacity: 1; color: var(--green); }

.row-sub {
  font-size:       12px;
  color:           var(--tx-3);
  margin-top:      4px;
  font-family:     var(--f-mono);
}

/* Status badge - more vibrant */
.badge {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  font-size:       13px;
  font-weight:     600;
  padding:         6px 14px;
  border-radius:   20px;
  white-space:     nowrap;
}
.badge-dot {
  width:           8px;
  height:          8px;
  border-radius:   50%;
  flex-shrink:     0;
}
.badge.st-up     { 
  color: var(--up);   
  background: var(--up-dim);   
  border: 1px solid var(--up-dim);
}
.badge.st-down   { 
  color: var(--down); 
  background: var(--down-dim); 
  border: 1px solid var(--down-dim);
}
.badge.st-warn   { 
  color: var(--warn); 
  background: var(--warn-dim); 
  border: 1px solid var(--warn-dim);
}
.badge.st-pause  { 
  color: var(--pause); 
  background: var(--pause-dim); 
  border: 1px solid var(--pause-dim);
}
.badge.st-up   .badge-dot { background: var(--up);   }
.badge.st-down .badge-dot { background: var(--down); }
.badge.st-warn .badge-dot { background: var(--warn); }
.badge.st-pause .badge-dot { background: var(--pause); }

/* Uptime cells */
.uptime-cell {
  font-family:     var(--f-mono);
  font-size:       13px;
  font-weight:     600;
  line-height:     1.4;
}
.uptime-cell .val-pct { display: block; }
.up-bar {
  height:          4px;
  margin-top:      6px;
  background:      var(--bg-elevated);
  border-radius:   2px;
  overflow:        hidden;
}
.up-fill {
  height:          100%;
  border-radius:   2px;
  transition:      width .8s ease;
}
.up-fill.cl-good { background: var(--up); }
.up-fill.cl-ok   { background: var(--warn); }
.up-fill.cl-bad  { background: var(--down); }
.cl-good { color: var(--up); }
.cl-ok   { color: var(--warn); }
.cl-bad  { color: var(--down); }
.cl-dim  { color: var(--tx-3); }

/* Expand chevron */
.row-chevron {
  display:         flex;
  align-items:     center;
  justify-content: flex-end;
  color:           var(--tx-3);
  transition:      transform var(--t), color var(--t);
}
.service-row.expanded .row-chevron { transform: rotate(90deg); color: var(--green); }

/* ── Expandable detail panel ── */
.detail-panel {
  display:         none;
  grid-column:     1 / -1;
  padding:         0 0 24px 0;
  animation:       slideDown .2s ease;
}
.detail-panel.open { display: block; }
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.detail-grid {
  display:         grid;
  grid-template-columns: repeat(3, 1fr);
  gap:             16px;
  margin-bottom:   20px;
  padding:         0 0 0 4px;
}
.detail-stat {
  background:      var(--bg-card);
  border:          1px solid var(--bd);
  border-radius:   var(--r-md);
  padding:         16px 20px;
  text-align:      center;
  box-shadow:      var(--shadow-sm);
}
.detail-stat-val {
  font-family:     var(--f-mono);
  font-size:       24px;
  font-weight:     700;
  display:         block;
  margin-bottom:   4px;
}
.detail-stat-lbl {
  font-size:       12px;
  color:           var(--tx-3);
  text-transform:  uppercase;
  letter-spacing:  .05em;
}

/* 90-day mini grid inside detail */
.detail-grid-title {
  font-size:       12px;
  font-weight:     700;
  color:           var(--tx-2);
  text-transform:  uppercase;
  letter-spacing:  .06em;
  margin-bottom:   12px;
}
.day-grid {
  display:         flex;
  flex-wrap:       wrap;
  gap:             4px;
  margin-bottom:   12px;
}
.day-block {
  width:           12px;
  height:          22px;
  border-radius:   2px;
  background:      var(--bg-elevated);
  cursor:          default;
  transition:      transform .1s;
  flex-shrink:     0;
}
.day-block:hover { transform: scaleY(1.3); }
.day-block.d-up   { background: var(--up); }
.day-block.d-down { background: var(--down); }
.day-block.d-warn { background: var(--warn); }

.day-legend {
  display:         flex;
  align-items:     center;
  gap:             12px;
  font-size:       12px;
  color:           var(--tx-3);
  margin-bottom:   20px;
}
.leg-block {
  width:           12px;
  height:          12px;
  border-radius:   2px;
  flex-shrink:     0;
}
.leg-block.leg-up   { background: var(--up); }
.leg-block.leg-down { background: var(--down); }
.leg-block.leg-warn { background: var(--warn); }

/* Incident list inside detail */
.incident-list {
  display:         flex;
  flex-direction:  column;
  gap:             10px;
}
.incident-row {
  display:         grid;
  grid-template-columns: auto 1fr auto auto;
  align-items:     center;
  gap:             14px;
  padding:         12px 16px;
  background:      var(--bg-card);
  border-radius:   var(--r-md);
  border-left:     4px solid;
  font-size:       14px;
  box-shadow:      var(--shadow-sm);
}
.incident-row.inc-down     { border-left-color: var(--down); }
.incident-row.inc-warn     { border-left-color: var(--warn); }
.incident-row.inc-up       { border-left-color: var(--up); }
.inc-dot {
  width:           10px;
  height:          10px;
  border-radius:   50%;
  flex-shrink:     0;
}
.dot-down { background: var(--down); }
.dot-warn { background: var(--warn); }
.dot-up   { background: var(--up); }
.inc-event { font-weight: 600; }
.inc-down .inc-event { color: var(--down); }
.inc-warn .inc-event { color: var(--warn); }
.inc-up   .inc-event { color: var(--up); }
.inc-date, .inc-dur, .inc-ago {
  font-family:     var(--f-mono);
  font-size:       12px;
  color:           var(--tx-2);
  white-space:     nowrap;
}
.inc-dur, .inc-ago { color: var(--tx-3); }
.no-incidents {
  font-size:       14px;
  color:           var(--tx-3);
  text-align:      center;
  padding:         24px;
  font-style:      italic;
}

/* ══════════════════════════════════════════════════════════════════
   GLOBAL INCIDENT LOG PANEL
   ══════════════════════════════════════════════════════════════════ */
.panel {
  background:      var(--bg-surface);
  border:          1px solid var(--bd);
  border-radius:   var(--r-lg);
  padding:         28px 28px 30px;
  box-shadow:      var(--shadow-lg);
}
.panel-header {
  display:         flex;
  align-items:     center;
  gap:             12px;
  margin-bottom:   24px;
}
.panel-title {
  font-size:       16px;
  font-weight:     700;
  color:           var(--tx);
}
.panel-title-icon {
  width:           36px;
  height:          36px;
  border-radius:   var(--r-sm);
  background:      var(--bg-elevated);
  border:          1px solid var(--bd);
  display:         flex;
  align-items:     center;
  justify-content: center;
  flex-shrink:     0;
}
.panel-sub {
  font-family:     var(--f-mono);
  font-size:       12px;
  color:           var(--tx-3);
  margin-left:     auto;
}

.global-incident-list {
  display:         flex;
  flex-direction:  column;
  gap:             12px;
}
.global-incident-item {
  padding:         16px 20px;
  background:      var(--bg-elevated);
  border-radius:   var(--r-md);
  border-left:     4px solid;
  box-shadow:      var(--shadow-sm);
}
.global-incident-item.gi-down     { border-left-color: var(--down); }
.global-incident-item.gi-warn     { border-left-color: var(--warn); }
.global-incident-item.gi-up       { border-left-color: var(--up); }
.gi-name {
  font-size:       14px;
  font-weight:     600;
  color:           var(--tx);
  margin-bottom:   6px;
}
.gi-meta {
  font-family:     var(--f-mono);
  font-size:       12px;
  color:           var(--tx-3);
  display:         flex;
  flex-wrap:       wrap;
  gap:             16px;
}
.gi-status-down { color: var(--down); }
.gi-status-warn { color: var(--warn); }
.gi-status-up   { color: var(--up); }

/* ══════════════════════════════════════════════════════════════════
   MODAL OVERLAY — Service detail modal
   ══════════════════════════════════════════════════════════════════ */

/* Overlay backdrop */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
}
.modal-overlay.open {
  opacity: 1;
  pointer-events: all;
}

/* Modal box - bright cream corporate */
.modal-box {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 20px;
  width: 100%;
  max-width: 620px;
  max-height: 88vh;
  overflow-y: auto;
  position: relative;
  transform: translateY(24px) scale(0.98);
  transition: transform 0.26s cubic-bezier(0.34,1.56,0.64,1);
  scrollbar-width: thin;
  scrollbar-color: rgba(15,157,88,0.3) transparent;
  box-shadow: 0 20px 40px rgba(0,0,0,0.08), 0 8px 16px rgba(0,0,0,0.06);
}
.modal-overlay.open .modal-box {
  transform: translateY(0) scale(1);
}
.modal-box::-webkit-scrollbar { width: 4px; }
.modal-box::-webkit-scrollbar-track { background: transparent; }
.modal-box::-webkit-scrollbar-thumb { background: rgba(15,157,88,0.2); border-radius: 4px; }

/* Modal header bar with status colour accent */
.modal-header {
  padding: 24px 28px 22px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: #ffffff;
}
.modal-status-orb {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 700;
  background: #ffffff;
  border: 2px solid;
  box-shadow: 0 8px 16px rgba(0,0,0,0.04);
  transition: all 0.3s;
}
.modal-status-orb.orb-up    { border-color: var(--up); color: var(--up); background: linear-gradient(135deg, #ffffff, #f0f9f4); }
.modal-status-orb.orb-down  { border-color: var(--down); color: var(--down); background: linear-gradient(135deg, #ffffff, #fef2f2); }
.modal-status-orb.orb-warn  { border-color: var(--warn); color: var(--warn); background: linear-gradient(135deg, #ffffff, #fff7ed); }
.modal-status-orb.orb-pause { border-color: var(--pause); color: var(--pause); background: linear-gradient(135deg, #ffffff, #f9fafb); }

.modal-title-block { flex: 1; min-width: 0; }
.modal-service-name {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #1e1e1e;
  margin-bottom: 8px;
  line-height: 1.2;
}
.modal-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 30px;
  border: 1px solid;
}
.modal-badge .mbdot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.modal-badge.st-up    { color: var(--up); background: rgba(15,157,88,0.06); border-color: rgba(15,157,88,0.15); }
.modal-badge.st-down  { color: var(--down); background: rgba(220,38,38,0.06); border-color: rgba(220,38,38,0.15); }
.modal-badge.st-warn  { color: var(--warn); background: rgba(249,115,22,0.06); border-color: rgba(249,115,22,0.15); }
.modal-badge.st-pause { color: var(--pause); background: rgba(107,114,128,0.06); border-color: rgba(107,114,128,0.15); }
.modal-badge.st-up   .mbdot { background: var(--up); }
.modal-badge.st-down .mbdot { background: var(--down); }
.modal-badge.st-warn .mbdot { background: var(--warn); }
.modal-badge.st-pause .mbdot { background: var(--pause); }

/* Close button */
.modal-close {
  position: absolute;
  top: 18px; right: 18px;
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,0.08);
  background: #f5f0e8;
  color: #6b7280;
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
  line-height: 1;
}
.modal-close:hover { 
  background: rgba(220,38,38,0.06); 
  border-color: var(--down); 
  color: var(--down); 
}

/* Modal body sections */
.modal-body { padding: 24px 28px 30px; background: #ffffff; }

/* Uptime stats row */
.modal-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 28px;
}
.modal-stat {
  background: #faf7f2;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 12px;
  padding: 16px 12px;
  text-align: center;
  box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}
.modal-stat-val {
  font-family: var(--f-mono);
  font-size: 24px;
  font-weight: 700;
  display: block;
  margin-bottom: 5px;
  line-height: 1;
}
.modal-stat-lbl {
  font-size: 11px;
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}
.mv-good { color: var(--up); }
.mv-ok   { color: var(--warn); }
.mv-bad  { color: var(--down); }
.mv-dim  { color: #9ca3af; }

/* Section titles inside modal */
.modal-section-title {
  font-size: 12px;
  font-weight: 700;
  color: #4b5563;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.modal-section-title::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 14px;
  background: var(--green);
  border-radius: 3px;
}

/* 90-day grid inside modal */
.modal-day-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 12px;
}
.modal-day-block {
  width: 11px;
  height: 22px;
  border-radius: 3px;
  background: #f0ece5;
  cursor: default;
  transition: transform 0.1s;
  flex-shrink: 0;
  border: 1px solid rgba(0,0,0,0.02);
}
.modal-day-block:hover { transform: scaleY(1.4); }
.modal-day-block.d-up   { background: var(--up); }
.modal-day-block.d-down { background: var(--down); }
.modal-day-block.d-warn { background: var(--warn); }

.modal-legend {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 12px;
  color: #6b7280;
  margin-bottom: 28px;
}
.modal-leg { 
  width: 12px; 
  height: 12px; 
  border-radius: 3px; 
  flex-shrink: 0; 
}
.modal-leg.leg-up   { background: var(--up); }
.modal-leg.leg-down { background: var(--down); }
.modal-leg.leg-warn { background: var(--warn); }

/* Incident rows inside modal */
.modal-incident-list { display: flex; flex-direction: column; gap: 8px; }
.modal-incident-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  background: #faf7f2;
  border-radius: 10px;
  border-left: 4px solid;
  font-size: 14px;
  transition: background 0.15s;
  border: 1px solid rgba(0,0,0,0.04);
  border-left-width: 4px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}
.modal-incident-row:hover { background: #f5f0e8; }
.modal-incident-row.mi-down { border-left-color: var(--down); }
.modal-incident-row.mi-warn { border-left-color: var(--warn); }
.modal-incident-row.mi-up   { border-left-color: var(--up); }
.mi-dot { 
  width: 10px; 
  height: 10px; 
  border-radius: 50%; 
  flex-shrink: 0; 
}
.mi-dot-down { background: var(--down); }
.mi-dot-warn { background: var(--warn); }
.mi-dot-up   { background: var(--up); }
.mi-event { font-weight: 600; }
.modal-incident-row.mi-down .mi-event { color: var(--down); }
.modal-incident-row.mi-warn .mi-event { color: var(--warn); }
.modal-incident-row.mi-up   .mi-event { color: var(--up); }
.mi-date { 
  font-family: var(--f-mono); 
  font-size: 12px; 
  color: #4b5563; 
  white-space: nowrap; 
}
.mi-dur  { 
  font-family: var(--f-mono); 
  font-size: 12px; 
  color: #6b7280; 
  white-space: nowrap; 
}
.mi-ago  { 
  font-family: var(--f-mono); 
  font-size: 12px; 
  color: #9ca3af; 
  white-space: nowrap; 
}

.modal-no-incidents {
  text-align: center;
  padding: 28px;
  color: #6b7280;
  font-size: 14px;
  background: #faf7f2;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.04);
}
.modal-divider { 
  height: 1px; 
  background: rgba(0,0,0,0.06); 
  margin: 24px 0; 
}

/* ══════════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════════ */
.site-footer {
  background:      var(--bg-base);
  border-top:      1px solid var(--bd);
  padding-top:     60px;
  position:        relative;
  z-index:         1;
}
.footer-inner {
  display:         flex;
  gap:             60px;
  flex-wrap:       wrap;
  padding-bottom:  48px;
}
.footer-brand { max-width: 320px; }
.footer-logo {
  display:         block;
  margin-bottom:   16px;
}
.footer-logo img { height: 38px; width: auto; display: block; }
.footer-tagline {
  font-size:       14px;
  color:           var(--tx-3);
  line-height:     1.7;
}
.footer-links {
  display:         flex;
  gap:             60px;
  flex:            1;
  flex-wrap:       wrap;
}
.footer-col {
  display:         flex;
  flex-direction:  column;
  gap:             12px;
  min-width:       160px;
}
.footer-col-title {
  font-size:       12px;
  font-weight:     700;
  color:           var(--tx-2);
  text-transform:  uppercase;
  letter-spacing:  .07em;
  margin-bottom:   4px;
}
.footer-col a {
  font-size:       14px;
  color:           var(--tx-3);
  text-decoration: none;
  transition:      color var(--t);
}
.footer-col a:hover { color: var(--green); }

.footer-bottom {
  background:      var(--bg-elevated);
  border-top:      1px solid var(--bd);
  padding:         16px 0;
}
.footer-bottom-inner {
  display:         flex;
  align-items:     center;
  flex-wrap:       wrap;
  gap:             16px;
  font-size:       13px;
  color:           var(--tx-3);
  justify-content: space-between;
}
.footer-link {
  color:           var(--green);
  text-decoration: none;
  font-weight:     500;
}
.footer-link:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .tbl-header,
  .service-row {
    grid-template-columns: 1fr 130px 80px 80px;
  }
  .hide-md { display: none !important; }
}
@media (max-width: 640px) {
  .tbl-header,
  .service-row {
    grid-template-columns: 1fr 110px 70px;
  }
  .hide-sm { display: none !important; }
  .metric { min-width: 90px; padding: 16px 10px; }
  .metric-val { font-size: 22px; }
  .hero { padding: 48px 0 40px; }
  .detail-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { gap: 32px; }
  .footer-links { gap: 32px; }
  .incident-row { grid-template-columns: auto 1fr; }
  .inc-dur, .inc-ago { display: none; }
  .topbar-status { display: none; }
  .topbar-inner { height: 56px; }
  
  /* Modal responsive */
  .modal-box { 
    max-height: 92vh; 
    border-radius: 20px 20px 0 0; 
  }
  .modal-overlay { 
    align-items: flex-end; 
    padding: 0; 
    background: rgba(0,0,0,0.4);
  }
  .modal-stats { 
    grid-template-columns: repeat(2, 1fr); 
  }
  .modal-incident-row { 
    grid-template-columns: auto 1fr auto; 
  }
  .mi-dur { display: none; }
  .modal-header { padding: 20px 24px 18px; }
  .modal-body { padding: 20px 24px 24px; }
}

/* ── Loading state animations ─── */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.services-block,
.panel {
  animation: fadeIn .4s ease both;
}