/* ───────── GitHub Primer (light) tokens ───────── */
:root{
  --bg-canvas: #ffffff;
  --bg-subtle: #f6f8fa;
  --bg-muted:  #eaeef2;
  --bg-emphasis: #24292f;
  --border-default: #d0d7de;
  --border-muted:   #d8dee4;
  --fg-default: #1f2328;
  --fg-muted:   #656d76;
  --fg-subtle:  #6e7781;
  --fg-on-emphasis: #ffffff;
  --accent-fg: #0969da;
  --accent-emphasis: #0969da;
  --accent-subtle: #ddf4ff;
  --success-fg: #1a7f37;
  --success-emphasis: #1f883d;
  --success-subtle: #dafbe1;
  --danger-fg: #cf222e;
  --danger-emphasis: #cf222e;
  --danger-subtle: #ffebe9;
  --attention-fg: #9a6700;
  --attention-subtle: #fff8c5;
  --done-fg: #8250df;
  --done-subtle: #fbefff;
  --shadow-sm: 0 1px 0 rgba(31,35,40,.04);
  --shadow-md: 0 3px 6px rgba(140,149,159,.15);
  --radius: 6px;
  --radius-lg: 12px;
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
  --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family: var(--font-sans);
  font-size: 14px; line-height: 1.5;
  color: var(--fg-default); background: var(--bg-canvas);
  -webkit-font-smoothing: antialiased;
}
a{ color: var(--accent-fg); text-decoration:none; }
a:hover{ text-decoration: underline; }
button{ font-family: inherit; }

