:root {
  --sky-top: #183958;
  --sky-mid: #25547a;
  --sea: #2c7f9f;
  --sand: #d7b86f;
  --panel: rgba(246, 244, 236, 0.9);
  --panel-strong: rgba(252, 249, 240, 0.98);
  --text: #12324a;
  --muted: #4f6d83;
  --accent: #ff9f1c;
  --accent-2: #23c483;
  --accent-3: #ffe082;
  --accent-4: #ff6f91;
  --success: #149b64;
  --danger: #db5b5b;
  --shadow: 0 22px 48px rgba(5, 20, 33, 0.28);
  --radius: 30px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Avenir Next", "Trebuchet MS", "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 12% 12%, rgba(255, 228, 123, 0.46), transparent 16%),
    radial-gradient(circle at 84% 18%, rgba(170, 232, 255, 0.34), transparent 20%),
    radial-gradient(circle at 50% 80%, rgba(166, 241, 191, 0.18), transparent 18%),
    linear-gradient(180deg, #5dcaf0 0%, #76d9ff 18%, #58b8f2 48%, #37a3d4 72%, #278ab6 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 10% 22%, rgba(255,255,255,0.14) 0 12px, transparent 14px),
    radial-gradient(circle at 74% 16%, rgba(255,255,255,0.1) 0 10px, transparent 12px),
    radial-gradient(circle at 88% 72%, rgba(255,255,255,0.08) 0 12px, transparent 14px);
  background-size: 320px 220px, 280px 180px, 340px 220px;
  opacity: 0.9;
}

body::after {
  content: "🐉";
  position: fixed;
  right: -40px;
  top: 90px;
  font-size: min(34vw, 420px);
  line-height: 1;
  opacity: 0.04;
  transform: rotate(-10deg);
  pointer-events: none;
  filter: saturate(0.6);
}

.app-shell::before {
  content: "🐉";
  position: fixed;
  left: -10px;
  bottom: 120px;
  font-size: min(22vw, 220px);
  line-height: 1;
  opacity: 0.03;
  transform: scaleX(-1) rotate(-12deg);
  pointer-events: none;
  filter: saturate(0.4);
}

.app-shell {
  width: min(1180px, calc(100% - 24px));
  margin: 0 auto;
  padding: max(18px, env(safe-area-inset-top)) 0 max(32px, env(safe-area-inset-bottom));
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: var(--text);
}

.eyebrow {
  margin: 0;
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #26779b;
  font-weight: 800;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.28);
}

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

h1 {
  margin-bottom: 0;
  font-family: "Avenir Next Condensed", "Trebuchet MS", sans-serif;
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  letter-spacing: 0.02em;
  color: #f5f0dc;
  text-shadow: 0 6px 0 rgba(7, 23, 37, 0.54), 0 2px 10px rgba(255, 255, 255, 0.12);
}

.brand-subtitle {
  margin-top: 4px;
  font-size: 1.02rem;
  font-weight: 800;
  color: #8b6231;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.36);
}

h2,
h3 {
  color: var(--text);
}

.pill,
.stat,
.badge,
.world-lock,
.mini-card {
  border-radius: 999px;
  padding: 10px 16px;
  background: rgba(255, 249, 232, 0.9);
  box-shadow: var(--shadow);
}

.home-section-title h3,
.map-section-title h3 {
  color: #143b57;
  text-shadow: 0 2px 10px rgba(255, 255, 255, 0.22);
}

.home-section-title .eyebrow,
.map-section-title .eyebrow {
  color: #1f7399;
}

.screen {
  display: grid;
  gap: 18px;
}

.panel {
  background: var(--panel);
  border: 2px solid rgba(255,255,255,0.26);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
  padding: 22px;
}

.hero {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 18px;
  align-items: center;
}

.hero p:not(.eyebrow) {
  font-size: 1.05rem;
  color: var(--muted);
}

.hero-art {
  min-height: 260px;
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 28% 24%, rgba(255,255,255,0.95), transparent 16%),
    radial-gradient(circle at 68% 70%, rgba(245,181,68,0.45), transparent 22%),
    linear-gradient(135deg, rgba(8,24,36,0.95), rgba(18,52,76,0.92) 48%, rgba(29,90,119,0.95));
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
}

.hero-art::after {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,0.14);
}

.hero-badge {
  position: absolute;
  top: 20px;
  right: 20px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(245, 181, 68, 0.18);
  border: 1px solid rgba(245, 181, 68, 0.35);
  color: white;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.76rem;
}

.hero-worlds {
  display: grid;
  grid-template-columns: repeat(2, minmax(72px, 1fr));
  gap: 18px;
  width: min(280px, 80%);
}

.hero-worlds span {
  display: grid;
  place-items: center;
  min-height: 88px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: white;
  font-size: 2.4rem;
}

.button-row,
.grid {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.grid {
  align-items: stretch;
}

.card,
.world-card,
.profile-card,
.leader-card,
.question-card {
  background: var(--panel-strong);
  border-radius: 26px;
  padding: 18px;
  box-shadow: var(--shadow);
  border: 2px solid rgba(255, 255, 255, 0.76);
}

.profile-card,
.leader-card {
  flex: 1 1 250px;
}

.card-title,
.section-title,
.world-kicker,
.world-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.card-title,
.world-header {
  align-items: center;
}

button,
input,
select {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
  min-height: 52px;
  padding: 12px 22px;
  border-radius: 999px;
  color: white;
  font-weight: 800;
  background: linear-gradient(180deg, #ffb839, var(--accent));
  box-shadow: 0 10px 0 #e98200, 0 18px 28px rgba(255, 159, 28, 0.25);
  transition: transform 0.15s ease, filter 0.15s ease;
  touch-action: manipulation;
}

button.secondary {
  background: linear-gradient(180deg, #47df9d, var(--accent-2));
  box-shadow: 0 10px 0 #15a766, 0 18px 28px rgba(35, 196, 131, 0.24);
}

button.ghost {
  color: var(--text);
  background: rgba(255,255,255,0.92);
  box-shadow: 0 8px 0 rgba(44, 122, 150, 0.14);
}

button.locked {
  filter: grayscale(1);
  cursor: not-allowed;
}

button:hover:not(.locked) {
  transform: translateY(-2px);
}

input,
select {
  width: 100%;
  border: 2px solid rgba(41, 167, 199, 0.2);
  border-radius: 18px;
  padding: 14px 16px;
  background: white;
  color: var(--text);
  min-height: 52px;
  font-size: 16px;
}

label {
  display: grid;
  gap: 8px;
  font-weight: 700;
}

.create-form label {
  font-weight: 600;
}

.avatar-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 14px;
}

.avatar-option {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  min-height: 124px;
  border-radius: 20px;
  padding: 14px 10px;
  border: 2px solid rgba(18, 52, 76, 0.05);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,252,255,0.96));
  box-shadow: 0 10px 0 rgba(39, 137, 169, 0.12);
  font-size: 1rem;
  cursor: pointer;
  color: var(--text);
  text-align: center;
  white-space: normal;
}

