/* ═══════════════════════════════════════════════════════════
   MARCIANUS DESIGN SYSTEM — Mobile Webapp Prototype
   Dark Enterprise · Decision UX · Mobile-First
═══════════════════════════════════════════════════════════ */
@import url('https://api.fontshare.com/v2/css?f[]=satoshi@400,500,700,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg-0:#050508;--bg-1:#0B0F1A;--bg-2:#0F0F1A;--bg-3:#111827;--bg-4:#141424;--bg-5:#1A1A2E;
  --bg-glass:rgba(17,24,39,0.72);--bg-card:rgba(14,14,24,0.88);
  --purple:#7B61FF;--purple-deep:#5D3FD3;--purple-50:#A78BFA;
  --purple-20:rgba(123,97,255,0.20);--purple-10:rgba(123,97,255,0.10);--purple-glow:rgba(123,97,255,0.40);
  --gold:#FFD700;--gold-warm:#F5C518;--blue-tech:#00D1FF;
  --success:#00C48C;--warning:#FFB020;--danger:#FF3B5C;--orange:#FF6B35;
  --fg-100:#fff;--fg-80:rgba(255,255,255,0.80);--fg-60:rgba(255,255,255,0.60);
  --fg-40:rgba(255,255,255,0.40);--fg-20:rgba(255,255,255,0.20);
  --border-1:rgba(255,255,255,0.06);--border-2:rgba(255,255,255,0.12);--border-3:rgba(255,255,255,0.20);
  --border-accent:rgba(123,97,255,0.40);
  --r-xs:4px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-full:9999px;
  --font:'Satoshi','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,'Liberation Sans',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'Cascadia Code','Fira Code',SFMono-Regular,Consolas,'Liberation Mono',monospace;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.30);--shadow-md:0 8px 24px rgba(0,0,0,0.40);
  --shadow-lg:0 20px 60px rgba(0,0,0,0.50);
  --header-h:52px;--tabbar-h:64px;--safe-b:env(safe-area-inset-bottom,0px);
}
html,body{margin:0;padding:0;background:var(--bg-0);overscroll-behavior-y:none;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-family:var(--font);color:var(--fg-100);font-size:16px;line-height:1.5;
  -webkit-tap-highlight-color:transparent;
}
button,input,select,textarea{font-family:var(--font);font-weight:500;border:none;background:none;color:inherit;outline:none}
button{cursor:pointer}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{display:none}
*{scrollbar-width:none}

/* ── App Canvas ─────────────────────────────────── */
#root{min-height:100dvh;display:flex;justify-content:center;
  background:radial-gradient(1200px 800px at 20% -10%,rgba(123,97,255,0.12),transparent 60%),
    radial-gradient(800px 600px at 110% 20%,rgba(0,209,255,0.07),transparent 55%),var(--bg-0);
  position:relative;isolation:isolate}
#root::before{content:'';position:fixed;inset:0;
  background-image:linear-gradient(rgba(255,255,255,0.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.018) 1px,transparent 1px);
  background-size:64px 64px;pointer-events:none;z-index:0;
  mask-image:radial-gradient(ellipse at top,black 30%,transparent 80%)}

.app-shell{width:100%;max-width:430px;height:100dvh;position:relative;display:flex;flex-direction:column;
  background:linear-gradient(180deg,#07070C 0%,#0B0F1A 40%,#0A0A14 100%);z-index:1;overflow:hidden}
@media(min-width:720px){
  .app-shell{height:min(calc(100dvh - 48px),920px);max-height:920px;border-radius:32px;margin:24px 0;
    border:1px solid rgba(255,255,255,0.05);
    box-shadow:0 60px 120px rgba(0,0,0,0.6),0 0 0 6px #0A0A12,0 0 80px rgba(123,97,255,0.08)}
}

/* ── Status Bar ─────────────────────────────────── */
.status-bar{height:44px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;
  font-size:14px;font-weight:600;flex-shrink:0;position:relative;z-index:5}
.status-bar .sb-right{display:flex;align-items:center;gap:5px}

/* ── Header ─────────────────────────────────────── */
.app-header{height:var(--header-h);padding:0 16px;display:flex;align-items:center;gap:12px;
  background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border-1);position:relative;z-index:50;flex-shrink:0}
.hdr-brand{width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(123,97,255,0.18),rgba(123,97,255,0.04));
  border:1px solid var(--border-accent);border-radius:10px;flex-shrink:0;overflow:hidden}
.hdr-brand img{width:18px;height:18px;object-fit:contain}
.hdr-info{flex:1;min-width:0;display:flex;flex-direction:column}
.hdr-eyebrow{font-family:var(--mono);font-size:9px;text-transform:uppercase;
  letter-spacing:0.18em;color:var(--purple-50);line-height:1}
.hdr-title{font-weight:700;font-size:16px;letter-spacing:-0.01em;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.hdr-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}

/* ── Icon Button ─────────────────────────────────── */
.icon-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,0.04);border:1px solid var(--border-1);border-radius:10px;
  color:var(--fg-80);transition:all 150ms ease-out;position:relative;flex-shrink:0}
