/* ============================================================
 * Arkturus Ops — Django Admin Skin
 * Matches ops-console: light sidebar, grid-bg content,
 * ink-primary interactive, crimson for danger/live only.
 *
 * Django admin HTML structure (4.2):
 *   #container (flex-column)
 *     #header  (full-width)
 *     .main#main (flex-ROW)
 *       .toggle-nav-sidebar (hidden)
 *       nav#nav-sidebar
 *       .content (flex:1)
 *         .breadcrumbs
 *         #content
 * ============================================================ */
@import url("tokens.css");
@import url("components.css");

/* ================================================================
 * BASE RESET
 * ================================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-sans) !important;
  font-size: var(--text-sm) !important;
  line-height: var(--leading-normal) !important;
  color: var(--text-body) !important;
  background: var(--bg-app) !important;
  -webkit-font-smoothing: antialiased;
}
::selection { background: var(--selection-bg); }
:focus-visible { outline: 2px solid var(--focus-ring) !important; outline-offset: 2px; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--neutral-300); border-radius: var(--radius-pill); border: 2px solid var(--bg-app); }
::-webkit-scrollbar-thumb:hover { background: var(--neutral-400); }
a, a:visited { color: var(--text-strong); text-decoration: none; }
a:hover { color: var(--text-body); text-decoration: underline; }

/* ================================================================
 * LAYOUT
 * ================================================================ */
#container {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100vh;
}

/* .main is the ROW that holds sidebar + content — do NOT set column */
.main, #main {
  display: flex !important;
  flex-direction: row !important;
  flex: 1 0 auto !important;
  align-items: flex-start;
}

/* ================================================================
 * HEADER — light topbar, full width
 * ================================================================ */
#header {
  width: 100%;
  flex-shrink: 0;
  background: var(--surface) !important;
  border-bottom: var(--hairline) solid var(--border-subtle) !important;
  height: var(--topbar-h) !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  box-shadow: none !important;
  position: sticky;
  top: 0;
  z-index: 100;
}

/* Branding: left block, same width as sidebar */
#branding {
  display: flex;
  align-items: center;
  width: var(--sidebar-w);
  flex-shrink: 0;
  height: 100%;
  padding: 0 var(--space-4);
  border-right: var(--hairline) solid var(--border-subtle);
}

.ark-branding { display: flex; align-items: center; gap: 10px; }
.ark-branding__mark {
  width: 30px; height: 30px; border-radius: 7px;
  background: var(--neutral-950);
  display: flex; align-items: center; justify-content: center;
  color: var(--neutral-400); flex-shrink: 0;
}
.ark-branding__name {
  display: block;
  font-family: var(--font-mono) !important;
  font-size: 14.5px !important;
  font-weight: var(--fw-semibold) !important;
  letter-spacing: -0.01em;
  color: var(--text-strong) !important;
  text-decoration: none !important;
  line-height: 1.1;
}
.ark-branding__name span { color: var(--crimson-600); }
.ark-branding__sub {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-faint);
  margin-top: 2px;
}

/* User tools: right side of topbar */
#user-tools {
  flex: 1;
  display: flex !important;
  align-items: center;
  justify-content: flex-end;
  padding: 0 var(--space-6);
  gap: var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-subtle) !important;
}
#user-tools a, #user-tools a:visited { color: var(--text-muted) !important; transition: color var(--dur-fast) var(--ease-out); }
#user-tools a:hover { color: var(--text-strong) !important; text-decoration: none; }
#user-tools strong { color: var(--text-body) !important; font-weight: var(--fw-medium); }

/* ================================================================
 * SIDEBAR — always visible, matches ops console nav panel
 * ================================================================ */

/* Hide toggle button, always show sidebar */
.toggle-nav-sidebar { display: none !important; }

#nav-sidebar {
  /* Override Django's hidden-by-default sidebar */
  flex: 0 0 var(--sidebar-w) !important;
  width: var(--sidebar-w) !important;
  margin-left: 0 !important;
  visibility: visible !important;
  left: 0 !important;

  background: var(--surface) !important;
  border-right: var(--hairline) solid var(--border-subtle) !important;
  border-top: none !important;

  position: sticky !important;
  top: var(--topbar-h) !important;
  max-height: calc(100vh - var(--topbar-h)) !important;
  overflow-y: auto;
  z-index: 10;
}

