/* ============================================================
   Design tokens
   ============================================================ */
:root {
  --bg:           #f5f5f5;
  --panel:        #ffffff;
  --line:         #e8e8ea;
  --line-light:   #f0f0f2;
  --text:         #1d1d1f;
  --muted:        #6b6b70;
  --muted-lt:     #adadb2;
  --green:        #1f9e57;
  --green-bg:     #e8f9ef;
  --red:          #d84e4e;
  --red-bg:       #fce8e8;
  --blue:         #1f6eff;
  --blue-bg:      #eef3ff;
  --amber:        #b8902e;
  --amber-bg:     #fdf6ea;
  --amber-border: #ede0c3;
  --sidebar-w:    215px;
  --topbar-h:     56px;
  --r-sm:         8px;
  --r-md:         12px;
  --r-lg:         16px;
  --shadow:       0 2px 12px rgba(0,0,0,0.06);
}

/* ============================================================
   Reset
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Roboto", "Segoe UI", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4,h5,h6,p { margin: 0; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; border: 0; }
button:disabled { opacity: 0.45; cursor: default; }
ul { list-style: none; margin: 0; padding: 0; }
pre { margin: 0; white-space: pre-wrap; word-break: break-all; }
a { text-decoration: none; color: inherit; }

/* Utility */
.text-muted  { color: var(--muted); }
.is-hidden   { display: none !important; }

/* ============================================================
   Hub Topbar
   ============================================================ */
.topbar {
  position: sticky;
  top: 0;
  z-index: 200;
  height: var(--topbar-h);
  background: #1b1b1c;
  color: #fff;
  display: grid;
  grid-template-columns: 180px 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 0 20px;
}

.topbar-brand {
  display: flex;
  align-items: center;
  gap: 9px;
}
.brand-mark {
  width: 26px; height: 26px;
  border: 2px solid rgba(255,255,255,0.82);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem;
}
.brand-name { font-size: 1rem; font-weight: 700; }

.topbar-nav {
  display: flex;
  gap: 24px;
}
.tnav-link {
  color: rgba(255,255,255,0.7);
  font-size: 0.88rem;
  cursor: pointer;
  transition: color .15s;
}
.tnav-link:hover { color: #fff; }
.new-tag {
  background: #2d74ff;
  color: #fff;
  font-size: 0.58rem;
  font-style: normal;
  font-weight: 700;
  border-radius: 999px;
  padding: 2px 6px;
  margin-left: 5px;
  vertical-align: middle;
}

.topbar-end { display: flex; align-items: center; gap: 12px; }

.btn-expert {
  background: linear-gradient(90deg, #9f31ff, #f59d3d);
  border: 0;
  border-radius: var(--r-sm);
  color: #fff;
  font-size: 0.82rem;
  font-weight: 700;
  padding: 8px 14px;
}
.topbar-icons { display: flex; gap: 7px; }
.t-icon {
  width: 14px; height: 14px;
  background: rgba(255,255,255,0.2);
  border-radius: 50%;
  display: block;
}
.user-pill {
  border: 1.5px solid #f2b839;
  border-radius: 999px;
  color: #fff;
  font-size: 0.73rem;
  font-weight: 700;
  padding: 6px 11px;
}

/* ============================================================
   App Shell
   ============================================================ */
.app-shell {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: calc(100vh - var(--topbar-h));
}

/* ============================================================
   Sidebar
   ============================================================ */
.sidebar {
  background: var(--panel);
  border-right: 1px solid var(--line);
  padding: 18px 10px;
}
.snav { display: flex; flex-direction: column; gap: 1px; }

.snav-item {
  border-radius: var(--r-sm);
  color: var(--muted);
  font-size: 0.88rem;
  padding: 9px 12px;
  cursor: pointer;
  transition: background .12s, color .12s;
}
.snav-item:hover { background: var(--line-light); color: var(--text); }
.snav-item.is-active { color: var(--text); font-weight: 600; }

.snav-sub {
  border-radius: var(--r-sm);
  color: var(--muted);
  font-size: 0.84rem;
  margin-left: 10px;
  padding: 7px 12px;
  cursor: pointer;
  transition: background .12s, color .12s;
}
.snav-sub:hover { background: var(--line-light); color: var(--text); }
.snav-sub.is-active {
  background: #f0f0f2;
  color: var(--text);
  font-weight: 600;
}

/* ============================================================
   Main Column
   ============================================================ */
.main-col { padding: 20px 24px; }
.page-wrap { margin: 0 auto; max-width: 1040px; }

/* ============================================================
   Page Header
   ============================================================ */
.page-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.page-hdr-left { display: flex; align-items: center; gap: 10px; }

.btn-back {
  width: 30px; height: 30px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--muted);
  font-size: 1.25rem;
  line-height: 1;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
}

.site-avi {
  width: 34px; height: 34px;
  background: #6c6c70;
  border-radius: 50%;
  color: #fff;
  font-size: 0.84rem;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

.site-name { font-size: 1.05rem; font-weight: 700; line-height: 1.2; }

.hdr-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 4px;
  flex-wrap: wrap;
}
.breadcrumb { color: var(--muted); font-size: 0.82rem; }

/* Plan toggle */
.plan-toggle {
  display: inline-flex;
  background: #f0f0f2;
  border-radius: 999px;
  padding: 3px;
}
.plan-btn {
  background: transparent;
  border: 0;
  border-radius: 999px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 600;
  padding: 6px 14px;
  transition: all .15s;
}
.plan-btn.is-active {
  background: var(--panel);
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
  color: var(--text);
}

.page-hdr-right { display: flex; align-items: center; gap: 8px; }

.btn-icon {
  width: 32px; height: 32px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--muted);
  font-size: 0.9rem;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
}
.btn-icon:hover { background: var(--line-light); }

