@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700;800&display=swap');
:root{--panel:rgba(5,7,16,.94);--border:rgba(255,23,79,.68);--red:#ff174f;--cyan:#35eaff;--green:#62ff8f;--text:#f6f8ff;--muted:#9ca8bd}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:"Rajdhani","Segoe UI",system-ui,sans-serif;color:var(--text);background:linear-gradient(90deg,rgba(0,0,0,.95),rgba(4,6,15,.8),rgba(0,0,0,.95)),radial-gradient(circle at 22% 9%,rgba(255,0,80,.23),transparent 28%),radial-gradient(circle at 76% 16%,rgba(142,0,255,.2),transparent 30%),url('/assets/img/rubymc-background-neon.png') center/cover fixed no-repeat;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.6)),repeating-linear-gradient(0deg,rgba(255,255,255,.025) 0 1px,transparent 1px 4px)}button,input,select{font:inherit}button{cursor:pointer}.rubymc-shell{position:relative;z-index:1;width:min(1560px,calc(100% - 40px));margin:24px auto 42px}.launcher-window{border:1px solid var(--border);border-radius:13px;background:linear-gradient(145deg,rgba(5,7,16,.96),rgba(7,8,19,.92)),radial-gradient(circle at 76% 14%,rgba(255,0,80,.1),transparent 36%);box-shadow:0 0 0 1px rgba(255,255,255,.04),0 0 34px rgba(255,0,80,.23),inset 0 0 80px rgba(0,0,0,.36);overflow:hidden}.app-window{min-height:680px;display:grid;grid-template-columns:178px 1fr}.app-sidebar{border-right:1px solid rgba(255,255,255,.07);background:linear-gradient(180deg,rgba(2,4,12,.82),rgba(2,3,9,.72));padding:15px 12px;display:flex;flex-direction:column}.app-title{color:var(--red);font-size:13px;font-weight:900;margin:0 0 18px;display:flex;align-items:center;gap:7px}.tab-nav{display:grid;gap:8px}.tab-link{min-height:38px;border:0;border-radius:7px;background:transparent;color:#dbe6f6;display:flex;align-items:center;gap:10px;text-align:left;padding:0 12px;font-weight:800;transition:.18s ease}.tab-link:hover,.tab-link.active{color:#fff;background:linear-gradient(90deg,rgba(255,23,79,.84),rgba(108,0,34,.7));box-shadow:0 0 16px rgba(255,23,79,.25)}.settings-link{margin-top:auto;border:1px solid rgba(255,255,255,.08)}.sidebar-status{margin-top:14px;color:#b9c8da;font-size:13px;display:flex;flex-wrap:wrap;row-gap:4px;column-gap:6px;align-items:center}.sidebar-status span{width:10px;height:10px;background:var(--green);border-radius:50%;box-shadow:0 0 10px var(--green)}.app-content{position:relative;min-height:680px;padding:34px;background:linear-gradient(90deg,rgba(5,7,16,.98),rgba(5,7,16,.72),rgba(0,0,0,.06)),url('/assets/img/rubymc-tela-inicio.png') center right/cover no-repeat}.window-controls{display:flex;gap:18px}.app-content>.window-controls{position:absolute;top:14px;right:18px;z-index:5}.window-controls span:first-child:before{content:'–';color:#aeb7c8;font-weight:900}.window-controls span:last-child:before{content:'×';color:#aeb7c8;font-weight:900}.tab-panel{display:none;min-height:600px;animation:tabIn .18s ease both}.tab-panel.active{display:block}@keyframes tabIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cyan-label{color:var(--cyan);font-weight:900;letter-spacing:1.8px;font-size:15px}.panel-grid{display:grid;grid-template-columns:minmax(360px,.9fr) minmax(420px,1.1fr);gap:30px;align-items:start}.hero-grid{align-items:center;min-height:560px}.panel-copy h1{margin:12px 0;font-size:clamp(42px,5vw,72px);line-height:.95}.panel-copy h3,.panel-heading h2,.permission-box h3,.about-box h3{margin:0 0 10px}.panel-heading{margin-bottom:24px;padding-right:70px}.panel-heading.with-actions{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.panel-heading h2{font-size:36px;text-transform:uppercase;letter-spacing:1px}.panel-copy p,.panel-heading p,.permission-box p,.about-box p{color:var(--muted);line-height:1.55;font-size:17px}.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}.btn{min-height:42px;padding:0 24px;border-radius:8px;border:1px solid rgba(255,255,255,.12);color:#fff;font-weight:900;transition:.16s ease}.btn:hover{transform:translateY(-2px);filter:brightness(1.12)}.btn-red{background:linear-gradient(180deg,#ff2b5f,#a3002b);box-shadow:0 0 18px rgba(255,23,79,.3)}.btn-dark{background:linear-gradient(180deg,rgba(32,36,51,.96),rgba(8,10,20,.96))}label{display:block;margin:16px 0 8px;color:#b6c2d4;font-size:13px;font-weight:900;letter-spacing:.8px}input,select{width:100%;min-height:43px;border-radius:8px;border:1px solid rgba(255,255,255,.13);background:rgba(7,10,20,.88);color:var(--text);padding:0 14px;outline:none}.hero-stats,.mini-stats{display:grid;gap:8px}.hero-stats{grid-template-columns:1fr 1fr;margin-top:32px;gap:6px}.mini-stats{grid-template-columns:repeat(3,1fr);margin:20px 0}.hero-stats div,.mini-stats div,.status-box,.permission-box,.about-box,.list-box{border:1px solid rgba(255,255,255,.12);background:rgba(6,9,18,.78);border-radius:9px}.hero-stats div,.mini-stats div{min-height:48px;padding:6px 10px}.hero-stats span,.mini-stats span{color:#8792a7;display:block;font-weight:800;font-size:11px}.hero-stats strong,.mini-stats strong{display:block;margin-top:4px;color:#fff;font-size:17px}.hero-stats em{color:var(--green);display:block;font-size:12px;font-style:normal}.home-stat-sub{color:var(--muted);display:block;font-size:11px;font-style:normal;margin-top:0}.preview-frame{margin:0;border:1px solid rgba(255,255,255,.1);border-radius:10px;overflow:hidden;background:rgba(0,0,0,.28);box-shadow:inset 0 0 40px rgba(0,0,0,.35)}.preview-frame img{width:100%;display:block;object-fit:cover;opacity:.94}.hero-preview img{min-height:360px}.small-frame{margin-top:18px}.dropzone{min-height:90px;border:1px dashed rgba(255,255,255,.22);border-radius:10px;display:grid;place-items:center;text-align:center;background:rgba(6,9,18,.7);cursor:pointer}.dropzone small{color:#7f899d}.section-subtitle{margin-top:24px!important}.list-box{min-height:36px;padding:8px;color:#d6e0ef}.modpack-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}.modpack-row:last-child{border-bottom:0}.status-box{margin-top:12px;padding:var(--panel-padding,10px)}.status-box span{color:var(--muted)}.status-box strong{display:block;margin-top:6px;color:var(--green);font-size:18px}.status-box em{color:#a8b3c7;display:block;font-style:normal;margin-top:4px}.mini-stats strong{color:var(--green);font-size:22px}.permission-box,.about-box{padding:var(--panel-padding,10px)}.permission-box ul{padding-left:20px;margin:16px 0 0}.permission-box li{margin:8px 0}.display-grid{grid-template-columns:minmax(360px,1fr) 260px}.terminal-display{min-height:360px;max-height:450px;overflow:auto;margin:0;border-radius:10px;border:1px solid rgba(255,255,255,.13);background:linear-gradient(180deg,rgba(2,5,11,.96),rgba(0,0,0,.96));color:#84ff97;font-family:"JetBrains Mono","Fira Code",monospace;font-size:12px;line-height:1.5;padding:10px;white-space:pre-wrap}.project-option{width:100%;min-height:78px;margin-bottom:12px;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:rgba(6,9,18,.78);color:var(--text);display:grid;grid-template-columns:48px 1fr;grid-template-rows:auto auto;text-align:left;padding:12px 16px}.project-option span{grid-row:1/3;font-size:28px;align-self:center}.project-option strong{font-size:19px}.project-option em{color:var(--muted);font-style:normal}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.toggle-row{min-height:42px;padding:0 12px;border:1px solid rgba(255,255,255,.1);border-radius:9px;background:rgba(6,9,18,.78);display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.toggle{width:42px;height:22px;border:0;border-radius:30px;background:#34394c;position:relative}.toggle:after{content:"";position:absolute;top:4px;left:4px;width:14px;height:14px;border-radius:50%;background:#fff;transition:.15s}.toggle.active{background:var(--red)}.toggle.active:after{left:24px}@media(max-width:1280px){.panel-grid,.display-grid{grid-template-columns:1fr}.app-window{grid-template-columns:155px 1fr}}@media(max-width:820px){.rubymc-shell{width:calc(100% - 16px);margin:10px auto}.hero-stats,.mini-stats,.settings-grid{grid-template-columns:1fr 1fr}.app-window{grid-template-columns:1fr}.app-sidebar{min-height:auto}.tab-nav{grid-template-columns:1fr 1fr;display:grid}.settings-link{margin-top:10px}.app-content{padding:28px 18px}}@media(max-width:560px){.hero-stats,.mini-stats,.settings-grid,.tab-nav{grid-template-columns:1fr}}.panel-copy{padding:20px}


/* =========================================================
   RubyMC - Aba Configurações no estilo da referência
   ========================================================= */

body[data-current-tab="settings"] .app-content {
  background:
    linear-gradient(90deg, rgba(5,7,16,.98), rgba(5,7,16,.90), rgba(8,5,18,.76)),
    radial-gradient(circle at 18% 12%, rgba(145,77,255,.14), transparent 28%),
    radial-gradient(circle at 78% 22%, rgba(255,23,79,.16), transparent 30%),
    url("/assets/img/rubymc-configuracoes.png") center center / cover no-repeat;
}

.settings-panel {
  min-height: 600px;
}

.settings-page-header {
  margin-bottom: 16px;
  padding-right: 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding-bottom: 12px;
}

.settings-title-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

.settings-icon {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  color: #d35cff;
  font-size: 20px;
  background:
    linear-gradient(145deg, rgba(145,77,255,.18), rgba(255,23,79,.08));
  box-shadow: 0 0 24px rgba(145,77,255,.28);
}

.settings-page-header h2 {
  margin: 0;
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.settings-page-header p {
  margin: 4px 0 0;
  color: var(--muted);
}

.settings-page-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  max-width: 620px;
  align-items: start;
}

.settings-right-column {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.settings-form-card,
.settings-accounts-card,
.settings-about-card {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  background:
    linear-gradient(145deg, rgba(7,10,22,.88), rgba(4,6,15,.88));
  box-shadow:
    inset 0 0 50px rgba(0,0,0,.24),
    0 0 24px rgba(255,23,79,.10);
  padding: var(--panel-padding);
}

.settings-form-card h3,
.settings-about-card h3 {
  margin: 0 0 6px;
  font-size: 18px;
}

.settings-form-card p,
.settings-about-card p {
  color: var(--muted);
  margin: 0 0 12px;
  line-height: 1.5;
}

.settings-fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 12px;
}

.field-box {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  background: rgba(6,9,18,.74);
  padding: 8px;
}

.field-box small {
  display: block;
  color: #8792a7;
  font-size: 11px;
  font-weight: 800;
  margin-bottom: 6px;
}

.field-box select,
.field-box input {
  min-height: 34px;
  border: 0;
  border-radius: 7px;
  background: rgba(2,5,12,.72);
  padding: 0 10px;
}

.settings-toggle-row {
  min-height: 38px;
  padding: 0 10px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  background: rgba(6,9,18,.78);
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  color: #e9f1ff;
  font-weight: 700;
}

.settings-connected {
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 9px;
  color: #b9c8da;
}

.settings-about-card {
  min-height: auto;
}

.settings-accounts-card h3 {
  margin: 0 0 6px;
}

.settings-about-brand {
  min-height: 80px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  background:
    radial-gradient(circle at 24% 50%, rgba(255,23,79,.20), transparent 34%),
    rgba(6,9,18,.58);
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px;
  margin: 10px 0 14px;
}

.settings-logo-orb {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 1px solid rgba(255,23,79,.56);
  overflow: hidden;
  background: rgba(0,0,0,.32);
  box-shadow: 0 0 22px rgba(255,23,79,.28);
  flex: 0 0 auto;
}

.settings-brand-text strong {
  display: block;
  color: var(--red-2, #ff315f);
  font-size: 28px;
  letter-spacing: 1px;
  line-height: .95;
  text-shadow: 0 0 16px rgba(255,23,79,.26);
}

.settings-title-group {
  display: flex;
  align-items: center;
  gap: 16px;
}

.settings-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  color: #d35cff;
  font-size: 26px;
  background:
    linear-gradient(145deg, rgba(145,77,255,.18), rgba(255,23,79,.08));
  box-shadow: 0 0 24px rgba(145,77,255,.28);
}

.settings-page-header h2 {
  margin: 0;
  font-size: 36px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.settings-page-header p {
  margin: 8px 0 0;
  color: var(--muted);
}

.settings-page-grid {
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(330px, 420px);
  gap: 28px;
  max-width: 940px;
  align-items: start;
}

.settings-right-column {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.settings-form-card,
.settings-accounts-card,
.settings-about-card {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  background:
    linear-gradient(145deg, rgba(7,10,22,.88), rgba(4,6,15,.88));
  box-shadow:
    inset 0 0 50px rgba(0,0,0,.24),
    0 0 24px rgba(255,23,79,.10);
  padding: 24px;
}

.settings-form-card h3,
.settings-about-card h3 {
  margin: 0 0 8px;
  font-size: 24px;
}

.settings-form-card p,
.settings-about-card p {
  color: var(--muted);
  margin: 0 0 18px;
  line-height: 1.5;
}

.settings-fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 18px;
}

.field-box {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  background: rgba(6,9,18,.74);
  padding: 10px;
}

.field-box small {
  display: block;
  color: #8792a7;
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 8px;
}

.field-box select,
.field-box input {
  min-height: 38px;
  border: 0;
  border-radius: 7px;
  background: rgba(2,5,12,.72);
  padding: 0 10px;
}

.settings-toggle-row {
  min-height: 46px;
  padding: 0 12px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  background: rgba(6,9,18,.78);
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  color: #e9f1ff;
  font-weight: 700;
}

.settings-connected {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 9px;
  color: #b9c8da;
}

.settings-connected span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 10px var(--green);
}

.settings-user-info {
  margin-top: 16px;
}

.settings-user-info hr {
  border: none;
  border-top: 1px solid rgba(255,255,255,.08);
  margin: 0 0 14px;
}

.settings-user-info .sui-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.settings-user-info .sui-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #333;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  overflow: hidden;
}