.icon-btn:hover{background:rgba(255,255,255,0.08);border-color:rgba(123,97,255,0.30)}
.icon-btn:active{transform:scale(0.94)}
.icon-btn .badge-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;
  background:var(--danger);border:2px solid var(--bg-1)}

/* ── Page scroll area ─────────────────────────────── */
.page-area{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  padding:0 0 calc(var(--tabbar-h) + 24px)}

/* ── Bottom Tab Bar ──────────────────────────────── */
.tabbar{height:calc(var(--tabbar-h) + var(--safe-b));padding-bottom:var(--safe-b);
  display:flex;align-items:stretch;background:rgba(8,8,14,0.90);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--border-1);position:absolute;bottom:0;left:0;right:0;z-index:60}
.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--fg-40);font-size:9px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  transition:color 150ms;position:relative;padding:8px 0}
.tab-btn svg{width:22px;height:22px;stroke-width:1.6}
.tab-btn.active{color:var(--fg-100)}
.tab-btn.active::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:32px;height:2px;background:linear-gradient(90deg,var(--purple),var(--blue-tech));
  border-radius:0 0 2px 2px;box-shadow:0 0 12px rgba(123,97,255,0.5)}
.tab-btn.fab-tab .fab-ring{width:50px;height:50px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--gold),var(--gold-warm));color:#050508;
  border-radius:16px;box-shadow:0 0 28px rgba(255,215,0,0.40),0 6px 16px rgba(0,0,0,0.4);
  margin-top:-14px;transition:transform 150ms}
.tab-btn.fab-tab:active .fab-ring{transform:scale(0.93)}
.tab-btn.fab-tab svg{stroke-width:2.2}
.tab-btn.fab-tab.active::after{display:none}

/* ── Eyebrow ────────────────────────────────────── */
.eyebrow{font-family:var(--mono);font-weight:500;font-size:9px;line-height:1;
  text-transform:uppercase;letter-spacing:0.18em;color:var(--purple-50)}
.eyebrow.gold{color:var(--gold)}.eyebrow.blue{color:var(--blue-tech)}.eyebrow.muted{color:var(--fg-40)}

