/* ═══════════════════ SHARED COMPONENTS ═══════════════════ */
.ntc-sym{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--ntc);font-weight:800;color:#000;flex-shrink:0;line-height:1;}
.ntc-sym.xs{width:14px;height:14px;font-size:8px;}
.ntc-sym.sm{width:18px;height:18px;font-size:10px;}
.ntc-sym.md{width:26px;height:26px;font-size:14px;}
.ntc-sym.lg{width:40px;height:40px;font-size:20px;}
.ntc-sym.glow{box-shadow:0 0 14px rgba(245,197,66,.65);}
.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.av-xs{width:26px;height:26px;font-size:11px;}.av-sm{width:36px;height:36px;font-size:14px;}.av-md{width:44px;height:44px;font-size:18px;}
.av-a{background:linear-gradient(135deg,#5cc8f8,#9d7ff4);}
.av-b{background:linear-gradient(135deg,#f06baa,#9d7ff4);}
.av-c{background:linear-gradient(135deg,#3de8a0,#5cc8f8);}
.av-d{background:linear-gradient(135deg,#f5c542,#f06baa);}
.av-e{background:linear-gradient(135deg,#9d7ff4,#f06baa);}
.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:100px;font-size:10px;font-weight:600;letter-spacing:.04em;}
.chip-gold{background:rgba(245,197,66,.12);color:var(--gold);border:1px solid rgba(245,197,66,.25);}
.chip-purp{background:rgba(157,127,244,.12);color:var(--purp);border:1px solid rgba(157,127,244,.25);}
.chip-blue{background:rgba(92,200,248,.1);color:var(--blue);border:1px solid rgba(92,200,248,.22);}
.chip-pink{background:rgba(240,107,170,.12);color:var(--pink);border:1px solid rgba(240,107,170,.25);}
.chip-green{background:rgba(61,232,160,.1);color:var(--green);border:1px solid rgba(61,232,160,.2);}
.chip-red{background:rgba(255,59,92,.1);color:var(--live);border:1px solid rgba(255,59,92,.25);}
.sec-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;}
.sec-title{font-family:var(--fd);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;}
.sec-act{font-size:12px;color:var(--purp);cursor:pointer;font-weight:500;}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px;border-radius:16px;font-family:var(--fd);font-weight:700;font-size:14px;border:none;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent;}
.btn:active{transform:scale(.97);}
.btn-grad{background:var(--grad);color:#fff;}
.btn-gold{background:var(--ntc);color:#000;font-weight:800;}
.btn-outline{background:transparent;border:1px solid var(--bord2);color:var(--muted);}

/* ═══════════════════ APP SHELL ═══════════════════ */
#app{
  width: 100%;
  max-width: 430px;
  /* Use fixed height trick — doesn't jump when browser chrome shows/hides */
  height: 100vh;
  height: -webkit-fill-available;
  height: 100svh;
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 80px rgba(0,0,0,.8);
  border-radius: 0;
  /* Allow internal scrolling only */
  touch-action: pan-y;
}
@media(min-width:500px){#app{border-radius:44px;height:min(932px,100dvh);}
  #bottom-nav{border-radius:0 0 40px 40px;overflow:hidden;max-width:430px;}
  .modal-sheet,.picker-sheet{max-width:430px;}
  #fab-menu{align-items:center;}
  #fab-options{bottom:calc(82px + var(--safe));}
}
.screen{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:none;flex-direction:column;background:var(--black);padding-bottom:0;}
.screen.active{display:flex;}
.screen::-webkit-scrollbar{display:none;}
.screen.has-nav{padding-bottom:calc(64px + var(--safe));}

/* ═══════════════════ BOTTOM NAV ═══════════════════ */
#bottom-nav{position:absolute;bottom:0;left:0;right:0;background:rgba(4,4,10,.96);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);display:none;align-items:center;padding:8px 0 calc(8px + var(--safe));z-index:200;}
#bottom-nav.show{display:flex;}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;-webkit-tap-highlight-color:transparent;}
.nav-icon{width:44px;height:30px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;transition:background .2s;}
.nav-item.active .nav-icon{background:rgba(157,127,244,.16);}
.nav-label{font-size:10px;color:var(--muted);letter-spacing:.04em;transition:color .2s;}
.nav-item.active .nav-label{color:var(--purp);font-weight:700;}
.nav-fab{width:54px;height:54px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;flex-shrink:0;box-shadow:0 4px 22px rgba(157,127,244,.55);-webkit-tap-highlight-color:transparent;transition:transform .25s;border:none;position:relative;z-index:2;}
.nav-fab:active{transform:scale(.9);}
.nav-fab.open{transform:rotate(45deg);}
/* FAB menu overlay */
#fab-menu{position:absolute;inset:0;z-index:190;pointer-events:none;opacity:0;transition:opacity .25s;}
#fab-menu.show{opacity:1;pointer-events:all;}
#fab-menu-bg{position:absolute;inset:0;background:rgba(4,4,10,.82);backdrop-filter:blur(14px);}
#fab-options{position:absolute;bottom:calc(72px + var(--safe));left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;width:240px;}
.fab-option{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--bord2);border-radius:20px;padding:14px 18px;width:100%;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .18s,border-color .2s;animation:fadeUp .3s ease both;}
.fab-option:active{transform:scale(.97);}
.fab-option.locked{opacity:.55;cursor:default;}
.fab-opt-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.fab-opt-body{flex:1;}
.fab-opt-title{font-family:var(--fd);font-size:14px;font-weight:700;margin-bottom:2px;}
.fab-opt-sub{font-size:11px;color:var(--muted);line-height:1.4;}
.fab-lock-badge{font-size:10px;background:rgba(157,127,244,.12);border:1px solid rgba(157,127,244,.25);border-radius:100px;padding:3px 8px;color:var(--purp);white-space:nowrap;}

/* ═══════════════════ TOPBAR ═══════════════════ */
.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:50;background:rgba(4,4,10,.95);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border-bottom:1px solid var(--border);padding:13px 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.tb-logo{font-family:var(--fd);font-size:20px;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block;}
.tb-right{display:flex;align-items:center;gap:9px;}
.icon-btn{width:36px;height:36px;border-radius:50%;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;}
.ntc-pill{display:flex;align-items:center;gap:5px;background:var(--card);border:1px solid rgba(245,197,66,.22);border-radius:100px;padding:6px 12px;cursor:pointer;-webkit-tap-highlight-color:transparent;}
.ntc-pill-val{font-family:var(--fd);font-size:12px;font-weight:700;color:var(--gold);}

/* ═══════════════════ MODAL SYSTEM ═══════════════════ */
.modal-ov{position:absolute;inset:0;z-index:300;background:rgba(0,0,0,.78);backdrop-filter:blur(12px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.modal-ov.show{opacity:1;pointer-events:all;}
.modal-sheet{background:var(--surf);border:1px solid var(--border);border-radius:28px 28px 0 0;width:100%;max-width:540px;padding:14px 20px calc(28px + var(--safe));transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);max-height:88vh;overflow-y:auto;}
.modal-sheet::-webkit-scrollbar{display:none;}
.modal-ov.show .modal-sheet{transform:translateY(0);}
.mhandle{width:36px;height:4px;border-radius:2px;background:var(--bord2);margin:0 auto 16px;}
.mtitle{font-family:var(--fd);font-size:19px;font-weight:800;margin-bottom:16px;}
.field{width:100%;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:13px 16px;color:var(--text);font-family:var(--fb);font-size:15px;outline:none;transition:border-color .2s;}
.field:focus{border-color:rgba(157,127,244,.5);}
.field::placeholder{color:var(--muted2);}
.field-label{font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-weight:500;display:block;margin-bottom:6px;}
.field-wrap{margin-bottom:14px;}
textarea.field{resize:none;min-height:80px;line-height:1.55;}

/* ═══════════════════ TOAST ═══════════════════ */
#toast-el{position:absolute;bottom:90px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--card2);border:1px solid var(--bord2);border-radius:100px;padding:10px 20px;font-size:13px;font-weight:500;white-space:nowrap;z-index:9000;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;}
#toast-el.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ═══════════════════ GIFT VISUALS (SVG CSS art) ═══════════════════ */
.gift-visual{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.gv-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 35%,rgba(4,4,10,.88) 100%);z-index:2;}
.gv-rarity{position:absolute;top:10px;left:11px;z-index:3;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:100px;font-size:10px;font-weight:700;letter-spacing:.06em;backdrop-filter:blur(8px);}
.gv-label{position:absolute;bottom:9px;left:13px;right:13px;z-index:3;}
.gv-cat{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:2px;}
.gv-name{font-family:var(--fd);font-size:15px;font-weight:800;letter-spacing:-.02em;line-height:1.1;text-shadow:0 2px 10px rgba(0,0,0,.9);}
.r-ultra{background:rgba(157,127,244,.45);color:#d4bbff;border:1px solid rgba(157,127,244,.6);}
.r-legendary{background:rgba(245,197,66,.4);color:#ffe066;border:1px solid rgba(245,197,66,.55);}
.r-rare{background:rgba(240,107,170,.4);color:#ffb3d4;border:1px solid rgba(240,107,170,.55);}
.r-common{background:rgba(92,200,248,.35);color:#b3e8ff;border:1px solid rgba(92,200,248,.5);}