.avatar-option.active {
  border-color: var(--accent);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,238,177,0.92));
  transform: scale(1.03);
}

.avatar-option span {
  display: block;
  font-size: 2.1rem;
  line-height: 1;
}

.avatar-option small {
  display: block;
  font-size: 0.98rem;
  line-height: 1.12;
  font-weight: 800;
}

.create-screen {
  place-items: center;
}

.create-panel {
  width: min(1100px, 100%);
  background:
    radial-gradient(circle at top right, rgba(215, 182, 99, 0.22), transparent 22%),
    radial-gradient(circle at bottom left, rgba(92, 150, 210, 0.14), transparent 24%),
    linear-gradient(180deg, rgba(251,248,238,0.98), rgba(238,246,251,0.96));
}

.create-heading {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 22px;
}

.create-heading h2 {
  margin-bottom: 8px;
  font-weight: 700;
}

.create-heading p:not(.eyebrow) {
  max-width: 42rem;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.55;
}

.create-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 22px;
  align-items: start;
}

.create-form {
  gap: 18px;
}

.create-section,
.create-preview-card,
.create-tip-card {
  padding: 18px;
  border-radius: 26px;
  background: rgba(255,255,255,0.84);
  border: 2px solid rgba(255,255,255,0.72);
  box-shadow: var(--shadow);
}

.create-section {
  display: grid;
  gap: 14px;
}

.create-section-title h3 {
  margin-bottom: 4px;
  font-weight: 700;
}

.create-preview {
  display: grid;
  gap: 16px;
}

.create-preview-card {
  text-align: center;
  background:
    radial-gradient(circle at top center, rgba(255, 229, 129, 0.44), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,248,214,0.96));
}

.create-preview-avatar {
  display: grid;
  place-items: center;
  width: 112px;
  height: 112px;
  margin: 10px auto 14px;
  border-radius: 32px;
  background: linear-gradient(180deg, #ffffff, #e9fbff);
  box-shadow: 0 12px 0 rgba(36, 145, 181, 0.13);
  font-size: 3.6rem;
  line-height: 1;
}

.create-preview-card h3 {
  font-size: 1.8rem;
  margin-bottom: 6px;
  font-weight: 700;
}

.create-preview-card p {
  color: var(--muted);
}

.create-preview-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 18px;
}

.create-tip-card h3 {
  margin-bottom: 8px;
}

.create-tip-card p {
  margin-bottom: 0;
  color: var(--muted);
}

.create-actions {
  justify-content: flex-start;
}

.stats-bar,
.top-stats,
.world-tags,
.achievements,
.ranking-list,
.summary-stack {
  display: grid;
  gap: 10px;
}

.stats-bar,
.top-stats,
.world-tags {
  display: flex;
  flex-wrap: wrap;
}

.stat {
  background: rgba(255,255,255,0.94);
  font-weight: 700;
  border: 1px solid rgba(214, 189, 129, 0.34);
  min-width: 104px;
  min-height: 74px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 12px 24px rgba(10, 24, 37, 0.16);
}

.progress {
  height: 14px;
  background: rgba(55, 165, 199, 0.18);
  border-radius: 999px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #ffe169, #ffb11c 52%, #ff8f70);
}

.small {
  font-size: 0.94rem;
  color: var(--muted);
}

.profile-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, 0.75fr);
  gap: 24px;
  align-items: stretch;
}

.journey-callout,
.focus-card,
.rival-card {
  background: rgba(255,255,255,0.68);
  border-radius: 24px;
  padding: 18px;
}

.focus-card,
.journey-callout {
  display: grid;
  gap: 14px;
  align-content: start;
}

.theme-panel {
  --kingdom-tint: rgba(255, 235, 150, 0.22);
  --kingdom-tint-2: rgba(167, 232, 255, 0.18);
  --kingdom-accent: #1ea7c8;
  --kingdom-accent-strong: #1494b6;
  --kingdom-glow: rgba(255, 226, 120, 0.46);
  background:
    radial-gradient(circle at top right, var(--kingdom-glow), transparent 24%),
    radial-gradient(circle at bottom left, var(--kingdom-tint-2), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.74));
  border: 2px solid rgba(255,255,255,0.82);
}

.profile-hero .eyebrow,
.question-card .eyebrow,
.mini-game-panel .eyebrow,
.secret-panel .eyebrow,
.celebration .eyebrow {
  color: #5bb2d0;
}

.theme-solar {
  --kingdom-tint: rgba(255, 227, 104, 0.38);
  --kingdom-tint-2: rgba(255, 164, 71, 0.2);
  --kingdom-accent: #f4a20f;
  --kingdom-accent-strong: #de7e00;
  --kingdom-glow: rgba(255, 233, 133, 0.6);
}

.theme-stone {
  --kingdom-tint: rgba(175, 190, 205, 0.3);
  --kingdom-tint-2: rgba(121, 165, 191, 0.2);
  --kingdom-accent: #6c8fa8;
  --kingdom-accent-strong: #4d7188;
  --kingdom-glow: rgba(205, 221, 234, 0.48);
}

.theme-forest {
  --kingdom-tint: rgba(121, 214, 146, 0.32);
  --kingdom-tint-2: rgba(55, 171, 117, 0.18);
  --kingdom-accent: #24a55d;
  --kingdom-accent-strong: #168149;
  --kingdom-glow: rgba(190, 248, 163, 0.5);
}

