/* ============ GENIE · Design System ============ */
:root{
  --bg:#0a0518;
  --bg-2:#140a2e;
  --surface:#171033;
  --surface-2:#1f1542;
  --line:rgba(255,255,255,.08);
  --txt:#f4f1ff;
  --txt-dim:#a99fce;
  --txt-mute:#6d6394;
  --pink:#ff2d6f;
  --magenta:#c026d3;
  --indigo:#4f46e5;
  --gold:#ffd166;
  --green:#34d399;
  --grad:linear-gradient(135deg,#ff2d6f 0%,#c026d3 50%,#4f46e5 100%);
  --grad-soft:linear-gradient(135deg,rgba(255,45,111,.16),rgba(79,70,229,.16));
  --radius:20px;
  --radius-sm:14px;
  --shadow:0 18px 50px -12px rgba(0,0,0,.6);
  --tabbar-h:72px;
  --maxw:520px;
  font-synthesis:none;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;height:100%}
body{
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(120% 80% at 50% -10%,#1b1140 0%,var(--bg) 55%);
  color:var(--txt);
  overscroll-behavior-y:none;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
button{font-family:inherit}
img{max-width:100%}

.app{
  position:relative;max-width:var(--maxw);margin:0 auto;min-height:100vh;min-height:100dvh;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(20,10,46,.4),transparent 240px);
}
.view{flex:1;padding:0 18px calc(var(--tabbar-h) + 28px);padding-top:env(safe-area-inset-top)}
.view.no-tab{padding-bottom:28px}
.hidden{display:none !important}
body.map-mode{overflow:hidden}
body.map-mode .view{padding:0}

/* ---------- Typography ---------- */
h1,h2,h3{margin:0;font-weight:800;letter-spacing:-.02em}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--txt-mute)}
.muted{color:var(--txt-dim)}
.center{text-align:center}

.brand{
  font-weight:900;letter-spacing:.04em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---------- Header ---------- */
.topbar{display:flex;align-items:center;gap:12px;padding:18px 2px 14px;position:sticky;top:0;z-index:5;
  background:linear-gradient(180deg,var(--bg) 60%,transparent);}
.topbar .logo{width:38px;height:38px;border-radius:11px;box-shadow:0 6px 18px rgba(192,38,211,.4)}
.topbar h2{font-size:20px}
.topbar .spacer{flex:1}
.icon-btn{width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:var(--surface);
  color:var(--txt);display:grid;place-items:center;cursor:pointer;font-size:18px;transition:.15s}
.icon-btn:active{transform:scale(.92)}
.badge-dot{position:relative}
.badge-dot::after{content:'';position:absolute;top:8px;right:8px;width:9px;height:9px;border-radius:50%;
  background:var(--pink);border:2px solid var(--surface)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  border:none;border-radius:var(--radius-sm);padding:15px 20px;font-size:16px;font-weight:700;
  cursor:pointer;width:100%;transition:transform .12s,filter .2s;color:#fff}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--grad);box-shadow:0 12px 28px -8px rgba(192,38,211,.6)}
.btn-primary:hover{filter:brightness(1.07)}
.btn-ghost{background:var(--surface);border:1px solid var(--line);color:var(--txt)}
.btn-gold{background:linear-gradient(135deg,#ffd166,#ff9f1c);color:#3a2400;box-shadow:0 12px 28px -10px rgba(255,159,28,.6)}
.btn-sm{padding:11px 15px;font-size:14px;width:auto}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card+.card{margin-top:14px}
.glow{position:relative;overflow:hidden}
.glow::before{content:'';position:absolute;inset:-40% -40% auto auto;width:240px;height:240px;
  background:radial-gradient(circle,rgba(192,38,211,.35),transparent 70%);filter:blur(10px);pointer-events:none}

/* ---------- Forms ---------- */
label{display:block;font-size:13px;font-weight:600;color:var(--txt-dim);margin:0 0 7px 2px}
input,textarea,select{
  width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);
  color:var(--txt);font-size:16px;padding:14px 15px;outline:none;transition:border .2s,box-shadow .2s}
input::placeholder,textarea::placeholder{color:var(--txt-mute)}
input:focus,textarea:focus,select:focus{border-color:var(--magenta);box-shadow:0 0 0 3px rgba(192,38,211,.2)}
.field+.field{margin-top:14px}

/* ---------- Onboarding ---------- */
.hero{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:32px 24px;gap:8px;position:relative}
.hero .lamp{width:128px;height:128px;filter:drop-shadow(0 18px 40px rgba(192,38,211,.55));animation:float 4.5s ease-in-out infinite}
.hero .wordmark{width:100%;max-width:340px;height:auto;filter:drop-shadow(0 16px 44px rgba(192,38,211,.5));animation:float 4.5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-14px) rotate(1deg)}}
.hero h1{font-size:46px;margin-top:6px}
.hero p{max-width:330px;color:var(--txt-dim);font-size:16px;line-height:1.5}
.hero .actions{width:100%;max-width:340px;margin-top:22px;display:flex;flex-direction:column;gap:12px}
.spark{position:absolute;border-radius:50%;background:var(--gold);opacity:.8;filter:blur(.3px);animation:tw 3s infinite}
@keyframes tw{0%,100%{opacity:.2;transform:scale(.7)}50%{opacity:.9;transform:scale(1.2)}}

/* ---------- Role choose ---------- */
.role-logo{display:block;width:100%;max-width:240px;height:auto;margin:10px auto 4px;filter:drop-shadow(0 10px 28px rgba(192,38,211,.45))}
.role-logo--svg{max-width:120px}
.role-grid{display:grid;gap:14px;margin-top:10px}
.role{display:flex;gap:16px;align-items:center;cursor:pointer;text-align:left}
.role .emoji{font-size:34px;width:62px;height:62px;border-radius:18px;display:grid;place-items:center;
  background:var(--grad-soft);border:1px solid var(--line);flex-shrink:0}
.role h3{font-size:19px}
.role p{margin:4px 0 0;font-size:13px;color:var(--txt-dim);line-height:1.4}

/* ---------- Wisher · I WISH ---------- */
.wish-stage{display:flex;flex-direction:column;gap:14px;padding-top:8px}
.wish-big{font-size:40px;font-weight:900;letter-spacing:-.02em;line-height:1.05}
.wish-input{font-size:22px;font-weight:600;min-height:120px;line-height:1.4;resize:none}
.cat-row{display:flex;gap:9px;overflow-x:auto;padding:4px 2px 8px;scrollbar-width:none}
.cat-row::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;display:flex;align-items:center;gap:7px;padding:10px 14px;border-radius:999px;
  background:var(--surface);border:1px solid var(--line);color:var(--txt-dim);font-size:14px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}
