:root {
  --app-bg-0: #070a12;
  --app-bg-1: #0b1630;
  --app-glass: rgba(255, 255, 255, 0.08);
  --app-glass-strong: rgba(255, 255, 255, 0.12);
  --app-border: rgba(255, 255, 255, 0.16);
}

/* ---------------------------------------------------------------------------
   Viewport-responsive layout (works with <meta name="viewport" …> in HTML)
   Fluid type, no horizontal spill, media + range sliders scale with width.
   --------------------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  font-size: clamp(14px, 0.65rem + 0.45vw, 17px);
  /* Keeps layout width stable when MDB/Bootstrap toggles body overflow (modal/picker open) */
  scrollbar-gutter: stable;
}

body {
  margin: 0;
  overflow-x: clip;
  scrollbar-gutter: stable;
}

img,
svg,
video,
canvas {
  max-width: 100%;
  height: auto;
}

.app-main {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.app-main .row {
  min-width: 0;
}

.app-admin-pie-panel {
  position: sticky;
  top: 86px;
  /* Give charts more vertical room; still sticky within viewport */
  height: calc(100vh - 80px);
  height: calc(100dvh - 80px);
  min-height: 420px;
  overflow: hidden;
}

.app-admin-charts-stack{
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.app-admin-pie-panel .card-body {
  height: 100%;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
}

/* Admin: custom days-range dropdown (same as Live rounds) */
.app-admin-days-dd{position:relative;display:inline-flex;align-items:center}
.app-admin-days-btn{
  background: rgba(20, 24, 38, 0.72) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.25);
  color:#fff !important;
  min-width:72px;
  text-align:center;
  justify-content:center;
  padding-left:14px;
  padding-right:30px; /* caret space */
  position:relative;
  font-weight:700;
  letter-spacing:.02em;
  border-radius:.5rem;
}
.app-admin-days-btn::after{
  content:"";
  position:absolute;
  right:12px;
  top:50%;
  width:7px;height:7px;
  border-right:2px solid rgba(226,232,240,.75);
  border-bottom:2px solid rgba(226,232,240,.75);
  transform:translateY(-60%) rotate(45deg);
  opacity:.9;
}
.app-admin-days-btn:focus{
  border-color: rgba(96, 165, 250, 0.45) !important;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), 0 14px 40px rgba(0, 0, 0, 0.25);
}
.app-admin-days-menu{
  position:absolute;
  top:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  min-width: 84px;
  max-height: 260px;
  overflow:auto;
  z-index: 3205;
  background: rgba(20, 24, 38, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 22px 55px rgba(0,0,0,.58);
  border-radius: 14px;
  padding: 6px;
  display:none;
}
.app-admin-days-menu.is-open{display:block}
.app-admin-days-opt{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  padding:8px 10px;
  border-radius:10px;
  border:0;
  background:transparent;
  color:rgba(255,255,255,.9);
  text-align:center;
}
.app-admin-days-opt:hover,.app-admin-days-opt:focus{background:rgba(255,255,255,.08);color:#fff;outline:none}
.app-admin-days-opt.is-active{background:rgba(99,102,241,.18)}

.app-admin-pie-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  min-height: 0;
}
.app-admin-pie-cell{
  min-width: 0;
  display: grid;
  grid-template-rows: var(--app-admin-pie-meta-h, 84px) 1fr;
  row-gap: 10px;
}

.app-admin-pie-meta{
  /* Keep both charts aligned even if copy wraps differently per language */
  height: var(--app-admin-pie-meta-h, 84px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.app-admin-pie-meta.text-center{
  align-items: center;
}

.app-admin-pie-meta .text-white-50.small{
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Admin tournaments page: prevent left column from shrinking on browser zoom.
   When space is tight, wrap to two rows instead of squeezing the left cards. */
body[data-tournaments-admin="1"] .app-admin-tournaments-wrap,
body[data-tournaments-admin="1"] .app-admin-pie-wrap {
  min-width: min(560px, 100%);
}

.app-admin-pie-canvas-wrap {
  position: relative;
  width: 100%;
  height: 50%;
  min-height: 160px;
  max-height: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.10), 0 18px 50px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.app-admin-pie-canvas-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(700px 360px at 15% 15%, rgba(147, 197, 253, 0.10), transparent 60%),
    radial-gradient(620px 360px at 85% 10%, rgba(196, 181, 253, 0.08), transparent 60%),
    radial-gradient(620px 360px at 70% 95%, rgba(45, 212, 191, 0.07), transparent 65%);
  opacity: 0.95;
}

.app-admin-pie-canvas-wrap canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
  min-height: 160px;
  max-height: 100%;
  position: relative;
  z-index: 1;
}

.app-admin-pie-grid .app-admin-pie-canvas-wrap{
  height: 360px;
  max-height: none;
}
.app-admin-pie-grid .app-admin-pie-canvas-wrap canvas{
  width: 320px !important;
  height: 320px !important;
  min-height: 320px;
  max-height: 320px;
}

.app-admin-bars-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.app-admin-bar-cell{
  min-width: 0;
  display: grid;
  grid-template-rows: var(--app-admin-bar-meta-h, 64px) 1fr;
  row-gap: 10px;
}
.app-admin-bar-meta{
  height: var(--app-admin-bar-meta-h, 64px);
  overflow: hidden;
}

.app-admin-bar-meta.text-center{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}
.app-admin-bar-meta .text-white-50.small{
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.app-admin-bar-canvas-wrap{
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.10), 0 18px 50px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
}
.app-admin-bar-canvas-wrap canvas{
  width: 100% !important;
  height: 100% !important;
}

/* ---------------------------------------------------------------------------
   Live-style compact dropdown (round selector) — reused in Admin model points
   --------------------------------------------------------------------------- */
.app-live-round-dd{position:relative}
.app-live-round-btn{
  background: rgba(20, 24, 38, 0.72) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.25);
  color:#fff !important;
  min-width:56px;
  text-align:center;
  justify-content:center;
  padding-left:12px;
  padding-right:26px; /* caret space */
  position:relative;
  border-radius: 14px;
}
.app-live-round-btn::after{
  content:"";
  position:absolute;
  right:10px;
  top:50%;
  width:7px;height:7px;
  border-right:2px solid rgba(226,232,240,.75);
  border-bottom:2px solid rgba(226,232,240,.75);
  transform:translateY(-60%) rotate(45deg);
  opacity:.9;
}
.app-live-round-btn:focus{
  border-color: rgba(96, 165, 250, 0.45) !important;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), 0 14px 40px rgba(0, 0, 0, 0.25);
}
.app-live-round-menu{
  position:absolute;
  top:calc(100% + 8px);
  left:50%;
  right:auto;
  transform:translateX(-50%);
  min-width: 84px;
  max-height: 260px;
  overflow:auto;
  z-index: 8505;
  background: rgba(20, 24, 38, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 22px 55px rgba(0,0,0,.58);
  border-radius: 14px;
  padding: 6px;
  display:none;
}
.app-live-round-menu.is-open{display:block}
.app-live-round-opt{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  padding:8px 10px;
  border-radius:10px;
  border:0;
  background:transparent;
  color:rgba(255,255,255,.9);
  text-align:center;
}
.app-live-round-opt:hover,
.app-live-round-opt:focus{
  background:rgba(255,255,255,.08);
  color:#fff;
  outline:none;
}
.app-live-round-opt.is-active{background:rgba(99,102,241,.18)}

@media (max-width: 991px){
  .app-admin-pie-grid{ grid-template-columns: 1fr; }
  .app-admin-bars-grid{ grid-template-columns: 1fr; }
  .app-admin-pie-canvas-wrap{ max-height: none; height: auto; }
  .app-admin-pie-canvas-wrap canvas{ height: 320px !important; }
}

input[type="range"].form-range {
  width: 100%;
  max-width: 100%;
  min-height: 2rem;
}

/* Create tournament: white players slider */
#createPlayersRange.form-range{
  accent-color: rgba(255,255,255,0.95);
}
#createPlayersRange.form-range::-webkit-slider-runnable-track{
  background: rgba(255,255,255,0.22);
  height: 0.35rem;
  border-radius: 999px;
}
#createPlayersRange.form-range::-webkit-slider-thumb{
  background: #ffffff;
  border: 1px solid rgba(255,255,255,0.4);
  box-shadow: 0 1px 5px rgba(0,0,0,0.25);
}
#createPlayersRange.form-range::-moz-range-track{
  background: rgba(255,255,255,0.22);
  height: 0.35rem;
  border-radius: 999px;
}
#createPlayersRange.form-range::-moz-range-thumb{
  background: #ffffff;
  border: 1px solid rgba(255,255,255,0.4);
  box-shadow: 0 1px 5px rgba(0,0,0,0.25);
}

.app-bg {
  min-height: 100vh;
  min-height: 100dvh;
  background:
    radial-gradient(900px 520px at 20% 10%, rgba(45, 212, 191, 0.25), transparent 58%),
    radial-gradient(840px 520px at 85% 0%, rgba(59, 130, 246, 0.25), transparent 60%),
    radial-gradient(840px 520px at 70% 90%, rgba(168, 85, 247, 0.18), transparent 55%),
    linear-gradient(180deg, var(--app-bg-1), var(--app-bg-0));
  color: #fff;
}