.settings-user-info .sui-details {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.settings-user-info .sui-details strong {
  font-size: 14px;
  color: #e0e0e0;
}

.settings-user-info .sui-details small {
  font-size: 12px;
  color: var(--muted, #888);
  text-transform: uppercase;
  letter-spacing: .3px;
}

.btn-logout {
  width: 100%;
  padding: 8px 16px;
  border: 1px solid rgba(255,23,79,.35);
  border-radius: 8px;
  background: rgba(255,23,79,.08);
  color: #ff8a80;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, border-color .2s;
}

.btn-logout:hover {
  background: rgba(255,23,79,.18);
  border-color: rgba(255,23,79,.6);
}

.settings-about-card {
  min-height: 308px;
}

.settings-accounts-card h3 {
  margin: 0 0 8px;
}

.settings-about-brand {
  min-height: 112px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  background:
    radial-gradient(circle at 24% 50%, rgba(255,23,79,.20), transparent 34%),
    rgba(6,9,18,.58);
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px;
  margin: 12px 0 20px;
}

.settings-logo-orb {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  border: 1px solid rgba(255,23,79,.56);
  overflow: hidden;
  background: rgba(0,0,0,.32);
  box-shadow: 0 0 22px rgba(255,23,79,.28);
  flex: 0 0 auto;
}

.settings-logo-orb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transform: none;
}

.settings-brand-text strong {
  display: block;
  color: var(--red-2, #ff315f);
  font-size: 36px;
  letter-spacing: 1px;
  line-height: .95;
  text-shadow: 0 0 16px rgba(255,23,79,.26);
}

.settings-brand-text span {
  color: white;
  font-weight: 900;
  letter-spacing: 4px;
  font-size: 13px;
}

.heart {
  color: var(--red);
}

.settings-update-button {
  width: 100%;
  margin-top: 8px;
}

@media (max-width: 980px) {
  .settings-page-grid {
    grid-template-columns: 1fr;
    max-width: none;
  }

  .settings-fields-grid {
    grid-template-columns: 1fr;
  }
}


/* =========================================================
   RubyMC Home Temple Background Patch
   Fundo da aba Início sem textos/botões, usando somente o templo.
   ========================================================= */

body {
  background:
    linear-gradient(90deg, rgba(0,0,0,.94), rgba(4,6,15,.78), rgba(0,0,0,.94)),
    radial-gradient(circle at 22% 9%, rgba(255,0,80,.20), transparent 28%),
    radial-gradient(circle at 76% 16%, rgba(142,0,255,.20), transparent 30%),
    url("/assets/img/rubymc-home-temple-bg.png") center center / cover fixed no-repeat !important;
}

/* Quando estiver na aba Início do layout single-page */
body[data-current-tab="home"] .app-content {
  background:
    linear-gradient(90deg, rgba(5,7,16,.98), rgba(5,7,16,.68), rgba(0,0,0,.10)),
    url("/assets/img/rubymc-home-temple-bg.png") center center / cover no-repeat !important;
}

/* Preview da tela inicial sem botões/textos queimados na imagem */
#tab-home .hero-preview img,
#tab-home .preview-frame img {
  content: url("/assets/img/rubymc-home-temple-bg.png");
  min-height: 360px;
  object-fit: cover;
  object-position: center center;
}

/* Para versões anteriores que usam .hero-panel ou .hero-content */
.hero-panel,
.hero-content {
  background:
    linear-gradient(90deg, rgba(5,7,16,.98), rgba(5,7,16,.68), rgba(0,0,0,.10)),
    url("/assets/img/rubymc-home-temple-bg.png") center center / cover no-repeat !important;
}


/* =========================================================
   RubyMC Background + Logo Fix
   Corrige:
   - excesso de imagens de fundo simultâneas;
   - fundo duplicado dentro do card da aba Início;
   - logo cortada no topo;
   - melhora leitura do painel principal.
   ========================================================= */

/* 1) O body deixa de repetir a imagem do templo/showcase.
   Ele fica só com base escura + brilho neon. */
body {
  background:
    radial-gradient(circle at 18% 8%, rgba(255, 0, 80, .20), transparent 26%),
    radial-gradient(circle at 78% 12%, rgba(142, 0, 255, .18), transparent 30%),
    linear-gradient(90deg, rgba(0,0,0,.98), rgba(4,6,15,.94), rgba(0,0,0,.98)) !important;
}

/* 2) Evita overlay pesado gerando aparência de várias imagens empilhadas. */
body::before {
  background:
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.52)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.020) 0 1px, transparent 1px 4px) !important;
}

/* 3) O fundo do templo fica somente na área principal da aba Início. */
body[data-current-tab="home"] .app-content {
  background:
    linear-gradient(90deg, rgba(5,7,16,.98) 0%, rgba(5,7,16,.82) 42%, rgba(5,7,16,.34) 100%),
    url("/assets/img/rubymc-home-temple-bg.png") center center / cover no-repeat !important;
}

/* 4) Nas outras abas, remove a imagem do templo do fundo para não parecer duplicado. */
body:not([data-current-tab="home"]) .app-content,
body[data-current-tab="modpacks"] .app-content,
body[data-current-tab="server"] .app-content,
body[data-current-tab="versions"] .app-content,
body[data-current-tab="vip"] .app-content,
body[data-current-tab="display"] .app-content,
body[data-current-tab="project"] .app-content,
body[data-current-tab="settings"] .app-content {
  background:
    radial-gradient(circle at 18% 12%, rgba(255,23,79,.10), transparent 26%),
    radial-gradient(circle at 78% 18%, rgba(145,77,255,.12), transparent 30%),
    linear-gradient(145deg, rgba(5,7,16,.98), rgba(7,8,19,.94)) !important;
}

/* 5) A aba Configurações mantém seu estilo próprio, mas sem repetir imagem grande atrás. */
body[data-current-tab="settings"] .app-content {
  background:
    radial-gradient(circle at 18% 12%, rgba(145,77,255,.14), transparent 28%),
    radial-gradient(circle at 78% 22%, rgba(255,23,79,.13), transparent 30%),
    linear-gradient(145deg, rgba(5,7,16,.98), rgba(8,5,18,.94)) !important;
}

/* 6) Remove a imagem duplicada dentro do preview da aba Início.
   Assim o templo aparece uma vez: como fundo da página/aba, não dentro de outro quadro. */
#tab-home .hero-preview,
#tab-home .preview-frame {
  display: none !important;
}

/* 7) Com o preview oculto, a tela inicial ocupa melhor o espaço. */
#tab-home .hero-grid,
#tab-home .panel-grid {
  grid-template-columns: minmax(360px, 720px) !important;
  align-items: center !important;
}

#tab-home .panel-copy {
  max-width: 720px;
}



/* 11) Melhora contraste dos textos sobre o fundo único. */
#tab-home .panel-copy,
#tab-home .panel-copy p,
#tab-home label {
  text-shadow: 0 2px 12px rgba(0,0,0,.75);
}

/* 12) Cards de estatísticas mais legíveis sobre o fundo. */
#tab-home .hero-stats div {
  background: rgba(6,9,18,.84) !important;
  backdrop-filter: blur(6px);
  padding: 8px 10px !important;
}

.hero-stats {
  gap: 8px !important;
}

.home-quick-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 16px;
}

.home-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  background: rgba(6,9,18,.78);
}

.home-card-icon {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
}

.home-card-body {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.home-card-label {
  font-size: 11px;
  font-weight: 800;
  color: #8792a7;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.home-card-body strong {
  font-size: 16px;
  color: #fff;
  display: flex;
  align-items: baseline;
  gap: 4px;
}

.home-card-unit {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  text-transform: none;
  letter-spacing: 0;
}

/* 13) Responsivo */
@media (max-width: 820px) {
  #tab-home .hero-grid,
  #tab-home .panel-grid {
    grid-template-columns: 1fr !important;
  }
}


/* =========================================================
   RubyMC Overscroll Background Fix
   Corrige o fundo branco ao puxar/arrastar a página para baixo.
   ========================================================= */

/* O branco aparece porque o fundo raiz do navegador/html fica visível
   quando existe overscroll no topo da página. */
html {
  min-height: 100%;
  background:
    radial-gradient(circle at 18% 8%, rgba(255, 0, 80, .20), transparent 26%),
    radial-gradient(circle at 78% 12%, rgba(142, 0, 255, .18), transparent 30%),
    linear-gradient(90deg, #02030a, #050716, #02030a) !important;
  background-color: #03040a !important;
  overscroll-behavior-y: none;
  overscroll-behavior-x: none;
}

/* Garante que o body nunca deixe a raiz branca aparecer. */
body {
  min-height: 100vh;
  min-height: 100dvh;
  background-color: #03040a !important;
  overscroll-behavior: none;
}

/* Camada fixa extra para cobrir a região acima do topo durante o puxão. */
body::after {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  top: -260px;
  height: 320px;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 8%, rgba(255, 0, 80, .18), transparent 28%),
    radial-gradient(circle at 78% 12%, rgba(142, 0, 255, .16), transparent 30%),
    linear-gradient(90deg, #02030a, #050716, #02030a);
}

/* Remove qualquer faixa clara herdada de wrappers externos. */
.rubymc-shell,
.app-window,
.app-content {
  background-clip: padding-box;
}

/* Caso algum navegador ignore overscroll-behavior, pelo menos a cor raiz fica escura. */
:root {
  background-color: #03040a !important;
}





/* =========================================================
   RubyMC Modpack Box Image Patch
   Implementa a caixa 3D RUBY na parte de Modpacks.
   ========================================================= */

.nav-modpack-icon,
.side-modpack-icon {
  width: 18px;
  height: 18px;
  object-fit: contain;
  flex: 0 0 auto;
  filter: drop-shadow(0 0 8px rgba(255, 23, 79, .60));
}

.title-modpack-icon {
  width: 80px;
  height: 80px;
  object-fit: contain;
  vertical-align: middle;
  margin-right: 10px;
  filter: drop-shadow(0 0 14px rgba(255, 23, 79, .70));
}

.modpack-box-badge {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 72px;
  margin: 0 0 12px;
  padding: 10px;
  border: 1px solid rgba(255, 23, 79, .34);
  border-radius: 12px;
  background:
    radial-gradient(circle at 14% 50%, rgba(255, 23, 79, .22), transparent 34%),
    linear-gradient(145deg, rgba(8, 10, 22, .84), rgba(4, 6, 15, .78));
  box-shadow:
    inset 0 0 40px rgba(0, 0, 0, .24),
    0 0 22px rgba(255, 23, 79, .13);
}

.modpack-box-badge img {
  width: 60px;
  height: 60px;
  object-fit: contain;
  flex: 0 0 auto;
  filter: drop-shadow(0 0 16px rgba(255, 23, 79, .70));
}

.modpack-box-badge strong {
  display: block;
  color: #fff;
  font-size: 18px;
  letter-spacing: .5px;
}

.modpack-box-badge small {
  display: block;
  color: var(--muted, #9ca8bd);
  margin-top: 4px;
  line-height: 1.35;
}

.dropzone.modpack-dropzone {
  position: relative;
  overflow: hidden;
  min-height: 80px;
  padding: 12px 12px 12px 90px;
  place-items: center start;
  text-align: left;
}

.dropzone.modpack-dropzone::before {
  content: "";
  position: absolute;
  left: 22px;
  top: 50%;
  width: 64px;
  height: 64px;
  transform: translateY(-50%);
  background: url("/assets/img/rubymc-modpack-box-icon.png") center / contain no-repeat;
  filter: drop-shadow(0 0 14px rgba(255, 23, 79, .65));
}

.dropzone.modpack-dropzone::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 72px 50%, rgba(255, 23, 79, .14), transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(53, 234, 255, .06), transparent 34%);
  pointer-events: none;
}

.dropzone.modpack-dropzone span,
.dropzone.modpack-dropzone small {
  position: relative;
  z-index: 1;
}

#tab-modpacks .preview-frame img[src*="rubymc-modpacks"],
#section-modpacks .module-preview img[src*="rubymc-modpacks"] {
  border-color: rgba(255, 23, 79, .26);
  box-shadow: 0 0 28px rgba(255, 23, 79, .12);
}

@media (max-width: 680px) {
  .modpack-box-badge {
    align-items: flex-start;
  }

  .modpack-box-badge img {
    width: 60px;
    height: 60px;
  }

  .dropzone.modpack-dropzone {
    padding-left: 18px;
    padding-top: 90px;
    text-align: center;
    place-items: center;
  }

  .dropzone.modpack-dropzone::before {
    left: 50%;
    top: 18px;
    transform: translateX(-50%);
  }
}


/* =========================================================
   RubyMC Discord Ruby Icon Patch
   Substitui o emoji de controle da página Discord por imagem
   mantendo tamanho de emoji.
   ========================================================= */

.rubymc-discord-icon,
.discord-ruby-icon,
.nav-discord-icon,
.title-discord-icon {
  width: 1.15em;
  height: 1.15em;
  display: inline-block;
  vertical-align: -0.18em;
  object-fit: contain;
  flex: 0 0 auto;
  filter: drop-shadow(0 0 7px rgba(255, 23, 79, .62));
}

/* Ícone do menu lateral: mesmo tamanho visual do emoji antigo */
.tab-link .nav-discord-icon {
  width: 18px;
  height: 18px;
  margin-right: 0;
}

/* Ícone no título da aba Discord Bot */
.panel-heading h2 .title-discord-icon,
.module-header h2 .title-discord-icon,
/* Ajutes para ícone do Discord no título do modal / card de verificação */
#tab-home .permission-box h3 .title-discord-icon,
  width: 1.05em;
  height: 1.05em;
  margin-right: 7px;
}

/* Evita que o ícone fique gigante caso herde regra de imagens do card */
.app-sidebar img.nav-discord-icon,
.window-sidebar img.nav-discord-icon {
  max-width: 18px !important;
  max-height: 18px !important;
}

/* Ajuste para botões com ícone e texto */
.tab-link {
  gap: 10px;
}


/* =========================================================
   RubyMC Server Live Status + Background Patch
   Fundo exclusivo da aba Servidor + painel de jogadores online.
   ========================================================= */

:root {
  --rubymc-server-bg: url("/assets/img/rubymc-server-page-bg.png");
  --rubymc-server-bg-dark: url("/assets/img/rubymc-server-page-bg-dark.png");
  --rubymc-server-bg-soft: url("/assets/img/rubymc-server-page-bg-soft.png");
}

body[data-current-tab="server"] #tab-server .ruby-panel,
body[data-current-tab="server"] #tab-server .server-panel,
body[data-current-tab="server"] .server-page-panel {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5,7,16,.96) 0%, rgba(5,7,16,.74) 44%, rgba(5,7,16,.34) 100%),
    radial-gradient(circle at 20% 16%, rgba(53,234,255,.14), transparent 32%),
    radial-gradient(circle at 78% 12%, rgba(255,23,79,.16), transparent 34%),
    var(--rubymc-server-bg-dark) center center / cover no-repeat !important;
}

body[data-current-tab="server"] #tab-server .ruby-panel::before,
body[data-current-tab="server"] .server-page-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.22)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.014) 0 1px, transparent 1px 4px);
}

body[data-current-tab="server"] #tab-server .ruby-panel > *,
body[data-current-tab="server"] .server-page-panel > * {
  position: relative;
  z-index: 1;
}

#tab-server {
  position: relative;
  isolation: isolate;
}

#tab-server::before {
  content: "";
  position: absolute;
  inset: -34px;
  z-index: -1;
  pointer-events: none;
  opacity: .72;
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(5,7,16,.96), rgba(5,7,16,.72), rgba(5,7,16,.34)),
    var(--rubymc-server-bg-soft) center center / cover no-repeat;
}

body:not([data-current-tab="server"]) #tab-server::before {
  opacity: 0;
}

#tab-server .panel-body > div:first-child,
#tab-server .server-live-card,
#tab-server .server-api-card {
  border: 1px solid rgba(53,234,255,.20);
  border-radius: 15px;
  padding: 20px;
  background:
    linear-gradient(145deg, rgba(5,7,16,.78), rgba(7,10,22,.58));
  box-shadow:
    inset 0 0 42px rgba(0,0,0,.24),
    0 0 26px rgba(53,234,255,.08),
    0 0 22px rgba(255,23,79,.08);
  backdrop-filter: blur(6px);
}

#tab-server .preview-card,
#tab-server .server-preview-card {
  position: relative;
  overflow: hidden;
  border-color: rgba(53,234,255,.30);
  box-shadow:
    0 0 30px rgba(53,234,255,.10),
    0 0 28px rgba(255,23,79,.12),
    inset 0 0 45px rgba(0,0,0,.28);
}

#tab-server .preview-card img,
#tab-server .server-preview-card img {
  content: url("/assets/img/rubymc-server-page-bg.png") !important;
  min-height: 330px;
  object-fit: cover;
  object-position: center center;
  opacity: .96;
}

.server-live-overlay {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  pointer-events: none;
}

.server-live-overlay div,
.server-live-grid div,
.server-player-list {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(4,7,16,.76);
  border-radius: 10px;
  backdrop-filter: blur(7px);
}

.server-live-overlay div {
  padding: 10px;
}

.server-live-overlay span,
.server-live-grid span {
  display: block;
  color: #8ea0b8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .6px;
}

