@font-face {
  font-family: 'Fontin';
  src: url('fontin_pc/Fontin-Regular.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'Fontin';
  src: url('fontin_pc/Fontin-Bold.otf') format('opentype');
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: 'Fontin';
  src: url('fontin_pc/Fontin-Italic.otf') format('opentype');
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: 'Fontin SmallCaps';
  src: url('fontin_pc/Fontin-SmallCaps.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:       #0d0d0d;
  --bg2:      #141410;
  --bg3:      #1c1c16;
  --border:   #2e2e22;
  --gold:     #c8a860;
  --gold-dim: #7a6030;
  --text:     #c8b99a;
  --text-dim: #7a6a4a;
  --green:    #a5f3a5;
  --green-dim:#3a6a3a;
  --red:      #e87070;
  --red-dim:  #6a2020;
  --blue:     #70aae8;
  --purple:   #b070e8;
  --teal:     #70e8c8;
}

html, body { height: 100%; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Fontin', 'Georgia', serif;
  font-size: 14px;
  line-height: 1.5;
  display: flex;
  flex-direction: column;
}

/* ── Header ── */
#header {
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  padding: 0.6rem 1.2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
}
#header-logo { height: 36px; width: auto; flex-shrink: 0; }
#header h1 { font-size: 1.1rem; color: var(--gold); letter-spacing: 0.06em; flex: 1; }
#header-nav { display: flex; gap: 0.5rem; flex-shrink: 0; }
#header-nav a {
  color: var(--text-dim); text-decoration: none;
  font-size: 0.82rem; padding: 0.25rem 0.6rem;
  border: 1px solid var(--border); border-radius: 2px;
  transition: color 0.2s, border-color 0.2s;
}
#header-nav a:hover { color: var(--gold); border-color: var(--gold-dim); }
#status-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--red-dim); border: 1px solid var(--red);
  flex-shrink: 0; transition: background 0.3s, border-color 0.3s;
}
#status-dot.connected { background: var(--green-dim); border-color: var(--green); }
#status-dot.connecting { background: #6a5a20; border-color: var(--gold); animation: blink 1s step-end infinite; }
@keyframes blink { 50% { opacity: 0.3; } }
#status-text { font-size: 0.8rem; color: var(--text-dim); }
#btn-reconnect {
  background: none; border: 1px solid var(--gold-dim);
  color: var(--gold); font-family: inherit; font-size: 0.78rem;
  padding: 0.2rem 0.6rem; cursor: pointer; border-radius: 2px;
  transition: border-color 0.2s, color 0.2s;
}
#btn-reconnect:hover { border-color: var(--gold); color: #e8c880; }

/* ── Connect Panel ── */
#connect-panel {
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  padding: 1rem 1.2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: flex-end;
}
#connect-panel.hidden { display: none; }
.field { display: flex; flex-direction: column; gap: 0.25rem; }
.field label { font-size: 0.72rem; color: var(--text-dim); letter-spacing: 0.05em; text-transform: uppercase; }
.field input {
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--text); font-family: monospace; font-size: 0.85rem;
  padding: 0.35rem 0.6rem; outline: none; border-radius: 2px;
  transition: border-color 0.2s;
}
.field input:focus { border-color: var(--gold-dim); }
#f-server { width: 220px; }
#f-slot   { width: 140px; }
#f-pass   { width: 130px; }
#btn-connect {
  background: #1c1c10; border: 1px solid var(--gold-dim);
  color: var(--gold); font-family: inherit; font-size: 0.88rem;
  padding: 0.35rem 1rem; cursor: pointer; border-radius: 2px;
  transition: background 0.2s, border-color 0.2s;
}
#btn-connect:hover { background: #2a2a14; border-color: var(--gold); }
#connect-error { font-size: 0.8rem; color: var(--red); align-self: center; }

/* ── Tabs ── */
#tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
  flex-shrink: 0;
}
.tab-btn {
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--text-dim); font-family: inherit; font-size: 0.85rem;
  padding: 0.55rem 1.1rem; cursor: pointer; letter-spacing: 0.04em;
  transition: color 0.2s, border-color 0.2s;
}
.tab-btn:hover { color: var(--text); }
.tab-btn.active { color: var(--gold); border-bottom-color: var(--gold); }
.tab-badge {
  display: inline-block; background: var(--bg3);
  color: var(--text-dim); font-size: 0.68rem;
  padding: 0 0.35rem; border-radius: 8px; margin-left: 0.3rem;
}