.app-page {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

.app-main {
  flex: 1 0 auto;
  display: flex;
}

.app-footer {
  flex-shrink: 0;
}

.app-footer-links,
.app-footer-copy {
  text-align: center;
}

.app-footer-links {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem 0.6rem;
  font-size: 12px;
  color: rgba(231, 238, 252, 0.65);
}

.app-footer-sep {
  opacity: 0.45;
}

.app-footer-link {
  color: rgba(231, 238, 252, 0.65);
  text-decoration: none;
}

.app-footer-link:hover,
.app-footer-link:focus {
  color: rgba(231, 238, 252, 0.92);
  text-decoration: underline;
}

.app-footer-copy {
  margin-top: 6px;
  font-size: 12px;
  color: rgba(231, 238, 252, 0.55);
}

/* Working club switcher (top bar, combobox-style) */
/* Lower than language/user so their dropdowns are not covered (see .app-lang-dd / .app-user-dd). */
.app-club-switcher {
  max-width: min(260px, 38vw);
  position: relative;
  z-index: 20;
}

.app-club-switcher .dropdown-menu.app-club-switcher__menu {
  z-index: 25 !important;
  background: rgba(15, 23, 42, 0.97) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.58) !important;
  /* Wider than the toggle: anchor to the right so the panel grows leftward (no horizontal overflow). */
  position: absolute !important;
  top: calc(100% + 6px) !important;
  right: 0 !important;
  left: auto !important;
  transform: none !important;
  margin-top: 0 !important;
  min-width: min(280px, calc(100vw - 24px)) !important;
  max-width: min(420px, calc(100vw - 24px)) !important;
  width: min(420px, calc(100vw - 24px)) !important;
  overflow-x: hidden;
}

.app-club-switcher__item--all {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
  margin-bottom: 2px;
}

.app-club-switcher__btn {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(248, 250, 252, 0.95);
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  max-width: 100%;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.app-club-switcher__btn:hover,
.app-club-switcher__btn:focus-visible {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.22);
  color: #fff;
}

.app-club-switcher__btn--static {
  cursor: default;
  pointer-events: none;
}

.app-club-switcher__current {
  max-width: 160px;
}

/* PadelStream hex + pala + PS (padelstream-club-icon.svg) */

/* Live: "New pairing" button should remain clickable for info popups,
   but look disabled when action is not allowed. */
#liveResultsNewPairBtn.is-disabled{
  opacity: 0.55;
  filter: saturate(0.25);
  cursor: not-allowed;
  pointer-events: auto;
}
#liveResultsNewPairBtn.is-disabled:hover{
  opacity: 0.55;
}
.app-club-switcher__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  opacity: 0.98;
}

.app-club-switcher__mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.35));
}

.app-club-switcher__menu {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  overflow: hidden;
}

/* Admin page: club filter uses header club-switcher look (manual open/close) */
.app-admin-club-menu{display:none}
.app-admin-club-menu.show{display:block}

/* Admin tournaments page: ensure club filter dropdown stays above right glass charts */
#adminClubDropdown{
  position: relative;
  z-index: 4500;
}
#adminClubMenu.dropdown-menu.app-club-switcher__menu{
  z-index: 9000 !important;
}

/* Admin tournaments page: guarantee left filters stack above right sticky glass */
body[data-tournaments-admin="1"] .app-admin-tournaments-wrap{
  position: relative;
  z-index: 5000;
}
body[data-tournaments-admin="1"] .app-admin-pie-wrap{
  position: relative;
  z-index: 10;
}
body[data-tournaments-admin="1"] .app-admin-pie-panel{
  z-index: 10;
}

/* When the admin club menu is portaled to <body>, it must keep header club-switcher styling. */
.dropdown-menu.app-club-switcher__menu.app-admin-club-ported{
  background: rgba(15, 23, 42, 0.97) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.58) !important;
  overflow-x: hidden;
  border-radius: 14px;
}

.app-club-switcher__item {
  border: 0;
  width: 100%;
  text-align: left;
  color: rgba(248, 250, 252, 0.95) !important;
  background: transparent;
}

.app-club-switcher__item:hover,
.app-club-switcher__item:focus-visible {
  background: rgba(255, 255, 255, 0.08) !important;
}

.app-club-switcher__item.active {
  background: rgba(99, 102, 241, 0.18) !important;
}

.app-club-switcher .dropdown-toggle::after {
  display: none !important;
}

.app-glass {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.04)),
    var(--app-glass);
  border: 1px solid var(--app-border);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

/* Home: tournament models cards should look "glassier" and less opaque */
.app-home-model-card.app-glass{
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.04)),
    rgba(14, 18, 32, 0.38) !important;
  border-color: rgba(255, 255, 255, 0.14) !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.app-home-model-metric{
  text-align: center;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  position: relative;
  z-index: 1;
}
.app-home-model-metric > div{
  text-align: center;
}
.app-home-model-bar{
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.04)),
    rgba(14, 18, 32, 0.30);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  position: relative;
  z-index: 30;
}

#homeModelSelectDd{
  position: relative;
  z-index: 200;
}
.app-home-model-edit{
  line-height: 1;
  text-decoration: none !important;
}
.app-home-model-edit:hover{ color: rgba(255,255,255,0.95) !important; }
.app-home-model-edit:focus-visible{
  outline: 2px solid rgba(255,255,255,0.35);
  outline-offset: 3px;
  border-radius: 8px;
}

/* Home: upcoming tournaments inside "Create next" card */
.app-home-upcoming{
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.10);
}

.app-home-upcoming-list{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.app-home-upcoming-item{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.app-home-upcoming-meta{
  flex: 0 0 auto;
  white-space: nowrap;
}

/* Home: left drawer sizing for model editor */
#homeModelDrawer.app-drawer--left{
  width: min(520px, 46vw);
}
@media (max-width: 991px){
  #homeModelDrawer.app-drawer--left{
    width: min(520px, calc(100vw - 24px));
  }
}

/* Home model drawer: match other slides (full viewport band, inner fills) */
#homeModelDrawer.app-drawer--left{
  top: calc(env(safe-area-inset-top, 0px) + 64px);
  bottom: env(safe-area-inset-bottom, 0px);
  height: auto;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}
#homeModelDrawer.app-drawer--left .app-drawer__inner{
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
  max-height: none;
  display: flex;
  flex-direction: column;
}
#homeModelDrawer.app-drawer--left .app-drawer__body{
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* Admin model drawer: same viewport band rules as Home drawer (never exceeds screen) */
#adminModelDrawer.app-drawer--left{
  top: calc(env(safe-area-inset-top, 0px) + 64px);
  bottom: env(safe-area-inset-bottom, 0px);
  height: auto;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}
#adminModelDrawer.app-drawer--left .app-drawer__inner{
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
  max-height: none;
  display: flex;
  flex-direction: column;
}
#adminModelDrawer.app-drawer--left .app-drawer__body{
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* Home: tournament model selector dropdown should match club dropdown style */
#homeModelSelectDd .app-glass-dropdown__menu.app-home-model-menu{
  background: rgba(15, 23, 42, 0.97) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.58) !important;
  border-radius: 14px;
  overflow: hidden;
  min-width: min(280px, calc(100vw - 24px));
  max-width: min(420px, calc(100vw - 24px));
  width: min(420px, calc(100vw - 24px));
  /* Anchor to the right so it grows leftwards (avoid off-screen overflow) */
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  left: auto;
  transform: none;
  margin-top: 0;
  z-index: 10050;
}
#homeModelSelectDd .app-glass-dropdown__option{
  text-align: left;
  padding: 10px 12px;
  border-radius: 0;
}

/* Home: make the model dropdown toggle match menu options */
#homeModelSelectDd .app-glass-dropdown__toggle{
  background: rgba(15, 23, 42, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  min-height: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
#homeModelSelectDd .app-glass-dropdown__toggle:hover,
#homeModelSelectDd .app-glass-dropdown__toggle:focus-visible{
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
}

/* Home: make these dropdown toggles match menu options */
#homeClubOpenPlayersDd .app-glass-dropdown__toggle,
#homeClubTournamentActivationDd .app-glass-dropdown__toggle{
  background: rgba(15, 23, 42, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  min-height: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
#homeClubOpenPlayersDd .app-glass-dropdown__toggle:hover,
#homeClubOpenPlayersDd .app-glass-dropdown__toggle:focus-visible,
#homeClubTournamentActivationDd .app-glass-dropdown__toggle:hover,
#homeClubTournamentActivationDd .app-glass-dropdown__toggle:focus-visible{
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
}

/* Settings drawer: make native selects match glass dropdown toggles */
#appSettingsDrawer #pf_pref_lang,
#appSettingsDrawer #pf_iana_tz,
#appSettingsDrawer #pf_open_players_after_create,
#appSettingsDrawer #pf_tournament_activation_mode{
  background: rgba(15, 23, 42, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  min-height: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: rgba(248, 250, 252, 0.95) !important;
}
#appSettingsDrawer #pf_pref_lang:hover,
#appSettingsDrawer #pf_iana_tz:hover,
#appSettingsDrawer #pf_open_players_after_create:hover,
#appSettingsDrawer #pf_tournament_activation_mode:hover{
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
}
#appSettingsDrawer #pf_pref_lang:focus,
#appSettingsDrawer #pf_iana_tz:focus,
#appSettingsDrawer #pf_open_players_after_create:focus,
#appSettingsDrawer #pf_tournament_activation_mode:focus{
  outline: none;
  border-color: rgba(96, 165, 250, 0.55) !important;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

