/**
 * Pro Tourny native app (Android / iOS WebView) — body.pt-native-app
 * Vertical layouts only: no sideways page scroll; tables become labeled cards.
 */

body.pt-native-app {
  overflow-x: hidden;
  max-width: 100vw;
}

body.pt-native-app .container-xl,
body.pt-native-app .tabs-section,
body.pt-native-app .dash-main,
body.pt-native-app .td-main,
body.pt-native-app .results-main {
  max-width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
}

/* Welcome hero — show headline + intro on iOS/Android app */
body.pt-native-app.welcome-page .hero.hero--canvas2 {
  padding: 0.35rem max(0.75rem, env(safe-area-inset-right, 0px)) 0.65rem
    max(0.75rem, env(safe-area-inset-left, 0px));
  min-height: 0;
}

body.pt-native-app.welcome-page .hero.hero--canvas2 > .hero-content,
body.pt-native-app.welcome-page .hero.hero--canvas2 > .welcome-top-card {
  display: block !important;
  max-width: 100%;
  box-sizing: border-box;
}

body.pt-native-app.welcome-page .hero.hero--canvas2 > .hero-content {
  padding: 0;
  margin-bottom: 0.35rem;
}

body.pt-native-app.welcome-page .hero.hero--canvas2 .hero-title {
  font-size: clamp(1.28rem, 5.2vw, 1.72rem);
  line-height: 1.22;
  margin: 0 0 0.5rem;
  text-align: center;
}

body.pt-native-app.welcome-page .welcome-top-card {
  margin: 0 auto 0.5rem;
  max-width: 100%;
  padding: 0.85rem 0.9rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06);
}

body.pt-native-app.welcome-page .welcome-top-card #welcomeHeroSubheadline {
  margin: 0;
  max-width: none;
  font-size: 0.9rem;
  line-height: 1.48;
  text-align: left;
}

body.pt-native-app.welcome-page .welcome-top-card #welcomeHeroSubheadline .welcome-hero-para {
  font-size: 0.9rem;
  margin-bottom: 0.55rem;
}

body.pt-native-app.welcome-page .welcome-top-card #welcomeHeroSubheadline .welcome-hero-para--features {
  display: none !important;
}

/*
 * Native: fixed header + safe-area on the bar (not body).
 * Sticky top:0 ignored body padding-top and pulled the logo into the notch on scroll.
 */
body.pt-native-app .header.header--welcome {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  max-width: 100vw;
  box-sizing: border-box;
  padding-top: env(safe-area-inset-top, 0px);
  z-index: 200;
}

/* Players, Calendar, Points, Results, registration — single-row header */
body.pt-native-app .header.header--welcome.header--actions-end .header-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-rows: auto;
  align-items: center;
  column-gap: 0.5rem;
  row-gap: 0;
  padding-top: 0.45rem;
  padding-bottom: 0.5rem;
  padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app .header.header--welcome.header--actions-end .header-inner > .logo {
  grid-column: 1;
  grid-row: 1;
  align-self: center;
  justify-self: start;
}

body.pt-native-app .header.header--welcome.header--actions-end .header-inner > .nav {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
  justify-self: end;
  width: auto;
  max-width: none;
  flex: 0 0 auto;
}

body.pt-native-app .header.header--welcome.header--actions-end .logo-mark-img {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}

body.pt-native-app .header.header--welcome.header--actions-end .logo-title {
  font-size: 1rem;
  line-height: 1.15;
}

body.pt-native-app .header.header--welcome.header--actions-end .logo-subtitle {
  font-size: 0.68rem;
  line-height: 1.22;
}

body.pt-native-app.pt-public-page main.pt-page-main,
body.pt-native-app.results-page main.results-main,
body.pt-native-app.pt-registration-form-page main.dash-main,
body.pt-native-app.pt-register-page main.register-page-main {
  padding-top: var(
    --pt-app-header-h,
    calc(env(safe-area-inset-top, 0px) + 5.25rem)
  );
}

body.pt-native-app.pt-registration-form-page #rfTournamentTitle,
body.pt-native-app.pt-register-page #regTournamentName {
  scroll-margin-top: calc(
    var(--pt-app-header-h, calc(env(safe-area-inset-top, 0px) + 5.25rem)) + 0.5rem
  );
}

/* Welcome home — two-row header (logo + menu, section tabs) */
body.pt-native-app.welcome-page .header--welcome .header-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-rows: auto auto;
  align-items: center;
  column-gap: 0.5rem;
  row-gap: 0.35rem;
  padding-top: 0.45rem;
  padding-bottom: 0.5rem;
  padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app.welcome-page .header--welcome .header-inner > .logo {
  grid-column: 1;
  grid-row: 1;
  align-self: center;
}

body.pt-native-app.welcome-page .header--welcome .header-inner > .nav.welcome-auth-nav {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
}

body.pt-native-app.welcome-page .welcome-sections-nav-shell {
  grid-column: 1 / -1;
  grid-row: 2;
  justify-self: stretch;
  width: 100%;
  max-width: 100%;
}

