/* ─── tokens ─────────────────────────────────────────────── */
:root {
--bg:         #09090b;
--surface:    #18181b;
--surface-2:  #27272a;
--border:     #3f3f46;
--border-lt:  #27272a;
--text:       #fafafa;
--text-2:     #a1a1aa;
--text-3:     #71717a;
--accent:     #3b82f6;
--accent-dim: #172554;
--red:        #ef4444;
--green:      #22c55e;
--amber:      #f59e0b;
--font:       -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
--mono:       "SF Mono", ui-monospace, "Cascadia Code", Consolas, monospace;
--table-thumb: 176px;
--table-gap:   3px;
--detail-card-min: 300px;
}

/* ─── reset ──────────────────────────────────────────────── */
*, *::before, *::after {
margin: 0; padding: 0;
box-sizing: border-box;
border-radius: 0;
}
input, select, button, textarea {
font-family: inherit;
border-radius: 0;
-webkit-appearance: none;
appearance: none;
}

/* ─── base ───────────────────────────────────────────────── */
html { height: 100%; }
body {
font-family: var(--font);
font-size: 14px;
line-height: 1.5;
color: var(--text);
background: var(--bg);
-webkit-font-smoothing: antialiased;
min-height: 100%;
}

/* ─── header ─────────────────────────────────────────────── */
header {
background: #000;
padding: 14px 24px;
display: flex;
align-items: center;
justify-content: space-between;
border-bottom: 1px solid var(--border);
}
header h1 { font-size: 12px; font-weight: 700; letter-spacing: .14em; }
.meta { font-family: var(--mono); font-size: 11px; color: var(--text-3); }

/* ─── stats bar ──────────────────────────────────────────── */
.stats-bar {
background: var(--surface);
border-bottom: 1px solid var(--border);
padding: 6px 24px;
font-size: 12px;
color: var(--text-3);
display: flex;
gap: 24px;
}
.stats-bar strong { color: var(--text-2); font-family: var(--mono); }

/* ─── toolbar ────────────────────────────────────────────── */
.toolbar {
background: var(--surface);
border-bottom: 1px solid var(--border);
padding: 10px 24px;
display: flex;
gap: 12px;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
}
.toolbar input[type="search"] {
font-size: 13px;
padding: 6px 10px;
border: 1px solid var(--border);
background: var(--bg);
color: var(--text);
width: 260px;
outline: none;
}
.toolbar input[type="search"]::placeholder { color: var(--text-3); }
.toolbar input[type="search"]:focus { border-color: var(--accent); }
.toolbar-group {
display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
}
.toolbar label {
font-size: 12px; color: var(--text-3);
display: flex; align-items: center; gap: 6px;
}
.toolbar select {
font-size: 12px; padding: 5px 8px;
border: 1px solid var(--border);
background: var(--surface-2); color: var(--text); cursor: pointer;
}
.toolbar input[type="number"] {
font-size: 12px; font-family: var(--mono);
padding: 5px 8px; border: 1px solid var(--border);
background: var(--bg); color: var(--text);
width: 90px; outline: none;
}
.toolbar input[type="number"]::placeholder { color: var(--text-3); }
.toolbar input[type="number"]:focus { border-color: var(--accent); }

/* ─── acceptable filter button ───────────────────────────── */
.acceptable-btn {
font-family: var(--mono);
font-size: 11px;
padding: 5px 12px;
border: 1px solid var(--border);
background: var(--bg);
color: var(--text-3);
cursor: pointer;
white-space: nowrap;
letter-spacing: .02em;
transition: all .12s;
}
.acceptable-btn:hover {
border-color: var(--text-3);
color: var(--text-2);
}
.acceptable-btn.require {
border-color: var(--green);
color: var(--green);
background: rgba(34, 197, 94, .08);
}
.acceptable-btn.exclude {
border-color: var(--red);
color: var(--red);
background: rgba(239, 68, 68, .08);
}

/* ─── acceptable badge (table row) ───────────────────────── */
.acceptable-badge {
display: inline-block;
font-size: 9px;
font-family: var(--mono);
padding: 0 4px;
border: 1px solid var(--green);
color: var(--green);
margin-left: 6px;
text-transform: lowercase;
letter-spacing: .02em;
vertical-align: middle;
}

/* ─── acceptable status (detail panel) ───────────────────── */
.detail-acceptable-true {
border-color: var(--green) !important;
color: var(--green) !important;
}
.detail-acceptable-false {
border-color: var(--border) !important;
color: var(--text-3) !important;
opacity: .5;
}

/* ─── flag bar ───────────────────────────────────────────── */
.flag-bar {
background: var(--surface);
border-bottom: 1px solid var(--border);
padding: 6px 24px;
display: flex;
gap: 6px;
align-items: center;
flex-wrap: wrap;
}
.flag-bar:empty { display: none; }
.flag-bar-label {
font-size: 10px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .06em;
color: var(--text-3);
margin-right: 4px;
}
.flag-btn {
font-family: var(--mono);
font-size: 10px;
padding: 3px 10px;
border: 1px solid var(--border);
background: var(--bg);
color: var(--text-3);
cursor: pointer;
text-transform: lowercase;
letter-spacing: .02em;
transition: all .12s;
}
.flag-btn:hover { border-color: var(--text-3); color: var(--text-2); }
.flag-btn.require {
border-color: var(--green);
color: var(--green);
background: rgba(34, 197, 94, .08);
}
.flag-btn.exclude {
border-color: var(--red);
color: var(--red);
background: rgba(239, 68, 68, .08);
text-decoration: line-through;
}

