@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=Barlow:wght@300;400;500;600&display=swap');

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

:root{
  --bg:#08090d; --bg2:#0d1018; --bg3:#111520;
  --surf:#161b28; --surf2:#1d2435;
  --border:rgba(255,255,255,0.06); --border2:rgba(255,255,255,0.12);
  --text:#eef0f5; --muted:#6a7490;
  --orange:#f47c20; --orange-b:#ff8c2a;
  --found:#34c759; --cold:#3db8f5; --warn:#ffcc00;
  --r:10px;
}

html,body{height:100%;background:var(--bg);font-family:'Barlow',sans-serif;color:var(--text);overflow:hidden;-webkit-font-smoothing:antialiased}

#app{
  width:100%;max-width:430px;height:100dvh;
  margin:0 auto;background:var(--bg);
  display:flex;flex-direction:column;overflow:hidden;
  padding-top:env(safe-area-inset-top);
  padding-bottom:env(safe-area-inset-bottom);
}

.google-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  background: white;
  color: #3c4043;
  border: none;
  border-radius: 8px;
  padding: 13px 16px;
  font-family: 'Barlow', sans-serif;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  margin-bottom: 4px;
}
.google-btn:hover { background: #f8f8f8; transform: translateY(-1px); }
.google-btn:active { transform: scale(0.98); }
.auth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 14px 0;
  color: var(--muted);
  font-size: 12px;
}
.auth-divider::before, .auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border2);
}

/* ── SIGNUP SCREEN ── */
#signup-screen {
  position: absolute;
  inset: 0;
  z-index: 200;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.signup-inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 48px 24px 36px;
  min-height: 100%;
}
.signup-logo {
  margin-bottom: 28px;
}
.signup-brand {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 26px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text);
}
.signup-brand span { color: var(--orange); }
.signup-brand-sub {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-top: 2px;
}
.signup-brand-sub strong { color: var(--orange); font-weight: 600; }
.signup-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 48px;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 0.95;
  color: var(--text);
  margin-bottom: 14px;
}
.signup-title span { color: var(--orange); }
.signup-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.65;
  margin-bottom: 24px;
}
.signup-bonus-badge {
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(244,124,32,0.08);
  border: 1px solid rgba(244,124,32,0.25);
  border-radius: var(--r);
  padding: 14px 16px;
  margin-bottom: 28px;
}
.signup-bonus-icon { font-size: 28px; flex-shrink: 0; }
.signup-bonus-val {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px;
  font-weight: 900;
  color: var(--orange);
  letter-spacing: 0.5px;
}
.signup-bonus-lbl { font-size: 12px; color: var(--muted); margin-top: 2px; }
.signup-form { display: flex; flex-direction: column; gap: 14px; }
.signup-field { display: flex; flex-direction: column; gap: 6px; }
.signup-label {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
}
.signup-optional { font-weight: 400; letter-spacing: 0; text-transform: none; opacity: 0.7; }
.signup-input {
  background: var(--surf);
  border: 1px solid var(--border2);
  border-radius: 8px;
  padding: 14px 16px;
  font-size: 16px;
  color: var(--text);
  font-family: 'Barlow', sans-serif;
  outline: none;
  transition: border-color 0.2s;
  -webkit-appearance: none;
}
.signup-input::placeholder { color: var(--muted); opacity: 0.6; }
.signup-input:focus { border-color: var(--orange); }
.signup-input.input-error { border-color: #ff4444; }
.signup-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  background: var(--orange);
  color: #08090d;
  border: none;
  border-radius: 8px;
  padding: 16px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 2px;
  cursor: pointer;
  transition: all 0.2s;
  margin-top: 4px;
}
.signup-btn:hover { background: var(--orange-b); transform: translateY(-1px); }
.signup-btn:active { transform: scale(0.98); }
.signup-terms {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.5;
  text-align: center;
  opacity: 0.7;
}
.signup-bmaz-note {
  margin-top: auto;
  padding-top: 28px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.6;
  border-top: 1px solid var(--border);
}