body.pt-native-app.welcome-page .welcome-header-sections-nav {
  justify-content: flex-start;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  gap: 0.55rem 0.85rem;
  padding-bottom: 0.12rem;
}

body.pt-native-app.welcome-page .welcome-header-sections-nav::-webkit-scrollbar {
  display: none;
  height: 0;
  width: 0;
}

body.pt-native-app.welcome-page .welcome-sections-scroll-rail {
  display: block;
  height: 22px;
  margin-top: 0.25rem;
  touch-action: none;
  cursor: pointer;
}

body.pt-native-app.welcome-page .welcome-header-section-link {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0.2rem 0;
  touch-action: manipulation;
  text-decoration: none !important;
  border: 0 !important;
  border-bottom: none !important;
  box-shadow: none !important;
  -webkit-tap-highlight-color: transparent;
}

body.pt-native-app.welcome-page .welcome-header-section-link:hover,
body.pt-native-app.welcome-page .welcome-header-section-link:focus,
body.pt-native-app.welcome-page .welcome-header-section-link:active,
body.pt-native-app.welcome-page .welcome-header-section-link:focus-visible {
  text-decoration: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  outline: none;
}

body.pt-native-app.welcome-page .welcome-header-section-link:focus-visible {
  outline: 2px solid var(--accent, #2563eb);
  outline-offset: 2px;
  border-radius: 4px;
}

body.pt-native-app.welcome-page .welcome-header-section-link[hidden] {
  display: none !important;
}

body.pt-native-app.welcome-page .header--welcome .logo-mark-img {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}

body.pt-native-app.welcome-page .header--welcome .logo-title {
  font-size: 1rem;
  line-height: 1.15;
}

body.pt-native-app.welcome-page .header--welcome .logo-subtitle {
  font-size: 0.68rem;
  line-height: 1.22;
}

body.pt-native-app.welcome-page main {
  padding-top: var(
    --pt-app-header-h,
    calc(env(safe-area-inset-top, 0px) + 7.75rem)
  );
}

body.pt-native-app.welcome-page #welcomeTournamentsSection,
body.pt-native-app.welcome-page #welcomeAdsSection,
body.pt-native-app.welcome-page #partnersSection,
body.pt-native-app.welcome-page #welcomeSiteFooter {
  scroll-margin-top: calc(
    var(--pt-app-header-h, calc(env(safe-area-inset-top, 0px) + 7.75rem)) + 0.35rem
  );
}

@media (max-width: 768px) {
  body.pt-native-app.welcome-page .welcome-auth-menu-panel {
    top: calc(
      var(--pt-app-header-h, calc(env(safe-area-inset-top, 0px) + 7rem)) + 0.35rem
    ) !important;
  }
}

body.pt-native-app #tdDrawsSection,
body.pt-native-app .td-bracket-root,
body.pt-native-app .td-bracket-knockout {
  overflow-x: visible;
  overflow-y: visible;
}

