h1 {
  margin:7px 0 0;
  font-size:29px;
  line-height:.96;
  letter-spacing:-.075em;
  font-weight:800;
}

.statGrid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:5px;
  margin-top:6px;
}

.statTile {
  padding:6px 7px;
  min-height:44px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow-sm);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}

.statLabel {
  font-size:9px;
  line-height:1;
  color:#7b8794;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.1em;
  opacity:.78;
}

.statValue {
  margin-top:2px;
  font-size:19px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.04em;
}

.statValue.bump { animation:bump .28s ease; }
@keyframes bump {
  0% { transform:scale(1); }
  40% { transform:scale(1.12); }
  100% { transform:scale(1); }
}

.sectionHeader {
  padding:9px 10px 7px;
  border-bottom:1px solid var(--line);
  display:flex;
  flex-direction:column;
  gap:3px;
}
.sectionTitle {
  display:flex;
  align-items:center;
  gap:8px;
  font-size:21px;
  line-height:1;
  font-weight:800;
  letter-spacing:-.05em;
}
.sectionTitle .icon {
  width:17px;
  height:17px;
  color:#334155;
  transform:translateY(-1px);
}
.sectionSub {
  color:var(--muted);
  opacity:.64;
  font-size:11px;
  line-height:1.35;
  text-wrap:pretty;
}
.sectionBody {
  padding:7px;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.02));
}

.plateGrid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:5px;
}
.sectionLabel {
  grid-column:1/-1;
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#71839b;
  margin:2px 0;
  padding-top:2px;
}
.sectionLabel.spaced { margin-top:8px; }

.plate.tap { animation:tapFlash .20s ease; }
@keyframes tapFlash {
  0% { filter:brightness(1); }
  50% { filter:brightness(1.08); }
  100% { filter:brightness(1); }
}

.empty {
  grid-column:1/-1;
  color:var(--muted);
  padding:8px 0;
  font-size:12px;
}

.stateLabel { fill:#0f172a; font-size:9px; font-weight:800; pointer-events:none; text-anchor:middle; dominant-baseline:middle; }

.infoCard {
  padding:8px 9px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow-sm);
  font-size:13px;
  line-height:1.38;
}

/* Stronger mission visibility */

}

.state.mission .stateLabel{
  fill:#7a4d0b;
  font-weight:900;
}

/* Clear mission target language */

/* Target button system */

}

}

/* Final canonical target button system */

}

/* Final canonical mission styles */

}

/* Final canonical tracker cell system */

/* Leaderboard fallback card */

/* Map target highlight only */