/* ───────── Top nav ───────── */
.topnav{
  background: var(--bg-emphasis); color: var(--fg-on-emphasis);
  padding: 12px 24px; display:flex; align-items:center; gap:16px;
}
.topnav .brand{
  display:flex; align-items:center; gap:8px;
  font-weight:600; color:var(--fg-on-emphasis); font-size:15px;
}
.topnav nav{ display:flex; gap:4px; margin-left:8px; }
.topnav nav a{
  color: var(--fg-on-emphasis); padding:6px 10px; font-size:13px;
  font-weight:500; border-radius: var(--radius); opacity:.85;
}
.topnav nav a:hover{ background: rgba(255,255,255,.08); opacity:1; text-decoration:none; }
.topnav nav a.active{ opacity:1; background: rgba(255,255,255,.06); }
.topnav .spacer{ flex:1; }
.topnav .search{
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  color: var(--fg-on-emphasis); border-radius: var(--radius);
  padding: 5px 10px; width: 280px; font-size: 13px;
}
.topnav .search::placeholder{ color: rgba(255,255,255,.55); }
.topnav .search:focus{ outline:none; border-color:#58a6ff; background: rgba(255,255,255,.12); }
.topnav .avatar{
  width:28px; height:28px; border-radius:50%;
  background: linear-gradient(135deg,#fb923c,#ef4444);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:600; color:#fff; text-decoration:none;
}
.topnav .avatar:hover{ text-decoration:none; }
.topnav .balance{
  font-size:12px; color: rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.15);
  padding:4px 8px; border-radius: var(--radius);
  font-family: var(--font-mono);
}
.topnav .anon-link{
  color:#fff; font-size:13px; font-weight:500; padding:6px 10px;
  border:1px solid rgba(255,255,255,.2); border-radius: var(--radius);
}
.topnav .anon-link:hover{ background: rgba(255,255,255,.06); text-decoration:none; }

/* ───────── Sub-nav ───────── */
.subnav{
  border-bottom: 1px solid var(--border-default); background: var(--bg-canvas);
  padding: 0 24px; display:flex; gap: 4px; overflow-x:auto;
}
.subnav a{
  padding: 12px 14px 10px; color: var(--fg-default); font-size: 14px;
  border-bottom: 2px solid transparent; display:flex; align-items:center; gap:6px;
  white-space:nowrap;
}
.subnav a:hover{ text-decoration:none; border-bottom-color: var(--border-default); }
.subnav a.active{ font-weight:600; border-bottom-color: #fd8c73; }
.subnav a .count{
  background: var(--bg-muted); color: var(--fg-default);
  font-size: 12px; padding: 1px 7px; border-radius: 999px;
  font-variant-numeric: tabular-nums;
}

/* ───────── Layout ───────── */
main{ max-width: 1280px; margin: 0 auto; padding: 24px; }
.page-header{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap: 16px; margin-bottom: 16px; flex-wrap:wrap;
}
.page-header h1{ margin:0; font-size: 22px; font-weight:600; }
.page-header p{ margin:4px 0 0; color: var(--fg-muted); font-size:13px; }

/* ───────── Buttons ───────── */
.btn{
  display:inline-flex; align-items:center; gap:6px;
  padding: 5px 12px; font-size: 14px; font-weight:500; line-height: 20px;
  border: 1px solid var(--border-default); border-radius: var(--radius);
  background: var(--bg-subtle); color: var(--fg-default);
  cursor: pointer; transition: background .15s, border-color .15s;
  text-decoration: none;
}
.btn:hover{ background: var(--bg-muted); border-color: rgba(31,35,40,.15); text-decoration:none; }
.btn-primary{
  background: var(--success-emphasis); color:#fff;
  border-color: rgba(31,35,40,.15); box-shadow: var(--shadow-sm);
}
.btn-primary:hover{ background:#1a7f37; color:#fff; }
.btn-accent{ background: var(--accent-emphasis); color:#fff; border-color: rgba(31,35,40,.15); }
.btn-accent:hover{ background:#0860c7; color:#fff; }
.btn-danger{ background:#fff; color: var(--danger-fg); }
.btn-danger:hover{ background: var(--danger-subtle); }
.btn-sm{ padding: 3px 10px; font-size:12px; line-height: 18px; }
.btn[disabled]{ opacity:.55; cursor:not-allowed; }

/* ───────── Cards / boxes ───────── */
.box{
  border: 1px solid var(--border-default); border-radius: var(--radius-lg);
  background: var(--bg-canvas); overflow: hidden;
}
.box-header{
  padding: 12px 16px; background: var(--bg-subtle);
  border-bottom: 1px solid var(--border-default);
  font-weight:600; display:flex; justify-content:space-between; align-items:center;
}
.box-row{ padding: 12px 16px; border-bottom: 1px solid var(--border-muted); }
.box-row:last-child{ border-bottom: none; }

/* ───────── Catalog ───────── */
.toolbar{
  display:flex; gap:8px; flex-wrap:wrap; align-items:center;
  padding: 12px; border:1px solid var(--border-default);
  border-radius: var(--radius); background: var(--bg-subtle); margin-bottom: 16px;
}
.toolbar input, .toolbar select{
  padding: 5px 10px; font-size:13px;
  border:1px solid var(--border-default); border-radius: var(--radius);
  background:#fff; color: var(--fg-default); font-family: inherit;
}
.toolbar input{ flex:1; min-width: 220px; }
.toolbar input:focus, .toolbar select:focus{
  outline: none; border-color: var(--accent-emphasis);
  box-shadow: 0 0 0 3px var(--accent-subtle);
}
.toolbar .chip{ font-size:12px; color: var(--fg-muted); margin-right:auto; }

.grid{
  display:grid; gap:16px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.card{
  border:1px solid var(--border-default); border-radius: var(--radius-lg);
  background:#fff; overflow:hidden; display:flex; flex-direction:column;
  transition: border-color .15s, box-shadow .15s, transform .15s;
  text-decoration:none; color: inherit;
}
.card:hover{
  border-color:#0969da; box-shadow: var(--shadow-md);
  transform: translateY(-1px); text-decoration:none;
}
.card .thumb{
  aspect-ratio: 16/10;
  background: linear-gradient(135deg, var(--bg-muted), var(--bg-subtle));
  display:flex; align-items:center; justify-content:center;
  border-bottom: 1px solid var(--border-muted); position: relative;
}
.card .thumb svg{ width: 64%; height: 64%; opacity:.85; }
.card .body{ padding: 12px 14px; flex:1; display:flex; flex-direction:column; gap:6px; }
.card .title{ font-weight:600; font-size:14px; line-height:1.3; }
.card .meta{ color: var(--fg-muted); font-size:12px; display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.card .price-row{
  margin-top:auto; padding-top:8px;
  display:flex; justify-content:space-between; align-items:flex-end;
  border-top: 1px dashed var(--border-muted);
}
.card .price{ font-family: var(--font-mono); font-weight:600; font-size:15px; }
.card .bidcount{ font-size:12px; color: var(--fg-muted); }

/* ───────── Badges ───────── */
.badge{
  display:inline-flex; align-items:center; gap:4px;
  font-size: 12px; padding: 1px 8px; border-radius: 999px;
  border:1px solid transparent; font-weight:500;
}
.badge-default{ background: var(--bg-muted); color: var(--fg-default); }
.badge-accent{ background: var(--accent-subtle); color: var(--accent-fg); border-color: rgba(9,105,218,.2); }
.badge-success{ background: var(--success-subtle); color: var(--success-fg); border-color: rgba(26,127,55,.2); }
.badge-danger{ background: var(--danger-subtle); color: var(--danger-fg); border-color: rgba(207,34,46,.2); }
.badge-attention{ background: var(--attention-subtle); color: var(--attention-fg); border-color: rgba(154,103,0,.2); }
.badge-done{ background: var(--done-subtle); color: var(--done-fg); border-color: rgba(130,80,223,.2); }
.badge-live{ background: #ffebe9; color:#cf222e; border-color: rgba(207,34,46,.25); }
.badge-live::before{
  content:''; display:inline-block; width:6px; height:6px; border-radius:50%;
  background: #cf222e; margin-right:2px;
  animation: pulse 1.4s infinite ease-in-out;
}
@keyframes pulse{ 0%,100%{opacity:1; transform:scale(1)} 50%{opacity:.4; transform:scale(.85)} }

.thumb-overlay{
  position:absolute; top:8px; right:8px;
  background: rgba(255,255,255,.92); border:1px solid var(--border-default);
  border-radius: var(--radius); padding: 2px 8px;
  font-size: 11px; font-family: var(--font-mono); color: var(--fg-default);
  backdrop-filter: blur(2px);
}
.thumb-overlay.urgent{ color: var(--danger-fg); border-color: var(--danger-emphasis); }
.thumb-id{
  position:absolute; top:8px; left:8px;
  background: rgba(36,41,47,.8); color:#fff;
  font-size: 10px; font-family: var(--font-mono);
  padding: 2px 6px; border-radius: 4px;
}

/* ───────── Lot detail ───────── */
.lot-grid{ display:grid; grid-template-columns: 1.5fr 1fr; gap: 24px; }
@media (max-width: 880px){ .lot-grid{ grid-template-columns: 1fr; } }
.lot-gallery{ border:1px solid var(--border-default); border-radius: var(--radius-lg); overflow:hidden; }
.lot-hero{
  aspect-ratio: 16/10;
  background: linear-gradient(135deg, var(--bg-muted), var(--bg-subtle));
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.lot-hero svg{ width: 60%; height: 60%; }
.lot-hero img{ display:block; }

.thumbs{
  display:flex; gap:6px; padding:8px; overflow-x:auto;
  background: var(--bg-subtle); border-top:1px solid var(--border-default);
}
.thumb-mini{
  flex:none; width:64px; height:48px; padding:0; border-radius:4px;
  border:1px solid var(--border-default); background:#fff; cursor:pointer;
  overflow:hidden;
}
.thumb-mini.active{
  border-color: var(--accent-emphasis);
  box-shadow: 0 0 0 2px var(--accent-subtle);
}

.bid-panel{
  border:1px solid var(--border-default); border-radius: var(--radius-lg);
  background:#fff; overflow:hidden; align-self:start;
  position:sticky; top: 16px;
}
.bid-panel .head{
  padding: 14px 16px; background: var(--bg-subtle);
  border-bottom: 1px solid var(--border-default);
  display:flex; justify-content:space-between; align-items:center;
}
.bid-panel .body{ padding: 16px; }
.bid-panel .price{
  font-family: var(--font-mono); font-size: 28px; font-weight:600; line-height:1.1;
}
.bid-panel .price-label{
  font-size:12px; color: var(--fg-muted);
  text-transform:uppercase; letter-spacing:.04em;
}
.bid-panel .meta-row{
  display:grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 14px 0 16px;
}
.meta-row .item{ font-size:12px; }
.meta-row .item .lbl{ color: var(--fg-muted); display:block; }
.meta-row .item .val{ font-weight:600; font-family: var(--font-mono); }

.countdown{ display:flex; gap:6px; align-items:flex-end; font-family: var(--font-mono); }
.countdown .num{ font-size:18px; font-weight:600; }
.countdown .lbl{ font-size:10px; color: var(--fg-muted); text-transform:uppercase; }

.bid-input{ display:flex; gap:8px; margin-bottom: 10px; }
.bid-input input{
  flex:1; padding: 7px 12px;
  border: 1px solid var(--border-default); border-radius: var(--radius);
  font-size: 15px; font-family: var(--font-mono); font-weight:600;
  color: var(--fg-default);
}
.bid-input input:focus{
  outline:none; border-color: var(--accent-emphasis);
  box-shadow: 0 0 0 3px var(--accent-subtle);
}
.bid-error{
  font-size: 12px; color: var(--danger-fg); background: var(--danger-subtle);
  padding: 6px 10px; border-radius: var(--radius); margin-bottom: 8px;
}
.quick-bids{ display:flex; gap:6px; flex-wrap:wrap; margin-bottom: 12px; }

.specs-table{ width:100%; border-collapse: collapse; font-size: 13px; }
.specs-table th, .specs-table td{
  text-align:left; padding: 8px 12px; border-bottom: 1px solid var(--border-muted);
}
.specs-table th{ width: 40%; color: var(--fg-muted); font-weight: 500; background: var(--bg-subtle); }

/* ───────── Tables ───────── */
.table{ width:100%; border-collapse: collapse; font-size:13px; }
.table th, .table td{
  text-align:left; padding: 8px 12px; border-bottom: 1px solid var(--border-muted);
}
.table th{
  background: var(--bg-subtle); color: var(--fg-muted);
  font-weight: 500; font-size: 12px; text-transform: uppercase; letter-spacing: .04em;
}
.table tbody tr:hover{ background: var(--bg-subtle); }
.table .mono{ font-family: var(--font-mono); }

/* ───────── Live room ───────── */
.live-grid{ display:grid; grid-template-columns: 2fr 1fr; gap: 16px; }
@media (max-width: 980px){ .live-grid{ grid-template-columns: 1fr; } }
.live-stage{
  border:1px solid var(--border-default); border-radius: var(--radius-lg);
  background:#fff; overflow:hidden;
}
.live-stage .stage-head{
  padding: 14px 18px;
  background: linear-gradient(180deg, #fff, var(--bg-subtle));
  border-bottom:1px solid var(--border-default);
  display:flex; justify-content:space-between; align-items:center;
}
.live-hero{
  aspect-ratio: 16/8;
  background: linear-gradient(135deg, var(--bg-muted), #fff);
  display:flex; align-items:center; justify-content:center;
  border-bottom: 1px solid var(--border-muted);
}
.live-hero svg{ width: 50%; height: 70%; }
.live-info{ padding: 16px 18px; display:flex; flex-direction:column; gap: 12px; }
.live-info .title{ font-size: 18px; font-weight:600; }
.live-info .price{ font-family: var(--font-mono); font-weight:600; font-size: 28px; }
.live-actions{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.live-actions .ask{ font-family: var(--font-mono); font-size:13px; color: var(--fg-muted); margin-left:auto; }

.feed{
  border:1px solid var(--border-default); border-radius: var(--radius-lg);
  background:#fff; overflow:hidden; display:flex; flex-direction:column;
}
.feed .head{
  padding: 12px 16px; background: var(--bg-subtle);
  border-bottom:1px solid var(--border-default); font-weight:600;
  display:flex; justify-content:space-between; align-items:center;
}
.feed-body{ max-height: 360px; overflow:auto; }
.feed-item{
  padding: 8px 14px; border-bottom: 1px solid var(--border-muted);
  display:flex; align-items:center; gap:10px; font-size:13px;
  animation: slideIn .3s ease-out;
}
@keyframes slideIn{ from{ background: var(--accent-subtle); } to{ background: transparent; } }
.feed-item .who{ font-weight:600; color: var(--fg-default); }
.feed-item .amt{ font-family: var(--font-mono); margin-left:auto; font-weight:600; }
.feed-item .ts{ color: var(--fg-subtle); font-size: 11px; font-family: var(--font-mono); }
.feed-item.system{ color: var(--fg-muted); font-style:italic; }

.upcoming-list .row{
  display:flex; align-items:center; gap:10px; padding: 10px 14px;
  border-bottom:1px solid var(--border-muted); cursor:pointer;
}
.upcoming-list .row:hover{ background: var(--bg-subtle); }
.upcoming-list .lot-no{
  font-family: var(--font-mono); font-size:11px; color: var(--fg-muted);
  width: 50px; flex:none;
}
.upcoming-list .name{ font-size:13px; flex:1; }
.upcoming-list .est{ font-family: var(--font-mono); font-size:12px; color: var(--fg-muted); }

/* ───────── Watchlist ───────── */
.stats{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 20px; }
@media (max-width: 760px){ .stats{ grid-template-columns: repeat(2,1fr); } }
.stat{
  border: 1px solid var(--border-default); border-radius: var(--radius-lg);
  padding: 14px 16px; background:#fff;
}
.stat .lbl{ font-size:12px; color: var(--fg-muted); }
.stat .val{ font-size:22px; font-weight:600; font-family: var(--font-mono); margin-top: 2px; }
.stat .delta{ font-size:12px; color: var(--success-fg); margin-top: 2px; }
.stat .delta.neg{ color: var(--danger-fg); }

.empty{ text-align:center; padding: 40px 20px; color: var(--fg-muted); }
.empty svg{ width: 56px; height: 56px; opacity:.5; margin-bottom: 8px; }

/* ───────── Auth (allauth) pages ───────── */
.auth-card{
  max-width: 380px; margin: 64px auto; padding: 24px 28px;
  border: 1px solid var(--border-default); border-radius: var(--radius-lg);
  background: #fff;
}
.auth-card h1{ margin:0 0 4px; font-size: 20px; font-weight:600; text-align:center; }
.auth-card .sub{ text-align:center; color: var(--fg-muted); margin-bottom: 18px; font-size: 13px; }
.auth-card form p{ margin: 0 0 12px; }
.auth-card label{ display:block; font-size:13px; font-weight:500; margin-bottom: 4px; }
.auth-card input[type=email],
.auth-card input[type=text],
.auth-card input[type=password]{
  width: 100%; padding: 7px 10px; font-size: 14px;
  border: 1px solid var(--border-default); border-radius: var(--radius);
  background:#fff; color: var(--fg-default); font-family: inherit;
}
.auth-card input:focus{
  outline:none; border-color: var(--accent-emphasis);
  box-shadow: 0 0 0 3px var(--accent-subtle);
}
.auth-card .btn{ width: 100%; justify-content:center; }
.auth-card .alt{ text-align:center; font-size: 13px; margin-top: 12px; color: var(--fg-muted); }
.auth-card .errors{
  background: var(--danger-subtle); color: var(--danger-fg);
  padding: 8px 12px; border-radius: var(--radius); font-size: 13px; margin-bottom: 12px;
}
.helptext{ font-size: 11px; color: var(--fg-muted); display:block; margin-top:2px; }

/* ───────── Messages ───────── */
.messages{ list-style:none; padding: 0; margin: 0 0 12px; }
.messages li{
  padding: 8px 12px; border-radius: var(--radius); font-size: 13px;
  margin-bottom: 6px; border: 1px solid var(--border-default);
  background: var(--bg-subtle);
}
.messages .success{ background: var(--success-subtle); color: var(--success-fg); border-color: rgba(26,127,55,.2); }
.messages .error{ background: var(--danger-subtle); color: var(--danger-fg); border-color: rgba(207,34,46,.2); }
.messages .info{ background: var(--accent-subtle); color: var(--accent-fg); border-color: rgba(9,105,218,.2); }

/* ───────── Misc utils ───────── */
.row-flex{ display:flex; gap: 12px; align-items:center; }
.gap-2{ gap: 8px; }
.mono{ font-family: var(--font-mono); }
.muted{ color: var(--fg-muted); font-size: 13px; }
.hidden{ display:none !important; }

/* ───────── Settings page ───────── */
.settings-grid{
  display:grid; gap:16px;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  max-width: 980px;
}
.settings-grid .form-row{ margin-bottom: 12px; }
.settings-grid .form-row label{
  display:block; font-size:13px; font-weight:500; margin-bottom: 4px;
}
.settings-grid .form-row input[type=text],
.settings-grid .form-row input[type=email],
.settings-grid .form-row input[type=password]{
  width: 100%; padding: 7px 10px; font-size: 14px;
  border: 1px solid var(--border-default); border-radius: var(--radius);
  background:#fff; color: var(--fg-default); font-family: inherit;
}
.settings-grid .form-row input:focus{
  outline:none; border-color: var(--accent-emphasis);
  box-shadow: 0 0 0 3px var(--accent-subtle);
}
.settings-grid .check-row{
  display:flex; gap:10px; padding: 10px 0;
  border-bottom: 1px solid var(--border-muted);
  align-items: flex-start;
}
.settings-grid .check-row:last-of-type{ border-bottom: none; }
.settings-grid .check-row input[type=checkbox]{ margin-top: 3px; }
.settings-grid .check-title{ font-size: 14px; font-weight: 500; }

footer.site{
  margin-top: 48px; padding: 24px;
  color: var(--fg-muted); font-size: 12px;
  border-top: 1px solid var(--border-default); text-align:center;
}
footer.site .links a{ margin: 0 8px; color: var(--fg-muted); }
