:root{
  --bg0:#05060a;
  --bg1:#0b1020;

  --card: rgba(255,255,255,0.04);
  --card2: rgba(255,255,255,0.06);
  --line: rgba(0,255,255,0.22);

  --text:#e9eef7;
  --muted: rgba(233,238,247,0.68);

  --a:#00f6ff;
  --b:#ff4fd8;
  --ball:#ffe66d;

  --shadow: 0 18px 60px rgba(0,0,0,0.55);
  --radius: 18px;
}

*{ box-sizing:border-box; }

html, body{
  height:100%;
}

body{
  margin:0;
  height:100vh;
  overflow:hidden; 
  color:var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  padding: 14px;

  background:
    radial-gradient(900px 520px at 15% 10%, rgba(0,246,255,0.18), transparent 60%),
    radial-gradient(800px 520px at 90% 12%, rgba(255,79,216,0.14), transparent 62%),
    radial-gradient(950px 700px at 50% 110%, rgba(255,230,109,0.08), transparent 58%),

    radial-gradient(circle at 18% 22%, rgba(255,255,255,0.14) 0 1px, transparent 2px),
    radial-gradient(circle at 62% 35%, rgba(255,255,255,0.12) 0 1px, transparent 2px),
    radial-gradient(circle at 78% 62%, rgba(255,255,255,0.10) 0 1px, transparent 2px),
    radial-gradient(circle at 34% 70%, rgba(255,255,255,0.10) 0 1px, transparent 2px),
    radial-gradient(circle at 88% 82%, rgba(255,255,255,0.08) 0 1px, transparent 2px),

    linear-gradient(rgba(0,246,255,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,79,216,0.06) 1px, transparent 1px),

    linear-gradient(180deg, #0b1020, #05060a);
  background-size:
    auto, auto, auto,
    auto, auto, auto, auto, auto,
    48px 48px, 48px 48px,
    auto;
  background-position:
    center, center, center,
    center, center, center, center, center,
    0 0, 0 0,
    center;
}


body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(1200px 800px at 50% 50%, transparent 55%, rgba(0,0,0,0.55)),
    repeating-linear-gradient(
      to bottom,
      rgba(0,0,0,0.0),
      rgba(0,0,0,0.0) 2px,
      rgba(0,0,0,0.10) 3px,
      rgba(0,0,0,0.10) 4px
    );
  mix-blend-mode: overlay;
  opacity: 0.55;
}

.layout{
  height: calc(100vh - 28px);
  display:grid;
  grid-template-columns: 270px 1fr 340px;
  gap: 16px;
  align-items:stretch;
}

.leftbar, .sidebar{
  height: 100%;
  overflow: hidden;
}

.games{
  height:100%;
  display:flex;
  flex-direction:column;
  gap: 14px;
  overflow:hidden;
}

.row{
  display:flex;
  gap: 14px;
  justify-content:center;
  align-items:stretch;
  flex-wrap:nowrap;
}

.tablecard{
  flex:1;
  min-width: 420px;
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}

.tablecard.wide{
  width: min(640px, 100%);
  flex: 0 1 auto;
  margin: 0 auto;
}

.tablecard::after{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  border-radius: calc(var(--radius) + 2px);
  background: linear-gradient(120deg, rgba(0,246,255,0.12), rgba(255,79,216,0.08), rgba(255,230,109,0.06));
  filter: blur(16px);
  opacity: 0.45;
}

.tablehead{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 9px 12px;
  font-weight: 800;
  color: rgba(233,238,247,0.92);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.28);
  letter-spacing: 0.2px;
}

.tablefoot{
  position:relative;
  z-index:1;
  padding: 8px 12px;
  border-top: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.24);
  color: rgba(233,238,247,0.78);
  font-size: 0.90rem;
  min-height: 34px;
}

