/* SpaceBoox — Design System monocromático (preto + branco-gelo) · clean / tech */
:root{ /* tema escuro */
  --bg:#0a0b0d; --bg-2:#101114; --bg-3:#17191d; --border:#23252b;
  --text:#f1f3f6; --muted:#8b909b; --brand:#f1f3f6; --brand-2:#f1f3f6;
  --ok:#3ecf8e; --warn:#e0b341; --danger:#ef6b6b; --info:#6aa9ff;
  --shimmer:rgba(0,0,0,.38);
  --shadow:0 1px 2px rgba(0,0,0,.5), 0 14px 40px rgba(0,0,0,.45);
  --shadow-2:0 6px 20px rgba(0,0,0,.55), 0 30px 64px rgba(0,0,0,.5);
  --radius:16px;
}
[data-theme="light"]{ /* tema claro (padrão) */
  --bg:#f3f4f6; --bg-2:#ffffff; --bg-3:#f1f2f5; --border:#e8eaef;
  --text:#0c0d10; --muted:#8b909b; --brand:#0c0d10; --brand-2:#0c0d10;
  --ok:#13a36a; --warn:#b9830f; --danger:#d34545; --info:#3a7bd5;
  --shimmer:rgba(255,255,255,.55);
  --shadow:0 1px 2px rgba(12,13,16,.05), 0 12px 34px rgba(12,13,16,.06);
  --shadow-2:0 8px 22px rgba(12,13,16,.10), 0 28px 58px rgba(12,13,16,.16);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,Segoe UI,Roboto,sans-serif;font-weight:400;background:var(--bg);color:var(--text);letter-spacing:-.01em;-webkit-font-smoothing:antialiased;transition:background .2s,color .2s}
a{color:var(--text);text-decoration:none}
a:hover{opacity:.7;text-decoration:none}
h1,h2,h3{letter-spacing:-.02em}
svg{display:inline-block;vertical-align:middle}

/* Layout */
.layout{display:flex;min-height:100vh}
.sidebar{width:248px;background:var(--bg-2);border-right:1px solid var(--border);padding:22px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:3px}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px;border-bottom:1px solid var(--border);margin-bottom:12px}
.brand img{width:34px;height:34px;border-radius:9px}
.brand b{font-size:15px;font-weight:600;letter-spacing:-.02em}
.brand small{display:block;color:var(--muted);font-size:11px;font-weight:400;letter-spacing:0}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);font-size:14px;font-weight:500}
.nav a:hover{background:var(--bg-3);color:var(--text);opacity:1}
.nav a.active{background:var(--brand);color:var(--bg-2)}
.nav a.active svg{opacity:1}
.nav .ico{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}
.nav .ico svg{width:18px;height:18px}
.sidebar .spacer{flex:1}
.main{flex:1;padding:30px 34px;max-width:1340px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;gap:16px}
.topbar h1{font-size:25px;font-weight:600;margin:0}
.topbar .sub{color:var(--muted);font-size:13px;margin-top:3px}

/* Botões / controles */
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--bg-2);color:var(--text);border:1px solid var(--border);padding:9px 15px;border-radius:11px;font-family:inherit;font-size:13px;font-weight:500;line-height:1;cursor:pointer;transition:.15s;letter-spacing:-.01em}
.btn:hover{border-color:var(--text);text-decoration:none}
.btn svg{width:16px;height:16px}
.btn.primary{background:var(--brand);color:var(--bg-2);border-color:var(--brand)}
.btn.primary:hover{opacity:.88;border-color:var(--brand)}
.btn.danger{color:var(--danger);border-color:transparent;background:var(--bg-3)}
.btn.danger:hover{border-color:var(--danger)}
.btn.sm{padding:6px 11px;font-size:12px}
.theme-toggle{background:var(--bg-2);border:1px solid var(--border);color:var(--text);width:40px;height:40px;border-radius:11px;cursor:pointer;font-size:15px}
.theme-toggle:hover{border-color:var(--text)}
.search{width:280px;max-width:42vw}
input,select,textarea{background:var(--bg-2);border:1px solid var(--border);color:var(--text);padding:10px 13px;border-radius:11px;font-size:13px;font-family:inherit;letter-spacing:-.01em}
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--text)}
label{font-size:12px;color:var(--muted);display:block;margin-bottom:6px;font-weight:500}