/* ─── flag badges (table + detail) ───────────────────────── */
.flag-badge {
display: inline-block;
font-size: 9px;
font-family: var(--mono);
padding: 0 4px;
border: 1px solid;
margin-left: 6px;
text-transform: lowercase;
letter-spacing: .02em;
vertical-align: middle;
}
.flag-badge-missing {
border-color: var(--red); color: var(--red);
}
.flag-badge-default {
border-color: var(--text-3); color: var(--text-3);
}
.detail-flags {
display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px;
}
.detail-flag {
font-size: 10px; font-family: var(--mono);
padding: 1px 8px; border: 1px solid var(--border);
color: var(--text-3); text-transform: lowercase;
}
.detail-flag-true  { border-color: var(--amber); color: var(--amber); }
.detail-flag-false { border-color: var(--border); color: var(--text-3); opacity: .5; }

/* ─── table ──────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
thead { position: sticky; top: 0; z-index: 10; }
th {
background: var(--surface);
border-bottom: 2px solid var(--border);
padding: 8px 16px; text-align: left;
font-size: 10px; font-weight: 700;
text-transform: uppercase; letter-spacing: .06em;
color: var(--text-3); cursor: pointer;
user-select: none; white-space: nowrap;
}
th.th-preview { cursor: default; }
th:hover { color: var(--text-2); }
th .arrow { margin-left: 4px; font-size: 9px; }
td {
padding: 7px 16px;
border-bottom: 1px solid var(--border-lt);
font-size: 13px; white-space: nowrap;
background: var(--bg); vertical-align: middle;
}

/* ── table preview cell ──────────────────────────────────── */
td.cell-preview {
padding: 6px 8px 6px 16px;
width:     calc(var(--table-thumb) * 2 + var(--table-gap) + 24px);
min-width: calc(var(--table-thumb) * 2 + var(--table-gap) + 24px);
}
.preview-grid { display: grid; gap: var(--table-gap); }
.preview-grid.count-1 { grid-template-columns: var(--table-thumb); grid-template-rows: var(--table-thumb); }
.preview-grid.count-2 { grid-template-columns: var(--table-thumb) var(--table-thumb); grid-template-rows: var(--table-thumb); }
.preview-grid.count-3,
.preview-grid.count-4 { grid-template-columns: var(--table-thumb) var(--table-thumb); grid-template-rows: var(--table-thumb) var(--table-thumb); }
.preview-grid img {
display: block;
width: var(--table-thumb); height: var(--table-thumb);
object-fit: cover; background: var(--surface-2);
border: 1px solid var(--border-lt);
}
.preview-empty {
width: var(--table-thumb); height: var(--table-thumb);
background: var(--surface-2);
border: 1px solid var(--border-lt);
display: flex; align-items: center; justify-content: center;
}
.preview-empty span { font-size: 11px; color: var(--text-3); font-family: var(--mono); }

/* ─── user row ───────────────────────────────────────────── */
.row-user { cursor: pointer; }
.row-user:hover td { background: var(--surface); }
.row-user.active td { background: var(--accent-dim); border-bottom-color: transparent; }
.cell-user { display: flex; align-items: center; gap: 8px; }
.avatar { width: 28px; height: 28px; object-fit: cover; flex-shrink: 0; background: var(--surface-2); }
.avatar-ph { width: 28px; height: 28px; background: var(--surface-2); flex-shrink: 0; }
.user-link { color: var(--accent); text-decoration: none; font-weight: 600; font-size: 13px; }
.user-link:hover { text-decoration: underline; }
.cell-price, .cell-num { font-family: var(--mono); font-size: 13px; }
.cell-date { font-family: var(--mono); font-size: 11px; color: var(--text-3); }