/* ── Buttons ────────────────────────────────────── */
.btn{height:44px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:600;font-size:14px;border-radius:var(--r-md);transition:all 150ms ease-out}
.btn:active{transform:scale(0.97)}
.btn-gold{background:var(--gold);color:#0B0F1A;box-shadow:var(--glow-gold,0 0 28px rgba(255,215,0,0.35))}
.btn-purple{background:linear-gradient(135deg,var(--purple),var(--purple-deep));color:#fff;
  box-shadow:0 0 20px rgba(123,97,255,0.35)}
.btn-ghost{background:rgba(255,255,255,0.04);color:var(--fg-100);border:1px solid var(--border-2)}
.btn-ghost:hover{background:rgba(255,255,255,0.08);border-color:var(--border-accent)}
.btn-sm{height:34px;padding:0 12px;font-size:12px;border-radius:10px}
.btn-block{width:100%}

/* ── Chips ──────────────────────────────────────── */
.chip{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;
  font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  background:rgba(255,255,255,0.04);border:1px solid var(--border-1);color:var(--fg-80);border-radius:var(--r-full);white-space:nowrap}
.chip.purple{color:var(--purple-50);background:var(--purple-10);border-color:rgba(123,97,255,0.30)}
.chip.gold{color:var(--gold);background:rgba(255,215,0,0.08);border-color:rgba(255,215,0,0.25)}
.chip.blue{color:var(--blue-tech);background:rgba(0,209,255,0.08);border-color:rgba(0,209,255,0.25)}
.chip.green{color:var(--success);background:rgba(0,196,140,0.10);border-color:rgba(0,196,140,0.25)}
.chip.live{color:#fff;background:rgba(255,59,92,0.85);border-color:transparent}
.chip .dot{width:5px;height:5px;border-radius:50%;background:currentColor;box-shadow:0 0 6px currentColor}
.chip.live .dot{animation:blink 1.4s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
@keyframes pulse{0%,100%{opacity:0.6}50%{opacity:0.25}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes micPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,59,92,0.5)}60%{box-shadow:0 0 0 7px rgba(255,59,92,0)}}

/* ── Cards ──────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--border-1);border-radius:var(--r-lg);
  overflow:hidden;transition:border-color 150ms,transform 150ms}
.card:active{transform:scale(0.99);border-color:rgba(123,97,255,0.25)}
.card-cover{position:relative;overflow:hidden}
.card-cover-fade{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(5,5,8,0.85) 100%);pointer-events:none}
.card-body{padding:14px 16px}
.card-actions{display:flex;align-items:center;gap:6px;padding:0 16px 14px}

/* ── Action Buttons (like/save/share) ────────── */
.act-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border-1);border-radius:var(--r-sm);
  color:var(--fg-60);font-size:11px;font-weight:500;transition:all 150ms}
.act-btn:hover,.act-btn.active{background:rgba(123,97,255,0.10);border-color:rgba(123,97,255,0.25);color:var(--fg-100)}
.act-btn svg{width:14px;height:14px}

/* ── Section ────────────────────────────────────── */
.section{padding:20px 16px 0}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-title{font-weight:700;font-size:17px;letter-spacing:-0.01em;margin-top:3px}
.section-link{font-size:12px;font-weight:600;color:var(--purple-50);display:flex;align-items:center;gap:4px}