.theme-tide {
  --kingdom-tint: rgba(107, 219, 255, 0.35);
  --kingdom-tint-2: rgba(50, 156, 223, 0.18);
  --kingdom-accent: #1da6d6;
  --kingdom-accent-strong: #0d7fa7;
  --kingdom-glow: rgba(170, 238, 255, 0.5);
}

.theme-windmill {
  --kingdom-tint: rgba(181, 241, 190, 0.32);
  --kingdom-tint-2: rgba(255, 222, 154, 0.2);
  --kingdom-accent: #48ae73;
  --kingdom-accent-strong: #2e8956;
  --kingdom-glow: rgba(238, 251, 191, 0.55);
}

.theme-crystal {
  --kingdom-tint: rgba(193, 220, 255, 0.34);
  --kingdom-tint-2: rgba(214, 191, 255, 0.22);
  --kingdom-accent: #7f74e8;
  --kingdom-accent-strong: #5f52cf;
  --kingdom-glow: rgba(226, 219, 255, 0.55);
}

.theme-skyline {
  --kingdom-tint: rgba(154, 214, 255, 0.34);
  --kingdom-tint-2: rgba(255, 219, 146, 0.18);
  --kingdom-accent: #2c97df;
  --kingdom-accent-strong: #1f72ac;
  --kingdom-glow: rgba(209, 235, 255, 0.52);
}

.theme-moonlagoon {
  --kingdom-tint: rgba(170, 208, 255, 0.32);
  --kingdom-tint-2: rgba(153, 132, 255, 0.2);
  --kingdom-accent: #6883ff;
  --kingdom-accent-strong: #4b61cc;
  --kingdom-glow: rgba(221, 227, 255, 0.56);
}

.theme-forge {
  --kingdom-tint: rgba(255, 180, 119, 0.34);
  --kingdom-tint-2: rgba(233, 101, 72, 0.18);
  --kingdom-accent: #e97433;
  --kingdom-accent-strong: #bc4e1d;
  --kingdom-glow: rgba(255, 219, 139, 0.56);
}

.theme-bazaar {
  --kingdom-tint: rgba(255, 230, 125, 0.32);
  --kingdom-tint-2: rgba(255, 159, 28, 0.2);
  --kingdom-accent: #f0a114;
  --kingdom-accent-strong: #ce7d00;
  --kingdom-glow: rgba(255, 238, 174, 0.58);
}

.theme-enigma {
  --kingdom-tint: rgba(198, 176, 255, 0.32);
  --kingdom-tint-2: rgba(102, 113, 214, 0.2);
  --kingdom-accent: #705de0;
  --kingdom-accent-strong: #4f3eb8;
  --kingdom-glow: rgba(227, 212, 255, 0.54);
}

.theme-measure {
  --kingdom-tint: rgba(130, 241, 220, 0.32);
  --kingdom-tint-2: rgba(51, 188, 173, 0.18);
  --kingdom-accent: #1da6a1;
  --kingdom-accent-strong: #0d7f7c;
  --kingdom-glow: rgba(181, 255, 231, 0.55);
}

.theme-chrono {
  --kingdom-tint: rgba(183, 226, 255, 0.32);
  --kingdom-tint-2: rgba(103, 160, 255, 0.2);
  --kingdom-accent: #3f87e7;
  --kingdom-accent-strong: #295fc2;
  --kingdom-glow: rgba(218, 242, 255, 0.55);
}

.theme-dragons {
  --kingdom-tint: rgba(255, 170, 171, 0.28);
  --kingdom-tint-2: rgba(255, 122, 83, 0.2);
  --kingdom-accent: #ea5f47;
  --kingdom-accent-strong: #bf3921;
  --kingdom-glow: rgba(255, 215, 135, 0.58);
}

.rival-card {
  border: 1px solid rgba(18, 52, 76, 0.08);
}

.dashboard-actions button {
  min-width: 150px;
}

.section-title {
  align-items: end;
  margin-bottom: 12px;
}

.map-section {
  display: grid;
  gap: 14px;
}

.map-section-title {
  align-items: center;
}

.map-board {
  position: relative;
  padding: 18px;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(30, 52, 73, 0.92), rgba(18, 37, 56, 0.94));
  border: 3px solid rgba(222, 202, 143, 0.3);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.map-board::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 28px;
  border: 2px dashed rgba(215, 188, 119, 0.2);
  pointer-events: none;
}

.map-board::after {
  content: "🐉";
  position: absolute;
  right: 18px;
  top: 26px;
  font-size: 150px;
  line-height: 1;
  opacity: 0.045;
  transform: rotate(-10deg);
  pointer-events: none;
}

.map-board-frame {
  position: relative;
  --map-columns: 8;
  --map-rows: 8;
  padding: 26px 18px 18px 44px;
  border-radius: 28px;
  background: rgba(243, 233, 202, 0.9);
}

.map-axis {
  position: absolute;
  z-index: 2;
  display: grid;
  gap: 8px;
  color: #fbf0cf;
  font-family: "Avenir Next Condensed", "Trebuchet MS", sans-serif;
  font-weight: 800;
  font-size: 0.9rem;
}

.map-axis-top {
  top: 0;
  left: 44px;
  right: 18px;
  grid-template-columns: repeat(var(--map-columns), minmax(0, 1fr));
  text-align: center;
  transform: translateY(-4px);
}

.map-axis-left {
  top: 26px;
  bottom: 18px;
  left: 0;
  width: 36px;
  align-content: stretch;
  grid-template-rows: repeat(var(--map-rows), minmax(0, 1fr));
  text-align: center;
}

.map-board-canvas {
  position: relative;
  z-index: 1;
  min-height: 1060px;
  padding: 22px 18px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 15% 16%, rgba(255,255,255,0.1), transparent 10%),
    radial-gradient(circle at 82% 20%, rgba(255,255,255,0.08), transparent 10%),
    linear-gradient(rgba(255,255,255,0.16) 2px, transparent 2px),
    linear-gradient(90deg, rgba(255,255,255,0.16) 2px, transparent 2px),
    linear-gradient(180deg, #28556f 0%, #3f8aa4 18%, #567c57 18.5%, #709f64 100%);
  background-size: auto, auto, calc(100% / var(--map-columns)) calc(100% / var(--map-rows)), calc(100% / var(--map-columns)) calc(100% / var(--map-rows)), auto;
  box-shadow: inset 0 0 0 3px rgba(245, 233, 202, 0.54);
  overflow: hidden;
}

