:root {
  /* Светлая тема — по умолчанию (бренд как на лендинге/guruseller.ru) */
  --bg: #f9fafb;
  --panel: #ffffff;
  --panel2: #f3f4f6;
  --txt: #111827;
  --muted: #6b7280;
  --accent: #2563eb;
  --accent2: #2563eb;
  --ok: #16a34a;
  --warn: #d97706;
  --err: #dc2626;
  --border: #e5e7eb;
  --accent-glow: rgba(37, 99, 235, .10);
}
[data-theme="dark"] {
  --bg: #0a0c10;
  --panel: #14171f;
  --panel2: #1c2029;
  --txt: #e7e9ee;
  --muted: #8b90a0;
  --accent: #2563eb;
  --accent2: #60a5fa;
  --ok: #2ecc71;
  --warn: #ffb84d;
  --err: #ff5c5c;
  --border: #2a2e38;
  --accent-glow: rgba(37, 99, 235, .18);
}
* { box-sizing: border-box; }
/* Атрибут hidden должен скрывать всегда — иначе display:grid у .auth-wrap/.app
   перебивает его (равная специфичность, author > UA) и вход/выход ломается. */
[hidden] { display: none !important; }
body { margin: 0; background: var(--bg); color: var(--txt);
  font: 14px/1.55 Onest, -apple-system, system-ui, "Segoe UI", Roboto, sans-serif; }
.brand { font-weight: 800; letter-spacing: -.02em; color: var(--accent); }
.muted { color: var(--muted); font-size: 13px; }
.btn { padding: 10px 16px; border: 0; border-radius: 8px; font-weight: 600;
  cursor: pointer; font-size: 14px; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: #1a6cff; }
.btn-ghost { background: var(--panel2); color: var(--txt); }
.btn-sm { padding: 5px 10px; font-size: 12px; }
input, textarea, select {
  background: var(--panel2); color: var(--txt);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 9px 11px; font: inherit; width: 100%;
}
textarea { resize: vertical; margin: 8px 0; }

/* AUTH */
.auth-wrap { min-height: 100vh; display: grid; place-items: center; padding: 20px;
  background: radial-gradient(circle at 70% 20%, var(--accent-glow), transparent 50%), var(--bg); }
.auth-card { width: 360px; background: var(--panel); border: 1px solid var(--border);
  border-radius: 16px; padding: 28px; }
.auth-card .brand { font-size: 13px; text-transform: uppercase; margin-bottom: 10px; }
.auth-card h1 { font-size: 22px; margin: 0 0 18px; }
.auth-card input { margin-bottom: 10px; }
.auth-card .btn { width: 100%; margin-top: 4px; }
.auth-error { color: var(--err); font-size: 13px; min-height: 18px; margin-top: 8px; }
.auth-switch { margin-top: 16px; font-size: 13px; color: var(--muted); }
.auth-switch a { color: var(--accent2); }

/* APP */
.app { display: grid; grid-template-columns: 230px 1fr; min-height: 100vh; }
.sidebar { background: var(--panel); border-right: 1px solid var(--border);
  padding: 22px 16px; display: flex; flex-direction: column; }
.sidebar .brand { font-size: 18px; margin-bottom: 24px; }
.sidebar nav { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.nav { padding: 9px 12px; border-radius: 8px; color: var(--muted);
  text-decoration: none; cursor: pointer; font-size: 14px; }
.nav:hover { background: var(--panel2); color: var(--txt); }
.nav.active { background: var(--accent); color: #fff; }
.sidebar-foot { display: flex; flex-direction: column; gap: 6px; padding-top: 16px;
  border-top: 1px solid var(--border); }
.sidebar-foot a { text-decoration: none; }

.content { padding: 32px 36px; max-width: 920px; }
.tab h2 { font-size: 24px; margin: 0 0 6px; }
.tab > .muted { margin-bottom: 20px; }

.cards-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
  gap: 14px; margin: 18px 0; }
.stat { background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; padding: 18px; }
.stat-num { font-size: 26px; font-weight: 700; color: var(--accent2); }
.stat-label { color: var(--muted); font-size: 12px; margin-top: 4px; }

.form-row { display: flex; gap: 10px; margin-bottom: 8px; }
.form-row > * { flex: 1; }

.list { margin-top: 18px; display: flex; flex-direction: column; gap: 8px; }
.row { background: var(--panel); border: 1px solid var(--border);
  border-radius: 10px; padding: 12px 14px; display: flex;
  align-items: center; justify-content: space-between; gap: 12px; }
.row .row-main { min-width: 0; }
.row .row-title { font-weight: 600; }
.row .row-sub { color: var(--muted); font-size: 12px; word-break: break-all; }
.row .row-actions { display: flex; gap: 6px; flex-shrink: 0; }
.badge { font-size: 11px; padding: 2px 7px; border-radius: 6px;
  background: var(--panel2); color: var(--muted); }
.badge.ok { background: rgba(46,204,113,.15); color: var(--ok); }
.badge.off { background: rgba(139,144,160,.15); color: var(--muted); }

.plan-card { background: var(--panel); border: 1px solid var(--border);
  border-radius: 14px; padding: 20px; }
.plan-card.popular { border-color: var(--accent); }
.plan-title { font-size: 20px; font-weight: 700; }
.plan-price { font-size: 26px; color: var(--accent2); font-weight: 700; margin: 6px 0; }
.plan-price small { font-size: 13px; color: var(--muted); font-weight: 400; }
.plan-card ul { list-style: none; padding: 0; margin: 12px 0; }
.plan-card li { padding: 4px 0 4px 20px; position: relative; font-size: 13px; }
.plan-card li::before { content: "✓"; position: absolute; left: 0; color: var(--ok); }
.plan-card .btn { width: 100%; }

.toast { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%);
  background: var(--panel2); border: 1px solid var(--border);
  padding: 12px 20px; border-radius: 10px; z-index: 100; }
.toast.ok { border-color: var(--ok); }
.toast.err { border-color: var(--err); }
.device-code { font-family: monospace; font-size: 22px; letter-spacing: 2px;
  background: #000; padding: 10px 16px; border-radius: 8px; display: inline-block; }

/* REPLY SETTINGS */
.rs-form { display: flex; flex-direction: column; gap: 14px; margin-top: 18px; }
.rs-form .form-row { margin-bottom: 0; }
.rs-field { display: flex; flex-direction: column; gap: 6px; }
.rs-field > label { color: var(--muted); font-size: 13px; }
.rs-checks { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr));
  gap: 8px; }