/* Settings drawer: make text inputs match glass dropdown toggles */
#appSettingsDrawer .app-settings-field:not(.app-settings-field--file),
#appSettingsDrawer #appNewEmail{
  background: rgba(15, 23, 42, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  min-height: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
#appSettingsDrawer .app-settings-field:not(.app-settings-field--file):hover,
#appSettingsDrawer #appNewEmail:hover{
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
}
#appSettingsDrawer .app-settings-field:not(.app-settings-field--file):focus,
#appSettingsDrawer #appNewEmail:focus{
  outline: none;
  border-color: rgba(96, 165, 250, 0.55) !important;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

/* Generic glass input (use outside settings/drawers) */
.app-glass-field{
  background: rgba(15, 23, 42, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  min-height: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: rgba(248, 250, 252, 0.95) !important;
}
.app-glass-field::placeholder{ color: rgba(248,250,252,0.55) !important; }
.app-glass-field:hover{
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
}
.app-glass-field:focus{
  outline: none;
  border-color: rgba(96, 165, 250, 0.55) !important;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

/* Past tournaments: make Apply Filters button match inputs */
.app-past-filter-btn{
  min-height: 44px;
  padding: 10px 14px;
  border-radius: 14px;
  font-weight: 600;
  position: relative;
  top: -2px;
}

/* Admin model drawer: align "only for club" row with labels */
#adminModelDrawer .app-admin-model-onlyrow{
  padding-left: 0 !important; /* neutralize Bootstrap .form-check left indent */
}

/* Admin model drawer: club dropdown should be narrower */
#adminModelDrawer #adminModelClubPickWrap .app-club-switcher{
  max-width: min(320px, 100%);
}
#adminModelDrawer #adminModelClubPickWrap .app-club-switcher__btn{
  width: 100%;
}
#adminModelDrawer #adminModelClubPickWrap .dropdown-menu.app-club-switcher__menu{
  min-width: 100% !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Admin: tournament model editor — center the scoring mini-labels above dropdowns */
#adminModelDrawer .app-admin-model-pts-label{
  text-align: center;
  width: 100%;
  line-height: 1.15;
  /* Match .app-live-round-btn padding so label centers exactly over the number
     (the caret is absolutely positioned, so padding creates the same visual centering). */
  padding-left: 12px;
  padding-right: 26px;
}

/* Glass-like fields across drawers (match Settings look) */
.app-drawer .form-control.bg-dark,
.app-drawer .form-select.bg-dark,
.app-drawer textarea.form-control.bg-dark{
  background: rgba(15, 23, 42, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  min-height: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: rgba(248, 250, 252, 0.95) !important;
}
.app-drawer .form-control.bg-dark:hover,
.app-drawer .form-select.bg-dark:hover,
.app-drawer textarea.form-control.bg-dark:hover{
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
}
.app-drawer .form-control.bg-dark:focus,
.app-drawer .form-select.bg-dark:focus,
.app-drawer textarea.form-control.bg-dark:focus{
  outline: none;
  border-color: rgba(96, 165, 250, 0.55) !important;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

/* Native <select> dropdown list is OS-controlled; avoid "white text on white list" on Windows.
   Hint dark widgets where supported. */
.app-drawer select.form-select{
  color-scheme: dark;
}

/* Custom glass dropdown (native <select> cannot style the OS dropdown list) */
.app-glass-dropdown {
  position: relative;
  min-width: 0;
}

.app-glass-dropdown__toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 38px;
  padding: 0.375rem 0.75rem;
  border-radius: 0.375rem;
  color: rgba(248, 250, 252, 0.95);
  cursor: pointer;
  text-align: left;
  font-size: 0.875rem;
  line-height: 1.5;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.05)),
    rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.app-glass-dropdown__toggle:hover {
  border-color: rgba(255, 255, 255, 0.22);
}

.app-glass-dropdown__toggle:focus-visible {
  outline: none;
  border-color: rgba(96, 165, 250, 0.55);
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

.app-glass-dropdown.is-open .app-glass-dropdown__toggle {
  border-color: rgba(96, 165, 250, 0.45);
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

.app-glass-dropdown__toggle .app-glass-dropdown__label {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.app-glass-dropdown__caret {
  flex: 0 0 auto;
  opacity: 0.85;
  font-size: 0.75rem;
  transition: transform 0.15s ease;
}

.app-glass-dropdown.is-open .app-glass-dropdown__caret {
  transform: rotate(180deg);
}

.app-glass-dropdown__menu {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 6px);
  z-index: 1080;
  padding: 6px;
  border-radius: 0.5rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.06)),
    rgba(15, 23, 42, 0.55);
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

/* Home: stronger dropdown menu opacity for readability */
#homeClubOpenPlayersDd .app-glass-dropdown__menu,
#homeClubTournamentActivationDd .app-glass-dropdown__menu{
  /* Match club dropdown style for consistency */
  background: rgba(15, 23, 42, 0.97) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.58) !important;
  border-radius: 14px;
  overflow: hidden;
  /* Anchor left (these dropdowns live on left column) */
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: auto;
  transform: none;
  margin-top: 0;
  min-width: min(280px, calc(100vw - 24px));
  max-width: min(420px, calc(100vw - 24px));
  width: min(420px, calc(100vw - 24px));
  padding: 6px;
}

.app-glass-dropdown__option {
  display: block;
  width: 100%;
  border: 0;
  border-radius: 0.375rem;
  padding: 0.5rem 0.65rem;
  margin: 0;
  text-align: left;
  font-size: 0.875rem;
  color: rgba(248, 250, 252, 0.95);
  background: transparent;
  cursor: pointer;
  transition: background 0.12s ease;
}

.app-glass-dropdown__option:hover,
.app-glass-dropdown__option:focus-visible {
  background: rgba(255, 255, 255, 0.10);
  outline: none;
}

.app-glass-dropdown__option.is-active {
  background: rgba(59, 130, 246, 0.18);
  border: 1px solid rgba(59, 130, 246, 0.35);
}

/* Settings: theme cards (dark/light) */
.app-theme-pickers{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
@media (max-width: 420px){
  .app-theme-pickers{ grid-template-columns: 1fr; }
}
.app-theme-card{
  width:100%;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  color: rgba(248,250,252,0.95);
  text-align:left;
  cursor:pointer;
  transition: background 120ms ease, border-color 120ms ease, transform 120ms ease;
}
.app-theme-card:hover{
  background: rgba(255,255,255,0.09);
  border-color: rgba(255,255,255,0.22);
}
.app-theme-card.is-active{
  border-color: rgba(96,165,250,0.45);
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.10);
}
.app-theme-card:active{ transform: scale(0.99); }
.app-theme-card__swatch{
  width:46px;
  height:34px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  flex: 0 0 auto;
}
.app-theme-card__swatch--dark{
  background: linear-gradient(180deg, rgba(2,6,23,0.95), rgba(15,23,42,0.85));
}
.app-theme-card__swatch--light{
  background: linear-gradient(180deg, rgba(248,250,252,0.98), rgba(226,232,240,0.92));
  border-color: rgba(15,23,42,0.10);
}
.app-theme-card__meta{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.app-theme-card__title{ font-weight:800; color:#fff; }
.app-theme-card__hint{
  font-size: 0.78rem;
  color: rgba(226,232,240,0.70);
}

.app-theme-card-wrap{
  position: relative;
  min-width: 0;
}
.app-theme-card-wrap--soon .app-theme-card[disabled]{
  cursor: not-allowed;
  opacity: 0.52;
  filter: saturate(0.9);
  pointer-events: none;
}
.app-theme-card-soon{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  border-radius: 14px;
}
.app-theme-card-soon__pill{
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(248,250,252,0.95);
  background: rgba(2,6,23,0.48);
  border: 1px solid rgba(255,255,255,0.2);
  box-shadow: 0 10px 32px rgba(0,0,0,0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Home: match Save button height to the glass trigger */
.app-home-trigger-save.btn {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
}

/* Badges with guaranteed contrast (avoid relying on bg-opacity utilities) */
.app-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  letter-spacing: 0.2px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  white-space: nowrap;
}

.app-badge--neutral {
  background: rgba(148, 163, 184, 0.14);
  border-color: rgba(148, 163, 184, 0.28);
  color: rgba(226, 232, 240, 0.92);
}

.app-badge--success {
  background: rgba(34, 197, 94, 0.18);
  border-color: rgba(34, 197, 94, 0.32);
  color: rgba(187, 247, 208, 0.98);
}

.app-badge--warning {
  background: rgba(245, 158, 11, 0.18);
  border-color: rgba(245, 158, 11, 0.32);
  color: rgba(253, 230, 138, 0.98);
}

.app-badge--danger {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.32);
  color: rgba(254, 202, 202, 0.98);
}

.app-badge--gender {
  padding: 6px 8px;
  gap: 0;
}

.app-badge--gender i {
  font-size: 0.95em;
}

.app-badge--activation {
  padding: 6px 8px;
  gap: 0;
}

.app-badge--activation i {
  font-size: 0.95em;
}

a.app-badge.app-badge--link {
  text-decoration: none;
  cursor: pointer;
  transition: filter 0.15s ease, transform 0.1s ease;
}

/* Same text color as non-link badges (link rule had higher specificity than .app-badge--* alone) */
a.app-badge.app-badge--link.app-badge--neutral {
  color: rgba(226, 232, 240, 0.92);
}

a.app-badge.app-badge--link.app-badge--success {
  color: rgba(187, 247, 208, 0.98);
}

a.app-badge.app-badge--link.app-badge--warning {
  color: rgba(253, 230, 138, 0.98);
}

a.app-badge.app-badge--link.app-badge--danger {
  color: rgba(254, 202, 202, 0.98);
}

a.app-badge.app-badge--link:hover {
  filter: brightness(1.12);
}

a.app-badge.app-badge--link:focus-visible {
  outline: 2px solid rgba(96, 165, 250, 0.65);
  outline-offset: 2px;
}

/* Tournament summary list */
.app-tournament-list {
  --app-tournament-row-h: 72px;
  --app-tournament-row-gap: 10px;
  display: flex;
  flex-direction: column;
  gap: var(--app-tournament-row-gap);
  /* Max 5 rows visible; scroll when more */
  max-height: calc((var(--app-tournament-row-h) * 5) + (var(--app-tournament-row-gap) * 4));
  overflow: auto;
  box-sizing: border-box;
  /* Keep content away from the vertical scrollbar (looks better on Win; avoids “stuck” UI).
     Use negative margin to avoid shrinking the rows vs other blocks (keeps columns aligned). */
  padding-right: 12px;
  margin-right: -12px;
  /* Reserve scrollbar width so row grids align across lists/cards (no layout jump when it appears). */
  scrollbar-gutter: stable;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.22) transparent;
}

.app-tournament-list--3{
  /* Max 3 rows visible; scroll when more */
  max-height: calc((var(--app-tournament-row-h) * 3) + (var(--app-tournament-row-gap) * 2));
}

.app-tournament-list--4{
  /* Max 4 rows visible; scroll when more */
  max-height: calc((var(--app-tournament-row-h) * 4) + (var(--app-tournament-row-gap) * 3));
}

.app-tournament-list--6{
  /* Max 6 rows visible; scroll when more */
  max-height: calc((var(--app-tournament-row-h) * 6) + (var(--app-tournament-row-gap) * 5));
}

/* Tournament list scrollbars (same style as matches/teams rail) */
.app-tournament-list::-webkit-scrollbar:vertical {
  width: 6px;
}
.app-tournament-list::-webkit-scrollbar:horizontal {
  height: 0;
}
.app-tournament-list::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.18);
  border-radius: 6px;
}
.app-tournament-list::-webkit-scrollbar-track {
  background: transparent;
}