/* ============================================================
   Module Card
   ============================================================ */
.module {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
}

/* Module Top */
.module-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line);
}

.status-row { display: flex; align-items: center; gap: 10px; }
.status-row h2 { font-size: 1.3rem; font-weight: 700; }

.status-chip {
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  padding: 5px 11px;
}
.status-chip.is-up     { background: var(--green-bg); color: var(--green); }
.status-chip.is-down   { background: var(--red-bg);   color: var(--red);   }
.status-chip.is-paused { background: var(--line);     color: var(--muted); }

#status-sub { font-size: 0.85rem; margin-top: 5px; }

.module-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

/* Range buttons (toolbar) */
.range-btns { display: flex; gap: 4px; }
.range-btn {
  background: #f3f3f5;
  border: 0;
  border-radius: var(--r-sm);
  color: #46464b;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 8px 11px;
  transition: background .12s;
}
.range-btn.is-active { background: #e0e0e4; color: var(--text); }
.range-btn:hover:not(.is-active) { background: #e8e8ea; }

/* Buttons */
.btn-primary {
  background: var(--blue);
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-weight: 700;
  padding: 9px 18px;
  transition: opacity .12s;
}
.btn-primary:hover:not(:disabled) { opacity: 0.88; }
.btn-primary.sm { font-size: 0.82rem; padding: 7px 14px; }

.btn-ghost {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  font-weight: 600;
  padding: 9px 16px;
  transition: background .12s;
}
.btn-ghost:hover { background: var(--line-light); }
.btn-ghost.sm { font-size: 0.82rem; padding: 7px 14px; }

/* Dropdown */
.menu-wrap { position: relative; }
.dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow);
  min-width: 190px;
  overflow: hidden;
  z-index: 50;
}
.dd-item {
  display: block;
  width: 100%;
  background: var(--panel);
  border: 0;
  border-bottom: 1px solid var(--line-light);
  font-size: 0.88rem;
  padding: 11px 14px;
  text-align: left;
  transition: background .1s;
}
.dd-item:last-child { border-bottom: 0; }
.dd-item:hover { background: var(--line-light); }

/* ============================================================
   Promo Banner
   ============================================================ */
.promo {
  background: linear-gradient(135deg, #ece1ff 0%, #f5f0ff 100%);
  border-bottom: 1px solid #d9ccff;
  padding: 14px 24px;
  color: #332b5c;
}
.promo-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: nowrap;
}
.promo-text { flex: 1; min-width: 0; }
.promo strong { font-size: 0.88rem; font-weight: 700; }
.promo p { font-size: 0.8rem; margin-top: 2px; color: #5a4a8a; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.promo-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.btn-upgrade {
  background: linear-gradient(90deg, #8e36f5, #d4732a);
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-size: 0.82rem;
  font-weight: 700;
  padding: 8px 16px;
  white-space: nowrap;
}
.btn-upgrade:hover { opacity: 0.9; }
.btn-dismiss {
  background: transparent;
  border: 0;
  color: #6b4db0;
  font-size: 0.8rem;
  text-decoration: underline;
}

/* ============================================================
   Views
   ============================================================ */
.view { display: none; padding: 24px; }
.view.is-active { display: block; }

/* ============================================================
   Uptime Strip
   ============================================================ */
.uptime-strip {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 18px;
  margin-bottom: 28px;
  align-items: flex-start;
}
.strip-date { font-size: 1.1rem; font-weight: 700; padding-top: 2px; }

.strip-bar {
  height: 14px;
  background: #b8f36e;
  border-radius: 3px;
}
.strip-days {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 2px;
  margin-top: 6px;
  text-align: center;
  color: var(--muted);
  font-size: 0.76rem;
}

.strip-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}
.sstat-lbl {
  color: var(--muted);
  font-size: 0.78rem;
  margin-bottom: 5px;
}
.sstat-val-row { display: flex; align-items: center; gap: 6px; }
.sstat-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.sstat-dot.is-up   { background: var(--green); }
.sstat-dot.is-down { background: var(--red); }
.sstat strong { font-size: 1.25rem; font-weight: 700; }
.sstat-hint { font-size: 0.78rem; margin-top: 3px; }