/* Nav search filter */
#nav-filter {
  font-family: var(--font-mono) !important;
  font-size: var(--text-xs) !important;
  background: var(--bg-sunken) !important;
  border: var(--hairline) solid var(--border-subtle) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--text-body) !important;
  height: var(--control-h-sm);
  padding: 0 var(--space-3) !important;
  width: calc(100% - 20px);
  margin: var(--space-3) 10px !important;
  display: block;
}
#nav-filter:focus {
  border-color: var(--border-strong) !important;
  box-shadow: 0 0 0 3px rgba(38,43,51,.12) !important;
  outline: none !important;
}

/* App section label */
#nav-sidebar .module caption,
#nav-sidebar .module__name,
#nav-sidebar th.model-name {
  display: block;
  font-family: var(--font-mono) !important;
  font-size: var(--text-2xs) !important;
  font-weight: var(--fw-medium) !important;
  letter-spacing: var(--tracking-label) !important;
  text-transform: uppercase !important;
  color: var(--text-faint) !important;
  padding: 14px var(--space-3) 5px !important;
  background: transparent !important;
  border: none !important;
  white-space: nowrap;
}

/* Module wrapper: remove default borders */
#nav-sidebar .module {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 var(--space-2) !important;
}
#nav-sidebar .module table { width: 100%; }
#nav-sidebar .module th { padding: 0 !important; width: 100%; }

/* Nav links */
#nav-sidebar a,
#nav-sidebar a:link,
#nav-sidebar a:visited {
  display: flex !important;
  align-items: center;
  width: 100%;
  font-size: var(--text-sm) !important;
  font-family: var(--font-sans) !important;
  color: var(--text-muted) !important;
  padding: 7px var(--space-2) !important;
  border-radius: var(--radius-sm) !important;
  border: var(--hairline) solid transparent !important;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out) !important;
  white-space: nowrap;
  text-decoration: none !important;
  margin-bottom: 1px;
}
#nav-sidebar a:hover {
  background: var(--surface-hover) !important;
  color: var(--text-body) !important;
  text-decoration: none !important;
}
#nav-sidebar .selected a,
#nav-sidebar a[aria-current="page"],
.nav-sidebar .current-app .section:link,
.nav-sidebar .current-app .section:visited {
  background: var(--surface-active) !important;
  color: var(--text-strong) !important;
  font-weight: var(--fw-medium) !important;
}

/* ================================================================
 * CONTENT AREA — grid bg, right of sidebar
 * ================================================================ */
.content, #content-start {
  flex: 1 !important;
  min-width: 0;
  background-color: var(--bg-app) !important;
  background-image: var(--grid-texture) !important;
  background-size: var(--grid-size) !important;
}

/* ================================================================
 * BREADCRUMBS
 * ================================================================ */
.breadcrumbs {
  background: var(--surface) !important;
  padding: var(--space-2) var(--space-6) !important;
  font-size: var(--text-xs) !important;
  font-family: var(--font-mono) !important;
  color: var(--text-subtle) !important;
  border-bottom: var(--hairline) solid var(--border-faint) !important;
  margin: 0 !important;
  line-height: 1;
}
.breadcrumbs a, .breadcrumbs a:visited { color: var(--text-muted) !important; }
.breadcrumbs a:hover { color: var(--text-body) !important; text-decoration: none; }

/* ================================================================
 * CONTENT PADDING + TITLE
 * ================================================================ */
#content {
  padding: var(--space-6) !important;
  background: transparent !important;
}
#content-main { background: transparent; }

#content h1, .content-title {
  font-family: var(--font-sans) !important;
  font-size: var(--text-xl) !important;
  font-weight: var(--fw-semibold) !important;
  color: var(--text-strong) !important;
  letter-spacing: var(--tracking-tight);
  margin: 0 0 var(--space-4) !important;
  padding-bottom: var(--space-3) !important;
  border-bottom: var(--hairline) solid var(--border-subtle);
  line-height: var(--leading-tight);
}

/* ================================================================
 * MODULES / PANELS
 * ================================================================ */
