:root {
  --court: #007a3d;
  --court-dark: #005f31;
  --court-glow: rgba(0, 122, 61, 0.18);
  --clay: #b96f39;
  --clay-soft: #fff6ee;
  --ball: #d9ff4f;
  --cream: #fffdf8;
  --ink: #122015;
  --muted: #6b7a70;
  --line: #dfe8e2;
  --line-strong: #cbded3;
  --soft: #e9f7ef;
  --shadow-preview: 0 18px 45px rgba(0, 70, 35, 0.10);
}

body {
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.70), rgba(255, 255, 255, 0.86)),
    url("tennis-hero.png?v=4"),
    radial-gradient(circle at 11% 18%, rgba(185, 111, 57, 0.12), transparent 24%),
    radial-gradient(circle at 86% 78%, rgba(217, 255, 79, 0.08), transparent 18%),
    radial-gradient(circle at 50% 120%, rgba(185, 111, 57, 0.10), transparent 30%),
    linear-gradient(135deg, #f8fbf8 0%, #eff8f2 42%, #fffdf8 100%);
  background-position: center top, center 18%, center, center, center, center;
  background-size: auto, cover, auto, auto, auto, auto;
  background-attachment: fixed;
  color: var(--ink);
}

body::before {
  display: none;
}

body::after {
  content: "";
  position: fixed;
  right: -180px;
  bottom: -190px;
  z-index: 0;
  width: 520px;
  height: 520px;
  border: 1px solid rgba(0, 95, 49, 0.10);
  border-radius: 50%;
  background:
    linear-gradient(62deg, transparent 47%, rgba(255, 255, 255, 0.42) 48%, transparent 50%),
    radial-gradient(circle, rgba(217, 255, 79, 0.07), transparent 62%);
  pointer-events: none;
}

.topbar,
.page-shell {
  position: relative;
  z-index: 1;
}

.page-shell::before {
  display: none;
}

.topbar {
  background: rgba(255, 253, 248, 0.88);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 8px 24px rgba(0, 80, 40, 0.06);
}

.brand {
  color: var(--court-dark);
  font-size: 1.22rem;
}

.nav-tab {
  border-radius: 12px;
  background: rgba(255, 253, 248, 0.78);
  color: var(--court-dark);
}

.nav-tab.active,
.nav-tab:hover {
  border-color: var(--court);
  background: linear-gradient(135deg, var(--court), var(--court-dark));
  color: #fff;
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(0, 122, 61, 0.18);
}

.page-header h1 {
  font-size: clamp(28px, 4vw, 46px);
  letter-spacing: -0.01em;
}

.subpage-hero {
  margin: -8px 0 28px;
  padding: 0 12px;
}

.subpage-hero-inner {
  position: relative;
  display: flex;
  min-height: 168px;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
  overflow: hidden;
  padding-top: 30px;
  padding-bottom: 28px;
  border: 1px solid rgba(203, 222, 211, 0.7);
  border-radius: 24px;
  background:
    radial-gradient(circle at 88% 30%, rgba(217, 255, 79, 0.11), transparent 15%),
    linear-gradient(90deg, rgba(0, 62, 36, 0.94), rgba(0, 95, 49, 0.78) 54%, rgba(185, 111, 57, 0.22)),
    url("tennis-hero.png?v=3");
  background-position: center 60%;
  background-size: cover;
  box-shadow: 0 22px 50px rgba(0, 70, 35, 0.14);
}

.subpage-hero-inner::before {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(0, 33, 20, 0.72), rgba(0, 70, 35, 0.42), rgba(255, 255, 255, 0.04)),
    linear-gradient(90deg, transparent 0 15%, rgba(255, 255, 255, 0.22) 15.2% 15.8%, transparent 16% 50%, rgba(255, 255, 255, 0.18) 50.2% 50.8%, transparent 51% 84%, rgba(255, 255, 255, 0.18) 84.2% 84.8%, transparent 85%),
    linear-gradient(0deg, transparent 0 18%, rgba(255, 255, 255, 0.20) 18.2% 18.8%, transparent 19% 50%, rgba(255, 255, 255, 0.14) 50.2% 50.8%, transparent 51% 82%, rgba(255, 255, 255, 0.16) 82.2% 82.8%, transparent 83%),
    radial-gradient(circle, rgba(185, 111, 57, 0.13) 0 0.9px, transparent 1.1px);
  background-size: auto, 100% 100%, 100% 100%, 16px 16px;
  content: "";
}

