/* Access — dashboard styles. Minimal, modern dark dashboard. Dependency-free.
 *
 * Mirrors the markup in app/Web/View/dashboard.php and the IDs/classes used by
 * public/assets/app.js. The colour variables are also referenced (by value) in
 * app.js for the ECharts palette — keep the two in sync.
 */

:root {
    --bg:        #0f1419;
    --bg-2:      #11161d;
    --panel:     #161b22;
    --panel-2:   #1b222b;
    --border:    #232a33;
    --grid:      #2a323d;
    --text:      #e6edf3;
    --muted:     #8b949e;
    --faint:     #586069;
    --accent:    #2f81f7;
    --ok:        #3fb950;
    --warn:      #d29922;
    --bad:       #f85149;
    --radius:    10px;
    --radius-sm: 6px;
    --gap:       16px;
    --mono:      ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
}

* { box-sizing: border-box; }

html, body { height: 100%; }

body {
    margin: 0;
    font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background: var(--bg);
    color: var(--text);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- App bar ------------------------------------------------------------- */
header.app-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap);
    padding: 12px 20px;
    background: linear-gradient(180deg, var(--panel-2), var(--panel));
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 20;
}
header.app-bar h1 {
    font-size: 16px;
    margin: 0;
    font-weight: 650;
    letter-spacing: .01em;
}
.app-bar__sub {
    font-weight: 400;
    color: var(--muted);
    font-size: 13px;
    margin-left: 8px;
}
.app-bar__right { display: flex; align-items: center; gap: 14px; }
.app-bar__note { color: var(--faint); font-size: 12px; white-space: nowrap; }

/* ---- Buttons ------------------------------------------------------------- */
.btn {
    font: inherit;
    font-size: 13px;
    padding: 7px 14px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    background: var(--panel);
    color: var(--text);
    cursor: pointer;
    transition: background .12s ease, border-color .12s ease, color .12s ease;
    line-height: 1.2;
}
.btn:hover { border-color: var(--accent); }
.btn--primary { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; }
.btn--primary:hover { background: #4b94ff; }
.btn--ghost { background: transparent; color: var(--muted); }
.btn--ghost:hover { color: var(--text); background: var(--panel); }

/* ---- Filter toolbar ------------------------------------------------------ */
.filters {
    display: flex;
    gap: var(--gap);
    flex-wrap: wrap;
    align-items: flex-end;
    padding: 14px 20px;
    background: var(--panel);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 53px;
    z-index: 15;
}
.filters label {
    color: var(--muted);
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.filters input[type="datetime-local"],
.filters select {
    font: inherit;
    color: var(--text);
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 7px 9px;
    min-width: 180px;
    color-scheme: dark;
}
.filters select { min-width: 220px; }
.filters input:focus,
.filters select:focus { outline: none; border-color: var(--accent); }

.filters__presets { display: flex; gap: 6px; align-items: center; }
.filters__presets .btn { padding: 7px 10px; }
.filters__presets .btn.is-active {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}

.filters__status {
    margin-left: auto;
    align-self: center;
    font-size: 12px;
    color: var(--faint);
    min-width: 90px;
    text-align: right;
}
.filters__status--busy { color: var(--accent); }
.filters__status--ok   { color: var(--ok); }
.filters__status--bad  { color: var(--bad); }

/* ---- Grid + cards -------------------------------------------------------- */
.grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--gap);
    padding: 20px;
    align-items: start;
}
.card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
    min-width: 0; /* allow children (tables/charts) to shrink inside the grid */
}
.card__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin: 0 0 12px;
}
.card h2 {
    font-size: 12px;
    color: var(--muted);
    margin: 0;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 650;
}
.card h2 .hint, .hint { color: var(--faint); font-weight: 400; text-transform: none; letter-spacing: 0; }
.card__meta { font-size: 12px; color: var(--faint); }
.card__meta strong { color: var(--text); }