.module {
  background: var(--surface) !important;
  border: var(--hairline) solid var(--border-subtle) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  margin-bottom: var(--space-4) !important;
  overflow: hidden;
}
.module h2, .module caption {
  background: var(--bg-sunken) !important;
  color: var(--text-subtle) !important;
  font-family: var(--font-mono) !important;
  font-size: var(--text-2xs) !important;
  font-weight: var(--fw-medium) !important;
  letter-spacing: var(--tracking-label) !important;
  text-transform: uppercase !important;
  padding: 9px var(--space-4) !important;
  border-bottom: var(--hairline) solid var(--border-subtle) !important;
  text-shadow: none !important;
  margin: 0 !important;
}
.module table { width: 100%; border-collapse: collapse; }

/* ================================================================
 * CHANGELIST TABLE
 * ================================================================ */
#changelist-form .results {
  border: var(--hairline) solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

#result_list {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
#result_list thead th {
  background: var(--bg-sunken) !important;
  color: var(--text-subtle) !important;
  font-family: var(--font-mono) !important;
  font-size: var(--text-2xs) !important;
  font-weight: var(--fw-medium) !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  border-bottom: var(--hairline) solid var(--border-subtle) !important;
  border-top: none !important;
  padding: 9px var(--space-3) !important;
  text-align: left; white-space: nowrap;
  position: sticky; top: var(--topbar-h);
}
#result_list thead th a, #result_list thead th a:visited {
  color: var(--text-subtle) !important;
  display: inline-flex; align-items: center; gap: 4px;
}
#result_list thead th a:hover { color: var(--text-body) !important; text-decoration: none; }
#result_list thead th.sorted .text { color: var(--text-body) !important; }

#result_list tbody tr {
  border-bottom: var(--hairline) solid var(--border-faint);
  transition: background var(--dur-instant) var(--ease-out);
}
#result_list tbody tr:last-child { border-bottom: none; }
#result_list tbody tr:hover td { background: var(--surface-hover) !important; }
#result_list tbody tr.selected td { background: var(--signal-bg) !important; }
#result_list td {
  padding: 9px var(--space-3) !important;
  color: var(--text-body);
  vertical-align: middle;
}
#result_list td a, #result_list td a:visited { color: var(--text-strong) !important; font-weight: var(--fw-medium); }
#result_list td a:hover { text-decoration: underline; }
.row1, .row2 { background: var(--surface) !important; }

/* Mono numeric columns */
#result_list td.field-coins,
#result_list td.field-current_hp,
#result_list td.field-vitality,
#result_list td.field-power,
#result_list td.field-price,
#result_list td.field-stock,
#result_list td.field-quantity {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

/* ================================================================
 * PAGINATION
 * ================================================================ */
.paginator {
  font-size: var(--text-xs) !important;
  color: var(--text-muted) !important;
  background: var(--bg-sunken) !important;
  border-top: var(--hairline) solid var(--border-subtle) !important;
  padding: var(--space-2) var(--space-4) !important;
}
.paginator a, .paginator a:visited { color: var(--text-body) !important; padding: 2px var(--space-2); border-radius: var(--radius-xs); }
.paginator a:hover { background: var(--surface-active) !important; text-decoration: none; }
.paginator .this-page { font-weight: var(--fw-semibold); color: var(--text-strong) !important; }

/* ================================================================
 * SEARCH + FILTERS
 * ================================================================ */
#toolbar {
  background: var(--surface) !important;
  border: var(--hairline) solid var(--border-subtle) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--space-3) var(--space-4) !important;
  display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap;
  margin-bottom: var(--space-4) !important;
  box-shadow: var(--shadow-sm);
}
#searchbar, input[type="search"] {
  font-family: var(--font-mono) !important;
  font-size: var(--text-sm) !important;
  height: var(--control-h-md);
  padding: 0 var(--space-3) !important;
  border: var(--hairline) solid var(--border-default) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--bg-sunken) !important;
  color: var(--text-body) !important;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
  min-width: 240px;
}
#searchbar:focus, input[type="search"]:focus {
  border-color: var(--border-strong) !important;
  box-shadow: 0 0 0 3px rgba(38,43,51,.12) !important;
  outline: none !important;
}