.server-live-overlay strong,
.server-live-grid strong {
  display: block;
  color: var(--green, #62ff8f);
  font-size: 18px;
  margin-top: 4px;
}

.server-live-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(92px, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.server-live-grid div {
  min-height: 74px;
  padding: 12px;
}

.server-player-list {
  margin-top: 12px;
  padding: 12px;
  min-height: 46px;
}

.server-player-list-title {
  color: #a8b8cc;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .7px;
  margin-bottom: 8px;
}

.server-player-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.server-player-tag {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(98,255,143,.10);
  border: 1px solid rgba(98,255,143,.24);
  color: #dfffe7;
  font-size: 13px;
  font-weight: 800;
}

.server-live-error {
  color: #ff8aa7 !important;
}

.server-motd {
  margin-top: 12px;
  color: #b7c3d7;
  font-size: 14px;
  line-height: 1.35;
}

.server-bars {
  display: inline-grid;
  grid-template-columns: repeat(5, 5px);
  gap: 3px;
  align-items: end;
  height: 20px;
  margin-left: 8px;
}

.server-bars i {
  display: block;
  width: 5px;
  background: rgba(98,255,143,.85);
  border-radius: 2px;
  box-shadow: 0 0 6px rgba(98,255,143,.40);
}

.server-bars i:nth-child(1) { height: 6px; }
.server-bars i:nth-child(2) { height: 9px; }
.server-bars i:nth-child(3) { height: 12px; }
.server-bars i:nth-child(4) { height: 16px; }
.server-bars i:nth-child(5) { height: 20px; }

@media (max-width: 980px) {
  .server-live-overlay,
  .server-live-grid {
    grid-template-columns: 1fr;
  }

  #tab-server .preview-card img,
  #tab-server .server-preview-card img {
    min-height: 260px;
  }
}


/* =========================================================
   RubyMC Server Remove Right Preview Patch
   Remove a imagem duplicada da direita na aba Servidor.
   Mantém somente a imagem principal como fundo da página.
   ========================================================= */

/* Remove o preview/imagem duplicada do lado direito da página Servidor */
#tab-server .preview-card,
#tab-server .server-preview-card,
#tab-server figure.preview-card,
#tab-server figure.server-preview-card {
  display: none !important;
}

/* Garante que a área do servidor não reserve coluna vazia para a imagem removida */
#tab-server .panel-body,
#tab-server .server-grid,
#tab-server .server-layout,
#tab-server .content-grid,
#tab-server .module-grid {
  grid-template-columns: minmax(420px, 760px) !important;
  justify-content: start !important;
}

/* Mantém somente o fundo da página Servidor */
body[data-current-tab="server"] #tab-server .ruby-panel,
body[data-current-tab="server"] #tab-server .server-panel,
body[data-current-tab="server"] .server-page-panel {
  background:
    linear-gradient(90deg, rgba(5,7,16,.94) 0%, rgba(5,7,16,.70) 44%, rgba(5,7,16,.30) 100%),
    radial-gradient(circle at 20% 16%, rgba(53,234,255,.12), transparent 32%),
    radial-gradient(circle at 78% 12%, rgba(255,23,79,.14), transparent 34%),
    url("/assets/img/rubymc-server-page-bg.png") center center / cover no-repeat !important;
}

/* Remove qualquer camada de imagem repetida vinda do preview antigo */
#tab-server .preview-card img,
#tab-server .server-preview-card img,
#tab-server .server-live-overlay {
  display: none !important;
}

/* Deixa o conteúdo principal mais bem posicionado após remover a imagem da direita */
#tab-server .panel-body > div:first-child,
#tab-server .server-live-card,
#tab-server .server-api-card {
  max-width: 760px;
}

/* A imagem de fundo continua mais visível, sem duplicar por trás do painel direito */
#tab-server::before {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88), rgba(5,7,16,.58), rgba(5,7,16,.24)),
    url("/assets/img/rubymc-server-page-bg.png") center center / cover no-repeat !important;
  opacity: .78;
}

/* Responsivo */
@media (max-width: 900px) {
  #tab-server .panel-body,
  #tab-server .server-grid,
  #tab-server .server-layout,
  #tab-server .content-grid,
  #tab-server .module-grid {
    grid-template-columns: 1fr !important;
  }

  #tab-server .panel-body > div:first-child,
  #tab-server .server-live-card,
  #tab-server .server-api-card {
    max-width: 100%;
  }
}


/* =========================================================
   RubyMC Server Clean Background No Front Patch
   Remove definitivamente o card/imagem frontal duplicada da
   aba Servidor e usa somente uma imagem limpa como fundo.
   ========================================================= */

:root {
  --rubymc-server-bg: url("/assets/img/rubymc-server-page-bg.png");
  --rubymc-server-bg-dark: url("/assets/img/rubymc-server-page-bg-dark.png");
  --rubymc-server-bg-soft: url("/assets/img/rubymc-server-page-bg-soft.png");
}

/* 1) Remove qualquer preview/card/figure frontal dentro da aba Servidor. */
#tab-server figure,
#tab-server .preview-card,
#tab-server .server-preview-card,
#tab-server .preview-frame,
#tab-server .server-live-overlay,
#tab-server [class*="preview"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* 2) Impede duplicação causada por pseudo-elementos antigos. */
#tab-server::before,
#tab-server::after,
body[data-current-tab="server"] #tab-server::before,
body[data-current-tab="server"] #tab-server::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

/* 3) Deixa somente UMA imagem de fundo aplicada no painel principal. */
body[data-current-tab="server"] #tab-server .ruby-panel,
body[data-current-tab="server"] #tab-server .server-panel,
body[data-current-tab="server"] .server-page-panel,
#tab-server .ruby-panel,
#tab-server .server-panel,
#tab-server.server-page-panel {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5,7,16,.92) 0%, rgba(5,7,16,.68) 42%, rgba(5,7,16,.26) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.12), transparent 32%),
    radial-gradient(circle at 78% 14%, rgba(255,23,79,.14), transparent 34%),
    var(--rubymc-server-bg) center center / cover no-repeat !important;
}

/* 4) Camada leve por cima do fundo, sem repetir imagem. */
body[data-current-tab="server"] #tab-server .ruby-panel::before,
#tab-server .ruby-panel::before,
#tab-server .server-panel::before,
.server-page-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.20)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0 1px, transparent 1px 4px) !important;
}

body[data-current-tab="server"] #tab-server .ruby-panel > *,
#tab-server .ruby-panel > *,
#tab-server .server-panel > *,
.server-page-panel > * {
  position: relative;
  z-index: 1;
}

/* 5) Ajusta a grade para não reservar espaço da imagem removida. */
#tab-server .panel-body,
#tab-server .server-grid,
#tab-server .server-layout,
#tab-server .content-grid,
#tab-server .module-grid {
  display: grid;
  grid-template-columns: minmax(420px, 760px) !important;
  justify-content: start !important;
  align-items: start !important;
}

/* 6) Cards de status mais limpos sobre o fundo único. */
#tab-server .panel-body > div:first-child,
#tab-server .server-live-card,
#tab-server .server-api-card,
#tab-server .status-box {
  max-width: 760px;
  border: 1px solid rgba(53,234,255,.18);
  border-radius: 15px;
  background:
    linear-gradient(145deg, rgba(5,7,16,.78), rgba(7,10,22,.56)) !important;
  box-shadow:
    inset 0 0 42px rgba(0,0,0,.24),
    0 0 26px rgba(53,234,255,.08),
    0 0 22px rgba(255,23,79,.08);
  backdrop-filter: blur(5px);
}

/* 7) Mantém os cards live funcionando, sem depender da imagem frontal. */
.server-live-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(92px, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.server-live-grid div,
.server-player-list {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(4,7,16,.74);
  border-radius: 10px;
  backdrop-filter: blur(7px);
}

.server-live-grid div {
  min-height: 74px;
  padding: 12px;
}

.server-live-grid span {
  display: block;
  color: #8ea0b8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .6px;
}

.server-live-grid strong {
  display: block;
  color: var(--green, #62ff8f);
  font-size: 18px;
  margin-top: 4px;
}

.server-player-list {
  margin-top: 12px;
  padding: 12px;
  min-height: 46px;
}

.server-player-list-title {
  color: #a8b8cc;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .7px;
  margin-bottom: 8px;
}

.server-player-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.server-player-tag {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(98,255,143,.10);
  border: 1px solid rgba(98,255,143,.24);
  color: #dfffe7;
  font-size: 13px;
  font-weight: 800;
}

.server-motd {
  margin-top: 12px;
  color: #b7c3d7;
  font-size: 14px;
  line-height: 1.35;
}

.server-live-error {
  color: #ff8aa7 !important;
}

.server-bars {
  display: inline-grid;
  grid-template-columns: repeat(5, 5px);
  gap: 3px;
  align-items: end;
  height: 20px;
  margin-left: 8px;
}

.server-bars i {
  display: block;
  width: 5px;
  background: rgba(98,255,143,.85);
  border-radius: 2px;
  box-shadow: 0 0 6px rgba(98,255,143,.40);
}

.server-bars i:nth-child(1) { height: 6px; }
.server-bars i:nth-child(2) { height: 9px; }
.server-bars i:nth-child(3) { height: 12px; }
.server-bars i:nth-child(4) { height: 16px; }
.server-bars i:nth-child(5) { height: 20px; }

/* 8) Responsivo. */
@media (max-width: 900px) {
  #tab-server .panel-body,
  #tab-server .server-grid,
  #tab-server .server-layout,
  #tab-server .content-grid,
  #tab-server .module-grid {
    grid-template-columns: 1fr !important;
  }

  #tab-server .panel-body > div:first-child,
  #tab-server .server-live-card,
  #tab-server .server-api-card,
  #tab-server .status-box {
    max-width: 100%;
  }
}


/* =========================================================
   RubyMC Server Background Final Patch
   Aplica a imagem final como fundo único da página Servidor
   e remove qualquer preview/card duplicado da direita.
   ========================================================= */

:root {
  --rubymc-server-bg: url("/assets/img/rubymc-server-page-bg.png");
  --rubymc-server-bg-dark: url("/assets/img/rubymc-server-page-bg-dark.png");
  --rubymc-server-bg-soft: url("/assets/img/rubymc-server-page-bg-soft.png");
}

/* Remove definitivamente a imagem/card frontal duplicado */
#tab-server figure,
#tab-server .preview-card,
#tab-server .server-preview-card,
#tab-server .preview-frame,
#tab-server .server-live-overlay,
#tab-server [class*="preview"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Impede repetição por pseudo-elementos antigos */
#tab-server::before,
#tab-server::after,
body[data-current-tab="server"] #tab-server::before,
body[data-current-tab="server"] #tab-server::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

/* Fundo único da aba Servidor */
body[data-current-tab="server"] #tab-server .ruby-panel,
body[data-current-tab="server"] #tab-server .server-panel,
body[data-current-tab="server"] .server-page-panel,
#tab-server .ruby-panel,
#tab-server .server-panel,
#tab-server.server-page-panel {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.62) 42%, rgba(5,7,16,.22) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.10), transparent 32%),
    radial-gradient(circle at 78% 14%, rgba(255,23,79,.13), transparent 34%),
    var(--rubymc-server-bg) center center / cover no-repeat !important;
}

/* Camada de leitura leve, sem imagem duplicada */
body[data-current-tab="server"] #tab-server .ruby-panel::before,
#tab-server .ruby-panel::before,
#tab-server .server-panel::before,
.server-page-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.18)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0 1px, transparent 1px 4px) !important;
}

body[data-current-tab="server"] #tab-server .ruby-panel > *,
#tab-server .ruby-panel > *,
#tab-server .server-panel > *,
.server-page-panel > * {
  position: relative;
  z-index: 1;
}

/* A página não reserva mais espaço para a imagem removida */
#tab-server .panel-body,
#tab-server .server-grid,
#tab-server .server-layout,
#tab-server .content-grid,
#tab-server .module-grid {
  display: grid;
  grid-template-columns: minmax(420px, 780px) !important;
  justify-content: start !important;
  align-items: start !important;
}

/* Cards transparentes para o fundo aparecer melhor */
#tab-server .panel-body > div:first-child,
#tab-server .server-live-card,
#tab-server .server-api-card,
#tab-server .status-box {
  max-width: 780px;
  border: 1px solid rgba(53,234,255,.18);
  border-radius: 15px;
  background:
    linear-gradient(145deg, rgba(5,7,16,.72), rgba(7,10,22,.50)) !important;
  box-shadow:
    inset 0 0 42px rgba(0,0,0,.22),
    0 0 26px rgba(53,234,255,.08),
    0 0 22px rgba(255,23,79,.08);
  backdrop-filter: blur(5px);
}

/* Cards live */
.server-live-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(82px, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.server-live-grid div,
.server-player-list {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(4,7,16,.70);
  border-radius: 10px;
  backdrop-filter: blur(7px);
}

.server-live-grid div {
  min-height: 54px;
  padding: 8px;
}

.server-live-grid span {
  display: block;
  color: #8ea0b8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .6px;
}

.server-live-grid strong {
  display: block;
  color: var(--green, #62ff8f);
  font-size: 16px;
  margin-top: 4px;
}

.server-player-list {
  margin-top: 8px;
  padding: 8px;
  min-height: 40px;
}

.server-player-list-title {
  color: #a8b8cc;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .7px;
  margin-bottom: 6px;
}

.server-player-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.server-player-tag {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(98,255,143,.10);
  border: 1px solid rgba(98,255,143,.24);
  color: #dfffe7;
  font-size: 12px;
  font-weight: 800;
}

.server-motd {
  margin-top: 8px;
  color: #b7c3d7;
  font-size: 13px;
  line-height: 1.35;
}

.server-live-error {
  color: #ff8aa7 !important;
}

.server-bars {
  display: inline-grid;
  grid-template-columns: repeat(5, 5px);
  gap: 3px;
  align-items: end;
  height: 20px;
  margin-left: 8px;
}

.server-bars i {
  display: block;
  width: 5px;
  background: rgba(98,255,143,.85);
  border-radius: 2px;
  box-shadow: 0 0 6px rgba(98,255,143,.40);
}

.server-bars i:nth-child(1) { height: 6px; }
.server-bars i:nth-child(2) { height: 9px; }
.server-bars i:nth-child(3) { height: 12px; }
.server-bars i:nth-child(4) { height: 16px; }
.server-bars i:nth-child(5) { height: 20px; }

@media (max-width: 900px) {
  #tab-server .panel-body,
  #tab-server .server-grid,
  #tab-server .server-layout,
  #tab-server .content-grid,
  #tab-server .module-grid {
    grid-template-columns: 1fr !important;
  }

  #tab-server .panel-body > div:first-child,
  #tab-server .server-live-card,
  #tab-server .server-api-card,
  #tab-server .status-box {
    max-width: 100%;
  }
}


/* =========================================================
   RubyMC Server Force Background Fix
   Corrige quando a imagem de fundo da aba Servidor não carrega
   por causa de seletor CSS incorreto.
   ========================================================= */

:root {
  --rubymc-server-bg-final: url("/assets/img/rubymc-server-page-bg-visible.png");
}

/* 1) Força o fundo diretamente na section da aba Servidor */
#tab-server {
  position: relative !important;
  isolation: isolate !important;
  overflow: hidden !important;
  background:
    linear-gradient(90deg, rgba(5,7,16,.86) 0%, rgba(5,7,16,.56) 42%, rgba(5,7,16,.18) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.10), transparent 32%),
    radial-gradient(circle at 78% 14%, rgba(255,23,79,.13), transparent 34%),
    var(--rubymc-server-bg-final) center center / cover no-repeat !important;
}

/* 2) Também força no painel ativo, caso o projeto use .tab-panel/.page-panel */
#tab-server.tab-panel,
#tab-server.page-panel,
#tab-server.panel-section,
#tab-server.active,
.tab-panel#tab-server,
.page-panel#tab-server {
  background:
    linear-gradient(90deg, rgba(5,7,16,.86) 0%, rgba(5,7,16,.56) 42%, rgba(5,7,16,.18) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.10), transparent 32%),
    radial-gradient(circle at 78% 14%, rgba(255,23,79,.13), transparent 34%),
    var(--rubymc-server-bg-final) center center / cover no-repeat !important;
}

/* 3) Se o layout coloca o conteúdo dentro de um artigo/card interno, aplica nele também */
#tab-server > article,
#tab-server > .panel,
#tab-server > .ruby-panel,
#tab-server > .server-panel,
#tab-server > .content-panel,
#tab-server > .page-content,
#tab-server > .server-page-panel {
  position: relative !important;
  overflow: hidden !important;
  background:
    linear-gradient(90deg, rgba(5,7,16,.82) 0%, rgba(5,7,16,.54) 42%, rgba(5,7,16,.16) 100%),
    var(--rubymc-server-bg-final) center center / cover no-repeat !important;
}

/* 4) Camada de leitura sem esconder demais a imagem */
#tab-server::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.16)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.010) 0 1px, transparent 1px 4px) !important;
}

#tab-server > * {
  position: relative !important;
  z-index: 1 !important;
}

/* 5) Remove de vez qualquer preview/card frontal duplicado */
#tab-server figure,
#tab-server .preview-card,
#tab-server .server-preview-card,
#tab-server .preview-frame,
#tab-server .server-live-overlay,
#tab-server [class*="preview"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* 6) Ajusta grid para uma coluna, já que removemos a imagem direita */
#tab-server .panel-body,
#tab-server .server-grid,
#tab-server .server-layout,
#tab-server .content-grid,
#tab-server .module-grid {
  display: grid !important;
  grid-template-columns: minmax(420px, 780px) !important;
  justify-content: start !important;
  align-items: start !important;
}

