:root{ --bg:#0a0a0a; --fg:#f5f5f5; --muted:#b5b5b5; --crimson:#d1121f; }
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--fg);font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5}
h1,h2{font-family:'Bebas Neue',system-ui}
.btn-red{background:linear-gradient(180deg,#ff3131,var(--crimson));}

/* bloqueia tudo quando não logado */
body.auth-locked #app-shell{display:none !important;}
body.auth-locked #login-gate{display:block !important;}

/* quando logado, esconde o formulário e mostra o app */
body.auth-unlocked #login-gate{display:none !important;}
body.auth-unlocked #app-shell{display:block !important;}

/* === Abas === */
.tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.15);margin-top:1rem}
.tab-link{
  flex:1;text-align:center;font-weight:600;padding:14px 0 10px;
  color:var(--muted);border:none;background:transparent;cursor:pointer;
  position:relative;transition:color .2s ease;
}
.tab-link:hover{color:var(--fg)}
.tab-link.active{color:#fff;font-weight:700}
.tab-link.active::after{
  content:"";position:absolute;left:20%;right:20%;bottom:0;height:3px;
  border-radius:2px;background:linear-gradient(90deg,#ff3131,var(--crimson));
  box-shadow:0 0 14px rgba(209,18,31,.4);
}
.tab-panel{display:none;animation:fadeIn .4s ease}
.tab-panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* chips/info (catálogo) */
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  font-weight:700;font-size:.95rem}
.text-azul{color:#3b82f6}.text-roxa{color:#a855f7}.text-rosa{color:#ec4899}

/* vela (catálogo) */
.vela{padding:6px 10px;border-radius:.5rem;font-weight:600;border:2px solid transparent;background-color:#1f2937}
.borda-verde{border-color:#10b981}

/* tooltip (catálogo) */
.tip{position:fixed;z-index:50;pointer-events:none;background:rgba(17,17,17,.9);color:#fff;
  border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:6px 8px;font-size:.8rem;
  box-shadow:0 6px 24px rgba(0,0,0,.45);transform:translate(-50%,-110%);
  opacity:0;transition:opacity .12s ease;white-space:nowrap}
.tip.show{opacity:1}

/* Minutagem */
.chip-final{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:12px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);font-weight:800}
.chip-final.active{outline:2px solid #10b981}
.bar{height:6px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,#ff7aa0,#ec4899)}
.table-minu th,.table-minu td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08)}
.tag-muted{display:inline-block;padding:4px 8px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);font-size:.85rem}
pre{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;line-height:1.35}
.tab-link.logout-tab{
  flex:0;
  padding:14px 14px 10px;
  font-size:1.4rem;
  line-height:1;
  color:var(--muted);
  min-width:0;
}
.tab-link.logout-tab:hover{color:#fff;}
.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.7);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
  z-index:200;
}
.modal-card{
  width:100%;
  max-width:320px;
  border-radius:1rem;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(20,20,20,.95);
  padding:1.5rem;
  box-shadow:0 18px 36px rgba(0,0,0,.45);
  text-align:center;
}
.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;}
.modal-actions button{flex:1;}
.btn-outline{
  background:transparent;
  border:1px solid rgba(255,255,255,.2);
  color:var(--fg);
  border-radius:.75rem;
  padding:.6rem 1rem;
  font-weight:600;
  cursor:pointer;
  transition:background .2s ease,border-color .2s ease;
}
.btn-outline:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.35);
}
#aviator-frame-wrap{
  position:relative;
  overflow:visible;
  transition:border-color .25s ease,box-shadow .25s ease,outline .25s ease;
}
#aviator-frame-wrap .aviator-frame-shell{
  position:relative;
  width:100%;
  height:100%;
  border-radius:inherit;
  overflow:hidden;
  background:inherit;
  z-index:1;
}
#aviator-frame-wrap.momento-pagando{
  border-color:rgba(168,85,247,.75);
  box-shadow:0 0 24px rgba(168,85,247,.45);
}
#aviator-frame-wrap.momento-recolhendo{
  border-color:rgba(59,130,246,.8);
  box-shadow:0 0 24px rgba(59,130,246,.45);
}
#aviator-frame-wrap .momento-tag{
  position:absolute;
  top:1px;
  left:50%;
  transform:translate(-50%,0);
  padding:4px 18px;
  min-width:120px;
  height:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:0 0 10px 10px;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:rgba(0,0,0,.65);
  color:#fff;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease,background .2s ease,box-shadow .2s ease;
  z-index:2;
}
#aviator-frame-wrap.momento-pagando .momento-tag,
#aviator-frame-wrap.momento-recolhendo .momento-tag{opacity:1;}
#aviator-frame-wrap.momento-pagando .momento-tag{
  background:rgba(168,85,247,.92);
  box-shadow:0 6px 16px rgba(168,85,247,.3);
}
#aviator-frame-wrap.momento-recolhendo .momento-tag{
  background:rgba(59,130,246,.92);
  box-shadow:0 6px 16px rgba(59,130,246,.3);
}