/* ── TOPBAR ── */
.topbar{height:56px;min-height:56px;flex-shrink:0;padding:0 18px;display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-bottom:1px solid var(--border);z-index:50}
.brand-name{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:900;text-transform:uppercase;letter-spacing:1px;color:var(--text)}
.brand-name span{color:var(--orange)}
.brand-sub{font-size:9px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:2px}
.brand-sub strong{color:var(--orange);font-weight:600}
.tracks-chip{display:flex;align-items:center;gap:6px;background:var(--surf);border:1px solid rgba(244,124,32,0.25);border-radius:20px;padding:6px 12px}
#pts{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;color:var(--orange)}
.tracks-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}

/* ── DEV BANNER ── */
#dev-banner{flex-shrink:0;background:#1a0d00;border-bottom:1px solid rgba(244,124,32,0.35);padding:5px 16px;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;color:var(--orange)}
#dev-banner button{background:rgba(244,124,32,0.15);border:1px solid rgba(244,124,32,0.3);color:var(--orange);border-radius:4px;padding:3px 10px;font-size:10px;cursor:pointer;font-family:'Barlow',sans-serif;text-transform:uppercase;letter-spacing:1px}

/* ── SCREEN WRAP & SCREENS ── */
.screen-wrap{flex:1;position:relative;overflow:hidden;min-height:0}
.screen{
  position:absolute;inset:0;
  overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;
  opacity:0;pointer-events:none;
  transform:translateX(100%);
  transition:transform 0.4s cubic-bezier(0.76,0,0.24,1), opacity 0.3s ease;
  will-change:transform;
  padding-bottom:20px;
}
/* Home starts visible */
#s-home{transform:translateX(0);opacity:1;pointer-events:auto}
#s-camera,#s-map{overflow:hidden;padding-bottom:0}

/* ── BOTTOM NAV ── */
.bnav{height:56px;min-height:56px;flex-shrink:0;display:flex;background:var(--bg);border-top:1px solid var(--border);z-index:50}
.nb{flex:1;background:none;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--muted);font-family:'Barlow',sans-serif;font-size:10px;letter-spacing:1px;text-transform:uppercase;transition:color 0.2s}
.nb.on{color:var(--orange)}
.nb svg{width:20px;height:20px;stroke:currentColor}

/* ── HOME ── */
.hero {
  position: relative;
  padding: 22px 18px 20px;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  background: linear-gradient(135deg, #08090d 40%, #110d06);
  min-height: 220px;
}
.hero-glow {
  position: absolute;
  bottom: -50px; right: -30px;
  width: 280px; height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(244,124,32,0.09) 0%, transparent 70%);
  pointer-events: none;
}
.hero-silhouette {
  position: absolute;
  right: -5px;
  bottom: -5px;
  width: 140px;
  height: auto;
  pointer-events: none;
  opacity: 1;
}