canvas{
  position:relative;
  z-index:1;
  display:block;
  width:100%;
  height:auto;
  background:
    radial-gradient(900px 380px at 50% 50%, rgba(0,246,255,0.08), transparent 62%),
    radial-gradient(800px 420px at 60% 40%, rgba(255,79,216,0.05), transparent 65%),
    linear-gradient(180deg, rgba(0,0,0,0.55), rgba(0,0,0,0.88));
  border-top: 1px solid rgba(0,255,255,0.12);
  border-bottom: 1px solid rgba(0,255,255,0.12);
  animation: glow 4s ease-in-out infinite alternate;
}

@keyframes glow{
  from{ filter: drop-shadow(0 0 12px rgba(0,246,255,0.18)); }
  to  { filter: drop-shadow(0 0 22px rgba(255,79,216,0.18)); }
}

.sidebar{
  display:flex;
  flex-direction:column;
  gap: 14px;
}

.panel{
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 12px;
  backdrop-filter: blur(10px);
  overflow:hidden;
}

.panel-title{
  font-weight: 900;
  font-size: 1.02rem;
  margin-bottom: 4px;
}

.panel-sub{
  color: var(--muted);
  font-size: 0.86rem;
  margin-bottom: 10px;
}

.leaderboard{
  display:flex;
  flex-direction:column;
  gap: 8px;
}

.lb-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 9px 10px;
  border-radius: 12px;
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(255,255,255,0.07);
}

.lb-name{
  display:flex;
  flex-direction:column;
  gap: 2px;
}

.lb-name strong{ font-size: 0.95rem; }
.lb-name span{ font-size: 0.82rem; color: var(--muted); }

.lb-wins{
  font-weight: 900;
  font-size: 1.02rem;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
}

.matchlog{
  max-height: 420px;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap: 8px;
  padding-right: 6px;
}

.log-item{
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  padding: 10px 10px;
  line-height: 1.25;
}

.log-item .small{
  color: var(--muted);
  font-size: 0.84rem;
  margin-top: 4px;
}

.leftbar{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 12px;
  backdrop-filter: blur(12px);
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(255,255,255,0.08);
}

.brand-logo{
  width: 44px;
  height: 44px;
  object-fit: contain;
  border-radius: 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  padding: 6px;
  filter: drop-shadow(0 0 16px rgba(0,246,255,0.18));
}

.brand-title{
  font-weight: 1000;
  font-size: 1.08rem;
  letter-spacing: 1.4px;
}

.brand-sub{
  color: var(--muted);
  font-size: 0.86rem;
  margin-top: 1px;
}

.navblock{ margin-top: 2px; }