/* ============================================================
   Dashboard Grid
   ============================================================ */
.dash-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.85fr) 255px;
  gap: 22px;
}
.dash-main { display: flex; flex-direction: column; gap: 20px; }

/* ============================================================
   Card
   ============================================================ */
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 18px 20px;
}
.card-hdr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.card-title {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.3;
}
.card-title::after { content: "."; color: var(--blue); }

.chart-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  color: var(--muted);
  font-size: 0.8rem;
  justify-content: flex-end;
}
.chart-meta b { color: var(--text); }

/* Range pills (in chart) */
.range-pills { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.range-pill {
  background: #f3f3f5;
  border: 0;
  border-radius: 999px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 600;
  padding: 6px 12px;
  transition: all .12s;
}
.range-pill.is-active { background: #1d1d1f; color: #fff; }
.range-pill:not(.is-active):not(.is-locked):hover { background: #e8e8ea; color: var(--text); }
.range-pill.is-locked {
  background: var(--amber-bg);
  color: var(--amber);
  cursor: not-allowed;
  opacity: 0.9;
  position: relative;
}
.pill-pro-tag {
  font-size: 0.62rem;
  font-weight: 700;
  opacity: 0.8;
  margin-left: 2px;
}

/* Tooltip for locked range pills */
.range-pill.is-locked[data-tip]:hover::before {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 7px);
  left: 50%;
  transform: translateX(-50%);
  background: #1d1d1f;
  color: #fff;
  font-size: 0.71rem;
  font-weight: 500;
  white-space: nowrap;
  padding: 5px 9px;
  border-radius: 6px;
  z-index: 100;
  pointer-events: none;
  box-shadow: 0 4px 12px rgba(0,0,0,.2);
}
.range-pill.is-locked[data-tip]:hover::after {
  content: "";
  position: absolute;
  bottom: calc(100% + 3px);
  left: 50%;
  transform: translateX(-50%);
  border: 4px solid transparent;
  border-top-color: #1d1d1f;
  z-index: 100;
  pointer-events: none;
}

/* Chart */
.chart-shell {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 10px;
  margin-top: 14px;
}
.chart-yaxis {
  height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: var(--muted);
  font-size: 0.72rem;
  text-align: right;
  padding-top: 4px;
}
.chart-panel {
  height: 220px;
  position: relative;
  border-left: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.chart-panel::before,
.chart-panel::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  border-top: 1px dashed var(--line-light);
  pointer-events: none;
}
.chart-panel::before { top: 33.3%; }
.chart-panel::after  { top: 66.6%; }

.chart-inner {
  height: 100%;
  padding: 8px 6px 0;
}
.chart-svg {
  display: block;
  width: 100%; height: 100%;
  overflow: visible;
}
.chart-pt {
  cursor: pointer;
  transition: r .1s;
}
.chart-pt:hover { r: 5; }

/* Tooltip */
.chart-tip {
  position: absolute;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  box-shadow: var(--shadow);
  padding: 8px 10px;
  pointer-events: none;
  z-index: 10;
  min-width: 108px;
}
.chart-tip strong { display: block; font-size: 0.88rem; }
.chart-tip span   { color: var(--muted); font-size: 0.76rem; }

/* Chart x-axis labels */
.chart-xaxis-wrap {
  display: grid;
  grid-template-columns: 54px 1fr;
  margin-top: 3px;
}
.chart-xaxis-pad { /* spacer matching y-axis + gap */ }
.chart-xaxis {
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  font-size: 0.69rem;
  padding: 0 2px;
  user-select: none;
}

/* Chart loading */
.is-chart-loading { position: relative; }
.is-chart-loading > * { opacity: 0.35; pointer-events: none; }
.is-chart-loading::after {
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  width: 22px; height: 22px;
  border: 2px solid rgba(31,110,255,.15);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: spin-c .8s linear infinite;
}
@keyframes spin-c {
  to { transform: translate(-50%,-50%) rotate(360deg); }
}

/* Feature cards */
.feat-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 14px;
}
.feat-card {
  background: #fafafa;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 12px 14px;
}
.feat-card.is-locked {
  background: linear-gradient(180deg, #fffdf9 0%, #fcf6ea 100%);
  border-color: var(--amber-border);
}
.feat-card-hdr {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 5px;
}
.feat-card-hdr h4 { font-size: 0.8rem; font-weight: 700; }
.feat-card strong { font-size: 0.9rem; display: block; }

/* ============================================================
   Incidents Table
   ============================================================ */
.inc-table { margin-top: 14px; }
.inc-head {
  display: grid;
  grid-template-columns: 100px 1fr 190px 95px;
  gap: 12px;
  padding: 0 12px 9px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.inc-row {
  display: grid;
  grid-template-columns: 100px 1fr 190px 95px;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-bottom: 1px solid var(--line-light);
  cursor: pointer;
  transition: background .12s;
}
.inc-row:last-child { border-bottom: 0; }
.inc-row:hover { background: #fafafa; border-radius: var(--r-sm); }

.inc-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.83rem;
  font-weight: 600;
}
.inc-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.is-resolved { color: var(--green); }
.is-alert    { color: var(--red); }
.inc-cause { font-size: 0.88rem; font-weight: 500; }
.inc-when  { color: var(--muted); font-size: 0.8rem; }
.inc-dur   { color: var(--muted); font-size: 0.8rem; font-variant-numeric: tabular-nums; }
.inc-empty { color: var(--muted); font-size: 0.88rem; padding: 14px 0 4px; }

/* ============================================================
   Right Rail
   ============================================================ */
.dash-rail { display: flex; flex-direction: column; gap: 0; }
.rail-card {
  border-bottom: 1px solid var(--line);
  padding: 16px 0;
}
.rail-card:first-child { padding-top: 4px; }
.rail-card:last-child  { border-bottom: 0; padding-bottom: 4px; }

.rail-lbl {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.rail-hdr { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.rail-hdr .rail-lbl { margin-bottom: 0; }

.rail-big { font-size: 1.2rem; font-weight: 700; }
.rail-big.is-up   { color: var(--green); }
.rail-big.is-down { color: var(--red); }
.rail-hint { font-size: 0.8rem; margin-top: 4px; }

.rail-rows { display: flex; flex-direction: column; gap: 10px; }
.rail-row-key { display: block; color: var(--muted); font-size: 0.77rem; margin-bottom: 2px; }
.rail-row strong { font-size: 0.88rem; }

/* Pro chip (amber, rail) */
.pro-chip {
  background: var(--amber-bg);
  border: 1px solid var(--amber-border);
  border-radius: 999px;
  color: var(--amber);
  font-size: 0.68rem;
  font-weight: 700;
  padding: 3px 8px;
  white-space: nowrap;
}

/* ============================================================
   Settings View
   ============================================================ */
.settings-hdr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.settings-title { font-size: 15px; font-weight: 700; }
.settings-title::after { content: "."; color: var(--blue); }

.settings-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip-stat {
  background: #fafafa;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  min-width: 90px;
  text-align: center;
}
.chip-stat > span { display: block; color: var(--muted); font-size: 0.72rem; margin-bottom: 3px; }
.chip-stat strong { font-size: 0.88rem; }

/* Settings list */
.settings-list {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
}

.settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 13px 18px;
  border-bottom: 1px solid var(--line-light);
}
.settings-row:last-child { border-bottom: 0; }

.settings-row-btn {
  display: flex;
  width: 100%;
  background: var(--panel);
  border: 0;
  border-bottom: 1px solid var(--line-light);
  text-align: left;
  padding: 13px 18px;
  gap: 16px;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: background .12s;
}
.settings-row-btn:last-child { border-bottom: 0; }
.settings-row-btn:hover { background: #fafafa; }

.row-left { display: flex; align-items: flex-start; gap: 13px; flex: 1; min-width: 0; }

.row-ico {
  width: 36px; height: 36px;
  background: #f3f3f5;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--muted);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.row-ico.is-pro {
  background: var(--amber-bg);
  border-color: var(--amber-border);
  color: var(--amber);
}

.row-copy { min-width: 0; }
.row-title-wrap { display: flex; align-items: center; gap: 7px; margin-bottom: 1px; }
.row-copy h3 { font-size: 13.5px; font-weight: 700; }
.row-copy p  { color: var(--muted); font-size: 0.8rem; margin-top: 1px; }

.row-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.row-val { color: var(--muted); font-size: 0.85rem; font-weight: 600; text-align: right; max-width: 160px; }
.row-val.is-locked { color: var(--muted-lt); letter-spacing: .05em; }
.row-lock { font-size: 0.7rem; opacity: 0.4; line-height: 1; }
.row-chevron { color: var(--muted-lt); font-size: 1.1rem; line-height: 1; }

/* Pro badge (gradient) */
.pro-badge {
  background: linear-gradient(90deg, #8e36f5, #d4732a);
  border-radius: 999px;
  color: #fff;
  font-size: 0.66rem;
  font-weight: 700;
  padding: 3px 8px;
  white-space: nowrap;
}

/* Toggle switch */
.switch { position: relative; display: inline-block; width: 48px; height: 26px; }
.switch input { opacity: 0; width: 0; height: 0; }
.slider {
  position: absolute;
  inset: 0;
  background: #c9c2b7;
  border-radius: 999px;
  cursor: pointer;
  transition: .18s;
}
.slider::before {
  content: "";
  position: absolute;
  width: 20px; height: 20px;
  left: 3px; bottom: 3px;
  background: #fff;
  border-radius: 50%;
  transition: .18s;
}
.switch input:checked + .slider { background: var(--blue); }
.switch input:checked + .slider::before { transform: translateX(22px); }

/* ============================================================
   Busy / Loading states
   ============================================================ */
.is-busy { pointer-events: none; position: relative; }
.is-busy::after {
  content: "";
  position: absolute;
  right: 10px; top: 50%;
  width: 13px; height: 13px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: currentColor;
  border-radius: 50%;
  animation: spin-btn .8s linear infinite;
}
@keyframes spin-btn {
  to { transform: translateY(-50%) rotate(360deg); }
}
.is-busy::after { transform: translateY(-50%); }

/* Ghost / icon busy: dark spinner */
.btn-ghost.is-busy::after,
.btn-icon.is-busy::after,
.plan-btn.is-busy::after {
  border-color: rgba(0,0,0,.12);
  border-top-color: #1d1d1f;
}

/* ============================================================
   Modals
   ============================================================ */
.modal {
  background: rgba(21,17,10,.45);
  border: 0;
  width: 100vw; height: 100vh;
  max-width: 100vw; max-height: 100vh;
  padding: 24px;
  display: flex; align-items: center; justify-content: center;
}
.modal::backdrop { background: rgba(21,17,10,.45); }

.modal-box {
  border-radius: var(--r-lg);
  width: 100%;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
}

/* Incident modal */
.inc-modal-box {
  background: #f6f2eb;
  max-width: 1060px;
}
.modal-hdr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 22px 16px;
  border-bottom: 1px solid #e8dfc9;
  background: #f6f2eb;
}
.modal-eyebrow { color: var(--muted); font-size: 0.78rem; margin-bottom: 4px; }
.modal-title   { font-size: 1.05rem; font-weight: 700; }
.modal-title-row { display: flex; align-items: center; gap: 8px; }

.inc-modal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 16px 22px 22px;
}
.modal-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px 16px;
}
.modal-panel.span2 { grid-column: 1 / -1; }
.panel-lbl { color: var(--muted); font-size: 0.78rem; margin-bottom: 7px; }
.modal-panel h4 { font-size: 0.95rem; font-weight: 600; }
.modal-panel pre {
  background: #fffdf9;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font-size: 0.78rem;
  padding: 10px 12px;
  width: 100%;
  overflow: auto;
}
textarea {
  display: block;
  width: 100%;
  background: #fffdf9;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--text);
  font: inherit;
  font-size: 0.85rem;
  padding: 10px 12px;
  resize: vertical;
}
.modal-footer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
}
.check-label { display: flex; align-items: center; gap: 6px; font-size: 0.83rem; }

.activity-list li {
  border-bottom: 1px solid var(--line-light);
  font-size: 0.85rem;
  padding: 8px 0;
}
.activity-list li:last-child { border-bottom: 0; }

/* Feature modal */
.feat-modal-box {
  background: var(--panel);
  max-width: 700px;
  padding: 22px;
}
.feat-modal-hdr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 0;
}

.feat-modal-body {
  border-top: 1px solid var(--line);
  margin-top: 16px;
  padding-top: 16px;
}
.feat-modal-body.is-locked {
  opacity: 0.6;
  pointer-events: none;
  user-select: none;
}

.feat-modal-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border-top: 1px solid var(--line);
  margin-top: 20px;
  padding-top: 16px;
}
.modal-actions { display: flex; gap: 8px; align-items: center; margin-left: auto; }

