/* gg-auction — terminal */

:root {
  --bg:        #0c0d10;
  --bg-2:      #15171c;
  --panel:     #101216;
  --line:      #1f232a;
  --line-2:    #2a2f37;
  --fg:        #d8dee4;
  --fg-soft:   #8a93a0;
  --fg-mute:   #5a6371;
  --accent:    #7ee787;   /* terminal green */
  --accent-2:  #79c0ff;   /* link blue */
  --warn:      #e3b341;
  --danger:    #f47067;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--fg);
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 13px;
  line-height: 1.45;
  font-feature-settings: "tnum", "calt" 0;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  display: flex; flex-direction: column;
}

a { color: var(--accent-2); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }
::selection { background: var(--accent); color: var(--bg); }

/* ---------- top bar ---------- */
.bar {
  display: flex; align-items: center; gap: 14px;
  padding: 8px 16px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
  font-size: 12px;
  color: var(--fg-soft);
  flex: 0 0 auto;
}
.bar a, .bar__btn { color: var(--fg-soft); }
.bar a:hover, .bar__btn:hover { color: var(--fg); text-decoration: none; }
.bar__brand { color: var(--accent) !important; font-weight: 700; }
.bar__sep { color: var(--fg-mute); }
.bar__path { color: var(--fg-mute); }
.bar__spacer { flex: 1; }
.bar__user { color: var(--fg); }
.bar__warn { color: var(--warn); }
.bar__btn {
  background: transparent; border: 0; padding: 0; cursor: pointer;
  font: inherit; color: var(--fg-soft);
}
.inline { display: inline; }

/* ---------- main ---------- */
main {
  flex: 1 1 auto;
  display: flex; flex-direction: column;
  padding: 16px;
  gap: 12px;
}

/* ---------- meta strip ---------- */
.meta {
  display: flex; flex-wrap: wrap; gap: 8px 14px; align-items: center;
  padding: 10px 12px;
  background: var(--panel);
  border: 1px solid var(--line);
  font-size: 12px;
  flex: 0 0 auto;
}
.meta__k { color: var(--fg-mute); }
.meta__k::after { content: "="; color: var(--fg-mute); margin-left: 2px; }
.meta__v { color: var(--fg); }
.meta__v--ok { color: var(--accent); }
.meta__v--off { color: var(--fg-mute); }
.meta__v--mono { color: var(--accent); font-feature-settings: "tnum"; }
.meta__v--mono [data-d], .meta__v--mono [data-h], .meta__v--mono [data-m], .meta__v--mono [data-s] {
  display: inline-block; min-width: 1.6ch; text-align: right;
}
.meta__sep { color: var(--line-2); }

/* ---------- flash ---------- */
.flash {
  padding: 8px 12px;
  background: var(--panel);
  border: 1px solid var(--line-2);
  border-left: 2px solid var(--accent-2);
  color: var(--fg);
  font-size: 12px;
  flex: 0 0 auto;
}
.flash::before { content: "[i] "; color: var(--accent-2); }
.flash.error { border-left-color: var(--danger); }
.flash.error::before { content: "[!] "; color: var(--danger); }