.navtitle{
  font-weight: 900;
  color: rgba(233,238,247,0.92);
  margin: 6px 6px 10px;
  font-size: 0.92rem;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

.navitem{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(0,0,0,0.26);
  border: 1px solid rgba(255,255,255,0.08);
  text-decoration:none;
  color: rgba(233,238,247,0.92);
  margin-bottom: 10px;
  transition: transform 120ms ease, background 120ms ease, border 120ms ease;
}

.navitem:hover{
  transform: translateY(-1px);
  background: rgba(0,0,0,0.32);
  border-color: rgba(255,255,255,0.11);
}

.navitem.active{
  border-color: rgba(0,246,255,0.28);
  box-shadow: 0 0 0 1px rgba(0,246,255,0.10), 0 18px 50px rgba(0,246,255,0.07);
}

.navicon{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  font-size: 18px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
}

.navtext{
  flex: 1;
  min-width: 0;
}

.navname{
  font-weight: 900;
  font-size: 0.96rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.navdesc{
  color: var(--muted);
  font-size: 0.84rem;
  margin-top: 2px;
}

.navpill{
  font-weight: 1000;
  font-size: 0.72rem;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
}

.navpill.live{
  color: rgba(0,246,255,0.98);
  border-color: rgba(0,246,255,0.24);
  background: rgba(0,246,255,0.10);
}

.navpill.soon{
  color: rgba(233,238,247,0.55);
  border-color: rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
}

.navitem.disabled{
  opacity: 0.45;
  filter: grayscale(0.35);
  cursor: not-allowed;
  pointer-events: none;
}

.leftfoot{
  margin-top: auto;
  padding: 12px;
  border-radius: 14px;
  background: rgba(0,0,0,0.26);
  border: 1px solid rgba(255,255,255,0.08);
}

.leftfoot-title{
  font-weight: 1000;
  margin-bottom: 4px;
}

.leftfoot-sub{
  color: rgba(233,238,247,0.80);
  font-size: 0.9rem;
}

.leftfoot-mini{
  color: var(--muted);
  font-size: 0.84rem;
  margin-top: 4px;
}

#loadingScreen{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#05060a;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity 0.8s ease;
}

.loading-content{
  text-align:center;
}

.loading-title{
  font-size:3rem;
  letter-spacing:4px;
  margin-bottom:20px;
  color:#00f6ff;
  text-shadow:0 0 20px rgba(0,246,255,0.6);
}

.loading-sub{
  margin-top:15px;
  color:rgba(255,255,255,0.7);
  font-size:1rem;
}

#loadingPong{
  border:2px solid rgba(0,255,255,0.3);
  border-radius:12px;
  background:#000;
  box-shadow:0 0 30px rgba(0,255,255,0.2);
}

.fade-out{
  opacity:0;
  pointer-events:none;
}

#mainContent{
  opacity:0;
  transition:opacity 1s ease;
}

#mainContent.visible{
  opacity:1;
}

.auth-shell{
  height: 100vh;
  width: 100vw;
  display:grid;
  place-items:center;
  padding: 16px;
}

.auth-card{
  width: min(680px, 96vw);
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 28px;
  backdrop-filter: blur(12px);
  position: relative;
  overflow:hidden;
}

.auth-card::after{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  border-radius: calc(var(--radius) + 2px);
  background: linear-gradient(120deg, rgba(0,246,255,0.14), rgba(255,79,216,0.10), rgba(255,230,109,0.06));
  filter: blur(16px);
  opacity: 0.45;
}

.auth-brand{
  position:relative;
  z-index:1;
  display:flex;
  gap: 12px;
  align-items:center;
  padding-bottom: 16px;
  margin-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}

.auth-logo{
  width: 54px;
  height: 54px;
  object-fit: contain;
  border-radius: 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  padding: 8px;
  filter: drop-shadow(0 0 16px rgba(0,246,255,0.18));
}

.auth-brandtitle{
  font-weight: 1000;
  font-size: 1.2rem;
  letter-spacing: 1.6px;
}

.auth-brandsub{
  color: var(--muted);
  font-size: 0.92rem;
  margin-top: 2px;
}

.auth-title{
  position:relative;
  z-index:1;
  margin: 0 0 6px;
  font-size: 1.7rem;
  font-weight: 950;
}

.auth-subtitle{
  position:relative;
  z-index:1;
  margin: 0 0 18px;
  color: var(--muted);
  line-height: 1.5;
}

.auth-form{ position:relative; z-index:1; }

.auth-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

@media (max-width: 700px){
  .auth-grid{ grid-template-columns: 1fr; }
}

.field{
  margin-bottom: 14px;
}

.field label{
  display:block;
  font-weight: 800;
  font-size: 0.92rem;
  margin-bottom: 8px;
  color: rgba(233,238,247,0.92);
}

.field input{
  width: 100%;
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.32);
  color: var(--text);
  font-size: 1rem;
  font-family: inherit;
  transition: all 180ms ease;
}

.field input:focus{
  outline:none;
  border-color: rgba(0,246,255,0.35);
  background: rgba(0,0,0,0.42);
  box-shadow: 0 0 0 3px rgba(0,246,255,0.10);
}

