/* Мобильное веб-приложение контролёра */
:root {
  --ctrl-bg: #0f1419;
  --ctrl-card: #1a222c;
  --ctrl-border: rgba(255, 255, 255, 0.08);
  --ctrl-text: #f1f5f9;
  --ctrl-muted: #94a3b8;
  --ctrl-accent: #38bdf8;
  --ctrl-ok: #34d399;
  --ctrl-danger: #f87171;
  --ctrl-safe-bottom: env(safe-area-inset-bottom, 0px);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body.ctrl-app {
  margin: 0;
  min-height: 100vh;
  min-height: 100dvh;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 16px;
  line-height: 1.45;
  background: var(--ctrl-bg);
  color: var(--ctrl-text);
  padding-bottom: calc(12px + var(--ctrl-safe-bottom));
}

.ctrl-header {
  position: sticky;
  top: 0;
  z-index: 10;
  padding: 12px 16px;
  padding-top: calc(12px + env(safe-area-inset-top, 0px));
  background: rgba(15, 20, 25, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ctrl-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.ctrl-header h1 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
}
.ctrl-header small {
  display: block;
  font-size: 0.72rem;
  color: var(--ctrl-muted);
  font-weight: 500;
}

.ctrl-main { padding: 14px 16px; max-width: 560px; margin: 0 auto; }

.ctrl-card {
  background: var(--ctrl-card);
  border: 1px solid var(--ctrl-border);
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 12px;
}

.ctrl-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
}
.ctrl-tab {
  flex: 1;
  padding: 10px 8px;
  border-radius: 10px;
  border: 1px solid var(--ctrl-border);
  background: transparent;
  color: var(--ctrl-muted);
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
}
.ctrl-tab.active {
  background: rgba(56, 189, 248, 0.15);
  border-color: rgba(56, 189, 248, 0.35);
  color: var(--ctrl-accent);
}

.ctrl-list-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 14px 16px;
  margin-bottom: 8px;
  border-radius: 12px;
  border: 1px solid var(--ctrl-border);
  background: var(--ctrl-card);
  color: inherit;
  font-size: 0.95rem;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.ctrl-list-item:active { opacity: 0.92; transform: scale(0.99); }
.ctrl-list-item .sub { font-size: 0.8rem; color: var(--ctrl-muted); margin-top: 4px; }

.ctrl-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 6px;
  margin-left: 8px;
  vertical-align: middle;
}
.ctrl-badge--active { background: rgba(52, 211, 153, 0.2); color: var(--ctrl-ok); }
.ctrl-badge--inactive { background: rgba(148, 163, 184, 0.2); color: var(--ctrl-muted); }
.ctrl-badge--draft { background: rgba(251, 191, 36, 0.2); color: #fbbf24; }

.ctrl-form label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--ctrl-muted);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ctrl-input {
  width: 100%;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--ctrl-border);
  background: #0f1419;
  color: var(--ctrl-text);
  font-size: 1rem;
  margin-bottom: 14px;
}
.ctrl-input:focus {
  outline: none;
  border-color: var(--ctrl-accent);
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.2);
}

.ctrl-input-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
  margin-bottom: 14px;
}
.ctrl-input-row .ctrl-input {
  flex: 1;
  min-width: 0;
  margin-bottom: 0;
}
.ctrl-copy-btn {
  flex-shrink: 0;
  width: 48px;
  min-height: 48px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid var(--ctrl-border);
  background: rgba(15, 20, 25, 0.6);
  color: var(--ctrl-accent);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-tap-highlight-color: transparent;
}
.ctrl-copy-btn:hover {
  border-color: rgba(56, 189, 248, 0.35);
  background: rgba(56, 189, 248, 0.08);
}
.ctrl-copy-btn:active {
  opacity: 0.9;
  transform: scale(0.98);
}
.ctrl-copy-btn:focus-visible {
  outline: 2px solid var(--ctrl-accent);
  outline-offset: 2px;
}

.ctrl-check {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px;
  border-radius: 12px;
  border: 1px solid var(--ctrl-border);
  margin-bottom: 16px;
  cursor: pointer;
  user-select: none;
}
.ctrl-check input { width: 22px; height: 22px; accent-color: var(--ctrl-accent); }

.ctrl-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 14px 16px;
  border-radius: 12px;
  border: none;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
}
.ctrl-btn--primary {
  background: linear-gradient(135deg, #0ea5e9, #0284c7);
  color: #fff;
}
.ctrl-btn--primary:disabled { opacity: 0.5; cursor: not-allowed; }
.ctrl-btn--ghost {
  background: transparent;
  color: var(--ctrl-muted);
  border: 1px solid var(--ctrl-border);
  margin-top: 8px;
}

.ctrl-auth-toggle {
  display: flex;
  gap: 0;
  margin-bottom: 18px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--ctrl-border);
}
.ctrl-auth-toggle button {
  flex: 1;
  padding: 10px;
  border: none;
  background: transparent;
  color: var(--ctrl-muted);
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
}
.ctrl-auth-toggle button.active {
  background: rgba(56, 189, 248, 0.2);
  color: var(--ctrl-accent);
}

.ctrl-error {
  background: rgba(248, 113, 113, 0.12);
  border: 1px solid rgba(248, 113, 113, 0.35);
  color: #fecaca;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 0.88rem;
  margin-bottom: 12px;
}
.ctrl-success {
  background: rgba(52, 211, 153, 0.12);
  border: 1px solid rgba(52, 211, 153, 0.35);
  color: #a7f3d0;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 0.88rem;
  margin-bottom: 12px;
}

.ctrl-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ctrl-accent);
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 14px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}

.empty-hint { color: var(--ctrl-muted); text-align: center; padding: 28px 16px; font-size: 0.9rem; }