.app-tournament-pad-right {
  padding-right: 14px;
}

/* Native date/time inputs (split field) — dark chrome + picker icon visible on glass UI */
.app-datetime-split input[type="date"],
.app-datetime-split input[type="time"] {
  color-scheme: dark;
}

.app-drawer .app-datetime-split input[type="date"]::-webkit-calendar-picker-indicator,
.app-drawer .app-datetime-split input[type="time"]::-webkit-calendar-picker-indicator {
  filter: invert(0.88);
  opacity: 0.9;
  cursor: pointer;
}

.app-drawer .app-datetime-split input[type="date"]:focus,
.app-drawer .app-datetime-split input[type="time"]:focus {
  border-color: rgba(96, 165, 250, 0.45) !important;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22);
}

/* Drawer (tournament editor) */
.app-drawer-overlay {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 64px);
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
  z-index: 7000;
}

.app-drawer-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}

.app-drawer {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 64px);
  right: 0;
  height: calc(100vh - (env(safe-area-inset-top, 0px) + 64px));
  height: calc(100dvh - (env(safe-area-inset-top, 0px) + 64px));
  width: min(520px, 92vw);
  transform: translateX(105%);
  transition: transform 220ms ease;
  z-index: 7100;
  padding: 14px;
}

/*
 * MDB date/time picker UI defaults to Bootstrap-like stacking (~1055).
 * Our glass drawers sit at 3100 and app modals at 3300, so pickers must sit above both.
 * Important: MDB uses .timepicker-modal (not .timepicker-modal-container) for the clock step —
 * without it, only the calendar had a high z-index and the time UI stayed behind the glass.
 */
.datepicker-backdrop,
.datepicker-modal-container,
.datepicker-dropdown-container,
body > [class*="datepicker-backdrop"],
body > [class*="datepicker-modal-container"],
body > [class*="datepicker-dropdown-container"],
.timepicker-backdrop,
.timepicker-modal-container,
.timepicker-modal,
.timepicker-container,
.datetimepicker-datepicker-modal,
.datetimepicker-timepicker-modal,
.datetimepicker-timepicker-container,
.datetimepicker-modal-container,
body > [class*="datetimepicker-timepicker"],
[class*="timepicker-"] {
  z-index: 8500 !important;
}

.app-drawer--wide {
  width: min(960px, 80vw);
}

/* Admin dual-drawers: keep default drawer height (accounts for header). */

.app-drawer--settings .app-drawer__inner {
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 28px);
}

.app-drawer__body--settings {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

.app-settings-avatar-preview {
  width: 72px;
  height: 72px;
  border-radius: 999px;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.2);
}

.app-settings-avatar-preview__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.app-settings-avatar-preview__ph {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-weight: 800;
  font-size: 1.25rem;
  letter-spacing: 0.04em;
}

.app-settings-club-list {
  color: rgba(255, 255, 255, 0.92);
}

.app-settings-club-row {
  min-width: 0;
}

.app-fav-club-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 30px;
  height: 30px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(20, 24, 38, 0.55);
  color: rgba(231, 238, 252, 0.75);
  box-shadow: 0 10px 28px rgba(0,0,0,0.22);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.app-fav-club-btn:hover{
  border-color: rgba(255,255,255,0.22);
  color: rgba(255,255,255,0.9);
}
.app-fav-club-btn.is-active{
  background: rgba(255, 215, 0, 0.14);
  border-color: rgba(255, 215, 0, 0.35);
  color: rgba(255, 215, 0, 0.95);
  box-shadow: 0 12px 34px rgba(255, 215, 0, 0.08), 0 10px 28px rgba(0,0,0,0.22);
}
.app-fav-club-btn:focus{
  outline: none;
  box-shadow: 0 0 0 0.12rem rgba(96, 165, 250, 0.22), 0 10px 28px rgba(0,0,0,0.22);
}

.app-busy-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.28);
  backdrop-filter: blur(6px) saturate(1.15);
  -webkit-backdrop-filter: blur(6px) saturate(1.15);
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease;
  z-index: 9500;
}
.app-busy-overlay.is-open{
  opacity: 1;
  pointer-events: auto;
}
.app-busy-modal{
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.98);
  min-width: min(520px, calc(100vw - 40px));
  max-width: min(520px, calc(100vw - 40px));
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  box-shadow: 0 18px 60px rgba(0,0,0,0.42);
  backdrop-filter: blur(16px) saturate(1.25);
  -webkit-backdrop-filter: blur(16px) saturate(1.25);
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
  z-index: 9501;
}
.app-busy-modal::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  background: radial-gradient(120% 140% at 15% 10%, rgba(255,255,255,0.16), transparent 55%),
              radial-gradient(110% 140% at 90% 0%, rgba(96,165,250,0.12), transparent 60%);
  pointer-events:none;
  opacity: 0.95;
}
.app-busy-modal > *{
  position: relative;
  z-index: 1;
}
.app-busy-modal.is-open{
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, -50%) scale(1);
}

.app-drawer--settings .app-settings-field {
  color: rgba(255, 255, 255, 0.96);
}
.app-drawer--settings .app-settings-field::placeholder {
  color: rgba(255, 255, 255, 0.42);
}
.app-drawer--settings .app-settings-field--readonly {
  color: rgba(255, 255, 255, 0.78);
  cursor: default;
}

.app-drawer--settings .app-settings-field--locked {
  color: rgba(255, 255, 255, 0.82);
  cursor: default;
}
.app-drawer--settings select.app-settings-field--locked {
  opacity: 0.75;
}
.app-drawer--settings .app-settings-field--file {
  color: rgba(255, 255, 255, 0.88);
}

/* Account settings: stacked glass dropdowns — later rows must not paint over an open menu above */
#appSettingsDrawer .app-club-switcher {
  position: relative;
  z-index: 2;
}
#appSettingsDrawer .app-club-switcher.is-settings-dd-open {
  z-index: 120;
}
#appSettingsDrawer .app-club-switcher__btn {
  max-width: 100%;
}
#appSettingsDrawer .app-club-switcher__current {
  max-width: min(280px, 72vw);
}

/* Custom user background behind cards (set via --app-user-card-bg on :root) */
.app-user-bg-on .app-tournament-item,
.app-user-bg-on .card.app-glass {
  background-image: linear-gradient(rgba(7, 10, 18, 0.82), rgba(7, 10, 18, 0.82)), var(--app-user-card-bg);
  background-size: cover;
  background-position: center;
}

/* Left teams rail (players drawer): compact list, internal scroll — never grows over the main drawer */
.app-drawer--left {
  left: 0;
  right: auto;
  transform: translateX(-105%);
  /* Inner content + padding + 2×200px cols + gap; min(480,48vw) fits two cols more often than 452 */
  width: min(480px, 48vw);
  z-index: 7085;
  /* Same outer inset as .app-drawer (14px) so dual panels align vertically */
  padding: 14px;
  box-sizing: border-box;
}

.app-drawer--left.is-open {
  transform: translateX(0);
}

/* Shrink-wrap list height when few teams; cap to viewport when many (body scrolls inside) */
.app-drawer--left .app-drawer__inner {
  height: auto;
  min-width: 0;
  min-height: 0;
  max-height: calc(100vh - 28px);
  max-height: calc(100dvh - 28px);
}

.app-drawer__head--rail {
  flex-shrink: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
}

/* Teams rail: Edit/Done flush right in head */
.app-teams-rail-head__pairtools {
  max-width: 100%;
}