.targetBtn{
  background:linear-gradient(180deg,#fff8ec,#fff3d6);
  border-color:rgba(183,121,31,.24);
  color:#8a5a12;
  box-shadow:none;
}
.targetBtn:hover{
  border-color:rgba(183,121,31,.34);
}
.targetButtonInner{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.targetButtonLabel{
  opacity:.82;
}
.targetButtonCode{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  height:24px;
  padding:0 8px;
  border-radius:999px;
  border:1px solid rgba(183,121,31,.22);
  background:rgba(255,255,255,.78);
  color:#7a4d0b;
  font-size:11px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.targetButtonPulse{ animation:targetButtonPulse .85s ease; }
@keyframes targetButtonPulse{
  0%{ transform:scale(1); box-shadow:none; }
}

.missionCompact{
  display:grid;
  gap:4px;
  padding:8px;
  border-radius:12px;
  border:1px solid rgba(183,121,31,.28);
  background:
    radial-gradient(240px 130px at 12% 0%, rgba(245,158,11,.13), transparent 60%),
    linear-gradient(180deg,#fffdf8,#fff8ec);
  box-shadow:0 8px 20px rgba(183,121,31,.08);
}
.missionCap{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#8a5a12;
}
.missionName{
  font-size:20px;
  line-height:1;
  font-weight:800;
  letter-spacing:-.05em;
  color:#6f4609;
  text-wrap:balance;
}
.missionHint{
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:fit-content;
  padding:5px 8px;
  border-radius:999px;
  border:1px solid rgba(183,121,31,.22);
  background:rgba(255,255,255,.72);
  color:#8a5a12;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.missionText{
  font-size:12px;
  line-height:1.35;
  color:#7a5b2d;
}
.missionPulse{ animation:missionPulse 1.1s ease; }
@keyframes missionPulse{
  0%{ box-shadow:0 0 0 0 rgba(245,158,11,.24), 0 8px 20px rgba(183,121,31,.08); transform:translateY(0); }
}

.plate{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:8px;
  padding:8px 9px;
  min-height:52px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow-sm);
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.plate:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 18px rgba(15,23,42,.08);
}
.plate:active{ transform:scale(.985); }
.plateMain{
  display:grid;
  gap:2px;
  min-width:0;
}
.plateCode{
  font-size:15px;
  font-weight:900;
  letter-spacing:-.03em;
  line-height:1;
  color:var(--text);
}
.plateName{
  font-size:11px;
  line-height:1.15;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.plateMark{
  width:18px;
  height:18px;
  border-radius:999px;
  border:1.5px solid #c7d0dc;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}
.plateMark::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:transparent;
}
.plate.found{
  background:linear-gradient(180deg,#f3f9ff,#ebf4ff);
  border-color:#9ec5ff;
}
.plate.found .plateMark{
  border-color:#3b82f6;
}
.plate.found .plateMark::before{
  background:#3b82f6;
}
.plate.mission:not(.found){
  background:linear-gradient(180deg,#fffaf1,#fff4df);
  border-color:rgba(183,121,31,.42);
  box-shadow:0 0 0 2px rgba(245,158,11,.10), 0 8px 16px rgba(183,121,31,.08);
}
.plate.mission:not(.found) .plateCode{
  color:#8a5a12;
}
.plate.mission:not(.found) .plateName{
  color:#7a5b2d;
}
.plate.mission:not(.found) .plateMark{
  border-color:#b7791f;
}
.plate.mission:not(.found) .plateMark::before{
  background:#b7791f;
}

.emptyPlayer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:8px 9px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow-sm);
}

.state.mission .shape{
  fill:#fff7e8;
  stroke:#b7791f !important;
  stroke-width:3.5 !important;
  filter:drop-shadow(0 0 9px rgba(245,158,11,.22));
}

/* Final harmony pass */
.targetBtn{
  background:linear-gradient(180deg,#fffaf1,#fff6e6) !important;
  border-color:rgba(183,121,31,.18) !important;
  color:#7a5420 !important;
}
.targetBtn:hover{
  border-color:rgba(183,121,31,.28) !important;
}
.targetButtonCode{
  min-width:32px !important;
  height:22px !important;
  font-size:10px !important;
  border-color:rgba(183,121,31,.18) !important;
}
.controls{
  gap:7px !important;
  padding:8px !important;
}
.fieldRow{
  gap:5px !important;
}
.startRow{
  gap:5px !important;
  padding:7px !important;
}
.actionRail{
  gap:5px !important;
}
.saveBanner{
  padding:7px 8px !important;
}
.topMetaRow{
  gap:7px !important;
}

/* FINAL cell refinement (no map changes) */
.plate{
  min-height:46px !important;
  padding:6px 8px !important;
}
.plateMain{
  gap:1px !important;
}
.plateMark{
  width:20px !important;
  height:20px !important;
  border-width:2px !important;
}
.plate:hover{
  transform:scale(1.01) !important;
}
.plate.mission:not(.found){
  box-shadow:0 0 0 2px rgba(245,158,11,.14), 0 6px 14px rgba(183,121,31,.08) !important;
}

/* Premium first-visit intro overlay */

.introTop,
.introPanel,
.introQuote,

.introPanel{
  border:1px solid rgba(15,23,42,.07);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,249,253,.88));
  padding:14px;
  display:grid;
  gap:12px;
}
.introEyebrow{
  font-size:10px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#7b8794;
}
.introSteps{
  display:grid;
  gap:10px;
}
.introStep{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:12px;
  align-items:start;
}
.introStepNum{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.08);
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:900;
  letter-spacing:.06em;
  color:#607084;
  flex:0 0 auto;
}
.introStepTitle{
  font-size:14px;
  line-height:1.15;
  font-weight:850;
  color:#0f172a;
}
.introStepText{
  margin-top:3px;
  font-size:13px;
  line-height:1.45;
  color:#566476;
}

.introPanel{
    padding:16px;
  }
  .introSteps{
    grid-template-columns:repeat(3,1fr);
    gap:12px;
  }
  .introStep{
    grid-template-columns:1fr;
    gap:10px;
  }
}

/* Compact premium first-visit intro overlay */
body.intro-open{
  overflow:hidden;
}
.introOverlay{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  background:
    radial-gradient(760px 380px at 18% -8%, rgba(10,132,255,.16), transparent 58%),
    radial-gradient(760px 380px at 118% 112%, rgba(245,158,11,.12), transparent 58%),
    linear-gradient(180deg, rgba(9,14,23,.74), rgba(9,14,23,.66));
  backdrop-filter:blur(12px);
}
.introOverlay.hidden{
  display:none !important;
}
.introShell{
  position:relative;
  width:100%;
  max-width:580px;
}
.introGlow{
  position:absolute;
  border-radius:999px;
  filter:blur(28px);
  pointer-events:none;
  opacity:.9;
}
.introGlowBlue{
  width:220px;
  height:220px;
  top:-44px;
  left:-34px;
  background:rgba(10,132,255,.14);
}
.introGlowGold{
  width:180px;
  height:180px;
  right:-24px;
  bottom:-24px;
  background:rgba(245,158,11,.12);
}
.introCard{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.52);
  background:linear-gradient(180deg, rgba(255,255,255,.985), rgba(247,250,255,.965));
  box-shadow:
    0 40px 72px rgba(15,23,42,.28),
    0 16px 30px rgba(15,23,42,.12);
  padding:20px 18px 16px;
  display:grid;
  gap:12px;
}
.introTop,.introPress,.introMiniGrid,.introQuote,.introActions{
  position:relative;
  z-index:1;
}
.introTop{
  display:grid;
  gap:8px;
}
.introBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:fit-content;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.08);
  background:rgba(255,255,255,.9);
  color:#607084;
  font-size:10px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.introTitle{
  margin:0;
  font-size:28px;
  line-height:.96;
  letter-spacing:-.065em;
  font-weight:900;
  color:#0f172a;
  max-width:14ch;
}
.introSub{
  margin:0;
  color:#566476;
  font-size:13px;
  line-height:1.45;
  max-width:48ch;
}
.introPress{
  border:1px solid rgba(15,23,42,.07);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,249,253,.88));
  padding:10px 12px;
  display:grid;
  gap:4px;
}
.introPressKicker{
  font-size:10px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#7b8794;
}
.introPressText{
  font-size:12px;
  line-height:1.45;
  color:#4b5563;
}
.introInlineQuote{
  display:inline;
  margin:0 2px;
  font-weight:900;
  color:#0f172a;
}
.introPressPunch{
  font-weight:800;
  color:#0a84ff;
}
.introMiniGrid{
  display:grid;
  gap:8px;
}
.introMiniCard{
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(15,23,42,.07);
  background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(246,248,252,.90));
  display:grid;
  gap:4px;
}
.introMiniTitle{
  font-size:12px;
  font-weight:850;
  color:#0f172a;
  line-height:1.1;
}
.introMiniText{
  font-size:12px;
  line-height:1.35;
  color:#566476;
}
.introQuote{
  padding:11px 13px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,249,237,.95), rgba(255,245,226,.92));
  border:1px solid rgba(183,121,31,.14);
  font-size:14px;
  line-height:1.32;
  letter-spacing:-.01em;
  font-weight:820;
  color:#7a5420;
}
.introActions{
  display:grid;
  gap:8px;
}
.introPrimary{
  min-height:46px;
  border-radius:14px;
  border:1px solid rgba(10,132,255,.26);
  background:linear-gradient(180deg,#1c99ff,#0a84ff);
  color:#fff;
  font-size:14px;
  font-weight:900;
  letter-spacing:-.01em;
  box-shadow:
    0 16px 28px rgba(10,132,255,.26),
    inset 0 1px 0 rgba(255,255,255,.26);
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease;
}
.introPrimary:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 30px rgba(10,132,255,.30);
}
.introPrimary:active{
  transform:scale(.985);
}
.introNote{
  font-size:10px;
  line-height:1.35;
  color:#667085;
  text-align:center;
}
@media (min-width:760px){
  .introCard{
    padding:22px 20px 18px;
    gap:13px;
  }
  .introTitle{
    font-size:30px;
  }
  .introMiniGrid{
    grid-template-columns:repeat(3,1fr);
  }
}