.map-board-canvas::before {
  content: "";
  position: absolute;
  inset: 72px 28px 34px 34px;
  border-radius: 44px 58px 54px 64px;
  background:
    radial-gradient(circle at 26% 32%, rgba(255,255,255,0.12), transparent 14%),
    radial-gradient(circle at 72% 72%, rgba(255,255,255,0.08), transparent 16%),
    linear-gradient(180deg, rgba(76, 146, 97, 0.86), rgba(127, 178, 98, 0.84));
  clip-path: polygon(6% 16%, 18% 6%, 34% 8%, 48% 18%, 59% 10%, 79% 12%, 90% 22%, 95% 38%, 98% 52%, 91% 71%, 83% 88%, 62% 95%, 44% 88%, 27% 95%, 11% 88%, 6% 70%, 4% 50%, 5% 34%);
  opacity: 0.92;
  box-shadow: inset 0 0 0 5px rgba(255,255,255,0.72);
}

.map-board-canvas::after {
  content: "";
  position: absolute;
  right: 8%;
  bottom: 12%;
  width: 20%;
  height: 18%;
  border-radius: 42% 58% 54% 46%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.14), transparent 18%),
    linear-gradient(180deg, rgba(112, 153, 79, 0.92), rgba(83, 124, 62, 0.92));
  box-shadow: inset 0 0 0 4px rgba(255,255,255,0.72);
  transform: rotate(-12deg);
  opacity: 0.95;
}

.map-board-header {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  margin-bottom: 20px;
  padding-right: 8px;
  color: #f4ebd0;
}

.map-board-header .small {
  color: #efe3bf;
}

.map-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.map-board-header .mini-card {
  background: rgba(255, 247, 225, 0.92);
}

.map-sticker {
  position: absolute;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  border-radius: 22px;
  background: rgba(255,255,255,0.2);
  font-size: 2.2rem;
}

.sticker-boat {
  top: 120px;
  left: 44%;
}

.sticker-mountain {
  top: 260px;
  left: 16%;
}

.sticker-forest {
  top: 160px;
  right: 15%;
}

.sticker-lighthouse {
  bottom: 108px;
  right: 8%;
}

.sticker-whale {
  top: 34px;
  right: 6%;
}

.sticker-camp {
  bottom: 260px;
  left: 64%;
}

.sticker-beach {
  bottom: 168px;
  left: 36%;
}

.sticker-treasure {
  right: 24%;
  bottom: 6%;
}

.map-path-layer,
.map-spots-grid {
  position: absolute;
  left: 18px;
  right: 18px;
  top: 152px;
  bottom: 20px;
}

.map-path-layer {
  z-index: 2;
  pointer-events: none;
}

.map-path-segment {
  position: absolute;
  height: 10px;
  border-radius: 999px;
  transform-origin: left center;
  background:
    repeating-linear-gradient(
      90deg,
      rgba(227, 198, 110, 0.9) 0 14px,
      rgba(227, 198, 110, 0) 14px 24px
    );
  opacity: 0.88;
}

.map-spots-grid {
  z-index: 3;
}

.map-spot {
  position: absolute;
  left: calc((var(--spot-col) - 1) * (100% / 8) + (100% / 16));
  top: calc((var(--spot-row) - 1) * (100% / 8) + (100% / 16));
  width: min(118px, calc(100% / 5.6));
  transform: translate(-50%, -50%);
  display: grid;
  justify-items: center;
  gap: 7px;
}

.map-spot-pin {
  display: grid;
  place-items: center;
  width: 68px;
  height: 68px;
  border-radius: 999px;
  border: 5px solid rgba(255,244,214,0.95);
  box-shadow: 0 16px 24px rgba(18, 66, 92, 0.16);
}

.map-spot-emoji {
  font-size: 1.65rem;
  line-height: 1;
}

.map-spot-card {
  width: 100%;
  display: grid;
  gap: 5px;
  padding: 8px 8px 9px;
  border-radius: 18px;
  background: rgba(255,250,238,0.84);
  border: 2px solid color-mix(in srgb, var(--kingdom-accent) 35%, white 65%);
  box-shadow: 0 16px 26px rgba(18, 66, 92, 0.12);
  backdrop-filter: blur(8px);
}