/* ── Main Content ── */
#content {
  flex: 1; overflow-y: auto;
  padding: 1rem 1.2rem;
}
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* ── Overview ── */
#overview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.2rem;
}
.stat-card {
  background: var(--bg2); border: 1px solid var(--border);
  padding: 0.75rem 1rem; border-radius: 2px;
}
.stat-card .label { font-size: 0.7rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.05em; }
.stat-card .value { font-size: 1.5rem; color: var(--gold); font-weight: bold; }
.stat-card .sub { font-size: 0.75rem; color: var(--text-dim); }

#slot-info {
  background: var(--bg2); border: 1px solid var(--border);
  padding: 0.75rem 1rem; margin-bottom: 1.2rem; border-radius: 2px;
}
#slot-info table { border-collapse: collapse; }
#slot-info td { padding: 0.2rem 1rem 0.2rem 0; font-size: 0.85rem; }
#slot-info td:first-child { color: var(--text-dim); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.04em; width: 100px; }

/* ── Messages ── */
#messages-feed {
  background: var(--bg2); border: 1px solid var(--border);
  padding: 0.5rem; max-height: 220px; overflow-y: auto;
  font-family: monospace; font-size: 0.78rem; border-radius: 2px;
}
.msg-line { padding: 0.15rem 0; border-bottom: 1px solid #1a1a12; }
.msg-line:last-child { border-bottom: none; }
.msg-time { color: var(--text-dim); margin-right: 0.4rem; }
.msg-item { color: var(--teal); }
.msg-hint { color: var(--purple); }
.msg-chat { color: var(--text); }
.msg-system { color: var(--gold-dim); font-style: italic; }

/* ── Items sort bar ── */
.sort-bar {
  display: flex; align-items: center; gap: 0.4rem;
  margin-bottom: 0.75rem; font-size: 0.78rem; color: var(--text-dim);
}
.sort-btn {
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--text-dim); font-family: inherit; font-size: 0.75rem;
  padding: 0.2rem 0.55rem; cursor: pointer; border-radius: 2px;
  transition: border-color 0.2s, color 0.2s;
}
.sort-btn.active { border-color: var(--gold-dim); color: var(--gold); }
.sort-btn:hover { border-color: var(--gold-dim); }