/* Manual pair hint: directly under head border, above team cards */
#playersTeamsDrawer .app-teams-rail__pair-hint {
  min-width: 0;
  line-height: 1.35;
}
#playersTeamsDrawer .app-teams-rail__pair-hint:not(.d-none) {
  margin: 0 0 10px;
}

/* Manual pair drag mode (tournaments players rail): unpaired cards accept drops */
.app-drawer--teams.is-teams-pair-drag .app-team-card[data-team-kind="unpaired"] {
  cursor: grab;
}
.app-drawer--teams.is-teams-pair-drag .app-team-card[data-team-kind="unpaired"]:active {
  cursor: grabbing;
}
/* Valid drop rows (solo) while dragging: lighter blue glass than .app-team-card--pair-drag-ghost */
.app-drawer--teams.is-teams-pair-drag.is-pair-dnd-active .app-team-card[data-team-kind="unpaired"].is-pair-drop-pool {
  background: linear-gradient(145deg, rgba(147, 197, 253, 0.16), rgba(59, 130, 246, 0.09));
  backdrop-filter: blur(10px) saturate(155%);
  -webkit-backdrop-filter: blur(10px) saturate(155%);
  border-color: rgba(147, 197, 253, 0.42);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.07) inset,
    0 4px 22px rgba(59, 130, 246, 0.14),
    0 0 18px rgba(59, 130, 246, 0.1);
  transition: background 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease;
}
.app-drawer--teams.is-teams-pair-drag.is-pair-dnd-active .app-team-card[data-team-kind="unpaired"].is-pair-drop-pool.is-drop-target {
  background: linear-gradient(145deg, rgba(96, 165, 250, 0.28), rgba(59, 130, 246, 0.15));
  border-color: rgba(186, 230, 253, 0.58);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.09) inset,
    0 8px 34px rgba(59, 130, 246, 0.26),
    0 0 28px rgba(59, 130, 246, 0.2);
  z-index: 1;
  position: relative;
}
/* Only unpaired rows: hide action buttons while dragging so clicks target the card, not edit/remove */
.app-drawer--teams.is-teams-pair-drag .app-team-card[data-team-kind="unpaired"] .app-team-card__actions {
  opacity: 0.35;
  pointer-events: none;
}

/* Custom drag preview: full team card, blue glass (HTML5 setDragImage) */
.app-team-card--pair-drag-ghost {
  background: linear-gradient(145deg, rgba(59, 130, 246, 0.42), rgba(15, 23, 42, 0.72)) !important;
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  border: 1px solid rgba(147, 197, 253, 0.55) !important;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.06) inset,
    0 16px 48px rgba(0, 0, 0, 0.45),
    0 0 32px rgba(59, 130, 246, 0.25);
  border-radius: 12px !important;
  overflow: hidden;
  opacity: 0.98;
}
.app-team-card--pair-drag-ghost .app-team-card__title {
  color: rgba(226, 232, 240, 0.95) !important;
}
.app-team-card--pair-drag-ghost .app-team-card__name {
  color: #f8fafc !important;
}
.app-team-card--pair-drag-ghost .app-team-card__name--muted {
  color: rgba(191, 219, 254, 0.88) !important;
}
.app-drawer--teams.is-teams-pair-drag .app-team-card.is-pair-drag-source {
  opacity: 0.35;
  transition: opacity 0.12s ease;
}

/* Complete pairs: not drop targets, but toolbar (unpair / edit / remove) stays active */
.app-drawer--teams.is-teams-pair-drag .app-team-card[data-team-kind="pair"] {
  opacity: 1;
  filter: none;
  cursor: default;
  user-select: none;
}
.app-drawer--teams.is-teams-pair-drag .app-team-card[data-team-kind="swap"] {
  opacity: 0.38;
  filter: grayscale(0.5) brightness(0.78);
  cursor: not-allowed !important;
  user-select: none;
}

.app-drawer__body--teams {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 0;
  /* overflow-x set by JS (hidden vs auto) so horizontal bar only when needed */
  overflow-x: hidden;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.22) transparent;
}

/* Admin left rails should always scroll vertically (models/users/clubs) */
#adminModelListDrawer.app-drawer--left .app-drawer__body.app-drawer__body--teams,
#adminUsersDrawer.app-drawer--left .app-drawer__body.app-drawer__body--teams,
#adminClubsDrawer.app-drawer--left .app-drawer__body.app-drawer__body--teams{
  overflow-y: auto;
}

/* Admin left rails: fill drawer height (enables body scrolling) */
#adminModelListDrawer.app-drawer--left .app-drawer__inner,
#adminUsersDrawer.app-drawer--left .app-drawer__inner,
#adminClubsDrawer.app-drawer--left .app-drawer__inner{
  height: 100%;
}

/* Scrollbars: vertical thin; horizontal bar only when JS adds .app-teams-rail--h-scroll (real overflow) */
.app-drawer__body--teams::-webkit-scrollbar:vertical {
  width: 6px;
}
.app-drawer__body--teams::-webkit-scrollbar:horizontal {
  height: 0;
}
.app-drawer__body--teams.app-teams-rail--h-scroll::-webkit-scrollbar:horizontal {
  height: 6px;
}
.app-drawer__body--teams::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.18);
  border-radius: 6px;
}
.app-drawer__body--teams::-webkit-scrollbar-track {
  background: transparent;
}

.app-teams-cols {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: flex-start;
  gap: 8px;
  width: max-content;
  max-width: none;
  min-height: min-content;
  /* Space after the last column when scrolling horizontally */
  padding-inline-end: var(--app-teams-rail-inset, clamp(14px, 2.8vw, 18px));
  box-sizing: border-box;
}

.app-teams-col {
  display: flex;
  flex-direction: column;
  /* Base spacing grows slightly with viewport height to avoid large empty bottoms.
     JS can still override via --tr-row-gap when it computes a perfect fill. */
  gap: var(--tr-row-gap, clamp(6px, 1.2vh, 18px));
  flex: 0 0 auto;
  width: 200px;
  min-width: 200px;
}

/* Rail fill mode: we keep normal top-to-bottom flow; JS only adjusts --tr-row-gap globally
   so column 2 (teams 11–20) aligns row-by-row with column 1. */
#playersTeamsDrawer.app-teams-rail--fill .app-teams-col{
  justify-content: flex-start;
}

.app-team-card {
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 10px;
  padding: 6px 8px;
  margin-bottom: 0;
  background: rgba(255, 255, 255, 0.05);
}

/* Teams rail tweak: increase each team card height by +4px total (top+bottom). */
#playersTeamsDrawer .app-team-card{
  padding-top: calc(6px + 2px);
  padding-bottom: calc(6px + 2px);
}

.app-team-card--solo {
  padding-bottom: 6px;
}

.app-team-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 6px;
  margin-bottom: 4px;
}

.app-team-card__actions {
  display: flex;
  align-items: center;
  gap: 0;
  flex-shrink: 0;
}

.app-team-card__btn {
  color: rgba(226, 232, 240, 0.8) !important;
  text-decoration: none !important;
  opacity: 0.92;
  padding: 2px 4px !important;
  min-width: 1.35rem;
  line-height: 1;
}

.app-team-card__btn:hover {
  color: #fff !important;
  opacity: 1;
}

.app-team-card--with-actions .app-team-card__title {
  margin-bottom: 0;
}

.app-team-card__title {
  font-weight: 600;
  color: rgba(248, 250, 252, 0.88);
  font-size: 0.65rem;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
  text-transform: uppercase;
  line-height: 1.2;
  flex: 1 1 auto;
  min-width: 0;
}

.app-team-card__name {
  color: #e2e8f0;
  font-size: 0.78rem;
  line-height: 1.28;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.app-team-card__name + .app-team-card__name {
  margin-top: 2px;
}

.app-team-card__name--muted {
  color: rgba(226, 232, 240, 0.5);
  font-size: 0.72rem;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* Teams rail: "Unpaired" line — brand blue (#60a5fa end of padelstream-club-icon.svg hexGrad) */
#playersTeamsDrawer .app-team-card[data-team-kind="unpaired"] .app-team-card__name--muted {
  color: #60a5fa;
  font-weight: 600;
}

/* Players import: busy overlay while parsing/uploading */
.app-import-busy{
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9100;
  background: rgba(0,0,0,0.25);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.app-import-busy.is-open{display:flex;}
.app-import-busy__card{
  width: min(420px, calc(100vw - 40px));
  padding: 16px 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 22px 55px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.10);
  text-align: center;
}
.app-import-busy__spinner{
  width: 28px;
  height: 28px;
  margin: 2px auto 10px;
  border-radius: 999px;
  border: 3px solid rgba(255,255,255,0.18);
  border-top-color: rgba(255,255,255,0.92);
  animation: appSpin 0.9s linear infinite;
}
.app-import-busy__title{
  color: rgba(248,250,252,0.98);
  font-weight: 800;
  letter-spacing: 0.01em;
}
.app-import-busy__hint{margin-top: 6px;}
@keyframes appSpin{to{transform:rotate(360deg)}}

/*
 * Players dual UI (#playersTeamsDrawer + #playersDrawer): width + vertical band must stay paired.
 * If you change padding, height, or flex for only one side, the rails misalign. Prefer editing
 * the body.app-players-dual-drawer rules below together, and test at ~900px and ~1400px width.
 */
/* Reserve space for left rail + padding when sizing the main drawer */
body.app-players-dual-drawer .app-drawer.app-drawer--wide {
  width: min(960px, calc(100vw - var(--app-teams-rail-w, min(480px, 48vw)) - 28px));
  max-width: calc(100vw - 16px);
}

@media (max-width: 900px) {
  .app-drawer--left {
    width: min(380px, 94vw);
    padding: 12px;
  }

  body.app-players-dual-drawer #playersDrawer.app-drawer--wide {
    padding: 12px;
  }

  .app-drawer--left .app-drawer__inner {
    max-height: calc(100vh - 24px);
    max-height: calc(100dvh - 24px);
  }

  .app-drawer--left .app-drawer__body.app-drawer__body--teams {
    --app-teams-rail-inset: clamp(13px, 2.6vw, 17px);
    --app-teams-rail-inline-end: clamp(13px, 2.2vw, 15px);
    padding: var(--app-teams-rail-inset) var(--app-teams-rail-inline-end) var(--app-teams-rail-inset) var(--app-teams-rail-inset);
  }

  .app-teams-cols {
    padding-inline-end: var(--app-teams-rail-inline-end, clamp(13px, 2.2vw, 15px));
  }

  .app-teams-col {
    width: 170px;
    min-width: 170px;
  }

  body.app-players-dual-drawer .app-drawer.app-drawer--wide {
    width: min(720px, calc(100vw - var(--app-teams-rail-w, min(380px, 94vw)) - 20px));
  }
}

.app-wiz-step .btn.btn-light {
  color: #0b1220 !important;
}

.app-wiz-step {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.10);
}

