/* ============================================================
   Rankvein — "Signal" design system
   Mission control for content operations.
   Dark (Signal) default + Light (Daylight).
   - Accent is swappable via [data-accent]:  violet (default) · cyan · lime · amber
   - Surface is swappable via [data-surface]: ink (near-black, default) · slate (cool-gray)
   Ported from the Claude Design "Signal" handoff (2026-06-16) and adapted for
   the Flask/Jinja app. Loaded alongside Tailwind during the page-by-page
   migration; once every page is on Signal, Tailwind + theme.css can be dropped.
   ============================================================ */

/* ----------  RESET-ish  ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.55;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow: hidden; /* app shell owns scrolling */
}
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--accent); color: var(--accent-ink); }

/* ============================================================
   THEME TOKENS
   ============================================================ */
:root {
  /* dark "Signal" (default) — near-black "ink" surfaces */
  --bg:            #0a0c0b;
  --bg-grain:      #0d100e;
  --s1:            #121514;   /* base card */
  --s2:            #181c1a;   /* raised */
  --s3:            #20251f;   /* hover / inset chips */
  --s-inset:       #0c0f0d;   /* wells, inputs */
  --line:          rgba(255,255,255,0.07);
  --line-strong:   rgba(255,255,255,0.13);
  --text:          #e9ece6;
  --text-mid:      #a7afa5;
  --text-dim:      #6f786e;
  --text-faint:    #4d544b;

  --shadow-card:   0 1px 0 rgba(255,255,255,0.03) inset, 0 8px 24px -12px rgba(0,0,0,0.6);
  --shadow-pop:    0 24px 60px -20px rgba(0,0,0,0.75);

  /* semantic */
  --good:          #7ee27a;
  --warn:          #f5c451;
  --bad:           #fb7185;
  --info:          #6bc5ff;

  /* accent — lime is the file default; the app sets [data-accent] (violet). */
  --accent:        #b4f23c;
  --accent-2:      #93d521;
  --accent-soft:   rgba(180,242,60,0.13);
  --accent-soft2:  rgba(180,242,60,0.07);
  --accent-ink:    #10160a;   /* text on accent fills */
  --accent-glow:   rgba(180,242,60,0.22);

  /* automation / AI accent (stays violet across themes) */
  --magic:         #b69bff;
  --magic-soft:    rgba(182,155,255,0.14);

  --radius-card:   16px;
  --radius-ctl:    11px;
  --radius-chip:   8px;

  --sidebar-w:     244px;
  --topbar-h:      62px;

  /* density (overwritten by [data-density]) */
  --pad-card:      22px;
  --row-h:         44px;
  --gap:           20px;

  --mono: "Space Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --display: "Space Grotesk", sans-serif;
}

/* ----- accent variants ----- */
[data-accent="violet"] {
  --accent: #a78bfa; --accent-2: #8b5cf6; --accent-soft: rgba(167,139,250,0.15);
  --accent-soft2: rgba(167,139,250,0.08); --accent-ink: #160a2e; --accent-glow: rgba(167,139,250,0.24);
}
[data-accent="cyan"] {
  --accent: #2ee6e6; --accent-2: #19c9d4; --accent-soft: rgba(46,230,230,0.13);
  --accent-soft2: rgba(46,230,230,0.07); --accent-ink: #04201f; --accent-glow: rgba(46,230,230,0.22);
}
[data-accent="lime"] {
  --accent: #b4f23c; --accent-2: #93d521; --accent-soft: rgba(180,242,60,0.13);
  --accent-soft2: rgba(180,242,60,0.07); --accent-ink: #10160a; --accent-glow: rgba(180,242,60,0.22);
}
[data-accent="amber"] {
  --accent: #ffb13d; --accent-2: #f59e0b; --accent-soft: rgba(255,177,61,0.14);
  --accent-soft2: rgba(255,177,61,0.07); --accent-ink: #271603; --accent-glow: rgba(255,177,61,0.22);
}

/* ----- surface variant: cool blue-gray (exact values from the design handoff) ----- */
[data-theme="dark"][data-surface="cool"] {
  --bg:            #0c0e13;
  --bg-grain:      #0f131a;
  --s1:            #161a22;
  --s2:            #1c212b;
  --s3:            #252b38;
  --s-inset:       #0e1117;
  --line:          rgba(190,205,235,0.09);
  --line-strong:   rgba(190,205,235,0.15);
  --text:          #e8ebf2;
  --text-mid:      #a3abbd;
  --text-dim:      #6b7488;
  --text-faint:    #4a5266;
}