/* 7) Deixa os cards mais transparentes para o fundo aparecer */
#tab-server .panel-body > div:first-child,
#tab-server .server-live-card,
#tab-server .server-api-card,
#tab-server .status-box,
#tab-server .server-card {
  max-width: 780px !important;
  background:
    linear-gradient(145deg, rgba(5,7,16,.68), rgba(7,10,22,.46)) !important;
  border: 1px solid rgba(53,234,255,.18) !important;
  backdrop-filter: blur(5px) !important;
}

/* 8) Caso alguma regra antiga esteja colocando fundo escuro sólido dentro da aba */
body[data-current-tab="server"] #tab-server {
  background:
    linear-gradient(90deg, rgba(5,7,16,.86) 0%, rgba(5,7,16,.56) 42%, rgba(5,7,16,.18) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.10), transparent 32%),
    radial-gradient(circle at 78% 14%, rgba(255,23,79,.13), transparent 34%),
    var(--rubymc-server-bg-final) center center / cover no-repeat !important;
}

@media (max-width: 900px) {
  #tab-server .panel-body,
  #tab-server .server-grid,
  #tab-server .server-layout,
  #tab-server .content-grid,
  #tab-server .module-grid {
    grid-template-columns: 1fr !important;
  }
}


/* =========================================================
   RubyMC Home Temple Stairs Image Patch
   Implementa a imagem próxima das escadas do templo na Página Início.
   ========================================================= */

:root {
  --rubymc-home-temple: url("/assets/img/rubymc-home-temple-stairs.png");
  --rubymc-home-temple-visible: url("/assets/img/rubymc-home-temple-stairs-visible.png");
  --rubymc-home-temple-dark: url("/assets/img/rubymc-home-temple-stairs-dark.png");
}

/* Fundo exclusivo quando a aba Início estiver ativa */
body[data-current-tab="home"] #tab-home,
body[data-current-tab="inicio"] #tab-home,
#tab-home.active {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5,7,16,.92) 0%, rgba(5,7,16,.64) 42%, rgba(5,7,16,.22) 100%),
    radial-gradient(circle at 18% 14%, rgba(255,23,79,.16), transparent 34%),
    radial-gradient(circle at 78% 12%, rgba(145,77,255,.13), transparent 36%),
    var(--rubymc-home-temple-visible) center center / cover no-repeat !important;
}

/* Camada leve para leitura sem esconder a imagem */
body[data-current-tab="home"] #tab-home::before,
body[data-current-tab="inicio"] #tab-home::before,
#tab-home.active::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.18)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.010) 0 1px, transparent 1px 4px);
}

body[data-current-tab="home"] #tab-home > *,
body[data-current-tab="inicio"] #tab-home > *,
#tab-home.active > * {
  position: relative;
  z-index: 1;
}

/* Substitui imagem/preview antiga da Home pela imagem das escadas do templo */
#tab-home .preview-card img,
#tab-home .preview-frame img,
#tab-home .hero-preview img,
#tab-home .module-preview img,
#tab-home img[src*="rubymc-inicio"],
#tab-home img[src*="rubymc-home"],
#tab-home img[src*="rubymc-main"] {
  content: url("/assets/img/rubymc-home-temple-stairs.png") !important;
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  object-position: center center;
}

/* Se o layout usa um card visual na direita, mantém a imagem ali também */
#tab-home .preview-card,
#tab-home .preview-frame,
#tab-home .hero-preview,
#tab-home .module-preview {
  border-color: rgba(255,23,79,.38);
  border-radius: 16px;
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(5,7,16,.72), rgba(7,10,22,.48)),
    var(--rubymc-home-temple-dark) center center / cover no-repeat !important;
  box-shadow:
    0 0 34px rgba(255,23,79,.18),
    inset 0 0 48px rgba(0,0,0,.26);
}

/* Hero/card inicial mais transparente para a arte aparecer */
#tab-home .panel-copy,
#tab-home .home-copy,
#tab-home .hero-copy,
#tab-home .status-card,
#tab-home .play-card,
#tab-home .display-card {
  background:
    linear-gradient(145deg, rgba(5,7,16,.72), rgba(7,10,22,.50)) !important;
  border-color: rgba(255,23,79,.22);
  backdrop-filter: blur(5px);
}

/* Caso o projeto tenha imagem principal no topo/hero */
.home-hero-image,
.home-main-image,
.home-temple-image {
  background:
    linear-gradient(90deg, rgba(5,7,16,.36), rgba(5,7,16,.10)),
    var(--rubymc-home-temple) center center / cover no-repeat !important;
}

/* Título da página Início com presença ruby/neon */
#tab-home h1,
#tab-home h2,
#tab-home .hero-title {
  text-shadow:
    0 0 20px rgba(255,23,79,.36),
    0 2px 12px rgba(0,0,0,.78);
}

/* Mantém legibilidade dos selects e botões */
#tab-home select,
#tab-home input {
  background: rgba(4,7,16,.78) !important;
  backdrop-filter: blur(5px);
}

@media (max-width: 900px) {
  body[data-current-tab="home"] #tab-home,
  body[data-current-tab="inicio"] #tab-home,
  #tab-home.active {
    background:
      linear-gradient(180deg, rgba(5,7,16,.90), rgba(5,7,16,.50)),
      var(--rubymc-home-temple-visible) center center / cover no-repeat !important;
  }

  #tab-home .preview-card img,
  #tab-home .preview-frame img,
  #tab-home .hero-preview img,
  #tab-home .module-preview img {
    min-height: 240px;
  }
}


/* =========================================================
   RubyMC All Pages Backgrounds Patch
   Fundos específicos para Início, Modpacks, Servidor,
   Discord e Projeto.
   ========================================================= */

:root {
  --ruby-page-home-bg: url("/assets/img/rubymc-page-home-bg.jpg");
  --ruby-page-modpacks-bg: url("/assets/img/rubymc-page-modpacks-orb-bg.jpg");
  --ruby-page-server-bg: url("/assets/img/rubymc-page-server-bg.jpg");
  --ruby-page-discord-bg: url("/assets/img/rubymc-page-discord-bg.jpg");
  --ruby-page-project-bg: url("/assets/img/rubymc-page-project-bg.jpg");
}

#tab-home,
#tab-modpacks,
#tab-server,
#tab-project {
  position: relative !important;
  isolation: isolate !important;
  overflow: hidden !important;
  background-color: #050710 !important;
}

/* Remove previews duplicados que estavam criando imagens repetidas */
#tab-home figure.preview-card,
#tab-home figure.preview-frame,
#tab-home .hero-preview,
#tab-server figure,
#tab-server .preview-card,
#tab-server .server-preview-card,
#tab-server .server-live-overlay,
#tab-project figure.preview-card,
#tab-project figure.preview-frame,
#tab-modpacks figure.preview-card,
#tab-modpacks figure.preview-frame {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

#tab-home,
body[data-current-tab="home"] #tab-home,
body[data-current-tab="inicio"] #tab-home,
#tab-home.active {
  background:
    linear-gradient(90deg, rgba(5,7,16,.90) 0%, rgba(5,7,16,.58) 44%, rgba(5,7,16,.22) 100%),
    radial-gradient(circle at 18% 14%, rgba(255,23,79,.16), transparent 34%),
    var(--ruby-page-home-bg) center center / cover no-repeat !important;
}

#tab-modpacks,
body[data-current-tab="modpacks"] #tab-modpacks,
#tab-modpacks.active {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.58) 42%, rgba(5,7,16,.20) 100%),
    radial-gradient(circle at 20% 18%, rgba(255,23,79,.18), transparent 34%),
    radial-gradient(circle at 78% 14%, rgba(145,77,255,.14), transparent 36%),
    var(--ruby-page-modpacks-bg) center center / cover no-repeat !important;
}

#tab-server,
body[data-current-tab="server"] #tab-server,
#tab-server.active {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.60) 42%, rgba(5,7,16,.22) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.12), transparent 32%),
    var(--ruby-page-server-bg) center center / cover no-repeat !important;
}

#tab-project,
body[data-current-tab="project"] #tab-project,
body[data-current-tab="projeto"] #tab-project,
#tab-project.active {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.58) 42%, rgba(5,7,16,.20) 100%),
    radial-gradient(circle at 22% 16%, rgba(255,23,79,.17), transparent 34%),
    radial-gradient(circle at 75% 14%, rgba(145,77,255,.13), transparent 36%),
    var(--ruby-page-project-bg) center center / cover no-repeat !important;
}

/* Camada leve para leitura */
#tab-home::before,
#tab-modpacks::before,
#tab-server::before,
#tab-project::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.18)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.010) 0 1px, transparent 1px 4px) !important;
}

#tab-home > *,
#tab-modpacks > *,
#tab-server > *,
#tab-project > * {
  position: relative !important;
  z-index: 1 !important;
}

/* Cards translúcidos */
#tab-home article,
#tab-home .panel-copy,
#tab-home .home-copy,
#tab-home .play-card,
#tab-home .display-card,
#tab-modpacks article,
#tab-modpacks .panel-copy,
#tab-modpacks .list-box,
#tab-modpacks .dropzone,
#tab-server article,
#tab-server .status-box,
#tab-server .server-live-card,
#tab-server .server-api-card,
#tab-project article,
#tab-project .project-card,
#tab-project .action-card {
  background:
    radial-gradient(circle at 18% 12%, rgba(53,234,255,.10), transparent 32%),
    radial-gradient(circle at 84% 16%, rgba(255,23,79,.12), transparent 30%),
    linear-gradient(145deg, rgba(6,9,18,.82), rgba(4,6,15,.74)) !important;
  border-color: rgba(53,234,255,.20) !important;
  backdrop-filter: blur(5px) !important;
  box-shadow:
    inset 0 0 48px rgba(0,0,0,.22),
    0 0 26px rgba(53,234,255,.08),
    0 0 22px rgba(255,23,79,.08) !important;
}

/* Ajuste de grid sem preview lateral */
#tab-home .panel-body,
#tab-server .panel-body,
#tab-project .panel-body,
#tab-modpacks .panel-body,
#tab-home .content-grid,
#tab-server .content-grid,
#tab-project .content-grid,
#tab-modpacks .content-grid,
#tab-home .module-grid,
#tab-server .module-grid,
#tab-project .module-grid,
#tab-modpacks .module-grid {
  grid-template-columns: minmax(360px, 620px) !important;
  justify-content: start !important;
  align-items: start !important;
}

#tab-home h1, #tab-home h2,
#tab-modpacks h1, #tab-modpacks h2,
#tab-server h1, #tab-server h2,
#tab-project h1, #tab-project h2 {
  text-shadow:
    0 0 20px rgba(255,23,79,.36),
    0 2px 12px rgba(0,0,0,.78) !important;
}

@media (max-width: 900px) {
  #tab-home .panel-body,
  #tab-server .panel-body,
  #tab-project .panel-body,
  #tab-modpacks .panel-body,
  #tab-home .content-grid,
  #tab-server .content-grid,
  #tab-project .content-grid,
  #tab-modpacks .content-grid,
  #tab-home .module-grid,
  #tab-server .module-grid,
  #tab-project .module-grid,
  #tab-modpacks .module-grid {
    grid-template-columns: 1fr !important;
  }
}




/* =========================================================
   RubyMC Modpacks Orb Background Replace Patch
   Substitui o fundo da página Modpacks pela imagem do Orbe RubyMC.
   Este bloco deve ficar no FINAL do launcher.css.
   ========================================================= */

:root {
  --ruby-modpacks-orb-final-bg: url("/assets/img/rubymc-page-modpacks-orb-bg.jpg");
}

/* Remove camadas antigas que duplicavam/triplicavam o fundo */
#tab-modpacks::before,
#tab-modpacks::after,
body[data-current-tab="modpacks"] #tab-modpacks::before,
body[data-current-tab="modpacks"] #tab-modpacks::after,
body[data-current-tab="modpacks"] .app-content::before,
body[data-current-tab="modpacks"] .app-content::after,
body[data-current-tab="modpacks"] .content-area::before,
body[data-current-tab="modpacks"] .content-area::after {
  content: none !important;
  display: none !important;
  background: none !important;
  background-image: none !important;
  opacity: 0 !important;
}

/* Remove preview/figure antigo para não aparecer outra imagem por cima */
#tab-modpacks figure,
#tab-modpacks .preview-card,
#tab-modpacks .preview-frame,
#tab-modpacks .module-preview,
#tab-modpacks .hero-preview,
#tab-modpacks [class*="preview"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Fundo único oficial da página Modpacks */
#tab-modpacks,
#tab-modpacks.active,
body[data-current-tab="modpacks"] #tab-modpacks {
  position: relative !important;
  isolation: isolate !important;
  overflow: hidden !important;
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.56) 42%, rgba(5,7,16,.18) 100%),
    radial-gradient(circle at 20% 18%, rgba(255,23,79,.15), transparent 34%),
    radial-gradient(circle at 76% 14%, rgba(145,77,255,.13), transparent 36%),
    var(--ruby-modpacks-orb-final-bg) center center / cover no-repeat !important;
  background-attachment: scroll !important;
}

/* Wrappers internos não podem ter outra imagem */
#tab-modpacks > article,
#tab-modpacks > .panel,
#tab-modpacks > .ruby-panel,
#tab-modpacks > .content-panel,
#tab-modpacks > .page-content,
#tab-modpacks .panel-body,
#tab-modpacks .content-grid,
#tab-modpacks .module-grid {
  background-image: none !important;
}

/* Cards translúcidos para a imagem aparecer bem */
#tab-modpacks article,
#tab-modpacks .panel-copy,
#tab-modpacks .list-box,
#tab-modpacks .dropzone,
#tab-modpacks .modpack-box-badge,
#tab-modpacks .status-box {
  background:
    linear-gradient(145deg, rgba(5,7,16,.74), rgba(7,10,22,.52)) !important;
  border-color: rgba(255,23,79,.26) !important;
  backdrop-filter: blur(5px) !important;
  box-shadow:
    inset 0 0 40px rgba(0,0,0,.22),
    0 0 24px rgba(255,23,79,.12) !important;
}

/* Mantém layout em uma coluna, sem reservar espaço para imagem lateral */
#tab-modpacks .panel-body,
#tab-modpacks .content-grid,
#tab-modpacks .module-grid,
#tab-modpacks .server-grid,
#tab-modpacks .server-layout {
  display: grid !important;
  grid-template-columns: minmax(420px, 780px) !important;
  justify-content: start !important;
  align-items: start !important;
}

/* Imagens internas extras não aparecem como segunda camada */
#tab-modpacks img:not(.modpack-icon):not(.app-logo):not(.brand-logo):not(.title-modpack-icon) {
  display: none !important;
}
#tab-modpacks .modpack-box-badge img {
  display: block !important;
}

/* Títulos mais legíveis */
#tab-modpacks h1,
#tab-modpacks h2,
#tab-modpacks h3,
#tab-modpacks .section-subtitle {
  text-shadow:
    0 0 18px rgba(255,23,79,.36),
    0 2px 10px rgba(0,0,0,.78) !important;
}

@media (max-width: 900px) {
  #tab-modpacks .panel-body,
  #tab-modpacks .content-grid,
  #tab-modpacks .module-grid,
  #tab-modpacks .server-grid,
  #tab-modpacks .server-layout {
    grid-template-columns: 1fr !important;
  }

  #tab-modpacks,
  #tab-modpacks.active,
  body[data-current-tab="modpacks"] #tab-modpacks {
    background:
      linear-gradient(180deg, rgba(5,7,16,.88), rgba(5,7,16,.48)),
      var(--ruby-modpacks-orb-final-bg) center center / cover no-repeat !important;
  }
}





