@charset "UTF-8";
:root {
  --color-palette-blue-100: #c9d5d4;
  --color-palette-blue-300: #3d89a8;
  --color-palette-blue-300-rgb: 61, 137, 168;
  --color-palette-blue-500: #276278;
  --color-palette-blue-800: #1F4E79;
  --color-palette-blue-900: #0f2e45;
  --color-palette-red-300: #E63946;
  --color-palette-red-500: #c31317;
  --color-palette-red-800: #7f0910;
  --color-palette-yellow-300: #ffe99a;
  --color-palette-yellow-500: #F4D35E;
  --color-palette-yellow-800: #d29f3a;
  --color-palette-black: #111010;
  --color-palette-gray-500: #454545;
  --color-palette-white: #ffffff;
  --color-bg-primary: var(--color-palette-blue-800);
  --color-bg-secondary: var(--color-palette-blue-300);
  --color-bg-secondary-rgb: var(--color-palette-blue-300-rgb);
  --color-bg-tertiary: var(--color-palette-blue-900);
  --color-bg-opacity-light: rgba(0, 0, 0, 0.25);
  --color-bg-opacity-med: rgba(0, 0, 0, 0.5);
  --color-bg-opacity-dark: rgba(0, 0, 0, 0.75);
  --color-bg-opacity-highlight: rgba(255, 255, 255, 0.5);
  --color-text-primary: var(--color-palette-white);
  --color-text-secondary: var(--color-palette-yellow-300);
  --color-btn-primary-bg-default: var(--color-palette-yellow-500);
  --color-btn-primary-bg-hover: var(--color-palette-yellow-800);
  --color-btn-primary-text-default: var(--color-palette-black);
  --color-btn-primary-text-hover: var(--color-palette-black);
  --color-btn-secondary-bg-default: var(--color-bg-opacity-med);
  --color-btn-secondary-bg-hover: var(--color-bg-opacity-light);
  --color-btn-secondary-text-default: var(--color-palette-white);
  --color-btn-secondary-text-hover: var(--color-palette-white);
  --color-form-input-bg: var(--color-bg-opacity-light);
  --color-form-input-placeholder: rgba(255, 255, 255, 0.75);
  --color-shape-bg: var(--color-palette-black);
  --color-shape-border: var(--color-palette-yellow-800);
  --shape-border-width: 3px;
  --shape-offset: 10px;
}
@media (min-width: 900px) {
  :root {
    --shape-border-width: 6px;
    --shape-offset: 20px;
  }
}
:root {
  --spacing-xxs: 4px;
  --spacing-xs: 8px;
  --spacing-sm: 16px;
  --spacing-md: 24px;
  --spacing-lg: 32px;
  --spacing-xl: 40px;
  --radius-xs: 8px;
  --radius-sm: 12px;
  --radius-md: 16px;
  --radius-lg: 18px;
  --radius-full: 999px;
  --font-family: 'Wendy One', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-size-text-xlarge: 3rem;
  --font-size-text-large: 2rem;
  --font-size-text-default: 1.5rem;
  --font-size-text-small: 1rem;
  --font-line-height-text-headline: 1;
  --font-line-height-text-default: 1.2;
  --font-weight-normal: 400;
  --anim-speed-fast: 150ms;
  --anim-speed: 300ms;
  --anim-speed-slow: 500ms;
  --anim-speed-slower: 800ms;
  --anim-speed-slowest: 1000ms;
  --anim-ease: ease-out;
  --z-index-default: 1;
  --z-index-above-default: 2;
  --z-index-modal: 3;
}

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

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center, hr,
dl, dt, dd, ol, ul, li,
form, fieldset, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
main, article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  border: 0;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

main, article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary {
  display: block;
}

img, audio, canvas, video {
  display: inline-block;
  margin: auto;
}

body {
  -ms-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  line-height: 1;
}

b, strong {
  font-weight: bold;
}

i, em {
  font-style: italic;
}

blockquote, q {
  quotes: none;
}

blockquote::before, blockquote::after,
q::before, q::after {
  content: "";
}

sub, sup {
  font-size: 0.75em;
  line-height: 1;
}

sub {
  vertical-align: sub;
}

sup {
  vertical-align: super;
}

fieldset {
  display: block;
  min-width: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  background: none;
  clear: both;
}

img {
  height: auto;
  max-width: 100%;
  width: auto;
}

