/* ===============================
   ALL24 base stylesheet
   Path: /assets/app.css
   =============================== */

   /* Auth page layout (login/register) */
   .page-center {
     min-height: 100vh;
     display: grid;
     place-items: center;
   }

   .auth-card {
     width: min(520px, 92vw);
     background: #0b0b0b;
     border: 1px solid rgba(255,255,255,.1);
     border-radius: 18px;
     padding: 20px 20px 22px;
     box-shadow: 0 10px 30px rgba(0,0,0,.35);
   }

   .auth-card .btn, .card .btn {
     width: 100%;
     margin-top: 16px;
   }
   .auth-card a, .card a {
     color:#FFF; text-decoration: none; text-align: center;
   }
   .auth-card a:hover, .card a:hover {
     color:#49B2E3;
   }
   .auth-card input + .btn {
     margin-top: 12px;
  }
/* Theme tokens */
:root{
  --bg:#000;
  --fg:#fff;
  --muted:#9aa4ad;
  --accent:#49B2E3;
  --panel:#222;
  --ok:#19c37d;
  --danger:#ea3d3d;
}

/* Resets / base */
html,body{height:100%}
*,*::before,*::after{box-sizing:border-box}
body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font:18px/1.6 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

/* Typography helpers */
.h{margin:0 0 6px; font-size:20px; font-weight:800}
.muted{color:var(--muted)}
.center{text-align:center}

/* Form controls */
label{display:block; font-size:14px; color:var(--muted); margin:12px 0 6px}
input,select,textarea{
  width:100%;
  padding:14px 16px;
  font-size:18px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:#111;
  color:#fff;
  outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(73,178,227,.15);
}

/* Buttons */
.btn{
  display:inline-block;
  padding:14px 18px;
  font-size:17px;
  font-weight:800;
  border:0;
  border-radius:12px;
  /*cursor:pointer;*/
  background:var(--accent);
  color:#001016;
}
.btn:disabled{opacity:.6; cursor:not-allowed}
.btn-ghost{
  background:transparent;
  color:#dfe6eb;
  border:0;
}

/* Alerts */
.error{
  display:none;
  margin-top:10px;
  font-size:16px;
  background:#b21a1a;
  border:1px solid #cf4e4e;
  padding:10px 12px;
  border-radius:10px;
}
.ok{
  display:none;
  margin-top:10px;
  font-size:16px;
  background:#103d26;
  border:1px solid #1f7a46;
  color:#d8ffe7;
  padding:10px 12px;
  border-radius:10px;
}

/* Cards / panels (reusable) */
.card,.panel,.step{
  background:#0b0b0b;
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  padding:20px;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}

/* Auth layout helpers (login + register) */
.page-center{min-height:100vh; display:grid; place-items:center}
.auth-card{width:min(520px,92vw)}
.logo{display:flex; justify-content:center; margin:6vh 0 12px}
.logo img{width:min(320px,80%); height:auto; display:block}