/* ----- light "Daylight" ----- */
[data-theme="light"] {
  --bg:            #f4f5f1;
  --bg-grain:      #eef0ea;
  --s1:            #ffffff;
  --s2:            #ffffff;
  --s3:            #f1f3ec;
  --s-inset:       #f4f5f1;
  --line:          rgba(17,21,15,0.09);
  --line-strong:   rgba(17,21,15,0.16);
  --text:          #14180f;
  --text-mid:      #5a6256;
  --text-dim:      #828a7d;
  --text-faint:    #aab0a3;
  --shadow-card:   0 1px 2px rgba(20,24,15,0.04), 0 8px 24px -16px rgba(20,24,15,0.14);
  --shadow-pop:    0 24px 60px -20px rgba(20,24,15,0.22);
  --good: #2f9e44; --warn: #d68910; --bad: #e03e52; --info: #1f87d6;
  --accent-ink: #14180f;
}
/* (No light+cool variant — in light theme the surface uses the default Daylight
   palette, matching the design handoff. "cool" is a dark-mode surface.) */
/* light accent re-tunes (darker so they read on white) */
[data-theme="light"]                        { --accent:#7c5cff; --accent-2:#6943f0; --accent-soft:rgba(124,92,255,0.12); --accent-soft2:rgba(124,92,255,0.06); --accent-glow:rgba(124,92,255,0.2);}
[data-theme="light"][data-accent="cyan"]    { --accent:#0bb6bd; --accent-2:#0a989e; --accent-soft:rgba(11,182,189,0.12); --accent-soft2:rgba(11,182,189,0.06); --accent-glow:rgba(11,182,189,0.18);}
[data-theme="light"][data-accent="lime"]    { --accent:#5fab00; --accent-2:#4d8c00; --accent-soft:rgba(95,171,0,0.13); --accent-soft2:rgba(95,171,0,0.06); --accent-glow:rgba(95,171,0,0.18);}
[data-theme="light"][data-accent="amber"]   { --accent:#e08600; --accent-2:#c26f00; --accent-soft:rgba(224,134,0,0.13); --accent-soft2:rgba(224,134,0,0.06); --accent-glow:rgba(224,134,0,0.18);}

/* density */
[data-density="compact"]  { --pad-card: 16px; --row-h: 38px; --gap: 14px; }
[data-density="comfy"]    { --pad-card: 28px; --row-h: 50px; --gap: 26px; }

/* ============================================================
   TYPE SCALE
   ============================================================ */
.display { font-family: var(--display); font-weight: 700; letter-spacing: -0.02em; line-height: 1.04; }
.h1 { font-family: var(--display); font-weight: 700; font-size: 27px; letter-spacing: -0.02em; line-height: 1.1; }
.h2 { font-family: var(--display); font-weight: 600; font-size: 19px; letter-spacing: -0.01em; line-height: 1.2; }
.h3 { font-family: var(--display); font-weight: 600; font-size: 15px; letter-spacing: -0.005em; }
.eyebrow { font-family: var(--mono); font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-dim); }
.mono { font-family: var(--mono); font-feature-settings: "tnum" 1; }
.metric { font-family: var(--display); font-weight: 700; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; line-height: 0.95; }
.dim { color: var(--text-dim); }
.mid { color: var(--text-mid); }
.measure-prose { max-width: 64ch; }

/* ============================================================
   APP SHELL LAYOUT
   ============================================================ */
.app { display: grid; grid-template-columns: var(--sidebar-w) 1fr; height: 100vh; width: 100vw; }
.app[data-rail="true"] { --sidebar-w: 72px; }

/* ---- Sidebar ---- */
.sidebar {
  background: var(--bg-grain);
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column;
  height: 100vh; overflow: hidden;
  position: relative; z-index: 30;
}
.brand { display: flex; align-items: center; gap: 11px; padding: 18px 18px 14px; }
.brand-mark {
  width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0;
  display: grid; place-items: center;
  background: linear-gradient(140deg, var(--accent), var(--accent-2));
  color: var(--accent-ink); font-family: var(--display); font-weight: 700; font-size: 18px;
  box-shadow: 0 0 18px -4px var(--accent-glow);
}
.brand-name { font-family: var(--display); font-weight: 700; font-size: 18px; letter-spacing: -0.01em; color: var(--text); }
.brand-sub { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-dim); margin-top: -1px; }

.nav { flex: 1; overflow-y: auto; padding: 6px 12px 12px; }
.nav-group-label { padding: 14px 10px 5px; }
.nav-item {
  display: flex; align-items: center; gap: 11px;
  padding: 0 11px; min-height: 38px; border-radius: 10px;
  color: var(--text-mid); font-size: 13.5px; font-weight: 500;
  position: relative; transition: background .14s, color .14s;
}
.nav-item:hover { background: var(--s2); color: var(--text); }
.nav-item.active { background: var(--accent-soft); color: var(--text); }
.nav-item.active::before {
  content:""; position:absolute; left:-12px; top:50%; transform:translateY(-50%);
  width:3px; height:18px; border-radius:0 3px 3px 0; background: var(--accent);
  box-shadow: 0 0 10px var(--accent-glow);
}
.nav-item .ico { color: var(--text-dim); flex-shrink: 0; }
.nav-item.active .ico { color: var(--accent); }
.nav-badge { margin-left: auto; font-family: var(--mono); font-size: 10.5px; font-weight: 700;
  background: var(--s3); color: var(--text-mid); border-radius: 6px; padding: 1px 6px; }
.nav-badge.live { background: var(--accent-soft); color: var(--accent-2); }

[data-rail="true"] .nav-label, [data-rail="true"] .brand-text, [data-rail="true"] .nav-group-label,
[data-rail="true"] .nav-badge, [data-rail="true"] .side-foot-text { display: none; }
[data-rail="true"] .nav-item { justify-content: center; padding: 0; }
[data-rail="true"] .brand { justify-content: center; padding: 18px 0 14px; }

.side-foot { border-top: 1px solid var(--line); padding: 10px 12px 14px; }
.user-chip { display: flex; align-items: center; gap: 10px; padding: 7px 9px; border-radius: 10px; }
.user-chip:hover { background: var(--s2); }
.avatar { width: 30px; height: 30px; border-radius: 9px; flex-shrink: 0; display: grid; place-items: center;
  font-family: var(--display); font-weight: 700; font-size: 13px; color: var(--text);
  background: var(--s3); border: 1px solid var(--line-strong); }

/* ---- Main column ---- */
.main { display: flex; flex-direction: column; height: 100vh; overflow: hidden; }
.topbar {
  height: var(--topbar-h); flex-shrink: 0;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 14px;
  padding: 0 26px; background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
}
.crumb { display: flex; align-items: center; gap: 8px; font-size: 13.5px; color: var(--text-dim); white-space: nowrap; }
.crumb a:hover { color: var(--text); }
.crumb .here { color: var(--text); font-weight: 600; white-space: nowrap; }

.scroll { flex: 1; overflow-y: auto; scroll-behavior: smooth; }
.page { max-width: 1320px; margin: 0 auto; padding: 30px 30px 80px; }

/* ============================================================
   COMPONENTS
   ============================================================ */
.card {
  background: var(--s1); border: 1px solid var(--line);
  border-radius: var(--radius-card); box-shadow: var(--shadow-card);
}
.card-pad { padding: var(--pad-card); }
.card-hd { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 16px; }

.btn {
  display: inline-flex; align-items: center; gap: 8px; justify-content: center;
  height: 40px; padding: 0 16px; border-radius: var(--radius-ctl);
  font-size: 13.5px; font-weight: 600; border: 1px solid transparent;
  transition: transform .12s, background .15s, border-color .15s, box-shadow .15s;
  white-space: nowrap; color: var(--text);
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: var(--accent-ink);
  box-shadow: 0 0 0 1px var(--accent-2) inset, 0 8px 20px -10px var(--accent-glow); }
.btn-primary:hover { box-shadow: 0 0 0 1px var(--accent) inset, 0 10px 26px -8px var(--accent-glow); }
.btn-ghost { background: var(--s2); color: var(--text); border-color: var(--line-strong); }
.btn-ghost:hover { background: var(--s3); border-color: var(--text-faint); }
.btn-quiet { background: transparent; color: var(--text-mid); }
.btn-quiet:hover { background: var(--s2); color: var(--text); }
.btn-sm { height: 32px; padding: 0 12px; font-size: 12.5px; border-radius: 9px; }
.btn-icon { width: 38px; height: 38px; padding: 0; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ----- Notifications (topbar bell + panel) ----- */
.notif-badge {
  position: absolute; top: -2px; right: -2px; min-width: 16px; height: 16px;
  padding: 0 4px; border-radius: 9px; box-sizing: border-box;
  background: var(--bad); color: #fff;
  font-family: var(--mono); font-size: 10px; font-weight: 700; line-height: 16px;
  text-align: center; border: 2px solid var(--bg); pointer-events: none;
}
.notif-item {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 11px 14px; border-bottom: 1px solid var(--line);
  text-decoration: none; color: var(--text); transition: background .12s;
}
.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: var(--s2); }
.notif-item.unread { background: var(--accent-soft2); }
.notif-dot { flex-shrink: 0; width: 8px; height: 8px; border-radius: 50%; margin-top: 5px; background: var(--text-dim); }
.notif-item.unread .notif-dot { box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 22%, transparent); }
.notif-info    { background: var(--info); }
.notif-error, .notif-bad { background: var(--bad); }
.notif-success, .notif-good { background: var(--good); }
.notif-warn    { background: var(--warn); }
.notif-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
.notif-title { font-size: 13px; font-weight: 600; line-height: 1.35; }
.notif-item.unread .notif-title { font-weight: 700; }
.notif-text { font-size: 12.5px; color: var(--text-mid); line-height: 1.4; }
.notif-time { font-family: var(--mono); font-size: 10.5px; color: var(--text-dim); margin-top: 1px; }

.chip {
  display: inline-flex; align-items: center; gap: 6px;
  height: 24px; padding: 0 9px; border-radius: 7px;
  font-family: var(--mono); font-size: 11px; font-weight: 700; letter-spacing: 0.02em;
  background: var(--s3); color: var(--text-mid); border: 1px solid var(--line);
}
.chip-good { background: color-mix(in srgb, var(--good) 14%, transparent); color: var(--good); border-color: transparent; }
.chip-warn { background: color-mix(in srgb, var(--warn) 16%, transparent); color: var(--warn); border-color: transparent; }
.chip-bad  { background: color-mix(in srgb, var(--bad) 15%, transparent);  color: var(--bad);  border-color: transparent; }
.chip-accent { background: var(--accent-soft); color: var(--accent-2); border-color: transparent; }
.chip-magic { background: var(--magic-soft); color: var(--magic); border-color: transparent; }

.input, .select, textarea.input {
  width: 100%; height: 42px; padding: 0 13px; border-radius: var(--radius-ctl);
  background: var(--s-inset); border: 1px solid var(--line-strong); color: var(--text);
  font-size: 13.5px; font-family: inherit; transition: border-color .15s, box-shadow .15s;
}
textarea.input { height: auto; min-height: 80px; padding: 10px 13px; line-height: 1.5; }
.input::placeholder { color: var(--text-faint); }
.input:focus, .select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.field-label { display: block; font-size: 12.5px; font-weight: 600; color: var(--text-mid); margin-bottom: 7px; }

/* live dot */
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); position: relative; flex-shrink: 0; }
.live-dot::after { content:""; position:absolute; inset:-4px; border-radius:50%; border:1px solid var(--accent);
  animation: ping 1.8s cubic-bezier(0,0,.2,1) infinite; }
