/* Lybia Custom — partner-site styles */
* { box-sizing: border-box; }
body {
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  background: #f7f8fb; color: #0f172a; margin: 0; line-height: 1.55;
}
.container { max-width: 1100px; margin: 0 auto; padding: 0 24px 64px; }
.lead { color: #475569; font-size: 16px; max-width: 720px; }
.muted { color: #64748b; font-size: 13px; }

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px; background: #fff;
  border-bottom: 1px solid #e2e8f0;
}
.topbar .brand { font-weight: 800; font-size: 18px; text-decoration: none; color: inherit; }
.topbar nav { display: flex; flex-wrap: wrap; gap: 6px 4px; justify-content: flex-end; align-items: center; }
.topbar nav a {
  color: #475569; text-decoration: none; font-size: 14px;
}
.topbar nav a:hover { color: #4f46e5; }
.topbar .navlink { padding: 4px 9px; border-radius: 7px; }
.topbar .navlink:hover { background: #eef2ff; color: #4f46e5; }
.topbar .navlink.active { background: #4f46e5; color: #fff; font-weight: 600; }
.topbar .me { color: #475569; font-size: 13px; }
.topbar .me strong { color: #0f172a; }
.sitefoot { margin: 48px auto 28px; font-size: 13px; text-align: center; }

.hero { padding: 56px 0 32px; }
.hero h1 { font-size: 38px; margin: 0 0 12px; letter-spacing: -0.01em; }

.card {
  background: #fff; border: 1px solid #e2e8f0; border-radius: 14px;
  padding: 22px; box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04); margin: 16px 0;
}
.grid { display: grid; gap: 16px; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.card-meta { font-family: ui-monospace, monospace; font-size: 11px; color: #94a3b8; text-transform: uppercase; letter-spacing: 0.06em; }
.card h2 { font-size: 18px; margin: 8px 0; }
.card h3 { font-size: 16px; margin: 0 0 8px; }
.card-desc { color: #475569; font-size: 14px; margin: 0 0 12px; }

.btn, .btn-secondary, .btn-success, .btn-danger {
  display: inline-block; padding: 10px 18px; border-radius: 10px;
  font-size: 14px; font-weight: 600; border: 0; cursor: pointer; text-decoration: none;
  transition: background 0.1s ease, transform 0.05s ease;
}
.btn { background: #4f46e5; color: #fff; }
.btn:hover { background: #4338ca; }
.btn-secondary { background: #fff; color: #0f172a; border: 1px solid #cbd5e1; }
.btn-secondary:hover { background: #f1f5f9; }
.btn-success { background: #059669; color: #fff; }
.btn-danger  { background: #dc2626; color: #fff; }
.btn[disabled] { opacity: 0.55; cursor: not-allowed; }

input.input, select.input, textarea.input {
  display: block; width: 100%;
  padding: 9px 12px; border-radius: 8px; border: 1px solid #cbd5e1;
  background: #fff; font-size: 14px; font-family: inherit;
}
input.input:focus, select.input:focus, textarea.input:focus {
  outline: none; border-color: #6366f1; box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
label { display: block; font-weight: 600; font-size: 13px; margin: 0 0 6px; }
.form-row { margin-bottom: 14px; }
.form-row + .form-row { margin-top: 14px; }

.chip {
  display: inline-flex; align-items: center; padding: 3px 10px;
  border-radius: 999px; font-size: 11px; font-weight: 600;
  background: #f1f5f9; color: #475569; margin-right: 4px;
}
.chip-ok    { background: #d1fae5; color: #065f46; }
.chip-warn  { background: #fef3c7; color: #92400e; }
.chip-fail  { background: #fee2e2; color: #991b1b; }
.chip-info  { background: #dbeafe; color: #1e40af; }
.chip-brand { background: #ede9fe; color: #5b21b6; }

.code { font-family: ui-monospace, monospace; font-size: 12px; background: #f1f5f9; padding: 1px 6px; border-radius: 4px; }

.notice-info  { background: #eff6ff; border: 1px solid #bfdbfe; border-radius: 10px; padding: 12px 16px; color: #1e40af; }
.notice-ok    { background: #ecfdf5; border: 1px solid #6ee7b7; border-radius: 10px; padding: 12px 16px; color: #065f46; }
.notice-warn  { background: #fffbeb; border: 1px solid #fcd34d; border-radius: 10px; padding: 12px 16px; color: #92400e; }
.notice-fail  { background: #fef2f2; border: 1px solid #fca5a5; border-radius: 10px; padding: 12px 16px; color: #991b1b; }

table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 10px 8px; border-bottom: 1px solid #f1f5f9; vertical-align: top; }
th { font-size: 11px; text-transform: uppercase; color: #64748b; letter-spacing: 0.06em; }

.console {
  background: #0f172a; color: #e2e8f0;
  padding: 14px 16px; border-radius: 8px;
  font-family: ui-monospace, monospace; font-size: 11.5px; line-height: 1.5;
  max-height: 480px; overflow: auto; white-space: pre-wrap; margin: 0;
}

.kv { display: grid; grid-template-columns: 180px 1fr; gap: 6px 14px; font-size: 14px; }
.kv dt { color: #64748b; }
.kv dd { margin: 0; }

.dot-pulse {
  width: 10px; height: 10px; border-radius: 50%; background: #2563eb;
  display: inline-block; box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.18);
  animation: pulse 1.2s infinite; margin-right: 6px;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.18); }
  50%      { box-shadow: 0 0 0 8px rgba(37, 99, 235, 0); }
}