#changelist-filter {
  background: var(--surface) !important;
  border: var(--hairline) solid var(--border-subtle) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden; box-shadow: var(--shadow-sm);
}
#changelist-filter h2 {
  font-family: var(--font-mono) !important;
  font-size: var(--text-2xs) !important;
  font-weight: var(--fw-medium) !important;
  letter-spacing: var(--tracking-label) !important;
  text-transform: uppercase !important;
  color: var(--text-subtle) !important;
  padding: 9px var(--space-4) !important;
  background: var(--bg-sunken) !important;
  border-bottom: var(--hairline) solid var(--border-subtle) !important;
  text-shadow: none !important; margin: 0 !important;
}
#changelist-filter h3 {
  font-size: var(--text-xs) !important;
  font-weight: var(--fw-semibold) !important;
  color: var(--text-muted) !important;
  padding: var(--space-3) var(--space-4) var(--space-1) !important;
}
#changelist-filter li { padding: 2px var(--space-4); border: none !important; }
#changelist-filter li a { font-size: var(--text-sm) !important; color: var(--text-body) !important; }
#changelist-filter li.selected a { font-weight: var(--fw-semibold) !important; color: var(--text-strong) !important; }

/* ================================================================
 * FORMS
 * ================================================================ */
.form-row {
  border-bottom: var(--hairline) solid var(--border-faint) !important;
  padding: var(--space-3) var(--space-4) !important;
}
.form-row:last-child { border-bottom: none !important; }
label { font-size: var(--text-xs) !important; font-weight: var(--fw-medium) !important; color: var(--text-muted) !important; }
label.required::after { color: var(--danger) !important; }