/* Cards de métrica */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:26px}
.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow)}
.card .k{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;display:flex;align-items:center;gap:7px}
.card .v{font-size:38px;font-weight:300;margin-top:10px;letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.card .v.ok{color:var(--ok)}.card .v.warn{color:var(--warn)}.card .v.danger{color:var(--danger)}.card .v.info{color:var(--info)}
.panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:22px}
.panel h2{margin:0 0 16px;font-size:15px;font-weight:600}
.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:20px}
@media(max-width:1000px){.grid-2{grid-template-columns:1fr}}

/* Tabela */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:12px 12px;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.07em}
tbody tr:hover{background:var(--bg-3)}
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:8px;font-size:11px;font-weight:600;background:var(--bg-3);color:var(--muted);border:1px solid var(--border)}
.badge.ok{background:transparent;color:var(--ok);border-color:color-mix(in srgb,var(--ok) 35%,transparent)}
.badge.warn{background:transparent;color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,transparent)}
.badge.danger{background:transparent;color:var(--danger);border-color:color-mix(in srgb,var(--danger) 35%,transparent)}
.badge.info{background:transparent;color:var(--info);border-color:color-mix(in srgb,var(--info) 35%,transparent)}
.badge.muted{background:var(--bg-3);color:var(--muted)}
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin-bottom:16px}
.empty{text-align:center;color:var(--muted);padding:46px;font-size:13px}
code{background:var(--bg-3);padding:2px 7px;border-radius:6px;font-size:12px}
.key{font-family:ui-monospace,Menlo,monospace;font-size:12px}
.flash{padding:12px 16px;border-radius:11px;margin-bottom:18px;font-size:13px;border:1px solid var(--border)}
.flash.ok{background:var(--bg-3);color:var(--ok);border-color:color-mix(in srgb,var(--ok) 30%,transparent)}
.flash.err{background:var(--bg-3);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 30%,transparent)}

/* Login */
.login-wrap{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--bg-2);border:1px solid var(--border);border-radius:22px;padding:40px;width:390px;max-width:100%;box-shadow:var(--shadow)}
.login-card .brand{justify-content:center;border:0;flex-direction:column;text-align:center;gap:8px;padding-bottom:8px}
.login-card .brand img{width:58px;height:58px}
.login-card input{width:100%;margin-bottom:14px}

/* Barras de progresso */
.progress{height:11px;background:var(--bg-3);border-radius:20px;overflow:hidden;margin-top:10px}
.progress > i{display:block;height:100%;border-radius:20px;background:var(--brand);position:relative;overflow:hidden;transition:width .4s ease}
/* brilho que percorre a parte concluída */
.progress > i::after{content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(90deg,transparent 0%,var(--shimmer) 50%,transparent 100%);
  transform:translateX(-100%);animation:sbxShimmer 2.2s ease-in-out infinite}
@keyframes sbxShimmer{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}
@media (prefers-reduced-motion: reduce){.progress > i::after{animation:none;display:none}}

