/* Стили админ-панели. Намеренно скромные — функциональность важнее. */
:root {
  --bg:      #f4f1ec;
  --panel:   #ffffff;
  --ink:     #2c2018;
  --muted:   #6e5b4a;
  --line:    #e1d7c8;
  --accent:  #3b5bf6;
  --danger:  #c0392b;
  --warn:    #d4a13b;
  --ok:      #2c7a3a;
  --radius:  4px;
}

* { box-sizing: border-box; }

body.admin {
  margin: 0; padding: 0; background: var(--bg); color: var(--ink);
  font-family: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
  font-size: 14px; line-height: 1.5;
}

a { color: var(--ink); }
a:hover { color: var(--accent); }

.admin__header {
  background: white;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 32px;
  padding: 12px 24px;
}
.admin__brand a { font-weight: 700; letter-spacing: 0.5px; text-decoration: none; }
.admin__nav { display: flex; gap: 16px; flex: 1; }
.admin__nav a { padding: 6px 4px; border-bottom: 2px solid transparent; text-decoration: none; }
.admin__nav a:hover { border-bottom-color: var(--accent); }
.admin__user { font-size: 13px; color: var(--muted); }

.admin__flashes { padding: 8px 24px; }
.admin__main    { padding: 24px; }
.admin__container { max-width: 1300px; margin: 0 auto; }

h1 { font-size: 24px; margin: 0 0 16px 0; }
h2 { font-size: 18px; margin: 32px 0 12px 0; }

/* статы дашборда */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 32px; }
.stat {
  background: var(--panel); padding: 24px; border-radius: var(--radius);
  border: 1px solid var(--line); text-decoration: none; display: block;
  transition: border-color 120ms;
}
.stat:hover { border-color: var(--accent); }
.stat__value { font-size: 32px; font-weight: 700; }
.stat__label { color: var(--muted); }

/* таблицы */
.data-table {
  width: 100%; border-collapse: collapse;
  background: var(--panel); border: 1px solid var(--line);
}
.data-table th, .data-table td {
  padding: 10px 12px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top;
}
.data-table th { background: #faf6ef; font-size: 13px; }
.data-table tbody tr:hover { background: #fbf8f3; }
.row--highlight { background: #fffaf0 !important; }
.row__actions { display: flex; flex-direction: column; gap: 4px; align-items: stretch; }
.row__actions form { display: flex; gap: 4px; }

/* бейджи */
.badge {
  display: inline-block; padding: 2px 8px; border-radius: 999px;
  font-size: 12px; background: #e9e3d7; color: var(--ink);
}
.badge--new       { background: #fde7e7; color: var(--danger); }
.badge--confirmed { background: #e7f1fd; color: var(--accent); }
.badge--completed { background: #e8f7eb; color: var(--ok); }
.badge--cancelled { background: #efebe5; color: var(--muted); }
.badge--pending   { background: #fff5e0; color: var(--warn); }
.badge--approved  { background: #e8f7eb; color: var(--ok); }
.badge--rejected  { background: #fde7e7; color: var(--danger); }
.badge--ok        { background: #e8f7eb; color: var(--ok); }
.badge--warn      { background: #fff5e0; color: var(--warn); }

/* tabs */
.tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.tab {
  padding: 6px 14px; border: 1px solid var(--line); border-radius: 999px;
  background: var(--panel); text-decoration: none; font-size: 13px;
}
.tab--active { background: var(--ink); color: white; border-color: var(--ink); }

/* кнопки */
.btn {
  display: inline-block;
  padding: 8px 16px; border: 1px solid var(--ink);
  background: white; color: var(--ink); cursor: pointer;
  border-radius: var(--radius); font-family: inherit; font-size: 13px;
  text-decoration: none;
}
.btn:hover { background: var(--ink); color: white; }
.btn--primary { background: var(--ink); color: white; }
.btn--primary:hover { background: var(--accent); border-color: var(--accent); }
.btn--small  { padding: 4px 10px; font-size: 12px; }
.btn--danger { border-color: var(--danger); color: var(--danger); background: white; }
.btn--danger:hover { background: var(--danger); color: white; }

/* формы */
.form { display: flex; flex-direction: column; gap: 12px; max-width: 720px; }
.form label { display: flex; flex-direction: column; gap: 4px; font-weight: 500; font-size: 13px; }
.form input, .form select, .form textarea {
  padding: 8px 10px; border: 1px solid var(--line); border-radius: var(--radius);
  font-family: inherit; font-size: 14px; font-weight: normal; background: white;
}
.form input:focus, .form select:focus, .form textarea:focus { outline: 2px solid var(--accent); outline-offset: 1px; border-color: var(--accent); }
.form-row--three { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }

/* блок-карточка */
.card-block { background: var(--panel); padding: 20px; border: 1px solid var(--line); border-radius: var(--radius); margin-bottom: 24px; }

/* фото-грид */
.photo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.photo-grid__item { background: var(--panel); padding: 8px; border: 1px solid var(--line); border-radius: var(--radius); }
.photo-grid__item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius); display: block; margin-bottom: 6px; }

.stars { color: var(--warn); letter-spacing: 2px; }

/* flash */
.flash {
  padding: 10px 14px; margin-bottom: 8px; border-radius: var(--radius);
  background: #fff8e6; border-left: 4px solid var(--warn);
}
.flash--danger  { background: #fde7e7; border-color: var(--danger); }
.flash--success { background: #e8f7eb; border-color: var(--ok); }
.flash--info    { background: #e7f1fd; border-color: var(--accent); }

/* логин */
.admin__login {
  max-width: 360px; margin: 80px auto;
  background: var(--panel); padding: 32px; border-radius: var(--radius);
  border: 1px solid var(--line);
}
.admin__login h1 { font-size: 20px; margin-bottom: 16px; }

.muted { color: var(--muted); }
.small { font-size: 12px; }
code { background: var(--bg); padding: 2px 4px; border-radius: 3px; font-size: 12px; }
.empty { padding: 32px 0; text-align: center; color: var(--muted); }