.app-wiz-step[data-step="1"] {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.app-create-timing-grid .app-create-timing-input {
  max-width: 12rem;
  text-align: center;
}

.app-create-timing-grid input[readonly] {
  cursor: pointer;
  opacity: 0.92;
}

/* Step 4: align “no time limit” checkbox with step title (avoid BS .form-check negative margins) */
.app-create-no-limit .app-create-no-limit__chk {
  float: none;
  margin-left: 0;
  margin-top: 0.2rem;
}

.app-drawer.is-open {
  transform: translateX(0);
}

.app-drawer__inner {
  height: 100%;
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.app-drawer__head {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
}

.app-drawer__body {
  padding: 16px;
  overflow: auto;
  flex: 1 1 auto;
}

/* Teams rail: symmetric padding; overflow-x toggled in JS (hidden default = no h-bar) */
.app-drawer--left .app-drawer__body.app-drawer__body--teams {
  --app-teams-rail-inset: clamp(14px, 2.8vw, 18px);
  min-width: 0;
  padding: var(--app-teams-rail-inset);
  overflow-x: hidden;
  overflow-y: hidden;
  box-sizing: border-box;
}

/* If 10 teams don't fit (short viewports), compress the rail instead of clipping. */
#playersTeamsDrawer.app-teams-rail--compact .app-drawer__body.app-drawer__body--teams{
  --app-teams-rail-inset: clamp(10px, 2.2vw, 14px);
}
#playersTeamsDrawer.app-teams-rail--compact .app-teams-col{gap: 5px;}
#playersTeamsDrawer.app-teams-rail--compact .app-team-card{padding: 5px 7px;}
#playersTeamsDrawer.app-teams-rail--compact .app-team-card__top{margin-bottom: 3px;}
#playersTeamsDrawer.app-teams-rail--compact .app-team-card__title{font-size: 0.62rem; margin-bottom: 3px;}
#playersTeamsDrawer.app-teams-rail--compact .app-team-card__name{font-size: 0.78rem; line-height: 1.15;}
#playersTeamsDrawer.app-teams-rail--compact .app-team-card__name--muted{font-size: 0.68rem; line-height: 1.15;}

/* Last resort: allow vertical scroll but keep it invisible (never show a vertical bar). */
#playersTeamsDrawer .app-drawer__body.app-drawer__body--teams.app-teams-rail--y-scroll{
  overflow-y: auto;
  scrollbar-width: none;
}
#playersTeamsDrawer .app-drawer__body.app-drawer__body--teams.app-teams-rail--y-scroll::-webkit-scrollbar{
  width: 0;
  height: 0;
}

/* Players teams rail: width adapts to 1 or 2 full columns (10 teams/col). */
#playersTeamsDrawer{
  --tr-col-w: 200px;
  --tr-gap: 8px;
  --tr-visible-cols: 1; /* JS: 1 (<=10) or 2 (>=11) */
  --tr-row-gap: 6px;    /* JS can increase this to use leftover height */
}
#playersTeamsDrawer.app-drawer--left{
  width: min(
    calc((var(--tr-visible-cols) * var(--tr-col-w)) + ((var(--tr-visible-cols) - 1) * var(--tr-gap)) + 56px),
    94vw
  );
}
#playersTeamsDrawer .app-teams-cols{gap: var(--tr-gap);}
#playersTeamsDrawer .app-teams-col{
  width: var(--tr-col-w);
  min-width: var(--tr-col-w);
}
#playersTeamsDrawer .app-teams-col{ gap: var(--tr-row-gap); }

@media (max-width: 900px){
  #playersTeamsDrawer{ --tr-col-w: 170px; }
}

/* Dual players UI: same header band height + top edge as main “add players” drawer */
body.app-players-dual-drawer #playersDrawer .app-drawer__head,
body.app-players-dual-drawer #playersTeamsDrawer .app-drawer__head {
  min-height: 3.25rem;
  box-sizing: border-box;
}

/*
 * Same viewport band for both shells: top+bottom (+ safe-area) beats height:100vh alone (subpixel /
 * mobile URL bar). Flex column lets .app-drawer__inner fill so both glass cards share one top edge.
 */
body.app-players-dual-drawer #playersTeamsDrawer.app-drawer--left,
body.app-players-dual-drawer #playersDrawer.app-drawer--wide {
  top: calc(env(safe-area-inset-top, 0px) + 64px);
  bottom: env(safe-area-inset-bottom, 0px);
  height: auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

body.app-players-dual-drawer #playersTeamsDrawer .app-drawer__inner,
body.app-players-dual-drawer #playersDrawer .app-drawer__inner {
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
  max-height: none;
}

.app-players-import-add-row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}
.app-players-import-add-row__download{
  flex: 0 1 auto;
  align-self: center;
  white-space: normal;
  text-align: center;
}
.app-players-import-add-btns{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  width: min(100%, 18rem);
  flex: 0 0 auto;
  margin-left: auto;
}
.app-players-import-add-btns .btn{
  width: 100%;
}

.app-drawer__foot {
  padding: 14px 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.10);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

/* Create wizard: Cancel (left) + Save (right) */
#tournamentCreateDrawer .app-drawer__foot {
  justify-content: space-between;
}

/* Create drawer: stable column width; inner clips to rounded glass */
#tournamentCreateDrawer .app-drawer__inner {
  box-sizing: border-box;
  max-height: calc(100vh - 28px);
  min-height: 0;
  overflow: hidden;
}

/*
 * -------- REVERSIBLE (delete this whole block to restore MDB defaults) --------
 * Tournament create: MDB Datetimepicker uses container: #tournamentCreateDrawer. Its dim layers
 * sit on top of .app-glass and read as a broken “double veil”. Hide only those backdrops here.
 */
#tournamentCreateDrawer .timepicker-wrapper {
  --mdb-timepicker-wrapper-bg: transparent;
  background-color: transparent !important;
}
#tournamentCreateDrawer .datepicker-backdrop {
  --mdb-datepicker-backdrop-background-color: transparent;
  background-color: transparent !important;
}
/* -------- end REVERSIBLE tournament-create MDB picker veil -------- */

/* --- Glass tooltips (inline “i” + floating from native title) --- */
.app-tooltip-glass {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.app-tooltip-glass__btn {
  width: 18px;
  height: 18px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(15, 23, 42, 0.35);
  backdrop-filter: blur(8px);
  color: rgba(248, 250, 252, 0.85);
  font-size: 0.65rem;
  font-weight: 700;
  line-height: 1;
  cursor: default;
}
.app-tooltip-glass__body {
  position: absolute;
  z-index: 12050;
  bottom: calc(100% + 6px);
  right: 0;
  width: min(260px, calc(100vw - 48px));
  padding: 10px 12px;
  font-size: 0.74rem;
  line-height: 1.35;
  text-align: left;
  color: #e2e8f0;
  border-radius: 12px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s ease;
  background: rgba(15, 23, 42, 0.52);
  backdrop-filter: blur(14px) saturate(1.2);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
}
.app-tooltip-glass:hover .app-tooltip-glass__body,
.app-tooltip-glass:focus-within .app-tooltip-glass__body {
  opacity: 1;
  pointer-events: auto;
}
/* JS: replaces native browser title tooltips (app.js initGlassTitleTooltips) */
.app-tooltip-glass--floating {
  position: fixed;
  z-index: 12060;
  max-width: min(280px, calc(100vw - 24px));
  padding: 10px 12px;
  font-size: 0.74rem;
  line-height: 1.35;
  text-align: left;
  color: #e2e8f0;
  border-radius: 12px;
  pointer-events: none;
  background: rgba(15, 23, 42, 0.52);
  backdrop-filter: blur(14px) saturate(1.2);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
  opacity: 0;
  transition: opacity 0.12s ease;
}
.app-tooltip-glass--floating.is-visible {
  opacity: 1;
}

.app-result-row {
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.06);
}

/* App modal (confirm) */
.app-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease;
  z-index: 7200;
}

.app-modal-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}