button:not([disabled]) {
  cursor: pointer;
}

body {
  background: linear-gradient(to bottom, var(--color-bg-primary), var(--color-bg-secondary));
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.site-header {
  align-items: center;
  display: flex;
  justify-content: center;
  padding: var(--spacing-md) var(--spacing-md) 0;
}
.site-header--content {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.site-header--title {
  align-items: center;
  display: flex;
  gap: var(--spacing-sm);
}
.site-header--tagline {
  color: var(--color-text-secondary);
  text-align: center;
}

.site-content {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--spacing-md);
  padding: var(--spacing-md);
}

.row {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  justify-content: center;
  position: relative;
}
@media (min-width: 900px) {
  .row {
    flex-direction: row;
  }
}

.column {
  display: flex;
  flex: 1;
  width: 100%;
}
@media (min-width: 900px) {
  .column.align-left {
    justify-content: flex-start;
  }
  .column.align-center {
    justify-content: center;
  }
  .column.align-right {
    justify-content: flex-end;
  }
}

.btn {
  background: var(--color-btn-primary-bg-default);
  border-bottom-right-radius: var(--radius-xs);
  border-top-left-radius: var(--radius-xs);
  border: 0;
  color: var(--color-btn-primary-text-default);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--font-family);
  font-size: var(--font-size-text-default);
  font-weight: var(--font-weight-normal);
  justify-content: center;
  line-height: var(--font-line-height-text-default);
  padding: var(--spacing-xs);
  touch-action: manipulation;
  transition: all var(--anim-speed) var(--anim-ease);
}
@media (min-width: 900px) {
  .btn {
    border-bottom-right-radius: var(--radius-sm);
    border-top-left-radius: var(--radius-sm);
    padding: var(--spacing-sm);
  }
}
.btn:hover, .btn:focus-visible {
  background: var(--color-btn-primary-bg-hover);
  color: var(--color-btn-primary-text-hover);
}
.btn-secondary {
  background: var(--color-btn-secondary-bg-default);
  color: var(--color-btn-secondary-text-default);
}
.btn-secondary:hover, .btn-secondary:focus-visible {
  background: var(--color-btn-secondary-bg-hover);
  color: var(--color-btn-secondary-text-hover);
}

body {
  color: var(--color-text-primary);
  font-family: var(--font-family);
  font-size: var(--font-size-text-default);
  font-weight: var(--font-weight-normal);
  line-height: var(--font-line-height-text-default);
}

h1, h2, h3, h4, h5, h6 {
  font-size: var(--font-size-text-large);
  font-weight: var(--font-weight-normal);
  line-height: var(--font-line-height-text-headline);
}

h1 {
  font-size: var(--font-size-text-xlarge);
}

.text-size-small {
  font-size: var(--font-size-text-small);
}

.text-size-large {
  font-size: var(--font-size-text-large);
}

.text-size-xlarge {
  font-size: var(--font-size-text-xlarge);
}

.text-color-secondary {
  color: var(--color-text-secondary);
}

.form-input {
  background: var(--color-form-input-bg);
  border: 0;
  color: var(--color-text-primary);
  display: inline-flex;
  flex: 1;
  font-family: var(--font-family);
  font-size: var(--font-size-text-default);
  font-weight: var(--font-weight-normal);
  height: 100%;
  line-height: var(--font-line-height-text-default);
  outline: none;
  padding: var(--spacing-xs) var(--spacing-sm);
}
.form-input[type=number] {
  flex: unset;
}
.form-input::placeholder {
  color: var(--color-form-input-placeholder);
}

.card {
  background: var(--color-bg-secondary);
  border: var(--shape-border-width) solid var(--color-shape-border);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
}
@media (min-width: 900px) {
  .card {
    max-width: 50%;
  }
}
.card--row {
  align-items: center;
  border-bottom: 2px solid var(--color-bg-opacity-light);
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  justify-content: flex-end;
  padding-bottom: var(--spacing-sm);
}