.chip.active{background:var(--grad);color:#fff;border-color:transparent}
.chip:active{transform:scale(.95)}

/* ---------- Wish list items ---------- */
.wish-item{display:flex;gap:13px;align-items:flex-start}
.wish-item .cat-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:22px;
  background:var(--grad-soft);border:1px solid var(--line);flex-shrink:0}
.wish-item .body{flex:1;min-width:0}
.wish-item h3{font-size:16px;line-height:1.3}
.wish-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:7px;font-size:12px;color:var(--txt-mute)}
.tag{padding:3px 9px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line)}
.tag.granted{color:var(--green);border-color:rgba(52,211,153,.3)}
.tag.pending{color:var(--gold);border-color:rgba(255,209,102,.3)}

/* ---------- Genie map ---------- */
#map{width:100%;height:100%;background:#0c0820}
.map-wrap{position:fixed;inset:0;max-width:var(--maxw);margin:0 auto}
.map-overlay-top{position:absolute;top:0;left:0;right:0;z-index:500;padding:max(12px,env(safe-area-inset-top)) 14px 12px;
  display:flex;gap:10px;align-items:center;background:linear-gradient(180deg,rgba(10,5,24,.92),transparent)}
.map-search{flex:1;display:flex;align-items:center;gap:9px;background:rgba(23,16,51,.9);border:1px solid var(--line);
  border-radius:14px;padding:11px 14px;backdrop-filter:blur(8px)}