/* RubyMC Discord + IA Final Feedback */
button.is-loading,
.btn.is-loading {
  opacity: .72;
  cursor: wait !important;
  filter: saturate(.75);
}
.discord-status-ok,
.ai-status-ok { color: #62ff8f !important; }
.discord-status-error,
.ai-status-error { color: #ff6b8f !important; }

/* RubyMC AI Chat Tab */
.ai-chat-layout {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 12px;
  align-items: start;
}
.ai-chat-main {
  min-height: 400px;
}
.ai-chat-container {
  display: flex;
  flex-direction: column;
  height: 400px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  background: rgba(4,7,16,.55);
  overflow: hidden;
}
.ai-chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  scroll-behavior: smooth;
}
.ai-chat-messages:empty::after {
  content: 'Envie uma mensagem para começar.';
  display: block;
  text-align: center;
  color: #6a7a99;
  padding: 40px 20px;
  font-style: italic;
}
.ai-message {
  display: flex;
  gap: 8px;
  max-width: 85%;
}
.ai-chat-input-bar {
  display: flex;
  gap: 8px;
  padding: 8px 10px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.20);
}
.ai-context-panel {
  padding: 10px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  background: rgba(4,7,16,.55);
}
.ai-context-panel h3 {
  margin: 0 0 8px;
  font-size: 14px;
  color: #fff;
}
.ai-chat-main {
  min-height: 480px;
}
.ai-chat-container {
  display: flex;
  flex-direction: column;
  height: 480px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  background: rgba(4,7,16,.55);
  overflow: hidden;
}
.ai-chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  scroll-behavior: smooth;
}
.ai-chat-messages:empty::after {
  content: 'Envie uma mensagem para começar.';
  display: block;
  text-align: center;
  color: #6a7a99;
  padding: 60px 20px;
  font-style: italic;
}
.ai-message {
  display: flex;
  gap: 10px;
  max-width: 85%;
}
.ai-user-message {
  align-self: flex-end;
  flex-direction: row-reverse;
}
.ai-bot-message {
  align-self: flex-start;
}
.ai-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.ai-bot-message .ai-avatar {
  background: rgba(255,23,79,.20);
  border: 1px solid rgba(255,23,79,.30);
}
.ai-user-message .ai-avatar {
  background: rgba(98,255,143,.15);
  border: 1px solid rgba(98,255,143,.25);
}
.ai-bubble {
  padding: 10px 14px;
  border-radius: 14px;
  line-height: 1.5;
  font-size: 13.5px;
  color: #d9e4f7;
  white-space: pre-wrap;
  word-break: break-word;
}
.ai-bot-message .ai-bubble {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}
.ai-user-message .ai-bubble {
  background: rgba(255,23,79,.12);
  border: 1px solid rgba(255,23,79,.20);
}
.ai-bubble p { margin: 0 0 6px; }
.ai-bubble p:last-child { margin: 0; }
.ai-bubble code {
  background: rgba(0,0,0,.30);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 12.5px;
}
.ai-bubble pre {
  background: rgba(0,0,0,.35);
  padding: 10px;
  border-radius: 8px;
  overflow-x: auto;
  margin: 6px 0;
  font-size: 12px;
}
.ai-chat-input-bar {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.20);
}
.ai-chat-input {
  flex: 1;
  resize: none;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(4,7,16,.66);
  color: #fff;
  padding: 10px 12px;
  outline: none;
  font-family: inherit;
  font-size: 13px;
  line-height: 1.4;
  min-height: 20px;
  max-height: 120px;
}
.ai-chat-input:focus {
  border-color: rgba(255,23,79,.40);
  box-shadow: 0 0 12px rgba(255,23,79,.08);
}
.ai-chat-input::placeholder {
  color: #5a6a89;
}
.ai-chat-input-bar .btn {
  align-self: flex-end;
  padding: 9px 20px;
  flex-shrink: 0;
}
.ai-context-panel {
  padding: 16px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  background: rgba(4,7,16,.55);
}
.ai-context-panel h3 {
  margin: 0 0 12px;
  font-size: 14px;
  color: #fff;
}
.ai-context-panel pre {
  margin: 0;
  font-size: 12px;
  line-height: 1.5;
  color: #8a9abc;
  white-space: pre-wrap;
  word-break: break-word;
}
.ai-typing .ai-bubble::after {
  content: '▊';
  animation: blink 1s step-end infinite;
  margin-left: 2px;
}
@keyframes blink {
  50% { opacity: 0; }
}

/* =========================================================
   RubyMC Layout Organization
   Consolidated layout rules for all content pages.
   ========================================================= */

:root {
  --ruby-display-bg: url("/assets/img/rubymc-display-logs.png");
}

/* === Page Backgrounds === */
#tab-home {
  background:
    linear-gradient(90deg, rgba(5,7,16,.90) 0%, rgba(5,7,16,.58) 44%, rgba(5,7,16,.22) 100%),
    radial-gradient(circle at 18% 14%, rgba(255,23,79,.16), transparent 34%),
    radial-gradient(circle at 78% 12%, rgba(145,77,255,.12), transparent 36%),
    var(--ruby-page-home-bg) center center / cover no-repeat !important;
}
#tab-modpacks {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.56) 42%, rgba(5,7,16,.18) 100%),
    radial-gradient(circle at 20% 18%, rgba(255,23,79,.15), transparent 34%),
    radial-gradient(circle at 76% 14%, rgba(145,77,255,.13), transparent 36%),
    var(--ruby-page-modpacks-bg) center center / cover no-repeat !important;
}
#tab-server {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.60) 42%, rgba(5,7,16,.22) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.12), transparent 32%),
    var(--ruby-page-server-bg) center center / cover no-repeat !important;
}
#tab-project {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.58) 42%, rgba(5,7,16,.20) 100%),
    radial-gradient(circle at 22% 16%, rgba(255,23,79,.17), transparent 34%),
    radial-gradient(circle at 75% 14%, rgba(145,77,255,.13), transparent 36%) !important;
}
#tab-display {
  background:
    linear-gradient(90deg, rgba(5,7,16,.88) 0%, rgba(5,7,16,.60) 42%, rgba(5,7,16,.22) 100%),
    radial-gradient(circle at 22% 16%, rgba(53,234,255,.10), transparent 32%),
    radial-gradient(circle at 78% 14%, rgba(255,23,79,.12), transparent 34%),
    var(--ruby-display-bg) center center / cover no-repeat !important;
}

/* === Grid Layouts === */

/* Home: 2 columns with preview image */
#tab-home .panel-grid {
  grid-template-columns: minmax(360px, 620px) !important;
}
#tab-home .preview-frame {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
#tab-home .preview-frame img {
  min-height: 360px;
  object-fit: cover;
  object-position: center;
}

/* Modpacks: single column form layout */
#tab-modpacks .panel-grid {
  grid-template-columns: minmax(360px, 620px) !important;
}

/* Server: single column status layout */
#tab-server .panel-grid {
  grid-template-columns: minmax(360px, 620px) !important;
}

/* Display: full width terminal */
#tab-display .panel-grid {
  grid-template-columns: 1fr !important;
}
#tab-display .preview-frame {
  display: none !important;
}

/* Project: 2 columns with preview sidebar */
#tab-project .panel-grid {
  grid-template-columns: minmax(360px, 480px) minmax(320px, 440px) !important;
}
#tab-project figure.preview-frame {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
#tab-project figure.preview-frame img {
  min-height: 340px;
  object-fit: cover;
  object-position: center;
}
#tab-project .project-actions {
  min-height: 320px;
}
.project-option {
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.project-option:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 20px rgba(255,23,79,.18);
  border-color: rgba(255,23,79,.30);
}
.project-option:last-child {
  margin-bottom: 0;
}

/* Modpack list: refined rows */
#tab-modpacks .modpack-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: background .12s;
}
#tab-modpacks .modpack-row:hover {
  background: rgba(255,23,79,.06);
}
#tab-modpacks .modpack-row strong {
  flex: 1;
  color: #fff;
  font-size: 14px;
}
#tab-modpacks .modpack-row span {
  color: var(--muted);
  font-size: 13px;
}
.modpack-remove-btn {
  width: 28px;
  height: 28px;
  border: 1px solid rgba(255,23,79,.35);
  border-radius: 6px;
  background: rgba(255,23,79,.12);
  color: #ff6b8f;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  transition: background .12s, border-color .12s;
}
.modpack-remove-btn:hover {
  background: rgba(255,23,79,.30);
  border-color: rgba(255,23,79,.60);
  color: #fff;
}
.modpack-remove-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
}

/* === Reading Layer === */
#tab-home::before, #tab-modpacks::before, #tab-server::before,
#tab-project::before, #tab-display::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.18)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.010) 0 1px, transparent 1px 4px) !important;
}
#tab-home > *, #tab-modpacks > *, #tab-server > *,
#tab-project > *, #tab-display > * {
  position: relative;
  z-index: 1;
}

/* === Card Transparency === */
#tab-home article, #tab-home .panel-copy,
#tab-modpacks article, #tab-modpacks .panel-copy, #tab-modpacks .list-box, #tab-modpacks .dropzone, #tab-modpacks .modpack-box-badge,
#tab-server article, #tab-server .status-box,
#tab-project article {
  background:
    radial-gradient(circle at 18% 12%, rgba(53,234,255,.10), transparent 32%),
    radial-gradient(circle at 84% 16%, rgba(255,23,79,.12), transparent 30%),
    linear-gradient(145deg, rgba(6,9,18,.82), rgba(4,6,15,.74)) !important;
  border-color: rgba(53,234,255,.20) !important;
  backdrop-filter: blur(5px) !important;
  box-shadow:
    inset 0 0 48px rgba(0,0,0,.22),
    0 0 26px rgba(53,234,255,.08),
    0 0 22px rgba(255,23,79,.08) !important;
}

/* === Responsive === */
@media (max-width: 1280px) {
  #tab-home .panel-grid,
  #tab-project .panel-grid {
    grid-template-columns: 1fr !important;
  }
  #tab-home .preview-frame,
  #tab-project figure.preview-frame {
    display: none !important;
  }
}

/* =========================================================
   RubyMC — Aba Versões
   ========================================================= */
.version-active-box {
  margin-bottom: 24px;
  padding: 18px 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgba(5, 7, 16, 0.6);
}
.version-active-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 0;
}
.version-active-loader {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  background: rgba(53, 234, 255, 0.15);
  color: var(--cyan);
}
.version-active-id {
  font-size: 18px;
  color: #fff;
}
.version-active-java {
  font-size: 12px;
  color: var(--muted);
  margin-left: auto;
}
.version-active-none {
  color: var(--muted);
  font-style: italic;
  padding: 10px 0;
}
.version-section {
  margin-bottom: 24px;
}
.version-section h3 {
  margin: 0 0 12px;
  font-size: 18px;
}
.version-install-form {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: end;
}
.version-install-form label {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 2px;
}
.version-install-form select {
  min-width: 180px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 6px;
  background: rgba(5, 7, 16, 0.8);
  color: var(--text);
  font-size: 14px;
}
.version-install-form button {
  white-space: nowrap;
}
#version-installed-list {
  min-height: 60px;
}
.version-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  margin-bottom: 6px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 8px;
  background: rgba(5, 7, 16, 0.4);
  transition: background 0.2s;
}
.version-item:hover {
  background: rgba(5, 7, 16, 0.7);
}
.version-item.version-active {
  border-color: rgba(53, 234, 255, 0.3);
  background: rgba(53, 234, 255, 0.05);
}
.version-item-info {
  display: flex;
  align-items: center;
  gap: 10px;
}
.version-item-info strong {
  font-size: 15px;
  color: #fff;
}
.version-item-loader {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
}
.version-item-info small {
  font-size: 11px;
  color: var(--muted);
}
.version-item-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.version-active-badge {
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 4px;
  background: rgba(53, 234, 255, 0.12);
  color: var(--cyan);
}
.btn-sm {
  padding: 4px 10px;
  font-size: 12px;
}
.list-box .empty-state {
  display: block;
  color: var(--muted);
  font-style: italic;
  padding: 20px;
  text-align: center;
}

/* ── Version Sub‑navigation ────────────────────────────── */
.version-subnav {
  display: flex;
  gap: 6px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  padding: 4px;
}
.version-subnav-link {
  flex: 1;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-weight: 700;
  font-size: 14px;
  padding: 8px 16px;
  border-radius: 8px;
  cursor: pointer;
  transition: .16s ease;
  text-align: center;
}
.version-subnav-link:hover {
  color: #fff;
  background: rgba(255,255,255,.05);
}
.version-subnav-link.active {
  color: #fff;
  background: linear-gradient(180deg,rgba(255,23,79,.7),rgba(168,0,43,.6));
  box-shadow: 0 0 12px rgba(255,23,79,.2);
}

/* ── Client Version Grid ──────────────────────────────── */
.client-versions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.client-version-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  background: rgba(5,7,16,.4);
  transition: .16s ease;
}
.client-version-card:hover {
  background: rgba(5,7,16,.7);
  border-color: rgba(255,255,255,.12);
}
.client-version-card.installed {
  border-color: rgba(98,255,143,.2);
  background: rgba(98,255,143,.04);
}
.client-version-info {
  display: flex;
  align-items: center;
  gap: 8px;
}
.client-version-info strong {
  font-size: 15px;
  color: #fff;
}
.client-version-type {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 4px;
  background: rgba(255,255,255,.06);
  color: var(--muted);
}
.client-version-badge {
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 4px;
  background: rgba(98,255,143,.12);
  color: var(--green);
  text-align: center;
}
.btn-filter {
  border: 1px solid rgba(255,255,255,.08);
  background: transparent;
  color: var(--muted);
  font-weight: 700;
  cursor: pointer;
  transition: .16s ease;
}
.btn-filter:hover {
  color: #fff;
  border-color: rgba(255,255,255,.2);
}
.btn-filter.active {
  color: #fff;
  border-color: var(--cyan);
  background: rgba(53,234,255,.08);
}
.version-client-filter {
  display: flex;
  gap: 6px;
  margin-bottom: 4px;
}