.app-modal {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.98);
  width: min(520px, 92vw);
  border-radius: 18px;
  /* Variant hooks (set by JS via .app-modal--*) */
  --app-modal-accent: rgba(56, 189, 248, 0.95); /* default: sky */
  --app-modal-overlay: rgba(0, 0, 0, 0.35);
  --app-modal-border: rgba(255, 255, 255, 0.12);
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
  z-index: 7300;
}

.app-modal.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, -50%) scale(1);
}

.app-modal__head {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
}

.app-modal__body {
  padding: 16px;
}

.app-modal__foot {
  padding: 14px 16px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.10);
}

/* App modal variants
   - Use these to separate "error" vs "saved/created" vs "flow actions" styling.
   - The JS will toggle these classes on #appAlertModal / #appConfirmModal.
*/
.app-modal--error{
  --app-modal-accent: rgba(176, 61, 80, 0.15); /* red */
  /* Override app glass tokens for errors */
  --app-glass: rgba(30, 20, 22, 0.85);
  --app-border: rgba(176, 61, 80, 0.4);
}
.app-modal--success{
  --app-modal-accent: rgba(34, 197, 94, 0.1); /* green */
  /* Override app glass tokens for success */
  --app-glass: rgba(18, 25, 20, 0.85);
  --app-border: rgba(34, 197, 94, 0.35);
}
.app-modal--flow{
  --app-modal-accent: rgba(168, 85, 247, 0.95); /* purple */
}

/* Subtle colored border glow per variant */
.app-modal.app-modal--error,
.app-modal.app-modal--success,
.app-modal.app-modal--flow{
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.10),
    0 14px 60px rgba(0,0,0,0.55),
    0 0 0 2px color-mix(in srgb, var(--app-modal-accent) 28%, transparent);
}

/* SUCCESS popup: green-tinted glass background + green OK button */
.app-modal.app-modal--success.app-glass{
  /* Keep the normal glass gradient, but tint via --app-glass above.
     Also force border to use the variant token. */
  border-color: var(--app-border) !important;
}

/* ERROR popup: red-tinted glass background + red OK button */
.app-modal.app-modal--error.app-glass{
  border-color: var(--app-border) !important;
}
.app-modal.app-modal--error .btn-primary{
  background-color: rgba(45, 20, 25, 0.9) !important;
  border-color: rgba(176, 61, 80, 0.3) !important;
}
.app-modal.app-modal--error .btn-primary:hover,
.app-modal.app-modal--error .btn-primary:focus-visible{
  background-color: rgba(65, 25, 30, 1) !important;
  border-color: rgba(176, 61, 80, 0.5) !important;
}
.app-modal.app-modal--success .btn-primary{
  background-color: rgba(20, 40, 30, 0.9) !important;
  border-color: rgba(34, 197, 94, 0.3) !important;
}
.app-modal.app-modal--success .btn-primary:hover,
.app-modal.app-modal--success .btn-primary:focus-visible{
  background-color: rgba(25, 60, 40, 1) !important;
  border-color: rgba(34, 197, 94, 0.5) !important;
}

/* Tournament list row: fixed-width actions column so the club column lines up on every row */
.app-tournament-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px 14px;
  align-items: center;
  width: 100%;
  position: relative;
}

/* Upcoming / Home: dedicated center column so play/pause aligns across rows (width no longer tied to __main) */
.app-tournament-row--playcol {
  grid-template-columns: minmax(0, 1fr) minmax(7.25rem, 11rem) auto;
}
.app-tournament-row--playcol .app-tournament-row__main {
  grid-column: 1;
}
.app-tournament-row--playcol .app-tournament-row__center {
  grid-column: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  overflow: visible;
}
.app-tournament-row--playcol .app-tournament-row__actions {
  grid-column: 3;
}

.app-tournament-row__main {
  min-width: 0;
  grid-column: 1;
}