.hint{
  font-size: 0.84rem;
  color: var(--muted);
  margin-top: 6px;
}

.auth-btn{
  width: 100%;
  padding: 16px;
  border-radius: 12px;
  border: 1px solid rgba(0,246,255,0.28);
  background: rgba(0,246,255,0.10);
  color: rgba(0,246,255,0.98);
  font-size: 1.05rem;
  font-weight: 950;
  font-family: inherit;
  cursor: pointer;
  transition: all 180ms ease;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  box-shadow: 0 0 0 1px rgba(0,246,255,0.10), 0 18px 50px rgba(0,246,255,0.07);
}

.auth-btn:hover{
  background: rgba(0,246,255,0.15);
  border-color: rgba(0,246,255,0.40);
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px rgba(0,246,255,0.15), 0 22px 60px rgba(0,246,255,0.12);
}

.auth-btn:disabled{
  opacity: 0.6;
  cursor: not-allowed;
  transform:none;
}

.auth-footer{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.10);
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--muted);
}

.auth-link{
  color: rgba(0,246,255,0.95);
  text-decoration:none;
  font-weight: 700;
}

.auth-link:hover{ opacity: 0.85; }

.auth-link.subtle{
  color: rgba(233,238,247,0.70);
  font-weight: 600;
}

.auth-divider{
  color: rgba(233,238,247,0.35);
}

.auth-alert{
  display:none;
  padding: 14px;
  border-radius: 12px;
  margin: 0 0 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.25);
}

.auth-alert.show{ display:block; animation: authSlide 0.35s ease; }

.auth-alert.success{
  border-color: rgba(0,246,255,0.28);
  background: rgba(0,246,255,0.10);
}

.auth-alert.error{
  border-color: rgba(255,79,216,0.28);
  background: rgba(255,79,216,0.10);
}

@keyframes authSlide{
  from{ opacity:0; transform: translateY(-8px); }
  to{ opacity:1; transform: translateY(0); }
}

.sidebar,
.panel,
.lb-row,
.log-item{
  isolation: isolate;
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
  background-clip: padding-box;
}

.panel{
  position: relative;
  overflow: hidden;


  background: rgba(10, 12, 18, 0.72);

  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

.panel::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;

  background: linear-gradient(
    90deg,
    rgba(0,0,0,0.30) 0%,
    rgba(0,0,0,0.10) 18%,
    rgba(0,0,0,0.00) 45%
  );
  opacity: 0.9;
}

.lb-row,
.log-item{
  position: relative;
  overflow: hidden;
  background: rgba(0,0,0,0.32);
}

.matchlog{
  scrollbar-color: rgba(255,255,255,0.25) transparent;
}
.matchlog::-webkit-scrollbar{ width: 8px; }
.matchlog::-webkit-scrollbar-track{ background: transparent; }
.matchlog::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,0.18);
  border-radius: 999px;
}

.brand-logo{
  width: 56px;
  height: 56px;

  padding: 0 !important;

  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);

  object-fit: cover; 
  background: transparent !important;

  display: block;
}

.follow-btn{
  display:flex;
  align-items:center;
  gap:12px;

  padding:12px;
  border-radius:14px;

  background: linear-gradient(
      145deg,
      rgba(255,255,255,0.05),
      rgba(255,255,255,0.02)
  );

  border:1px solid rgba(255,255,255,0.08);
  text-decoration:none;
  color:var(--text);

  transition: all 0.22s ease;
  position:relative;
  overflow:hidden;
}

.follow-btn:hover{
  transform: translateY(-2px);
  border-color: rgba(0,246,255,0.30);

  box-shadow:
      0 8px 24px rgba(0,246,255,0.12),
      inset 0 0 16px rgba(0,246,255,0.06);
}


.follow-btn::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
      120deg,
      transparent 20%,
      rgba(0,246,255,0.15),
      transparent 80%
  );
  opacity:0;
  transition: opacity 0.3s ease;
}