input[type="text"], input[type="password"], input[type="email"],
input[type="url"], input[type="number"], input[type="tel"],
input[type="date"], input[type="datetime-local"], textarea, select {
  font-family: var(--font-sans) !important;
  font-size: var(--text-sm) !important;
  color: var(--text-body) !important;
  background: var(--surface) !important;
  border: var(--hairline) solid var(--border-default) !important;
  border-radius: var(--radius-sm) !important;
  padding: 0 var(--space-3) !important;
  height: var(--control-h-md);
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
textarea {
  height: auto !important; min-height: 80px;
  padding: var(--space-2) var(--space-3) !important;
  resize: vertical; line-height: var(--leading-normal);
}
input:focus, textarea:focus, select:focus {
  border-color: var(--border-strong) !important;
  box-shadow: 0 0 0 3px rgba(38,43,51,.12) !important;
  outline: none !important;
}
input[type="checkbox"], input[type="radio"] {
  width: 15px; height: 15px; accent-color: var(--action-ink); cursor: pointer;
}
select[multiple] { height: auto !important; min-height: 80px; padding: var(--space-1) !important; }
.help { font-size: var(--text-xs) !important; color: var(--text-subtle) !important; margin-top: 3px !important; }
.errornote {
  font-size: var(--text-sm) !important; color: var(--danger-text) !important;
  background: var(--danger-bg) !important; border: var(--hairline) solid var(--danger-border) !important;
  border-radius: var(--radius-md) !important;
  padding: var(--space-3) var(--space-4) !important; margin-bottom: var(--space-4) !important;
}
ul.errorlist { padding: 0 !important; margin: 4px 0 0 !important; list-style: none; }
ul.errorlist li { color: var(--danger-text) !important; font-size: var(--text-xs) !important; margin-top: 2px; }

/* ================================================================
 * BUTTONS
 * ================================================================ */
.button, input[type="submit"], input[type="button"],
button, .submit-row input, .submit-row button, a.button {
  font-family: var(--font-sans) !important;
  font-size: var(--text-sm) !important;
  font-weight: var(--fw-medium) !important;
  height: var(--control-h-md);
  padding: 0 var(--space-4) !important;
  background: var(--action-ink) !important;
  color: var(--text-on-ink) !important;
  border: var(--hairline) solid var(--action-ink) !important;
  border-radius: var(--radius-sm) !important;
  cursor: pointer !important;
  transition: background var(--dur-fast) var(--ease-out) !important;
  text-decoration: none !important;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: none !important; text-shadow: none !important;
  line-height: 1; white-space: nowrap;
}
.button:hover, input[type="submit"]:hover, button:hover, a.button:hover {
  background: var(--action-ink-hover) !important;
  border-color: var(--action-ink-hover) !important;
  color: var(--text-on-ink) !important; text-decoration: none !important;
}
.button:active, input[type="submit"]:active, button:active { background: var(--action-ink-active) !important; }

.button.default, .historylink, a.viewsitelink {
  background: transparent !important; color: var(--text-body) !important;
  border-color: var(--border-default) !important;
}
.button.default:hover { background: var(--surface-hover) !important; }

.deletelink, a.deletelink {
  background: transparent !important; color: var(--danger-text) !important;
  border-color: var(--danger-border) !important;
}
.deletelink:hover, a.deletelink:hover {
  background: var(--danger-bg) !important; border-color: var(--signal) !important;
}

.submit-row {
  background: var(--bg-sunken) !important;
  border-top: var(--hairline) solid var(--border-subtle) !important;
  padding: var(--space-3) var(--space-6) !important;
  display: flex !important; align-items: center !important;
  gap: var(--space-2) !important; flex-wrap: wrap; box-shadow: none !important;
}
.submit-row p { margin: 0; display: flex; align-items: center; gap: var(--space-2); }

/* ================================================================
 * ACTIONS
 * ================================================================ */
.actions {
  background: var(--bg-sunken) !important;
  border-top: var(--hairline) solid var(--border-subtle) !important;
  border-bottom: var(--hairline) solid var(--border-subtle) !important;
  padding: var(--space-2) var(--space-3) !important;
  display: flex; align-items: center; gap: var(--space-2);
}
.actions select { height: var(--control-h-sm); font-size: var(--text-xs) !important; padding: 0 var(--space-2) !important; }
.actions .button { height: var(--control-h-sm); font-size: var(--text-xs) !important; padding: 0 var(--space-3) !important; }

/* ================================================================
 * OBJECT TOOLS
 * ================================================================ */
.object-tools { float: right; margin: 0 !important; padding: 0 !important; list-style: none; display: flex; gap: var(--space-2); }
.object-tools a, .object-tools a:visited {
  font-size: var(--text-xs) !important; height: var(--control-h-sm);
  padding: 0 var(--space-3) !important; background: transparent !important;
  color: var(--text-muted) !important; border: var(--hairline) solid var(--border-default) !important;
  border-radius: var(--radius-sm) !important; display: inline-flex; align-items: center;
  transition: background var(--dur-instant) var(--ease-out);
}
.object-tools a:hover {
  background: var(--surface-hover) !important; color: var(--text-body) !important;
  border-color: var(--border-strong) !important; text-decoration: none;
}

/* ================================================================
 * INLINES + FIELDSETS
 * ================================================================ */
.inline-group {
  border: var(--hairline) solid var(--border-subtle) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden; margin-top: var(--space-4) !important; box-shadow: var(--shadow-sm);
}
.inline-group h2 {
  background: var(--bg-sunken) !important; font-family: var(--font-mono) !important;
  font-size: var(--text-2xs) !important; font-weight: var(--fw-medium) !important;
  letter-spacing: var(--tracking-label) !important; text-transform: uppercase !important;
  color: var(--text-subtle) !important; padding: 9px var(--space-4) !important;
  border-bottom: var(--hairline) solid var(--border-subtle) !important;
  text-shadow: none !important; margin: 0 !important;
}
.inline-group td, .inline-group th { padding: var(--space-2) var(--space-3) !important; font-size: var(--text-xs) !important; }
.inline-related { border-top: var(--hairline) solid var(--border-faint) !important; padding-top: var(--space-3) !important; }
.inline-related:first-of-type { border-top: none !important; }

fieldset {
  border: var(--hairline) solid var(--border-subtle) !important;
  border-radius: var(--radius-lg) !important; padding: 0 !important;
  margin: 0 0 var(--space-4) !important; overflow: hidden;
}
fieldset h2 {
  background: var(--bg-sunken) !important; font-family: var(--font-mono) !important;
  font-size: var(--text-2xs) !important; font-weight: var(--fw-medium) !important;
  letter-spacing: var(--tracking-label) !important; text-transform: uppercase !important;
  color: var(--text-subtle) !important; padding: 9px var(--space-4) !important;
  border-bottom: var(--hairline) solid var(--border-subtle) !important;
  margin: 0 !important; text-shadow: none !important;
}

/* ================================================================
 * MESSAGES
 * ================================================================ */
ul.messagelist { padding: 0 !important; margin: 0 0 var(--space-4) !important; list-style: none; }
ul.messagelist li {
  padding: var(--space-3) var(--space-4) !important; border-radius: var(--radius-md) !important;
  margin-bottom: var(--space-2) !important; font-size: var(--text-sm) !important;
  border: var(--hairline) solid transparent !important; background-image: none !important;
}
ul.messagelist li.success { background: var(--success-bg) !important; border-color: var(--success-border) !important; color: var(--success-text) !important; }
ul.messagelist li.warning { background: var(--warning-bg) !important; border-color: var(--warning-border) !important; color: var(--warning-text) !important; }
ul.messagelist li.error   { background: var(--danger-bg)  !important; border-color: var(--danger-border)  !important; color: var(--danger-text)  !important; }
ul.messagelist li.info    { background: var(--info-bg)    !important; border-color: var(--info-border)    !important; color: var(--info-text)    !important; }

/* ================================================================
 * CALENDAR
 * ================================================================ */
.calendarbox, .clockbox {
  background: var(--surface) !important; border: var(--hairline) solid var(--border-default) !important;
  border-radius: var(--radius-md) !important; box-shadow: var(--shadow-md) !important;
}
.calendar caption { background: var(--bg-sunken) !important; color: var(--text-muted) !important; font-family: var(--font-mono) !important; font-size: var(--text-xs) !important; }
.calendar td.selected a { background: var(--action-ink) !important; border-radius: var(--radius-xs); color: var(--text-on-ink) !important; }

/* ================================================================
 * CUSTOM BADGES
 * ================================================================ */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: var(--text-2xs);
  font-weight: var(--fw-medium); letter-spacing: .02em;
  padding: 2px 8px; border-radius: var(--radius-xs); border: var(--hairline) solid;
}
.badge-success { background: var(--success-bg); color: var(--success-text); border-color: var(--success-border); }
.badge-info    { background: var(--info-bg);    color: var(--info-text);    border-color: var(--info-border);    }
.badge-warning { background: var(--warning-bg); color: var(--warning-text); border-color: var(--warning-border); }
.badge-danger  { background: var(--danger-bg);  color: var(--danger-text);  border-color: var(--danger-border);  }
.badge-live {
  background: var(--signal-bg); color: var(--signal-text); border-color: var(--signal-border);
}
.badge-live::before {
  content: ''; display: inline-block; width: 6px; height: 6px;
  border-radius: var(--radius-pill); background: var(--signal);
  animation: ark-pulse 2s ease-out infinite;
}
@media (prefers-reduced-motion: reduce) { .badge-live::before { animation: none; } }

/* ================================================================
 * MISC
 * ================================================================ */
.nowrap { white-space: nowrap; }
hr { border: 0; border-top: var(--hairline) solid var(--border-subtle); margin: var(--space-4) 0; }
.related-widget-wrapper { display: flex; align-items: center; gap: var(--space-1); }
.related-widget-wrapper select { flex: 1; }

textarea[name="detail"], textarea[name="data"],
textarea[name="gimmick_schedule"], textarea[name="pending_trigger"],
textarea[name="extra_flags"], textarea[name="passive_value"] {
  font-family: var(--font-mono) !important; font-size: var(--text-xs) !important;
  background: var(--bg-sunken) !important; line-height: 1.55;
}

/* ================================================================
 * LOGIN PAGE
 * ================================================================ */
body.login #header { display: none; }
body.login .main, body.login #main { justify-content: center; align-items: center; min-height: 100vh; }
body.login #nav-sidebar { display: none !important; }
body.login #content-start { flex: 0 0 auto; width: 360px; background: transparent; }
body.login .module { border-radius: var(--radius-xl) !important; box-shadow: var(--shadow-lg) !important; }