.map-spot-card h3 {
  margin-bottom: 0;
  font-size: 0.76rem;
  line-height: 1.15;
  text-wrap: balance;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.map-spot-topic {
  font-weight: 700;
  color: var(--kingdom-accent-strong);
}

.map-spot-card p.small {
  margin-bottom: 0;
  line-height: 1.2;
}

.map-spot-top {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.map-spot-coord,
.map-spot-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 7px;
  border-radius: 999px;
  background: rgba(255,255,255,0.86);
  font-size: 0.64rem;
  font-weight: 800;
}

.map-spot-coord {
  color: var(--kingdom-accent-strong);
  letter-spacing: 0.05em;
}

.map-spot-status {
  color: var(--muted);
}

.map-spot button {
  width: 100%;
  min-height: 30px;
  padding: 6px 9px;
  font-size: 0.76rem;
  white-space: nowrap;
  box-shadow: 0 7px 0 color-mix(in srgb, var(--kingdom-accent-strong) 62%, #3e3e3e 38%), 0 14px 22px rgba(18, 66, 92, 0.16);
}

.map-spot .mini-card {
  padding: 5px 8px;
  font-size: 0.72rem;
  background: rgba(255,255,255,0.78);
}

.map-spot.is-locked .map-spot-card {
  opacity: 0.76;
}

.map-spot.is-completed .map-spot-card {
  background:
    radial-gradient(circle at top right, var(--kingdom-glow), transparent 30%),
    linear-gradient(180deg, rgba(248,255,251,0.98), rgba(238,255,244,0.96));
}

.map-spot-pin.node-active {
  background: linear-gradient(180deg, white, color-mix(in srgb, var(--kingdom-accent) 58%, white 42%));
}

.map-spot-pin.node-completed {
  background: linear-gradient(180deg, white, color-mix(in srgb, var(--kingdom-accent) 42%, #8ee0af 58%));
}

.map-spot-pin.node-locked {
  background: linear-gradient(180deg, #edf5f8, #cfe3ea);
  filter: saturate(0.5);
}

.map-spot.is-final .map-spot-pin {
  box-shadow: 0 0 0 8px rgba(255, 230, 128, 0.35), 0 16px 24px rgba(18, 66, 92, 0.16);
}

.info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.compact-panel,
.compact-card {
  max-width: 100%;
}

.compact-card {
  padding: 14px 16px;
}

.map-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 16px;
}

.world-card {
  min-height: 240px;
  display: grid;
  gap: 12px;
  align-content: start;
  position: relative;
  overflow: hidden;
}

.world-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 7px;
  background: linear-gradient(180deg, var(--accent-2), var(--accent));
}

.world-card.locked-card {
  opacity: 0.62;
}

.world-card.completed-card::before {
  background: linear-gradient(180deg, #1f9d68, #54d39c);
}

.world-route {
  color: var(--muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.world-icon {
  width: 62px;
  height: 62px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, rgba(240,138,36,0.16), rgba(41,167,199,0.14));
  font-size: 1.8rem;
  flex-shrink: 0;
}

.world-card button {
  margin-top: auto;
}

.question-card {
  display: grid;
  gap: 18px;
  text-align: center;
  background:
    radial-gradient(circle at top center, rgba(255,229,159,0.4), transparent 26%),
    var(--panel-strong);
}

.question-text {
  font-size: clamp(1.9rem, 4.8vw, 3rem);
  margin: 18px auto;
  max-width: 860px;
  line-height: 1.15;
}

.story-text {
  font-size: clamp(1.15rem, 2.8vw, 1.7rem);
  line-height: 1.45;
}

.pet-face {
  font-size: 3.4rem;
  line-height: 1;
}

.answer-box {
  max-width: 640px;
  margin: 0 auto;
  gap: 14px;
  width: 100%;
}

.result-banner {
  min-height: 32px;
  font-weight: 700;
  line-height: 1.35;
}

.result-hint {
  color: var(--muted);
}

.answer-review {
  width: min(640px, 100%);
  margin: 0 auto;
  padding: 18px 20px;
  border-radius: 24px;
  border: 2px solid rgba(255,255,255,0.76);
  box-shadow: var(--shadow);
}

.answer-review-success {
  background: linear-gradient(180deg, rgba(226, 255, 240, 0.96), rgba(242, 255, 248, 0.98));
}

.answer-review-error {
  background: linear-gradient(180deg, rgba(255, 238, 238, 0.96), rgba(255, 247, 247, 0.98));
}

.answer-review-title {
  margin-bottom: 10px;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--text);
}

.mini-game-panel,
.secret-panel {
  display: grid;
  gap: 20px;
}

.kingdom-restored {
  display: grid;
  gap: 16px;
}

.kingdom-restored-art,
.kingdom-scene-art {
  display: grid;
  place-items: center;
  min-height: 132px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top center, var(--kingdom-glow), transparent 24%),
    linear-gradient(180deg, color-mix(in srgb, white 90%, var(--kingdom-tint) 10%), color-mix(in srgb, white 86%, var(--kingdom-tint-2) 14%));
  box-shadow: inset 0 0 0 2px rgba(255,255,255,0.84), var(--shadow);
  font-size: clamp(2.8rem, 8vw, 4.6rem);
  letter-spacing: 0.12em;
  animation: bobMap 3.2s ease-in-out infinite;
}

.theme-scene {
  position: relative;
  overflow: hidden;
}

.theme-scene::before,
.theme-scene::after {
  position: absolute;
  display: grid;
  place-items: center;
  opacity: 0.58;
  font-size: 2rem;
}

.theme-scene::before {
  top: 18px;
  right: 22px;
}

.theme-scene::after {
  left: 24px;
  bottom: 18px;
}

.theme-solar.theme-scene::before { content: "☀️"; }
.theme-solar.theme-scene::after { content: "🌼"; }
.theme-stone.theme-scene::before { content: "🪨"; }
.theme-stone.theme-scene::after { content: "🦅"; }
.theme-forest.theme-scene::before { content: "🌲"; }
.theme-forest.theme-scene::after { content: "🦉"; }
.theme-tide.theme-scene::before { content: "⚓"; }
.theme-tide.theme-scene::after { content: "🐬"; }
.theme-windmill.theme-scene::before { content: "🌪️"; }
.theme-windmill.theme-scene::after { content: "🪽"; }
.theme-crystal.theme-scene::before { content: "💠"; }
.theme-crystal.theme-scene::after { content: "🦄"; }
.theme-skyline.theme-scene::before { content: "🏙️"; }
.theme-skyline.theme-scene::after { content: "📘"; }
.theme-moonlagoon.theme-scene::before { content: "🌙"; }
.theme-moonlagoon.theme-scene::after { content: "🐸"; }
.theme-forge.theme-scene::before { content: "⚒️"; }
.theme-forge.theme-scene::after { content: "🛡️"; }
.theme-bazaar.theme-scene::before { content: "🪙"; }
.theme-bazaar.theme-scene::after { content: "🛍️"; }
.theme-enigma.theme-scene::before { content: "🧩"; }
.theme-enigma.theme-scene::after { content: "📜"; }
.theme-measure.theme-scene::before { content: "📏"; }
.theme-measure.theme-scene::after { content: "🧪"; }
.theme-chrono.theme-scene::before { content: "⏱️"; }
.theme-chrono.theme-scene::after { content: "🕊️"; }
.theme-dragons.theme-scene::before { content: "🐉"; }
.theme-dragons.theme-scene::after { content: "🏰"; }

.kingdom-scene-card {
  display: grid;
  grid-template-columns: minmax(180px, 0.8fr) minmax(0, 1.2fr);
  gap: 18px;
  align-items: center;
}

.mini-game-copy {
  display: grid;
  gap: 6px;
}

.mini-game-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.mini-card-button {
  position: relative;
  min-height: 110px;
  border-radius: 28px;
  background: linear-gradient(180deg, #ffffff, color-mix(in srgb, white 68%, var(--kingdom-tint-2) 32%));
  color: var(--text);
  box-shadow: 0 12px 0 color-mix(in srgb, var(--kingdom-accent) 26%, rgba(36, 145, 181, 0.14));
  overflow: hidden;
}

.mini-card-button .mini-card-front,
.mini-card-button .mini-card-back {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 2.4rem;
  transition: opacity 180ms ease, transform 180ms ease;
}

.mini-card-button .mini-card-back {
  opacity: 0;
  transform: scale(0.85);
}

.mini-card-button.is-diamond {
  background: linear-gradient(180deg, #fff7de, color-mix(in srgb, white 60%, var(--kingdom-tint) 40%));
}

.mini-card-button.is-decoy {
  background: linear-gradient(180deg, #f8fcff, color-mix(in srgb, white 74%, var(--kingdom-tint-2) 26%));
}

.mini-card-button.is-diamond .mini-card-front,
.mini-card-button.is-decoy .mini-card-front {
  opacity: 0;
  transform: scale(1.2);
}

.mini-card-button.is-diamond .mini-card-back,
.mini-card-button.is-decoy .mini-card-back {
  opacity: 1;
  transform: scale(1);
}

.secret-hero {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.05fr);
  gap: 24px;
  align-items: center;
}

.secret-orbit {
  position: relative;
  min-height: 360px;
  border-radius: 34px;
  background:
    radial-gradient(circle at center, rgba(255, 240, 160, 0.75), transparent 26%),
    linear-gradient(180deg, rgba(20, 69, 103, 0.98), rgba(8, 33, 54, 0.98));
  overflow: hidden;
}

.secret-core,
.secret-diamond {
  position: absolute;
  display: grid;
  place-items: center;
  border-radius: 999px;
}

.secret-core {
  top: 50%;
  left: 50%;
  width: 116px;
  height: 116px;
  transform: translate(-50%, -50%);
  background: linear-gradient(180deg, #fff9dd, #ffd661);
  box-shadow: 0 0 42px rgba(255, 232, 140, 0.55);
  font-size: 3.5rem;
}

.secret-diamond {
  width: 74px;
  height: 74px;
  background: rgba(255,255,255,0.96);
  box-shadow: 0 10px 18px rgba(9, 28, 44, 0.34);
  color: #0e7698;
  font-size: 1.4rem;
  font-weight: 800;
}

.secret-diamond span {
  font-size: 1.5rem;
  line-height: 1;
}

.secret-diamond strong {
  font-size: 0.78rem;
}

.secret-diamond.locked {
  filter: grayscale(1);
  opacity: 0.72;
}

.secret-diamond.ready {
  animation: orbitGlow 3.4s ease-in-out infinite;
}

.secret-diamond:nth-child(2) { top: 18px; left: 50%; transform: translateX(-50%); }
.secret-diamond:nth-child(3) { top: 72px; right: 32px; }
.secret-diamond:nth-child(4) { top: 50%; right: 12px; transform: translateY(-50%); }
.secret-diamond:nth-child(5) { right: 36px; bottom: 54px; }
.secret-diamond:nth-child(6) { bottom: 18px; left: 50%; transform: translateX(-50%); }
.secret-diamond:nth-child(7) { bottom: 54px; left: 36px; }
.secret-diamond:nth-child(8) { top: 50%; left: 12px; transform: translateY(-50%); }
.secret-diamond:nth-child(9) { top: 72px; left: 32px; }

.secret-copy {
  display: grid;
  gap: 16px;
}

.secret-reward-card {
  padding: 18px;
  border-radius: 24px;
  background: rgba(255,255,255,0.9);
  box-shadow: var(--shadow);
}

@keyframes orbitGlow {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 10px 18px rgba(9, 28, 44, 0.34);
  }
  50% {
    transform: scale(1.07);
    box-shadow: 0 10px 26px rgba(111, 235, 255, 0.5);
  }
}

.challenge-actions {
  justify-content: center;
}

.challenge-actions button {
  min-width: 220px;
}

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

.error-text {
  color: var(--danger);
}

.leader-card,
.mini-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.toast,
.celebration {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  max-width: calc(100vw - 20px);
}

.toast {
  bottom: max(20px, env(safe-area-inset-bottom));
  width: min(620px, calc(100vw - 24px));
  padding: 16px 20px;
  border-radius: 20px;
  background: rgba(18, 66, 92, 0.94);
  color: white;
  box-shadow: var(--shadow);
  text-align: center;
  font-size: 1rem;
  line-height: 1.4;
}

.celebration {
  top: max(16px, env(safe-area-inset-top));
  width: min(560px, calc(100% - 20px));
  padding: 18px;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(255,245,196,0.98));
  box-shadow: var(--shadow);
  text-align: center;
  max-height: calc(100vh - 32px);
  overflow: auto;
}

.topbar .pill {
  background: linear-gradient(180deg, #e6cc84, #b68b3d);
  color: #1d2230;
  border: 2px solid rgba(255,235,181,0.42);
  font-weight: 800;
}

.home-screen {
  gap: 26px;
}

.treasure-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  align-items: start;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 10% 12%, rgba(255, 208, 96, 0.32), transparent 18%),
    radial-gradient(circle at 84% 20%, rgba(101, 217, 255, 0.26), transparent 22%),
    radial-gradient(circle at 34% 82%, rgba(140, 235, 183, 0.22), transparent 18%),
    linear-gradient(180deg, rgba(255, 250, 227, 0.98), rgba(243, 249, 255, 0.96));
  border-color: rgba(255, 215, 102, 0.34);
}

.treasure-hero::before {
  content: "🐉";
  position: absolute;
  right: -12px;
  top: 14px;
  font-size: min(18vw, 180px);
  opacity: 0.08;
  transform: rotate(6deg);
}

.treasure-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 24%, rgba(255,255,255,0.46) 0 22px, transparent 24px),
    radial-gradient(circle at 72% 12%, rgba(255,255,255,0.38) 0 18px, transparent 20px),
    radial-gradient(circle at 86% 62%, rgba(255,255,255,0.26) 0 20px, transparent 22px);
  pointer-events: none;
  opacity: 0.8;
}

.treasure-copy,
.treasure-map {
  position: relative;
  z-index: 1;
}

.treasure-copy {
  display: grid;
  gap: 18px;
  align-content: start;
  max-width: 860px;
}

.treasure-copy h2 {
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: 1.05;
  margin-bottom: 0;
  color: #163d58;
}

.treasure-copy p:not(.eyebrow) {
  font-size: 1.08rem;
  color: #45667f;
  max-width: 46rem;
}

.treasure-copy .eyebrow {
  color: #1b8eb7;
}

.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.home-pill {
  background: rgba(255, 246, 221, 0.94);
}

.treasure-map {
  min-height: 600px;
  border-radius: 36px;
  background:
    linear-gradient(180deg, #6fd9ff 0%, #57c6f1 18%, #5fd0da 18.5%, #2fa1c0 100%);
  border: 4px solid rgba(255, 244, 194, 0.72);
  overflow: hidden;
  box-shadow: inset 0 -14px 0 rgba(255,255,255,0.14);
}

.map-paper {
  position: absolute;
  inset: 72px 40px 34px;
  border-radius: 42px 52px 40px 50px;
  background:
    radial-gradient(circle at 18% 28%, rgba(123, 171, 98, 0.34), transparent 18%),
    radial-gradient(circle at 72% 34%, rgba(96, 165, 86, 0.28), transparent 20%),
    radial-gradient(circle at 54% 74%, rgba(77, 137, 73, 0.24), transparent 16%),
    linear-gradient(transparent 0 100%),
    linear-gradient(180deg, #f0d596, #c9a055);
  border: 4px solid rgba(255,236,188,0.58);
  box-shadow:
    inset 0 0 0 2px rgba(120, 77, 15, 0.24),
    0 18px 30px rgba(6, 20, 30, 0.34);
  transform: rotate(-3deg);
}

.map-paper::before,
.map-paper::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.map-paper::before {
  inset: 34px 58px 44px 44px;
  border-radius: 41% 59% 53% 47% / 48% 41% 59% 52%;
  background:
    radial-gradient(circle at 14% 72%, rgba(106, 161, 89, 0.34), transparent 16%),
    radial-gradient(circle at 28% 24%, rgba(121, 179, 99, 0.3), transparent 18%),
    radial-gradient(circle at 76% 24%, rgba(120, 169, 105, 0.26), transparent 18%),
    radial-gradient(circle at 80% 72%, rgba(93, 145, 83, 0.24), transparent 16%);
  border: 2px solid rgba(129, 99, 36, 0.22);
  opacity: 0.85;
}

.map-paper::after {
  inset: 18px;
  border-radius: 34px 42px 36px 40px;
  background:
    linear-gradient(rgba(133, 94, 28, 0.14) 0 0) 16% 0 / 2px 100% no-repeat,
    linear-gradient(rgba(133, 94, 28, 0.14) 0 0) 36% 0 / 2px 100% no-repeat,
    linear-gradient(rgba(133, 94, 28, 0.14) 0 0) 56% 0 / 2px 100% no-repeat,
    linear-gradient(rgba(133, 94, 28, 0.14) 0 0) 76% 0 / 2px 100% no-repeat,
    linear-gradient(rgba(133, 94, 28, 0.14) 0 0) 0 24% / 100% 2px no-repeat,
    linear-gradient(rgba(133, 94, 28, 0.14) 0 0) 0 48% / 100% 2px no-repeat,
    linear-gradient(rgba(133, 94, 28, 0.14) 0 0) 0 72% / 100% 2px no-repeat;
  opacity: 0.38;
}

.map-tag,
.map-compass,
.map-stop,
.map-boat,
.map-route {
  position: absolute;
}

.map-tag {
  top: 22px;
  left: 26px;
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(251, 233, 183, 0.94);
  color: #53380e;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.map-compass,
.map-boat {
  display: grid;
  place-items: center;
  width: 82px;
  height: 82px;
  border-radius: 24px;
  background: rgba(255,246,217,0.9);
  box-shadow: 0 16px 24px rgba(8, 21, 32, 0.28);
  font-size: 2.2rem;
}

.map-compass {
  top: 24px;
  right: 26px;
}

.map-boat {
  left: 24px;
  bottom: 26px;
}

.map-route {
  height: 0;
  border-top: 5px dashed rgba(91, 53, 4, 0.58);
  transform-origin: left center;
}

.route-one {
  top: 31%;
  left: 23%;
  width: 14%;
  transform: rotate(-12deg);
}

.route-two {
  top: 31%;
  left: 43%;
  width: 16%;
  transform: rotate(28deg);
}

.route-three {
  top: 47%;
  left: 49%;
  width: 12%;
  transform: rotate(108deg);
}

.route-four {
  top: 62%;
  left: 58%;
  width: 12%;
  transform: rotate(-14deg);
}

.route-five {
  top: 30%;
  left: 79%;
  width: 12%;
  transform: rotate(-76deg);
}

.map-stop {
  display: grid;
  justify-items: center;
  gap: 5px;
  width: 148px;
  padding: 14px 12px 12px;
  border-radius: 24px;
  background: rgba(255,246,223,0.94);
  color: #28394c;
  text-align: center;
  box-shadow: 0 16px 24px rgba(8, 21, 32, 0.28);
  animation: bobMap 3.2s ease-in-out infinite;
  border: 2px solid rgba(126, 90, 27, 0.1);
}

.map-stop span {
  font-size: 1.65rem;
  line-height: 1;
}

.map-stop strong {
  display: block;
  font-size: 0.94rem;
  line-height: 1.08;
  text-wrap: balance;
}

.map-stop small {
  font-size: 0.72rem;
  letter-spacing: 0.03em;
  line-height: 1.15;
  color: #6b5330;
}

.stop-one {
  top: 28%;
  left: 8%;
}

.stop-two {
  top: 20%;
  left: 34%;
  animation-delay: 0.4s;
}

.stop-three {
  top: 41%;
  right: 8%;
  animation-delay: 0.8s;
}

.stop-four {
  top: 61%;
  left: 49%;
  animation-delay: 1.2s;
}

.stop-five {
  top: 62%;
  right: 20%;
  animation-delay: 1.6s;
}

.stop-six {
  top: 12%;
  right: 6%;
  animation-delay: 2s;
}

.stop-treasure {
  background: linear-gradient(180deg, #fff7d8, #ffd37a);
}

.home-section-title {
  align-items: center;
}

.home-screen .section-title h3 {
  color: #f7f0da;
}

.home-profile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
  gap: 18px;
}

.home-profile-grid .profile-card {
  flex: initial;
}

.map-profile-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 12px;
  align-content: start;
  min-height: 100%;
  background:
    radial-gradient(circle at top right, rgba(255, 241, 167, 0.64), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(255,248,222,0.98));
}

.map-profile-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 10px;
  background: linear-gradient(180deg, #ffb31d, #ff7e6f, #2dcc8e);
}

.profile-sticker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.9);
  color: #0f7a9c;
  font-weight: 800;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.home-empty {
  display: grid;
  gap: 16px;
  place-items: start;
  text-align: left;
  background:
    radial-gradient(circle at top right, rgba(255, 236, 151, 0.5), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,247,215,0.98));
}

@keyframes bobMap {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-6px);
  }
}