/* Top bar (single-row header) */
.topbar{
  position:sticky; top:0; z-index:100;
  display:flex; align-items:center;
  padding:0 14px;
  height:48px;
  background:#0a0b0d;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar .brand{display:flex; align-items:center; gap:10px; margin-right:20px}
.topbar .brand img{height:24px; width:auto}

/* Inline nav (in header) */
.nav-inline{display:flex; gap:2px; flex:1}
.nav-item{
  padding:6px 12px; border-radius:6px;
  color:rgba(255,255,255,.55); text-decoration:none;
  font:13px/1.2 system-ui; font-weight:600;
  transition:all .12s ease;
}
.nav-item:hover{color:#fff; background:rgba(255,255,255,.06)}
.nav-item.active{color:#fff; background:rgba(73,178,227,.18)}

/* User actions (right side of header) */
.user-actions{display:flex; align-items:center; gap:4px; margin-left:auto}
.header-btn{
  padding:6px 10px; border-radius:6px;
  font:12px/1 system-ui; color:rgba(255,255,255,.55);
  cursor:pointer; transition:all .12s;
}
.header-btn:hover{color:#fff; background:rgba(255,255,255,.06)}

/* Mobile hamburger (appears left of brand on mobile) */
.nav-toggle{
  display:none; border:0; background:0; padding:8px;
  cursor:pointer; flex-direction:column; gap:4px;
  width:36px; height:36px; justify-content:center; align-items:center;
  order: -1; margin-right: 4px;
}
.nav-toggle span{
  display:block; width:18px; height:2px; background:#fff;
  border-radius:1px; transition:all .2s;
}

/* Layout-fixed: lock viewport, hide footer */
body.layout-fixed{overflow:hidden; height:100dvh}
body.layout-fixed footer{display:none !important}
body.layout-fixed .teambar{display:none}
body.layout-fixed .tb-admin-actions{display:none}

/* Legacy tabs (kept for other pages) */
.tabs{display:flex; gap:8px; padding:10px 14px; border-bottom:1px solid rgba(255,255,255,.08); background:#111; }
.tab{padding:10px 12px; border-radius:10px; color:#dfe6eb; text-decoration:none}
.tab.active,.tab:hover{background:rgba(73,178,227,.15); color:#fff}

/* App layout */
.app-layout{display:grid; grid-template-columns:280px 1fr; gap:14px; padding:14px}
.side-panel{background:var(--panel); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:12px}

/* Utility */
.hidden{display:none}


/* minimal modal styles */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:50}
.modal-backdrop .modal{width:min(560px,92vw);background:#0b0b0b;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:16px}
.modal-backdrop .modal h3{margin:0 0 8px}
.modal-backdrop .modal .muted{margin:0 0 10px}
.modal-backdrop .input-row{display:flex;gap:8px}
.modal-backdrop .input-row input{flex:1}
.modal-backdrop .list{margin-top:10px;display:grid;gap:8px}
.modal-backdrop .item{padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#111;cursor:pointer}
.modal-backdrop .item:hover{border-color:#49B2E3}
.modal-backdrop .modal .actions{margin-top:12px;display:flex;gap:8px;justify-content:flex-end}


/* Team switcher + banners */
.teambar {
  display:flex; align-items:center; gap:10px; padding:8px 14px;
  border-bottom:1px solid rgba(255,255,255,.08); background:#111;
}
.team-switch { position:relative; }
.team-btn {
  background:#0b0b0b; color:#fff; border:1px solid rgba(255,255,255,.14);
  padding:8px 12px; border-radius:10px; font-weight:700;
}
.team-dd {
  position:absolute; top:110%; left:0; min-width:260px; z-index:30;
  background:#0b0b0b; border:1px solid rgba(255,255,255,.14); border-radius:10px; padding:8px; display:none;
}
.team-dd .item { padding:8px 10px; border-radius:8px; }
.team-dd .item:hover { background:rgba(255,255,255,.08); }

.banner {
  margin:10px 14px 0; padding:10px 12px;
  border-radius:10px; background:#102033; border:1px solid rgba(73,178,227,.35);
}
.banner .muted { color:#c8d8e6 }
.link-btn { color:#49B2E3; background:transparent; border:0; padding:0 2px; }
.join-panel { margin:10px 14px; padding:12px; border:1px solid rgba(255,255,255,.14); background:#111; border-radius:10px; display:none; }
.join-row { display:flex; gap:8px; }
@media (max-width:560px){ .join-row { display:block; } }
.result { padding:10px; border:1px solid rgba(255,255,255,.12); border-radius:10px; background:#0b0b0b; }
.result + .result { margin-top:8px; }







/* Base: desktop/tablet stays as-is */
.app-layout { display:grid; grid-template-columns: 280px 1fr; gap:16px; padding:16px; }

/* Mobile responsive */
@media (max-width: 768px) {
  .nav-inline { display:none }
  .nav-toggle { display:flex !important }
  .user-actions { margin-right:8px }
  .app-layout { grid-template-columns: 1fr; }
  .side-panel { order:2; }
  .panel { order:1; }
  .card { border-radius:14px; }
  .btn, .btn-ghost, .team-btn { padding:12px 14px; border-radius:12px; }
  .card.wide { width: 90%; }
  .app-layout > .grid-wide { grid-column: 1; }
}

/* Mobile nav dropdown */
.mobile-menu {
  display:none; z-index:100;
  background:#0a0b0d;
  border-bottom: 1px solid rgba(255,255,255,.1);
  padding:6px 8px;
}
.mobile-menu a {
  display:block; padding:12px 14px; border-radius:8px;
  text-decoration:none; color:rgba(255,255,255,.7); font:14px/1.2 system-ui; font-weight:600;
}
.mobile-menu a:hover, .mobile-menu a.active { background:rgba(255,255,255,.06); color:#fff; }



.centered-form {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  margin-top: 5vh;
}


.app-layout > .grid-wide { grid-column: 1 / -1 !important; }