/* ── REVIEW ── */
.review-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 40px 24px 32px;
  min-height: 100%;
}
.review-header { text-align: center; margin-bottom: 32px; }
.review-h-emoji { font-size: 56px; margin-bottom: 14px; animation: burst 0.5s ease both; }
.review-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 36px; font-weight: 900;
  text-transform: uppercase; color: var(--text);
  letter-spacing: 1px;
}
.review-sub { font-size: 13px; color: var(--muted); margin-top: 6px; }
.review-stars {
  display: flex; gap: 10px; margin-bottom: 16px;
}
.star {
  font-size: 52px;
  color: var(--surf2);
  cursor: pointer;
  transition: color 0.15s, transform 0.15s;
  line-height: 1;
  -webkit-text-stroke: 1px rgba(244,124,32,0.3);
}
.star:hover { transform: scale(1.15); color: rgba(244,124,32,0.5); }
.star.active { color: var(--orange); -webkit-text-stroke: none; }
.review-rating-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px; font-weight: 700;
  color: var(--muted); margin-bottom: 20px;
  min-height: 28px; transition: color 0.2s;
}
.review-comment-wrap { width: 100%; margin-bottom: 14px; }
.review-textarea {
  width: 100%;
  background: var(--surf);
  border: 1px solid var(--border2);
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 14px;
  color: var(--text);
  font-family: 'Barlow', sans-serif;
  resize: none;
  outline: none;
}
.review-textarea:focus { border-color: var(--orange); }
.review-share-prompt { width: 100%; margin-bottom: 14px; }
.review-share-msg {
  font-size: 14px; color: var(--text);
  text-align: center; margin-bottom: 12px;
  font-weight: 500;
}
.hero-content { position: relative; z-index: 2; max-width: 220px; }
.hero-eyebrow { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--orange); font-weight: 600; margin-bottom: 10px; }
.hero-title { font-family: 'Barlow Condensed', sans-serif; font-size: 44px; font-weight: 900; line-height: 0.95; text-transform: uppercase; color: var(--text); }
.hero-title span { color: var(--orange); }
.hero-desc { margin-top: 12px; font-size: 13px; color: var(--muted); line-height: 1.6; }
.hero-stats { display: flex; gap: 20px; margin-top: 16px; }
.hero-stat-val { font-family: 'Barlow Condensed', sans-serif; font-size: 28px; font-weight: 900; color: var(--orange); }
.hero-stat-lbl { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; }
.sec-label{padding:14px 18px 6px;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}
.town-card{margin:0 14px 8px;border-radius:var(--r);background:var(--surf);border:1px solid var(--border);padding:13px 15px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all 0.2s}
.town-card:hover{border-color:rgba(244,124,32,0.35);background:var(--surf2)}
.town-card.locked{opacity:0.5;cursor:pointer;}
.t-bar-left{width:3px;border-radius:2px;align-self:stretch;background:var(--orange);flex-shrink:0}
.t-bar-left.dim{background:var(--surf2)}
.t-body{flex:1;min-width:0}
.t-name{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:0.5px}
.t-name.muted{color:var(--muted)}
.t-meta{font-size:11px;color:var(--muted);margin-top:2px}
.t-prog{height:2px;background:rgba(255,255,255,0.05);border-radius:2px;margin-top:8px;overflow:hidden}
.t-prog div{height:100%;background:var(--orange);border-radius:2px;transition:width 0.6s}
.t-count{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;color:var(--orange);flex-shrink:0}
.lock-icon svg{width:14px;height:14px;stroke:var(--muted)}
.bmaz-strip{margin:14px 14px 20px;border-radius:var(--r);background:linear-gradient(135deg,var(--surf),#1a1208);border:1px solid rgba(244,124,32,0.18);padding:14px 16px;display:flex;align-items:center;gap:14px}
.bmaz-strip-icon{font-size:28px;flex-shrink:0}
.bmaz-strip-hed{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:900;text-transform:uppercase;color:var(--orange);letter-spacing:0.5px}
.bmaz-strip-sub{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.5}
.bmaz-strip-link{font-size:11px;color:var(--orange);font-weight:600;margin-top:5px}

/* ── MAP ── */
#map-tiles{position:absolute;inset:0;z-index:1}
.map-chip{position:absolute;z-index:10;background:rgba(8,9,13,0.88);border:1px solid var(--border2);border-radius:8px;backdrop-filter:blur(10px)}
.town-chip{top:12px;left:12px;padding:8px 14px;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:1px}
.town-chip span{color:var(--orange)}
.sensor-chip{top:12px;right:12px;padding:10px 13px;display:flex;flex-direction:column;align-items:center;gap:5px;min-width:86px}
.sens-lbl{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted)}
.sens-ring-wrap{position:relative;width:50px;height:50px}
.sens-emoji{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:18px}
.sens-word{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase}
.sens-dist{font-size:10px;color:var(--muted)}
.pin-wrap{display:flex;flex-direction:column;align-items:center}
.pin-dot{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:1.5px solid;cursor:pointer;transition:transform 0.15s}
.pin-dot:hover{transform:scale(1.12)}
.pin-dot svg{width:15px;height:15px}
.pin-active{background:rgba(244,124,32,0.15);border-color:rgba(244,124,32,0.55);color:var(--orange)}
.pin-found{background:rgba(52,199,89,0.15);border-color:rgba(52,199,89,0.55);color:var(--found)}
.pin-label{margin-top:4px;background:rgba(8,9,13,0.88);border:1px solid var(--border2);border-radius:4px;padding:2px 7px;font-size:9px;white-space:nowrap;font-weight:600;color:var(--text)}
.label-found{color:var(--found)}

/* ── CLUE ── */
.back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;color:var(--muted);font-family:'Barlow',sans-serif;font-size:13px;padding:14px 18px 0;transition:color 0.2s}
.back-btn:hover{color:var(--text)}
.clue-hero{padding:16px 18px 14px;border-bottom:1px solid var(--border)}
.clue-eyebrow{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);font-weight:600;margin-bottom:6px}
.clue-biz{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:900;text-transform:uppercase;color:var(--text);line-height:1}
.clue-sub{font-size:12px;color:var(--muted);margin-top:5px}
.clue-card{margin:14px;border-radius:var(--r);background:var(--surf);border:1px solid var(--border);border-left:3px solid var(--orange);padding:16px}
.clue-card-lbl{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--orange);opacity:0.8;margin-bottom:10px}
.clue-txt{font-size:15px;line-height:1.7;color:var(--text);font-style:italic}
.meta-row{margin:0 14px;display:flex;gap:8px}
.meta-box{flex:1;background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:11px 13px}
.meta-lbl{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.meta-val{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--orange);margin-top:3px;transition:color 0.3s}
.hints-sec{margin:14px 14px 0}
.hints-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.hint-row{width:100%;margin-bottom:6px;background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:12px 13px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all 0.2s;font-family:'Barlow',sans-serif;text-align:left}
.hint-row:hover{border-color:var(--border2);background:var(--surf2)}
.h-badge{width:28px;height:28px;border-radius:5px;background:var(--bg3);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;color:var(--muted);flex-shrink:0}
.h-body{flex:1}
.h-title{font-size:13px;font-weight:600;color:var(--text)}
.h-pen{font-size:11px;color:var(--muted);margin-top:2px}
.h-cost{background:rgba(244,124,32,0.1);border:1px solid rgba(244,124,32,0.22);border-radius:5px;padding:4px 9px;font-size:11px;font-weight:700;color:var(--orange);white-space:nowrap;font-family:'Barlow Condensed',sans-serif}
.cta-btn{margin:14px;width:calc(100% - 28px);background:var(--orange);color:#08090d;border:none;border-radius:8px;padding:15px;font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:900;text-transform:uppercase;letter-spacing:2px;cursor:pointer;transition:all 0.15s}
.cta-btn:hover{background:var(--orange-b);transform:translateY(-1px)}
.cta-btn:active{transform:scale(0.98)}
.cta-btn:disabled{background:var(--found);cursor:default;transform:none;color:white}

/* ── CAMERA ── */
#s-camera{background:#020304}
.cam-label{position:absolute;top:14px;left:50%;transform:translateX(-50%);background:rgba(5,6,8,0.85);border:1px solid rgba(244,124,32,0.3);border-radius:6px;padding:7px 16px;font-family:'Barlow Condensed',sans-serif;font-size:13px;color:var(--orange);font-weight:700;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;z-index:10}
.cam-corners{position:absolute;inset:14px;pointer-events:none;z-index:10}
.cc{position:absolute;width:28px;height:28px}
.cc.tl{top:0;left:0;border-top:2px solid var(--orange);border-left:2px solid var(--orange)}
.cc.tr{top:0;right:0;border-top:2px solid var(--orange);border-right:2px solid var(--orange)}
.cc.bl{bottom:0;left:0;border-bottom:2px solid var(--orange);border-left:2px solid var(--orange)}
.cc.br{bottom:0;right:0;border-bottom:2px solid var(--orange);border-right:2px solid var(--orange)}
.cam-controls{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;z-index:10}
.shutter{width:66px;height:66px;border-radius:50%;background:var(--text);border:3px solid var(--orange);cursor:pointer;transition:all 0.15s;display:flex;align-items:center;justify-content:center}
.shutter:hover{transform:scale(1.06)}
.shutter:active{transform:scale(0.88)}
.shutter-inner{width:50px;height:50px;border-radius:50%;background:var(--orange)}
.skip-btn{background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;font-family:'Barlow',sans-serif}
.skip-btn:hover{color:var(--text)}
.camera-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--bg2);z-index:5}
.cam-fallback-txt{font-size:15px;color:var(--muted);text-align:center;padding:0 30px;line-height:1.6}