/* ─── Página pública RoadMap / Comunidade ───────────────────────────────── */
.pub{max-width:1180px;margin:0 auto;padding:30px 24px 60px}
.pub-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}
.pub-head .logo{display:flex;align-items:center;gap:13px}
.pub-head .logo img{width:42px;height:42px;border-radius:11px}
.pub-head h1{margin:0;font-size:20px;font-weight:600}
.pub-head small{color:var(--muted);font-size:12.5px}
.pub-hero{background:var(--text);color:var(--bg-2);border-radius:22px;padding:42px 40px;margin:8px 0 30px;position:relative;overflow:hidden}
.pub-hero h2{margin:0 0 12px;font-size:34px;font-weight:300;letter-spacing:-.03em}
.pub-hero p{margin:0;opacity:.66;font-size:15px;font-weight:300;line-height:1.6;max-width:760px}
.rm-grid{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}
@media(max-width:920px){.rm-grid{grid-template-columns:1fr}}
.rm-item{background:var(--bg-2);border:1px solid var(--border);border-radius:18px;padding:24px;box-shadow:var(--shadow);margin-bottom:18px}
.rm-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.rm-item h3{margin:0;font-size:19px;font-weight:500;letter-spacing:-.02em;line-height:1.3}
.rm-meta{font-size:12.5px;color:var(--muted);margin:8px 0 14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rm-pct{font-size:26px;font-weight:300;letter-spacing:-.03em;font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}
.rm-desc{font-size:14.5px;color:var(--muted);font-weight:300;line-height:1.6;margin:14px 0}
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:8px;font-size:11px;font-weight:600;background:var(--bg-3);color:var(--muted);border:1px solid var(--border)}
.chip.dev{background:var(--text);color:var(--bg-2);border-color:var(--text)}
.chip.done{background:transparent;color:var(--muted);border-color:var(--border)}
.chip.plan{background:var(--bg-3);color:var(--muted)}
.comments{margin-top:18px;border-top:1px solid var(--border);padding-top:16px}
.comment{display:flex;gap:11px;margin-bottom:14px}
.comment .av{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--bg-3)}
.comment .bubble{background:var(--bg-3);border-radius:13px;padding:11px 14px;flex:1}
.comment .who{font-size:12.5px;font-weight:600}
.comment .who span{color:var(--muted);font-weight:400}
.comment .body{font-size:13.5px;margin-top:4px;font-weight:300;line-height:1.5}
.comment .acts{margin-top:8px;display:flex;gap:14px;font-size:12px;color:var(--muted)}
.comment .acts button{background:none;border:0;color:var(--muted);cursor:pointer;font-size:12px;display:inline-flex;gap:4px;align-items:center}
.comment .acts button:hover{color:var(--text)}
.comment .replies{margin-left:47px;margin-top:12px}
.react-bar{display:flex;gap:6px;margin-top:8px;align-items:center}
.react-bar button{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:3px 9px;font-size:13px;cursor:pointer}
.react-bar button:hover{border-color:var(--text)}
.aside-card{background:var(--bg-2);border:1px solid var(--border);border-radius:18px;padding:22px;box-shadow:var(--shadow);margin-bottom:18px}
.aside-card h3{margin:0 0 14px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}
.aside-card input,.aside-card textarea,.aside-card select{width:100%;margin-bottom:11px}
.modal-bg{position:fixed;inset:0;background:rgba(8,9,11,.55);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:50;padding:18px}
.modal-bg.open{display:flex}
.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:30px;width:430px;max-width:100%;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow)}
.modal h3{margin:0 0 20px;font-size:19px;font-weight:600}
.user-pill{display:flex;align-items:center;gap:9px;background:var(--bg-2);border:1px solid var(--border);border-radius:30px;padding:4px 14px 4px 4px;font-size:13px}
.user-pill img{width:30px;height:30px;border-radius:50%;object-fit:cover}
.pending{background:var(--bg-3);border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);color:var(--warn);padding:11px 15px;border-radius:11px;font-size:13px}

/* Timeline de atualizações */
.rm-details{margin:14px 0}
.rm-details summary{cursor:pointer;font-size:13px;font-weight:500;color:var(--text);list-style:none}
.rm-details summary::-webkit-details-marker{display:none}
.timeline{list-style:none;margin:14px 0 4px;padding:0 0 0 18px;border-left:1px solid var(--border)}
.timeline li{position:relative;margin-bottom:16px}
.timeline li:before{content:'';position:absolute;left:-22px;top:4px;width:7px;height:7px;border-radius:50%;background:var(--text)}
.tl-date{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.02em}
.tl-body{font-size:13.5px;margin-top:3px;font-weight:300;line-height:1.5}

/* Datas + tecnologias */
.rm-dates{display:flex;flex-wrap:wrap;gap:10px;font-size:12.5px;margin:12px 0;color:var(--text)}
.rm-dates span{background:var(--bg-3);border:1px solid var(--border);padding:6px 12px;border-radius:9px;display:inline-flex;align-items:center;gap:6px;font-weight:400}
.rm-dates b{font-weight:600}
.tech-tags{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0}
.tech-tags .tech{font-size:11px;font-weight:500;padding:4px 11px;border-radius:20px;background:transparent;color:var(--text);border:1px solid var(--border)}

/* Cropper */
.crop-area{margin:12px 0}
.crop-area img{max-width:100%;display:block}
.crop-preview{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid var(--text);margin:8px auto;display:none}