/* ─── detail row ─────────────────────────────────────────── */
.row-detail td {
padding: 0; background: var(--surface);
border-bottom: 2px solid var(--border); white-space: normal;
}
.detail-inner { padding: 20px 24px; }
.detail-head {
display: flex; justify-content: space-between;
align-items: flex-start; margin-bottom: 16px;
padding-bottom: 14px; border-bottom: 1px solid var(--border);
flex-wrap: wrap; gap: 12px;
}
.detail-identity { display: flex; align-items: flex-start; gap: 12px; }
.detail-avatar { width: 52px; height: 52px; object-fit: cover; background: var(--surface-2); flex-shrink: 0; }
.detail-display-name { font-size: 15px; font-weight: 700; }
.detail-sn { font-size: 12px; color: var(--accent); text-decoration: none; font-family: var(--mono); }
.detail-sn:hover { text-decoration: underline; }
.detail-desc {
margin-top: 4px; font-size: 11px; color: var(--text-3);
max-width: 420px; white-space: normal; word-break: break-word; line-height: 1.4;
}
.detail-right { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0; }
.detail-meta { display: flex; gap: 16px; font-size: 11px; color: var(--text-3); font-family: var(--mono); }
.detail-links { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.detail-link-tag {
display: inline-flex; align-items: center; gap: 3px;
padding: 2px 8px; border: 1px solid var(--border);
background: var(--bg); color: var(--text-2);
text-decoration: none; font-size: 11px; font-family: var(--mono);
transition: border-color .12s, color .12s;
}
.detail-link-tag:hover { border-color: var(--accent); color: var(--accent); }
.detail-link-label { font-weight: 700; text-transform: uppercase; font-size: 9px; letter-spacing: .03em; color: var(--text-3); }
.detail-grid { display: grid; grid-template-columns: 260px 1fr; gap: 24px; }
.detail-section h3 {
font-size: 10px; font-weight: 700; text-transform: uppercase;
letter-spacing: .06em; color: var(--text-3);
margin-bottom: 10px; padding-bottom: 6px;
border-bottom: 1px solid var(--border-lt);
}

/* ─── price history ──────────────────────────────────────── */
.ph-genre { margin-bottom: 14px; }
.ph-genre:last-child { margin-bottom: 0; }
.ph-genre-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.genre-tag {
font-size: 10px; font-weight: 700; text-transform: uppercase;
letter-spacing: .04em; color: var(--text-2);
padding: 1px 6px; border: 1px solid var(--border); background: var(--bg);
}
.ph-range { font-size: 11px; color: var(--text-3); font-family: var(--mono); }
.ph-list { list-style: none; }
.ph-list li {
display: flex; justify-content: space-between;
padding: 3px 0; font-size: 12px;
border-bottom: 1px solid var(--border-lt);
}
.ph-list li:last-child { border-bottom: none; }
.ph-val  { font-family: var(--mono); font-weight: 600; color: var(--text); }
.ph-date { font-family: var(--mono); font-size: 11px; color: var(--text-3); }
.ph-up   { color: var(--red); }
.ph-down { color: var(--green); }

/* ─── works grid (detail) ────────────────────────────────── */
.works-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(var(--detail-card-min), 1fr));
gap: 6px;
}
.work-card {
display: block; text-decoration: none;
border: 1px solid var(--border-lt); background: var(--bg);
transition: border-color .12s; overflow: hidden;
}
.work-card:hover { border-color: var(--accent); }
.work-thumb-img { display: block; width: 100%; aspect-ratio: 1; object-fit: cover; background: var(--surface-2); }
.work-thumb-empty {
width: 100%; aspect-ratio: 1; display: flex;
align-items: center; justify-content: center; background: var(--surface-2);
}
.work-thumb-empty span { font-size: 11px; color: var(--text-3); font-family: var(--mono); padding: 8px; text-align: center; word-break: break-all; }
.work-info { padding: 4px 8px; border-top: 1px solid var(--border-lt); display: flex; justify-content: space-between; align-items: center; }
.work-genre { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--text-3); letter-spacing: .04em; }
.work-date { font-size: 10px; color: var(--text-3); font-family: var(--mono); }
.work-nsfw { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--amber); margin-left: 4px; }
.work-body {
padding: 4px 8px 6px; font-size: 11px; line-height: 1.35;
color: var(--text-3); white-space: normal; word-break: break-word;
max-height: 54px; overflow: hidden; border-top: 1px solid var(--border-lt);
}

/* ─── pagination ─────────────────────────────────────────── */
.pagination {
display: flex; justify-content: center; align-items: center;
gap: 2px; padding: 16px 24px;
background: var(--surface); border-top: 1px solid var(--border); flex-wrap: wrap;
}
.page-btn {
font-family: var(--mono); font-size: 12px; padding: 6px 12px;
border: 1px solid var(--border); background: var(--bg);
color: var(--text-2); cursor: pointer;
transition: border-color .12s, color .12s; min-width: 38px; text-align: center;
}
.page-btn:hover { border-color: var(--accent); color: var(--accent); }
.page-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.page-btn.disabled { opacity: .3; pointer-events: none; }
.page-ellipsis { font-family: var(--mono); font-size: 12px; padding: 6px 4px; color: var(--text-3); }
.page-info { font-family: var(--mono); font-size: 11px; color: var(--text-3); margin-left: 12px; }

/* ─── messages ───────────────────────────────────────────── */
.msg { text-align: center; padding: 48px 24px; color: var(--text-3); font-size: 13px; background: var(--bg); }
.msg-sm { color: var(--text-3); font-size: 12px; }

/* ─── scrollbar ──────────────────────────────────────────── */
::-webkit-scrollbar       { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border); }

/* ─── responsive ─────────────────────────────────────────── */
@media (max-width: 1200px) { :root { --table-thumb: 120px; --detail-card-min: 240px; } }
@media (max-width: 900px) { .detail-grid { grid-template-columns: 1fr; } }
@media (max-width: 700px) {
:root { --table-thumb: 88px; --detail-card-min: 160px; }
.toolbar input[type="search"] { width: 100%; }
}