* { box-sizing: border-box; margin: 0; }
body { font-family: -apple-system, 'Segoe UI', Roboto, sans-serif; background: #f1f5f9; color: #0f172a; display: flex; min-height: 100vh; }

.sidebar { width: 210px; background: #1e1b4b; color: #e0e7ff; padding: 22px 14px; flex-shrink: 0; }
.sidebar .logo { font-size: 1.25em; font-weight: 700; margin-bottom: 26px; }
.sidebar nav a { display: block; color: #c7d2fe; text-decoration: none; padding: 9px 12px; border-radius: 8px; margin-bottom: 4px; font-size: 0.95em; }
.sidebar nav a:hover { background: #312e81; color: #fff; }
.demo-badge { margin-top: 30px; background: #f59e0b; color: #451a03; padding: 8px 10px; border-radius: 8px; font-weight: 700; font-size: 0.8em; text-align: center; }

main { flex: 1; padding: 30px 38px; max-width: 1060px; }
h1 { font-size: 1.5em; margin-bottom: 8px; }
h2 { font-size: 1.1em; margin: 22px 0 10px; }
.muted { color: #64748b; font-size: 0.92em; margin: 6px 0 16px; }

.cards { display: flex; gap: 14px; margin: 18px 0; flex-wrap: wrap; }
.card.action { flex: 1; min-width: 200px; background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 16px; text-decoration: none; color: inherit; transition: 0.15s; }
.card.action:hover { border-color: #6366f1; box-shadow: 0 4px 14px rgba(99,102,241,0.15); }
.card.action b { display: block; margin-bottom: 5px; }
.card.action span { color: #64748b; font-size: 0.86em; }

.stats { display: flex; gap: 14px; margin: 10px 0 6px; }
.stat { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 12px 22px; text-align: center; }
.stat b { font-size: 1.5em; color: #4f46e5; display: block; }
.stat span { color: #64748b; font-size: 0.82em; }

.panel { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 20px; margin: 14px 0; }
.panel.center { text-align: center; padding: 50px; }
label { display: block; margin: 12px 0; font-weight: 600; font-size: 0.92em; }
label small { color: #64748b; font-weight: 400; }
input, select, textarea { width: 100%; padding: 9px 11px; margin-top: 5px; border: 1px solid #cbd5e1; border-radius: 8px; font-size: 0.95em; font-family: inherit; }
input:focus, select:focus, textarea:focus { outline: 2px solid #818cf8; border-color: transparent; }
.row { display: flex; gap: 14px; } .row label { flex: 1; }
.check { display: flex; align-items: center; gap: 8px; font-weight: 400; }
.check input { width: auto; margin: 0; }

.btn { display: inline-block; background: #e2e8f0; color: #0f172a; border: none; padding: 10px 18px; border-radius: 8px; font-size: 0.93em; font-weight: 600; cursor: pointer; text-decoration: none; margin-top: 8px; }
.btn:hover { filter: brightness(0.95); }
.btn.primary { background: #4f46e5; color: #fff; }
.btn.small { padding: 5px 10px; font-size: 0.82em; margin: 0; }
.btn.danger { background: #fee2e2; color: #b91c1c; }

.alert { background: #fef2f2; border: 1px solid #fca5a5; color: #b91c1c; padding: 12px 16px; border-radius: 10px; margin: 12px 0; }
.ok { background: #ecfdf5; border: 1px solid #6ee7b7; color: #047857; padding: 10px 16px; border-radius: 10px; margin: 12px 0; }

table.list { width: 100%; border-collapse: collapse; background: #fff; border-radius: 12px; overflow: hidden; border: 1px solid #e2e8f0; }
table.list th { background: #f8fafc; text-align: left; font-size: 0.82em; color: #64748b; }
table.list th, table.list td { padding: 9px 12px; border-bottom: 1px solid #f1f5f9; font-size: 0.92em; }

.badge { padding: 3px 10px; border-radius: 20px; font-size: 0.8em; font-weight: 700; }
.badge.ready { background: #ecfdf5; color: #047857; }
.badge.running, .badge.pending { background: #eff6ff; color: #1d4ed8; }
.badge.error { background: #fef2f2; color: #b91c1c; }

.serp { display: flex; flex-direction: column; gap: 8px; margin: 10px 0; }
.serp-item { display: flex; gap: 10px; align-items: flex-start; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px; padding: 10px 12px; font-weight: 400; cursor: pointer; }
.serp-item input { width: auto; margin-top: 4px; }
.serp-item .pos { color: #4f46e5; font-weight: 700; min-width: 30px; }
.serp-item small { color: #64748b; word-break: break-all; }

.toolbar { display: flex; gap: 10px; margin: 14px 0; flex-wrap: wrap; }
.result { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 28px 34px; line-height: 1.6; }
.result h1 { font-size: 1.45em; margin: 0 0 12px; }
.result h2 { font-size: 1.2em; margin: 20px 0 8px; color: #312e81; }
.result h3 { font-size: 1.03em; margin: 14px 0 6px; }
.result table { border-collapse: collapse; margin: 10px 0; }
.result th, .result td { border: 1px solid #cbd5e1; padding: 6px 10px; font-size: 0.92em; }
.result .sec { background: #f8fafc; border-left: 3px solid #818cf8; border-radius: 0 8px 8px 0; padding: 10px 14px; margin: 8px 0 14px; font-size: 0.93em; }
.result .sec p { margin: 4px 0; }
.result ul, .result ol { padding-left: 22px; margin: 8px 0; }

.spinner { width: 38px; height: 38px; border: 4px solid #e0e7ff; border-top-color: #4f46e5; border-radius: 50%; margin: 0 auto 16px; animation: spin 0.9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* --- вход / пользователь в сайдбаре / админка --- */
.who { margin-top: 18px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.15); font-size: 13px; }
.who-email { color: #cbd5e1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 6px; }
.who-out { color: #fca5a5 !important; text-decoration: none; }
.who-out:hover { text-decoration: underline; }
.users-tbl { border-collapse: collapse; width: 100%; max-width: 920px; margin-top: 10px; }
.users-tbl th, .users-tbl td { text-align: left; padding: 9px 12px; border-bottom: 1px solid #eee; font-size: 14px; }
.users-tbl th { color: #666; font-weight: 600; }
.badge-ok { background: #e6f6ec; color: #1a7f37; padding: 2px 8px; border-radius: 6px; font-size: 12px; }
.badge-no { background: #fde8e8; color: #b42318; padding: 2px 8px; border-radius: 6px; font-size: 12px; }
.mini { font-size: 12px; padding: 5px 10px; }
.mini.danger { background: #fff; color: #b42318; border: 1px solid #f3b4b4; }
.ok-note { background: #e6f6ec; color: #1a7f37; padding: 10px 14px; border-radius: 8px; margin: 12px 0; max-width: 520px; }

/* --- заявки на доступ в админке --- */
.pending-box { background: #e6f6ec; border: 1px solid #9ad9b0; border-radius: 10px;
  padding: 14px 16px; margin: 14px 0 22px; max-width: 620px; }
.pending-title { font-weight: 600; color: #1a7f37; margin-bottom: 10px; }
.pending-row { display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 7px 0; border-top: 1px solid #cdedd6; font-size: 14px; }
.pending-row:first-of-type { border-top: none; }
.btn-allow { background: #1a7f37; color: #fff; border: none; border-radius: 7px;
  padding: 7px 16px; font-size: 13px; font-weight: 600; cursor: pointer; }
.btn-allow:hover { background: #166a2e; }
