/* ==========================================================
   STATUS • UI (Topographic dark / glass)
   Tutte le classi sono compatibili con status.html + status.js
   ========================================================== */

.status-page{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:#e5e7eb;
}

/* --- Background pattern (SVG topographic lines) --- */
:root{
  --st-bg: #020617;
  --c-ok: #22c55e;
  --c-maint: #22d3ee;
  --c-warn: #f59e0b;
  --c-bad: #ef4444;
  --st-panel: rgba(15,23,42,.62);
  --st-panel-2: rgba(2,6,23,.50);
  --st-border: rgba(148,163,184,.16);
  --st-border-strong: rgba(148,163,184,.22);
  --st-muted: #9ca3af;
  --st-text: #f8fafc;
}

/* ---------------- HERO ---------------- */
.status-hero{
  padding: 120px 0 28px;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(900px 420px at 16% 12%, rgba(59,130,246,.18), transparent 62%),
    radial-gradient(900px 420px at 74% 18%, rgba(34,197,94,.12), transparent 62%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1400' height='900' viewBox='0 0 1400 900'%3E%3Cg fill='none' stroke='%2394a3b8' stroke-opacity='.18' stroke-width='1.2'%3E%3Cpath d='M-40 210 C 220 120, 420 120, 700 210 S 1180 320, 1480 190'/%3E%3Cpath d='M-40 320 C 220 250, 420 260, 700 320 S 1180 420, 1480 300'/%3E%3Cpath d='M-40 430 C 220 360, 420 370, 700 430 S 1180 520, 1480 420'/%3E%3Cpath d='M-40 540 C 220 470, 420 480, 700 540 S 1180 630, 1480 530'/%3E%3Cpath d='M-40 650 C 220 590, 420 600, 700 650 S 1180 740, 1480 640'/%3E%3Cpath d='M-40 760 C 220 700, 420 710, 700 760 S 1180 850, 1480 750'/%3E%3C/g%3E%3Cg fill='none' stroke='%233b82f6' stroke-opacity='.14' stroke-width='1'%3E%3Cpath d='M-60 160 C 260 40, 520 80, 760 170 S 1200 340, 1500 140'/%3E%3Cpath d='M-60 610 C 260 510, 520 520, 760 610 S 1200 720, 1500 600'/%3E%3C/g%3E%3C/svg%3E"),
    repeating-linear-gradient(
      112deg,
      rgba(148,163,184,.06) 0px,
      rgba(148,163,184,.06) 1px,
      transparent 1px,
      transparent 18px
    ),
    var(--st-bg);
  background-size: 1100px 720px, 1100px 720px, 1500px 960px, auto, auto;
  background-position: 0 0, 0 0, center -80px, center, center;
}

.status-hero h1{
  margin: 0 0 8px;
  font-size: clamp(34px, 4vw, 56px);
  font-weight: 850;
  letter-spacing: -0.03em;
  color: var(--st-text);
}

.status-hero p{
  margin: 0 0 26px;
  color: #cbd5e1;
  font-size: 16px;
}

.status-cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 980px){
  .status-cards{ grid-template-columns: 1fr; }
}

.s-card{
  border-radius: 18px;
  padding: 18px;
  border: 1px solid var(--st-border);
  background: linear-gradient(180deg, rgba(15,23,42,.72), rgba(15,23,42,.48));
  box-shadow: 0 18px 44px rgba(0,0,0,.45);
  backdrop-filter: blur(10px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  position: relative;
  overflow: hidden;
}

.s-card::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(420px 220px at 18% 0%, rgba(255,255,255,.06), transparent 55%);
  pointer-events:none;
}

.s-card-label{
  display:block;
  font-size: 13px;
  color: var(--st-muted);
  margin-bottom: 8px;
  letter-spacing: .02em;
}

.s-card-value{
  display:block;
  font-size: 42px;
  font-weight: 850;
  color: var(--st-text);
  line-height: 1;
}