/* ─── Ajude o Desenvolvedor (PIX) — card premium ────────────────────────── */
.support{padding:24px 22px;position:relative;overflow:hidden;box-shadow:var(--shadow-2);transition:box-shadow .25s ease,transform .25s ease}
.support:hover{transform:translateY(-2px)}
/* marca d'água </> translúcida no canto */
.support::after{content:'';position:absolute;top:22px;right:14px;width:92px;height:92px;
  background-color:var(--text);opacity:.07;pointer-events:none;z-index:0;
  -webkit-mask:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='16 18 22 12 16 6'/><polyline points='8 6 2 12 8 18'/><line x1='14' y1='4' x2='10' y2='20'/></svg>") center/contain no-repeat;
          mask:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='16 18 22 12 16 6'/><polyline points='8 6 2 12 8 18'/><line x1='14' y1='4' x2='10' y2='20'/></svg>") center/contain no-repeat}
.support > *{position:relative;z-index:1}
.support-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600}
.support-amount{font-size:46px;font-weight:300;letter-spacing:-.04em;margin:8px 0 2px;font-variant-numeric:tabular-nums;line-height:1}
.support-amount .cur{font-size:20px;color:var(--muted);font-weight:400;margin-right:4px;letter-spacing:0}
.support-amount .cents{font-size:24px;color:var(--muted)}
.support-status{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin:6px 0 16px;font-weight:300}
.support-status .mood{font-size:18px}
.support-goal-bar{height:5px;background:var(--bg-3);border-radius:20px;overflow:hidden}
.support-goal-bar > i{display:block;height:100%;background:var(--brand);border-radius:20px}
.support-goal-txt{font-size:11.5px;color:var(--muted);margin:8px 0 16px;font-weight:300}
.support-cta{width:100%;justify-content:center}
/* botão por card de módulo */
/* sugestões não aprovadas (transparência) */
.rej-item{font-size:13px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.rej-date{font-size:11px;color:var(--muted);margin:3px 0 4px}
.support-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:16px 0 4px;padding-top:16px;border-top:1px solid var(--border)}
/* linha de ações unificada (Pix + comentários) — compacta o card */
.rm-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:16px 0 4px;padding-top:16px;border-top:1px solid var(--border)}
.support-btn{font-weight:500}
.support-sum{font-size:12px;font-weight:600;color:var(--text)}
.support-sum::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--ok);margin-right:6px;vertical-align:middle}

/* Pop-up de agradecimento */
.modal-bg.open .modal{animation:sbxModalIn .3s ease}
@keyframes sbxModalIn{0%{transform:translateY(14px) scale(.97);opacity:0}100%{transform:none;opacity:1}}
.modal.thanks{text-align:center;max-width:430px}
.modal.thanks h3{font-size:21px;margin:6px 0 12px;font-weight:500}
.modal.thanks p{color:var(--muted);font-size:14px;line-height:1.65;margin:0 0 22px;font-weight:300}
.thanks-badge{width:80px;height:80px;border-radius:50%;margin:4px auto 18px;display:flex;align-items:center;justify-content:center;font-size:34px;background:var(--text);box-shadow:var(--shadow);animation:sbxPop .5s cubic-bezier(.2,.8,.3,1.5)}
@keyframes sbxPop{0%{transform:scale(.3);opacity:0}60%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}

/* Modais com formulário */
.modal .field-label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin:0 0 7px}
.modal input, .modal select, .modal textarea{width:100%;margin-bottom:15px}
.modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal .modal-actions{display:flex;gap:10px;margin-top:6px}
.modal .modal-actions .btn{flex:1;justify-content:center}
.modal .note{font-size:12px;color:var(--muted);margin:15px 0 0;text-align:center;line-height:1.55;font-weight:300}
.modal .crop-preview{margin-bottom:15px}
@media(min-width:861px){ .modal-form{width:470px} }