/* Modal form elements */
.modal-stack { display: flex; flex-direction: column; gap: 16px; }
.modal-switch-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.modal-switch-row > span { font-size: 14px; font-weight: 600; }
.modal-field { display: flex; flex-direction: column; gap: 8px; }
.modal-field-lbl { font-size: 14px; font-weight: 600; }
.modal-note { color: var(--muted); font-size: 0.83rem; }

.modal-input-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}
.modal-input-row span { color: var(--muted); font-weight: 600; font-size: 0.88rem; }
.modal-select,
.modal-num-input {
  display: block;
  width: 100%;
  background: #fffdf9;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--text);
  font: inherit;
  font-size: 0.88rem;
  padding: 10px 12px;
}

.token-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.token-opt { cursor: pointer; }
.token-opt input { display: none; }
.token-opt span {
  display: inline-flex;
  background: #f5f5f5;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 6px 12px;
  transition: all .12s;
}
.token-opt.is-on span {
  background: var(--blue-bg);
  border-color: #cfdcff;
  color: var(--blue);
}
.token-opt.is-disabled { cursor: not-allowed; opacity: 0.5; }

/* Upsell block in modal */
.upsell-block { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.upsell-block span { color: var(--muted); font-size: 0.85rem; }

/* API card */
.api-card { }
.api-card pre {
  background: #fafafa;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--text);
  font-size: 0.78rem;
  margin-top: 14px;
  padding: 14px;
  overflow: auto;
  max-height: 520px;
}

/* ============================================================
   Plan Upgrade / Downgrade Overlay
   ============================================================ */
.upgrade-overlay {
  position: fixed;
  inset: 0;
  background: rgba(8, 8, 18, 0.78);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.28s ease;
  backdrop-filter: blur(4px);
}
.upgrade-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}
.upgrade-box {
  background: #fff;
  border-radius: 20px;
  padding: 36px 32px 30px;
  text-align: center;
  max-width: 360px;
  width: 90%;
  box-shadow: 0 28px 90px rgba(0,0,0,0.32);
  transform: scale(0.93) translateY(8px);
  transition: transform 0.38s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.upgrade-overlay.is-visible .upgrade-box {
  transform: scale(1) translateY(0);
}
.upgrade-icon {
  font-size: 2.6rem;
  margin-bottom: 12px;
  display: block;
  animation: icon-pulse 0.6s ease-out;
}
@keyframes icon-pulse {
  0%   { transform: scale(0.7); opacity: 0; }
  60%  { transform: scale(1.15); }
  100% { transform: scale(1); opacity: 1; }
}
.upgrade-title {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0 0 20px;
  color: var(--text);
}
.upgrade-progress {
  background: #f0f0f3;
  border-radius: 999px;
  height: 6px;
  overflow: hidden;
  margin-bottom: 20px;
}
.upgrade-bar {
  height: 100%;
  background: linear-gradient(90deg, #8e36f5, #1f6eff);
  border-radius: 999px;
  width: 0%;
  transition: width 1.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.upgrade-checks {
  text-align: left;
  list-style: none;
  padding: 0;
  margin: 0;
  min-height: 120px;
}
.upgrade-checks li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  font-size: 0.88rem;
  color: var(--muted);
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.3s, transform 0.3s, color 0.3s;
}
.upgrade-checks li.is-visible {
  opacity: 1;
  transform: none;
  color: var(--text);
}
.upgrade-checks li::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  background: var(--green-bg);
  color: var(--green);
  border-radius: 50%;
  font-size: 0.7rem;
  font-weight: 700;
  flex-shrink: 0;
}
.upgrade-done {
  font-size: 0.88rem;
  color: var(--green);
  font-weight: 600;
  margin: 12px 0 0;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1100px) {
  .topbar { grid-template-columns: 1fr; height: auto; padding: 12px 16px; gap: 8px; }
  .topbar-nav, .topbar-end { flex-wrap: wrap; }
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { border-right: 0; border-bottom: 1px solid var(--line); }
  .dash-grid { grid-template-columns: 1fr; }
  .dash-rail { display: grid; grid-template-columns: 1fr 1fr; gap: 0 24px; }
  .rail-card:last-child { border-bottom: 1px solid var(--line); }
  .inc-head, .inc-row { grid-template-columns: 90px 1fr; }
  .inc-head span:nth-child(3),
  .inc-head span:nth-child(4),
  .inc-row .inc-when,
  .inc-row .inc-dur { display: none; }
  .feat-cards { grid-template-columns: 1fr 1fr; }
  .inc-modal-grid { grid-template-columns: 1fr; }
  .modal-panel.span2 { grid-column: 1; }
  .settings-hdr { flex-direction: column; }
  .uptime-strip { grid-template-columns: 1fr; }
  .strip-stats { grid-template-columns: 1fr 1fr; }
  .module-top { flex-direction: column; gap: 12px; }
  .module-actions { flex-wrap: wrap; }
  .stat-cards { grid-template-columns: 1fr; }
  .uptime-periods { grid-template-columns: 1fr 1fr; }
  .chart-stats-row { grid-template-columns: 1fr 1fr 1fr; }
}

/* ============================================================
   Fix: dialog must be hidden when not open
   ============================================================ */
dialog:not([open]) { display: none !important; }

/* ============================================================
   Stat Cards Row  (top of dashboard, like UptimeRobot)
   ============================================================ */
.stat-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
.stat-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 16px 18px;
}
.stat-lbl {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.stat-big {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.1;
}
.stat-big.is-up   { color: var(--green); }
.stat-big.is-down { color: var(--red);   }
.stat-big.is-paused { color: var(--muted); }
.stat-sub {
  font-size: 0.8rem;
  margin-top: 5px;
}

/* 24h mini bar inside stat card */
.sc-bar-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 0 4px;
}
.sc-bar {
  display: flex;
  gap: 2px;
  flex: 1;
  height: 24px;
  align-items: stretch;
}
.sc-seg {
  flex: 1;
  border-radius: 2px;
  background: var(--green);
  min-width: 0;
  cursor: pointer;
  transition: opacity .12s;
}
.sc-seg:hover { opacity: .72; }
.sc-seg.is-down { background: var(--red); }
.sc-pct {
  font-size: 1rem;
  font-weight: 700;
  color: var(--green);
  white-space: nowrap;
}
.sc-pct.is-down { color: var(--red); }