/* ── WIN ── */
.win-hero {
  padding: 36px 18px 24px;
  text-align: center;
  background: linear-gradient(180deg, #1a0d00 0%, var(--bg) 100%);
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.win-burst {
  font-size: 64px;
  line-height: 1;
  margin-bottom: 12px;
  animation: burst 0.6s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
}
@keyframes burst {
  0%  { transform: scale(0) rotate(-15deg); opacity: 0; }
  60% { transform: scale(1.25) rotate(5deg); }
  100%{ transform: scale(1) rotate(0deg); opacity: 1; }
}
.win-eyebrow {
  font-size: 12px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--orange);
  font-weight: 700;
  margin-bottom: 10px;
}
.win-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 72px;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 0.88;
  color: var(--text);
  animation: slidein 0.5s ease both;
  animation-delay: 0.2s;
  opacity: 0;
}
@keyframes slidein {
  from { transform: translateY(24px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.win-title span { color: var(--orange); display: block; }
.win-sub { font-size: 14px; color: var(--muted); margin-top: 12px; animation: slidein 0.5s ease both; animation-delay: 0.35s; opacity: 0; }
.win-pts-hero {
  margin-top: 16px;
  animation: slidein 0.5s ease both;
  animation-delay: 0.45s;
  opacity: 0;
}
.win-pts-hero span:first-child {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 48px;
  font-weight: 900;
  color: var(--orange);
}
.win-pts-unit { font-size: 14px; color: var(--muted); margin-left: 6px; text-transform: uppercase; letter-spacing: 1px; }
.win-reward-card { margin: 16px 14px 12px; background: rgba(244,124,32,0.1); border: 1.5px solid rgba(244,124,32,0.35); border-radius: var(--r); padding: 18px; text-align: center; }
.win-reward-lbl { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.win-reward-code { font-family: 'Barlow Condensed', sans-serif; font-size: 42px; font-weight: 900; color: var(--orange); letter-spacing: 4px; }
.win-reward-desc { font-size: 14px; color: var(--text); margin-top: 8px; font-weight: 500; }
.win-reward-exp { font-size: 11px; color: var(--muted); margin-top: 4px; }
.win-reward-note { font-size: 11px; color: var(--orange); margin-top: 8px; font-weight: 600; opacity: 0.8; }
.win-photo-wrap { margin: 0 14px 12px; }
.win-photo-inner { border-radius: 12px; overflow: hidden; height: 180px; border: 1px solid rgba(244,124,32,0.3); background: linear-gradient(145deg,#0d0a06,#080608); display: flex; align-items: center; justify-content: center; position: relative; }
.win-photo-bar { position: absolute; bottom: 0; left: 0; right: 0; padding: 20px 14px 10px; background: linear-gradient(0,rgba(5,6,8,0.85),transparent); font-size: 11px; color: rgba(255,255,255,0.5); }
.win-photo-bar strong { color: var(--orange); }
.win-caption-box { margin: 0 14px 10px; background: var(--surf); border: 1px solid var(--border); border-left: 3px solid var(--orange); border-radius: 8px; padding: 13px; }
.win-caption-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.win-caption-lbl { font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); }
.copy-btn { background: var(--orange); color: #08090d; border: none; border-radius: 5px; padding: 5px 11px; font-size: 11px; font-weight: 700; cursor: pointer; font-family: 'Barlow Condensed', sans-serif; letter-spacing: 1px; text-transform: uppercase; }
.win-caption-txt { font-size: 12px; color: var(--muted); line-height: 1.65; }
.win-share-row { margin: 0 14px 14px; display: flex; gap: 8px; }
.share-btn { flex: 1; border-radius: 8px; padding: 12px; border: 1px solid var(--border); background: var(--surf); cursor: pointer; transition: all 0.2s; font-family: 'Barlow Condensed', sans-serif; font-size: 15px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; display: flex; align-items: center; justify-content: center; gap: 7px; }
.share-btn:hover { border-color: var(--border2); background: var(--surf2); }
.share-btn.ig { color: #e1306c; }
.share-btn.fb { color: #1877f2; }

/* ── FIND ME BUTTON ── */
.find-me-btn{
  position:absolute;bottom:16px;right:16px;z-index:20;
  width:40px;height:40px;border-radius:50%;
  background:rgba(8,9,13,0.88);border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text);
  backdrop-filter:blur(8px);
  transition:all 0.2s;
}
.find-me-btn:hover{border-color:var(--orange);color:var(--orange)}

/* ── FIND CELEBRATION ── */
.find-celebrate{
  position:absolute;inset:0;z-index:500;
  background:rgba(8,9,13,0.88);
  display:flex;align-items:flex-end;justify-content:center;
  pointer-events:none;
}
.find-card{
  position:relative;z-index:2;
  width:calc(100% - 28px);margin-bottom:80px;
  background:var(--surf);border:1px solid rgba(244,124,32,0.35);
  border-radius:14px;padding:18px 20px;
  transform:translateY(120%);opacity:0;
  transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1), opacity 0.3s;
}
.find-card.card-show{transform:translateY(0);opacity:1}
.find-card-track{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);font-weight:700;margin-bottom:6px}
.find-card-biz{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:900;text-transform:uppercase;color:var(--text);margin-bottom:10px}
.find-card-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.find-card-pts{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;color:var(--found)}
.find-card-prog{font-size:12px;color:var(--muted)}
.find-card-prints{display:flex;gap:4px;flex-wrap:wrap}
.find-print-dot{font-size:16px;opacity:0.2;transition:opacity 0.3s}
.find-print-dot.found{opacity:1}

/* ── FOOTPRINT TRAIL ── */
.footprint-trail{padding:8px 0 4px;position:relative}
.trail-step{display:flex;align-items:center;gap:10px;padding:0 4px}
.trail-left{flex-direction:row;padding-left:12px}
.trail-right{flex-direction:row-reverse;padding-right:12px}
.trail-foot{flex-shrink:0;transition:color 0.3s}
.trail-found{color:var(--orange)}
.trail-ghost{color:rgba(255,255,255,0.1)}
.trail-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;color:var(--muted);letter-spacing:0.5px;transition:color 0.3s}
.trail-label-found{color:var(--text)}
.trail-line{width:2px;height:20px;margin:0 auto;background:rgba(255,255,255,0.06);border-radius:1px;transition:background 0.3s}
.trail-line-found{background:rgba(244,124,32,0.4)}

/* ── INSTRUCTIONS HEADER ── */
.instr-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0;flex-shrink:0}
.instr-header-title{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;text-transform:uppercase;color:var(--text);letter-spacing:1px}
.instr-skip-btn{font-size:13px;color:var(--orange);cursor:pointer;padding:4px 8px;border:1px solid rgba(244,124,32,0.3);border-radius:6px;font-weight:600;letter-spacing:0.5px}
.instr-skip-btn:hover{background:rgba(244,124,32,0.1)}

/* ── OPT-IN ── */
.optin-wrap{margin:10px 14px 0;padding:10px 12px;border-radius:8px;background:var(--bg3);border:1px solid var(--border)}
.optin-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.optin-check-wrap{position:relative;flex-shrink:0;margin-top:1px}
.optin-check-wrap input[type=checkbox]{position:absolute;opacity:0;width:16px;height:16px;margin:0;cursor:pointer;z-index:2}
.optin-check{display:block;width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border2);background:var(--surf);transition:all 0.2s;position:relative}
.optin-check-wrap input:checked + .optin-check{background:var(--orange);border-color:var(--orange)}
.optin-check-wrap input:checked + .optin-check::after{content:'';position:absolute;left:4px;top:1px;width:5px;height:9px;border:2px solid #08090d;border-top:none;border-left:none;transform:rotate(45deg)}
.optin-text{font-size:11px;color:var(--muted);line-height:1.5}
.optin-text span{color:var(--muted);font-style:italic}
.danger-row { display: flex; gap: 8px; margin: 14px 14px 20px; }
.danger-btn { flex: 1; background: none; border: 1px solid rgba(255,80,80,0.25); color: rgba(255,80,80,0.55); border-radius: 6px; padding: 10px 14px; font-size: 12px; cursor: pointer; font-family: 'Barlow', sans-serif; transition: all 0.2s; text-align: center; }
.danger-btn:hover { border-color: rgba(255,80,80,0.5); color: rgba(255,80,80,0.85); }

/* ── INSTRUCTIONS ── */
.instr-wrap { display: flex; flex-direction: column; height: 100%; padding: 20px 0 16px; position: relative; }
.instr-skip-btn { position: absolute; top: 20px; right: 20px; font-size: 13px; color: var(--muted); cursor: pointer; z-index: 10; padding: 4px 8px; }
.instr-skip-btn:hover { color: var(--text); }
.instr-cards { flex: 1; position: relative; overflow: hidden; margin: 0 0 16px; }
.instr-card {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 20px 28px;
  text-align: center;
  transition: transform 0.35s cubic-bezier(0.76,0,0.24,1), opacity 0.3s;
}
.instr-icon { font-size: 64px; margin-bottom: 16px; line-height: 1; }
.instr-step { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--orange); font-weight: 600; margin-bottom: 10px; }
.instr-title { font-family: 'Barlow Condensed', sans-serif; font-size: 34px; font-weight: 900; text-transform: uppercase; color: var(--text); margin-bottom: 14px; letter-spacing: 0.5px; }
.instr-body { font-size: 15px; color: var(--muted); line-height: 1.7; max-width: 300px; }
.instr-body strong { color: var(--text); font-weight: 600; }
.instr-body em { color: var(--orange); font-style: normal; }
.instr-dots { display: flex; justify-content: center; gap: 8px; margin-bottom: 16px; }
.instr-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--surf2); transition: all 0.2s; }
.instr-dot.active { background: var(--orange); width: 20px; border-radius: 3px; }
.instr-nav { display: flex; justify-content: space-between; align-items: center; padding: 0 20px; }
.instr-nav-btn { background: none; border: 1px solid var(--border2); border-radius: 8px; color: var(--text); font-family: 'Barlow Condensed', sans-serif; font-size: 16px; font-weight: 700; padding: 10px 20px; cursor: pointer; transition: all 0.2s; letter-spacing: 1px; text-transform: uppercase; }
.instr-nav-btn:hover { border-color: var(--orange); color: var(--orange); }
.player-card {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 14px 14px 0;
  background: var(--surf);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 14px 16px;
}
.player-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(244,124,32,0.15);
  border: 1.5px solid rgba(244,124,32,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px;
  font-weight: 900;
  color: var(--orange);
  flex-shrink: 0;
}
.player-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--text);
  letter-spacing: 0.5px;
}
.player-email { font-size: 12px; color: var(--muted); margin-top: 2px; }
.stat-row{display:flex;gap:8px;margin:14px 14px 0}
.stat-b{flex:1;background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:12px}
.stat-v{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;color:var(--orange)}
.stat-l{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.prog-sec{margin:14px 14px 0}
.prog-sec-lbl{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.prog-row{display:flex;align-items:center;gap:10px;padding:12px 13px;background:var(--surf);border:1px solid var(--border);border-radius:8px;margin-bottom:5px;cursor:pointer;transition:all 0.2s}
.prog-row:hover{border-color:var(--border2);background:var(--surf2)}
.prog-row-done{border-color:rgba(52,199,89,0.2);background:rgba(52,199,89,0.04)}
.prog-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);flex-shrink:0}
.prog-dot.off{background:var(--surf2);border:1px solid var(--border2)}
.prog-row-info{flex:1}
.prog-row-name{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;text-transform:uppercase;color:var(--text)}
.prog-row-type{font-size:11px;color:var(--muted);margin-top:1px}
.prog-row-pts{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;color:var(--orange)}
.bmaz-cta{margin:14px 14px 0;background:linear-gradient(135deg,#1a1208,#0d1018);border:1px solid rgba(244,124,32,0.2);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:14px}
.bmaz-cta-hed{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:900;text-transform:uppercase;color:var(--orange)}
.bmaz-cta-sub{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.5}
.bmaz-cta-link{font-size:12px;color:var(--orange);font-weight:700;margin-top:5px}

/* ── MODAL ── */
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.7);z-index:200;display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity 0.3s}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal-box{background:var(--surf);border:1px solid var(--border2);border-radius:16px 16px 0 0;padding:24px 20px 36px;width:100%}
.modal-level{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:10px}
.modal-body{font-size:15px;line-height:1.7;color:var(--text);white-space:pre-line}
.modal-close{margin-top:20px;width:100%;background:var(--orange);color:#08090d;border:none;border-radius:8px;padding:14px;font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:900;text-transform:uppercase;cursor:pointer}

/* ── TOAST ── */
.toast{position:fixed;bottom:70px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--surf2);border:1px solid var(--border2);border-radius:8px;padding:10px 18px;font-size:13px;color:var(--text);opacity:0;transition:all 0.28s;white-space:nowrap;z-index:999;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.toast-warn{border-color:rgba(255,204,0,0.4);color:var(--warn)}
.toast.toast-success{border-color:rgba(52,199,89,0.4);color:var(--found)}

/* ── PROFILE SCREEN ── */
.profile-hero{text-align:center;padding:20px 18px 16px;border-bottom:1px solid var(--border)}
.profile-avatar{width:64px;height:64px;border-radius:50%;background:rgba(244,124,32,0.15);border:2px solid rgba(244,124,32,0.4);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;color:var(--orange);margin:0 auto 12px}
.profile-name{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:900;text-transform:uppercase;color:var(--text);letter-spacing:0.5px}
.profile-email{font-size:12px;color:var(--muted);margin-top:4px}
.profile-qr-section{margin:14px;background:var(--surf);border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center}
.profile-qr-label{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:900;text-transform:uppercase;color:var(--orange);letter-spacing:0.5px;margin-bottom:4px}
.profile-qr-sub{font-size:12px;color:var(--muted);margin-bottom:14px}
.profile-qr-wrap{display:flex;justify-content:center;margin-bottom:10px}
.profile-qr-wrap canvas{border-radius:10px;border:3px solid rgba(244,124,32,0.3)}
.profile-qr-hint{font-size:11px;color:var(--muted);opacity:0.7}
.profile-redemption{margin:0 14px 14px}
.redemption-item{display:flex;align-items:center;gap:12px;padding:12px 13px;background:var(--surf);border:1px solid var(--border);border-radius:8px;margin-bottom:6px}
.redemption-icon{font-size:22px;flex-shrink:0}
.redemption-info{flex:1}
.redemption-name{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;text-transform:uppercase;color:var(--text)}
.redemption-val{font-size:11px;color:var(--muted);margin-top:1px}
.redemption-cost{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;color:var(--orange)}

/* ── WIN REWARD MENU ── */
.win-reward-menu{margin:10px 0 8px;display:flex;flex-direction:column;gap:6px}
.win-reward-item{font-size:13px;color:var(--muted);padding:6px 10px;background:var(--bg3);border-radius:6px;text-align:left}
