html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

.shell,
.panel,
.panel * {
  min-width: 0;
}

.link-pills {
  max-width: 100%;
}

.item-pill,
.spell-pill,
.consume-pill,
.gem-pill,
.enchant-pill {
  max-width: 100%;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
  line-height: 1.25;
  flex-wrap: wrap;
}

.easy-fix-rollup .rollup-card-link {
  align-items: flex-start;
  justify-content: flex-start;
  gap: 6px;
  white-space: normal;
  overflow-wrap: anywhere;
}

.easy-fix-rollup .rollup-card-link strong,
.easy-fix-rollup .rollup-card-link span {
  min-width: 0;
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
}

.tank-sim-baseline-note {
  grid-column: 1 / -1;
  align-self: end;
}

.roster-board {
  display: grid;
  gap: 12px;
}

.roster-card {
  position: relative;
  display: grid;
  grid-template-columns:
    minmax(180px, 1.35fr)
    minmax(90px, .55fr)
    minmax(110px, .65fr)
    minmax(220px, 1.45fr)
    minmax(190px, 1.15fr);
  gap: 12px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel2);
  padding: 14px;
  overflow: visible;
}

.roster-name {
  font-weight: 900;
  color: var(--text);
  overflow-wrap: anywhere;
}

.roster-metric label {
  display: block;
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.roster-metric strong {
  display: block;
  overflow-wrap: anywhere;
}

.roster-opportunity {
  position: relative;
  display: grid;
  gap: 5px;
  align-content: start;
}

.opportunity-main {
  color: var(--accent2);
  font-weight: 900;
  overflow-wrap: anywhere;
}

.opportunity-above_sim .opportunity-main {
  color: var(--ok);
}

.opportunity-summary {
  color: var(--muted);
  font-size: .88rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.opportunity-trigger {
  justify-self: start;
  background: rgba(255, 255, 255, .06);
  border: 1px solid var(--line);
  color: var(--text);
  padding: 5px 9px;
  border-radius: 999px;
  font-size: .78rem;
}

.opportunity-popover {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  width: min(420px, calc(100vw - 48px));
  max-width: min(420px, calc(100vw - 48px));
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #0b111a;
  color: var(--text);
  box-shadow: 0 18px 50px rgba(0, 0, 0, .45);
  padding: 14px;
  z-index: 30;
  white-space: normal;
  overflow-wrap: anywhere;
  display: none;
}

.opportunity-popover dl {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
}

.opportunity-popover div {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 8px;
}

.opportunity-popover dt {
  color: var(--muted);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.opportunity-popover dd {
  margin: 0;
  line-height: 1.35;
}

.roster-opportunity:hover .opportunity-popover,
.roster-opportunity:focus-within .opportunity-popover {
  display: block;
}

.roster-status {
  display: grid;
  gap: 7px;
  line-height: 1.35;
}

.repair-card-list,
.repair-group-list {
  display: grid;
  gap: 14px;
}

.repair-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel2);
  padding: 14px;
  overflow-wrap: anywhere;
}

.repair-card-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.repair-card-head h2,
.repair-card-head h3 {
  margin: 8px 0 4px;
}

.repair-detail-grid {
  display: grid;
  grid-template-columns: minmax(140px, .7fr) minmax(100px, .45fr) minmax(170px, .8fr) minmax(240px, 1.4fr);
  gap: 12px;
}

.repair-detail-grid label,
.job-card label,
.job-detail-grid label {
  display: block;
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.suffix-repair-list {
  display: grid;
  gap: 10px;
}

.suffix-repair-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(220px, 1.2fr);
  gap: 12px;
  align-items: start;
}

.suffix-select-wrap select,
.filter-row select,
.gear-suffix-control select {
  max-width: 100%;
}

.jobs-card-list {
  display: grid;
  gap: 10px;
}

.audit-result-list,
.roster-directory {
  display: grid;
  gap: 12px;
}

.audit-result-card,
.roster-directory-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel2);
  padding: 12px;
  overflow-wrap: anywhere;
}

.audit-result-head,
.roster-directory-card {
  display: grid;
  grid-template-columns: minmax(180px, 1.2fr) minmax(180px, 1fr) minmax(100px, .5fr);
  gap: 12px;
  align-items: start;
}

.audit-result-head {
  grid-template-columns: minmax(180px, 1fr) auto;
  margin-bottom: 10px;
}

.audit-result-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
  margin: 10px 0;
}

.audit-result-grid label,
.roster-directory-card label {
  display: block;
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.job-card {
  display: grid;
  grid-template-columns: minmax(90px, .45fr) minmax(150px, .7fr) minmax(90px, .45fr) minmax(170px, .7fr) minmax(240px, 1.6fr);
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel2);
  padding: 12px;
  overflow-wrap: anywhere;
}

.batch-toolbar,
.batch-report-row,
.batch-order-preview li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.batch-toolbar {
  margin-bottom: 12px;
}

.batch-order-preview {
  display: grid;
  gap: 8px;
  margin: 0 0 14px;
  padding-left: 0;
  list-style: none;
}

.batch-order-preview li {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, .04);
  padding: 10px;
}

.batch-order-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.batch-order-actions button {
  padding: 7px 9px;
  border-radius: 10px;
}

.batch-report-check {
  justify-content: flex-start;
  min-width: 160px;
}

.job-error-text,
.debug-pre,
pre,
.logbox {
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.job-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 12px 0;
}

#fight-review tr {
  grid-template-areas:
    "fight fight fight type duration active"
    "actual deaths pots package sim delta"
    "confidence confidence confidence recommendation recommendation recommendation";
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

