/*
 * YAPS Control v0 — functional dark theme.
 * CSS variables pattern-copied from yaps/app/views/layouts/admin.html.erb
 * (the [data-theme="dark"] set), stripped to just what this app uses.
 */

:root {
  --bg: #111827;
  --card: #1f2937;
  --text: #e5e7eb;
  --text-muted: #9ca3af;
  --text-tertiary: #64748b;
  --border: #374151;
  --sidebar: #0b1929;
  --header-bg: #1f2937;
  --input-bg: #374151;
  --input-border: #4b5563;
  --table-stripe: #1a2332;
  --table-hover: #253345;
  --danger: #f87171;
  --danger-bg: #450a0a;
  --success: #4ade80;
  --success-bg: #052e16;
  --primary: #60a5fa;
  --primary-bg: #172554;
  --warning: #fbbf24;
  --warning-bg: #451a03;
  --info: #5bc8f0;
  --info-bg: #1a2a3a;
  --navy: #1e3a5f;
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --space-xs: 4px;
  --space-sm: 6px;
  --space-md: 8px;
  --space-lg: 12px;
  --space-xl: 16px;
  --space-2xl: 24px;
  --font-xs: 0.75rem;
  --font-sm: 0.8rem;
  --font-md: 0.85rem;
  --font-base: 0.9rem;
  --font-lg: 1rem;
  --font-xl: 1.2rem;
  --font-2xl: 1.6rem;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: var(--font-base);
  line-height: 1.5;
}

a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3, h4 { margin: 0 0 var(--space-lg); color: var(--text); }
h1 { font-size: var(--font-2xl); }
h2 { font-size: var(--font-xl); }
h3 { font-size: var(--font-lg); }
small, .xs { font-size: var(--font-xs); color: var(--text-muted); }
.muted { color: var(--text-muted); }
.w-full { width: 100%; }

.app-shell { display: flex; min-height: 100vh; }
.sidebar {
  width: 220px;
  background: var(--sidebar);
  border-right: 1px solid var(--border);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  position: sticky;
  top: 0;
  height: 100vh;
}
.brand { display: flex; align-items: center; gap: var(--space-md); font-weight: 700; color: var(--text); margin-bottom: var(--space-lg); }
.brand-mark { color: var(--info); }
.nav { display: flex; flex-direction: column; gap: var(--space-xs); flex: 1; }
.nav-link {
  display: block;
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  color: var(--text-muted);
  font-size: var(--font-md);
}
.nav-link:hover { background: var(--navy); color: var(--text); text-decoration: none; }
.nav-link-active { background: var(--primary-bg); color: var(--text); }
.sidebar-foot { border-top: 1px solid var(--border); padding-top: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-md); }

.content { flex: 1; padding: var(--space-2xl); max-width: 100%; }

.auth-shell { max-width: 460px; margin: 80px auto; padding: var(--space-2xl); }

.flash { padding: var(--space-md) var(--space-lg); border-radius: var(--radius-md); margin-bottom: var(--space-lg); border: 1px solid; }
.flash-notice { background: var(--success-bg); color: var(--success); border-color: var(--success); }
.flash-alert  { background: var(--danger-bg);  color: var(--danger);  border-color: var(--danger); }

.btn {
  display: inline-block;
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-size: var(--font-md);
  cursor: pointer;
  text-decoration: none;
}
.btn:hover { background: var(--input-bg); text-decoration: none; }
.btn-sm { padding: 2px var(--space-md); font-size: var(--font-xs); }
.btn-primary { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-primary:hover { filter: brightness(1.1); background: var(--primary); }
.btn-danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.btn-danger:hover { filter: brightness(1.1); background: var(--danger); }
.btn-ghost { background: transparent; }
.btn-ghost:hover { background: var(--navy); }
.btn-row { display: flex; gap: var(--space-md); flex-wrap: wrap; }

.field { margin-bottom: var(--space-lg); }
.field label { display: block; margin-bottom: var(--space-xs); font-size: var(--font-sm); color: var(--text-muted); }
.field input[type=text],
.field input[type=email],
.field input[type=password],
.field input[type=number],
.field textarea,
.field select {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--text);
  font-size: var(--font-md);
}
.field textarea { min-height: 96px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.field-errors { color: var(--danger); font-size: var(--font-sm); margin-top: var(--space-xs); }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); }

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  margin-bottom: var(--space-xl);
}
.card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-lg); border-bottom: 1px solid var(--border); padding-bottom: var(--space-md); }
.card-header h2, .card-header h3 { margin: 0; }

.data-table { width: 100%; border-collapse: collapse; font-size: var(--font-md); }
.data-table th {
  text-align: left;
  font-weight: 600;
  color: var(--text-muted);
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border);
  background: var(--card);
}
.data-table td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.data-table tbody tr:nth-child(even) { background: var(--table-stripe); }
.data-table tbody tr:hover { background: var(--table-hover); }
.data-table-wrapper { overflow-x: auto; }

.chip { display: inline-block; padding: 1px var(--space-md); border-radius: 999px; font-size: var(--font-xs); font-weight: 600; background: var(--input-bg); color: var(--text); }
.chip-success { background: var(--success-bg); color: var(--success); }
.chip-info    { background: var(--info-bg);    color: var(--info); }
.chip-warning { background: var(--warning-bg); color: var(--warning); }
.chip-danger  { background: var(--danger-bg);  color: var(--danger); }
.chip-muted   { background: var(--input-bg);   color: var(--text-muted); }
.dot { display: inline-block; width: 10px; height: 10px; border-radius: 999px; vertical-align: middle; background: var(--text-tertiary); }
.dot-success { background: var(--success); }
.dot-warning { background: var(--warning); }
.dot-danger  { background: var(--danger); }

.detail-row { display: grid; grid-template-columns: 220px 1fr; gap: var(--space-lg); padding: var(--space-md) 0; border-bottom: 1px solid var(--border); }
.detail-row:last-child { border-bottom: 0; }
.detail-label { color: var(--text-muted); font-size: var(--font-sm); }
.detail-value { color: var(--text); word-break: break-all; }
.detail-value pre, .mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: var(--font-sm); white-space: pre-wrap; background: var(--bg); padding: var(--space-md); border-radius: var(--radius-md); border: 1px solid var(--border); }

.page-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-xl); }
.page-actions { display: flex; gap: var(--space-md); }

.qr-box { display: flex; align-items: center; justify-content: center; padding: var(--space-xl); background: #fff; border-radius: var(--radius-md); width: fit-content; }
.qr-box svg { width: 220px; height: 220px; }
