:root {
  --bg-page:#f6f3ef;
  --bg-surface:#ffffff;
  --bg-soft:#fbf8f5;
  --bg-sidebar:#ffffff;
  --bg-sidebar-hover:#f5efea;
  --bg-sidebar-active:#faecea;
  --text-primary:#1f1a17;
  --text-secondary:#6f675f;
  --text-muted:#9b948c;
  --border:#e7dfd6;
  --border-strong:#ddd2c6;
  --shadow:0 8px 30px rgba(27,20,15,.05);
  --shadow-lg:0 14px 40px rgba(27,20,15,.09);
  --accent-admin:#c03a2b;
  --accent-admin-dark:#a33023;
  --accent-admin-light:#faecea;
  --accent-green:#2f7d4b;
  --accent-green-light:#eaf5ee;
  --accent-gold:#9a771b;
  --accent-gold-light:#f6efdb;
  --accent-blue:#48657c;
  --accent-blue-light:#edf3f7;
  --radius-xl:18px;
  --radius-lg:14px;
  --radius-md:11px;
  --radius-sm:10px;
  --sidebar-width:252px;
  --topbar-height:72px;
  --font-display:'DM Serif Display', Georgia, 'Times New Roman', serif;
  --font-body:'DM Sans', Inter, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing:border-box; }
html, body { margin:0; padding:0; }
body {
  font-family:var(--font-body);
  background:var(--bg-page);
  color:var(--text-primary);
}
a { color:inherit; text-decoration:none; }
button, input, select, textarea { font:inherit; }
code {
  background:#f3eee8;
  border:1px solid var(--border);
  border-radius:8px;
  padding:1px 6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:.92em;
}

.shell {
  min-height:100vh;
  display:grid;
  grid-template-columns:var(--sidebar-width) 1fr;
}

.sidebar {
  position:sticky;
  top:0;
  height:100vh;
  background:var(--bg-sidebar);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  overflow:auto;
  z-index:30;
}

.brand {
  display:flex;
  align-items:center;
  gap:12px;
  padding:22px 20px 18px;
  border-bottom:1px solid var(--border);
}
.brand-mark {
  width:40px;
  height:40px;
  border-radius:12px;
  background:var(--accent-admin);
  color:#fff;
  display:grid;
  place-items:center;
  box-shadow:0 8px 20px rgba(192,58,43,.22);
}
.brand-name {
  font-family:var(--font-display);
  font-size:28px;
  line-height:1;
}
.brand-sub {
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--accent-admin);
  margin-top:4px;
}

.nav-group { padding:18px 14px 0; }
.nav-label {
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.09em;
  color:var(--text-muted);
  font-weight:700;
  padding:0 10px 8px;
}
.nav { display:grid; gap:4px; }
.nav a {
  display:flex;
  align-items:center;
  gap:11px;
  padding:11px 12px;
  border-radius:12px;
  color:var(--text-secondary);
  transition:.18s ease;
  font-size:14px;
}
.nav a:hover {
  background:var(--bg-sidebar-hover);
  color:var(--text-primary);
}
.nav a.active {
  background:var(--bg-sidebar-active);
  color:var(--accent-admin);
  font-weight:600;
}
.nav a .count {
  margin-left:auto;
  font-size:11px;
  font-weight:700;
  padding:4px 8px;
  border-radius:999px;
  background:var(--accent-admin-light);
  color:var(--accent-admin);
}