.hidden {
  display: none !important;
}

.confetti {
  animation: floatBurst 900ms ease-out forwards;
}

@keyframes floatBurst {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(-6px) scale(1.02);
  }
}

.noscript-banner {
  margin: 16px auto;
  width: min(720px, calc(100% - 24px));
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--text);
  box-shadow: var(--shadow);
}

@media (max-width: 1100px) {
  .hero,
  .profile-hero,
  .info-grid,
  .treasure-hero,
  .kingdom-scene-card,
  .secret-hero {
    grid-template-columns: 1fr;
  }

  .create-layout {
    grid-template-columns: 1fr;
  }

  .create-heading {
    flex-direction: column;
    align-items: flex-start;
  }

  .map-axis {
    display: none;
  }

  .treasure-map {
    min-height: 520px;
  }

  .map-board-frame {
    padding: 14px;
  }

  .map-board-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .map-legend {
    justify-content: flex-start;
  }

  .map-board-canvas {
    min-height: auto;
    padding: 18px 14px 16px;
  }

  .map-board-canvas::before {
    inset: 104px 18px 18px;
  }

  .map-board-canvas::after {
    width: 26%;
    height: 14%;
  }

  .map-path-layer {
    display: none;
  }

  .map-spots-grid {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-top: 18px;
  }

  .map-spot {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    transform: none;
    align-items: start;
  }

  .map-spot-card {
    height: 100%;
    padding: 12px;
  }

  .map-spot-card h3 {
    font-size: 0.92rem;
  }

  .map-spot button {
    min-height: 34px;
    font-size: 0.84rem;
  }

  .section-title,
  .topbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .button-row button,
  .dashboard-actions button {
    width: 100%;
    min-width: 0;
  }

  .challenge-actions button {
    width: 100%;
  }

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

@media (max-width: 600px) {
  .app-shell {
    width: min(100%, calc(100% - 12px));
  }

  .panel,
  .card,
  .world-card,
  .profile-card,
  .leader-card,
  .question-card {
    padding: 16px;
    border-radius: 22px;
  }

  .treasure-map {
    min-height: 440px;
  }

  .map-paper {
    inset: 72px 18px 26px;
  }

  .map-compass,
  .map-boat {
    width: 58px;
    height: 58px;
    border-radius: 20px;
    font-size: 1.6rem;
  }

  .map-stop {
    width: 104px;
    padding: 10px 8px;
  }

  .stop-one {
    top: 26%;
    left: 4%;
  }

  .stop-two {
    top: 19%;
    left: 30%;
  }

  .stop-three {
    top: 42%;
    right: 4%;
  }

  .stop-four {
    top: 64%;
    left: 40%;
  }

  .stop-five {
    top: 67%;
    right: 14%;
  }

  .stop-six {
    top: 12%;
    right: 2%;
  }

  .route-one {
    top: 31%;
    left: 23%;
    width: 14%;
  }

  .route-two {
    top: 30%;
    left: 47%;
    width: 14%;
    transform: rotate(30deg);
  }

  .route-three {
    top: 48%;
    left: 50%;
    width: 14%;
    transform: rotate(110deg);
  }

  .route-four {
    top: 67%;
    left: 56%;
    width: 12%;
    transform: rotate(-8deg);
  }

  .route-five {
    top: 31%;
    left: 81%;
    width: 12%;
    transform: rotate(-74deg);
  }

  .world-header {
    align-items: flex-start;
  }

  .avatar-picker {
    grid-template-columns: repeat(auto-fit, minmax(94px, 1fr));
  }

  .avatar-option {
    min-height: 112px;
    padding: 12px 8px;
  }

  .avatar-option small {
    font-size: 0.86rem;
  }

  .create-panel,
  .create-section,
  .create-preview-card,
  .create-tip-card {
    padding: 16px;
  }

  .create-preview-avatar {
    width: 96px;
    height: 96px;
    border-radius: 28px;
    font-size: 3rem;
  }

  .map-board {
    padding: 16px;
  }

  .map-board-frame {
    padding: 10px;
  }

  .map-board-canvas {
    min-height: auto;
  }

  .map-spot-card {
    padding: 16px;
  }

  .map-spot-pin {
    width: 64px;
    height: 64px;
    border-width: 4px;
  }

  .map-spot-emoji {
    font-size: 1.6rem;
  }

  .map-spot-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .map-sticker {
    width: 56px;
    height: 56px;
    border-radius: 18px;
    font-size: 1.7rem;
  }

  .brand-subtitle {
    font-size: 0.92rem;
  }

  .mini-game-grid {
    grid-template-columns: 1fr;
  }

  .mini-card-button {
    min-height: 88px;
  }

  .secret-orbit {
    min-height: 320px;
  }

  .secret-core {
    width: 92px;
    height: 92px;
    font-size: 2.8rem;
  }

  .secret-diamond {
    width: 62px;
    height: 62px;
  }
}