/* Clean collapsible sections */
.sectionTitleSm{ font-size:18px; }

/* Subtle gameplay feedback */
.plate{
  transition:transform .08s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.plate.tap{
  transform:scale(.985);
}
.plate:hover{
  transform:translateY(-1px);
}
.state{
  transition:filter .12s ease, opacity .12s ease;
}

.targetFlash{
  animation:targetFlashPulse .45s ease;
}
@keyframes targetFlashPulse{
  0%{ transform:scale(1); }
  40%{ transform:scale(1.02); }
  100%{ transform:scale(1); }
}


/* Option A polish pass */
.plate{
  will-change:transform;
}
.plate.found{
  box-shadow:0 8px 18px rgba(16,185,129,.08);
}
.plate.mission:not(.found){
  box-shadow:0 10px 22px rgba(183,121,31,.10);
}
.plate.tap{
  animation:plateTapFeedback .16s ease;
}
@keyframes plateTapFeedback{
  0%{ transform:scale(1); }
  50%{ transform:scale(.975); }
  100%{ transform:scale(1); }
}

.state.mission{
  filter:drop-shadow(0 4px 10px rgba(183,121,31,.16));
}

.leader{
  transition:transform .10s ease, box-shadow .12s ease, border-color .12s ease;
}
.leader:hover{
  transform:translateY(-1px);
}