.map-search input{background:transparent;border:none;padding:0;font-size:15px}
.map-search input:focus{box-shadow:none}
.map-stats{position:absolute;bottom:calc(var(--tabbar-h) + 14px);left:14px;right:14px;z-index:500;display:flex;gap:10px}
.map-stat{flex:1;background:rgba(23,16,51,.92);border:1px solid var(--line);border-radius:14px;padding:11px 13px;backdrop-filter:blur(8px)}
.map-stat b{display:block;font-size:20px}
.map-stat span{font-size:11px;color:var(--txt-dim)}
.leaflet-container{font:inherit}
.leaflet-popup-content-wrapper{background:var(--surface);color:var(--txt);border-radius:16px;border:1px solid var(--line)}
.leaflet-popup-tip{background:var(--surface)}
.leaflet-popup-content{margin:14px 16px}
.wish-marker{display:grid;place-items:center;width:38px;height:38px;border-radius:50% 50% 50% 4px;
  transform:rotate(45deg);background:var(--grad);box-shadow:0 6px 16px rgba(192,38,211,.55);border:2px solid #fff}
.wish-marker span{transform:rotate(-45deg);font-size:18px}
.pop h3{font-size:16px;margin-bottom:4px}
.pop p{font-size:13px;color:var(--txt-dim);margin:0 0 10px}

/* ---------- List / Leaderboard ---------- */
.section-title{display:flex;align-items:center;justify-content:space-between;margin:22px 2px 12px}
.section-title h2{font-size:18px}
.rank{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.rank:last-child{border-bottom:none}
.rank .pos{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;font-weight:800;background:var(--surface-2)}
.rank.top1 .pos{background:linear-gradient(135deg,#ffd166,#ff9f1c);color:#3a2400}
.rank.top2 .pos{background:linear-gradient(135deg,#e2e8f0,#94a3b8);color:#1e293b}
.rank.top3 .pos{background:linear-gradient(135deg,#f0a878,#b45309);color:#2a1500}
.rank .info{flex:1;min-width:0}
.rank .info b{font-size:15px}
.rank .info span{display:block;font-size:12px;color:var(--txt-mute)}
.rank .count{font-weight:800;color:var(--gold)}

/* ---------- Dashboard metrics ---------- */
.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.metric{padding:16px}
.metric .k{font-size:30px;font-weight:900;line-height:1}
.metric .l{font-size:12px;color:var(--txt-dim);margin-top:6px}
.metric .k.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.progress{height:10px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:10px}
.progress>i{display:block;height:100%;background:var(--grad);border-radius:999px}
.bars{display:flex;flex-direction:column;gap:11px;margin-top:6px}
.bar-row{display:grid;grid-template-columns:84px 1fr 40px;align-items:center;gap:10px;font-size:13px}
.bar-track{height:9px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.bar-track>i{display:block;height:100%;background:var(--grad);border-radius:999px}

/* ---------- Chat ---------- */
.chat-list .rank{cursor:pointer}
.chat-thread{display:flex;flex-direction:column;height:calc(100dvh - var(--tabbar-h) - 70px)}
.bubbles{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:9px;padding:8px 2px}
.bubble{max-width:80%;padding:11px 14px;border-radius:16px;font-size:14px;line-height:1.4}
.bubble.me{align-self:flex-end;background:var(--grad);border-bottom-right-radius:5px}
.bubble.them{align-self:flex-start;background:var(--surface-2);border:1px solid var(--line);border-bottom-left-radius:5px}
.chat-compose{display:flex;gap:9px;padding:10px 0}
.chat-compose input{flex:1}
.chat-compose .icon-btn{flex-shrink:0;background:var(--grad);border:none}

/* ---------- Tabbar ---------- */
.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:var(--maxw);height:var(--tabbar-h);
  display:flex;align-items:stretch;justify-content:space-around;z-index:600;
  background:rgba(15,9,33,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom)}
.tab{flex:1;border:none;background:none;color:var(--txt-mute);display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;font-size:10.5px;font-weight:600;cursor:pointer;transition:.15s;position:relative}
.tab .ic{font-size:21px;line-height:1}
.tab.active{color:var(--txt)}
.tab.active .ic{transform:translateY(-1px);filter:drop-shadow(0 4px 10px rgba(192,38,211,.7))}
.tab.active::before{content:'';position:absolute;top:0;width:26px;height:3px;border-radius:0 0 4px 4px;background:var(--grad)}
.tab .fab{width:50px;height:50px;margin-top:-22px;border-radius:16px;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:24px;box-shadow:0 10px 24px -6px rgba(192,38,211,.7)}

/* ---------- Toasts ---------- */
.toasts{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(var(--tabbar-h) + 18px);z-index:1000;
  display:flex;flex-direction:column;gap:8px;width:calc(100% - 36px);max-width:calc(var(--maxw) - 36px);pointer-events:none}
.toast{background:var(--surface-2);border:1px solid var(--line);border-left:3px solid var(--magenta);
  border-radius:13px;padding:13px 15px;font-size:14px;box-shadow:var(--shadow);animation:slideup .3s ease}
.toast.success{border-left-color:var(--green)}
.toast.gold{border-left-color:var(--gold)}
@keyframes slideup{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- Modal sheet ---------- */
.sheet-back{position:fixed;inset:0;z-index:900;background:rgba(5,2,14,.66);backdrop-filter:blur(3px);
  display:flex;align-items:flex-end;justify-content:center;animation:fade .2s}
.sheet{width:100%;max-width:var(--maxw);background:var(--surface);border-radius:24px 24px 0 0;border:1px solid var(--line);
  padding:10px 18px calc(20px + env(safe-area-inset-bottom));max-height:88dvh;overflow-y:auto;animation:slideup .28s ease}
.sheet .grip{width:42px;height:5px;border-radius:999px;background:var(--line);margin:6px auto 14px}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---------- Misc ---------- */
.row{display:flex;gap:12px;align-items:center}
.row.between{justify-content:space-between}
.stack{display:flex;flex-direction:column;gap:10px}
.empty{text-align:center;color:var(--txt-mute);padding:48px 20px}
.empty .big{font-size:48px;margin-bottom:10px}
.divider{height:1px;background:var(--line);margin:18px 0}
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;background:var(--grad-soft);
  border:1px solid var(--line);font-size:12px;font-weight:600}
.anon-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--green)}
.avatar{width:46px;height:46px;border-radius:14px;object-fit:cover;background:var(--surface-2);flex-shrink:0}
