/* public/app.css */

:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --text:#111;
  --muted:#777;
  --border:#e5e7eb;
  --accent:#111;
}

*{ box-sizing:border-box; }

body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
  background:var(--bg);
  color:var(--text);
}

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:underline; }

/* ── Шапка ───────────────────────────────────────────── */
.top{
  display:flex;
  align-items:center;
  gap:12px;
  padding:9px 16px;
  background:var(--accent);
  color:#fff;
  position:sticky;
  top:0;
  z-index:10;
  font-size:13px;
}
.top a{ color:#fff; }
.top a:hover{ opacity:.8; text-decoration:none; }
.spacer{ flex:1; }

/* ── Обёртка ─────────────────────────────────────────── */
.wrap{
  max-width:1200px;
  margin:0 auto;
  padding:14px 16px;
}

h1{ margin:0 0 6px; font-size:20px; font-weight:700; }
h2{ margin:0 0 8px; font-size:14px; font-weight:600; text-transform:uppercase;
    letter-spacing:.04em; color:var(--muted); }

/* ── Уведомления ─────────────────────────────────────── */
.notice{
  border:1px solid #f0c36d;
  background:#fff8e1;
  border-radius:8px;
  padding:8px 12px;
  margin:10px 0 12px;
  font-size:13px;
}

/* ── Grids ───────────────────────────────────────────── */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:10px;
  align-items:start;
}
.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  align-items:start;
}

/* ── Карточки ────────────────────────────────────────── */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px;
  box-shadow:0 1px 3px rgba(0,0,0,.05);
}

.muted{ color:var(--muted); font-size:12px; }

/* ── Формы ───────────────────────────────────────────── */
.form{
  display:flex;
  flex-direction:column;
  gap:7px;
}
.row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.field label{
  display:block;
  font-size:11px;
  color:var(--muted);
  margin:0 0 3px;
  font-weight:500;
}

input, select, button{ font:inherit; }

input, select{
  width:100%;
  padding:5px 8px;
  border:1px solid var(--border);
  border-radius:7px;
  background:#fff;
  font-size:13px;
}
input:focus, select:focus{
  outline:2px solid #2563eb33;
  border-color:#2563eb77;
}

select[multiple]{ min-height:120px; }

button{
  padding:6px 11px;
  border:0;
  border-radius:7px;
  background:#111;
  color:#fff;
  cursor:pointer;
  font-size:13px;
  font-weight:500;
}
button:hover{ opacity:.86; }

/* ── Варианты кнопок ─────────────────────────────────── */
.btn{ cursor:pointer; }
.btn-small{ padding:4px 9px; font-size:12px; border-radius:6px; }
.btn-mini { padding:3px 7px;  font-size:11px; border-radius:5px; line-height:1.4; }
.btn:disabled{ opacity:.5; cursor:not-allowed; }
.btn-danger{ background:#dc2626; }
.btn-danger:hover{ background:#b91c1c; opacity:1; }
.btn-secondary{ background:#6b7280; }
.btn-secondary:hover{ background:#4b5563; opacity:1; }
.btn-outline{
  background:transparent;
  border:1px solid var(--border);
  color:var(--text);
}
.btn-outline:hover{ background:#f3f4f6; opacity:1; }

/* ── Разделитель ─────────────────────────────────────── */
.hr{ height:1px; background:var(--border); margin:10px 0; }

/* ── Таблицы ─────────────────────────────────────────── */
.tbl-wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
.tbl{ width:100%; border-collapse:collapse; }
.tbl th{
  padding:5px 8px;
  vertical-align:middle;
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--muted);
  border-bottom:1px solid var(--border);
  white-space:nowrap;
}
.tbl td{ padding:5px 8px; vertical-align:middle; font-size:13px; }
.tbl tbody tr{ border-bottom:1px solid #f1f1f1; }
.tbl tbody tr:hover{ background:#fafafa; }
.nowrap{ white-space:nowrap; }
.topic{ white-space:normal; word-break:break-word; }

/* ── Строка-секция в операторской ────────────────────── */
.section-row td{
  background:#f7f7f7;
  font-size:12px;
  padding:6px 8px;
  font-weight:600;
  color:var(--muted);
}

/* ── Адаптация ───────────────────────────────────────── */
@media (max-width:900px){
  .grid-3{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .grid-3{ grid-template-columns:1fr; }
  .row   { grid-template-columns:1fr; }
  .wrap  { padding:10px; }
  h1     { font-size:17px; }
  .top   { padding:8px 10px; gap:8px; font-size:12px; }
  .card  { padding:10px; }
}