@keyframes animScore {
  0% {
    transform: scale(1);
  }
  40% {
    transform: scale(1.025);
    background: var(--color-bg-opacity-highlight);
  }
  100% {
    transform: scale(1);
  }
}
.scoreboard {
  list-style: none;
  margin: 0;
  padding: 0;
}
.scoreboard--item {
  background: var(--color-bg-opacity-med);
  display: flex;
  justify-content: space-between;
  padding: var(--spacing-xs) var(--spacing-sm);
  transition: all var(--anim-speed-slow) var(--anim-ease);
}
.scoreboard--item:nth-child(odd) {
  background: var(--color-bg-opacity-light);
}
.scoreboard--item.current-player {
  color: var(--color-text-secondary);
}
.scoreboard--item.current-player .scoreboard--item-name {
  cursor: pointer;
}
.scoreboard--item.anim-score {
  animation: animScore 1000ms cubic-bezier(0.2, 0.9, 0.3, 1);
  transform-origin: center center;
}
.scoreboard--item-name-editable {
  background: transparent;
  border-radius: var(--spacing-xxs);
  border: 2px solid var(--color-text-secondary);
  color: var(--color-text-secondary);
  display: inline-flex;
  flex: 1;
  font-family: inherit;
  font-size: inherit;
  max-width: 70%;
  padding: 0 var(--spacing-xs);
}
.scoreboard--item-name-editable:focus {
  outline: none;
}
.scoreboard--item-score {
  display: inline-flex;
}

.status-bar {
  align-items: center;
  background: var(--color-bg-secondary);
  border: var(--shape-border-width) solid var(--color-shape-border);
  flex: 1;
  gap: var(--spacing-sm);
  justify-content: space-between;
  padding: var(--spacing-sm);
}

.game-row {
  padding: var(--spacing-xs);
}
@media (min-width: 900px) {
  .game-row {
    padding: var(--spacing-sm);
  }
}