/* ── Server Control Buttons ──────────────────────────────── */
.btn-server-start {
  background: linear-gradient(180deg, #62ff8f, #1a8f3a);
  box-shadow: 0 0 18px rgba(98, 255, 143, 0.3);
}
.btn-server-stop {
  background: linear-gradient(180deg, #ff4444, #aa0000);
  box-shadow: 0 0 18px rgba(255, 68, 68, 0.3);
}

/* ── Auth Modal ─────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
.modal-box {
  background:
    linear-gradient(145deg, rgba(7,10,22,.95), rgba(4,6,15,.95));
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 32px;
  max-width: 440px;
  width: 90%;
  text-align: center;
}
.modal-box h3 {
  margin: 0 0 16px;
  font-size: 20px;
}
.modal-box p {
  margin: 8px 0;
  font-size: 14px;
  color: var(--muted);
}
.auth-code {
  font-size: 36px;
  font-weight: 800;
  letter-spacing: 8px;
  font-family: monospace;
  color: var(--cyan);
  background: rgba(53, 234, 255, 0.06);
  border-radius: 8px;
  padding: 12px;
  margin: 12px 0;
}
.auth-status {
  font-size: 13px;
  color: var(--muted);
  min-height: 20px;
}
.modal-box .actions {
  margin-top: 16px;
  justify-content: center;
}

/* ── Settings Accounts Card ──────────────────────────────── */
.settings-accounts-card p {
  margin: 0 0 16px;
  font-size: 13px;
  color: var(--muted);
}
.account-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  gap: 8px;
}
.account-row:last-child {
  border-bottom: none;
}
.account-row .account-info {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
}
.account-row .account-name {
  font-weight: 600;
  font-size: 14px;
}
.account-row .account-email {
  font-size: 12px;
  color: var(--muted);
}
.account-row .account-badge {
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 700;
}
.account-badge-online {
  background: rgba(98, 255, 143, 0.12);
  color: #62ff8f;
}
.account-badge-offline {
  background: rgba(255, 68, 68, 0.12);
  color: #ff6b6b;
}
.account-row .account-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.account-row .btn-sm {
  padding: 3px 8px;
  font-size: 11px;
}
.account-active-indicator {
  color: var(--cyan);
  font-size: 18px;
  margin-right: 4px;
}
.edition-badge-edition {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 3px;
  font-weight: 700;
  margin-left: 6px;
  background: rgba(98, 255, 143, 0.12);
  color: #62ff8f;
  vertical-align: middle;
}
.edition-badge-java {
  background: rgba(255, 23, 79, 0.12);
  color: #ff6b6b;
}

/* ── Bedrock Edition Section (Home tab) ──────────────────── */
  margin-top: 12px;
  padding-top: 8px;
}
  border: none;
  border-top: 1px solid rgba(53, 234, 255, 0.25);
  margin: 4px 0 10px;
}
  font-size: 14px;
  font-weight: 700;
  color: var(--cyan);
  margin: 0 0 8px;
  text-shadow: 0 0 10px rgba(53, 234, 255, 0.25);
}
  display: flex;
  gap: 8px;
  align-items: end;
  flex-wrap: wrap;
}
  min-width: 120px;
  flex: 0 0 auto;
}
  width: 100%;
}
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--muted);
  min-height: 18px;
}
  margin-top: 12px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 8px;
}
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 10px;
}
  display: block;
  margin-top: 6px;
  font-size: 11px;
  color: var(--muted);
  line-height: 1.5;
}
  background: rgba(255,255,255,0.08);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 10px;
}
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
  font-size: 12px;
  color: var(--text);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 10px;
  max-width: 260px;
}
  background: var(--border);
  color: var(--text);
  border: none;
  border-radius: 4px;
  padding: 3px 10px;
  cursor: pointer;
  font-size: 11px;
  margin-right: 8px;
}
  background: var(--cyan);
}
  width: 100%;
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--muted);
  min-height: 16px;
}
  display: flex;
  gap: 8px;
  align-items: center;
  background: rgba(98,255,143,0.06);
  border: 1px solid rgba(98,255,143,0.15);
  border-radius: 8px;
  padding: 6px 10px;
  margin-bottom: 8px;
}
  font-size: 13px;
}
  color: #62ff8f;
}
  color: var(--muted);
}
  font-size: 11px;
  color: var(--muted);
  font-family: monospace;
}
  font-size: 11px;
  color: var(--cyan);
  font-family: monospace;
}
  content: "•";
  margin: 0 3px;
  color: var(--muted);
}
  font-size: 11px;
  color: var(--text);
  margin-left: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 280px;
}
  margin-bottom: 10px;
}
  display: flex;
  gap: 8px;
  align-items: center;
}
  flex: 1;
  min-width: 140px;
  max-width: 260px;
}
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--muted);
  min-height: 16px;
}
  display: flex;
  flex-direction: column;
  gap: 6px;
}
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 6px 8px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 6px;
}
  border-color: rgba(98,255,143,0.2);
  background: rgba(98,255,143,0.04);
}
  flex: 1;
  font-size: 13px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 6px;
}
  font-size: 11px;
  color: var(--muted);
  font-family: monospace;
}
  font-size: 13px;
  font-weight: 600;
}
.btn-cyan {
  background: linear-gradient(180deg, #35eaff, #0c94a8);
  box-shadow: 0 0 14px rgba(53, 234, 255, 0.2);
}
.btn-cyan:hover {
  box-shadow: 0 0 20px rgba(53, 234, 255, 0.35);
}
.btn-cyan:disabled {
  opacity: 0.5;
  filter: saturate(0.5);
}

.btn-green {
  background: linear-gradient(180deg, #62ff8f, #1a8f3a);
  box-shadow: 0 0 14px rgba(98, 255, 143, 0.25);
}
.btn-green:hover {
  box-shadow: 0 0 20px rgba(98, 255, 143, 0.4);
}
.btn-green:disabled {
  opacity: 0.5;
  filter: saturate(0.5);
}

/* =========================================================
   RubyMC Server Version Selector
   Permite escolher a versão do servidor Java diretamente
   na Página de Servidor.
   ========================================================= */

.server-version-control {
  margin-top: 10px;
  padding: 10px;
  border: 1px solid rgba(53, 234, 255, .18);
  border-radius: 12px;
  background:
    radial-gradient(circle at 16% 0%, rgba(53,234,255,.10), transparent 34%),
    linear-gradient(145deg, rgba(6,9,18,.78), rgba(4,7,16,.64));
  box-shadow:
    inset 0 0 34px rgba(0,0,0,.20),
    0 0 18px rgba(53,234,255,.06);
}

.server-version-control label {
  margin-top: 0;
}

.server-version-row {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.server-version-row select {
  min-height: 34px;
}

.server-version-row .btn-sm {
  min-height: 34px;
  padding: 0 12px;
}

.server-version-hint {
  display: block;
  margin-top: 6px;
  color: #a8b8cc;
  line-height: 1.35;
}

@media (max-width: 680px) {
  .server-version-row {
    grid-template-columns: 1fr;
  }

  .server-version-row .btn-sm {
    width: 100%;
  }
}

/* =========================================================
   RubyMC Server Runtime Selector
   Seletor Java / Bedrock na Página Servidor.
   ========================================================= */

.server-runtime-selector {
  margin: 10px 0 4px;
  border: 1px solid rgba(53, 234, 255, .22) !important;
  border-radius: 12px !important;
  background:
    radial-gradient(circle at 12% 20%, rgba(53,234,255,.10), transparent 28%),
    linear-gradient(145deg, rgba(5,7,16,.86), rgba(7,10,22,.62)) !important;
  box-shadow:
    inset 0 0 36px rgba(0,0,0,.22),
    0 0 20px rgba(53,234,255,.08),
    0 0 18px rgba(255,23,79,.06);
  padding: 10px !important;
}

.server-runtime-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.server-runtime-header small,
.server-runtime-field small {
  display: block;
  color: #8ea0b8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: 4px;
}

.server-runtime-header strong {
  display: block;
  color: #fff;
  font-size: 16px;
  line-height: 1.1;
}

.server-runtime-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  min-height: 28px;
  padding: 0 10px;
  border: 1px solid rgba(98,255,143,.30);
  border-radius: 999px;
  color: #dfffe7;
  background: rgba(98,255,143,.10);
  font-weight: 900;
  box-shadow: 0 0 12px rgba(98,255,143,.14);
}

.server-runtime-badge.is-bedrock {
  border-color: rgba(53,234,255,.34);
  color: #e2fbff;
  background: rgba(53,234,255,.10);
  box-shadow: 0 0 12px rgba(53,234,255,.16);
}

.server-runtime-grid {
  display: grid;
  grid-template-columns: minmax(130px, .8fr) minmax(160px, 1.2fr) auto;
  gap: 8px;
  align-items: end;
}

.server-runtime-field {
  margin: 0 !important;
}

.server-runtime-field select,
#server-runtime-type,
#server-runtime-version {
  min-height: 34px;
}

.server-runtime-refresh {
  min-height: 34px;
  white-space: nowrap;
}

.server-runtime-help {
  display: block;
  color: #a8b8cc;
  font-size: 12px;
  font-style: normal;
  margin-top: 8px;
  line-height: 1.35;
}

button.is-loading,
.btn.is-loading {
  opacity: .72;
  cursor: wait !important;
  filter: saturate(.75);
}

@media (max-width: 760px) {
  .server-runtime-grid {
    grid-template-columns: 1fr;
  }

  .server-runtime-refresh {
    width: 100%;
  }
}

/* =========================================================
   RubyMC — Aba Versões — Layout unificado
   Cards empilhados (embaixo), conteúdo lado a lado.
   ========================================================= */

:root {
  --versions-max-width: 620px;
  --versions-card-gap: 8px;
  --panel-padding: 10px;
  --panel-gap: 8px;
  --panel-radius: 12px;
}

#tab-versions {
  width: 100%;
  max-width: var(--versions-max-width);
  margin: 0;
}

#tab-versions .panel-heading {
  max-width: var(--versions-max-width);
  margin: 0 0 10px;
}

#tab-versions .panel-heading h2 {
  font-size: 20px;
  margin-bottom: 4px;
}

#tab-versions .panel-heading p {
  font-size: 13px;
  margin: 0;
}

#tab-versions .panel-grid {
  display: block;
  width: 100%;
  max-width: var(--versions-max-width);
}

#tab-versions .panel-copy {
  width: 100%;
  max-width: 100%;
}

/* ---- Cards ---- */
#tab-versions .version-active-box,
#tab-versions .version-section {
  border: 1px solid rgba(53, 234, 255, .20);
  border-radius: 12px;
  background:
    radial-gradient(circle at 18% 12%, rgba(53, 234, 255, .10), transparent 32%),
    radial-gradient(circle at 84% 16%, rgba(255, 23, 79, .12), transparent 30%),
    linear-gradient(145deg, rgba(6, 9, 18, .82), rgba(4, 6, 15, .74));
  box-shadow:
    inset 0 0 48px rgba(0, 0, 0, .22),
    0 0 26px rgba(53, 234, 255, .08),
    0 0 22px rgba(255, 23, 79, .08);
  padding: 10px;
  margin-bottom: 8px;
}

#tab-versions .version-active-box h3,
#tab-versions .version-section h3 {
  margin: 2px 0 4px;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: .8px;
}

/* ---- Active version card ---- */
#tab-versions #version-active-detail,
#tab-versions .version-active-detail {
  width: 100%;
}

#tab-versions #version-active-detail .version-active-card,
#tab-versions .version-active-detail .version-active-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
  width: 100%;
}

/* ---- Install form ---- */
#tab-versions .version-install-form {
  display: grid;
  grid-template-columns: auto minmax(100px, 1fr) auto minmax(100px, 1fr) auto;
  gap: 8px;
  align-items: end;
  width: 100%;
}

#tab-versions .version-install-form label {
  margin: 0 0 4px;
  font-size: 11px;
  white-space: nowrap;
}

#tab-versions .version-install-form select,
#tab-versions .version-install-form input {
  width: 100%;
  min-width: 0;
}

#tab-versions .version-install-form select {
  min-width: 0;
}

#tab-versions #version-install-btn {
  width: auto;
  min-width: 0;
  height: 36px;
  white-space: nowrap;
}

#tab-versions #version-installed-list {
  width: 100%;
  max-height: 130px;
  overflow-y: auto;
  padding: 6px;
}

#tab-versions .version-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
  width: 100%;
  min-height: 34px;
  padding: 6px 8px;
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 10px;
  background: rgba(4, 7, 16, .65);
}

#tab-versions .version-item-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

/* ---- Bedrock section ---- */
  margin-top: 10px;
  padding: 10px;
  border: 1px solid rgba(53, 234, 255, .20);
  border-radius: 12px;
  background:
    radial-gradient(circle at 18% 12%, rgba(53, 234, 255, .10), transparent 32%),
    radial-gradient(circle at 84% 16%, rgba(255, 23, 79, .12), transparent 30%),
    linear-gradient(145deg, rgba(6, 9, 18, .82), rgba(4, 6, 15, .74));
  box-shadow:
    inset 0 0 48px rgba(0, 0, 0, .22),
    0 0 26px rgba(53, 234, 255, .08),
    0 0 22px rgba(255, 23, 79, .08);
}

  margin: 2px 0 4px;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: .8px;
}

  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: flex-start;
  margin-bottom: 8px;
}

  max-width: 760px;
}

  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 8px;
}

  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .12);
  color: #dbe6f6;
  background: rgba(7, 10, 20, .70);
  font-weight: 900;
  transition: .16s ease;
  cursor: pointer;
}

  color: #fff;
  border-color: rgba(53, 234, 255, .38);
  background:
    linear-gradient(90deg, rgba(53, 234, 255, .26), rgba(255, 23, 79, .16)),
    rgba(7, 10, 20, .82);
  box-shadow: 0 0 18px rgba(53, 234, 255, .14);
}

  display: none;
}

  display: block;
}

  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--versions-card-gap);
  align-items: stretch;
  width: 100%;
}

  min-width: 0;
  width: 100%;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, .11);
  border-radius: 12px;
  background:
    linear-gradient(145deg, rgba(5, 7, 16, .72), rgba(7, 10, 22, .58));
}

  margin: 0 0 4px;
  font-size: 14px;
}

  color: var(--muted, #9ca8bd);
  line-height: 1.45;
}

  min-height: auto;
}

  min-width: 0;
}

  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: end;
  width: 100%;
}

#tab-versions .compact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

  display: grid;
  gap: 6px;
  min-height: 40px;
  width: 100%;
}

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 10px;
  padding: 6px 8px;
  background: rgba(4, 7, 16, .65);
}

  display: block;
  color: #fff;
  font-size: 15px;
}

  display: block;
  color: #9ca8bd;
  margin-top: 3px;
}

  border-color: rgba(98, 255, 143, .28);
  background:
    radial-gradient(circle at 12% 50%, rgba(98, 255, 143, .10), transparent 34%),
    rgba(4, 7, 16, .72);
}

  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 27px;
  padding: 0 10px;
  border-radius: 999px;
  color: #dffaff;
  border: 1px solid rgba(53, 234, 255, .26);
  background: rgba(53, 234, 255, .10);
  font-weight: 900;
  font-size: 12px;
}

  display: block;
  width: 100%;
  min-height: 42px;
  padding: 8px 10px;
  border-radius: 9px;
  border: 1px solid rgba(255, 255, 255, .13);
  background: rgba(7, 10, 20, .88);
  color: var(--text, #f6f8ff);
}

  min-height: 20px;
  margin: 6px 0 0;
}

  min-height: 32px;
}

  min-height: 30px;
  padding: 0 10px;
  font-size: 12px;
}

/* ---- Desktop wide ---- */
@media (min-width: 1280px) {
  :root {
    --versions-max-width: 580px;
  }
}

/* ---- Tablet ---- */
@media (max-width: 1100px) {
  :root {
    --versions-max-width: 100%;
  }

  #tab-versions {
    margin: 0;
  }

    grid-template-columns: 1fr;
  }

    min-height: auto;
  }
}

/* ---- Mobile ---- */
@media (max-width: 900px) {
  #tab-versions .version-install-form,
  #tab-versions .version-item,
  #tab-versions #version-active-detail .version-active-card,
  #tab-versions .version-active-detail .version-active-card {
    grid-template-columns: 1fr;
  }

  #tab-versions .version-active-box,
  #tab-versions .version-section,
    padding: 8px;
  }

  #tab-versions #version-install-btn,
    width: 100%;
  }

  #tab-versions .version-item-actions {
    justify-content: stretch;
  }

  #tab-versions .version-item-actions .btn,
    flex: 1 1 140px;
  }
}

/* ════════════════════════════════════════════════════════════
   VIP Tab
   ════════════════════════════════════════════════════════════ */
#tab-vip {
  width: 100%;
  max-width: var(--versions-max-width, 620px);
  margin: 0;
}

#tab-vip .panel-heading {
  max-width: var(--versions-max-width, 620px);
  margin: 0 0 10px;
}

#tab-vip .panel-heading h2 {
  font-size: 20px;
  margin-bottom: 4px;
}

#tab-vip .panel-heading p {
  font-size: 13px;
  margin: 0;
}

#tab-vip .panel-grid {
  display: block;
  width: 100%;
  max-width: var(--versions-max-width, 620px);
}

#tab-vip .panel-copy {
  width: 100%;
  max-width: 100%;
}

/* Status card */
#tab-vip .vip-status-card {
  border: 1px solid rgba(255, 215, 0, 0.25);
  border-radius: 12px;
  background:
    radial-gradient(circle at 18% 12%, rgba(255, 215, 0, 0.08), transparent 32%),
    radial-gradient(circle at 84% 16%, rgba(255, 23, 79, 0.10), transparent 30%),
    linear-gradient(145deg, rgba(6, 9, 18, 0.82), rgba(4, 6, 15, 0.74));
  box-shadow:
    inset 0 0 48px rgba(0, 0, 0, 0.22),
    0 0 26px rgba(255, 215, 0, 0.06);
  padding: 16px 20px;
  margin-bottom: 12px;
}

#tab-vip .vip-status-card h3 {
  margin: 0 0 8px;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text);
}

#tab-vip .vip-status-detail {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

#tab-vip .vip-status-badge {
  font-size: 14px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 6px;
}

#tab-vip .vip-status-badge.active {
  background: rgba(255, 215, 0, 0.15);
  color: #ffd700;
  border: 1px solid rgba(255, 215, 0, 0.3);
}

#tab-vip .vip-status-badge.none {
  background: rgba(255, 255, 255, 0.06);
  color: var(--muted);
}

#tab-vip .vip-status-plan {
  font-size: 18px;
  color: #fff;
  font-weight: 700;
}

#tab-vip .vip-status-expires {
  font-size: 12px;
  color: var(--muted);
}

/* Plans grid */
#tab-vip .vip-plans-section {
  margin-bottom: 12px;
}

#tab-vip .vip-plans-section h3 {
  margin: 0 0 10px;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

#tab-vip .vip-plans-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
}

#tab-vip .vip-plan-card {
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 10px;
  background: rgba(4, 7, 16, 0.65);
  padding: 16px;
  text-align: center;
  transition: border-color 0.2s, box-shadow 0.2s;
}

#tab-vip .vip-plan-card:hover {
  border-color: rgba(255, 215, 0, 0.3);
  box-shadow: 0 0 20px rgba(255, 215, 0, 0.06);
}

#tab-vip .vip-plan-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  display: block;
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

#tab-vip .vip-plan-price {
  font-size: 24px;
  font-weight: 800;
  color: #ffd700;
  display: block;
  margin: 6px 0;
}

#tab-vip .vip-plan-price small {
  font-size: 14px;
  color: var(--muted);
  font-weight: 400;
}

#tab-vip .vip-plan-desc {
  font-size: 12px;
  color: var(--muted);
  display: block;
  margin-bottom: 12px;
  line-height: 1.4;
}