/* ── Avatar ─────────────────────────────────────── */
.avatar{width:40px;height:40px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;color:#fff;background:linear-gradient(135deg,var(--purple-deep),var(--purple));
  flex-shrink:0;position:relative;overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar.lg{width:52px;height:52px;font-size:18px;border-radius:16px}
.avatar.sm{width:28px;height:28px;font-size:10px;border-radius:8px}
.avatar.online::after{content:'';position:absolute;bottom:-1px;right:-1px;width:11px;height:11px;
  border-radius:50%;background:var(--success);border:2px solid var(--bg-1)}

/* ── MatchRing ──────────────────────────────────── */
.match-ring{position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.match-ring svg{transform:rotate(-90deg)}
.match-ring .ring-val{position:absolute;font-weight:900;letter-spacing:-0.02em}

/* ── Stories Rail ───────────────────────────────── */
.stories-rail{display:flex;gap:10px;overflow-x:auto;padding:12px 16px 8px;scroll-snap-type:x mandatory}
.story-item{width:80px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px;scroll-snap-align:start}
.story-ring{width:62px;height:62px;border-radius:50%;padding:2px;
  background:linear-gradient(135deg,var(--purple),var(--gold));display:flex;align-items:center;justify-content:center}
.story-ring.viewed{background:var(--border-2)}
.story-ring-inner{width:100%;height:100%;border-radius:50%;background:var(--bg-1);
  display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid var(--bg-1)}
.story-ring-inner img{width:100%;height:100%;object-fit:cover}
.story-label{font-size:10px;font-weight:600;color:var(--fg-60);text-align:center;
  max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── Horizontal Scroll ──────────────────────────── */
.h-scroll{display:flex;gap:12px;overflow-x:auto;padding:0 16px 4px;scroll-snap-type:x mandatory}
.h-scroll>*{scroll-snap-align:start;flex-shrink:0}

/* ── Search Bar ─────────────────────────────────── */
.search-bar{display:flex;align-items:center;gap:8px;height:40px;padding:0 14px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border-1);border-radius:var(--r-md);margin:0 16px}
.search-bar input{flex:1;background:transparent;font-size:14px;color:var(--fg-100)}
.search-bar input::placeholder{color:var(--fg-40)}
.search-bar svg{color:var(--fg-40);flex-shrink:0;width:18px;height:18px}

/* ── Skeleton ───────────────────────────────────── */
.skeleton{background:linear-gradient(90deg,rgba(255,255,255,0.04),rgba(255,255,255,0.10),rgba(255,255,255,0.04));
  background-size:200% 100%;animation:shimmer 1.5s linear infinite;border-radius:var(--r-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Loading state canónico (design system) ──────────────────────────────────
   .loading-state era usado em ~12 sítios SEM CSS (texto simples "A carregar…").
   Agora é um loader on-brand consistente: spinner roxo + texto. Aplica-se a TODOS
   de uma vez, garantindo consistência de ponta a ponta. */
.loading-state{display:flex;align-items:center;justify-content:center;gap:10px;
  padding:26px 16px;min-height:84px;color:var(--fg-40);font-size:13px;font-weight:600;
  letter-spacing:.01em;text-align:center}
.loading-state::before{content:"";width:17px;height:17px;border-radius:50%;flex-shrink:0;
  border:2px solid rgba(123,97,255,0.22);border-top-color:var(--purple);
  animation:mxSpin .7s linear infinite}
.loading-state.inline{display:inline-flex;padding:0;min-height:0;gap:7px}
.loading-state.inline::before{width:13px;height:13px;border-width:2px}
@keyframes mxSpin{to{transform:rotate(360deg)}}

/* Spinner reutilizável p/ botões/zonas onde só se quer o anel (sem texto). */
.mx-spin{display:inline-block;width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(123,97,255,0.22);border-top-color:var(--purple);
  animation:mxSpin .7s linear infinite;vertical-align:middle}
.mx-spin.sm{width:13px;height:13px}
.mx-spin.on-accent{border-color:rgba(255,255,255,0.35);border-top-color:#fff}
@media (prefers-reduced-motion:reduce){
  .loading-state::before,.mx-spin{animation-duration:1.4s}
}

/* ── Reveal animation ───────────────────────────── */
.reveal{opacity:0;transform:translateY(10px);animation:reveal-in 400ms ease-out forwards}
.reveal-d1{animation-delay:80ms}.reveal-d2{animation-delay:160ms}.reveal-d3{animation-delay:240ms}
@keyframes reveal-in{to{opacity:1;transform:translateY(0)}}

/* ── Page transition ────────────────────────────── */
.page-area{scroll-behavior:smooth}
.page-enter{animation:page-fade-in 250ms cubic-bezier(0.16,1,0.3,1) forwards}
@keyframes page-fade-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ── Card hover polish ──────────────────────────── */
.card{transition:border-color 200ms,transform 200ms,box-shadow 200ms}
.card:hover{border-color:rgba(123,97,255,0.18);box-shadow:0 4px 16px rgba(0,0,0,0.25)}
.card:active{transform:scale(0.985);box-shadow:none}

/* ── Button press feedback ──────────────────────── */
.btn{transition:all 150ms cubic-bezier(0.16,1,0.3,1)}
.btn:hover{filter:brightness(1.08)}
.btn-gold:hover{box-shadow:0 0 36px rgba(255,215,0,0.45)}
.btn-purple:hover{box-shadow:0 0 28px rgba(123,97,255,0.45)}

/* ── Tab transition ─────────────────────────────── */
.tab-btn{transition:color 200ms,transform 150ms}
.tab-btn:active{transform:scale(0.92)}
.tab-btn.active svg{filter:drop-shadow(0 0 4px rgba(123,97,255,0.4))}

/* ── Divider ────────────────────────────────────── */
.divider{height:1px;background:var(--border-1);margin:0 16px}

/* ── Input ──────────────────────────────────────── */
.input{width:100%;height:44px;background:rgba(255,255,255,0.04);border:1px solid var(--border-1);
  border-radius:var(--r-md);padding:0 14px;color:var(--fg-100);font-size:14px;transition:all 150ms}
.input:focus{border-color:var(--border-accent);background:rgba(123,97,255,0.04)}

/* ── Progress Bar ───────────────────────────────── */
.progress-bar{width:100%;height:4px;background:rgba(255,255,255,0.08);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--blue-tech));border-radius:2px;
  transition:width 600ms ease}

/* ── Toggle ─────────────────────────────────────── */
.toggle{width:42px;height:24px;border-radius:12px;background:rgba(255,255,255,0.10);
  position:relative;transition:background 150ms;flex-shrink:0}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;
  background:#fff;transition:transform 150ms;box-shadow:0 2px 6px rgba(0,0,0,0.3)}
.toggle.on{background:var(--purple)}.toggle.on::after{transform:translateX(18px)}

/* ── Hexis FAB ──────────────────────────────────── */
.hexis-fab{position:absolute;right:14px;bottom:calc(var(--tabbar-h) + var(--safe-b) + 14px);z-index:55;
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,var(--purple),var(--purple-deep));
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 0 28px rgba(123,97,255,0.50),0 6px 16px rgba(0,0,0,0.4);
  transition:transform 150ms;overflow:visible}
.hexis-fab:active{transform:scale(0.92)}
.hexis-fab img{width:24px;height:24px;object-fit:contain;filter:brightness(2)}

/* ── Bottom Sheet ───────────────────────────────── */
.sheet-backdrop{position:absolute;inset:0;background:rgba(5,5,8,0.70);backdrop-filter:blur(4px);
  z-index:70;opacity:0;pointer-events:none !important;transition:opacity 200ms;visibility:hidden}
.sheet-backdrop.open{opacity:1;pointer-events:auto !important;visibility:visible}
.bottom-sheet{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,#141424,#0F0F1A);
  border-top:1px solid rgba(123,97,255,0.20);border-radius:24px 24px 0 0;
  padding:8px 0 calc(16px + var(--safe-b));z-index:71;height:60%;max-height:60%;
  overflow:hidden;display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform 280ms cubic-bezier(0.16,1,0.3,1);
  pointer-events:none !important;visibility:hidden}
.bottom-sheet.open{transform:translateY(0);pointer-events:auto !important;visibility:visible}
.bottom-sheet .sheet-scroll{flex:1;overflow-y:auto;min-height:0}
.sheet-handle{width:40px;height:4px;border-radius:4px;background:var(--fg-20);margin:8px auto 14px}

/* ── Tab Pills ──────────────────────────────────── */
.tab-pills{display:flex;gap:3px;background:rgba(255,255,255,0.03);padding:3px;border-radius:var(--r-md);
  border:1px solid var(--border-1);
  /* Responsivo: se os pills não couberem (5 subtabs em ecrãs estreitos), scroll
     horizontal suave SEM scrollbar — fica DENTRO da box em qualquer telemóvel. */
  overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;-ms-overflow-style:none}
.tab-pills::-webkit-scrollbar{display:none}
/* Utility: linha com scroll horizontal limpo (sem scrollbar) — qualquer telemóvel */
.no-scrollbar{scrollbar-width:none;-ms-overflow-style:none}
.no-scrollbar::-webkit-scrollbar{display:none}
/* Focus mode: quando um jogo/widget interativo está aberto no feed, o FAB do Hexis
   recolhe-se (some + desce) para não sobrepor nem intercetar cliques das opções. */
body.mx-focus-game .hexis-fab{opacity:0;pointer-events:none;transform:translateY(28px) scale(0.82)}
.tab-pill{flex:1 0 auto;display:flex;align-items:center;justify-content:center;gap:5px;
  padding:8px 7px;border-radius:10px;font-size:12px;font-weight:600;color:var(--fg-40);
  transition:all 150ms;white-space:nowrap}
.tab-pill.active{background:rgba(123,97,255,0.18);color:var(--purple-50)}
.tab-pill svg{width:14px;height:14px}

/* ── Glassmorphism Popup ────────────────────────── */
.glass-popup{position:absolute;inset:8px;top:calc(44px + var(--header-h) + 4px);
  bottom:calc(var(--tabbar-h) + var(--safe-b) + 64px);
  background:rgba(10,10,20,0.97);border:1px solid rgba(123,97,255,0.30);border-radius:20px;
  box-shadow:0 0 60px rgba(123,97,255,0.25),0 0 120px rgba(123,97,255,0.08),var(--shadow-lg);backdrop-filter:blur(24px);
  display:flex;flex-direction:column;overflow:hidden;z-index:200;
  animation:popup-in 200ms cubic-bezier(0.16,1,0.3,1)}
.glass-popup::before{content:'';position:absolute;inset:0;border-radius:20px;
  background:radial-gradient(circle at 30% 10%,rgba(123,97,255,0.12),transparent 50%),
    radial-gradient(circle at 80% 90%,rgba(0,209,255,0.06),transparent 40%);
  pointer-events:none;z-index:0}
@keyframes popup-in{from{opacity:0;transform:scale(0.95) translateY(10px)}to{opacity:1;transform:none}}

/* ── Onboarding overlay ─────────────────────────── */
.onboarding-overlay{position:absolute;inset:0;z-index:300;background:linear-gradient(180deg,#050508,#0B0F1A);display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}
.onboarding-overlay::before{content:'';position:absolute;inset:0;background:radial-gradient(600px 400px at 50% 30%,rgba(123,97,255,0.18),transparent 70%),radial-gradient(400px 300px at 70% 80%,rgba(0,209,255,0.08),transparent 60%);pointer-events:none}
.ob-step{animation:ob-in 400ms cubic-bezier(0.16,1,0.3,1)}
@keyframes ob-in{from{opacity:0;transform:translateY(20px) scale(0.97)}to{opacity:1;transform:none}}
.ob-dots{display:flex;gap:6px;justify-content:center;margin:20px 0}
.ob-dot{width:8px;height:8px;border-radius:50%;background:var(--fg-20);transition:all 250ms}
.ob-dot.active{background:var(--purple);width:24px;border-radius:4px;box-shadow:0 0 10px rgba(123,97,255,0.5)}

/* ── Utility ────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ── Acessibilidade (WCAG) ───────────────────────────────────────────────────
   Anel de foco visível APENAS para navegação por teclado (não no rato/toque),
   movimento reduzido honrado, e alvos de toque mínimos. */
:focus:not(:focus-visible){outline:none}
:focus-visible{outline:2px solid var(--purple-50);outline-offset:2px;border-radius:6px}
button:focus-visible,a:focus-visible,[role="button"]:focus-visible,[tabindex]:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--purple-50);outline-offset:2px}
/* Alvos de toque ≥ 40px (WCAG 2.5.5) para botões de ícone. */
button,[role="button"]{min-height:0}
.icon-btn,.tab-btn{min-width:40px;min-height:40px}
/* Salta para o conteúdo (leitores de ecrã / teclado). */
.skip-link{position:absolute;left:-9999px;top:8px;z-index:9999;background:var(--purple);color:#fff;padding:8px 14px;border-radius:8px;font-weight:700}
.skip-link:focus{left:8px}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.text-pretty{text-wrap:pretty}

/* ── Image Frame Fixes ──────────────────────────── */
/* All cover images in cards */
.card-cover img,.card img[style*="object-fit"]{object-fit:cover;object-position:center 30%;width:100%;height:100%}
/* Avatar images always fill circle/square */
.avatar img{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:inherit}
/* Story ring images */
.story-ring-inner img{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:50%}
/* Marketplace product thumbnails */
button[style*="overflow:hidden"] img{object-fit:cover;object-position:center}
/* Generic: any image inside a fixed-size container */
[style*="position:relative"] > img[style*="position:absolute"]{object-fit:cover;object-position:center 30%}
/* Prevent images from overflowing rounded containers */
[style*="borderRadius"] > img,[style*="border-radius"] > img{border-radius:inherit}
/* GradientCover images */
.card-cover{overflow:hidden}
.card-cover > img{display:block;width:100%;height:100%;object-fit:cover;object-position:center 30%}

/* Hexis thinking loader (estilo /loading cósmico) — anel orbital + pulso do símbolo */
@keyframes mxOrbit { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes mxPulse { 0%,100% { opacity: 0.65; transform: scale(0.94); } 50% { opacity: 1; transform: scale(1.06); } }