.sidebar-footer {
  margin-top:auto;
  padding:18px 16px 22px;
  border-top:1px solid var(--border);
}
.user-mini {
  display:flex;
  align-items:center;
  gap:10px;
}
.user-avatar {
  width:36px;
  height:36px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:var(--accent-admin-light);
  color:var(--accent-admin);
  font-weight:700;
}
.user-meta { min-width:0; }
.user-name {
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.user-role {
  font-size:12px;
  color:var(--text-muted);
}

.main {
  min-width:0;
  display:flex;
  flex-direction:column;
}

.topbar {
  position:sticky;
  top:0;
  z-index:20;
  height:var(--topbar-height);
  background:rgba(246,243,239,.92);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:0 28px;
}
.topbar-left {
  display:flex;
  align-items:center;
  gap:14px;
}
.page-title {
  font-family:var(--font-display);
  font-size:34px;
  line-height:1;
  margin:0;
}
.page-kicker {
  font-size:12px;
  color:var(--text-muted);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.topbar-actions {
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.badge-env {
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(192,58,43,.15);
  background:var(--accent-admin-light);
  color:var(--accent-admin);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.sidebar-mobile-toggle {
  display:none;
  width:42px;
  height:42px;
  border:none;
  border-radius:12px;
  background:#fff;
  color:var(--text-primary);
  border:1px solid var(--border);
}

.page { padding:28px; }
.page-stack { display:grid; gap:22px; }

.metrics {
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}
.metrics-mini {
  grid-template-columns:repeat(3, minmax(0, 1fr));
}
.metric-card,
.card {
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
}
.metric-card {
  padding:18px 18px 16px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.metric-card-mini {
  padding:16px 18px;
}
.metric-icon {
  width:42px;
  height:42px;
  border-radius:12px;
  display:grid;
  place-items:center;
  flex-shrink:0;
}
.metric-icon.red { background:var(--accent-admin-light); color:var(--accent-admin); }
.metric-icon.green { background:var(--accent-green-light); color:var(--accent-green); }
.metric-icon.gold { background:var(--accent-gold-light); color:var(--accent-gold); }
.metric-icon.blue { background:var(--accent-blue-light); color:var(--accent-blue); }
.metric-label {
  font-size:11px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
  display:flex;
  align-items:center;
  gap:6px;
}
.metric-value {
  font-size:34px;
  font-family:var(--font-display);
  line-height:1.1;
  margin:4px 0 8px;
}
.metric-value-mini {
  font-size:28px;
  margin-bottom:4px;
}
.metric-meta {
  font-size:13px;
  color:var(--text-secondary);
}
.metric-meta strong { color:var(--text-primary); }

.card { padding:22px; }
.card-header {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.card-title {
  margin:0;
  font-family:var(--font-display);
  font-size:28px;
  line-height:1.1;
}
.card-subtitle {
  margin-top:6px;
  color:var(--text-secondary);
  font-size:14px;
  line-height:1.55;
}
.wrap-actions {
  flex-wrap:wrap;
}
.align-start-mobile {
  align-items:flex-start;
}

.grid-2 {
  display:grid;
  grid-template-columns:minmax(0, 1.7fr) minmax(300px, 1fr);
  gap:22px;
}
.grid-3 {
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.module-grid {
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}
.provider-grid {
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.split-grid {
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:22px;
}
.split-grid-tight {
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}

.module-card,
.provider-card {
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(180deg, #fff 0%, #fbf7f4 100%);
  box-shadow:none;
}
.module-card {
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:180px;
}
.module-card.compact-card {
  min-height:0;
}
.module-card:hover {
  transform:translateY(-1px);
  box-shadow:var(--shadow-lg);
}
.module-card .eyebrow,
.eyebrow {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--text-muted);
}
.module-card h3 {
  font-family:var(--font-display);
  font-size:26px;
  margin:0;
}
.module-card p {
  margin:0;
  color:var(--text-secondary);
  line-height:1.55;
  flex:1;
}
.module-meta {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  color:var(--text-secondary);
  font-size:13px;
}

.provider-card {
  padding:18px;
  display:grid;
  gap:10px;
  background:#fff;
}
.provider-name {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
}
.provider-name h4 {
  margin:0;
  font-size:18px;
  font-weight:700;
  font-family:var(--font-body);
}
.provider-subtitle {
  font-size:12px;
  color:var(--text-muted);
  margin-top:4px;
}
.provider-lines {
  display:grid;
  gap:6px;
  font-size:13px;
  color:var(--text-secondary);
}
.provider-lines strong { color:var(--text-primary); }

.kpi-chip {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
}
.kpi-chip.red { background:var(--accent-admin-light); color:var(--accent-admin); }
.kpi-chip.green, .kpi-chip.ok { background:var(--accent-green-light); color:var(--accent-green); }
.kpi-chip.gold, .kpi-chip.warn { background:var(--accent-gold-light); color:var(--accent-gold); }
.kpi-chip.blue, .kpi-chip.neutral { background:var(--accent-blue-light); color:var(--accent-blue); }
.kpi-chip.danger, .kpi-chip.err { background:var(--accent-admin-light); color:var(--accent-admin); }

.list {
  display:grid;
  gap:12px;
}
.compact-list { gap:10px; }
.list-item {
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px 15px;
  background:var(--bg-soft);
}
.list-item h4 {
  margin:0 0 4px;
  font-size:15px;
  font-weight:700;
  font-family:var(--font-body);
}
.list-item p {
  margin:0;
  color:var(--text-secondary);
  font-size:13px;
  line-height:1.55;
}
.link-arrow {
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--accent-admin);
  font-weight:700;
}

.btn {
  appearance:none;
  border:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:12px;
  padding:11px 14px;
  font-weight:600;
  transition:.18s ease;
}
.btn:hover { transform:translateY(-1px); }
.btn-primary {
  background:var(--accent-admin);
  color:#fff;
  box-shadow:0 8px 20px rgba(192,58,43,.22);
}
.btn-primary:hover { background:var(--accent-admin-dark); }
.btn-secondary {
  background:var(--bg-surface);
  color:var(--text-primary);
  border:1px solid var(--border);
}
.btn-ghost {
  background:transparent;
  color:var(--text-secondary);
  border:1px dashed var(--border);
}
.btn-block { width:100%; }

.status-pill {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:700;
  padding:7px 10px;
  border-radius:999px;
  white-space:nowrap;
}
.status-pill.ok { background:var(--accent-green-light); color:var(--accent-green); }
.status-pill.warn { background:var(--accent-gold-light); color:var(--accent-gold); }
.status-pill.danger,
.status-pill.err { background:var(--accent-admin-light); color:var(--accent-admin); }
.status-pill.neutral { background:#f1eeea; color:var(--text-secondary); }

.status-dot {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
}
.status-dot.ok { background:var(--accent-green-light); color:var(--accent-green); }
.status-dot.warn { background:var(--accent-gold-light); color:var(--accent-gold); }
.status-dot.neutral { background:#f1eeea; color:var(--text-secondary); }

.note {
  padding:14px 16px;
  border-radius:14px;
  background:#fff6ea;
  border:1px solid #f0dfb9;
  color:#7e5f14;
  font-size:13px;
  line-height:1.55;
}
.note.red {
  background:var(--accent-admin-light);
  border-color:#f4d2ce;
  color:var(--accent-admin-dark);
}
.notice {
  display:flex;
  align-items:flex-start;
  gap:10px;
  border:1px solid var(--border);
  border-radius:14px;
  padding:13px 15px;
  margin-bottom:18px;
  background:#fff;
}
.notice.success { background:var(--accent-green-light); border-color:#d8eadf; color:var(--accent-green); }
.notice.danger { background:var(--accent-admin-light); border-color:#f4d2ce; color:var(--accent-admin-dark); }

.timeline {
  position:relative;
  display:grid;
  gap:16px;
  padding-left:20px;
}
.timeline::before {
  content:"";
  position:absolute;
  left:5px;
  top:6px;
  bottom:6px;
  width:2px;
  background:var(--border);
}
.timeline-compact { gap:14px; }
.timeline-item {
  position:relative;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:16px;
  padding:16px 18px;
}
.timeline-item::before {
  display:none;
}
.timeline-marker {
  position:absolute;
  left:-19px;
  top:18px;
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--accent-blue);
  box-shadow:0 0 0 4px var(--accent-blue-light);
}
.timeline-marker.ok {
  background:var(--accent-green);
  box-shadow:0 0 0 4px var(--accent-green-light);
}
.timeline-marker.warn {
  background:var(--accent-gold);
  box-shadow:0 0 0 4px var(--accent-gold-light);
}
.timeline-marker.danger,
.timeline-marker.err {
  background:var(--accent-admin);
  box-shadow:0 0 0 4px var(--accent-admin-light);
}
.timeline-content h3,
.timeline-content h4 {
  margin:0 0 8px;
  font-size:18px;
  font-weight:700;
  font-family:var(--font-body);
}
.timeline-content p {
  margin:0;
  color:var(--text-secondary);
  font-size:14px;
  line-height:1.6;
}
.timeline-meta {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
  color:var(--text-muted);
  font-size:12px;
}
.detail-block {
  margin-top:14px;
  padding-top:14px;
  border-top:1px dashed var(--border);
}
.detail-label {
  font-size:11px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
  margin-bottom:6px;
}
.detail-text {
  color:var(--text-secondary);
  line-height:1.6;
  font-size:14px;
}
.tag-list {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.tag {
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  background:#f3eee8;
  color:var(--text-secondary);
  border:1px solid var(--border);
  font-size:12px;
}

.definition-list {
  display:grid;
  gap:8px;
}
.compact-definition-list .definition-row {
  grid-template-columns:150px 1fr;
}
.definition-row {
  display:grid;
  grid-template-columns:160px 1fr;
  gap:12px;
  padding:10px 0;
  border-bottom:1px dashed var(--border);
}
.definition-row:last-child { border-bottom:none; }
.definition-row dt {
  color:var(--text-muted);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
}
.definition-row dd {
  margin:0;
  color:var(--text-primary);
}

.table-scroll,
.table-wrap {
  overflow:auto;
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
}
.admin-table,
.table {
  width:100%;
  border-collapse:collapse;
  min-width:760px;
}
.admin-table th,
.admin-table td,
.table th,
.table td {
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  text-align:left;
  vertical-align:top;
}
.admin-table th,
.table th {
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--text-muted);
  font-weight:700;
  background:#fbf8f5;
}
.admin-table tr:last-child td,
.table tr:last-child td { border-bottom:none; }
.comparison-table td,
.comparison-table th { white-space:nowrap; }
.inventory-block + .inventory-block { margin-top:22px; }
.inventory-title {
  margin:0 0 12px;
  font-family:var(--font-display);
  font-size:24px;
}

.field,
.field-inline {
  display:grid;
  gap:7px;
}
.field > span,
.field-inline > span {
  font-size:12px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
  display:flex;
  align-items:center;
  gap:6px;
}
.input,
.select,
.textarea {
  width:100%;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text-primary);
  border-radius:12px;
  padding:12px 14px;
  transition:border-color .18s ease, box-shadow .18s ease;
}
.input:focus,
.select:focus,
.textarea:focus {
  outline:none;
  border-color:#e1b8b2;
  box-shadow:0 0 0 4px rgba(192,58,43,.08);
}
.textarea {
  resize:vertical;
  min-height:120px;
}
.monospace,
.log-viewer {
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}
.log-viewer {
  margin:0;
  background:#171310;
  color:#f3eee8;
  border-radius:14px;
  padding:16px;
  min-height:220px;
  max-height:520px;
  overflow:auto;
  font-size:12px;
  line-height:1.6;
}
.inline-form {
  display:flex;
  align-items:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
.field-inline { min-width:180px; }
.filter-grid {
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:12px;
  margin-bottom:20px;
}
.form-grid {
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
.field-full {
  grid-column:1 / -1;
}
.field-actions {
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.checkbox-list {
  display:grid;
  gap:14px;
}
.checkbox-card {
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:15px 16px;
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--bg-soft);
}
.checkbox-card input {
  width:18px;
  height:18px;
  margin-top:3px;
  accent-color:var(--accent-admin);
}
.checkbox-card h3 {
  margin:0 0 4px;
  font-size:15px;
  font-weight:700;
  font-family:var(--font-body);
}
.checkbox-card p {
  margin:0;
  color:var(--text-secondary);
  font-size:13px;
  line-height:1.55;
}

.empty-state {
  min-height:180px;
  display:grid;
  place-items:center;
  gap:10px;
  text-align:center;
  color:var(--text-secondary);
  border:1px dashed var(--border-strong);
  border-radius:16px;
  padding:28px 24px;
  background:var(--bg-soft);
}
.empty-state i {
  font-size:32px;
  color:var(--text-muted);
}
.small { font-size:12px; color:var(--text-muted); }
.widget-hidden { display:none !important; }
.footer-note { font-size:12px; color:var(--text-muted); padding-top:4px; }
.info-tip {
  border:none;
  background:transparent;
  color:var(--text-muted);
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.info-tip:hover { color:var(--accent-admin); }

.admin-toast {
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:9999;
  min-width:220px;
  max-width:360px;
  padding:13px 15px;
  border-radius:14px;
  background:#1f1a17;
  color:#fff;
  box-shadow:var(--shadow-lg);
  opacity:0;
  transform:translateY(8px);
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
}
.admin-toast.show {
  opacity:1;
  transform:translateY(0);
}
.admin-toast.error {
  background:var(--accent-admin-dark);
}

.login-shell {
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:32px 18px;
}
.login-card {
  width:min(480px, 100%);
  background:#fff;
  border:1px solid var(--border);
  border-radius:24px;
  box-shadow:var(--shadow-lg);
  padding:28px;
}
.login-brand {
  padding:0 0 20px;
  border-bottom:1px solid var(--border);
  margin-bottom:22px;
}
.login-copy h1 {
  margin:0 0 10px;
  font-family:var(--font-display);
  font-size:34px;
}
.login-copy p {
  margin:0;
  color:var(--text-secondary);
  line-height:1.6;
}
.login-form {
  display:grid;
  gap:14px;
  margin-top:18px;
}
.login-links {
  margin-top:18px;
  text-align:center;
  font-size:13px;
  color:var(--text-secondary);
}
.login-links a { color:var(--accent-admin); font-weight:700; }

.mt-3 { margin-top:1rem; }

@media (max-width: 1260px) {
  .metrics,
  .module-grid,
  .provider-grid,
  .grid-3 { grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .grid-2,
  .split-grid,
  .split-grid-tight,
  .form-grid,
  .filter-grid { grid-template-columns:1fr; }
}

@media (max-width: 980px) {
  .shell { grid-template-columns:1fr; }
  .sidebar {
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    width:min(86vw, 320px);
    transform:translateX(-105%);
    transition:transform .22s ease;
    box-shadow:var(--shadow-lg);
  }
  .sidebar.open { transform:translateX(0); }
  .sidebar-mobile-toggle { display:inline-grid; place-items:center; }
  .page { padding:20px; }
}

@media (max-width: 720px) {
  .topbar {
    position:relative;
    height:auto;
    padding:16px 18px;
    flex-direction:column;
    align-items:flex-start;
  }
  .page { padding:18px; }
  .metrics,
  .metrics-mini,
  .module-grid,
  .provider-grid,
  .grid-3 { grid-template-columns:1fr; }
  .card,
  .metric-card { padding:18px; }
  .page-title { font-size:28px; }
}