.follow-btn:hover::after{
  opacity:1;
}


.follow-icon{
  width:28px;
  height:28px;
  object-fit:contain;
  filter: drop-shadow(0 0 6px rgba(255,255,255,0.35));
}


.follow-title{
  font-weight:800;
  font-size:0.95rem;
}

.follow-sub{
  font-size:0.8rem;
  color:var(--muted);
}

.thought-filter{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin: 10px 0 12px;
}

.tf-btn{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.26);
  color: rgba(233,238,247,0.86);
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.86rem;
  cursor: pointer;
  transition: transform 140ms ease, background 140ms ease, border 140ms ease, opacity 140ms ease;
}

.tf-btn:hover{
  transform: translateY(-1px);
  border-color: rgba(0,246,255,0.22);
}

.tf-btn.active{
  border-color: rgba(0,246,255,0.28);
  background: rgba(0,246,255,0.10);
  color: rgba(0,246,255,0.95);
  box-shadow: 0 0 0 1px rgba(0,246,255,0.10), 0 12px 30px rgba(0,246,255,0.06);
}

.thoughts{
  max-height: 460px;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap: 8px;
  padding-right: 6px;
}

.thought{
  background: rgba(0,0,0,0.30);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 14px;
  padding: 10px 10px;
}

.thought-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 6px;
}

.thought-who{
  font-weight: 900;
  color: rgba(233,238,247,0.92);
  font-size: 0.95rem;
}

.thought-msg{
  color: rgba(233,238,247,0.84);
  font-size: 0.92rem;
  line-height: 1.25;
}

.thought-tag{
  display:inline-block;
  margin-right: 8px;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 900;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
  color: rgba(233,238,247,0.78);
}

.thoughts{
  scrollbar-gutter: stable;
  scrollbar-width: thin;  
  scrollbar-color: rgba(0,246,255,0.28) rgba(6,10,22,0.45); 
}

.thoughts::-webkit-scrollbar{
  width: 10px;
}

.thoughts::-webkit-scrollbar-track{
  background: linear-gradient(
    180deg,
    rgba(6,10,22,0.65),
    rgba(6,10,22,0.35)
  );
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: inset 0 0 0 1px rgba(0,246,255,0.04);
}

.thoughts::-webkit-scrollbar-thumb{
  border-radius: 999px;

  background: linear-gradient(
    180deg,
    rgba(0,246,255,0.30),
    rgba(120,80,255,0.22)
  );

  border: 2px solid rgba(6,10,22,0.75);
  box-shadow:
    0 0 14px rgba(0,246,255,0.12),
    inset 0 0 8px rgba(255,255,255,0.08);
}

.thoughts::-webkit-scrollbar-thumb:hover{
  background: linear-gradient(
    180deg,
    rgba(0,246,255,0.42),
    rgba(255,79,216,0.24)
  );
  box-shadow:
    0 0 18px rgba(0,246,255,0.18),
    inset 0 0 10px rgba(255,255,255,0.10);
}

.thoughts::-webkit-scrollbar-corner{
  background: transparent;
}


.thoughts{
  background: linear-gradient(
    180deg,
    rgba(6,10,22,0.22),
    rgba(0,0,0,0.00)
  );
  border-radius: 14px;
  padding-right: 8px;
}

.thoughts{
  -webkit-mask-image: linear-gradient(to bottom,
    transparent 0%,
    black 7%,
    black 93%,
    transparent 100%
  );
  mask-image: linear-gradient(to bottom,
    transparent 0%,
    black 7%,
    black 93%,
    transparent 100%
  );
}