/* ---------- lots: stacked rows, each row horizontal ---------- */
.lots {
  display: flex; flex-direction: column;
  gap: 10px;
}
.lot {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: 12px 16px;
  display: grid;
  grid-template-columns:
    /* lot/N */ minmax(60px, auto)
    /* buy-in name + est hands */ minmax(160px, 0.9fr)
    /* bid */ minmax(150px, 1fr)
    /* leader block */ minmax(140px, 0.9fr)
    /* bid form */ minmax(220px, 1.1fr)
    /* hint */ minmax(150px, 0.8fr);
  align-items: center;
  gap: 16px;
  position: relative;
}
.lot::before {
  content: "";
  position: absolute; left: 0; top: 0;
  width: 2px; height: 100%;
  background: var(--line-2);
}
.lot[data-bracket="t1"]::before { background: var(--accent-2); }
.lot[data-bracket="t2"]::before { background: var(--accent); }
.lot[data-bracket="t3"]::before { background: var(--warn); }
.lot[data-bracket="t4"]::before { background: #ff9e64; }
.lot[data-bracket="t5"]::before { background: var(--danger); }

.lot__id { color: var(--fg-mute); font-size: 11px; }
.lot__id::before { content: "// "; color: var(--line-2); }
.lot__name {
  display: flex; flex-direction: column; gap: 2px;
  color: var(--fg); font-weight: 500; font-size: 13px;
  min-width: 0;
}
.lot__tier-hands { color: var(--fg-mute); font-size: 11px; font-weight: 400; }
.lot__tier-hands .muted { color: var(--fg-mute); font-style: italic; }

.lot__field { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.lot__k { color: var(--fg-mute); font-size: 10px; text-transform: lowercase; }
.lot__v { color: var(--fg); font-size: 13px; }
.lot__v--off { color: var(--fg-mute); }

.lot__v--bid {
  color: var(--accent);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.01em;
  font-feature-settings: "tnum";
  transition: color 0.2s ease;
  display: inline-flex; align-items: baseline; gap: 2px;
}
.lot__v--bid.flash-update { color: var(--warn); }
.lot__v--bid [data-amount].lot__v--off { font-size: 22px; color: var(--fg-mute); font-weight: 500; }
.lot__currency { color: var(--fg-mute); font-size: 14px; font-weight: 500; margin-right: 2px; }
.lot__hands { display: block; color: var(--fg-mute); font-size: 11px; margin-top: 2px; min-height: 1em; }
.lot__me { color: var(--accent); font-size: 11px; }
.bid--mine { border-color: var(--accent); }

/* bid form */
.bid {
  display: flex; align-items: stretch;
  border: 1px solid var(--line-2);
  background: var(--bg);
  min-width: 0;
}
.bid__prompt {
  padding: 0 8px;
  display: flex; align-items: center;
  color: var(--accent);
  font-weight: 700;
  border-right: 1px solid var(--line-2);
}
.bid input[type=text] {
  min-width: 0;
  border: 0; background: transparent;
  color: var(--fg);
  font: inherit;
  font-size: 13px;
  padding: 8px 10px;
  font-feature-settings: "tnum";
}
.bid input.bid__amt { flex: 1 1 auto; }
.bid__sep {
  display: flex; align-items: center;
  padding: 0 8px;
  color: var(--fg-mute);
  font-size: 11px;
  border-left: 1px solid var(--line-2);
}
.bid input.bid__hands {
  flex: 1 1 130px;
  border-left: 1px solid var(--line-2);
  color: var(--fg-soft);
}
.bid input[type=text]::placeholder { color: var(--fg-mute); }
.bid input[type=text]:focus { outline: none; }
.bid:focus-within { border-color: var(--accent); }
.bid.invalid { border-color: var(--danger); }

.bid button {
  border: 0;
  border-left: 1px solid var(--line-2);
  background: transparent;
  color: var(--fg);
  font: inherit;
  font-size: 12px;
  padding: 0 14px;
  cursor: pointer;
  transition: background 0.1s ease, color 0.1s ease;
}
.bid button:hover { background: var(--accent); color: var(--bg); }
.bid button:disabled { color: var(--fg-mute); cursor: not-allowed; background: transparent; }

.lot__hint {
  font-size: 11px;
  color: var(--fg-mute);
  min-width: 0;
}
.lot__hint.invalid { color: var(--danger); }

.lot__final {
  padding: 6px 10px;
  background: var(--bg);
  border: 1px solid var(--line-2);
  border-left: 2px solid var(--accent);
  font-size: 12px;
  display: flex; gap: 10px; align-items: baseline;
  grid-column: 5 / span 2;
}

/* ---------- panel (form pages) ---------- */
.panel {
  width: 100%;
  max-width: 380px;
  margin: 32px auto 24px;
  background: var(--panel);
  border: 1px solid var(--line);
  padding: 22px 22px 20px;
}
.panel h1 {
  font-size: 14px;
  font-weight: 700;
  color: var(--fg);
  margin: 0 0 4px;
}
.panel h1::before { content: "$ "; color: var(--accent); }
.panel__lede { color: var(--fg-soft); margin: 0 0 14px; font-size: 12px; }
.panel__form { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
.panel__form > label {
  display: block;
  font-size: 11px; color: var(--fg-mute);
}
.panel__form > label > input,
.panel__form > label > select {
  display: block;
  margin-top: 4px;
}
.panel__form input,
.panel__form select {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid var(--line-2); background: var(--bg);
  color: var(--fg);
  font: inherit; font-size: 13px;
  padding: 8px 10px;
  border-radius: 0;
  width: 100%;
}
.panel__form select {
  background-image: linear-gradient(45deg, transparent 50%, var(--fg-mute) 50%),
                    linear-gradient(135deg, var(--fg-mute) 50%, transparent 50%);
  background-position: calc(100% - 14px) 14px, calc(100% - 9px) 14px;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 28px;
  cursor: pointer;
}
.panel__form select:focus,
.panel__form input:focus { outline: none; border-color: var(--accent); }
.panel__form input::placeholder { color: var(--fg-mute); }
.panel__form button { margin-top: 4px; align-self: flex-start; }
.panel__form .muted { font-size: 11px; }
.panel__foot { font-size: 12px; color: var(--fg-mute); margin: 14px 0 0; }

/* ---------- buttons (default) ---------- */
button[type=submit], .panel__form button {
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--accent);
  padding: 8px 14px;
  font: inherit; font-size: 12px;
  cursor: pointer;
  transition: background 0.1s ease, color 0.1s ease;
}
button[type=submit]:hover, .panel__form button:hover {
  background: var(--accent);
  color: var(--bg);
}
button.danger {
  background: var(--bg);
  border-color: var(--danger);
  color: var(--danger);
}
button.danger:hover { background: var(--danger); color: var(--bg); }

/* ---------- admin ---------- */
.admin { padding: 4px 0; max-width: none; }
.admin h1 { font-size: 14px; margin: 0 0 12px; }
.admin h1::before { content: "$ "; color: var(--accent); }
.admin h2 { font-size: 12px; color: var(--fg-soft); margin: 18px 0 8px; font-weight: 500; text-transform: lowercase; }
.admin h2::before { content: "## "; color: var(--fg-mute); }
.admin__form { max-width: 520px; }
.admin__fs {
  border: 1px solid var(--line);
  background: var(--bg);
  padding: 10px 14px 12px;
  margin: 4px 0 8px;
}
.admin__fs legend {
  font-size: 11px;
  color: var(--fg-mute);
  padding: 0 6px;
  text-transform: lowercase;
}
.admin__fs .admin__inline {
  display: grid;
  grid-template-columns: 110px 1fr;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--fg-soft);
  margin: 4px 0;
  text-transform: none;
}
.admin__fs .admin__inline input { padding: 6px 9px; font-size: 12px; }

.t {
  width: 100%;
  border-collapse: collapse;
  background: var(--panel);
  border: 1px solid var(--line);
  font-size: 12px;
  margin: 4px 0 16px;
}
.t th, .t td { padding: 7px 10px; border-bottom: 1px solid var(--line); text-align: left; }
.t thead th { color: var(--fg-mute); background: var(--bg-2); font-weight: 500; font-size: 11px; }
.t tbody tr:last-child td { border-bottom: 0; }
.t .num { text-align: right; }
.t__ok { color: var(--accent); }
.t__off { color: var(--fg-mute); }
.t__void td { text-decoration: line-through; color: var(--fg-mute); }
.t button { padding: 4px 10px; font-size: 11px; }
.t form + form { margin-left: 4px; }

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

/* ---------- howto (below lots) ---------- */
.howto {
  margin-top: 6px;
  padding: 14px 16px;
  background: var(--panel);
  border: 1px solid var(--line);
}
.howto h2 {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 500;
  color: var(--fg-soft);
}
.howto ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column;
  gap: 6px;
}
.howto li {
  font-size: 12px;
  color: var(--fg-soft);
  line-height: 1.55;
  display: flex; gap: 8px;
}
.howto li span {
  color: var(--accent);
  font-weight: 500;
  flex: 0 0 auto;
}
.howto code {
  font-family: inherit;
  background: var(--bg);
  padding: 0 4px;
  border: 1px solid var(--line);
  color: var(--fg);
  font-size: 11px;
}
.howto strong { color: var(--fg); font-weight: 700; }