/* ============================================================
   Uptime Period Boxes  (7d / 30d / 365d / MTBF)
   ============================================================ */
.uptime-periods {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 22px;
}
.period-box {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px 16px;
}
.period-lbl {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.period-val {
  font-size: 1.45rem;
  font-weight: 700;
  line-height: 1.2;
  color: var(--green);
}
.period-val.is-amber  { color: #b8902e; }
.period-val.is-locked {
  color: var(--muted-lt);
  filter: blur(5px);
  user-select: none;
}
.period-hint {
  font-size: 0.78rem;
  margin-top: 4px;
}
.period-hint.is-locked {
  filter: blur(4px);
  user-select: none;
}

/* ============================================================
   Chart stats row below chart  (like UptimeRobot)
   ============================================================ */
.chart-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  margin-top: 16px;
  padding-top: 14px;
}
.cstat {
  padding: 0 20px;
  border-right: 1px solid var(--line);
}
.cstat:first-child { padding-left: 0; }
.cstat:last-child  { border-right: 0; }
.cstat-lbl {
  display: block;
  color: var(--muted);
  font-size: 0.76rem;
  margin-bottom: 4px;
}
.cstat strong { font-size: 1.1rem; font-weight: 700; }

/* ============================================================
   Right Rail — Location (World Map)
   ============================================================ */
.loc-map {
  position: relative;
  width: 100%;
  height: 96px;
  border-radius: var(--r-sm);
  overflow: hidden;
  margin-bottom: 8px;
  background: #eaf3fb;
}
.continent {
  fill: #b8ccdc;
  stroke: #a0b8cc;
  stroke-width: 0.5;
  stroke-linejoin: round;
}
/* USA: lon=-94.6 lat=38.6  →  svgX=237/1000=23.7%
   With xMidYMin slice on 255×96 container:
   scale=255/1000=0.255  →  screenX=60px=23.7%  screenY=143*0.255=36.5px=38% */
.loc-dot-wrap {
  position: absolute;
  left: 23.7%;
  top: 38%;
  transform: translate(-50%, -50%);
  z-index: 5;
  width: 8px; height: 8px;
}
.loc-dot {
  width: 8px; height: 8px;
  background: var(--green);
  border-radius: 50%;
  border: 1.5px solid #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.25);
  position: relative;
  z-index: 2;
}
.loc-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--green);
  animation: loc-pulse 2.4s ease-out infinite;
}
@keyframes loc-pulse {
  0%   { transform: scale(1);   opacity: 0.55; }
  100% { transform: scale(4.5); opacity: 0; }
}
.loc-region-lbl {
  font-size: 0.9rem;
  font-weight: 700;
  margin: 0 0 2px;
}
.loc-region-sub { font-size: 0.75rem; }