#tab-vip .vip-plan-card .btn {
  width: 100%;
}

#tab-vip .doacao-row {
  display: flex;
  gap: 6px;
  align-items: center;
}

#tab-vip .doacao-row .doacao-input {
  flex: 1;
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 6px;
  background: rgba(0, 0, 0, 0.3);
  color: var(--text);
  font-size: 13px;
  text-align: center;
}

#tab-vip .doacao-row .doacao-input:focus {
  border-color: #22c55e;
  outline: none;
}

#tab-vip .doacao-row .btn {
  width: auto;
  white-space: nowrap;
}

/* Payment history */
#tab-vip .vip-history-section {
  margin-bottom: 12px;
}

#tab-vip .vip-history-section h3 {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--text);
}

#tab-vip .vip-pending-section {
  margin-bottom: 12px;
}

#tab-vip .vip-pending-section h3 {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 8px;
  color: #fbbf24;
}

#tab-vip .vip-pending-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#tab-vip .vip-pending-item {
  border: 1px solid rgba(251, 191, 36, 0.15);
  border-radius: 8px;
  background: rgba(251, 191, 36, 0.03);
  padding: 12px;
}

#tab-vip .vip-pending-item .pending-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}

#tab-vip .vip-pending-item .pending-plan {
  font-weight: 700;
  font-size: 13px;
}

#tab-vip .vip-pending-item .pending-amount {
  color: #ffd700;
  font-weight: 700;
}

#tab-vip .vip-pending-item .pending-user {
  font-size: 12px;
  color: var(--muted);
}

#tab-vip .vip-pending-item .pending-ocr {
  font-size: 11px;
  color: var(--muted);
  margin: 4px 0;
  font-style: italic;
}

#tab-vip .vip-pending-item .pending-receipt {
  margin: 6px 0;
  max-width: 300px;
  border-radius: 6px;
  overflow: hidden;
}

#tab-vip .vip-pending-item .pending-receipt img {
  width: 100%;
  display: block;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
}

#tab-vip .vip-pending-item .pending-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

#tab-vip .vip-pending-item .btn-confirm {
  background: #22c55e;
  color: #fff;
  border: none;
  padding: 6px 14px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
}

#tab-vip .vip-pending-item .btn-confirm:hover {
  background: #16a34a;
}

#tab-vip .vip-pending-item .btn-reject {
  background: #ef4444;
  color: #fff;
  border: none;
  padding: 6px 14px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
}

#tab-vip .vip-pending-item .btn-reject:hover {
  background: #dc2626;
}

#tab-vip .vip-history-section h3 {
  margin: 0 0 10px;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

#tab-vip .vip-history-filters {
  display: flex;
  gap: 6px;
  margin-bottom: 10px;
}

#tab-vip .vip-filter-btn {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--muted);
  padding: 4px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  transition: all 0.15s;
}

#tab-vip .vip-filter-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text);
}

#tab-vip .vip-filter-btn.active {
  background: rgba(255, 215, 102, 0.12);
  border-color: rgba(255, 215, 102, 0.3);
  color: var(--gold);
}

#tab-vip .vip-history-list {
  width: 100%;
  max-height: 200px;
  overflow-y: auto;
  padding: 4px 0;
  min-height: 40px;
}

#tab-vip .vip-history-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  margin-bottom: 4px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 8px;
  background: rgba(4, 7, 16, 0.4);
}

#tab-vip .vip-history-date {
  font-size: 12px;
  color: var(--muted);
}

#tab-vip .vip-history-plan {
  font-size: 13px;
  color: var(--text);
  font-weight: 600;
}

#tab-vip .vip-history-amount {
  font-size: 14px;
  color: #ffd700;
  font-weight: 700;
}

#tab-vip .vip-history-status {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
}

#tab-vip .vip-history-status.completed {
  background: rgba(98, 255, 143, 0.12);
  color: var(--green);
}

#tab-vip .vip-history-status.pending {
  background: rgba(255, 193, 7, 0.12);
  color: #ffc107;
}

#tab-vip .vip-history-status.failed {
  background: rgba(255, 23, 79, 0.12);
  color: var(--red);
}

#tab-vip .vip-history-status.rejected {
  background: rgba(255, 87, 34, 0.12);
  color: #ff5722;
}

/* ── VIP Badges (Admin / Staff) ─────────────────── */
#tab-vip .vip-role-badge.team {
  display: inline-block;
  background: linear-gradient(135deg, #00c853, #00a843);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  margin-top: 6px;
  letter-spacing: .3px;
}

#tab-vip .vip-staff-badge {
  display: inline-block;
  background: linear-gradient(135deg, #7c4dff, #651fff);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 12px;
  margin-bottom: 8px;
  letter-spacing: .3px;
}

#tab-vip .vip-plan-card.staff-discount {
  border-color: rgba(124, 77, 255, .4);
  background: linear-gradient(135deg, rgba(124, 77, 255, .06), rgba(101, 31, 255, .03));
}

/* ── Discord Tab — Verification Box ──────────────── */
#tab-home #discord-code-msg {
  display: block;
  margin-top: 8px;
  font-size: 13px;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 6px;
  background: rgba(0, 0, 0, .2);
}
#tab-home #complete-verification-btn {
  background: linear-gradient(180deg, #ff2b5f, #a3002b);
  box-shadow: 0 0 24px rgba(255, 23, 79, .35), inset 0 0 40px rgba(255, 215, 0, .06);
  border: 1px solid rgba(255, 215, 0, .2);
  font-size: 16px;
  min-height: 48px;
  letter-spacing: .8px;
  text-transform: uppercase;
  transition: .2s ease;
}
#tab-home #complete-verification-btn:hover {
  box-shadow: 0 0 32px rgba(255, 23, 79, .5), inset 0 0 40px rgba(255, 215, 0, .1);
  border-color: rgba(255, 215, 0, .4);
  transform: translateY(-3px);
}
#tab-home #complete-verification-btn:disabled {
  opacity: .4;
  filter: saturate(.5);
  transform: none;
}

/* ── Login Overlay ───────────────────────────────── */
.login-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(8, 10, 20, .92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.login-card {
  background: linear-gradient(145deg, #1a1d2e, #13151f);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 20px;
  padding: 48px 40px;
  max-width: 400px;
  width: 90%;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .5);
}

.login-card .login-logo {
  font-size: 56px;
  margin-bottom: 8px;
  filter: drop-shadow(0 0 20px rgba(255, 23, 79, .3));
}

.login-card h1 {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  margin: 0 0 8px;
}

.login-card p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 28px;
}

#login-error-msg {
  color: #ff4757;
  font-size: 13px;
  margin-top: 16px;
  padding: 8px 12px;
  background: rgba(255, 71, 87, .1);
  border-radius: 8px;
  display: none;
}

.login-card .spinner {
  width: 36px;
  height: 36px;
  margin: 16px auto 0;
  border: 3px solid rgba(255, 255, 255, .08);
  border-top-color: var(--red);
  border-radius: 50%;
  animation: spin .8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.btn-discord {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #5865f2 !important;
  color: #fff !important;
  border: 0;
  border-radius: 8px;
  padding: 12px 28px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: background .2s, transform .15s;
}

.btn-discord:hover {
  background: #4752c4 !important;
  transform: scale(1.03);
}

.btn-discord:active {
  transform: scale(.97);
}

.role-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  margin-left: 0;
  text-transform: uppercase;
  letter-spacing: .3px;
  white-space: nowrap;
  flex-shrink: 0;
}

.role-badge-admin {
  background: rgba(255, 23, 79, .18);
  color: #ff4757;
  border: 1px solid rgba(255, 23, 79, .25);
}

.role-badge-player {
  background: rgba(88, 101, 242, .18);
  color: #8b9aff;
  border: 1px solid rgba(88, 101, 242, .25);
}

.limited-badge {
  font-size: 9px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  background: rgba(255, 193, 7, .18);
  color: #ffc107;
  border: 1px solid rgba(255, 193, 7, .25);
  margin-left: auto;
  text-transform: uppercase;
  letter-spacing: .2px;
}

.sidebar-status {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 8px;
  column-gap: 6px;
  padding: 4px 0;
}
.sidebar-status .role-badge {
  width: auto;
  height: auto;
  background: rgba(255, 23, 79, .18);
  border-radius: 4px;
  box-shadow: none;
}

/* ── Terms Modal Overlay ──────────────────────────── */
.terms-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(8, 10, 20, .92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.terms-modal {
  background: linear-gradient(145deg, #1a1d2e, #13151f);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 16px;
  width: 90%;
  max-width: 760px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .5);
}
.terms-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(255, 255, 255, .06);
}
.terms-modal-header h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
}
.terms-modal-close {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
  transition: color .2s;
}
.terms-modal-close:hover {
  color: #fff;
}
.terms-modal-content {
  flex: 1;
  min-height: 0;
}
.terms-modal-content iframe {
  width: 100%;
  height: 60vh;
  border: 0;
  display: block;
}
.terms-modal-footer {
  padding: 16px 24px;
  text-align: center;
  border-top: 1px solid rgba(255, 255, 255, .06);
}

/* ── Member Status Card ──────────────────────────── */
.msc-card {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(145deg, rgba(7,10,22,.98), rgba(4,6,15,.95)) !important;
  box-shadow: inset 0 0 48px rgba(0,0,0,.22), 0 0 22px rgba(255,23,79,.08);
}
.msc-card .msc-accent-bar {
  height: 3px;
  background: linear-gradient(90deg, var(--red), var(--cyan), var(--red));
  background-size: 200% 100%;
  animation: msc-accent-shift 4s ease-in-out infinite;
}
@keyframes msc-accent-shift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}
.msc-body {
  padding: 28px 28px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.msc-badge-wrap {
  position: relative;
  margin-bottom: 12px;
}
.msc-badge {
  position: relative;
  z-index: 1;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(255,23,79,.25), rgba(53,234,255,.1));
  border: 2px solid rgba(255,23,79,.4);
  color: #fff;
  animation: msc-badge-pulse 2.5s ease-in-out infinite;
}
.msc-badge-glow {
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,23,79,.35), transparent 70%);
  animation: msc-glow-pulse 2.5s ease-in-out infinite;
}
@keyframes msc-badge-pulse {
  0%, 100% { box-shadow: 0 0 12px rgba(255,23,79,.3); }
  50% { box-shadow: 0 0 28px rgba(255,23,79,.6), 0 0 60px rgba(255,23,79,.15); }
}
@keyframes msc-glow-pulse {
  0%, 100% { opacity: .6; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.1); }
}
.msc-title {
  margin: 0 0 4px;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: 1px;
  background: linear-gradient(135deg, #fff, var(--red));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.msc-verified-tag {
  font-size: 12px;
  font-weight: 600;
  color: var(--green);
  letter-spacing: .5px;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 14px;
  padding: 3px 12px;
  border-radius: 20px;
  background: rgba(98, 255, 143, .1);
  border: 1px solid rgba(98, 255, 143, .2);
}
.msc-desc {
  margin: 0 0 22px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--muted);
  max-width: 360px;
}
.msc-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  width: 100%;
  margin-bottom: 22px;
}
.msc-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 8px;
  border-radius: 10px;
  background: rgba(255, 255, 255, .03);
  border: 1px solid rgba(255, 255, 255, .06);
  transition: all .25s ease;
}
.msc-stat:hover {
  background: rgba(255, 23, 79, .06);
  border-color: rgba(255, 23, 79, .2);
  transform: translateY(-2px);
}
.msc-stat-icon {
  font-size: 20px;
  line-height: 1;
  margin-bottom: 2px;
}
.msc-stat-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.msc-stat-value {
  font-size: 16px;
  font-weight: 800;
  color: #fff;
}
.msc-btn {
  width: 100%;
  padding: 12px 24px;
  font-size: 15px;
  font-weight: 700;
}


/* =========================================================
   RubyMC Premium Discord Section (Home)
   ========================================================= */

.home-discord-section {
  margin-top: 28px;
}