#fight-review td[data-label="Fight"] { grid-area: fight; }
#fight-review td[data-label="Type"] { grid-area: type; }
#fight-review td[data-label="Duration"] { grid-area: duration; }
#fight-review td[data-label="Actual DPS"],
#fight-review td[data-label="Actual HPS"] { grid-area: actual; }
#fight-review td[data-label="Active"] { grid-area: active; }
#fight-review td[data-label="Deaths"] { grid-area: deaths; }
#fight-review td[data-label="Pots"] { grid-area: pots; }
#fight-review td[data-label="Best sim package"] { grid-area: package; }
#fight-review td[data-label="Best sim"] { grid-area: sim; }
#fight-review td[data-label="Delta"] { grid-area: delta; }
#fight-review td[data-label="Confidence"] { grid-area: confidence; }
#fight-review td[data-label="Recommendation"] { grid-area: recommendation; }

#gear .table-wrap,
#consumables .table-wrap,
#fight-review .table-wrap {
  overflow: visible;
}

#gear table,
#gear thead,
#gear tbody,
#gear tr,
#gear th,
#gear td,
#consumables table,
#consumables thead,
#consumables tbody,
#consumables tr,
#consumables th,
#consumables td,
#fight-review table,
#fight-review thead,
#fight-review tbody,
#fight-review tr,
#fight-review th,
#fight-review td {
  display: block;
  width: 100%;
}

#gear thead,
#consumables thead,
#fight-review thead {
  display: none;
}

#gear tbody,
#consumables tbody,
#fight-review tbody {
  display: grid;
  gap: 12px;
}

#gear tr,
#consumables tr,
#fight-review tr {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel2);
  padding: 12px;
}

#gear tr {
  grid-template-columns: minmax(90px, .5fr) minmax(220px, 1.4fr) minmax(150px, 1fr) minmax(170px, 1fr) minmax(120px, .8fr) minmax(150px, 1fr);
}

#consumables tr {
  grid-template-columns: minmax(160px, 1fr) minmax(220px, 1.35fr) repeat(3, minmax(90px, .55fr)) minmax(180px, 1.2fr) minmax(110px, .7fr);
}

#gear td,
#consumables td,
#fight-review td {
  white-space: normal;
  border: 0;
  padding: 0;
  overflow-wrap: anywhere;
}

.sim-announcement-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 28px;
  border-bottom: 1px solid rgba(255, 176, 32, .35);
  background: rgba(255, 176, 32, .14);
  color: var(--text);
  position: relative;
  z-index: 4;
}

.sim-announcement-bar.is-hidden {
  display: none;
}

.sim-announcement-bar div {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.sim-announcement-bar strong,
.sim-announcement-bar span {
  overflow-wrap: anywhere;
}

.sim-announcement-bar a {
  flex: 0 0 auto;
  border: 1px solid rgba(255, 176, 32, .55);
  border-radius: 999px;
  padding: 6px 10px;
  color: var(--text);
}

#gear td::before,
#consumables td::before,
#fight-review td::before {
  content: attr(data-label);
  display: block;
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

@media (max-width: 1100px) {
  .roster-card {
    grid-template-columns: minmax(160px, 1.2fr) repeat(2, minmax(90px, .6fr)) minmax(190px, 1.2fr);
  }

  .roster-status {
    grid-column: 1 / -1;
  }

  #gear tr,
  #consumables tr,
  #fight-review tr {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #fight-review tr {
    grid-template-areas:
      "fight fight"
      "type duration"
      "actual active"
      "deaths pots"
      "package package"
      "sim delta"
      "confidence confidence"
      "recommendation recommendation";
  }

  .repair-detail-grid,
  .job-card {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .topbar {
    height: auto;
    min-height: 68px;
    align-items: flex-start;
    gap: 10px;
    flex-direction: column;
    padding: 12px 14px;
  }

  nav {
    flex-wrap: wrap;
    gap: 6px;
    width: 100%;
  }

  nav a,
  nav button {
    font-size: .8rem;
  }

  .sim-announcement-bar {
    align-items: flex-start;
    flex-direction: column;
    padding: 12px 14px;
  }

  .roster-card,
  .easy-fix-rollup .split,
  #gear tr,
  #consumables tr,
  #fight-review tr {
    grid-template-columns: 1fr;
  }

  .easy-fix-rollup .summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .easy-fix-rollup .rollup-card-link {
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
  }

  #fight-review tr {
    grid-template-areas:
      "fight"
      "type"
      "duration"
      "actual"
      "active"
      "deaths"
      "pots"
      "package"
      "sim"
      "delta"
      "confidence"
      "recommendation";
  }

  .repair-card-head,
  .suffix-repair-row,
  .repair-detail-grid,
  .audit-result-head,
  .roster-directory-card,
  .job-card,
  .job-detail-grid,
  .batch-toolbar,
  .batch-report-row,
  .batch-order-preview li {
    grid-template-columns: 1fr;
    display: grid;
  }

  .opportunity-popover {
    left: 0;
    right: auto;
    width: min(360px, calc(100vw - 40px));
  }

  .opportunity-popover div {
    grid-template-columns: 1fr;
  }

  .panel-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .actions,
  .inline-form {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    width: 100%;
  }

  .inline-form label,
  .inline-form input,
  .inline-form button {
    width: 100%;
  }

  .check {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    overflow-wrap: anywhere;
  }

  .check input {
    width: auto;
  }

  .hero {
    border-radius: 16px;
    padding: 20px;
  }
}