/* ============================================================
   Right Rail — Pro Lock Wall
   ============================================================ */
.rail-pro-lock {
  background: #fafafa;
  border-color: var(--line) !important;
}
.rail-pro-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.btn-upgrade-xs {
  background: linear-gradient(90deg, #8e36f5, #d4732a);
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 5px 11px;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity .12s;
}
.btn-upgrade-xs:hover { opacity: .88; }

.rail-pro-row {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 8px 4px;
  border-top: 1px solid var(--amber-border);
  cursor: pointer;
  border-radius: 0;
  transition: background .12s;
}
.rail-pro-row:hover { background: #fef2db; border-radius: var(--r-sm); }
.rail-pro-icon { font-size: 1rem; flex-shrink: 0; line-height: 1.5; }
.rail-pro-copy { flex: 1; min-width: 0; }
.rail-pro-copy strong {
  font-size: 0.82rem;
  font-weight: 700;
  display: block;
  margin-bottom: 1px;
}
.rail-pro-copy p {
  font-size: 0.74rem;
  color: var(--muted);
  margin: 0;
  line-height: 1.4;
}
.rail-pro-arrow {
  color: var(--muted-lt);
  font-size: 1rem;
  flex-shrink: 0;
  line-height: 2.2;
}

/* ============================================================
   Right Rail — Integrations
   ============================================================ */
.int-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--line-light);
}
.int-row:last-child { border-bottom: 0; }
.int-icon {
  width: 28px; height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  flex-shrink: 0;
}
.int-name { flex: 1; font-size: 0.85rem; font-weight: 500; }
.int-btn {
  background: var(--line-light);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  padding: 4px 10px;
  cursor: pointer;
  transition: all .12s;
}
.int-btn:not(.is-locked):hover { background: var(--blue); border-color: var(--blue); color: #fff; }
.int-btn.is-locked {
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
}

/* ============================================================
   Rail: Pro feature rows  (compact, with hover tooltip)
   ============================================================ */
.rail-feat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid var(--line-light);
  cursor: pointer;
  position: relative;
}
.rail-feat-row:last-child { border-bottom: 0; }
.rail-feat-row:hover { background: transparent; }
.rail-feat-label {
  font-size: 0.84rem;
  font-weight: 500;
  color: var(--text);
}
.rail-feat-val {
  font-size: 0.78rem;
  color: var(--muted);
  text-align: right;
  max-width: 90px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Hover tooltip for rail feat rows */
.rail-feat-row .feat-tip {
  display: none;
  position: absolute;
  right: 0;
  bottom: calc(100% + 6px);
  background: #1d1d1f;
  color: #fff;
  font-size: 0.75rem;
  line-height: 1.4;
  padding: 8px 10px;
  border-radius: var(--r-sm);
  white-space: normal;
  width: 180px;
  z-index: 99;
  pointer-events: none;
  box-shadow: 0 4px 16px rgba(0,0,0,.18);
}
.rail-feat-row:hover .feat-tip { display: block; }

/* ============================================================
   Settings page — clean, no icons, no amber
   ============================================================ */
.settings-row .row-ico,
.settings-row-btn .row-ico { display: none; }

.row-pro-label {
  color: var(--blue);
  font-size: 0.68rem;
  font-weight: 700;
  background: var(--blue-bg);
  border: 1px solid #c5d8ff;
  border-radius: 999px;
  padding: 2px 7px;
  white-space: nowrap;
}

.is-blurred {
  filter: blur(5px);
  user-select: none;
  pointer-events: none;
}

/* ============================================================
   Status row — allow sub text inline
   ============================================================ */
.status-row { flex-wrap: wrap; }
.status-row #status-sub { font-size: .85rem; margin: 0; }

/* ============================================================
   Status Page — Free Upsell
   ============================================================ */
.sp-upsell {
  max-width: 640px;
  margin: 0 auto;
  padding: 40px 24px;
  text-align: center;
}
.sp-upsell-icon {
  font-size: 2.8rem;
  margin-bottom: 14px;
}
.sp-upsell-title {
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 10px;
}
.sp-upsell-sub {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.6;
  margin-bottom: 32px;
}
.sp-features-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
  text-align: left;
  margin-bottom: 32px;
}
.sp-feat {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px 16px;
}
.sp-feat-icon {
  font-size: 1.2rem;
  display: block;
  margin-bottom: 6px;
}
.sp-feat strong {
  font-size: 0.85rem;
  color: var(--text);
  display: block;
  margin-bottom: 3px;
}
.sp-feat p {
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.45;
}
.sp-upgrade-btn {
  font-size: 0.9rem;
  padding: 10px 28px;
}