/* Контейнер для нескольких групп-переключателей в шапке карточки (вендор + вид). */
.card__controls { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }

/* Маленькая кнопка в заголовке колонки (напр. "show all" в блоке coverage). */
.btn--xs { padding: 2px 8px; font-size: 11px; text-transform: none; letter-spacing: 0; font-weight: 500; }
.coverage__col h3 { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* Переключатель представления внутри шапки карточки (диаграмма/график). */
.viewtoggle { display: flex; gap: 4px; align-self: center; flex: none; }
.viewtoggle .btn { padding: 3px 9px; font-size: 11px; }
.viewtoggle .btn.is-active { background: var(--accent); border-color: var(--accent); color: #fff; }

/* URL lookup: компактная карточка, пока запрос не дал результата —
   прячем график и таблицу (KPI скрыты атрибутом hidden). */
#urllookup.is-empty #chart-urlstats,
#urllookup.is-empty #tbl-url-paths { display: none; }

/* Поле поиска по URL/маске. */
.urlsearch { display: flex; gap: 8px; margin: 0 0 12px; }
.urlsearch input {
    flex: 1; min-width: 0;
    padding: 9px 12px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font: inherit;
    font-family: var(--mono);
    font-size: 13px;
}
.urlsearch input:focus { outline: none; border-color: var(--accent); }
.urlsearch .btn { flex: none; }

.col-12 { grid-column: span 12; }
.col-8  { grid-column: span 8; }
.col-6  { grid-column: span 6; }
.col-4  { grid-column: span 4; }

/* ---- Charts -------------------------------------------------------------- */
.chart { width: 100%; height: 320px; }
.chart--sm { height: 220px; }

/* ---- KPI strip ----------------------------------------------------------- */
.kpis {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--gap);
}
.kpi {
    background: var(--bg-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
    text-align: left;
}
.kpi__val {
    font-size: 26px;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -.01em;
    font-variant-numeric: tabular-nums;
}
.kpi__val--ok   { color: var(--ok); }
.kpi__val--warn { color: var(--warn); }
.kpi__val--bad  { color: var(--bad); }
.kpi__lbl {
    margin-top: 4px;
    font-size: 11px;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
}

/* ---- Data tables --------------------------------------------------------- */
table.data {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    table-layout: fixed;
}
table.data th,
table.data td {
    text-align: left;
    padding: 7px 8px;
    border-bottom: 1px solid var(--border);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
}
table.data th {
    color: var(--muted);
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .04em;
    position: sticky;
    top: 0;
    background: var(--panel);
}
table.data tbody tr:hover td { background: var(--panel-2); }
table.data td.num, table.data th.num { text-align: right; font-variant-numeric: tabular-nums; }
table.data td.mono { font-family: var(--mono); font-size: 12px; }
table.data td.path { font-family: var(--mono); font-size: 12px; color: var(--text); }
/* URL-ячейки кликабельны, но в покое выглядят как обычный путь: цвет наследуется,
   подчёркивание только по ховеру (даёт глобальное a:hover), на ховере — акцент. */
table.data td.path a { color: inherit; text-decoration: none; }
table.data td.path a:hover { color: var(--accent); text-decoration: underline; }
table.data .data__empty td {
    color: var(--faint);
    text-align: center;
    padding: 18px 8px;
    white-space: normal;
}
table.data.data--mini { font-size: 12px; }
table.data.data--mini th, table.data.data--mini td { padding: 5px 6px; }

/* Wrap mini tables / overflowing tables so long monospace paths can scroll. */
.card table.data { display: block; max-height: 360px; overflow: auto; }
.card table.data thead, .card table.data tbody, .card table.data tr { width: 100%; }
.card table.data tr { display: table; width: 100%; table-layout: fixed; }
.coverage table.data { max-height: 240px; }

/* Verified vs fake: фиксируем высоту таблицы fake-IP, чтобы карточка совпадала по
   высоте с соседней Crawl volume (chart--sm 220 + таблица 100 ≈ chart 320);
   лишние строки — скроллом. Иначе таблица растягивала карточку и оставляла
   «дырку» под Crawl volume в той же грид-строке. */
#tbl-fake-ips { height: 100px; }

/* "Not crawled by Google": LOC (.path, max-width:0 + ellipsis) забирает всё свободное
   место, LASTMOD прижимаем к содержимому — иначе table-layout:fixed делил 2 колонки
   50/50 и URL сжимался при пустой половине под датой. */
#tbl-never-crawled th:nth-child(2),
#tbl-never-crawled td:nth-child(2) { width: 116px; }

/* Status classes / Worst offenders в одной грид-строке: жмём таблицу worst-offenders
   под высоту пончика Status classes (chart--sm 220), чтобы карточки совпали по высоте;
   лишние 4xx/5xx-строки — скроллом внутри таблицы. */
#tbl-worst { height: 220px; }

/* ---- Badges -------------------------------------------------------------- */
.badge {
    display: inline-block;
    padding: 1px 7px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    background: rgba(139,148,158,.15);
    color: var(--muted);
}
.badge.ok   { background: rgba(63,185,80,.16);  color: var(--ok); }
.badge.warn { background: rgba(210,153,34,.16); color: var(--warn); }
.badge.bad  { background: rgba(248,81,73,.16);  color: var(--bad); }

/* ---- Coverage block ------------------------------------------------------ */
.coverage { display: flex; flex-direction: column; gap: var(--gap); }
.coverage__stats {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--gap);
}
.coverage__tables {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gap);
}
.coverage__col h3 {
    font-size: 12px;
    color: var(--muted);
    margin: 0 0 8px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* ---- Footer -------------------------------------------------------------- */
.app-foot {
    padding: 16px 20px 28px;
    color: var(--faint);
    font-size: 12px;
    border-top: 1px solid var(--border);
    margin-top: 8px;
}

/* ---- Login (rendered by DashboardController::loginForm) ------------------ */
.login {
    max-width: 340px;
    margin: 12vh auto;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px 24px;
}
.login h1 { font-size: 18px; margin: 0 0 4px; }
.login p.sub { color: var(--muted); margin: 0 0 18px; font-size: 13px; }
.login label { display: block; color: var(--muted); font-size: 12px; margin-bottom: 6px; text-transform: uppercase; letter-spacing: .04em; }
.login input[type="password"],
.login input[type="text"] {
    width: 100%;
    padding: 10px 11px;
    margin: 0 0 16px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font: inherit;
}
.login input:focus { outline: none; border-color: var(--accent); }
.login button {
    width: 100%;
    padding: 11px;
    background: var(--accent);
    color: #fff;
    border: 0;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font: inherit;
    font-weight: 600;
}
.login button:hover { background: #4b94ff; }
.login .error {
    color: var(--bad);
    background: rgba(248,81,73,.1);
    border: 1px solid rgba(248,81,73,.3);
    border-radius: var(--radius-sm);
    padding: 8px 11px;
    margin-bottom: 16px;
    font-size: 13px;
}

/* ---- Responsive ---------------------------------------------------------- */
@media (max-width: 1100px) {
    .col-8 { grid-column: span 12; }
    .col-4 { grid-column: span 6; }
}
@media (max-width: 900px) {
    .col-8, .col-6, .col-4 { grid-column: span 12; }
    .kpis { grid-template-columns: repeat(2, 1fr); }
    .coverage__stats { grid-template-columns: repeat(2, 1fr); }
    .coverage__tables { grid-template-columns: 1fr; }
    .filters { position: static; }
    header.app-bar { position: static; }
}
@media (max-width: 560px) {
    .kpis { grid-template-columns: 1fr 1fr; }
    .filters input[type="datetime-local"], .filters select { min-width: 140px; }
    .app-bar__note { display: none; }
}

/* Honour reduced-motion. */
@media (prefers-reduced-motion: reduce) {
    .btn { transition: none; }
}