/* PIX modal */
.preset-row{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:14px}
.preset{background:var(--bg-2);border:1px solid var(--border);border-radius:11px;padding:12px 0;font-weight:500;font-size:13px;cursor:pointer;color:var(--text);font-variant-numeric:tabular-nums}
.preset:hover{border-color:var(--text)}
.preset.on{background:var(--brand);color:var(--bg-2);border-color:var(--brand)}
.countdown{font-size:34px;font-weight:300;color:var(--text);font-variant-numeric:tabular-nums;margin-bottom:12px;letter-spacing:-.02em}
.donate-qr{width:210px;height:210px;border-radius:14px;border:1px solid var(--border);background:#fff;padding:8px;margin:0 auto 14px;display:block}
.donate-waiting{font-size:13px;color:var(--muted);margin-top:12px;font-weight:300}
.donate-done{font-size:14px;font-weight:500;color:var(--ok);background:var(--bg-3);border:1px solid color-mix(in srgb,var(--ok) 30%,transparent);border-radius:11px;padding:13px;margin-top:12px}
.donate-expired{font-size:13px;color:var(--warn);margin-top:12px}

/* ═══ RESPONSIVIDADE ═══════════════════════════════════════════════════════ */
@media (max-width: 860px){
  .layout{flex-direction:column}
  .sidebar{width:auto;height:auto;position:static;flex-direction:column;border-right:0;border-bottom:1px solid var(--border)}
  .sidebar .brand{margin-bottom:10px}
  .nav{display:flex;flex-wrap:wrap;gap:5px}
  .nav a{padding:8px 12px;font-size:13px}
  .sidebar .spacer{display:none}
  .main{padding:18px}
  .topbar{flex-wrap:wrap;gap:12px}
  .topbar h1{font-size:22px}
  .topbar > div:last-child{width:100%;justify-content:space-between}
  .search{flex:1;width:auto;max-width:none}
  table{display:block;overflow-x:auto;white-space:nowrap}
  /* Público */
  .pub{padding:20px 16px 48px}
  .pub-head{flex-wrap:wrap}
  .pub-hero{padding:30px 24px;border-radius:18px}
  .pub-hero h2{font-size:26px}
  .pub-hero p{font-size:14px}
  .rm-item{padding:20px}
  .rm-item h3{font-size:18px}
  .rm-pct{font-size:23px}
  .modal{width:100%;padding:22px}
  .comment .replies{margin-left:22px}
}
@media (max-width: 480px){
  .card .v{font-size:32px}
  .pub-head h1{font-size:17px}
  .pub-hero h2{font-size:23px}
  .rm-item h3{font-size:17px}
  .support-amount{font-size:40px}
  .preset-row{grid-template-columns:repeat(2,1fr)}
}

/* Curtida única (coração) */
.like-btn{display:inline-flex;align-items:center;gap:6px;font-variant-numeric:tabular-nums}
.like-btn .lc{font-size:12px;font-weight:600;color:var(--text)}
.like-btn.on{border-color:var(--text)}

/* Modal de Atualizações (changelog por módulo) */
.upd-mod{border:1px solid var(--border);border-radius:13px;padding:15px 16px;margin-bottom:12px}
.upd-mod-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.upd-mod-head strong{font-size:15px;font-weight:600}
.upd-ver{margin-left:auto;font-size:14px;font-weight:300;color:var(--muted);font-variant-numeric:tabular-nums}

/* Comentários recolhíveis */
.cmt-toggle{background:none;border:1px solid var(--border);border-radius:10px;padding:8px 13px;font-size:12.5px;font-weight:500;color:var(--text);cursor:pointer}
.cmt-toggle:hover{border-color:var(--text)}
.cmt-more{background:none;border:0;color:var(--text);font-size:12.5px;font-weight:600;cursor:pointer;padding:8px 0;margin-top:4px}
.cmt-more:hover{opacity:.65}

/* ─── Seletor de idioma (1 botão + menu de bandeiras) ─────────────────────── */
.sbx-lang{position:relative;display:inline-block}
.sbx-lang-btn{width:40px;height:40px;border-radius:11px;background:var(--bg-2);border:1px solid var(--border);color:var(--text);font-size:16px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}
.sbx-lang-btn:hover{border-color:var(--text)}
.sbx-lang-menu{position:absolute;top:46px;right:0;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;min-width:172px;display:none;z-index:60}
.sbx-lang.open .sbx-lang-menu{display:block;animation:sbxModalIn .18s ease}
.sbx-lang-opt{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;text-decoration:none;color:var(--text);font-size:13px;white-space:nowrap}
.sbx-lang-opt:hover{background:var(--bg-3)}
.sbx-lang-opt.on{background:var(--bg-3);font-weight:600}
.sbx-lang-opt .fl{font-size:16px}

/* ─── Menu do avatar (perfil) ─────────────────────────────────────────────── */
.user-menu{position:relative;display:inline-flex}
.user-ph{padding:0;border:0;background:none;cursor:pointer;line-height:0;border-radius:50%}
.user-ph .av{width:32px;height:32px;border-radius:50%;object-fit:cover;display:block;border:2px solid transparent}
.user-ph:hover .av{border-color:var(--border)}
.user-pop{position:absolute;top:44px;left:0;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;min-width:200px;display:none;z-index:60}
.user-menu.open .user-pop{display:block;animation:sbxModalIn .18s ease}
.user-pop a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:8px;text-decoration:none;color:var(--text);font-size:13.5px;white-space:nowrap}
.user-pop a:hover{background:var(--bg-3)}
.user-pop a svg{width:17px;height:17px;flex:0 0 auto}