/* ── Section Header ──────────────────────────── */
.ds-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 22px;
  padding: 0 4px;
}
.ds-header-orb {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  border-radius: 14px;
  background: linear-gradient(145deg, rgba(88,101,242,.2), rgba(88,101,242,.05));
  border: 1px solid rgba(88,101,242,.25);
  box-shadow: 0 0 24px rgba(88,101,242,.15);
  flex-shrink: 0;
}
.ds-header-text { flex: 1; }
.ds-header-title {
  margin: 0;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  background: linear-gradient(135deg, #fff, #8b9aff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.ds-header-sub {
  margin: 4px 0 0;
  font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
}

/* ── Grid ────────────────────────────────────── */
.ds-grid {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 22px;
  align-items: start;
}
.ds-main-col {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.ds-side-col {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

/* ── Server Card ─────────────────────────────── */
.ds-server-card {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(88,101,242,.2);
  background: linear-gradient(145deg, rgba(7,10,22,.9), rgba(4,6,15,.82));
  box-shadow: inset 0 0 50px rgba(0,0,0,.22), 0 0 28px rgba(88,101,242,.08);
  backdrop-filter: blur(5px);
}
.ds-server-banner {
  height: 72px;
  background:
    linear-gradient(135deg, rgba(88,101,242,.35), rgba(53,234,255,.08)),
    radial-gradient(circle at 22% 40%, rgba(88,101,242,0.15), transparent 50%);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.ds-server-body {
  padding: 0 22px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.ds-server-avatar {
  position: relative;
  width: 56px;
  height: 56px;
  margin-top: -28px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, rgba(88,101,242,.3), rgba(53,234,255,.1));
  border: 2px solid rgba(88,101,242,.4);
  box-shadow: 0 0 22px rgba(88,101,242,.2);
  flex-shrink: 0;
}
.ds-server-avatar svg {
  width: 28px;
  height: 28px;
}
.ds-server-status-dot {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #43b581;
  border: 2px solid rgba(7,10,22,.9);
  box-shadow: 0 0 8px rgba(67,181,129,.5);
}
.ds-server-info {
  flex: 1;
  min-width: 120px;
}
.ds-server-name {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: .5px;
}
.ds-server-badge {
  display: inline-block;
  margin-top: 2px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1px;
  padding: 2px 10px;
  border-radius: 4px;
  background: rgba(88,101,242,.18);
  color: #8b9aff;
  border: 1px solid rgba(88,101,242,.25);
  text-transform: uppercase;
}
.ds-server-stats {
  display: flex;
  gap: 14px;
}
.ds-server-stat {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.ds-stat-icon { font-size: 14px; line-height: 1; }
.ds-stat-online { filter: drop-shadow(0 0 4px rgba(67,181,129,.4)); }
.ds-server-stat strong {
  font-size: 16px;
  font-weight: 800;
  color: #fff;
}
.ds-stat-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .3px;
}
.ds-btn-invite {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  border-radius: 8px;
  border: 0;
  background: linear-gradient(135deg, #5865f2, #4752c4);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s ease;
  box-shadow: 0 0 16px rgba(88,101,242,.25);
  flex-shrink: 0;
}
.ds-btn-invite:hover {
  background: linear-gradient(135deg, #6b7aff, #5865f2);
  transform: translateY(-2px);
  box-shadow: 0 0 28px rgba(88,101,242,.35);
}
.ds-btn-invite:active {
  transform: translateY(0);
}

/* ── Verify Card ─────────────────────────────── */
.ds-verify-card {
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(145deg, rgba(7,10,22,.88), rgba(4,6,15,.78));
  box-shadow: inset 0 0 48px rgba(0,0,0,.2), 0 0 22px rgba(255,23,79,.06);
  overflow: hidden;
}
.ds-verify-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 22px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(88,101,242,.04);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .3px;
  color: #b0bbf5;
}
.ds-verify-header svg { flex-shrink: 0; }

/* ── Verify Steps ────────────────────────────── */
.ds-verify-steps {
  display: flex;
  flex-direction: column;
}
.ds-verify-step {
  display: flex;
  gap: 14px;
  padding: 18px 22px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: opacity .3s ease;
}
.ds-verify-step:last-child { border-bottom: 0; }
.ds-step-marker {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 20px;
  padding-top: 2px;
}
.ds-step-status {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
  white-space: nowrap;
}
.ds-step-body { flex: 1; min-width: 0; }
.ds-step-title {
  font-size: 15px;
  font-weight: 700;
  color: #f0f4ff;
  margin-bottom: 2px;
}
.ds-step-desc {
  font-size: 12.5px;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 12px;
}
.ds-step-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.ds-terms-check {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: #c8d6ef;
  cursor: pointer;
}
.ds-terms-check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: #5865f2;
  cursor: pointer;
}
.ds-link-btn {
  background: none;
  border: none;
  color: #8b9aff;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.ds-link-btn:hover { color: #a8b4ff; }
.btn-discord-sm {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  border-radius: 6px;
  border: 0;
  background: #5865f2;
  color: #fff;
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  transition: all .15s ease;
}
.btn-discord-sm:hover { background: #4752c4; }
.btn-dark-sm {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: #d0dcf0;
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  transition: all .15s ease;
}
.btn-dark-sm:hover { background: rgba(255,255,255,.08); }
.btn-red-sm {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  border-radius: 6px;
  border: 0;
  background: linear-gradient(180deg, #ff2b5f, #c2002e);
  color: #fff;
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  transition: all .15s ease;
}
.btn-red-sm:hover { background: linear-gradient(180deg, #ff3d6b, #d6003a); }
.ds-step-box {
  margin-top: 8px;
}
.ds-step-box-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.ds-code-input {
  width: 100px;
  padding: 6px 10px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
  background: rgba(0,0,0,.3);
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  font-family: monospace;
  text-align: center;
  letter-spacing: 4px;
  outline: none;
  transition: border-color .2s;
}
.ds-code-input:focus { border-color: #5865f2; }
.ds-code-input:disabled { opacity: .4; }
.ds-msg {
  margin-top: 8px;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 12.5px;
  font-weight: 600;
  background: rgba(0,0,0,.2);
}
.ds-btn-complete {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: 8px;
  border: 1px solid rgba(255,215,0,.2);
  background: linear-gradient(180deg, #ff2b5f, #a3002b);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s ease;
  box-shadow: 0 0 24px rgba(255,23,79,.3), inset 0 0 40px rgba(255,215,0,.06);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.ds-btn-complete:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 32px rgba(255,23,79,.45), inset 0 0 40px rgba(255,215,0,.1);
  border-color: rgba(255,215,0,.35);
}
.ds-btn-complete:disabled {
  opacity: .4;
  filter: saturate(.5);
  transform: none;
  cursor: default;
}

/* ── Admin Card (sidebar) ────────────────────── */
.ds-admin-card {
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(145deg, rgba(7,10,22,.88), rgba(4,6,15,.78));
  box-shadow: inset 0 0 48px rgba(0,0,0,.2);
  padding: 18px;
}
.ds-admin-header {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  color: #f0f4ff;
  margin-bottom: 6px;
}
.ds-admin-header svg { color: #5865f2; flex-shrink: 0; }
.ds-admin-desc {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
  margin: 0 0 14px;
}
.ds-admin-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ds-admin-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
  color: #d0dcf0;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s ease;
  text-align: left;
}
.ds-admin-btn:hover {
  background: rgba(88,101,242,.08);
  border-color: rgba(88,101,242,.2);
  color: #fff;
}
.ds-admin-btn svg { flex-shrink: 0; color: #8b9aff; }

/* ── Responsive ──────────────────────────────── */
@media (max-width: 860px) {
  .ds-grid {
    grid-template-columns: 1fr;
  }
  .ds-side-col {
    order: -1;
  }
  .ds-admin-grid {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .ds-admin-btn {
    flex: 1;
    min-width: 120px;
  }
}

/* Botão "Tornar-se Membro Ruby" full-width */
#tab-home #complete-verification-btn {
  width: 100% !important;
  height: 48px !important;
  margin-top: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 15px !important;
}

#server-state {
  word-break: break-word;
}

/* =========================================================
   Dashboard — RubyMC Home Page Consolidado
   ========================================================= */

.dash {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* ── Hero ── */

.dash-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  padding: 22px 24px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(145deg, rgba(5,7,16,.88), rgba(7,8,19,.78));
  box-shadow: inset 0 0 60px rgba(0,0,0,.2), 0 0 30px rgba(255,23,79,.05);
}

.dash-hero-left {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.dash-hero-emoji {
  font-size: 28px;
  line-height: 1;
  margin-bottom: 2px;
}

.dash-hero-text {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}

.dash-hero-title {
  margin: 0;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  text-transform: uppercase;
  background: linear-gradient(135deg, #fff 30%, var(--red));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.dash-hero-sub {
  margin: 0;
  font-size: 16px;
  color: var(--muted);
  font-weight: 600;
}

.dash-hero-desc {
  margin: 2px 0 0;
  font-size: 13px;
  color: var(--muted);
}

.dash-actions {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}

.btn-glass {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  transition: .2s ease;
}
.btn-glass:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.25);
  box-shadow: 0 0 20px rgba(255,255,255,.06);
}

.dash-hero-right {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
}

.dash-profile-label {
  font-size: 11px;
  font-weight: 800;
  color: #8792a7;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.dash-hero-right select {
  min-width: 180px;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(2,4,12,.7);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}

/* ── Stats Row ── */

.dash-stats {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}

.dash-stat {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(5,7,16,.85);
  transition: .25s ease;
  position: relative;
  overflow: hidden;
}
.dash-stat::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 10px;
  opacity: 0;
  transition: .25s ease;
}
.dash-stat:hover {
  border-color: rgba(255,255,255,.18);
  transform: translateY(-1px);
}
.dash-stat:hover::before {
  opacity: 1;
}

.dash-stat[data-stat="version"]::before {
  background: linear-gradient(135deg, rgba(255,23,79,.08), transparent);
}
.dash-stat[data-stat="server"]::before {
  background: linear-gradient(135deg, rgba(53,234,255,.08), transparent);
}
.dash-stat[data-stat="status"]::before {
  background: linear-gradient(135deg, rgba(98,255,143,.08), transparent);
}
.dash-stat[data-stat="discord"]::before {
  background: linear-gradient(135deg, rgba(88,101,242,.08), transparent);
}
.dash-stat[data-stat="modpacks"]::before {
  background: linear-gradient(135deg, rgba(255,193,7,.08), transparent);
}

.dash-stat-icon {
  font-size: 20px;
  line-height: 1;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.dash-stat-body {
  display: flex;
  flex-direction: column;
  gap: 1px;
  position: relative;
  z-index: 1;
  min-width: 0;
}

.dash-stat-label {
  font-size: 10px;
  font-weight: 800;
  color: #8792a7;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.dash-stat-value {
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
}

.dash-stat-body small {
  font-size: 10px;
  color: var(--muted);
  font-weight: 600;
}

/* ── Main Grid ── */

.dash-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: start;
}

/* ── Dashboard Card ── */

.dash-card {
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(145deg, rgba(5,7,16,.92), rgba(7,8,19,.82));
  box-shadow: inset 0 0 48px rgba(0,0,0,.15), 0 0 20px rgba(255,23,79,.04);
  overflow: hidden;
  transition: .25s ease;
}
.dash-card:hover {
  border-color: rgba(255,255,255,.14);
}

.dash-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
}

.dash-card-header-icon {
  font-size: 16px;
  line-height: 1;
}

.dash-card-header h3 {
  margin: 0;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .5px;
  text-transform: uppercase;
  flex: 1;
}

.dash-card-body {
  padding: 16px 18px 18px;
}

/* ── Community Guild ── */

.dash-guild-banner {
  height: 40px;
  margin: -16px -18px 0;
  background: linear-gradient(135deg, rgba(88,101,242,.3), rgba(53,234,255,.06));
  border-bottom: 1px solid rgba(88,101,242,.15);
}

.dash-guild-info {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}

.dash-guild-avatar {
  position: relative;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, rgba(88,101,242,.25), rgba(53,234,255,.08));
  border: 2px solid rgba(88,101,242,.35);
  flex-shrink: 0;
}

.dash-guild-dot {
  position: absolute;
  bottom: -2px;
  right: -2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #43b581;
  border: 2px solid rgba(5,7,16,.95);
  animation: dash-pulse 2s ease-in-out infinite;
}

@keyframes dash-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(67,181,129,.6); }
  50% { box-shadow: 0 0 0 4px rgba(67,181,129,0); }
}

.dash-guild-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dash-guild-name {
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  letter-spacing: .3px;
}

.dash-guild-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1px;
  padding: 1px 8px;
  border-radius: 3px;
  background: rgba(88,101,242,.15);
  color: #8b9aff;
  border: 1px solid rgba(88,101,242,.2);
  text-transform: uppercase;
  width: fit-content;
}

.dash-guild-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin: 14px 0;
}

.dash-guild-stat {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.dash-guild-stat strong {
  display: block;
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
}
.dash-guild-stat small {
  font-size: 9px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
}

.dash-invite-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 10px;
  border-radius: 8px;
  border: 0;
  background: linear-gradient(135deg, #5865f2, #4752c4);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 0 16px rgba(88,101,242,.2);
  transition: .2s ease;
}
.dash-invite-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 0 24px rgba(88,101,242,.35);
}

/* ── Verification Steps ── */

.dash-vstep {
  display: flex;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.dash-vstep:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.dash-vstep:first-child {
  padding-top: 2px;
}

.dash-vstep-marker {
  flex-shrink: 0;
  width: 28px;
  padding-top: 2px;
}

.dash-vstep-status {
  display: inline-block;
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(255,255,255,.06);
  color: var(--muted);
  border: 1px solid rgba(255,255,255,.08);
}

.dash-vstep-body {
  flex: 1;
  min-width: 0;
}

.dash-vstep-title {
  font-size: 14px;
  font-weight: 700;
  color: #f0f4ff;
}

.dash-vstep-desc {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 10px;
}

.dash-vstep-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.dash-terms-check {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
  cursor: pointer;
}
.dash-terms-check input[type="checkbox"] {
  accent-color: var(--red);
}

.dash-link-btn {
  background: none;
  border: none;
  color: var(--cyan);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.dash-link-btn:hover {
  color: #fff;
}

.dash-vstep-box {
  margin-top: 8px;
}

.dash-vstep-box-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dash-code-input {
  width: 90px;
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(2,4,12,.7);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 2px;
}

.dash-msg {
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 6px;
  margin-top: 6px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}

/* ── Member Status Card ── */

.dash-card-member .dash-card-body {
  padding: 14px 18px 16px;
}

.dash-verified-badge {
  font-size: 12px;
  font-weight: 800;
  color: var(--green);
  background: rgba(98,255,143,.12);
  border: 1px solid rgba(98,255,143,.2);
  border-radius: 20px;
  padding: 2px 10px;
  margin-left: auto;
}

.dash-member-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.dash-member-stat {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px;
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}

.dash-member-stat-icon {
  font-size: 18px;
  line-height: 1;
}

.dash-member-stat-label {
  display: block;
  font-size: 9px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .3px;
}

.dash-member-stat-value {
  display: block;
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  margin-top: 1px;
}

.dash-card-member .dash-invite-btn {
  margin-top: 12px;
}

/* ── Admin ── */

.dash-admin {
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(5,7,16,.8);
  padding: 14px 18px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 20px;
}

.dash-admin-header {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  color: #f0f4ff;
  flex-shrink: 0;
}

.dash-admin-icon {
  font-size: 16px;
}

.dash-admin-desc {
  margin: 0;
  font-size: 11px;
  color: var(--muted);
  flex: 1;
  min-width: 160px;
}

.dash-admin-status {
  display: flex;
  gap: 12px;
  font-size: 11px;
  color: var(--muted);
  flex-shrink: 0;
}
.dash-admin-status strong {
  color: #fff;
}

.dash-admin-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.dash-admin-btn {
  padding: 6px 12px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: #d0dcf0;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: .2s ease;
  white-space: nowrap;
}
.dash-admin-btn:hover {
  background: rgba(88,101,242,.1);
  border-color: rgba(88,101,242,.25);
  color: #fff;
}

/* ── Responsive ── */

@media (max-width: 1200px) {
  .dash-stats {
    grid-template-columns: repeat(3, 1fr);
  }
  .dash-hero-title {
    font-size: 24px;
  }
}

@media (max-width: 1000px) {
  .dash-grid {
    grid-template-columns: 1fr;
  }
  .dash-admin {
    flex-direction: column;
    align-items: stretch;
  }
  .dash-admin-actions {
    flex-wrap: wrap;
  }
}

@media (max-width: 700px) {
  .dash-hero {
    flex-direction: column;
  }
  .dash-hero-right {
    width: 100%;
  }
  .dash-hero-right select {
    width: 100%;
  }
  .dash-stats {
    grid-template-columns: repeat(2, 1fr);
  }
  .dash-guild-stats {
    grid-template-columns: 1fr;
  }
  .dash-member-stats {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .dash-stats {
    grid-template-columns: 1fr;
  }
  .dash-actions {
    flex-direction: column;
  }
  .dash-actions .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ── Animations ── */

@keyframes dash-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.dash-hero { animation: dash-fade-in .35s ease both; }
.dash-stats { animation: dash-fade-in .35s ease .08s both; }
.dash-grid { animation: dash-fade-in .35s ease .15s both; }
.dash-admin { animation: dash-fade-in .35s ease .22s both; }

/* ── PIX Modal ── */
.pix-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.75);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(4px);
  animation: dash-fade-in .2s ease both;
}

.pix-modal {
  background: linear-gradient(145deg, #1a1a2e, #16213e);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 32px;
  max-width: 460px;
  width: 100%;
  position: relative;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}

.pix-modal-close {
  position: absolute;
  top: 12px;
  right: 16px;
  background: none;
  border: none;
  color: var(--muted, #888);
  font-size: 22px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 8px;
  transition: background .15s;
}
.pix-modal-close:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
}

.pix-modal-title {
  margin: 0 0 4px;
  font-size: 22px;
  color: #fff;
}

.pix-modal-plan {
  margin: 0 0 20px;
  font-size: 14px;
  color: var(--muted, #888);
}
.pix-modal-plan strong {
  color: #4ade80;
  font-size: 18px;
}

.pix-modal-qr-wrapper {
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
}

.pix-modal-qr {
  width: 220px;
  height: 220px;
  border-radius: 12px;
  background: #fff;
  padding: 8px;
  image-rendering: pixelated;
}

.pix-modal-code label {
  display: block;
  font-size: 12px;
  color: var(--muted, #888);
  margin-bottom: 6px;
}

.pix-code-box {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(0,0,0,.3);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 16px;
}

.pix-code-box code {
  flex: 1;
  font-size: 11px;
  color: #ccc;
  word-break: break-all;
  line-height: 1.4;
  user-select: all;
}

.pix-modal-status {
  text-align: center;
  padding: 10px;
  border-radius: 10px;
  background: rgba(255,255,255,.04);
  margin-bottom: 16px;
  font-size: 14px;
  color: var(--muted, #aaa);
}

.pix-modal-status.success {
  background: rgba(74,222,128,.1);
  color: #4ade80;
}

.pix-status-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}

.pix-status-dot.pending {
  background: #facc15;
  animation: pix-pulse 1.2s ease-in-out infinite;
}

.pix-status-dot.completed {
  background: #4ade80;
}

@keyframes pix-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .4; transform: scale(.8); }
}

.pix-modal-actions {
  display: flex;
  gap: 10px;
}
.pix-modal-actions .btn {
  flex: 1;
  justify-content: center;
}

.pix-modal-receipt {
  margin: 12px 0;
  padding: 10px;
  border: 1px dashed rgba(255, 255, 255, 0.15);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.15);
}

.pix-modal-receipt .pix-receipt-label {
  font-size: 12px;
  color: var(--muted, #9ca8bd);
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
}

.pix-modal-receipt .pix-receipt-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.pix-modal-receipt .pix-receipt-input {
  flex: 1;
  min-width: 0;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  background: rgba(0, 0, 0, 0.2);
  color: var(--text, #fff);
  font-size: 12px;
}

.pix-modal-receipt .pix-receipt-input::file-selector-button {
  padding: 4px 10px;
  border: none;
  border-radius: 4px;
  background: #3b82f6;
  color: #fff;
  font-size: 11px;
  cursor: pointer;
  margin-right: 8px;
}

.pix-modal-receipt .pix-receipt-status {
  font-size: 11px;
  margin-top: 6px;
  color: var(--muted, #9ca8bd);
}

.pix-modal-receipt .pix-receipt-status.success {
  color: #22c55e;
}

.pix-modal-receipt .pix-receipt-status.error {
  color: #ef4444;
}

.btn-blue {
  background: #3b82f6;
  color: #fff;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  transition: background 0.2s;
}

.btn-blue:hover {
  background: #2563eb;
}

.btn-ghost {
  background: transparent;
  color: var(--muted, #9ca8bd);
  border: 1px solid rgba(255,255,255,.08);
  transition: all .15s ease;
}
.btn-ghost:hover {
  color: #fff;
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.15);
}