/* ── Class cards ── */
.class-section-header {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.3rem 0; margin-bottom: 0.6rem;
  border-bottom: 1px solid var(--border);
  cursor: pointer; user-select: none;
}
.class-section-header h3 { font-size: 0.82rem; color: var(--gold); letter-spacing: 0.06em; text-transform: uppercase; }
.class-section-header .cat-count { font-size: 0.72rem; color: var(--text-dim); }
.class-section-header .collapse-icon { color: var(--text-dim); font-size: 1.6rem; transition: transform 0.2s; flex-shrink: 0; }
.class-section-header.collapsed .collapse-icon { transform: rotate(-90deg); }
.class-section-header.collapsed + .class-rows { display: none; }
.class-rows { display: flex; flex-direction: row; gap: 20px; align-items: flex-start; margin-bottom: 1.2rem; }
.class-rows.collapsed { display: none; }
.class-col  { display: flex; flex-direction: column; gap: 0.4rem; }
.class-row  { display: flex; flex-wrap: wrap; gap: 0.35rem; align-items: flex-start; }
.class-card {
  display: flex; flex-direction: column; align-items: center; gap: 0.2rem;
  background: var(--bg3); border: 1px solid var(--border);
  padding: 0.4rem 0.3rem; border-radius: 3px; width: 68px;
  font-size: 0.65rem; text-align: center; color: var(--text-dim);
  transition: border-color 0.2s;
}
.class-card img { width: 44px; height: 44px; object-fit: contain; opacity: 0.25; filter: grayscale(1); transition: opacity 0.2s, filter 0.2s; }
.class-card.received img  { opacity: 1; filter: none; }
.class-card.received.base { border-color: #4a2a10; color: #e08858; }
.class-card.received.asc  { border-color: #4a2a10; color: var(--gold); }

/* ── Items Tab ── */
.cat-section { margin-bottom: 1.2rem; }
.cat-header {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.3rem 0; margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
  cursor: pointer; user-select: none;
}
.cat-header h3 { font-size: 0.82rem; color: var(--gold); letter-spacing: 0.06em; text-transform: uppercase; }
.cat-header .cat-count { font-size: 0.72rem; color: var(--text-dim); }
.cat-header .collapse-icon { color: var(--text-dim); font-size: 1.6rem; transition: transform 0.2s; flex-shrink: 0; }
.cat-header.collapsed .collapse-icon { transform: rotate(-90deg); }
.cat-header.collapsed + .cat-body { display: none; }
.cat-body { display: flex; flex-wrap: wrap; gap: 0.3rem; }
.cat-body.collapsed { display: none; }
.item-tag {
  display: inline-flex; align-items: center; gap: 0.3rem;
  background: var(--bg3); border: 1px solid var(--border);
  padding: 0.15rem 0.4rem 0.15rem 0.2rem; border-radius: 2px;
  font-size: 0.78rem; color: var(--text);
}
.item-tag .item-count {
  background: var(--bg2); color: var(--gold);
  font-size: 0.68rem; padding: 0 0.3rem; border-radius: 8px;
}
.item-img {
  width: 22px; height: 22px; object-fit: contain;
  image-rendering: pixelated; flex-shrink: 0;
}
.item-tag:not(.gem):not(.support):not(.util):not(.class) .item-img {
  width: 44px; height: 44px;
}
.item-level {
  background: var(--bg2); color: var(--text-dim);
  font-size: 0.65rem; padding: 0 0.25rem; border-radius: 8px; margin-left: 0.1rem;
}
.item-tag.gem    { border-color: #2a5a2a; color: var(--green); }
.item-tag.support { border-color: #5a2a2a; color: var(--red); }
.item-tag.util   { border-color: #1a3a5a; color: var(--blue); }
.item-tag.flask  { border-color: #4a3a10; color: #e8c860; }
.item-tag.class  { border-color: #4a2a10; color: var(--red); }
.item-tag.weapon { border-color: #3a2a10; color: #c8a870; }
.item-tag.armour { border-color: #2a3a4a; color: var(--teal); }

/* ── Locations Tab ── */
.act-section { margin-bottom: 0.75rem; }
.act-header {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.4rem 0.6rem; background: var(--bg2);
  border: 1px solid var(--border); cursor: pointer;
  border-radius: 2px; user-select: none;
}
.act-header h3 { font-size: 0.82rem; color: var(--gold); flex: 1; }
.act-progress { font-size: 0.75rem; color: var(--text-dim); white-space: nowrap; }
.act-toggle { color: var(--text-dim); font-size: 1.6rem; flex-shrink: 0; transition: transform 0.2s; }
.act-header.collapsed .act-toggle { transform: rotate(-90deg); }
.act-header.collapsed + .act-locations { display: none; }
.act-bar-wrap { flex: 1; background: var(--bg3); height: 6px; border-radius: 3px; overflow: hidden; min-width: 80px; }
.act-bar { height: 100%; background: var(--green-dim); border-radius: 3px; transition: width 0.4s; }
.act-bar.complete { background: var(--green); }
.act-locations {
  background: var(--bg2); border: 1px solid var(--border);
  border-top: none; padding: 0.4rem;
  display: flex; flex-wrap: wrap; gap: 0.25rem;
}
.loc-tag {
  font-size: 0.7rem; padding: 0.15rem 0.4rem;
  border-radius: 2px; border: 1px solid var(--border);
  color: var(--text-dim);
}
.loc-tag.checked   { color: var(--green-dim); text-decoration: line-through; border-color: var(--green-dim); }
.loc-tag.unchecked { color: var(--text); border-color: var(--border); }
.loc-tag.unknown   { color: var(--text-dim); }

/* ── Hints Tab ── */
#hints-table-wrap { overflow-x: auto; }
#hints-table {
  width: 100%; border-collapse: collapse; font-size: 0.8rem;
}
#hints-table th {
  background: var(--bg2); color: var(--text-dim);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em;
  padding: 0.4rem 0.6rem; text-align: left;
  border-bottom: 1px solid var(--border);
}
#hints-table td { padding: 0.35rem 0.6rem; border-bottom: 1px solid var(--border); }
#hints-table tr:hover td { background: var(--bg2); }
#hints-table .hint-item { color: var(--teal); }
#hints-table .hint-loc { color: var(--text-dim); }
#hints-table .hint-found { color: var(--green); }
#hints-table .hint-notfound { color: var(--text-dim); }
#hints-table .hint-sender { color: var(--gold-dim); }

/* ── Passive Points Bar ── */
.passive-bar-section {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--border);
}
.passive-bar-img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  flex-shrink: 0;
}
.passive-bar-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-dim);
}
.passive-bar-count {
  font-size: 0.82rem;
  color: var(--gold);
  font-weight: bold;
}
/* ── Empty states ── */
.empty-state {
  color: var(--text-dim); font-size: 0.85rem; font-style: italic;
  padding: 2rem; text-align: center;
}

/* ── Disconnected overlay ── */
#disconnected-msg {
  color: var(--text-dim); font-style: italic;
  padding: 3rem; text-align: center; font-size: 1rem;
}

/* ── Equipment Page ── */
.eq-grid {
  display: grid;
  grid-template-columns: 1.6fr 1.6fr 0.7fr 1fr 1fr 0.7fr 1.6fr 1.6fr;
  gap: 3px;
  max-width: 750px;
  margin: 0 auto;
  grid-template-areas:
    ". . . helmet helmet . . ."
    "weapon weapon . helmet helmet . offhand offhand"
    "weapon weapon . bodyarmour bodyarmour amulet offhand offhand"
    "weapon weapon ringleft bodyarmour bodyarmour ringright offhand offhand"
    ". gloves gloves bodyarmour bodyarmour boots boots ."
    ". gloves gloves belt belt boots boots ."
    ". flasks flasks flasks flasks flasks flasks .";
  padding: 0.5rem;
}
.eq-slot {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 3px; padding: 5px 3px;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 2px;
}
.eq-slot-title {
  font-size: 0.75rem; color: var(--gold-dim);
  text-transform: uppercase; letter-spacing: 0.04em; white-space: nowrap;
}
.eq-slot-img { width: 38px; height: 38px; object-fit: contain; }
[style*="grid-area:helmet"] .eq-slot-img { width: 50px; height: 50px; }
.eq-slot-fill .eq-slot-img { width: 106px; height: 170px; }
[style*="grid-area:offhand"] .eq-slot-img { width: 106px; height: 170px; }
.eq-slot-empty .eq-slot-img { filter: grayscale(1) opacity(0.2); }
.eq-rarity-row {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 0; font-size: 0.73rem; line-height: 1.5;
}
.eq-rarity-stack {
  display: flex; flex-direction: column; align-items: center;
  font-size: 0.73rem; line-height: 1.5; gap: 0;
}
.eq-rarity-sep { color: var(--border); }
.eq-rarity-off    { color: var(--text-dim); opacity: 0.4; font-weight: 600; }
.eq-rarity-normal { color: #e8e8e8; font-weight: 600; }
.eq-rarity-magic  { color: #8888ff; font-weight: 600; }
.eq-rarity-rare   { color: #f0e040; font-weight: 600; }
.eq-rarity-unique { color: #c06020; font-weight: 600; }
.eq-links { display: flex; flex-direction: column; align-items: center; gap: 1px; margin-top: 4px; }
.eq-links-label { font-size: 0.68rem; color: var(--text-dim); }
.eq-link-row { display: flex; align-items: center; flex-wrap: wrap; justify-content: center; }
.eq-link-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #1e2e1e; border: 1px solid #334433;
  display: inline-block; flex-shrink: 0;
}
.eq-link-dot.lit { background: #4a8a4a; border-color: #6aaa6a; }
.eq-link-conn { width: 5px; height: 2px; background: #334433; display: inline-block; flex-shrink: 0; }
.eq-link-conn.lit { background: #5a9a5a; }
.eq-sub-list { display: flex; flex-direction: column; gap: 0.6rem; width: 100%; padding: 2px 6px; box-sizing: border-box; }
.eq-sub-row  { display: flex; align-items: flex-start; gap: 6px; font-size: 0.68rem; }
.eq-sub-label { color: var(--text); flex-shrink: 0; min-width: 3.8rem; text-align: left; font-size: 1.1rem; }
.eq-flask-row { display: flex; gap: 3px; grid-area: flasks; }
.eq-flask-row .eq-slot { flex: 1; }
.eq-rarity-2col {
  display: grid;
  grid-template-columns: minmax(2.8rem, 1fr) auto minmax(2.8rem, 1fr);
  gap: 0 3px; align-content: start;
}
.eq-slot-fill .eq-rarity-2col,
[style*="grid-area:offhand"] .eq-sub-list { margin-top: auto; }
.eq-slot-fill .eq-slot-img,
[style*="grid-area:offhand"] .eq-slot-img { margin-top: auto; }

/* ── Medium: 2-col classes ── */
@media (max-width: 948px) {
  .class-rows { flex-wrap: wrap; }
  .class-col { flex: 0 0 calc(50% - 10px); }
}

/* ── Mobile ── */
@media (max-width: 660px) {
  /* Header */
  #header { padding: 0.4rem 0.75rem; gap: 0.5rem; }
  #header h1 { font-size: 0.82rem; }
  #header-logo { height: 26px; }
  #status-text { font-size: 0.72rem; max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

  /* Connect panel — stack vertically, full-width inputs */
  #connect-panel { flex-direction: column; align-items: stretch; padding: 0.75rem; }
  #f-server, #f-slot, #f-pass { width: 100%; }
  #btn-connect { width: 100%; margin-top: 0.1rem; }
  #connect-error { text-align: center; }

  /* Tabs — horizontal scroll, no scrollbar */
  #tabs { overflow-x: auto; scrollbar-width: none; }
  #tabs::-webkit-scrollbar { display: none; }
  .tab-btn { padding: 0.5rem 0.7rem; font-size: 0.78rem; white-space: nowrap; flex-shrink: 0; }

  /* Content padding */
  #content { padding: 0.6rem 0.75rem; }

  /* Overview */
  #overview-grid { grid-template-columns: 1fr 1fr; gap: 0.5rem; }
  .stat-card .value { font-size: 1.2rem; }

  /* Classes — stack columns vertically */
  .class-rows { flex-direction: column; gap: 0.75rem; }
  .class-col { width: 100%; }
  .class-card { width: 60px; font-size: 0.6rem; padding: 0.3rem 0.2rem; }
  .class-card img { width: 36px; height: 36px; }

  /* Items — shrink non-gem images back down */
  .item-tag:not(.gem):not(.support):not(.util):not(.class) .item-img { width: 28px; height: 28px; }

  /* Equipment — reflow grid into 2 columns, flasks at bottom */
  .eq-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "helmet     helmet"
      "weapon     offhand"
      "bodyarmour bodyarmour"
      "belt       amulet"
      "ringleft   ringright"
      "gloves     boots"
      "flasks     flasks";
    max-width: 100%;
    padding: 0.25rem;
  }
  .eq-slot-img { width: 30px; height: 30px; }
  [style*="grid-area:helmet"] .eq-slot-img { width: 38px; height: 38px; }
  .eq-slot-fill .eq-slot-img { width: 56px; height: 90px; margin-top: 0; }
  [style*="grid-area:offhand"] .eq-slot-img { width: 56px; height: 90px; margin-top: 0; }
  .eq-slot-fill .eq-rarity-2col,
  [style*="grid-area:offhand"] .eq-sub-list { margin-top: 0; }
  .eq-slot-title { font-size: 0.65rem; }
  .eq-sub-label { font-size: 0.85rem; }
  .eq-rarity-2col { font-size: 0.62rem; }
  .eq-flask-row { gap: 2px; }

  /* Hints table — keep horizontal scroll, shrink text */
  #hints-table { font-size: 0.72rem; }
  #hints-table th, #hints-table td { padding: 0.2rem 0.35rem; }
}

/* ── Narrow mobile: 2-row tab grid ── */
@media (max-width: 472px) {
  #tabs { overflow-x: unset; flex-wrap: wrap; }
  .tab-btn {
    flex: 1 0 30%;
    white-space: normal;
    text-align: center;
    font-size: 0.72rem;
    padding: 0.45rem 0.3rem;
    border-bottom: 2px solid transparent;
    border-top: 1px solid var(--border);
  }
  .tab-btn:first-child,
  .tab-btn:nth-child(2),
  .tab-btn:nth-child(3) { border-top: none; }
}