@keyframes ping { 0%{transform:scale(.6);opacity:.9} 100%{transform:scale(2.1);opacity:0} }

/* progress */
.track { height: 6px; border-radius: 99px; background: var(--s-inset); overflow: hidden; position: relative; }
.track-fill { height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--accent-2), var(--accent)); position: relative; }
.track-fill.magic { background: linear-gradient(90deg, var(--magic), #d7c4ff); }
.track-fill.shimmer::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  transform: translateX(-100%); animation: shimmer 1.6s ease-in-out infinite;
}
@keyframes shimmer { 100% { transform: translateX(100%); } }

/* Live now — topbar pill + dashboard task cards */
.task-pill {
  display: inline-flex; align-items: center; gap: 8px; height: 34px; padding: 0 13px;
  border-radius: 9px; font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.01em; text-decoration: none; white-space: nowrap;
  background: var(--accent-soft); color: var(--accent-2); border: 1px solid transparent;
  transition: background .15s, border-color .15s;
}
.task-pill:hover { background: var(--accent-soft); border-color: var(--accent-2); }
.live-card {
  display: block; padding: 14px; border-radius: var(--radius-ctl);
  background: var(--s-inset); border: 1px solid var(--line); text-decoration: none;
  transition: border-color .15s, transform .15s;
}
.live-card:hover { border-color: var(--accent-2); transform: translateY(-1px); }
.live-msg { margin-top: 9px; font-size: 12.5px; color: var(--text-mid); line-height: 1.4;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* table */
.tbl { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.tbl thead th { text-align: left; padding: 0 14px 10px; font-family: var(--mono); font-size: 10.5px;
  font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim);
  border-bottom: 1px solid var(--line); }
.tbl tbody td { padding: 0 14px; height: var(--row-h); border-bottom: 1px solid var(--line); color: var(--text-mid); vertical-align: middle; }
.tbl tbody tr { transition: background .12s; }
.tbl tbody tr:hover { background: var(--s2); }
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl .strong { color: var(--text); font-weight: 600; }

/* segmented */
.seg { display: inline-flex; background: var(--s-inset); border: 1px solid var(--line); border-radius: 10px; padding: 3px; gap: 2px; }
.seg button { height: 30px; padding: 0 13px; border-radius: 7px; font-size: 12.5px; font-weight: 600;
  background: transparent; color: var(--text-dim); border: none; }
.seg button.on { background: var(--s2); color: var(--text); box-shadow: var(--shadow-card); }
[data-theme="light"] .seg button.on { background: #fff; }

/* delta pill */
.delta { display: inline-flex; align-items: center; gap: 3px; font-family: var(--mono); font-size: 12px; font-weight: 700; }
.delta.up { color: var(--good); }
.delta.down { color: var(--bad); }
.delta.flat { color: var(--text-dim); }

/* misc utils */
.row { display: flex; align-items: center; }
.col { display: flex; flex-direction: column; }
.grid { display: grid; gap: var(--gap); }
.hairline { height: 1px; background: var(--line); border: none; margin: 0; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 99px; border: 3px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: var(--text-faint); background-clip: padding-box; }

/* focus ring */
:where(a,button,[role="button"],input,select,textarea,[tabindex]):focus-visible {
  outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 6px;
}

/* dashboard: needs-you action cards */
.qcard { display: flex; align-items: center; gap: 12px; padding: 14px; border-radius: var(--radius-ctl);
  background: var(--s-inset); border: 1px solid var(--line); cursor: pointer; transition: border-color .14s, background .14s, transform .12s; }
.qcard:hover { border-color: var(--line-strong); background: var(--s2); transform: translateY(-1px); }
.qicon { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; flex-shrink: 0; }

/* dashboard: site portfolio row */
.site-row { display: flex; align-items: center; gap: 11px; padding: 10px 8px; border-radius: 10px;
  transition: background .12s; cursor: pointer; }
.site-row:hover { background: var(--s2); }

/* checkbox */
.cbx { width: 18px; height: 18px; border-radius: 6px; border: 1.5px solid var(--line-strong); display: grid; place-items: center;
  color: var(--accent-ink); transition: background .12s, border-color .12s; flex-shrink: 0; }
.cbx.on { background: var(--accent); border-color: var(--accent); }

/* range input */
input[type="range"] { -webkit-appearance: none; appearance: none; height: 5px; border-radius: 99px; background: var(--s-inset); accent-color: var(--accent); }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; width: 17px; height: 17px; border-radius: 50%;
  background: var(--accent); border: 3px solid var(--bg); cursor: pointer; box-shadow: 0 0 0 1px var(--accent); }
input[type="range"]::-moz-range-thumb { width: 14px; height: 14px; border-radius: 50%; background: var(--accent); border: 3px solid var(--bg); cursor: pointer; }

/* toast (carried over from the app) */
#toast-container { position: fixed; z-index: 1100; bottom: 18px; right: 18px; display: flex; flex-direction: column; gap: 10px; max-width: 380px; pointer-events: none; }
.toast { pointer-events: auto; display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px;
  background: var(--s2); border: 1px solid var(--line-strong); border-left-width: 3px;
  border-radius: var(--radius-ctl); box-shadow: var(--shadow-pop); font-size: 13.5px; color: var(--text); }

/* skip link */
.skip-link { position: fixed; top: 10px; left: 10px; z-index: 2000; transform: translateY(-150%);
  background: var(--accent); color: var(--accent-ink); font-weight: 700; padding: 8px 14px; border-radius: 9px; transition: transform .15s; }
.skip-link:focus { transform: none; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* entrance — animates transform only (never opacity) so content is visible even when paused */
@keyframes rise { from { transform: translateY(12px); } to { transform: none; } }
.rise { animation: rise .55s cubic-bezier(.16,1,.3,1) backwards; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .live-dot::after { display: none; }
  .rise { animation: none; }
}