.subpage-hero-inner::after {
  position: absolute;
  right: 38px;
  top: 28px;
  width: 72px;
  height: 72px;
  border: 1px solid rgba(217, 255, 79, 0.28);
  border-radius: 999px;
  background:
    linear-gradient(62deg, transparent 43%, rgba(255, 255, 255, 0.42) 45%, transparent 49%),
    linear-gradient(-62deg, transparent 43%, rgba(255, 255, 255, 0.28) 45%, transparent 49%),
    radial-gradient(circle at 34% 28%, rgba(255, 255, 255, 0.35), transparent 16%),
    radial-gradient(circle, rgba(217, 255, 79, 0.18), rgba(217, 255, 79, 0.03));
  content: "";
}

.subpage-hero-inner > * {
  position: relative;
  z-index: 1;
}

.subpage-hero .eyebrow {
  color: rgba(217, 255, 79, 0.9);
}

.subpage-hero h2 {
  max-width: 680px;
  margin: 0;
  color: #fff;
  font-size: clamp(30px, 5vw, 58px);
  font-weight: 900;
  line-height: 0.98;
}

.subpage-hero-note {
  max-width: 320px;
  padding: 9px 13px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: rgba(0, 40, 24, 0.24);
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.95rem;
  font-weight: 800;
  text-align: right;
  backdrop-filter: blur(8px);
}

.eyebrow {
  color: var(--court);
}

.surface {
  border-color: var(--line);
  border-radius: 22px;
  background:
    radial-gradient(circle at 100% 0%, rgba(185, 111, 57, 0.045), transparent 24%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(255, 255, 255, 0.94));
  box-shadow: var(--shadow-preview);
  position: relative;
  overflow: hidden;
}

.surface::before {
  position: absolute;
  right: -60px;
  top: -80px;
  width: 190px;
  height: 190px;
  border: 1px solid rgba(185, 111, 57, 0.14);
  border-radius: 999px;
  background:
    linear-gradient(115deg, transparent 46%, rgba(255, 255, 255, 0.72) 47%, transparent 49%),
    linear-gradient(22deg, transparent 45%, rgba(185, 111, 57, 0.12) 46%, transparent 48%),
    radial-gradient(circle, rgba(217, 255, 79, 0.07), transparent 64%);
  content: "";
  pointer-events: none;
}

.surface::after {
  position: absolute;
  inset: auto 20px 16px auto;
  width: 118px;
  height: 52px;
  border-right: 1px solid rgba(0, 95, 49, 0.08);
  border-bottom: 1px solid rgba(0, 95, 49, 0.08);
  border-radius: 0 0 18px 0;
  content: "";
  pointer-events: none;
}

.surface > * {
  position: relative;
  z-index: 1;
}

.day-block,
.round-block {
  padding: 22px;
}

.day-title,
.round-title {
  margin: -22px -22px 18px;
  padding: 16px 22px;
  border-radius: 22px 22px 0 0;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(90deg, rgba(233, 247, 239, 0.95), rgba(255, 246, 238, 0.55));
}

.day-title h2,
.round-title h2,
.compact-surface h2 {
  letter-spacing: -0.01em;
}

.date-pending-note {
  width: fit-content;
  margin: 0 0 14px;
  padding: 8px 12px;
  border: 1px solid rgba(0, 122, 61, 0.14);
  border-radius: 999px;
  background: rgba(233, 247, 239, 0.85);
  color: var(--court-dark);
  font-size: 0.9rem;
  font-weight: 800;
}

.schedule-card,
.result-card,
.player-card,
.match-card,
.detail-match-card,
.team-detail-member,
.detail-stat-grid div {
  border-color: var(--line);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(255, 255, 255, 0.94));
  box-shadow: 0 10px 28px rgba(0, 70, 35, 0.06);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.schedule-card:hover,
.result-card:hover,
.player-card:hover,
.match-card:hover,
.detail-match-card:hover {
  border-color: var(--line-strong);
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(0, 90, 45, 0.14);
}

.btn,
.nav-tab.as-button {
  border-radius: 12px;
  font-weight: 800;
}

.btn-success {
  border-color: transparent;
  background: linear-gradient(135deg, var(--court), var(--court-dark));
  box-shadow: 0 10px 22px rgba(0, 122, 61, 0.22);
}

.btn-success:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(0, 122, 61, 0.28);
}

.btn-outline-success,
.btn-outline-secondary {
  border-color: var(--line);
  background: rgba(255, 255, 255, 0.78);
}