@media (max-width: 720px) {
}

/* ---------- responsive ---------- */
@media (max-width: 1080px) {
  .lot {
    grid-template-columns: minmax(60px, auto) 1fr 1fr;
    grid-template-rows: auto auto;
    row-gap: 10px;
  }
  .lot__field--bid { grid-column: 2; }
  .lot__field:nth-of-type(2) { grid-column: 3; }
  .bid { grid-column: 1 / span 2; }
  .lot__hint { grid-column: 3; align-self: end; text-align: right; }
  .lot__final { grid-column: 1 / span 3; }
}
@media (max-width: 720px) {
  body { overflow: auto; }
  main { gap: 10px; padding: 12px; }
  .lot {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    gap: 4px;
    padding: 10px 12px;
  }
  .lot__field--bid, .lot__field:nth-of-type(2), .bid, .lot__hint, .lot__final { grid-column: 1; }
  .lot__id { font-size: 10px; }
  .lot__name {
    flex-direction: row; flex-wrap: wrap; align-items: baseline;
    gap: 4px 10px;
  }
  .lot__name > span:first-child { font-size: 12px; }
  .lot__tier-hands { font-size: 11px; }
  .lot__field { flex-direction: row; align-items: baseline; gap: 8px; }
  .lot__field > .lot__k { min-width: 44px; }
  .lot__v--bid { font-size: 17px; gap: 0; }
  .lot__v--bid [data-amount] { font-size: 17px; }
  .lot__v--bid [data-amount].lot__v--off { font-size: 17px; }
  .lot__currency { font-size: 11px; }
  .lot__u { font-size: 10px; }
  .lot__v { font-size: 12px; }
  .bid { margin-top: 2px; }
  .bid input[type=text] { padding: 6px 8px; font-size: 12px; }
  .bid__prompt, .bid__sep { padding: 0 6px; }
  .bid button { padding: 0 10px; font-size: 11px; }
  .lot__hint { text-align: left; font-size: 10px; margin-top: 2px; }
  .bar { flex-wrap: wrap; gap: 8px 12px; }
  .bar__spacer { flex-basis: 100%; height: 0; }
  .howto { padding: 12px 14px; }
  .howto li { font-size: 11px; }
}