.game-border {
  background: var(--color-shape-border);
  clip-path: polygon(var(--shape-border-width) var(--shape-border-width), calc(100% - var(--shape-border-width)) calc(var(--shape-offset) + var(--shape-border-width)), calc(100% - var(--shape-offset) - var(--shape-border-width)) calc(100% - var(--shape-border-width)), calc(var(--shape-offset) + var(--shape-border-width)) calc(100% - var(--shape-border-width)));
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.game-board {
  background: var(--color-bg-tertiary);
  clip-path: polygon(0 0, 100% var(--shape-offset), calc(100% - var(--shape-offset)) 100%, var(--shape-offset) 100%);
  display: flex;
  flex-direction: column;
  flex: 1;
  height: 90vh;
  max-height: 90vh;
  max-width: 100vw;
  overflow: hidden;
  position: relative;
  touch-action: manipulation;
  user-select: none;
}
.game-board--round {
  align-items: center;
  display: flex;
  gap: var(--spacing-xs);
  justify-content: flex-end;
  position: absolute;
  right: 15px;
  top: 15px;
  z-index: var(--z-index-above-default);
}
@media (min-width: 900px) {
  .game-board--round {
    right: 20px;
    top: 30px;
  }
}
.game-board--round-timer {
  align-items: center;
  background: var(--color-bg-opacity-dark);
  border-radius: var(--radius-full);
  border: var(--shape-border-width) solid var(--color-bg-secondary);
  display: flex;
  font-size: var(--font-size-text-default);
  height: 60px;
  justify-content: center;
  width: 60px;
}
.game-board--round-count {
  background: var(--color-bg-opacity-dark);
  border: var(--shape-border-width) solid var(--color-bg-secondary);
  display: flex;
  font-size: var(--font-size-text-small);
  padding: var(--spacing-xs) var(--spacing-sm);
}
.game-board--container {
  display: block;
  height: 100%;
  overflow: auto;
  position: relative;
  width: 100%;
  z-index: var(--z-index-default);
}
.game-board--content {
  width: 3000px;
}
.game-board--map {
  display: block;
  margin: 0;
  opacity: 0;
  transition: opacity var(--anim-speed) var(--anim-ease);
}
.game-board--banner {
  background: var(--color-bg-opacity-dark);
  border: var(--shape-border-width) solid var(--color-bg-secondary);
  left: 50%;
  padding: var(--spacing-sm) var(--spacing-lg);
  position: absolute;
  text-align: center;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: var(--z-index-above-default);
}

.treasure {
  align-items: center;
  background: var(--color-bg-opacity-dark);
  border: 2px solid var(--color-bg-secondary);
  border-radius: var(--radius-full);
  display: flex;
  font-size: var(--font-size-text-large);
  height: var(--font-size-text-xlarge);
  justify-content: center;
  position: absolute;
  transform: translate(0, 0);
  transition: background var(--anim-speed) var(--anim-ease);
  width: var(--font-size-text-xlarge);
  z-index: var(--z-index-default);
}
.treasure:active {
  transform: translate(0, 0) scale(0.98);
}
.treasure:hover, .treasure:focus {
  background: var(--color-bg-opacity-highlight);
}

.treasure-clone {
  border-radius: var(--radius-full);
  opacity: 1;
  pointer-events: none;
  position: fixed;
  transform-origin: center center;
  z-index: var(--z-index-above-default);
}

.map-picker {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.map-picker--item {
  background: transparent;
  border-radius: var(--radius-sm);
  border: 3px solid var(--color-bg-secondary);
  cursor: pointer;
  overflow: hidden;
  padding: 2px;
  transition: all var(--anim-speed) var(--anim-ease);
  width: 100%;
}
.map-picker--item:hover, .map-picker--item:focus {
  outline: none;
}
.map-picker--item:hover .map-picker--thumb, .map-picker--item:focus .map-picker--thumb {
  transform: scale(1.1);
}
.map-picker--item.selected {
  border: 3px solid var(--color-btn-primary-bg-default);
  position: relative;
}
.map-picker--item.selected::before {
  background: var(--color-bg-opacity-light);
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  z-index: var(--z-index-default);
}
.map-picker--item.selected::after {
  align-items: center;
  background: var(--color-btn-primary-bg-default);
  border-radius: var(--radius-full);
  color: var(--color-btn-primary-text-default);
  content: "✓";
  display: flex;
  font-size: var(--font-size-text-default);
  height: var(--spacing-lg);
  justify-content: center;
  position: absolute;
  right: var(--spacing-xs);
  top: var(--spacing-xs);
  width: var(--spacing-lg);
  z-index: var(--z-index-above-default);
}
.map-picker--item.selected:hover .map-picker--thumb, .map-picker--item.selected:focus .map-picker--thumb {
  transform: scale(1);
}
.map-picker--thumb {
  aspect-ratio: 16/9;
  border-radius: var(--radius-xs);
  display: block;
  object-fit: cover;
  transition: all var(--anim-speed) var(--anim-ease);
  width: 100%;
}

@keyframes fadeInOverlay {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes slideInPanel {
  from {
    transform: translateX(100%);
  }
  to {
    transform: translateX(0);
  }
}
.drawer {
  align-items: stretch;
  display: flex;
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: var(--z-index-modal);
}
.drawer.hidden {
  display: none;
}
.drawer--overlay {
  animation: fadeInOverlay var(--anim-speed) var(--anim-ease) forwards;
  background: var(--color-bg-opacity-med);
  cursor: pointer;
  height: 100vh;
  left: 0;
  opacity: 0;
  position: fixed;
  top: 0;
  transition: opacity var(--anim-speed) var(--anim-ease);
  width: 100vw;
}
.drawer--panel {
  animation: slideInPanel var(--anim-speed) var(--anim-ease) forwards;
  background: var(--color-bg-primary);
  border-left: var(--shape-border-width) solid var(--color-shape-border);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  height: 100vh;
  max-width: 80vw;
  padding: var(--spacing-md);
  position: fixed;
  right: 0;
  top: 0;
  width: 100%;
}
@media (min-width: 900px) {
  .drawer--panel {
    width: 400px;
  }
}
.drawer--header {
  align-items: center;
  display: flex;
  gap: var(--spacing-md);
  justify-content: space-between;
}
.drawer--content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  max-height: 100vh;
  overflow-y: auto;
}
.drawer--content-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.drawer--row {
  align-items: center;
  border-bottom: 2px solid var(--color-shape-border);
  display: flex;
  justify-content: space-between;
  padding-bottom: var(--spacing-xs);
}
.drawer--close-btn {
  align-items: center;
  appearance: none;
  background: transparent;
  border: 2px solid transparent;
  color: var(--color-text);
  cursor: pointer;
  display: flex;
  font-size: var(--font-size-text-large);
  height: var(--spacing-xl);
  justify-content: center;
  padding: 0;
  width: var(--spacing-xl);
}
.drawer--close-btn:hover, .drawer--close-btn:focus {
  border-color: var(--color-bg-secondary);
  outline: none;
}

.hidden {
  display: none;
}

.fading-out {
  opacity: 0;
  transition: opacity 300ms ease-out;
}

/*# sourceMappingURL=style.css.map */