/* ============================================================
   Status Page — Pro Content
   ============================================================ */
.sp-loading, .sp-error {
  padding: 32px;
  color: var(--muted);
  font-size: 0.9rem;
}
.sp-error { color: var(--red); }

.sp-pro { display: flex; flex-direction: column; gap: 16px; }

/* Header */
.sp-pro-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.sp-pro-name-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}
.sp-pro-name {
  font-size: 1.15rem;
  font-weight: 700;
}
.sp-name-edit-btn {
  font-size: 0.78rem;
  color: var(--muted);
  opacity: 0.7;
}
.sp-name-edit-btn:hover { opacity: 1; color: var(--blue); }

.sp-name-editor {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--blue-bg);
  border: 1px solid #c5d8ff;
  border-radius: var(--r-sm);
}
.sp-name-input {
  flex: 1;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 0.9rem;
  background: #fff;
  outline: none;
}
.sp-name-input:focus { border-color: var(--blue); }

.sp-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--green-bg);
  color: var(--green);
  border-radius: 999px;
  padding: 3px 10px;
  font-size: 0.72rem;
  font-weight: 600;
  flex-shrink: 0;
}
.sp-status-badge::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
}

/* URL rows */
.sp-url-list { display: flex; flex-direction: column; gap: 0; }
.sp-url-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 0;
  border-bottom: 1px solid var(--line-light);
  gap: 12px;
}
.sp-url-row:last-child { border-bottom: 0; }
.sp-url-lbl { color: var(--muted); font-size: 0.82rem; flex-shrink: 0; }
.sp-url-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.sp-url-val {
  color: var(--blue);
  font-size: 0.82rem;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 260px;
}
.sp-url-val:hover { text-decoration: underline; }
.sp-copy-btn {
  background: var(--line-light);
  border: 1px solid var(--line);
  border-radius: 5px;
  padding: 2px 7px;
  font-size: 0.78rem;
  color: var(--muted);
  cursor: pointer;
  flex-shrink: 0;
  transition: background .12s;
}
.sp-copy-btn:hover { background: var(--line); color: var(--text); }

/* Editable settings rows */
.sp-settings-list { display: flex; flex-direction: column; }
.sp-settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 0;
  border-bottom: 1px solid var(--line-light);
  gap: 24px;
}
.sp-settings-row:last-child { border-bottom: 0; }
.sp-settings-copy { flex: 1; }
.sp-settings-copy strong { font-size: 0.87rem; color: var(--text); }
.sp-settings-copy p { font-size: 0.78rem; color: var(--muted); margin-top: 2px; }
.sp-select {
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 5px 10px;
  font-size: 0.82rem;
  background: #fff;
  color: var(--text);
  cursor: pointer;
  flex-shrink: 0;
  min-width: 120px;
}