/* —— Welcome: 2-row tournament grid (matches styles.css @768px) —— */
body.pt-native-app .welcome-tournaments-table-wrap,
body.pt-native-app .welcome-tournaments-table-wrap.table-responsive {
  overflow-x: hidden !important;
  max-width: 100%;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table {
  min-width: 0 !important;
  width: 100%;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0 0.75rem;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table thead {
  display: none;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table tbody {
  display: block;
  width: 100%;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table tbody tr {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: auto auto;
  width: 100%;
  max-width: 100%;
  margin-bottom: 0.75rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden;
  background: var(--surface, #fff);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table tbody td {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box;
  padding: 0.4rem 0.35rem;
  border: 0;
  border-right: 1px solid rgba(226, 232, 240, 0.95);
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
  text-align: left;
  font-size: 0.72rem;
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: normal !important;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table tbody td:nth-child(4n) {
  border-right: none;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table tbody td:nth-child(n + 5) {
  border-bottom: none;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table tbody td::before {
  display: block;
  content: attr(data-label);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--text-muted, #64748b);
  margin-bottom: 0.2rem;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table .td-stat {
  text-align: left;
  font-weight: 600;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournaments-table .td-poster {
  align-items: center;
  text-align: center;
}

body.pt-native-app .welcome-tournaments-table-wrap .tournament-poster {
  width: 44px;
  height: 44px;
  object-fit: cover;
  border-radius: 6px;
}

body.pt-native-app .welcome-tournaments-table-wrap .td-action-stack {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  width: 100%;
}

body.pt-native-app .welcome-tournaments-table-wrap .td-action-stack .btn {
  width: 100%;
  min-height: 36px;
  justify-content: center;
  font-size: 0.65rem;
  padding: 0.3rem 0.35rem;
}

/* —— Generic card tables (tournament details, registration, dash) —— */
body.pt-native-app .tournaments-table-wrap:not(.pt-bracket-scroll),
body.pt-native-app .dash-table-wrap:not(.pt-bracket-scroll),
body.pt-native-app .table-responsive:not(.pt-bracket-scroll):not(.welcome-tournaments-table-wrap) {
  overflow-x: visible !important;
  max-width: 100%;
}

body.pt-native-app .tournaments-table.pt-mobile-stack,
body.pt-native-app .td-players-table,
body.pt-native-app .td-winners-table,
body.pt-native-app .dash-table.pt-mobile-stack {
  min-width: 0 !important;
  width: 100%;
}

body.pt-native-app .tournaments-table.pt-mobile-stack thead,
body.pt-native-app .td-players-table thead,
body.pt-native-app .td-winners-table thead,
body.pt-native-app .dash-table.pt-mobile-stack thead {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

body.pt-native-app .tournaments-table.pt-mobile-stack tbody,
body.pt-native-app .td-players-table tbody,
body.pt-native-app .td-winners-table tbody,
body.pt-native-app .dash-table.pt-mobile-stack tbody {
  display: block;
}

body.pt-native-app .tournaments-table.pt-mobile-stack tbody tr,
body.pt-native-app .td-players-table tbody tr,
body.pt-native-app .td-winners-table tbody tr,
body.pt-native-app .dash-table.pt-mobile-stack tbody tr {
  display: block;
  margin-bottom: 0.85rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

body.pt-native-app .tournaments-table.pt-mobile-stack tbody td,
body.pt-native-app .td-players-table tbody td,
body.pt-native-app .td-winners-table tbody td,
body.pt-native-app .dash-table.pt-mobile-stack tbody td {
  display: block;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  white-space: normal !important;
  word-break: break-word;
  overflow-wrap: anywhere;
  border-bottom: 1px solid #eef2f7;
  padding: 0.5rem 0.75rem;
  text-align: left;
}

body.pt-native-app .tournaments-table.pt-mobile-stack tbody tr td:last-child,
body.pt-native-app .td-players-table tbody tr td:last-child,
body.pt-native-app .td-winners-table tbody tr td:last-child,
body.pt-native-app .dash-table.pt-mobile-stack tbody tr td:last-child {
  border-bottom: none;
}

body.pt-native-app .tournaments-table.pt-mobile-stack tbody td::before,
body.pt-native-app .td-players-table tbody td::before,
body.pt-native-app .td-winners-table tbody td::before,
body.pt-native-app .dash-table.pt-mobile-stack tbody td::before {
  display: block;
  content: attr(data-label);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  margin-bottom: 0.2rem;
}

body.pt-native-app .td-winners-table .td-podium-photo {
  max-width: 100%;
  width: 100%;
  height: auto;
  aspect-ratio: 4/3;
}

body.pt-native-app .td-winners-table .td-winner-cell-inner {
  align-items: stretch;
}

/* —— Tournament details header —— */
body.pt-native-app .td-header-top-bar {
  flex-direction: column;
  align-items: stretch;
}

body.pt-native-app .td-header-bar-right {
  flex-wrap: wrap;
  justify-content: flex-start;
}

body.pt-native-app .td-header-right--topbar {
  flex-wrap: wrap;
  white-space: normal;
}

body.pt-native-app .td-title {
  font-size: 1.15rem;
  line-height: 1.25;
  word-break: break-word;
}

body.pt-native-app .td-subtitle,
body.pt-native-app .td-meta-row {
  flex-wrap: wrap;
}

body.pt-native-app .td-event-row {
  flex-direction: column;
  align-items: stretch;
}

body.pt-native-app .td-event-side {
  text-align: left;
  white-space: normal;
}

body.pt-native-app .td-filter-row {
  flex-direction: column;
  align-items: stretch;
}

body.pt-native-app .td-filter-label--grow {
  width: 100%;
}

/* Points table: same columns as web, scaled to fit (no horizontal scroll) */
body.pt-native-app .td-rr-table-wrap.td-rr-standings-only,
body.pt-native-app .tdb-rr-standings-block {
  overflow-x: hidden !important;
  max-width: 100%;
}

body.pt-native-app .standings-scale-container {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  margin: 0 auto 0.75rem;
}

body.pt-native-app .standings-scale-container .td-rr-standings-table,
body.pt-native-app .standings-scale-container .tdb-rr-standings-table {
  width: max-content;
  min-width: 0;
}

/* Knockout bracket — DOM columns (iframe bracket JS does not run in WebView) */
body.pt-native-app .td-bracket-root {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

body.pt-native-app .td-bracket-knockout .td-bracket-columns,
body.pt-native-app .td-bracket-knockout--dom .td-bracket-columns {
  display: flex !important;
  flex-direction: row;
  align-items: flex-start;
  min-width: min-content;
  visibility: visible;
  opacity: 1;
}

body.pt-native-app .td-bracket-knockout--dom .td-bracket-round {
  width: 318px;
  flex-shrink: 0;
}

body.pt-native-app .td-bracket-knockout--dom .td-bracket-connector-gap {
  display: block;
  flex-shrink: 0;
}

body.pt-native-app .td-bracket-knockout--dom .td-bracket-card {
  background: #fff;
  border: 1px solid #d1d5db;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.08);
}

body.pt-native-app .td-bracket-knockout--dom .td-bracket-iframe-wrap {
  display: none !important;
}

body.pt-native-app .td-bracket-print-dom {
  width: 100%;
  max-width: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  background: #f3f4f6;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
}

body.pt-native-app .td-bracket-print-dom .wrap {
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

body.pt-native-app .td-bracket-knockout--print-dom .td-bracket-print-host {
  display: none !important;
}

body.pt-native-app .td-bracket-print-dom .a4-print-slice-btn {
  display: inline-block !important;
  min-height: 40px;
  padding: 8px 12px;
  touch-action: manipulation;
}

body.pt-native-app .td-bracket-toolbar .dash-btn {
  min-height: 44px;
  touch-action: manipulation;
}

body.pt-native-app .td-bracket-print-host {
  width: 100%;
  max-width: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  background: #f3f4f6;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
}

body.pt-native-app .td-bracket-print-host .td-bracket-print-iframe {
  display: block;
  border: 0;
  min-width: 100%;
}

/* Per-round Print / Bracket controls are desktop-only */
body.pt-native-app .td-bracket-print-dom .td-bracket-round-print-btn,
body.pt-native-app .td-bracket-print-dom .td-bracket-round-view-btn,
body.pt-native-app .td-bracket-knockout .td-bracket-round-print-btn,
body.pt-native-app .td-bracket-knockout .td-bracket-round-view-btn {
  display: none !important;
}

body.pt-native-app #tdBracketRoundModal[aria-hidden="false"],
body.pt-native-app #tdBracketRoundModal.td-bracket-round-modal--open {
  z-index: 9999;
  position: fixed;
  inset: 0;
}

body.pt-native-app .td-bracket-knockout--modal .td-bracket-columns {
  padding-bottom: 1.5rem;
}

body.pt-native-app .td-main,
body.pt-native-app .td-bracket-root {
  overflow-x: auto;
  overflow-y: visible;
}

body.pt-native-app .bracket-container {
  max-width: 100%;
  overflow: visible;
  height: auto !important;
}

/* —— Results page —— */
body.pt-native-app .results-hero-grid {
  grid-template-columns: 1fr;
  text-align: center;
}

body.pt-native-app .results-hero-logo-wrap {
  justify-content: center;
}

body.pt-native-app .results-hero-meta {
  grid-template-columns: 1fr;
}

body.pt-native-app .results-winners-wrap,
body.pt-native-app .results-interviews-grid,
body.pt-native-app .results-sponsors-grid,
body.pt-native-app .results-media-wall {
  max-width: 100%;
  overflow-x: hidden;
}

body.pt-native-app .results-interviews-grid {
  grid-template-columns: 1fr;
}

body.pt-native-app .results-sponsors-grid {
  grid-template-columns: 1fr;
}

/* Touch-friendly controls */
body.pt-native-app .btn,
body.pt-native-app .dash-btn,
body.pt-native-app .tab,
body.pt-native-app .td-tab {
  min-height: 40px;
}

body.pt-native-app input,
body.pt-native-app select,
body.pt-native-app textarea {
  font-size: 16px;
}

/* Welcome header menu — both auth buttons visible in dropdown */
body.pt-native-app .welcome-auth-nav {
  flex: 0 0 auto !important;
  width: auto !important;
}

body.pt-native-app .welcome-auth-menu-panel:not([hidden]) {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 3.75rem);
  right: max(0.75rem, env(safe-area-inset-right, 0px));
  z-index: 500;
}

body.pt-native-app .welcome-auth-menu-panel .auth-buttons {
  display: flex !important;
  flex-direction: column;
  flex-wrap: nowrap;
}

body.pt-native-app .welcome-auth-menu-panel .auth-buttons .btn:not(.welcome-auth-item-hidden):not([hidden]) {
  display: inline-flex !important;
  width: 100%;
}

body.pt-native-app .welcome-auth-login-hint {
  font-size: 0.75rem;
  line-height: 1.5;
  text-align: left;
}

body.pt-native-app .welcome-auth-menu-panel #signupBtn:not(.welcome-auth-item-hidden):not([hidden]) {
  display: inline-flex !important;
}

body.pt-native-app.welcome-auth-public-off .header--welcome .welcome-auth-nav,
body.pt-native-app .header--welcome .welcome-auth-nav.welcome-auth-nav-hidden {
  display: none !important;
}

/* —— No network (native app): in-page banner when API calls fail —— */
.pt-native-offline-banner {
  position: fixed;
  inset: 0;
  z-index: 10060;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  background: rgba(241, 245, 249, 0.97);
  box-sizing: border-box;
}

.pt-native-offline-banner[hidden] {
  display: none !important;
}

.pt-native-offline-banner__inner {
  max-width: 20rem;
  text-align: center;
  padding: 1.75rem 1.5rem;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
}

.pt-native-offline-banner__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 0.85rem;
  border-radius: 50%;
  background: #fee2e2;
  color: #b91c1c;
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1;
}

.pt-native-offline-banner__text {
  margin: 0 0 1.1rem;
  font-size: 1.1rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.35;
}

.pt-native-offline-banner__retry {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.55rem 1.25rem;
  border: none;
  border-radius: 10px;
  background: #4f46e5;
  color: #fff;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  touch-action: manipulation;
}

.pt-native-offline-banner__retry:active {
  background: #4338ca;
}

body.pt-native-app.pt-native-offline-active {
  overflow: hidden;
}

/* Welcome poster modal: show poster + scrollable details in WebView */
body.pt-native-app #posterModal .poster-modal-box {
  max-height: min(92vh, 92dvh);
}

body.pt-native-app #posterModal .poster-modal-body {
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}

body.pt-native-app #posterModal .poster-modal-poster-wrap {
  display: flex;
}

body.pt-native-app #posterModal #posterModalImage {
  width: 100%;
  max-height: min(48vh, 400px);
  object-fit: contain;
}

/* Registration: Terms & Privacy pop-ups above WebView chrome */
body.pt-native-app #regTermsModal,
body.pt-native-app #regPrivacyModal {
  z-index: 10060;
}

body.pt-native-app #regTermsModal .modal-box-text,
body.pt-native-app #regPrivacyModal .modal-box-text {
  max-height: min(78vh, 78dvh);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

body.pt-native-app .reg-consent-option .reg-inline-link {
  touch-action: manipulation;
}

/* Welcome help chat FAB — sit above home indicator / bottom edge */
body.pt-native-app .help-chat-fab {
  bottom: calc(3rem + env(safe-area-inset-bottom, 0px));
  right: max(1rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app .help-chat-panel {
  bottom: calc(6rem + env(safe-area-inset-bottom, 0px));
  right: max(0.75rem, env(safe-area-inset-right, 0px));
  left: max(0.75rem, env(safe-area-inset-left, 0px));
}

/* Calendar, Points, Results, Registration — Home top-right (Android / iOS app) */
body.pt-native-app.pt-calendar-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-points-page .header--welcome .pt-page-home-link,
body.pt-native-app.results-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-register-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-registration-form-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-players-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-player-reg-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-role-directory-page .header--welcome .pt-page-home-link {
  font-size: 0.8rem;
  padding: 0.4rem 0.75rem;
  min-height: 0;
  line-height: 1.2;
  font-weight: 600;
  white-space: nowrap;
  border-radius: var(--radius-sm, 8px);
  touch-action: manipulation;
}

body.pt-native-app.pt-players-page .header.header--welcome,
body.pt-native-app.pt-calendar-page .header.header--welcome,
body.pt-native-app.pt-points-page .header.header--welcome,
body.pt-native-app.pt-player-reg-page .header.header--welcome,
body.pt-native-app.pt-role-directory-page .header.header--welcome {
  z-index: 300;
}

body.pt-native-app.pt-players-page .header--welcome .logo,
body.pt-native-app.pt-players-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-player-reg-page .header--welcome .logo,
body.pt-native-app.pt-player-reg-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-role-directory-page .header--welcome .logo,
body.pt-native-app.pt-role-directory-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-calendar-page .header--welcome .logo,
body.pt-native-app.pt-calendar-page .header--welcome .pt-page-home-link,
body.pt-native-app.pt-points-page .header--welcome .logo,
body.pt-native-app.pt-points-page .header--welcome .pt-page-home-link {
  position: relative;
  z-index: 2;
  pointer-events: auto;
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: rgba(37, 99, 235, 0.12);
}

body.pt-native-app .header--welcome .logo .logo-mark-img,
body.pt-native-app .header--welcome .logo .logo-text {
  pointer-events: none;
}

body.pt-native-app.pt-register-page .header--welcome .logo-mark-img,
body.pt-native-app.pt-registration-form-page .header--welcome .logo-mark-img {
  width: 44px;
  height: 44px;
}

body.pt-native-app.pt-register-page .header--welcome .logo-subtitle,
body.pt-native-app.pt-registration-form-page .header--welcome .logo-subtitle {
  font-size: 0.72rem;
  line-height: 1.2;
  max-width: min(52vw, 14rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 520px) {
  body.pt-native-app.pt-register-page main.register-page-main {
    padding-top: var(
      --pt-app-header-h,
      calc(env(safe-area-inset-top, 0px) + 5.25rem)
    );
    padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
    padding-bottom: 1.75rem;
  }

  body.pt-native-app.pt-registration-form-page main.dash-main.pt-page-main {
    padding-left: max(1rem, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, env(safe-area-inset-right, 0px));
  }
}

body.pt-native-app.pt-players-page .pt-players-directory-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
}

body.pt-native-app.pt-players-page .pt-players-directory-card {
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.08);
}

body.pt-native-app.pt-players-page .pt-players-directory-card:hover {
  transform: none;
}

body.pt-native-app.results-page .header--welcome .logo-mark-img {
  width: 44px;
  height: 44px;
}

body.pt-native-app.results-page .header--welcome .logo-subtitle {
  font-size: 0.72rem;
}

body.pt-native-app.results-page .header--welcome .logo-title {
  font-size: 0.95rem;
}

/* —— ProTourny Calendar & Points (native app — compact, same layout as web) —— */
body.pt-native-app.pt-calendar-page,
body.pt-native-app.pt-points-page {
  font-size: 15px;
}

body.pt-native-app.pt-calendar-page .pt-page-main,
body.pt-native-app.pt-points-page .pt-page-main,
body.pt-native-app.pt-players-page .pt-page-main {
  padding-top: var(
    --pt-app-header-h,
    calc(env(safe-area-inset-top, 0px) + 5.25rem)
  );
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 2rem;
}

body.pt-native-app.pt-players-page .pt-players-hero,
body.pt-native-app.pt-calendar-page .pt-players-hero,
body.pt-native-app.pt-points-page .pt-players-hero {
  padding: 0.45rem 0 0.5rem;
}

body.pt-native-app.pt-players-page .pt-players-hero-bar,
body.pt-native-app.pt-calendar-page .pt-players-hero-bar,
body.pt-native-app.pt-points-page .pt-players-hero-bar {
  padding-left: max(0.65rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.65rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app.pt-players-page .pt-players-hero-title,
body.pt-native-app.pt-calendar-page .pt-players-hero-title,
body.pt-native-app.pt-points-page .pt-players-hero-title {
  flex-direction: column;
  align-items: flex-start;
  gap: 0.02em;
  font-size: clamp(1.1rem, 4.8vw, 1.24rem);
  line-height: 1.08;
  white-space: normal;
}

body.pt-native-app.pt-players-page .pt-players-hero-title-line:first-child,
body.pt-native-app.pt-calendar-page .pt-players-hero-title-line:first-child,
body.pt-native-app.pt-points-page .pt-players-hero-title-line:first-child {
  font-size: 1.05em;
}

body.pt-native-app.pt-players-page .pt-players-hero-title-line,
body.pt-native-app.pt-calendar-page .pt-players-hero-title-line,
body.pt-native-app.pt-points-page .pt-players-hero-title-line {
  display: block;
}

body.pt-native-app.pt-players-page .pt-players-hero-intro,
body.pt-native-app.pt-calendar-page .pt-players-hero-intro,
body.pt-native-app.pt-points-page .pt-players-hero-intro {
  display: block;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  font-size: 0.78rem;
  line-height: 1.35;
  margin-top: 0.2rem;
}

body.pt-native-app.pt-calendar-page .pt-players-hero-stat--multi.pt-cal-stats {
  flex-wrap: wrap;
  gap: 0.25rem;
  max-width: 10.5rem;
  justify-content: flex-end;
}

body.pt-native-app.pt-calendar-page .pt-players-hero-stat--multi .pt-cal-stat {
  flex: 1 1 calc(50% - 0.15rem);
  min-width: 3.25rem;
  padding: 0.26rem 0.35rem;
}

body.pt-native-app.pt-calendar-page .pt-players-hero-stat--multi .pt-cal-stat-value {
  font-size: 0.82rem;
}

body.pt-native-app.pt-calendar-page .pt-players-hero-stat--multi .pt-cal-stat-label {
  font-size: 0.55rem;
}

body.pt-native-app.pt-players-page .pt-page-section,
body.pt-native-app.pt-calendar-page .pt-page-section,
body.pt-native-app.pt-points-page .pt-page-section {
  margin-top: 0.5rem;
}

body.pt-native-app.pt-players-page .pt-page-section .container-xl,
body.pt-native-app.pt-calendar-page .pt-page-section .container-xl,
body.pt-native-app.pt-points-page .pt-page-section .container-xl {
  padding-left: max(0.65rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.65rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app.pt-calendar-page .container-xl,
body.pt-native-app.pt-points-page .container-xl {
  padding-left: max(0.65rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.65rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app.pt-calendar-page .header--welcome .logo-mark-img,
body.pt-native-app.pt-points-page .header--welcome .logo-mark-img,
body.pt-native-app.pt-player-reg-page .header--welcome .logo-mark-img {
  width: 44px;
  height: 44px;
}

body.pt-native-app.pt-player-reg-page .header--welcome .logo-subtitle {
  font-size: 0.72rem;
  line-height: 1.2;
  max-width: min(52vw, 14rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.pt-native-app.pt-player-reg-page .pt-player-reg-hero {
  padding: 0.45rem 0 0.5rem;
}

body.pt-native-app.pt-player-reg-page .pt-page-section .container-xl {
  padding-left: max(0.65rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.65rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app.pt-player-reg-page .pt-player-reg-grid {
  grid-template-columns: 1fr;
}

body.pt-native-app.pt-player-reg-page .pt-player-reg-form {
  padding: 1rem 0.85rem 1.25rem;
}

body.pt-native-app.pt-player-reg-page .pt-player-reg-actions .btn {
  width: 100%;
  touch-action: manipulation;
}

body.pt-native-app.pt-player-reg-page .pt-player-reg-success-actions .btn {
  width: 100%;
  max-width: 18rem;
  touch-action: manipulation;
  pointer-events: auto;
}

body.pt-native-app.pt-player-reg-page .pt-player-reg-success:not([hidden]) {
  position: relative;
  z-index: 2;
  pointer-events: auto;
}

body.pt-native-app.pt-role-directory-page .pt-role-reg-modal {
  width: min(100%, calc(100vw - 0.75rem));
  max-height: min(92vh, 860px);
}

body.pt-native-app.pt-role-directory-page .pt-role-reg-modal .modal-body-text.pt-role-reg-modal-body {
  padding: 0.5rem 0.65rem 0.55rem;
}

body.pt-native-app.pt-role-directory-page .pt-players-hero-btn {
  touch-action: manipulation;
}

body.pt-native-app.pt-calendar-page .header--welcome .logo-subtitle,
body.pt-native-app.pt-points-page .header--welcome .logo-subtitle {
  font-size: 0.72rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-table-head,
body.pt-native-app.pt-points-page .pt-cal-table-head {
  padding: 0.7rem 0.75rem 0.55rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-table-title,
body.pt-native-app.pt-points-page .pt-cal-table-title {
  font-size: 0.92rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-table-sub,
body.pt-native-app.pt-points-page .pt-cal-table-sub {
  font-size: 0.78rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-toolbar {
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.35rem;
  margin-bottom: 0.55rem;
}

body.pt-native-app.pt-points-page .pt-cal-toolbar {
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.35rem;
  margin-bottom: 0.55rem;
}

body.pt-native-app.pt-points-page .pt-cal-filter-wrap {
  flex: 1 1 auto;
  min-width: 0;
}

body.pt-native-app.pt-points-page .pt-cal-filter-wrap .muted {
  display: none;
}

body.pt-native-app.pt-calendar-page .pt-cal-search {
  flex: 1 1 auto;
  min-width: 0;
  width: auto;
}

body.pt-native-app.pt-points-page .pt-cal-filter-wrap {
  width: 100%;
}

body.pt-native-app.pt-calendar-page .pt-cal-search {
  padding: 0.32rem 0.55rem;
  border-radius: 8px;
  gap: 0.35rem;
  box-shadow: none;
}

body.pt-native-app.pt-calendar-page .pt-cal-search-icon {
  font-size: 0.78rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-search input {
  font-size: 0.8rem;
  line-height: 1.2;
  min-height: 0;
  height: 1.2rem;
  -webkit-appearance: none;
  appearance: none;
}

body.pt-native-app.pt-calendar-page .pt-cal-search input[type="search"]::-webkit-search-decoration,
body.pt-native-app.pt-calendar-page .pt-cal-search input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
}

body.pt-native-app.pt-calendar-page .pt-cal-filter {
  flex: 0 0 auto;
  width: auto;
  min-width: 6.5rem;
  max-width: 36%;
  padding: 0.36rem 0.45rem;
  border-radius: 8px;
  font-size: 0.78rem;
}

body.pt-native-app.pt-points-page .pt-cal-filter {
  width: 100%;
  min-width: 0;
  padding: 0.36rem 0.55rem;
  border-radius: 8px;
  font-size: 0.8rem;
}

/* Calendar: use mobile group cards in native app (not broken rowspan table) */
body.pt-native-app.pt-calendar-page .pt-cal-table-wrap {
  display: none !important;
}

body.pt-native-app.pt-calendar-page .pt-cal-mobile-list:not([hidden]) {
  display: flex;
  padding: 0 0.65rem 0.65rem;
  gap: 0.55rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-mobile-group-head {
  padding: 0.45rem 0.55rem 0.4rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-mobile-meta-line {
  margin-top: 0.28rem;
  gap: 0.28rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-mobile-meta-item {
  font-size: 0.72rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-mobile-events {
  padding: 0.25rem 0.55rem 0.4rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-mobile-event {
  padding: 0.28rem 0;
}

body.pt-native-app.pt-calendar-page .pt-cal-tournament-name,
body.pt-native-app.pt-calendar-page .pt-cal-tournament-link {
  font-size: 0.88rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-tournament-meta {
  font-size: 0.68rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-sport-badge {
  font-size: 0.62rem;
  padding: 0.14rem 0.4rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-event-name {
  font-size: 0.74rem;
  padding: 0.12rem 0.35rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-mobile-event-when {
  font-size: 0.72rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-table-head {
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
}

body.pt-native-app.pt-calendar-page .pt-cal-table-title {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.pt-native-app.pt-calendar-page .pt-cal-table-sub {
  flex-shrink: 0;
  white-space: nowrap;
}

/* Points: dedicated mobile cards in native app (same as web mobile) */
body.pt-native-app.pt-points-page .pt-points-desktop-only {
  display: none !important;
}

body.pt-native-app.pt-points-page .pt-points-mobile-list:not([hidden]) {
  display: flex;
  padding: 0 0.55rem 0.55rem;
  gap: 0.5rem;
}

body.pt-native-app.pt-points-page .pt-points-mobile-rank-card,
body.pt-native-app.pt-points-page .pt-points-mobile-result {
  padding: 0.58rem 0.65rem;
  border-radius: 10px;
}

body.pt-native-app.pt-points-page .pt-points-mobile-player {
  font-size: 0.88rem;
}

body.pt-native-app.pt-points-page .pt-points-mobile-rank-meta {
  font-size: 0.72rem;
  gap: 0.28rem 0.5rem;
}

body.pt-native-app.pt-points-page .pt-points-mobile-tournament {
  font-size: 0.86rem;
}

body.pt-native-app.pt-points-page .pt-points-mobile-event {
  font-size: 0.76rem;
}

body.pt-native-app.pt-points-page .pt-points-row {
  font-size: 0.78rem;
}

body.pt-native-app.pt-points-page .pt-points-place {
  min-width: 4rem;
  font-size: 0.68rem;
}

body.pt-native-app.pt-points-page .pt-rank-badge {
  min-width: 1.5rem;
  height: 1.5rem;
  font-size: 0.74rem;
}

body.pt-native-app.pt-points-page .pt-total-points {
  font-size: 0.88rem;
}

body.pt-native-app.pt-points-page .pt-points-leaderboard-shell,
body.pt-native-app.pt-points-page .pt-points-results-shell {
  margin-bottom: 0.85rem;
  border-radius: 12px;
}

/* —— Profile + tournament dashboard (dashboard-body) —— */
body.pt-native-app.dashboard-body .dash-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  max-width: 100vw;
  box-sizing: border-box;
  padding-top: env(safe-area-inset-top, 0px);
  z-index: 200;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

body.pt-native-app.dashboard-body .dash-header-inner {
  padding-top: 0.5rem;
  padding-bottom: 0.55rem;
  padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app.dashboard-body .dash-logo-site-mark {
  width: 48px;
  height: 48px;
}

body.pt-native-app.dashboard-body .dash-logo-text {
  font-size: 1rem;
  line-height: 1.15;
}

body.pt-native-app.dashboard-body .dash-tagline {
  font-size: 0.72rem;
  line-height: 1.2;
}

body.pt-native-app.dashboard-body:has(.dash-header) .dash-main {
  padding-top: var(
    --pt-app-header-h,
    calc(env(safe-area-inset-top, 0px) + 5.5rem)
  );
}

body.pt-native-app.dashboard-body.td-details-page .dash-main.td-main {
  padding-top: max(0.65rem, env(safe-area-inset-top, 0px));
}

/* —— Instant PDF Draw (draws.html) —— */
body.pt-native-app.pt-draws-page .dash-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  max-width: 100vw;
  box-sizing: border-box;
  padding-top: env(safe-area-inset-top, 0px);
  z-index: 200;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

body.pt-native-app.pt-draws-page .dash-header-inner {
  padding-top: 0.45rem;
  padding-bottom: 0.5rem;
  padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
}

body.pt-native-app.pt-draws-page .dash-logo-site-mark {
  width: 48px;
  height: 48px;
}

body.pt-native-app.pt-draws-page .dash-logo-text {
  font-size: 1rem;
  line-height: 1.15;
}

body.pt-native-app.pt-draws-page .dash-tagline {
  font-size: 0.72rem;
  line-height: 1.2;
}

body.pt-native-app.pt-draws-page .draws-main {
  padding-top: var(
    --pt-app-header-h,
    calc(env(safe-area-inset-top, 0px) + 5.25rem)
  );
  padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
  padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
  padding-bottom: max(1.5rem, env(safe-area-inset-bottom, 0px));
}

body.pt-native-app.pt-draws-page .draws-preview-header {
  flex-wrap: wrap;
  gap: 0.5rem;
}

body.pt-native-app.pt-draws-page .draws-preview-header .dash-btn {
  font-size: 0.82rem;
  padding: 0.45rem 0.75rem;
}

/* Create account / login modals — scrollable, full width on small screens */
body.pt-native-app #signupModal[aria-hidden="false"],
body.pt-native-app #loginModal[aria-hidden="false"] {
  align-items: center;
  padding: max(0.5rem, env(safe-area-inset-top, 0px)) max(0.65rem, env(safe-area-inset-right, 0px))
    max(0.5rem, env(safe-area-inset-bottom, 0px)) max(0.65rem, env(safe-area-inset-left, 0px));
}

body.pt-native-app .signup-modal-box.modal-auth-canvas {
  width: min(440px, calc(100vw - 1.25rem));
  max-width: none;
  max-height: min(90dvh, 680px);
}

body.pt-native-app .signup-modal-box > #signupForm.auth-form {
  -webkit-overflow-scrolling: touch;
}

body.pt-native-app .signup-modal-box .auth-form input,
body.pt-native-app .signup-modal-box .auth-form select {
  font-size: 16px;
}

body.pt-native-app .signup-modal-box .auth-form .auth-radio-group--signup-gender {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.35rem;
}

body.pt-native-app .signup-modal-box .auth-form .auth-radio-group--signup-gender .auth-radio-option {
  min-height: 2.5rem;
  padding: 0.38rem 0.25rem;
}