.form-control,
.form-select {
  border-color: var(--line);
  border-radius: 12px;
  background-color: rgba(255, 255, 255, 0.90);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--court);
  box-shadow: 0 0 0 4px rgba(0, 122, 61, 0.12);
}

.time-pill,
.score-chip,
.rank {
  background: linear-gradient(135deg, #ecf8f0, #fffdf8);
  color: var(--court-dark);
}

.rank {
  border: 1px solid rgba(0, 122, 61, 0.12);
  background:
    linear-gradient(60deg, transparent 42%, rgba(255, 255, 255, 0.86) 44%, transparent 47%),
    radial-gradient(circle at 35% 30%, rgba(255, 255, 255, 0.8), transparent 18%),
    radial-gradient(circle, rgba(217, 255, 79, 0.20), #e7f7ef 68%);
  box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.66), 0 5px 12px rgba(0, 95, 49, 0.08);
}

.points {
  background: linear-gradient(135deg, var(--court), var(--court-dark));
  box-shadow: 0 8px 18px rgba(0, 122, 61, 0.22);
}

.time-pill {
  background:
    linear-gradient(90deg, rgba(0, 122, 61, 0.10), transparent),
    #ecf8f0;
}

.standings-table {
  overflow: hidden;
  border-radius: 18px;
  border-collapse: separate;
  border-spacing: 0;
}

.standings-table th {
  background:
    linear-gradient(90deg, rgba(232, 246, 238, 0.98), rgba(255, 246, 238, 0.78)),
    linear-gradient(90deg, transparent 0 24%, rgba(0, 95, 49, 0.10) 24.5% 25%, transparent 25.5%);
  color: var(--court-dark);
  letter-spacing: 0.04em;
}

.standings-table tbody tr {
  transition: background 0.15s ease, transform 0.15s ease;
}

.standings-table tr:hover td {
  background: linear-gradient(90deg, rgba(232, 246, 238, 0.62), rgba(255, 253, 248, 0.9));
}

.standings-table tbody tr:hover {
  transform: translateX(2px);
}

.standings-table td {
  border-color: rgba(203, 222, 211, 0.65);
}

.standings-table td:nth-child(6),
.standings-table td:nth-child(7),
.standings-table td:nth-child(8) {
  color: var(--court-dark);
  font-weight: 800;
}

.standings-table td:nth-child(7),
.standings-table td:nth-child(8) {
  color: #8a542c;
}

.metric-strip,
.page-count {
  padding: 7px 11px;
  border: 1px solid rgba(203, 222, 211, 0.72);
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.72);
}

.view-note {
  border-color: rgba(203, 222, 211, 0.9);
  background: linear-gradient(135deg, #edf8f1, #fffdf8);
}

.date-pending-note,
.time-pill {
  border: 1px solid rgba(0, 122, 61, 0.10);
}

.score-chip {
  border: 1px solid rgba(185, 111, 57, 0.14);
  color: var(--clay);
}

.participant-link {
  color: var(--court-dark);
}

.participant-link:hover {
  color: var(--court);
}

.detail-stat-grid div {
  position: relative;
  overflow: hidden;
}

.detail-stat-grid div::after {
  position: absolute;
  right: -16px;
  bottom: -18px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background:
    linear-gradient(60deg, transparent 43%, rgba(255, 255, 255, 0.72) 45%, transparent 49%),
    radial-gradient(circle, rgba(217, 255, 79, 0.13), transparent 68%);
  content: "";
}

.detail-stat-grid strong {
  color: var(--court-dark);
}

.detail-match-card h3 {
  color: var(--ink);
}

@media (max-width: 760px) {
  .subpage-hero {
    margin-top: -10px;
  }

  .subpage-hero-inner {
    min-height: 150px;
    align-items: start;
    flex-direction: column;
    justify-content: flex-end;
    padding: 22px 18px;
    border-radius: 18px;
  }

  .subpage-hero h2 {
    font-size: clamp(28px, 11vw, 42px);
  }

  .subpage-hero-note {
    text-align: left;
  }

  .surface {
    border-radius: 18px;
  }

  .day-block,
  .round-block {
    padding: 16px;
  }

  .day-title,
  .round-title {
    margin: -16px -16px 14px;
    padding: 14px 16px;
    border-radius: 18px 18px 0 0;
  }

  .nav-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
  }

  .nav-tab {
    flex: 0 0 auto;
  }
}
