:root {
  --ink: #1a1e1a;
  --water: #4a8a5a;
  --bg: #e8ece8;
  --gold: #c4a030;
  --coral: #b04a3a;
  --leaf: #2a6a2a;
  --tile: #f4f6f4;
  --soft: rgba(26,30,26,.72);
  --bw: 3px;
}
* { box-sizing: border-box; }
html { max-width: 100%; overflow-x: hidden; }
body {
  margin: 0;
  color: var(--ink);
  background: linear-gradient(90deg, #4a8a5a33 1px, transparent 1px), linear-gradient(0deg, #1a1e1a14 1px, transparent 1px), #e8ece8;
  background-size: 32px 32px;
  font-family: "Trebuchet MS", Inter, system-ui, sans-serif;
  overflow-x: hidden;
}
main, .topbar, .hero, .play-section, .page { max-width: 100vw; }
a { color: inherit; }
.topbar {
  position: sticky; top: 0; z-index: 20;
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 18px;
  padding: 12px clamp(16px, 4vw, 48px);
  background: var(--bg); border-bottom: 4px solid var(--ink);
}
.brand {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 950; text-decoration: none;
}
.brand img { width: 46px; height: 46px; }
.topbar nav {
  min-width: 0; display: flex; justify-content: center;
  gap: 8px; flex-wrap: wrap;
}
.topbar nav a {
  padding: 10px 12px; border: 3px solid transparent;
  text-decoration: none; font-weight: 900;
}
.topbar nav a:hover, .topbar nav a.active {
  border-color: var(--ink); background: var(--gold);
}
.language {
  display: inline-grid; grid-template-columns: repeat(auto-fit, minmax(38px, 1fr));
  border: 3px solid var(--ink); background: var(--ink);
}
.language button {
  min-width: 40px; min-height: 36px; border: 0;
  color: var(--bg); background: transparent;
  font-weight: 950; cursor: pointer; font-size: 12px;
}
.language button.active { color: var(--ink); background: var(--gold); }
.hero {
  display: grid;
  grid-template-columns: minmax(340px, .85fr) minmax(380px, 1fr);
  min-height: 56vh; border-bottom: 5px solid var(--ink);
}
.hero-copy {
  min-width: 0; display: grid; align-content: center;
  gap: 22px; padding: clamp(28px, 6vw, 78px); background: var(--tile);
}
.label {
  width: fit-content; padding: 8px 12px;
  color: var(--bg); background: var(--coral);
  border: 3px solid var(--ink); font-weight: 950; text-transform: uppercase;
}
h1, h2, h3, p { margin: 0; }
h1 {
  max-width: 720px; font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(52px, 7vw, 108px); line-height: .88;
}
.hero-copy p, .page-head p {
  max-width: 640px; color: var(--soft);
  font-size: 19px; line-height: 1.5; font-weight: 800;
}
.actions { display: flex; flex-wrap: wrap; gap: 12px; }
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 48px; padding: 0 18px; color: var(--ink);
  background: var(--gold); border: 3px solid var(--ink);
  box-shadow: 5px 5px 0 var(--ink);
  font-weight: 950; text-decoration: none; cursor: pointer;
}
.btn.secondary { background: var(--water); }
.btn.plain { background: var(--tile); }
.btn:active { transform: translate(3px,3px); box-shadow: 2px 2px 0 var(--ink); }
.hero-map {
  position: relative; overflow: hidden;
  display: grid; place-items: center;
  background: linear-gradient(135deg, #4a8a5a40, #c4a03038), var(--bg);
}
.hero-map::before {
  content: ""; position: absolute;
  inset: auto -8% 20% -8%; height: 110px;
  background: var(--water); border-top: 3px solid var(--ink);
  border-bottom: 3px solid var(--ink); transform: rotate(-6deg);
}
.hero-img {
  position: relative; z-index: 2; width: min(70%, 500px);
  border: 5px solid var(--ink); box-shadow: 15px 15px 0 var(--ink);
}
.hero-badge {
  position: absolute; z-index: 3; right: 8%; bottom: 16%;
  width: min(28%, 180px);
}
.play-section {
  display: grid; grid-template-columns: minmax(320px, 1fr) 340px;
  gap: 28px; padding: clamp(22px, 4vw, 54px);
  background: linear-gradient(180deg, var(--tile), var(--bg));
}
.game-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 18px; margin-bottom: 14px;
}
.game-head h2, .page-head h1 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(36px, 5vw, 70px); line-height: .95;
}
.scorebar {
  display: grid; grid-template-columns: repeat(4, minmax(78px, 1fr));
  gap: 8px; margin-bottom: 14px;
}
.scorebar div, .board-panel, .info-block, .page-card, .contact-card {
  background: var(--tile); border: 3px solid var(--ink);
}
.scorebar div { padding: 10px; }
.scorebar span {
  display: block; color: var(--soft);
  font-size: 11px; font-weight: 950; text-transform: uppercase;
}
.scorebar strong { display: block; font-size: 28px; line-height: 1; }
.board-panel { padding: clamp(10px, 2vw, 20px); }
.game-canvas { display: block; max-width: 100%; border: 3px solid var(--ink); }
.side { display: grid; align-content: start; gap: 14px; }
.info-block { padding: 18px; }
.info-block h3, .page-card h2, .contact-card h2 {
  margin-bottom: 8px; font-family: Georgia, "Times New Roman", serif;
  font-size: 28px; line-height: 1;
}
.info-block p, .info-block li, .page-card p, .contact-card p {
  color: var(--soft); font-weight: 780; line-height: 1.55;
}
.info-block ul { margin: 0; padding-left: 20px; }
.status {
  min-height: 48px; padding: 12px;
  background: var(--ink); color: var(--bg); font-weight: 900;
}
.game-start {
  display: block; width: 100%; padding: 14px;
  background: var(--gold); border: 3px solid var(--ink);
  box-shadow: 5px 5px 0 var(--ink);
  font-weight: 950; font-size: 18px; cursor: pointer;
  margin-bottom: 12px;
}
.game-start:active { transform: translate(2px,2px); box-shadow: 2px 2px 0 var(--ink); }
.page { padding: clamp(24px, 6vw, 78px); }
.page-head { max-width: 980px; margin-bottom: 24px; }
.page-head p { margin-top: 14px; }
.page-grid, .contact-grid {
  display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px;
}
.page-card, .contact-card { padding: 24px; }
.page-card.wide { grid-column: 1 / -1; }
.footer {
  padding: 24px clamp(20px, 4vw, 54px);
  color: var(--bg); background: var(--ink); font-weight: 850;
}
@media (max-width: 980px) {
  .topbar { grid-template-columns: 1fr auto; }
  .brand { grid-column: 1; }
  .topbar nav {
    grid-column: 1 / -1; justify-content: flex-start;
    overflow-x: auto; flex-wrap: nowrap; max-width: 100%;
  }
  .language { grid-column: 2; grid-row: 1; }
  .hero, .play-section { grid-template-columns: 1fr; }
  .side { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px) {
  .topbar {
    grid-template-columns: auto 1fr; justify-content: stretch;
    padding: 10px 12px; gap: 10px;
  }
  .language { position: fixed; top: 10px; left: 72px; z-index: 40; }
  .brand span { display: none; }
  h1 { font-size: 48px; max-width: 8.6ch; }
  .hero-copy p { max-width: 28ch; font-size: 17px; }
  .hero-copy, .page { padding: 24px 16px; }
  .hero-map { min-height: 320px; }
  .scorebar, .side, .page-grid, .contact-grid { grid-template-columns: 1fr; }
}