.s-card-value.ok{ color: #22c55e; }
.s-card-value.bad{ color: #fb7185; }

.s-card-icon{
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(18px 18px at 30% 25%, rgba(255,255,255,.20), transparent 60%),
    rgba(2,6,23,.55);
  box-shadow: 0 10px 30px rgba(0,0,0,.28);
}

.s-card-icon i{ font-size: 18px; }
.s-ico-blue{ color:#60a5fa; }
.s-ico-green{ color:#22c55e; }
.s-ico-red{ color:#fb7185; }

/* ---------------- LIST AREA ---------------- */
.status-list{
  padding: 20px 0 80px;
  background:
    radial-gradient(1200px 760px at 50% 0%, rgba(59,130,246,.10), transparent 65%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1400' height='900' viewBox='0 0 1400 900'%3E%3Cg fill='none' stroke='%2394a3b8' stroke-opacity='.14' stroke-width='1'%3E%3Cpath d='M-60 260 C 240 160, 520 170, 780 260 S 1200 390, 1500 240'/%3E%3Cpath d='M-60 370 C 240 290, 520 300, 780 370 S 1200 510, 1500 350'/%3E%3Cpath d='M-60 480 C 240 400, 520 410, 780 480 S 1200 620, 1500 460'/%3E%3Cpath d='M-60 590 C 240 520, 520 530, 780 590 S 1200 730, 1500 580'/%3E%3Cpath d='M-60 700 C 240 630, 520 640, 780 700 S 1200 840, 1500 690'/%3E%3C/g%3E%3C/svg%3E"),
    var(--st-bg);
  background-size: auto, 1500px 960px, auto;
  background-position: center, center -140px, center;
}

/* ---------------- GROUP ROW (accordion) ---------------- */
.s-row{
  border-radius: 18px;
  border: 1px solid var(--st-border);
  background: linear-gradient(180deg, rgba(15,23,42,.64), rgba(15,23,42,.46));
  box-shadow: 0 16px 38px rgba(0,0,0,.42);
  margin-top: 14px;
  overflow:hidden;
}

.s-row-btn{
  width:100%;
  padding: 16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  background: transparent;
  border: 0;
  color: #e5e7eb;
  cursor:pointer;
}

.s-left{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 240px;
}

.s-chevron{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: rgba(2,6,23,.55);
  border: 1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#cbd5e1;
}

.s-title{
  font-size: 20px;
  font-weight: 750;
  letter-spacing: -0.01em;
}

.s-sub{
  margin-left: 10px;
  color: var(--st-muted);
  font-size: 14px;
  font-weight: 550;
}

.s-mid{ flex: 1; display:flex; justify-content:flex-start; }

.uptime{
  display:flex;
  gap: 3px;
  align-items:center;
  min-width: 340px;
  max-width: 520px;
}

.tick{
  width: 5px;
  height: 18px;
  border-radius: 4px;
  background: rgba(148,163,184,.18);
}

.tick.ok{ background: var(--c-ok); }
.tick.maint{ background: var(--c-maint); }
.tick.warn{ background: var(--c-warn); }
.tick.bad{ background: var(--c-bad); }

.s-right{
  display:flex;
  align-items:center;
  gap: 18px;
  min-width: 240px;
  justify-content:flex-end;
}

.s-state{
  display:flex;
  align-items:center;
  gap: 10px;
  color:#cbd5e1;
  font-weight: 650;
}

.state-dot{
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background:#22c55e;
  box-shadow: 0 0 16px rgba(34,197,94,.25);
}

.s-uptime{ color:#e5e7eb; font-weight: 750; }

.s-row.open .s-chevron i{
  transform: rotate(90deg);
  transition: transform .15s ease;
}

.s-panel{
  display:none;
  padding: 0 18px 16px;
  border-top: 1px solid rgba(148,163,184,.12);
  color:#cbd5e1;
}

.s-row.open .s-panel{ display:block; }

@media (max-width: 820px){
  .uptime{ min-width: 220px; }
  .s-right{ min-width: 180px; }
}

/* ---------------- CARDS inside accordion ---------------- */
.svc-cards{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 980px){
  .svc-cards{ grid-template-columns: 1fr; }
}

.svc-card{
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(15,23,42,.70);
  box-shadow: 0 18px 44px rgba(0,0,0,.45);
  padding: 18px;
  position: relative;
  overflow:hidden;
  backdrop-filter: blur(10px);
}


.svc-card-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  position: relative;
}

.svc-card-title{
  font-size: 22px;
  font-weight: 850;
  letter-spacing: -0.02em;
  color: var(--st-text);
}

.svc-card-sub{
  margin-top: 6px;
  color: var(--st-muted);
  font-weight: 650;
}

.svc-state{
  margin-top: 10px;
  display:flex;
  align-items:center;
  gap: 8px;
  font-weight: 850;
  font-size: 13px;
  letter-spacing: .01em;
}
.svc-state.ok{ color: var(--c-ok); }
.svc-state.maint{ color: var(--c-maint); }
.svc-state.warn{ color: var(--c-warn); }
.svc-state.bad{ color: var(--c-bad); }
.svc-state.maint i{ color:#ffffff; }
.svc-state.maint span{ color: var(--c-maint); }

.svc-card-grid{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  position: relative;
}

.svc-k{ color: var(--st-muted); font-size: 13px; }
.svc-v{ color: var(--st-text); font-weight: 850; margin-top: 4px; }

.svc-last{ margin-top: 12px; color: var(--st-muted); font-size: 13px; position: relative; }

/* status mapping per bordo card */
.svc-card[data-st="ok"]{ border-color: rgba(34,197,94,.35); }
.svc-card[data-st="maint"]{ border-color: rgba(34,211,238,.45); }
.svc-card[data-st="warn"]{ border-color: rgba(245,158,11,.45); }
.svc-card[data-st="bad"]{ border-color: rgba(239,68,68,.45); }

/* ---------------- Alerts + Provider ---------------- */
/* Alerts: niente “box dentro box” (i banner sono già card) */
.alerts-box{
  margin-top: 18px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

/* Provider: resta come pannello */
.provider-box{
  margin-top: 18px;
  border-radius: 18px;
  border: 1px solid var(--st-border);
  background: linear-gradient(180deg, rgba(15,23,42,.60), rgba(15,23,42,.45));
  box-shadow: 0 16px 38px rgba(0,0,0,.40);
  padding: 16px 18px 18px;
  backdrop-filter: blur(10px);
}

.alerts-top,
.provider-top{
  display:flex;
  justify-content:space-between;
  gap: 12px;
  flex-wrap: wrap;
  align-items:flex-start;
}

.alerts-box h2,
.provider-box h2{
  margin: 0 0 6px;
  color: var(--st-text);
  font-size: 18px;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.alerts-sub,
.provider-box p{ margin: 0; color:#cbd5e1; }

.alert{
  margin-top: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(2,6,23,.42);
  padding: 12px 14px;
}

.alert-top{
  display:flex;
  justify-content:space-between;
  gap: 12px;
  align-items:flex-start;
  flex-wrap: wrap;
}

.alert-title{
  margin: 0;
  color: var(--st-text);
  font-weight: 850;
  font-size: 14px;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.alert-meta{
  color: var(--st-muted);
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.alert-body{ margin: 8px 0 0; color:#cbd5e1; font-size: 14px; line-height: 1.5; }

.alert-pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(2,6,23,.55);
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color:#e5e7eb;
}

.alert-pill.ok{ box-shadow: 0 0 16px rgba(34,197,94,.18); }
.alert-pill.warn{ box-shadow: 0 0 16px rgba(245,158,11,.18); }
.alert-pill.bad{ box-shadow: 0 0 16px rgba(239,68,68,.18); }

.alert-empty{
  margin-top: 12px;
  padding: 14px;
  border-radius: 16px;
  border: 1px dashed rgba(148,163,184,.22);
  color: var(--st-muted);
  background: rgba(2,6,23,.25);
}

/* ---------------- Alerts (banner like Maintenance screenshot) ---------------- */
.notice{
  margin-top: 12px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(15,23,42,.55);
  box-shadow: 0 16px 38px rgba(0,0,0,.40);
  padding: 22px;
  backdrop-filter: blur(10px);
}

.notice-inner{ display:flex; gap: 14px; align-items:flex-start; }
.notice-icon{ font-size: 22px; line-height: 1; color: #ffffff; margin-top: 2px; }
.notice-head{ font-size: 18px; font-weight: 900; margin: 0; }
.notice-name{ margin-top: 10px; font-size: 18px; font-weight: 900; color: var(--st-text); }
.notice-status{ margin-top: 6px; color:#e5e7eb; font-weight: 650; line-height: 1.45; white-space: pre-line; }
.notice-meta{ margin-top: 12px; display:flex; gap: 18px; flex-wrap: wrap; color:#cbd5e1; font-size: 13px; }

.notice[data-lvl="ok"]{ border-color: rgba(34,197,94,.28); }
.notice[data-lvl="ok"] .notice-head{ color: var(--c-ok); }

.notice[data-lvl="maint"]{ border-color: rgba(34,211,238,.30); }
.notice[data-lvl="maint"] .notice-head{ color: var(--c-maint); }

.notice[data-lvl="warn"]{ border-color: rgba(245,158,11,.28); }
.notice[data-lvl="warn"] .notice-head{ color: var(--c-warn); }

.notice[data-lvl="bad"]{ border-color: rgba(239,68,68,.28); }
.notice[data-lvl="bad"] .notice-head{ color: var(--c-bad); }


/* provider components grid */
.provider-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
@media (max-width: 820px){
  .provider-grid{ grid-template-columns: 1fr; }
}

.comp{
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(2,6,23,.42);
  border: 1px solid rgba(255,255,255,.08);
  display:flex;
  justify-content:space-between;
  gap: 10px;
}
.comp span{ color:#e5e7eb; }
.comp small{ color: var(--st-muted); text-transform: uppercase; letter-spacing: .08em; }

.comp small.st-ok{ color: rgba(34,197,94,.95); }
.comp small.st-warn{ color: rgba(245,158,11,.95); }
.comp small.st-bad{ color: rgba(239,68,68,.95); }

/* ---------------- Maintenance banner ---------------- */
#maintenance-banner{ margin-top: 18px; }

.maint{
  border-radius: 18px;
  border: 1px solid rgba(34,211,238,.35);
  background: rgba(15,23,42,.55);
  box-shadow: 0 16px 38px rgba(0,0,0,.40);
  padding: 22px;
  backdrop-filter: blur(10px);
}

.maint-inner{ display:flex; gap: 14px; align-items:flex-start; }
.maint-icon{ font-size: 24px; line-height: 1; color: #ffffff; margin-top: 2px; }
.maint-head{ font-size: 18px; font-weight: 900; color: var(--c-maint); margin: 0; }
.maint-name{ margin-top: 10px; font-size: 18px; font-weight: 900; color: var(--st-text); }
.maint-status{ margin-top: 6px; color:#e5e7eb; font-weight: 700; }
.maint-meta{ margin-top: 12px; display:flex; gap: 18px; flex-wrap: wrap; color:#cbd5e1; font-size: 13px; }




/* =========================================================
   PATCH "RIQUADRO" (uguale alle immagini)
   ========================================================= */

/* Banner manutenzione: più trasparente così si vede la topo-map sotto */
.maint{
  border-radius: 18px;
  border: 1px solid rgba(34,211,238,.40);
  background: linear-gradient(180deg, rgba(2,6,23,.30), rgba(2,6,23,.18));
  box-shadow: 0 16px 38px rgba(0,0,0,.35);
  padding: 22px;
  backdrop-filter: blur(10px);
}

.maint-inner{ display:flex; gap: 16px; align-items:flex-start; }

.maint-icon{
  width: 42px;
  height: 42px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 24px;
  line-height: 1;
  color: #ffffff;
}

.maint-head{ font-size: 18px; font-weight: 900; color: rgba(34,211,238,1); }
.maint-name{ margin-top: 8px; font-size: 20px; font-weight: 900; color: #f8fafc; }
.maint-status{ margin-top: 8px; color: rgba(226,232,240,.92); font-weight: 650; }
.maint-meta{
  margin-top: 10px;
  display:flex;
  gap: 22px;
  flex-wrap: wrap;
  color: rgba(203,213,225,.92);
  font-size: 13px;
}

/* Avvisi: stesso stile del banner, solo colori diversi */
.notice{
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(2,6,23,.30), rgba(2,6,23,.18));
  box-shadow: 0 16px 38px rgba(0,0,0,.35);
  padding: 22px;
  backdrop-filter: blur(10px);
}

.notice-inner{ display:flex; gap: 16px; align-items:flex-start; }
.notice-icon{
  width: 42px;
  height: 42px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 22px;
  color:#fff;
}

.notice-head{ font-size: 18px; font-weight: 900; }
.notice-name{ margin-top: 8px; font-size: 20px; font-weight: 900; color:#f8fafc; }
.notice-status{ margin-top: 8px; color: rgba(226,232,240,.92); font-weight: 650; white-space: pre-line; }
.notice-meta{ margin-top: 10px; display:flex; gap: 22px; flex-wrap: wrap; color: rgba(203,213,225,.92); font-size: 13px; }

/* bordi per colore (verde/giallo/rosso/azzurro) */
.notice[data-lvl="ok"]{ border: 1px solid rgba(34,197,94,.35); }
.notice[data-lvl="ok"] .notice-head{ color: rgba(34,197,94,1); }

.notice[data-lvl="warn"]{ border: 1px solid rgba(245,158,11,.38); }
.notice[data-lvl="warn"] .notice-head{ color: rgba(245,158,11,1); }

.notice[data-lvl="bad"]{ border: 1px solid rgba(239,68,68,.38); }
.notice[data-lvl="bad"] .notice-head{ color: rgba(239,68,68,1); }

.notice[data-lvl="maint"]{ border: 1px solid rgba(34,211,238,.40); }
.notice[data-lvl="maint"] .notice-head{ color: rgba(34,211,238,1); }

/* Card servizio uguale riquadro: stato inline (non bottone) */
.svc-card{
  border-radius: 18px;
  background: rgba(15,23,42,.60);
  box-shadow: 0 18px 44px rgba(0,0,0,.40);
  padding: 18px;
  backdrop-filter: blur(10px);
}

.svc-card-title{ font-size: 22px; font-weight: 900; color:#f8fafc; }
.svc-card-sub{ margin-top: 6px; color: rgba(148,163,184,.95); font-weight: 650; }

.svc-state{
  margin-top: 10px;
  display:flex;
  align-items:center;
  gap: 8px;
  font-weight: 650;
  font-size: 14px;
  letter-spacing: 0;
}

/* icona sempre grigina, testo colorato */
.svc-state i{ color: rgba(148,163,184,.95); }

.svc-state.ok span{ color: rgba(34,197,94,1); }
.svc-state.warn span{ color: rgba(245,158,11,1); }
.svc-state.bad span{ color: rgba(239,68,68,1); }
.svc-state.maint span{ color: rgba(34,211,238,1); }

/* Bordo per stato */
.svc-card[data-st="ok"]{ border: 1px solid rgba(34,197,94,.35); }
.svc-card[data-st="warn"]{ border: 1px solid rgba(245,158,11,.40); }
.svc-card[data-st="bad"]{ border: 1px solid rgba(239,68,68,.40); }
.svc-card[data-st="maint"]{ border: 1px solid rgba(34,211,238,.45); }

/* valori */
.svc-k{ color: rgba(148,163,184,.95); font-size: 13px; }
.svc-v{ color:#f8fafc; font-size: 18px; font-weight: 900; margin-top: 4px; }