/* ─── Input do código 2FA ─────────────────────────────────────────────────── */
.twofa-input{width:230px;text-align:center;font-size:38px;font-weight:700;letter-spacing:.45em;padding:14px 0 14px .45em;border:1px solid var(--border);border-radius:14px;background:var(--bg-3);color:var(--text);font-variant-numeric:tabular-nums}
.twofa-input:focus{border-color:var(--text);outline:none}
.link-btn{background:none;border:0;color:var(--muted);font-size:13px;cursor:pointer;text-decoration:underline}
.link-btn:hover{color:var(--text)}

/* ─── Editar perfil (layout alinhado) ─────────────────────────────────────── */
.perfil-card .field-label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin:0 0 7px}
.perfil-card .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.perfil-card input, .perfil-card select{width:100%;margin-bottom:14px}
.perfil-card input[type=file]{margin-bottom:0}
.perfil-card .modal-actions{display:flex;gap:10px;margin-top:6px;margin-bottom:0}
.perfil-card .modal-actions .btn{margin-bottom:0}
@media (max-width:560px){ .perfil-card .form-row{grid-template-columns:1fr} }

/* ─── Loja de Módulos ─────────────────────────────────────────────────────── */
/* botão "Módulos Disponíveis" com sombra (top bar do RoadMap) */
.btn.btn-shadow{box-shadow:0 6px 18px rgba(12,13,16,.16);font-weight:600}
/* botões do topo do RoadMap — mesma fonte/ícone (via .btn) e largura natural/compacta */
.rm-topbtn{display:inline-flex;align-items:center;gap:7px}
[data-theme="light"] .btn.btn-shadow{box-shadow:0 8px 22px rgba(12,13,16,.16)}
.btn.btn-shadow:hover{transform:translateY(-1px)}

/* filtro */
.store-filter{display:flex;flex-wrap:wrap;gap:9px;margin:0 0 24px}
.store-filter .chip{text-decoration:none;padding:8px 15px;font-size:12.5px;cursor:pointer;transition:.15s}
.store-filter .chip:hover{border-color:var(--text);color:var(--text)}
.store-filter .chip.on{background:var(--text);color:var(--bg-2);border-color:var(--text)}