.rs-check { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.rs-check input { width: auto; }
.rs-faq-row { display: flex; gap: 8px; align-items: center; margin-bottom: 8px; }
.rs-faq-row input { flex: 1; }
.rs-actions { display: flex; align-items: center; gap: 12px; margin-top: 4px; }

/* SIDEBAR FOOTER (как у GuruStat) */
.foot-head { color: var(--muted); font-size: 11px; text-transform: uppercase;
  letter-spacing: .05em; margin-bottom: 8px; }
.foot-email { font-size: 13px; color: var(--txt); font-weight: 600; word-break: break-all; }
.foot-logout { display: flex; align-items: center; gap: 8px; margin-top: 8px;
  padding: 8px 10px; border-radius: 8px; font-size: 13px; color: var(--err);
  background: rgba(220, 38, 38, .07); }
.foot-logout:hover { background: rgba(220, 38, 38, .12); }
.foot-logout svg, .foot-links svg, .foot-theme svg { width: 16px; height: 16px; flex-shrink: 0; }
.foot-links { display: flex; flex-direction: column; gap: 2px; margin-top: 12px;
  padding-top: 12px; border-top: 1px solid var(--border); }
.foot-links a { display: flex; align-items: center; gap: 8px; padding: 6px 10px;
  border-radius: 8px; font-size: 13px; color: var(--muted); }
.foot-links a:hover { background: var(--panel2); color: var(--txt); }
.foot-theme { display: flex; align-items: center; gap: 8px; margin-top: 10px;
  width: 100%; padding: 8px 10px; border-radius: 8px; background: transparent;
  border: 1px solid var(--border); color: var(--muted); cursor: pointer; font: inherit;
  font-size: 13px; }
.foot-theme:hover { background: var(--panel2); color: var(--txt); }

/* СОГЛАСИЯ (152-ФЗ) */
.auth-consent { display: flex; flex-direction: column; gap: 10px; margin: 8px 0 14px; }
.consent-row { display: flex; gap: 8px; align-items: flex-start; font-size: 12.5px;
  color: var(--muted); line-height: 1.45; cursor: pointer; }
.consent-row input { width: auto; margin-top: 2px; flex-shrink: 0; }
.consent-row a { color: var(--accent); }

/* COOKIE-БАННЕР */
.cookie-bar { position: fixed; left: 50%; bottom: 18px; transform: translateX(-50%);
  max-width: 640px; width: calc(100% - 32px); background: var(--panel);
  border: 1px solid var(--border); border-radius: 12px; padding: 13px 16px;
  display: flex; align-items: center; gap: 14px; box-shadow: 0 8px 30px rgba(0,0,0,.18);
  z-index: 200; font-size: 13px; color: var(--muted); }
.cookie-bar a { color: var(--accent); }
.cookie-bar .btn { flex-shrink: 0; }

/* ЛИЦЕНЗИЯ / БАЛАНС */
.license-box, .hint-box { background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; padding: 16px 18px; margin: 4px 0 18px; }
.license-row { display: flex; align-items: center; gap: 12px; padding: 5px 0; flex-wrap: wrap; }
.license-row > .muted { min-width: 110px; }
.lic-token { background: var(--panel2); padding: 5px 10px; border-radius: 6px;
  font-family: ui-monospace, Menlo, monospace; font-size: 12px; word-break: break-all; flex: 1; min-width: 180px; }
.hint-box { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.hint-box .btn { margin-left: auto; }