@media (max-width: 980px){

  html, body{
    height: auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  body{
    overflow-x:hidden;
    padding:10px;
  }

  .layout{
    display:block !important;
    height:auto !important;
  }

  .mnav-btn{
    position: fixed;
    top: 12px;
    left: 12px;
    z-index: 9999;

    width: 44px;
    height: 44px;
    border-radius: 14px;

    background: rgba(0,0,0,0.45);
    border: 1px solid rgba(255,255,255,0.10);
    backdrop-filter: blur(10px);

    display: grid;
    place-items: center;
    gap: 4px;
    padding: 10px;
    cursor: pointer;

    box-shadow: 0 10px 30px rgba(0,0,0,0.45);
  }

  .mnav-btn span{
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: rgba(233,238,247,0.92);
    box-shadow: 0 0 10px rgba(0,246,255,0.15);
    display:block;
  }

  .mnav-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    z-index: 9997;
    opacity: 0;
    pointer-events: none;
    transition: opacity 200ms ease;
  }

  .mnav-backdrop.open{
    opacity: 1;
    pointer-events: auto;
  }

  .leftbar{
    position: fixed !important;
    top: 0;
    left: 0;
    height: 100vh;
    width: min(86vw, 360px);
    z-index: 9998;

    transform: translateX(-110%);
    transition: transform 240ms cubic-bezier(.2,.9,.2,1);

    border-radius: 0 18px 18px 0;
    box-shadow: 0 30px 80px rgba(0,0,0,0.65);

    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .leftbar.open{
    transform: translateX(0);
  }

  .brand-logo{
    width:56px !important;
    height:56px !important;
    object-fit: cover !important;
    border-radius: 16px;
  }

  .navblock{
    display:block !important;
  }

  .navtitle{
    display:block !important;
  }

  #mainContent{
    height:auto !important;
    min-height:auto !important;
  }

  .games{
    width:100% !important;
    margin-top: 58px;
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
  }

  .row{
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
    flex-wrap:nowrap !important;
  }

  .tablecard,
  .tablecard.wide{
    width:100% !important;
    max-width:100% !important;
  }

  canvas{
    width:100% !important;
    height:auto !important;
    display:block;
  }

  .tablehead{
    font-size:0.92rem;
    padding:10px 10px;
  }

  .tablefoot{
    font-size:0.82rem;
    padding:10px 10px;
  }

  .sidebar{
    width:100% !important;
    margin-top:12px;
    display:block !important;
  }

  .sidebar .panel:first-child{
    display:none !important;
  }

  .panel{
    padding:12px;
  }

  .panel-title{
    font-size:0.95rem;
  }

  #thoughts{
    max-height: 320px;
    overflow:auto !important;
    -webkit-overflow-scrolling: touch;
    padding-right:6px;
    border-radius: 14px;
  }

  .thought{
    padding:10px;
    font-size:0.84rem;
  }

  .thought-msg{
    font-size:0.84rem;
    line-height:1.35;
  }

  .thought-top{
    font-size:0.72rem;
  }

  .thought-filter{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
  }

  .tf-btn{
    padding:6px 10px;
    font-size:0.72rem;
  }

  #thoughts::-webkit-scrollbar{
    width:6px;
  }
  #thoughts::-webkit-scrollbar-thumb{
    background:rgba(0,180,255,0.45);
    border-radius:999px;
  }
}


@media (max-width: 520px){

  body{ padding: 8px; }

  .mnav-btn{
    top: 10px;
    left: 10px;
  }

  .tablehead{
    font-size:0.84rem;
  }

  .tablefoot{
    font-size:0.76rem;
  }

  #thoughts{
    max-height: 280px;
  }

  .panel-title{
    font-size:0.88rem;
  }

  .auth-card{
    padding:18px;
  }

  .auth-title{
    font-size:1.3rem;
  }
}


@media (hover:none){
  .navitem:hover{ transform:none; }
  .auth-btn:hover{ transform:none; }
  .tf-btn:hover{ transform:none; }
}

.mnav-btn,
.mnav-backdrop{
  display: none;
}

@media (max-width: 980px){
  .mnav-btn{
    display: grid;
  }
  .mnav-backdrop{
    display: block;
  }
}