.shell {
  display: grid;
  grid-template-columns: var(--sidebar-w, 264px) 1fr;
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--s4, 16px);
  padding: var(--s5, 20px) var(--s4, 16px);
  background: var(--glass, rgba(16, 19, 28, 0.78));
  backdrop-filter: var(--blur, blur(20px));
  -webkit-backdrop-filter: var(--blur, blur(20px));
  border-right: 1px solid var(--line, #2f3a55);
}

.side-club {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.side-club-meta {
  min-width: 0;
}

.side-club-name {
  color: var(--text, #e8ecf4);
  font: 600 15px var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.side-club-sub {
  margin-top: 3px;
  color: var(--text-3, var(--dim, #8e9bb5));
  font: 500 var(--fs-cap, 11px) var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cta {
  width: 100%;
  background: var(--gold, var(--accent, #ffd34d));
  color: #1a1408;
  border: none;
  border-radius: var(--r-pill, 999px);
  font: 600 var(--fs-sm, 13px) var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
  padding: 11px 16px;
  cursor: pointer;
  transition: transform .18s ease, filter .18s ease, opacity .18s ease;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28), 0 10px 24px rgba(0, 0, 0, 0.18);
}

.cta:hover:not(:disabled) {
  filter: brightness(1.04);
  transform: translateY(-1px);
}

.cta:disabled {
  opacity: .45;
  cursor: default;
}

.side-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.side-nav button {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  height: 40px;
  padding: 0 12px;
  border: none;
  border-radius: var(--r-sm, 10px);
  background: transparent;
  color: var(--text-2, var(--dim, #8e9bb5));
  font: 500 var(--fs-sm, 13px) var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
  text-align: left;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}

.side-nav button svg,
.logout-btn svg,
#icoCoin svg {
  flex-shrink: 0;
}

.side-nav button:hover {
  background: var(--surface, rgba(255, 255, 255, 0.06));
  color: var(--text, #e8ecf4);
}

.side-nav button.active {
  background: var(--surface-2, rgba(255, 255, 255, 0.1));
  color: var(--text, #e8ecf4);
  font-weight: 600;
}

.side-nav button.active svg {
  color: var(--gold, var(--accent, #ffd34d));
}

.side-foot {
  margin-top: auto;
  padding-top: var(--s4, 16px);
  border-top: 1px solid var(--line, #2f3a55);
  display: flex;
  flex-direction: column;
  gap: var(--s3, 12px);
}

.side-fin {
  display: flex;
  flex-direction: column;
  gap: 10px;
  cursor: pointer;
  border-radius: 8px;
  padding: 8px;
  margin: -8px;
  transition: background 0.15s ease;
}

.side-fin:hover {
  background: var(--surface, rgba(255, 255, 255, 0.06));
}

.stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.stat-label {
  color: var(--text-3, var(--dim, #8e9bb5));
  font: 500 var(--fs-cap, 11px) var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.stat-value {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text, #e8ecf4);
  font: 500 var(--fs-sm, 13px) var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
  font-variant-numeric: tabular-nums;
}

.stat-value b {
  color: inherit;
  font-weight: 600;
}

.logout-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 38px;
  padding: 0 12px;
  border: none;
  border-radius: var(--r-sm, 10px);
  background: transparent;
  color: var(--text-3, var(--dim, #8e9bb5));
  font: 500 var(--fs-sm, 13px) var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
  text-align: left;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}

.logout-btn:hover {
  background: var(--surface, rgba(255, 255, 255, 0.06));
  color: var(--text, #e8ecf4);
}

main#page {
  padding: var(--s6, 24px) var(--s6, 24px) 80px;
  max-width: 1180px;
  margin: 0 auto;
  width: 100%;
  min-width: 0;
}

/* Top bar + drawer scrim are mobile-only; hidden by default on wide screens. */
.topbar,
.nav-scrim {
  display: none;
}

/* Tablet: collapse the sidebar to an icon rail. Floored at 761px so phones
   (handled by the drawer block below) keep the full-label sidebar. */
@media (min-width: 761px) and (max-width: 1100px) {
  .shell {
    grid-template-columns: var(--sidebar-w-rail, 76px) 1fr;
  }

  .sidebar {
    align-items: center;
    padding-inline: var(--s2, 8px);
  }

  .side-club-meta,
  .stat-label,
  .logout-btn span,
  .side-nav button span {
    display: none;
  }

  .side-club,
  .side-nav,
  .side-foot {
    width: 100%;
  }

  .side-club {
    justify-content: center;
  }

  .cta {
    min-height: 52px;
    padding: 8px 6px;
    font-size: 10px;
    line-height: 1.15;
    text-align: center;
    overflow-wrap: anywhere;
  }

  .side-nav button,
  .logout-btn {
    justify-content: center;
    padding-inline: 0;
  }

  .side-fin {
    align-items: center;
  }
}

/* Phone: a fixed top bar with a hamburger, and the sidebar becomes a proper
   off-canvas drawer that slides in over a dimming scrim. The drawer reuses the
   full-label sidebar (nav, finances, play CTA, logout) so nothing is hidden. */
@media (max-width: 760px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .topbar {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 70;
    align-items: center;
    gap: var(--s3, 12px);
    height: 56px;
    padding: 0 var(--s3, 12px);
    background: var(--glass, rgba(16, 19, 28, 0.78));
    backdrop-filter: var(--blur, blur(20px));
    -webkit-backdrop-filter: var(--blur, blur(20px));
    border-bottom: 1px solid var(--line, #2f3a55);
  }

  .topbar-burger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    flex: 0 0 auto;
    border: 1px solid var(--line, #2f3a55);
    border-radius: var(--r-sm, 10px);
    background: var(--surface, rgba(255, 255, 255, 0.06));
    color: var(--text, #e8ecf4);
    cursor: pointer;
  }

  .topbar-title {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
  }

  .topbar-name {
    color: var(--text, #e8ecf4);
    font: 600 15px var(--font, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif);
    letter-spacing: -0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 80;
    width: min(82vw, 320px);
    height: 100vh;
    align-items: stretch;
    padding: var(--s5, 20px) var(--s4, 16px);
    transform: translateX(-100%);
    transition: transform 0.26s ease;
  }

  .shell.nav-open .sidebar {
    transform: translateX(0);
    box-shadow: var(--shadow-2);
  }

  .nav-scrim {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 75;
    background: rgba(0, 0, 0, 0.55);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.26s ease;
  }

  .shell.nav-open .nav-scrim {
    opacity: 1;
    pointer-events: auto;
  }

  main#page {
    padding-top: calc(56px + var(--s4, 16px));
  }
}
