/* ==========================================================================
   HAGGLR — app.css  (game + dashboard)
   ========================================================================== */
.bg{position:fixed;inset:0;z-index:-2;width:100%;height:100%}
.bg-wash{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg, rgba(23,16,25,.86), rgba(23,16,25,.95));}

.page{width:min(1080px,100%);margin-inline:auto;padding:clamp(20px,4vw,40px) var(--pad) 80px}
.page__head{margin-bottom:26px}
.page__head .h-sec{margin-top:6px}
.page__head .lead{margin-top:10px}

/* ================= GAME ================================================= */
.g-head{margin-bottom:26px;max-width:60ch}
.g-head .h-sec{margin-top:6px}

.g-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.g-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.g-grid{grid-template-columns:1fr}}

.vcard{text-align:left;cursor:pointer;color:var(--parch);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(0,0,0,.14)),var(--ink-2);
  border:2px solid var(--line);border-top:4px solid var(--accent,var(--gold));
  padding:20px 18px;box-shadow:var(--shadow);transition:transform .08s,border-color .12s}
.vcard:hover{transform:translateY(-3px);border-color:var(--accent,var(--gold))}
.vcard__top{display:flex;justify-content:center;margin-bottom:6px}
.vcard__spr{width:70px;height:70px;background:#0f0a12;border:2px solid var(--line);padding:6px}
.vcard__name{font-family:var(--f-head);font-size:22px;text-align:center;margin-top:8px}
.vcard__title{font-family:var(--f-pixel);font-size:11px;letter-spacing:1px;text-transform:uppercase;
  color:var(--accent,var(--gold));text-align:center;margin-top:3px}
.vcard__blurb{color:var(--parch-2);font-size:14.5px;margin-top:12px;line-height:1.45}
.vcard__go{font-family:var(--f-head);font-size:14px;color:var(--gold);margin-top:14px}

/* -- board -- */
.board{display:grid;grid-template-columns:288px 1fr;gap:16px;align-items:start}
@media(max-width:820px){.board{grid-template-columns:1fr}}
.board__vendor{border-top:4px solid var(--accent,var(--gold));position:relative}
.board__back{position:absolute;top:12px;left:12px;background:none;border:0;cursor:pointer;
  font-family:var(--f-pixel);font-size:12px;letter-spacing:1px;color:var(--parch-2)}
.board__back:hover{color:var(--gold)}
.vend{text-align:center;padding-top:26px}
.vend__spr{width:112px;height:112px;background:#0f0a12;border:2px solid var(--line);padding:10px;margin:0 auto}
.vend__name{font-family:var(--f-head);font-size:26px;margin-top:12px}
.vend__title{font-family:var(--f-pixel);font-size:12px;letter-spacing:1px;color:var(--accent,var(--gold));text-transform:uppercase;margin-top:4px}
.vend__mood{font-family:var(--f-mono);font-size:14px;color:var(--gold);margin-top:14px;
  border:2px solid var(--line);padding:8px 10px;display:inline-block}
.vend__hint{color:var(--parch-2);font-size:14px;margin-top:14px;line-height:1.5}

.board__main{display:flex;flex-direction:column;gap:16px;min-width:0}

.deal__row{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.deal__item{width:76px;height:76px;background:#0f0a12;border:2px solid var(--line);padding:6px}
.deal__info{flex:1;min-width:160px}
.deal__name{font-family:var(--f-head);font-size:24px;color:var(--parch)}
.deal__tier{font-size:12px;letter-spacing:.5px;color:var(--parch-2);margin-top:4px}
.deal__tag{font-size:22px}
.deal__tag .now{font-size:24px}

.meter{position:relative;height:22px;background:#0f0a12;border:2px solid var(--line-soft);margin-top:12px;overflow:hidden}
.meter__fill{position:absolute;inset:0 auto 0 0;width:100%;background:var(--ember);transition:width .4s ease,background .3s}
.meter__lab{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-pixel);font-size:11px;letter-spacing:1px;color:#0d0a12;mix-blend-mode:luminosity}

.chat{height:min(46vh,380px);overflow:hidden;padding:0}
.chat__log{height:100%;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:16px}
.msg{max-width:82%;padding:10px 13px;font-size:15.5px;line-height:1.45;border:2px solid var(--line-soft)}
.msg--vendor{align-self:flex-start;background:#241726;border-bottom-left-radius:0}
.msg--you{align-self:flex-end;background:#123018;border-color:#2b5c30;color:#eaf6d4;border-bottom-right-radius:0}
.msg__who{display:block;font-size:10px;letter-spacing:1px;opacity:.65;margin-bottom:3px}

.inp{display:flex;flex-direction:column;gap:10px}
.inp__chips{display:flex;flex-wrap:wrap;gap:8px}
.qchip{cursor:pointer;font-family:var(--f-pixel);font-size:12px;letter-spacing:.5px;color:var(--parch);
  background:rgba(255,255,255,.04);border:2px solid var(--line-soft);padding:8px 11px;transition:.12s}
.qchip:hover{border-color:var(--gold);color:var(--gold)}
.inp__row{display:flex;gap:10px}
.inp__field{flex:1;min-width:0;font-family:var(--f-body);font-size:16px;color:var(--parch);
  background:#0f0a12;border:2px solid var(--line);padding:14px 14px}
.inp__field:focus{outline:none;border-color:var(--gold)}

/* -- end overlay -- */
.over{margin-top:4px;text-align:center;border-top:4px solid var(--green)}
.over__stamp{font-size:34px;margin-bottom:8px}
.over__price{display:flex;gap:12px;align-items:baseline;justify-content:center;margin-top:6px}
.over__now{font-family:var(--f-display);font-size:44px;color:var(--gold);
  text-shadow:0 3px 0 var(--gold-deep)}
.over__was{font-family:var(--f-mono);color:var(--parch-2);text-decoration:line-through;font-size:18px}
.over__disc{font-family:var(--f-head);font-size:20px;color:var(--green);margin-top:8px}
.over__line{color:var(--parch-2);max-width:44ch;margin:12px auto 0;line-height:1.5}
.over__btns{margin-top:20px;justify-content:center}
.over__copied{margin-top:12px;font-size:12px;letter-spacing:1px;color:var(--green)}

/* ================= DASHBOARD =========================================== */
.d-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
@media(max-width:720px){.d-tiles{grid-template-columns:1fr}}
.d-tile{text-align:left}
.d-tile__label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--parch-2)}
.d-tile__big{font-family:var(--f-display);font-size:clamp(34px,5vw,50px);color:var(--gold);line-height:1;margin-top:8px;
  text-shadow:0 3px 0 var(--gold-deep)}
.d-tile__sub{color:var(--parch-2);font-size:14px;margin-top:8px}

.d-you{margin-bottom:16px;border-top:4px solid var(--gold)}
.d-you__head{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:18px}
.d-you__handle{display:flex;gap:8px;align-items:center}
.d-handle{font-family:var(--f-mono);font-size:15px;color:var(--parch);background:#0f0a12;
  border:2px solid var(--line);padding:9px 12px;width:180px;max-width:46vw}
.d-handle:focus{outline:none;border-color:var(--gold)}
.d-handle__save{padding:9px 14px;font-size:14px}
.d-you__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:640px){.d-you__grid{grid-template-columns:repeat(2,1fr)}}
.d-you__stat{background:#0f0a12;border:2px solid var(--line-soft);padding:16px 14px;text-align:center}
.d-you__big{font-family:var(--f-head);font-size:26px;color:var(--parch)}
.d-you__lab{font-size:11px;letter-spacing:.5px;color:var(--parch-2);margin-top:6px}

.d-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
@media(max-width:860px){.d-cols{grid-template-columns:1fr}}
.d-panel__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.d-sub{font-family:var(--f-pixel);font-size:11px;letter-spacing:1px;color:var(--parch-2)}

.lb{display:flex;flex-direction:column}
.lb__empty{color:var(--parch-2);padding:14px 0;font-size:15px}
.lb__row{display:grid;grid-template-columns:26px 30px 1fr auto auto;gap:10px;align-items:center;
  padding:11px 0;border-bottom:1px solid var(--line-soft)}
.lb__row:last-child{border-bottom:0}
.lb__row--me{background:rgba(255,207,74,.06);margin-inline:-10px;padding-inline:10px}
.lb__rank{font-family:var(--f-display);font-size:18px;color:var(--gold-deep);text-align:center}
.lb__spr{width:26px;height:26px}
.lb__who{font-family:var(--f-head);font-size:15px;color:var(--parch);min-width:0;overflow:hidden;text-overflow:ellipsis}
.lb__item{display:block;font-family:var(--f-pixel);font-size:10px;letter-spacing:.5px;color:var(--parch-2)}
.lb__price{font-size:13px;color:var(--parch-2);white-space:nowrap}
.lb__price s{opacity:.55;margin-left:4px}
.lb__disc{font-family:var(--f-head);font-size:15px;white-space:nowrap}
.lb__disc--hi{color:var(--green)} .lb__disc--mid{color:var(--gold)} .lb__disc--lo{color:var(--ember)}

.feed{display:flex;flex-direction:column}
.feed__row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.feed__row:last-child{border-bottom:0}
.feed__spr{width:34px;height:34px;background:#0f0a12;border:2px solid var(--line-soft);padding:3px}
.feed__mid{flex:1;min-width:0}
.feed__t{font-size:14.5px;color:var(--parch)}
.feed__i{font-family:var(--f-pixel);font-size:10px;letter-spacing:.5px;color:var(--parch-2);margin-top:2px}
.feed__r{text-align:right;white-space:nowrap}
.feed__p{font-size:13px;color:var(--parch-2)}
.feed__p s{opacity:.55;margin-left:4px}
.feed__d{font-family:var(--f-head);font-size:14px}
.feed__ago{font-family:var(--f-pixel);font-size:9px;letter-spacing:.5px;color:var(--stone);margin-top:2px}
