/* referral — фирменный стиль панели, ОДИН-В-ОДИН с applications (CLAUDE.md §19, §23).
   Источник дизайн-токенов: applications/astral-admin.html (:root). Акцент — коралловый,
   шрифт Onest. Фиолетовый как основной НЕ используется (оставлен только как доп. акцент). */
:root{
  --bg:#f4f5f8;
  --surface:#ffffff;
  --card:#ffffff;            /* алиас для существующих классов */
  --ink:#1b2a4a;
  --ink-soft:#71798c;
  --line:#ececf1;
  --coral:#fa573a;
  --coral-dark:#e8412a;
  --coral-soft:#feeee9;
  --green:#00b54e;
  --green-soft:#e3f7ec;
  --amber:#f5a524;
  --amber-soft:#fdf3e1;
  --violet:#7c5cfc;
  --violet-soft:#f0ecff;
  --blue:#1db1df;
  --blue-soft:#e4f6fc;
  --r-card:22px;
  --r-pill:999px;
  --radius:22px;             /* алиас для существующих классов */
  --shadow-sm:0 1px 2px rgba(27,42,74,.05), 0 4px 14px rgba(27,42,74,.05);
  --shadow-lg:0 24px 60px rgba(27,42,74,.22);
  --shadow:var(--shadow-sm);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Onest',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--ink);background:var(--bg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--coral);text-decoration:none;font-weight:600}
a:hover{text-decoration:underline}
*:focus-visible{outline:2px solid var(--coral);outline-offset:2px}

/* ── Логотип ── */
.logo-dot{display:inline-block;width:12px;height:12px;border-radius:50%;
  background:linear-gradient(135deg,var(--coral),#ff8763);vertical-align:middle;margin-right:8px}

/* ── Авторизация / анкета ── */
.auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 600px at 50% -10%,#fdeee9,transparent),var(--bg);padding:24px}
.auth-card{background:var(--surface);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-lg);
  padding:34px;width:100%;max-width:400px}
.auth-card.wide{max-width:600px}
.auth-logo{font-weight:700;color:var(--ink-soft);font-size:12.5px;letter-spacing:.4px;
  text-transform:uppercase;margin-bottom:14px}
.auth-card h1{font-size:22px;font-weight:700;letter-spacing:-.3px;margin:0 0 6px}
.auth-title{font-size:24px;font-weight:800;letter-spacing:-.4px;margin:0 0 6px;display:flex;align-items:center;gap:4px}
.auth-sub{color:var(--ink-soft);margin:0 0 20px;font-size:14px;line-height:1.5}
.auth-foot{margin-top:18px;color:var(--ink-soft);font-size:14px;text-align:center}

/* ── ЕДИНЫЙ вид ВСЕХ текстовых полей (любая обёртка) ──────────────────────
   :where() = нулевая специфичность: «голые» <input>/<select>/<textarea> всегда
   выглядят правильно, а классы (.search/.field/.dd-search) легко переопределяют.
   Поэтому поля красивы где угодно — даже вне <form> (напр. SMTP-настройки в админке). */
:where(input:not([type=checkbox]):not([type=radio]):not([type=hidden]), select, textarea){
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:14px;
  font-size:14px;font-family:inherit;color:var(--ink);background:#fbfbfd;outline:none;
  transition:border .15s,box-shadow .15s,background .15s}
:where(textarea){resize:vertical;min-height:88px}
:where(input:not([type=checkbox]):not([type=radio]):not([type=hidden]), select, textarea):focus{
  border-color:var(--coral);background:#fff;box-shadow:0 0 0 4px var(--coral-soft)}
:where(input)::placeholder,:where(textarea)::placeholder{color:#aab0bd}

/* ── Формы со схемой <label>текст<input></label> (вход/админ-вход) ── */
form label{display:block;font-size:13px;color:var(--ink);margin-bottom:14px;font-weight:600}
form label input,form label select{margin-top:7px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
@media(max-width:560px){.grid2,.grid3{grid-template-columns:1fr}}

/* ── Кнопки (как в applications: пилюля, коралл) ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;
  border-radius:var(--r-pill);padding:12px 22px;font-size:14px;font-weight:600;font-family:inherit;
  transition:transform .12s,box-shadow .15s,background .15s,filter .15s;white-space:nowrap;text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--coral);color:#fff;width:100%;box-shadow:0 8px 20px rgba(250,87,58,.3)}
.btn.primary:hover{background:var(--coral-dark);text-decoration:none}
.btn.primary:disabled,.btn.primary[disabled]{background:#f3b9ad;box-shadow:none;cursor:not-allowed;filter:none}
.btn.ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn.ghost:hover{border-color:#d7dae2;background:#fafafc;text-decoration:none}
.btn.sm{padding:8px 15px;font-size:13px}

.alert{border-radius:14px;padding:12px 15px;font-size:14px;margin-bottom:16px;font-weight:500}
.alert.err{background:var(--coral-soft);color:var(--coral-dark);border:1px solid #fcc5b8}
.alert.ok{background:var(--green-soft);color:#0a7c43;border:1px solid #b8e8cc}

/* ── Анкета партнёра: поля .field (как в applications/settings) ── */
.reg-form{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;position:relative}
.field>label{font-size:13px;font-weight:600;color:var(--ink);margin:0}
.field .req{color:var(--coral)}
.field .hint{font-size:11.5px;color:var(--ink-soft);font-weight:400}
.field input,.field select{padding:13px 15px;border:1.5px solid var(--line);border-radius:14px;font-size:14px;
  font-family:inherit;background:#fbfbfd;color:var(--ink);width:100%;margin:0;
  transition:border .15s,box-shadow .15s,background .15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--coral);background:#fff;box-shadow:0 0 0 4px var(--coral-soft)}
.field.ok input{border-color:var(--green);background:#fff;box-shadow:0 0 0 3px var(--green-soft)}
.field.error input{border-color:var(--coral);background:#fff;box-shadow:0 0 0 3px var(--coral-soft)}
.field-err{font-size:12px;color:var(--coral);font-weight:500;display:none}
.field.error .field-err{display:block}

/* Подсказка под полем восстановления пароля («почта найдена/не найдена») */
.reset-note{font-size:13px;font-weight:500;line-height:1.45;display:none}
.reset-note.show{display:block}
.reset-note.err{color:var(--coral-dark)}
.reset-note.ok{color:#0a7c43}
.reset-note a{color:var(--coral)}

/* Всплывающее окошко-подсказка под полем (напр. «почта уже есть») */
.field-pop{position:absolute;top:calc(100% + 8px);left:0;z-index:20;max-width:340px;
  background:var(--ink);color:#fff;padding:10px 14px;border-radius:12px;font-size:12.5px;font-weight:500;line-height:1.45;
  box-shadow:0 12px 32px rgba(27,42,74,.22);opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity .15s,transform .15s,visibility .15s}
.field-pop a{color:#ffd2c7;text-decoration:underline}
.field-pop.show{opacity:1;visibility:visible;transform:translateY(0)}

/* ── Выпадающее меню с поиском live (как status-dd в applications) ── */
.dd{position:relative;width:100%}
.dd-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;
  padding:13px 15px;border:1.5px solid var(--line);border-radius:14px;background:#fbfbfd;color:var(--ink);
  font-size:14px;font-family:inherit;cursor:pointer;text-align:left;
  transition:border .15s,box-shadow .15s,background .15s}
.dd-trigger:hover{border-color:#d7dae2}
.dd-trigger.placeholder{color:var(--ink-soft)}
.dd.open .dd-trigger{border-color:var(--coral);background:#fff;box-shadow:0 0 0 4px var(--coral-soft)}
.field.ok .dd-trigger{border-color:var(--green);background:#fff}
.dd-chevron{width:16px;height:16px;flex:none;opacity:.6;transition:transform .15s}
.dd.open .dd-chevron{transform:rotate(180deg)}
.dd-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:55;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:0 16px 40px rgba(27,42,74,.18),0 2px 8px rgba(27,42,74,.08);padding:8px;
  display:none;flex-direction:column;gap:6px}
.dd.open .dd-menu{display:flex;animation:ddpop .15s ease}
@keyframes ddpop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.dd-search{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-family:inherit;
  font-size:13px;color:var(--ink);outline:none;transition:border .15s,box-shadow .15s}
.dd-search:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft)}
.dd-list{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.dd-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:12px;
  background:transparent;font-family:inherit;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;text-align:left}
.dd-item:hover,.dd-item.kbd{background:#f5f6f9}
.dd-item.sel{background:var(--coral-soft);color:var(--coral-dark);font-weight:600}
.dd-item .dd-code{font-size:12px;font-weight:700;color:var(--ink-soft);min-width:24px}
.dd-empty{padding:14px 12px;font-size:13px;color:var(--ink-soft);text-align:center}

/* ── Радио-карточки «Вариант сотрудничества» ── */
.radio-group{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.radio-group{grid-template-columns:1fr}}
.radio-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1.5px solid var(--line);
  border-radius:14px;background:#fbfbfd;cursor:pointer;transition:border .15s,background .15s;font-weight:500}
.radio-card:hover{border-color:#d7dae2}
.radio-card input{position:absolute;opacity:0;width:0;height:0;margin:0}
.radio-dot{width:20px;height:20px;border-radius:50%;border:2px solid #cfd4de;flex:none;position:relative;transition:border-color .15s}
.radio-card:has(input:checked){border-color:var(--coral);background:var(--coral-soft)}
.radio-card:has(input:checked) .radio-dot{border-color:var(--coral)}
.radio-card:has(input:checked) .radio-dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--coral)}

/* ── Чек-боксы согласий ── */
.consents{display:flex;flex-direction:column;gap:14px;margin-top:4px}
.check-row{display:flex;align-items:flex-start;gap:11px;font-size:13px;color:var(--ink);line-height:1.45;cursor:pointer}
.check-row input{width:18px;height:18px;accent-color:var(--coral);flex:none;margin:1px 0 0;cursor:pointer}
.check-row.required-mark .check-text::after{content:" *";color:var(--coral)}

/* ── Каркас приложения (кабинет/админка) ── */
.app-shell{display:grid;grid-template-columns:268px 1fr;min-height:100vh}
.sidebar{background:#fbfbfd;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px}
.brand{font-weight:700;font-size:16px;padding:10px 12px 20px;display:flex;align-items:center}
.nav{display:flex;flex-direction:column;gap:4px;flex:1}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:14px;color:#5a6275;
  font-weight:500;cursor:pointer;font-size:14px;position:relative}
.nav-item span{width:20px;text-align:center}
.nav-item:hover{background:#f2f2f6;color:var(--ink);text-decoration:none}
.nav-item.active{background:var(--coral-soft);color:var(--coral-dark);font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:4px;border-radius:0 4px 4px 0;background:var(--coral)}
.side-foot{border-top:1px solid var(--line);padding-top:14px;margin-top:10px}
.who-name{font-weight:600;font-size:14px}
.who-sub{color:var(--ink-soft);font-size:12px}
.logout{display:inline-block;margin-top:10px;font-size:13px;color:var(--ink-soft);font-weight:600}
.logout:hover{color:var(--coral)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:68px;display:flex;align-items:center;padding:0 34px;border-bottom:1px solid var(--line);
  background:var(--surface);font-weight:700;font-size:20px;letter-spacing:-.3px}
.view-root{padding:30px 34px;min-width:0}

/* ── Карточки/таблицы ── */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:20px}
.card h2{margin:0 0 4px;font-size:16.5px;font-weight:700}
.card .muted{color:var(--ink-soft);font-size:12.5px;margin:0 0 16px}
.stat-row{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);padding:18px 20px;min-width:150px}
.stat .n{font-size:26px;font-weight:800;letter-spacing:-.5px}
.stat .l{color:var(--ink-soft);font-size:13px}
.stat.coral .n{color:var(--coral)} .stat.green .n{color:var(--green)}
.stat.amber .n{color:var(--amber)} .stat.violet .n{color:var(--violet)} .stat.blue .n{color:var(--blue)}

table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th{text-align:left;color:var(--ink-soft);font-weight:700;font-size:12px;text-transform:uppercase;
  letter-spacing:.04em;padding:12px;border-bottom:1px solid var(--line);background:#fafafc}
table.tbl td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
table.tbl tr:hover td{background:#fafbff}
.pill{display:inline-block;padding:4px 12px;border-radius:var(--r-pill);font-size:12px;font-weight:700}
.pill.pending{background:var(--amber-soft);color:#b4690e}
.pill.active{background:var(--green-soft);color:#0a7c43}
.pill.blocked{background:var(--coral-soft);color:var(--coral-dark)}
.search{padding:11px 15px;border:1px solid var(--line);border-radius:var(--r-pill);width:280px;max-width:100%;
  font-size:14px;font-family:inherit;outline:none;background:var(--surface);box-shadow:var(--shadow-sm)}
.search:focus{border-color:var(--coral);box-shadow:0 0 0 4px var(--coral-soft)}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.code-chip{font-family:ui-monospace,Menlo,monospace;background:#f3f5fc;border-radius:8px;padding:2px 8px;font-size:13px}

/* ── Toast ── */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--ink);color:#fff;padding:14px 24px;border-radius:var(--r-pill);font-size:14px;font-weight:600;
  box-shadow:0 12px 34px rgba(27,42,74,.3);pointer-events:none;transition:opacity .25s,transform .25s;z-index:99999;max-width:92vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--coral-dark)}

.empty{color:var(--ink-soft);text-align:center;padding:30px}

/* ── Модальное окно (как в applications) ── */
.overlay{position:fixed;inset:0;background:rgba(27,42,74,.42);backdrop-filter:blur(3px);
  display:none;align-items:flex-start;justify-content:center;padding:60px 20px;z-index:40;overflow-y:auto}
.overlay.show{display:flex;animation:ofade .2s ease}
@keyframes ofade{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border-radius:24px;width:100%;max-width:460px;box-shadow:var(--shadow-lg);
  animation:mpop .25s cubic-bezier(.2,.9,.3,1.2);overflow:hidden}
@keyframes mpop{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:flex-start;gap:14px;padding:24px 26px 6px}
.modal-head .m-ic{width:46px;height:46px;border-radius:14px;background:var(--coral-soft);color:var(--coral);
  display:grid;place-items:center;flex:none;font-size:22px}
.modal-head h3{font-size:19px;font-weight:700;letter-spacing:-.3px;margin:0}
.modal-head p{font-size:13px;color:var(--ink-soft);font-weight:500;margin:3px 0 0}
.modal-x{margin-left:auto;width:34px;height:34px;border-radius:11px;border:none;background:#f2f3f6;
  display:grid;place-items:center;cursor:pointer;flex:none;font-size:16px;color:var(--ink-soft);line-height:1}
.modal-x:hover{background:#e8eaef}
.modal-body{padding:18px 26px 4px;display:flex;flex-direction:column;gap:14px}
.modal-foot{padding:20px 26px 24px;display:flex;gap:12px;justify-content:flex-end}

/* ── Юридические страницы (оферта/политики) ── */
.legal{max-width:820px;margin:0 auto;padding:48px 24px}
.legal .card{padding:40px}
.legal h1{font-size:26px;font-weight:800;letter-spacing:-.4px;margin:0 0 8px}
.legal .lead{color:var(--ink-soft);margin:0 0 24px}
.legal h2{font-size:17px;margin:24px 0 8px}
.legal p,.legal li{font-size:14px;line-height:1.6;color:var(--ink)}
.legal .placeholder{background:var(--amber-soft);border:1px dashed #f0d4a8;border-radius:12px;padding:12px 16px;color:#8a5a0e;font-size:13px}
.legal .back{display:inline-block;margin-top:28px}
