:root {
  color-scheme: dark;
  --bg: #11140f;
  --panel: #1c2119;
  --panel-2: #252b20;
  --ink: #f3efe2;
  --muted: #b8b09a;
  --line: rgba(243, 239, 226, 0.16);
  --accent: #d8a844;
  --accent-2: #6bb6a6;
  --danger: #d96c58;
  --good: #87c66a;
  --shadow: rgba(0, 0, 0, 0.35);
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-width: 320px;
  background:
    radial-gradient(circle at 16% 8%, rgba(216, 168, 68, 0.18), transparent 25rem),
    linear-gradient(135deg, #10140f 0%, #20251c 48%, #2a201c 100%);
  color: var(--ink);
}

button {
  border: 0;
  border-radius: 6px;
  color: inherit;
  cursor: pointer;
  font: inherit;
  min-height: 42px;
  padding: 0.7rem 0.95rem;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.app-shell {
  min-height: 100vh;
}

.hero {
  display: grid;
  min-height: 34vh;
  overflow: hidden;
  position: relative;
}

.hero__backdrop {
  background:
    linear-gradient(90deg, rgba(17, 20, 15, 0.86), rgba(17, 20, 15, 0.18)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1400 520'%3E%3Cdefs%3E%3ClinearGradient id='s' x1='0' x2='1'%3E%3Cstop stop-color='%23252b20'/%3E%3Cstop offset='1' stop-color='%235a4331'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect fill='url(%23s)' width='1400' height='520'/%3E%3Cpath fill='%2311140f' d='M0 387l84-68 74 38 90-112 103 92 76-62 93 94 88-152 99 125 84-74 73 61 97-144 89 138 74-41 98 100 78-52 100 67v123H0z'/%3E%3Cpath fill='%232d5e55' opacity='.72' d='M0 421l94-42 94 23 83-58 98 54 98-22 83 42 89-70 91 56 92-31 82 45 91-55 99 48 74-25 132 42v92H0z'/%3E%3Cpath fill='%23d8a844' opacity='.48' d='M1042 100c44 10 87 31 118 62-49-13-98-11-146 5 36-38 34-37 28-67z'/%3E%3Cpath fill='%23f3efe2' opacity='.35' d='M1148 147c44-6 82 3 116 24-44 4-75 18-107 45 10-31 9-47-9-69z'/%3E%3Ccircle cx='235' cy='98' r='42' fill='%23d8a844' opacity='.55'/%3E%3C/svg%3E");
  background-size: cover;
  inset: 0;
  position: absolute;
}

.hero__content {
  align-self: end;
  max-width: 760px;
  padding: 4rem clamp(1rem, 5vw, 4rem) 3.2rem;
  position: relative;
}

.journey-started .hero {
  min-height: 86px;
}

.journey-started .hero__backdrop {
  background:
    linear-gradient(90deg, rgba(17, 20, 15, 0.94), rgba(17, 20, 15, 0.7)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1400 180'%3E%3Crect fill='%23252b20' width='1400' height='180'/%3E%3Cpath fill='%2311140f' d='M0 132l116-50 92 30 112-74 126 66 118-32 112 50 142-82 134 76 116-36 132 52 100-26 100 40v34H0z'/%3E%3Cpath fill='%23d8a844' opacity='.35' d='M1050 36c46 8 82 24 114 52-44-10-86-8-128 6 25-26 28-37 14-58z'/%3E%3C/svg%3E");
  background-size: cover;
}

.journey-started .hero__content {
  align-self: center;
  padding: 1rem clamp(1rem, 4vw, 3rem);
}

.journey-started .hero .eyebrow,
.journey-started .hero p:last-child {
  display: none;
}

.journey-started .hero h1 {
  font-size: clamp(1.9rem, 4vw, 2.7rem);
  line-height: 1;
  margin-bottom: 0;
}

.eyebrow,
.panel-label {
  color: var(--accent-2);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0;
  margin: 0 0 0.45rem;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  font-size: clamp(3.25rem, 10vw, 7.2rem);
  line-height: 0.9;
  margin-bottom: 1rem;
}

h2 {
  font-size: 1.35rem;
  margin-bottom: 0.7rem;
}

h3 {
  font-size: 1rem;
  margin-bottom: 0.7rem;
}

.hero p:last-child {
  color: #ded7c5;
  font-size: 1.08rem;
  line-height: 1.6;
  max-width: 640px;
}

.game-frame {
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  padding: 0 clamp(1rem, 4vw, 3rem) 3rem;
}

.status-panel,
.main-panel {
  background: rgba(28, 33, 25, 0.94);
  border: 1px solid var(--line);
  box-shadow: 0 18px 50px var(--shadow);
}

.status-panel {
  align-self: start;
  border-radius: 8px;
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

.main-panel {
  border-radius: 8px;
  min-height: 620px;
  overflow: hidden;
}

.resource-bar {
  background: rgba(0, 0, 0, 0.2);
  border-bottom: 1px solid var(--line);
  padding: 0.65rem;
}

.progress-track {
  background: rgba(243, 239, 226, 0.12);
  border-radius: 999px;
  height: 12px;
  overflow: hidden;
}

.next-stop,
.capacity-meter {
  background: rgba(107, 182, 166, 0.1);
  border: 1px solid rgba(107, 182, 166, 0.22);
  border-radius: 6px;
  padding: 0.75rem;
}

.next-stop span,
.next-stop small,
.capacity-meter span,
.capacity-meter small {
  color: var(--muted);
  display: block;
  font-size: 0.78rem;
}

.next-stop strong {
  display: block;
  margin: 0.2rem 0;
}

.capacity-meter {
  background: rgba(255, 255, 255, 0.055);
}

.capacity-meter__label {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.45rem;
}

.capacity-meter__label strong.is-overloaded {
  color: #ffb6a8;
}

.capacity-meter__track {
  background: rgba(243, 239, 226, 0.12);
  border-radius: 999px;
  height: 10px;
  margin-bottom: 0.45rem;
  overflow: hidden;
}

.capacity-meter__track div {
  background: linear-gradient(90deg, var(--accent-2), var(--accent));
  height: 100%;
}

.capacity-meter__track div.is-overloaded {
  background: var(--danger);
}

#progress-fill {
  background: linear-gradient(90deg, var(--accent-2), var(--accent));
  height: 100%;
  transition: width 240ms ease;
  width: 0;
}

.stat-grid {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: repeat(2, 1fr);
}

.stat-grid div {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 0.7rem;
}

.inventory-list div,
.inventory-list button {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  border-radius: 6px;
  min-width: 112px;
  padding: 0.45rem 0.6rem;
}

.inventory-list div.is-empty-rations {
  background: rgba(217, 108, 88, 0.16);
  border-color: rgba(217, 108, 88, 0.64);
}

.inventory-list div.is-empty-rations span,
.inventory-list div.is-empty-rations strong {
  color: #ffb6a8;
}

.stat-grid span,
.inventory-list span,
.character-card span {
  color: var(--muted);
  font-size: 0.78rem;
}

.stat-grid strong,
.inventory-list strong {
  font-size: 1.05rem;
}

.inventory-list button {
  align-items: center;
  display: grid;
  grid-template-columns: 1fr auto;
  min-height: 0;
  text-align: left;
}

.inventory-list div {
  align-items: center;
  display: flex;
  gap: 0.5rem;
  justify-content: space-between;
}

.inventory-list button:not(:disabled) {
  border-color: rgba(107, 182, 166, 0.55);
  box-shadow: inset 0 0 0 1px rgba(107, 182, 166, 0.22);
}

.inventory-list button small {
  color: var(--muted);
  grid-column: 1 / -1;
  display: block;
  font-size: 0.72rem;
  margin-top: 0.15rem;
}

.inventory-list {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
}

.party-list {
  display: grid;
  gap: 0.55rem;
}

.party-row {
  border-left: 4px solid var(--accent-2);
  display: grid;
  gap: 0.25rem;
  padding: 0.55rem 0.65rem;
}

.party-row.is-dead {
  border-color: var(--danger);
  opacity: 0.58;
}

.health-bar {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  height: 7px;
  overflow: hidden;
}

.health-bar div {
  background: var(--good);
  height: 100%;
}

.tabs {
  background: rgba(0, 0, 0, 0.18);
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 0.35rem;
  padding: 0.6rem;
}

.tab {
  background: transparent;
  color: var(--muted);
}

.tab.is-active {
  background: rgba(255, 255, 255, 0.08);
  color: var(--ink);
}

.screen {
  display: none;
  padding: clamp(1rem, 3vw, 1.5rem);
}

.screen.is-active {
  display: block;
}

.screen-heading,
.setup-actions {
  align-items: center;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.character-grid {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 1.2rem;
}

.character-card,
.choice-card,
.event-card,
.location-banner,
.town-market {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.character-card {
  padding: 0.85rem;
}

.character-card strong {
  display: block;
  margin-bottom: 0.25rem;
}

.skill-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.65rem;
}

.skill-pills b {
  background: rgba(107, 182, 166, 0.16);
  border: 1px solid rgba(107, 182, 166, 0.25);
  border-radius: 999px;
  color: #c7f3e9;
  font-size: 0.76rem;
  padding: 0.2rem 0.45rem;
}

.shop-layout {
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(230px, 0.85fr) minmax(0, 1.3fr);
}

.option-stack,
.shop-grid {
  display: grid;
  gap: 0.7rem;
}

.choice-card {
  align-items: start;
  display: grid;
  gap: 0.6rem;
  grid-template-columns: 1fr auto;
  padding: 0.85rem;
}

.choice-card.is-selected {
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent);
}

.choice-card p {
  color: var(--muted);
  line-height: 1.45;
  margin-bottom: 0;
}

.qty-row {
  align-items: center;
  display: grid;
  gap: 0.5rem;
  grid-template-columns: 1fr auto auto auto;
}

.qty-row button,
.small-button {
  background: rgba(255, 255, 255, 0.08);
  min-height: 34px;
  min-width: 38px;
  padding: 0.35rem 0.55rem;
}

.primary-button {
  background: var(--accent);
  color: #17140d;
  font-weight: 800;
}

.secondary-button {
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid var(--line);
}

#setup-warning {
  color: var(--danger);
  margin: 0;
  min-height: 1.5rem;
}

.location-banner {
  margin-bottom: 1rem;
  padding: 1rem;
}

.location-banner p {
  color: var(--muted);
  line-height: 1.55;
  margin-bottom: 0;
}

.event-card {
  min-height: 260px;
  padding: 1rem;
}

.event-card p {
  color: #ddd6c3;
  line-height: 1.55;
}

.pace-controls {
  display: grid;
  gap: 0.6rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 1rem;
}

.pace-button {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  text-align: left;
}

.pace-button.is-selected {
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent);
}

.pace-button small {
  color: var(--muted);
  display: block;
  font-size: 0.76rem;
  margin-top: 0.25rem;
}

.outcome-card {
  border-left: 5px solid var(--accent-2);
  padding-left: 1rem;
}

.road-summary {
  background: rgba(255, 255, 255, 0.055);
  border-left: 5px solid var(--accent-2);
  margin-bottom: 1rem;
  padding: 0.75rem 0.85rem;
}

.road-summary.good {
  border-color: var(--good);
}

.road-summary.bad {
  border-color: var(--danger);
}

.road-summary p {
  margin-bottom: 0.35rem;
}

.outcome-card.good {
  border-color: var(--good);
}

.outcome-card.bad {
  border-color: var(--danger);
}

.outcome-details {
  color: var(--muted);
  font-size: 0.92rem;
}

.event-options {
  display: grid;
  gap: 0.65rem;
  margin-top: 1rem;
}

.event-options button {
  background: var(--panel-2);
  border: 1px solid var(--line);
  text-align: left;
}

.event-options small {
  color: var(--muted);
  display: block;
  margin-top: 0.25rem;
}

.road-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin: 1rem 0;
}

.town-market {
  display: none;
  padding: 1rem;
}

.market-heading {
  align-items: center;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.market-heading h3 {
  margin-bottom: 0;
}

.town-market.is-active {
  display: block;
}

.market-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.log-list {
  display: grid;
  gap: 0.65rem;
  list-style-position: inside;
  margin: 0;
  padding: 0;
}

.log-list li {
  background: rgba(255, 255, 255, 0.05);
  border-left: 4px solid var(--accent-2);
  padding: 0.7rem 0.8rem;
}

.result-good {
  color: var(--good);
}

.result-bad {
  color: var(--danger);
}

@media (max-width: 960px) {
  .game-frame,
  .shop-layout {
    grid-template-columns: 1fr;
  }

  .character-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  .hero__content {
    padding-top: 3rem;
  }

  .character-grid,
  .inventory-list,
  .stat-grid {
    grid-template-columns: 1fr;
  }

  .screen-heading,
  .setup-actions,
  .choice-card,
  .qty-row,
  .pace-controls {
    align-items: stretch;
    grid-template-columns: 1fr;
  }

  .screen-heading,
  .setup-actions {
    flex-direction: column;
  }

  .tabs {
    overflow-x: auto;
  }
}