.app-tournament-row__club {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  text-align: right;
  font-weight: 600;
  font-size: 0.85rem;
  line-height: 1.35;
  color: rgba(226, 232, 240, 0.9);
  padding: 0 4px;
  max-width: 14rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-tournament-row__club a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.app-tournament-row__actions {
  grid-column: 2;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  justify-content: flex-end;
  min-width: 0;
}

.app-tournament-row__title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-tournament-row__actions > .app-badge,
.app-tournament-row__actions > a.app-badge {
  flex-shrink: 1;
  min-width: 0;
}

.app-tournament-row__btn-edit,
.app-tournament-row__btn-hide,
.app-tournament-row__btn-pause {
  flex-shrink: 0;
  box-sizing: border-box;
  width: 2.35rem;
  min-width: 2.35rem;
  height: 2.35rem;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  text-decoration: none !important;
  line-height: 1;
}

/* Admin: canonical models list — disabled delete button (protected models) */
.admin-model-del.is-disabled,
.admin-model-del[disabled]{
  opacity: 0.35 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

/* Admin slides: make delete buttons match Tournaments tab delete look */
.admin-model-del,
.admin-user-del,
.admin-club-del{
  color: #fecaca !important;
  background: rgba(248, 113, 113, 0.12) !important;
  border: 1px solid rgba(248, 113, 113, 0.35) !important;
}
.admin-model-del:hover,
.admin-user-del:hover,
.admin-club-del:hover,
.admin-model-del:focus-visible,
.admin-user-del:focus-visible,
.admin-club-del:focus-visible{
  color: #fff !important;
  background: rgba(248, 113, 113, 0.22) !important;
  border-color: rgba(248, 113, 113, 0.5) !important;
}

/* Manual start (Play): flow inside dedicated __center column (see .app-tournament-row--playcol) */
.app-tournament-row__center-ctl{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  pointer-events: none;
}

.app-tournament-row__center-ctl .app-tournament-row__btn-play{
  position:relative;
  pointer-events: auto; /* clickable */
}

.app-tournament-row__center-paused{
  position:absolute;
  left:calc(100% + 10px);
  top:50%;
  transform:translateY(-50%);
  white-space:nowrap;
  pointer-events: none; /* badge must not block play */
}

.app-tournament-row__btn-play{
  width: 2.05rem;
  height: 2.05rem;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(34, 197, 94, 0.45);
  background: rgba(34, 197, 94, 0.12);
  color: rgba(220, 252, 231, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  cursor: pointer;
}

.app-tournament-row__btn-play:hover{
  border-color: rgba(34, 197, 94, 0.75);
  background: rgba(34, 197, 94, 0.20);
  color: #ffffff;
}

.app-tournament-row__btn-play:active{
  transform: scale(0.98);
}

.app-tournament-row__btn-play.is-paused{
  color: #fde68a !important;
  background: rgba(251, 191, 36, 0.16);
  border-color: rgba(251, 191, 36, 0.55) !important;
}
.app-tournament-row__btn-play.is-paused:hover{
  color:#fff !important;
  background: rgba(251, 191, 36, 0.24);
  border-color: rgba(251, 191, 36, 0.75) !important;
}

/* Play+Pause (resume) icon stack */
.app-tournament-row__btn-play .app-playpause{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  line-height: 1;
}
.app-tournament-row__btn-play .app-playpause i.fa-pause{
  opacity:.85;
  font-size:0.95em;
}
.app-tournament-row__btn-play .app-playpause i.fa-play{
  font-size:1.02em;
}

/* FontAwesome icons have different intrinsic widths; normalize so the stack centers */
.app-tournament-row__btn-play .app-playpause i{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 1em;
}


.app-tournament-row__btn-edit {
  color: #fff !important;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.app-tournament-row__btn-edit:hover {
  color: #fff !important;
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.35) !important;
}

.app-tournament-row__btn-hide {
  color: #fecaca !important;
  background: rgba(248, 113, 113, 0.12);
  border: 1px solid rgba(248, 113, 113, 0.35) !important;
}

.app-tournament-row__btn-hide:hover {
  color: #fff !important;
  background: rgba(248, 113, 113, 0.22);
  border-color: rgba(248, 113, 113, 0.5) !important;
}

.app-tournament-row__btn-play-square{
  color: rgba(220, 252, 231, 0.95) !important;
  background: rgba(34, 197, 94, 0.12);
  border: 1px solid rgba(34, 197, 94, 0.45) !important;
  width: 2.05rem;
  height: 2.05rem;
  border-radius: 10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  padding: 0 !important; /* neutralize Bootstrap p-1 so it centers like tournaments tab */
  align-self: center;
}

/* Normalize icon width so play/pause glyph centers */
.app-tournament-row__btn-play-square i{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
}
.app-tournament-row__btn-play-square:hover{
  color: #fff !important;
  background: rgba(34, 197, 94, 0.20);
  border-color: rgba(34, 197, 94, 0.75) !important;
}
.app-tournament-row__btn-play-square.is-paused{
  color: #fde68a !important;
  background: rgba(251, 191, 36, 0.16);
  border-color: rgba(251, 191, 36, 0.55) !important;
}
.app-tournament-row__btn-play-square.is-paused:hover{
  color:#fff !important;
  background: rgba(251, 191, 36, 0.24);
  border-color: rgba(251, 191, 36, 0.75) !important;
}

.app-tournament-row__btn-pause{
  color: #fde68a !important;
  background: rgba(251, 191, 36, 0.12);
  border: 1px solid rgba(251, 191, 36, 0.38) !important;
}

.app-tournament-row__btn-pause:hover{
  color: #fff !important;
  background: rgba(251, 191, 36, 0.20);
  border-color: rgba(251, 191, 36, 0.55) !important;
}

/* Below ~900px the fixed 380px actions column steals space from title/club — stack club row */
@media (max-width: 900px) {
  .app-tournament-row {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto;
  }

  .app-tournament-row__main {
    grid-column: 1;
    grid-row: 1;
  }

  .app-tournament-row__actions {
    grid-column: 2;
    grid-row: 1;
    align-self: start;
    max-width: min(100vw - 48px, 360px);
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  /* On narrow screens let rows grow naturally (wrapping labels/badges). */
  .app-tournament-item,
  .app-tournament-item.is-active {
    height: auto;
  }
}

.app-tournament-item {
  position: relative;
  z-index: 1;
  border-radius: 16px;
  padding: 10px 14px;
  /* Keep row height consistent across the 3 lists (avoids “squashed” scheduled rows on Windows). */
  min-height: 72px;
  height: var(--app-tournament-row-h, 72px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
}

.app-tournament-item:hover,
.app-tournament-item:focus {
  background: rgba(255, 255, 255, 0.085);
  border-color: rgba(255, 255, 255, 0.18);
  transform: translateY(-1px);
  outline: none;
}

.app-tournament-item.is-selected {
  background: rgba(99, 102, 241, 0.14);
  border-color: rgba(99, 102, 241, 0.32);
}

.app-tournament-item.is-active {
  background: rgba(34, 197, 94, 0.10);
  border-color: rgba(34, 197, 94, 0.26);
  padding: 10px 14px;
  min-height: 72px;
  height: var(--app-tournament-row-h, 72px);
}

/* Keep past list header above scrolling rows */
.app-tournaments-past-head {
  position: relative;
  z-index: 50;
  padding: 0;
  margin: 0 0 10px 0;
  background: transparent;
  border: 0;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.app-tournaments-past-head .btn {
  position: relative;
  z-index: 60;
}

/* Devices status segmented bar (visual reference) */
.app-device-bar {
  height: 12px;
  border-radius: 999px;
  overflow: hidden;
  display: flex;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.app-device-seg {
  height: 100%;
  min-width: 0;
}

.app-device-seg--success {
  background: rgba(34, 197, 94, 0.75);
}

.app-device-seg--warning {
  background: rgba(245, 158, 11, 0.80);
}

.app-device-seg--danger {
  background: rgba(239, 68, 68, 0.80);
}

.app-glass--nav {
  position: sticky;
  top: 0;
  /* Must stay above scrolling glass cards/panels, but below modals/drawers. */
  z-index: 6500;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  border-radius: 0;
  /* Keep navbar height stable even with larger brand icon */
  height: 64px;
  padding-top: 0;
  padding-bottom: 0;
  overflow: visible;
}

.app-glass--nav .container-fluid {
  height: 64px;
  align-items: center;
}

.app-glass--nav .navbar-brand {
  padding-top: 0;
  padding-bottom: 0;
}

.app-glass--card {
  border-radius: 18px;
}

.app-brand {
  text-decoration: none;
  gap: 0;
  flex-shrink: 0;
  --brand-icon-size: 83px;
  /* The PNG has extra transparent padding on the right.
     We crop it in a wrapper so the hex edge aligns with the text. */
  --brand-icon-crop-right: 0.30; /* 30% */
  /* small spacing between hex edge and text */
  --brand-icon-overlap: 6px;
  /* vertical alignment tweak to match desired reference */
  --brand-icon-y: 5px;
}

.app-brand-icon-wrap {
  width: calc(var(--brand-icon-size) * (1 - var(--brand-icon-crop-right)));
  height: var(--brand-icon-size);
  overflow: hidden;
  display: block;
  flex: 0 0 auto;
  margin-right: var(--brand-icon-overlap);
  transform: translateY(var(--brand-icon-y));
}

.app-brand-icon {
  width: var(--brand-icon-size);
  height: var(--brand-icon-size);
  max-width: none;
  /* Reboot img { max-width: 100% } was shrinking the PNG inside the crop wrapper → squashed logo */
  object-fit: contain;
  display: block;
  opacity: 0.95;
}

.app-brand-name {
  position: relative;
  left: 0;
  font-weight: 700;
  letter-spacing: 0.2px;
}

.app-brand-accent {
  background: linear-gradient(90deg, #a7f3d0, #93c5fd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 2px 18px rgba(147, 197, 253, 0.18);
}

.app-lang-btn {
  position: relative;
  z-index: 1;
  border-radius: 999px;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.12);
}

.app-lang-btn:hover {
  background: rgba(0, 0, 0, 0.18);
}

.app-lang-menu {
  background: rgba(20, 24, 38, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 101;
}

.app-lang-menu .dropdown-item {
  color: rgba(255, 255, 255, 0.88);
}

.app-lang-menu .dropdown-item:hover,
.app-lang-menu .dropdown-item:focus {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
}

.app-lang-menu .dropdown-item:active {
  background: rgba(99, 102, 241, 0.25);
}

.app-user-btn {
  position: relative;
  z-index: 1;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.12);
  text-decoration: none;
  color: rgba(255, 255, 255, 0.92);
  padding: 0;
}

.app-user-btn:hover {
  background: rgba(0, 0, 0, 0.18);
}

.app-user-btn--has-photo {
  padding: 0;
  overflow: hidden;
}

.app-user-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: inherit;
}

.app-user-initials {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.6px;
  text-transform: uppercase;
}

.app-user-menu {
  background: rgba(20, 24, 38, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 111;
}

.app-user-menu .dropdown-item {
  color: rgba(255, 255, 255, 0.88);
}

.app-user-menu .dropdown-item:hover,
.app-user-menu .dropdown-item:focus {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
}

.app-user-menu .app-user-theme-opt {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.18);
  color: rgba(255, 255, 255, 0.92);
  font-weight: 600;
}
.app-user-menu .app-user-theme-opt:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}
.app-user-menu .app-user-theme-opt.is-active {
  border-color: rgba(99, 102, 241, 0.55);
  background: rgba(99, 102, 241, 0.22);
  color: #fff;
}

/* Centered header navigation */
.app-nav-center {
  flex: 1 1 auto;
  display: flex;
  justify-content: center;
}

.app-nav-links {
  gap: 1.1rem;
}

.app-nav-link {
  color: rgba(231, 238, 252, 0.92) !important;
  font-weight: 600;
  font-size: 16px;
  padding: 12px 16px;
  border-radius: 14px;
  text-shadow: 0 1px 14px rgba(0, 0, 0, 0.35);
}

.app-nav-link:hover,
.app-nav-link:focus {
  color: rgba(255, 255, 255, 0.95) !important;
  background: rgba(255, 255, 255, 0.12);
}

.app-nav-link.active {
  color: rgba(255, 255, 255, 0.98) !important;
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.app-nav-right {
  flex: 0 0 auto;
}

@media (max-width: 991.98px) {
  .app-nav-center {
    justify-content: flex-start;
    padding-top: 10px;
  }
  .app-nav-links {
    gap: 0.45rem;
  }
  .app-nav-link {
    font-size: 15px;
    padding: 10px 14px;
  }
}

/* Nav overlays: club < language < user (DOM order is club, lang, user). */
.app-lang-dd {
  position: relative;
  z-index: 100;
}

/* Manual language menu (no MDB): same placement as user menu */
.app-lang-dd-manual .app-lang-menu {
  position: absolute;
  top: 100%;
  right: 0;
  left: auto;
  margin-top: 8px;
}

.app-user-dd {
  position: relative;
  z-index: 110;
}

/* Keep user dropdown as overlay (never affects layout) */
.app-user-menu {
  position: absolute;
  top: 100%;
  right: 0;
  left: auto;
  margin-top: 8px;
}

.app-flag-sphere {
  position: relative;
  display: inline-block;
  border-radius: 999px;
  overflow: hidden;
  vertical-align: middle;
  line-height: 0;
  flex: 0 0 auto;
  box-shadow:
    0 10px 22px rgba(0, 0, 0, 0.35),
    inset 8px 10px 16px rgba(255, 255, 255, 0.16),
    inset -10px -12px 18px rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.08);
}

.app-flag-sphere--30 {
  width: 30px;
  height: 30px;
}

.app-flag-sphere--20 {
  width: 20px;
  height: 20px;
}

.app-flag-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* Prevent any global img rules from stretching */
.app-lang-menu .app-flag-sphere,
.app-lang-btn .app-flag-sphere {
  max-width: none;
  max-height: none;
}

/* glass highlight + specular reflection */
.app-flag-sphere::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    140% 100% at 28% 22%,
    rgba(255, 255, 255, 0.70) 0%,
    rgba(255, 255, 255, 0.28) 16%,
    rgba(255, 255, 255, 0.00) 58%
  );
  pointer-events: none;
  opacity: 0.9;
}

.app-flag-sphere::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(140% 140% at 70% 78%, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0.00) 58%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.00) 42%);
  opacity: 0.85;
  pointer-events: none;
}

/* Note: no backdrop-filter blur on flags (keep them crisp). */

.app-avatar {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.35), rgba(45, 212, 191, 0.25));
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: #fff;
}

/* Make MDB inputs look good on dark glass */
.form-outline .form-control {
  background: rgba(0, 0, 0, 0.18);
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.10);
}

.form-outline .form-control:focus {
  background: rgba(0, 0, 0, 0.22);
  border-color: rgba(99, 102, 241, 0.65);
  box-shadow: 0 0 0 0.25rem rgba(99, 102, 241, 0.15);
}

.form-check-input {
  background-color: rgba(0, 0, 0, 0.18);
  border-color: rgba(255, 255, 255, 0.22);
}

/* Fallback if blur not supported */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .app-glass {
    background: rgba(20, 24, 38, 0.92);
  }
}