/* grid de cards */
.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:18px}
.store-card{position:relative;display:flex;flex-direction:column;background:var(--bg-2);border:1px solid var(--border);border-radius:18px;padding:22px;text-decoration:none;color:var(--text);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}
.store-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.store-badge{position:absolute;top:14px;right:14px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:4px 9px;border-radius:20px;background:var(--text);color:var(--bg-2)}
.store-badge.new{background:var(--ok);color:#fff}
.store-badge.updated{background:var(--info);color:#fff}
.store-badge.hot{background:#e2554d;color:#fff}
.store-logo{width:60px;height:60px;border-radius:15px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:14px}
.store-logo img{width:100%;height:100%;object-fit:cover}
.store-logo span{font-size:24px;font-weight:700;color:var(--muted)}
.store-logo.lg{width:84px;height:84px;border-radius:20px}
.store-logo.lg span{font-size:34px}
.store-cat-tag{display:inline-block;font-size:11px;color:var(--muted);margin-bottom:8px}
.store-card-name{margin:0 0 6px;font-size:16px;font-weight:600;letter-spacing:-.01em}
/* topo do card: logo + título lado a lado (mais compacto) */
.store-card-head{display:flex;align-items:center;gap:13px;margin-bottom:12px}
.store-card-head .store-logo{margin-bottom:0;flex:0 0 auto;width:54px;height:54px;border-radius:13px}
.store-card-htext{min-width:0}
.store-card-htext .store-cat-tag{margin-bottom:3px}
.store-card-htext .store-card-name{margin:0;font-size:15.5px;line-height:1.25}
.store-card-desc{margin:0 0 14px;font-size:12.5px;color:var(--muted);line-height:1.55;flex:1}
.store-price{font-size:50px;font-weight:200;letter-spacing:-.04em;font-variant-numeric:tabular-nums;line-height:1;color:var(--text);margin:14px 0 6px}
.store-price .cur{font-size:20px;color:var(--muted);font-weight:400;margin-right:7px;letter-spacing:0}
.store-price.sm{font-size:27px;margin:4px 0 12px}
.store-price.muted{color:var(--muted);font-size:16px;font-weight:400}
.store-card-meta{font-size:11px;color:var(--muted);display:flex;gap:5px;flex-wrap:wrap}

/* detalhe */
.store-back{display:inline-block;margin:0 0 16px;color:var(--muted);text-decoration:none;font-size:13px}
.store-back:hover{color:var(--text)}
.store-detail{display:grid;grid-template-columns:1fr 320px;gap:26px;align-items:start}
.store-detail-main{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:30px;box-shadow:var(--shadow)}
.store-detail-head{display:flex;gap:18px;align-items:flex-start;margin-bottom:20px}
.store-detail-head h2{margin:4px 0 6px;font-size:26px;font-weight:600;letter-spacing:-.02em}
.store-meta{font-size:12.5px;color:var(--muted)}
.store-desc{font-size:14.5px;line-height:1.7;color:var(--text);margin-bottom:8px}
.store-h3{font-size:15px;font-weight:600;margin:24px 0 12px}
.store-doc{font-size:13.5px;line-height:1.7;color:var(--muted);background:var(--bg-3);border-radius:12px;padding:16px 18px}
.store-changelog{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.store-changelog li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.store-buy{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:32px 28px;box-shadow:var(--shadow-2);position:sticky;top:18px}
.store-price-lbl{font-size:11.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600;margin-bottom:2px}
.store-price-once{font-size:12.5px;color:var(--muted);margin:6px 0 26px}
.store-cta{width:100%;justify-content:center;margin-bottom:12px;padding:14px 18px;font-size:14.5px}
.store-sub-note{font-size:13px;color:var(--muted);line-height:1.75;margin-top:12px;padding-top:20px;border-top:1px solid var(--border)}
.store-soon{font-size:12.5px;color:var(--warn);margin-top:16px;line-height:1.6}
@media (max-width:760px){ .store-detail{grid-template-columns:1fr} .store-buy{position:static} }

/* ── Galeria do módulo (loja) ───────────────────────────────────────────── */
.store-shots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:20px 0 6px}
.store-shot{padding:0;border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:zoom-in;background:var(--bg);aspect-ratio:16/10;transition:transform .15s ease,box-shadow .15s ease}
.store-shot img{width:100%;height:100%;object-fit:cover;display:block}
.store-shot:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.18)}
@media (max-width:640px){ .store-shots{grid-template-columns:repeat(2,1fr)} }

/* Lightbox */
.shot-lb{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(12,14,20,.88);backdrop-filter:blur(4px)}
.shot-lb.open{display:flex}
.shot-lb-stage{max-width:92vw;max-height:86vh;display:flex;align-items:center;justify-content:center}
.shot-lb-stage img{max-width:92vw;max-height:86vh;border-radius:12px;box-shadow:0 18px 60px rgba(0,0,0,.55);object-fit:contain}
.shot-lb-x{position:absolute;top:18px;right:22px;width:42px;height:42px;border-radius:50%;border:none;background:rgba(255,255,255,.14);color:#fff;font-size:26px;line-height:1;cursor:pointer}
.shot-lb-x:hover{background:rgba(255,255,255,.28)}
.shot-lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;border:none;background:rgba(255,255,255,.14);color:#fff;font-size:32px;line-height:1;cursor:pointer}
.shot-lb-nav:hover{background:rgba(255,255,255,.28)}
.shot-lb-nav.prev{left:24px}
.shot-lb-nav.next{right:24px}
.shot-lb-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;font-size:13px;background:rgba(0,0,0,.4);padding:5px 14px;border-radius:20px}

/* Admin: galeria de edição do módulo */
.shots-edit{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 8px}
.shots-edit:empty{display:none}
.shot-thumb{position:relative;width:84px;height:60px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}
.shot-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.shot-del{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:rgba(0,0,0,.6);color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.shot-del:hover{background:var(--danger)}
