:root {
  --window-bg: #e2eaf3;
  --panel-bg: #d8e2ed;
  --panel-dark-bg: #8b9caf;
  --panel-dark-fg: #f3f6fa;
  --card-bg: #e9f0f7;
  --card-fg: #26374a;
  --text-primary: #26374a;
  --header-bg: #c3cfdd;
  --border: #99abc0;
  --row-even: #f3f7fc;
  --row-odd: #e7eef7;
  --button-bg: #c7d2de;
  --button-active-bg: #b8c6d6;
  --ghost-bg: #edf3fa;
  --success-bg: #e7fff4;
  --error-bg: #ffe9ea;
  --link: #285787;
  --self: #fff0bf;
  --rival: #dff6ef;
}

body.theme-dark {
  --window-bg: #111a24;
  --panel-bg: #182535;
  --panel-dark-bg: #22364a;
  --panel-dark-fg: #eef5ff;
  --card-bg: #1a2837;
  --card-fg: #e4eefb;
  --text-primary: #e4eefb;
  --header-bg: #2b3b4f;
  --border: #4d657d;
  --row-even: #203041;
  --row-odd: #172432;
  --button-bg: #294056;
  --button-active-bg: #34506a;
  --ghost-bg: #1d2b3a;
  --success-bg: #143325;
  --error-bg: #442127;
  --link: #8ec4ff;
  --self: #5b4a1e;
  --rival: #1d4b3e;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--window-bg);
  color: var(--text-primary);
  font-family: "Segoe UI", Tahoma, sans-serif;
  overflow-x: hidden;
}

body.theme-dark .app-panel p,
body.theme-dark .panel p,
body.theme-dark .muted,
body.theme-dark .muted-copy,
body.theme-dark .panel-note,
body.theme-dark .summary-strip dt,
body.theme-dark .filter-label,
body.theme-dark .tier-summary-label {
  color: #b7c7d8;
}

body.theme-dark .site-header {
  background: rgba(17, 26, 36, 0.96);
}

body.theme-dark .home-score-card {
  background: linear-gradient(180deg, #1f3041 0%, #182736 100%);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.24);
}

body.theme-dark .home-score-title {
  background: linear-gradient(180deg, #24384b 0%, #1d2e3f 100%);
  border-bottom-color: #425a73;
}

body.theme-dark .home-score-jacket-bubble,
body.theme-dark .home-score-jacket-art,
body.theme-dark .jacket-thumb,
body.theme-dark .jacket-large,
body.theme-dark .jacket-hero,
body.theme-dark .browse-jacket-square,
body.theme-dark .jacket-placeholder {
  background: #0f1720;
}

body.theme-dark input,
body.theme-dark select {
  background: #142130;
  color: var(--text-primary);
  border-color: var(--border);
}

body.theme-dark input::placeholder {
  color: #9eb0c4;
}

body.theme-dark .profile-menu-dropdown,
body.theme-dark .score-card-link,
body.theme-dark .mini-profile-card,
body.theme-dark .difficulty-card,
body.theme-dark .rank-chip,
body.theme-dark .activity-card,
body.theme-dark .summary-strip div,
body.theme-dark .metric-pill,
body.theme-dark .mini-stat,
body.theme-dark .tier-summary-card,
body.theme-dark .browse-counter-value {
  background: var(--row-even);
}

body.theme-dark .home-score-title span,
body.theme-dark .browse-song-title,
body.theme-dark .brand,
body.theme-dark .site-nav a,
body.theme-dark .site-nav button,
body.theme-dark .profile-menu-dropdown a,
body.theme-dark .profile-menu-action,
body.theme-dark .settings-switch-label {
  color: var(--text-primary);
}

body.theme-dark .browse-song-series,
body.theme-dark .browse-difficulty-tag,
body.theme-dark .compare-empty,
body.theme-dark .filter-clear-link,
body.theme-dark .eyebrow,
body.theme-dark .browse-counter-label,
body.theme-dark .leaderboard-subhead {
  color: #b7c7d8;
}

body.theme-dark .filter-clear-link:hover,
body.theme-dark a:hover {
  color: #b9dbff;
}

body.theme-dark .toggle-pill span {
  background: var(--button-bg);
  color: var(--text-primary);
}

body.theme-dark .toggle-pill.is-selected span {
  background: var(--button-active-bg);
}

body.theme-dark .settings-switch-ui {
  background: #40556b;
}

body.theme-dark .settings-switch input:checked + .settings-switch-ui {
  background: #6aa9f1;
  border-color: #6aa9f1;
}

body.theme-dark .settings-switch-ui::after {
  background: #eef5ff;
}

body.theme-dark .tier-requirement.is-complete {
  background: #173428;
}

body.theme-dark .tier-star {
  color: #f2be6b;
}

body.theme-dark .home-score-jacket-art,
body.theme-dark .browse-jacket-square,
body.theme-dark .jacket-thumb,
body.theme-dark .jacket-large,
body.theme-dark .jacket-hero {
  border-color: #4d657d;
}

a {
  color: var(--link);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

img {
  display: block;
  max-width: 100%;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(226, 234, 243, 0.96);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(10px);
}

.site-header-inner {
  width: min(1320px, calc(100% - 24px));
  margin: 0 auto;
  padding: 14px 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.brand {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
}

.site-nav {
  display: flex;
  flex-wrap: wrap;
  min-width: 0;
  align-items: center;
  gap: 10px;
}

.site-nav a,
.site-nav button {
  font-weight: 700;
}

.site-nav form {
  margin: 0;
}

.profile-menu {
  position: relative;
}

.profile-menu-trigger {
  width: 46px;
  height: 46px;
  padding: 0;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--ghost-bg);
}

.profile-menu-trigger img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}

.profile-menu-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 190px;
  display: none;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--card-bg);
  box-shadow: 0 12px 30px rgba(38, 55, 74, 0.16);
}

.profile-menu:hover .profile-menu-dropdown,
.profile-menu:focus-within .profile-menu-dropdown,
.profile-menu.is-open .profile-menu-dropdown {
  display: grid;
  gap: 2px;
}

.profile-menu-dropdown a,
.profile-menu-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 10px 12px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--text-primary);
  text-align: left;
  font: inherit;
  font-weight: 700;
}

.profile-menu-dropdown a:hover,
.profile-menu-action:hover {
  background: var(--row-even);
  text-decoration: none;
}

.notification-bubble,
.menu-notification-bubble {
  display: inline-grid;
  place-items: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  border: 2px solid var(--card-bg);
  background: #ef3450;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 2px 8px rgba(11, 22, 34, 0.26);
}

.profile-notification-bubble {
  position: absolute;
  top: -5px;
  right: -5px;
  z-index: 5;
}

.menu-notification-bubble {
  flex: 0 0 auto;
}

.notification-list {
  display: grid;
  gap: 10px;
}

.notification-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card-bg);
  color: var(--text-primary);
}

.notification-item:hover {
  text-decoration: none;
  background: var(--row-even);
}

.notification-item.is-unread {
  border-color: var(--accent);
  box-shadow: inset 4px 0 0 var(--accent);
}

.notification-title {
  font-weight: 900;
}

.notification-body {
  margin-top: 4px;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 700;
}

.notification-time {
  flex: 0 0 auto;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

@media (max-width: 640px) {
  .notification-item {
    display: grid;
    gap: 8px;
  }

  .notification-time {
    white-space: normal;
  }
}

.solid-link,
button {
  appearance: none;
  border: 1px solid var(--border);
  background: var(--button-bg);
  color: var(--text-primary);
  padding: 10px 14px;
  border-radius: 12px;
  cursor: pointer;
  font: inherit;
}

button:hover,
.solid-link:hover {
  background: var(--button-active-bg);
  text-decoration: none;
}

.ghost,
.ghost-button {
  background: var(--ghost-bg);
}

.page-shell {
  width: min(1320px, calc(100% - 24px));
  margin: 0 auto;
  padding: 16px 0 28px;
  min-width: 0;
  overflow-x: clip;
}

.flash-stack {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.flash {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 700;
}

.flash-success {
  background: var(--success-bg);
}

.flash-error {
  background: var(--error-bg);
}

.app-panel,
.panel,
.empty-panel {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 8px 18px rgba(38, 55, 74, 0.08);
  min-width: 0;
}

.empty-panel {
  color: var(--text-primary);
}

.card-hero {
  background: linear-gradient(180deg, #eef4fa 0%, var(--card-bg) 100%);
}

.card-grid,
.stats-grid {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
}

.stats-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.home-intro,
.dashboard-hero,
.song-header,
.dashboard-columns {
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.8fr);
  margin-bottom: 16px;
}

.home-intro h1,
.panel h1,
.app-panel h1 {
  margin: 0 0 10px;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.08;
}

.app-panel h2,
.panel h2 {
  margin: 0 0 6px;
  font-size: 28px;
}

.panel h3,
.app-panel h3 {
  margin: 0 0 8px;
  font-size: 20px;
}

.app-panel p,
.panel p,
.muted,
.muted-copy,
.panel-note {
  color: #4f647d;
}

.summary-strip,
.profile-stat-list,
.pill-row,
.hero-actions,
.inline-form,
.activity-meta,
.section-heading {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.summary-strip {
  margin: 0;
  justify-content: flex-start;
}

.summary-strip div,
.mini-stat,
.metric-pill,
.rank-chip {
  min-width: 120px;
  padding: 14px 16px;
  background: var(--row-even);
  border: 1px solid var(--border);
  border-radius: 14px;
}

.summary-strip dt {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #5d6f83;
}

.summary-strip dd,
.mini-stat strong,
.metric-pill strong,
.rank-chip strong {
  margin: 6px 0 0;
  font-size: 28px;
  font-weight: 800;
}

.feed-section {
  margin-bottom: 18px;
  content-visibility: auto;
  contain-intrinsic-size: 520px;
}

.users-search-panel {
  display: grid;
  gap: 12px;
}

.users-search-panel .search-field {
  width: 100%;
}

.users-search-toolbar {
  display: flex;
  justify-content: flex-end;
}

.users-detailed-link {
  justify-self: end;
}

.eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #5d6f83;
}

.section-heading {
  justify-content: space-between;
  margin-bottom: 10px;
}

.section-heading h2 {
  margin: 0 0 4px;
  font-size: 24px;
}

.section-heading p {
  margin: 0;
}

.feed-section .section-heading {
  justify-content: center;
  text-align: center;
}

.feed-section .section-heading > div {
  display: grid;
  justify-items: center;
  gap: 4px;
}

.home-news-ticker {
  width: min(100%, 854px);
  margin: 0 auto 16px;
  border: 1px solid rgba(49, 115, 181, 0.22);
  border-radius: 12px;
  background: #f3f7fc;
  box-shadow: 0 8px 18px rgba(38, 55, 74, 0.08);
  overflow: hidden;
}

.home-news-ticker-track {
  max-height: 126px;
  overflow: auto;
}

.home-news-ticker-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: baseline;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(153, 171, 192, 0.35);
  font-size: 14px;
  font-weight: 750;
  line-height: 1.35;
  color: var(--text-primary);
}

.home-news-ticker-text {
  min-width: 0;
}

.home-news-ticker-time {
  color: #6f7c8a;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.home-news-ticker-part-user,
.home-news-ticker-part-song,
.home-news-ticker-part-score,
.home-news-ticker-part-chart,
.home-news-ticker-part-placement,
.home-news-ticker-part-requirement,
.home-news-ticker-part-tier {
  font-weight: 950;
}

a.home-news-ticker-part {
  text-decoration: none;
}

a.home-news-ticker-part:hover {
  text-decoration: underline;
}

.home-news-ticker-part-user {
  color: #2e73b8;
}

.home-news-ticker-part-song {
  color: #2e73b8;
}

.home-news-ticker-part-chart {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 999px;
  background: rgba(49, 115, 181, 0.10);
  font-size: 12px;
  line-height: 1.35;
  white-space: nowrap;
}

.home-news-ticker-part-chart.home-news-ticker-part-rating-d1 {
  color: #F5A623;
  background: rgba(245, 166, 35, 0.13);
}

.home-news-ticker-part-chart.home-news-ticker-part-rating-d2 {
  color: #238dc8;
  background: rgba(110, 198, 255, 0.14);
}

.home-news-ticker-part-chart.home-news-ticker-part-rating-d3 {
  color: #E53935;
  background: rgba(229, 57, 53, 0.12);
}

.home-news-ticker-part-chart.home-news-ticker-part-rating-d4 {
  color: #8E44AD;
  background: rgba(142, 68, 173, 0.13);
}

.home-news-ticker-part-chart.home-news-ticker-part-rating-d5 {
  color: #49C15A;
  background: rgba(73, 193, 90, 0.13);
}

body.game-asc .home-news-ticker-part-chart.home-news-ticker-part-rating-d1 {
  color: #49C15A;
  background: rgba(73, 193, 90, 0.13);
}

body.game-asc .home-news-ticker-part-chart.home-news-ticker-part-rating-d2 {
  color: #F5A623;
  background: rgba(245, 166, 35, 0.13);
}

body.game-asc .home-news-ticker-part-chart.home-news-ticker-part-rating-d3 {
  color: #238dc8;
  background: rgba(110, 198, 255, 0.14);
}

body.game-asc .home-news-ticker-part-chart.home-news-ticker-part-rating-d4 {
  color: #E53935;
  background: rgba(229, 57, 53, 0.12);
}

body.game-asc .home-news-ticker-part-chart.home-news-ticker-part-rating-d5 {
  color: #8E44AD;
  background: rgba(142, 68, 173, 0.13);
}

.home-news-ticker-part-score,
.home-news-ticker-part-placement {
  color: #0f8a63;
}

.home-news-ticker-part-requirement,
.home-news-ticker-part-tier {
  color: #8c4eb5;
}

.home-news-ticker-item:last-child {
  border-bottom: 0;
}

.home-news-ticker-item.is-empty {
  color: var(--text-muted);
}

.home-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(320px, 420px));
  gap: 14px;
  justify-content: center;
}

.home-feed-pager {
  display: grid;
  grid-template-columns: 48px 48px 48px;
  align-items: center;
  justify-content: center;
  width: min(100%, 854px);
  min-height: 36px;
  margin: 12px auto 0;
}

.home-feed-pager.is-hidden {
  display: none;
}

.home-feed-page-button {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  padding: 0;
  border: 1px solid rgba(49, 115, 181, 0.26);
  border-radius: 999px;
  background: #f3f7fc;
  color: var(--text-primary);
  cursor: pointer;
  box-shadow: 0 6px 14px rgba(38, 55, 74, 0.08);
}

.home-feed-page-button::before {
  content: "";
  width: 9px;
  height: 9px;
  border-top: 3px solid currentColor;
  border-right: 3px solid currentColor;
}

.home-feed-page-slot {
  width: 48px;
  height: 36px;
  display: grid;
  align-items: center;
}

.home-feed-page-slot-prev {
  justify-items: end;
}

.home-feed-page-slot-next {
  justify-items: start;
}

.home-feed-page-button-prev {
  justify-self: end;
}

.home-feed-page-button-prev::before {
  transform: translateX(2px) rotate(-135deg);
}

.home-feed-page-button-next {
  justify-self: start;
}

.home-feed-page-button-next::before {
  transform: translateX(-2px) rotate(45deg);
}

.home-feed-page-button:hover:not(:disabled) {
  transform: translateY(-1px);
}

.home-feed-page-button:disabled {
  cursor: default;
  opacity: 0.72;
}

.home-feed-page-button.is-hidden {
  visibility: hidden;
  pointer-events: none;
}

.home-feed-page-label {
  width: 48px;
  text-align: center;
  color: var(--text-muted);
  font-size: 14px;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}

.home-score-card {
  position: relative;
  width: min(100%, 420px);
  height: 156px;
  display: grid;
  grid-template-columns: 30px 108px minmax(0, 1fr);
  grid-template-rows: 42px minmax(0, 1fr);
  grid-template-areas:
    "accent title title"
    "accent jacket body";
  gap: 0;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: linear-gradient(180deg, #f3f7fc 0%, #e5edf6 100%);
  box-shadow: 0 8px 18px rgba(38, 55, 74, 0.08);
  overflow: hidden;
  cursor: pointer;
  justify-self: center;
}

.home-score-hitbox {
  position: absolute;
  inset: 0;
  z-index: 3;
  border-radius: inherit;
}

.home-score-hitbox:hover {
  text-decoration: none;
}

.home-score-card > :not(.home-score-hitbox) {
  position: relative;
  z-index: 2;
}

.home-score-card > .home-score-style-badge {
  position: absolute;
  top: 1px;
  left: 1px;
  z-index: 6;
  width: 28px;
  height: 28px;
  pointer-events: none;
}

.home-score-style-icon {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.pair-play-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.pair-play-toggle[hidden] {
  display: none;
}

.pair-play-toggle button,
.pair-play-toggle .pair-play-toggle-button {
  display: grid;
  place-items: center;
  min-width: 34px;
  height: 30px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card-bg);
  color: var(--text-muted);
  font-weight: 900;
  line-height: 1;
  text-align: center;
  cursor: pointer;
  text-decoration: none;
}

.pair-play-toggle button.is-active,
.pair-play-toggle .pair-play-toggle-button.is-active {
  background: var(--link);
  border-color: var(--link);
  color: #fff;
}

.home-score-accent {
  grid-area: accent;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.18);
}

.home-score-accent span {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 15px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: 0.04em;
  color: #fff;
  white-space: nowrap;
}

.home-score-accent.rating-d1 {
  background: linear-gradient(180deg, #f7ba4f 0%, #d98d00 100%);
}

.home-score-accent.rating-d2 {
  background: linear-gradient(180deg, #74d3ff 0%, #238dc8 100%);
}

.home-score-accent.rating-d3 {
  background: linear-gradient(180deg, #ef6a64 0%, #ba221d 100%);
}

.home-score-accent.rating-d4 {
  background: linear-gradient(180deg, #a76ad7 0%, #6a2c99 100%);
}

.home-score-accent.rating-d5 {
  background: linear-gradient(180deg, #49c15a 0%, #1f8a37 100%);
}

body.game-asc .home-score-accent.rating-d1 {
  background: linear-gradient(180deg, #49c15a 0%, #1f8a37 100%);
}

body.game-asc .home-score-accent.rating-d2 {
  background: linear-gradient(180deg, #f7ba4f 0%, #d98d00 100%);
}

body.game-asc .home-score-accent.rating-d3 {
  background: linear-gradient(180deg, #74d3ff 0%, #238dc8 100%);
}

body.game-asc .home-score-accent.rating-d4 {
  background: linear-gradient(180deg, #ef6a64 0%, #ba221d 100%);
}

body.game-asc .home-score-accent.rating-d5 {
  background: linear-gradient(180deg, #a76ad7 0%, #6a2c99 100%);
}

.home-score-jacket {
  grid-area: jacket;
  display: grid;
  place-items: center;
  position: relative;
  width: 92px;
  height: 92px;
  padding: 0;
  overflow: visible;
  pointer-events: none;
  z-index: 4;
  align-self: center;
  justify-self: center;
}

.home-score-jacket-bubble {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: transparent;
  overflow: hidden;
}

.home-score-jacket-art {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 0;
  border: 0;
  background: transparent;
}

.home-score-jacket img.home-score-jacket-frame {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%);
  object-fit: contain;
  border-radius: 0;
  border: 0;
  background: transparent;
  pointer-events: none;
  z-index: 3;
}

.home-score-title {
  grid-area: title;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px 0 18px;
  background: linear-gradient(180deg, #edf3fa 0%, #dce6f1 100%);
  border-bottom: 1px solid #b4c5d8;
}

.home-score-main {
  grid-area: body;
  min-width: 0;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 6px;
  text-align: center;
  padding: 10px 16px 12px 8px;
}

.home-score-title span {
  display: block;
  width: 100%;
  color: var(--text-primary);
  font-size: 21px;
  font-weight: 800;
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-align: center;
}

.home-score-meta a:hover {
  text-decoration: none;
}

.home-score-meta,
.home-score-submeta {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.1;
}

.home-score-meta a {
  color: var(--link);
  position: relative;
  z-index: 4;
}

.home-score-meta a,
.home-score-value,
.home-score-submeta {
  text-align: center;
}

.home-score-submeta {
  color: #5d6f83;
}

.home-score-value {
  font-size: 28px;
  font-weight: 900;
  line-height: 1;
  color: var(--text-primary);
}

.score-feed {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(340px, 420px);
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 6px;
}

.score-feed-item {
  display: grid;
  gap: 8px;
}

.score-card-link {
  display: block;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: #dfe7f1;
}

.score-card-link img {
  width: 100%;
  height: auto;
}

.feed-meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 14px;
}

.filter-bar,
.stack-form,
.suggestions-block,
.mini-card-grid,
.difficulty-breakdown,
.rank-chip-grid,
.activity-list,
.auth-shell {
  display: grid;
  gap: 12px;
}

.filter-bar {
  grid-template-columns: minmax(0, 1.6fr) minmax(220px, 0.8fr) auto;
  align-items: end;
}

.stack-form {
  max-width: 460px;
}

label {
  display: grid;
  gap: 6px;
  font-weight: 700;
}

.check-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
}

.check-row input {
  width: 18px;
  height: 18px;
  padding: 0;
}

input,
select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #f8fbfe;
  color: var(--text-primary);
  font: inherit;
}

.table-shell {
  overflow-x: auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--row-even);
}

table {
  width: 100%;
  min-width: 860px;
  border-collapse: collapse;
}

thead th {
  padding: 12px;
  text-align: left;
  background: var(--header-bg);
  color: var(--text-primary);
  border-bottom: 1px solid var(--border);
}

tbody td {
  padding: 12px;
  border-top: 1px solid rgba(153, 171, 192, 0.55);
  vertical-align: middle;
}

tbody tr:nth-child(even) {
  background: var(--row-odd);
}

.song-table td,
.song-table th {
  white-space: nowrap;
}

.jacket-cell {
  width: 88px;
}

.jacket-thumb {
  width: 64px;
  height: 64px;
  object-fit: contain;
  aspect-ratio: 1 / 1;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
}

.jacket-placeholder {
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
  text-align: center;
  font-size: 12px;
  background: var(--row-odd);
  border: 1px solid var(--border);
  border-radius: 12px;
}

.song-header-jacket {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.song-jacket-frame-wrap {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 320px;
  max-width: 100%;
}

.jacket-large {
  width: 220px;
  max-width: 100%;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: #fff;
}

.song-header-large {
  grid-template-columns: 320px minmax(0, 1fr);
}

.jacket-hero {
  width: 320px;
  max-width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: #fff;
}

.rainbow-sweep-frame {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 3;
  pointer-events: none;
  transform: translate(-50%, -50%);
}

.song-rainbow-sweep-frame {
  width: calc(100% + 42px);
  height: calc(100% + 42px);
  object-fit: contain;
}

.rainbow-sweep-frame.is-hidden {
  display: none;
}

.song-header-copy {
  display: grid;
  gap: 8px;
  align-content: center;
}

.song-header-copy p {
  margin: 0;
}

.song-group-panel {
  margin-bottom: 16px;
}

.song-controls-row {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.song-controls-left,
.song-controls-right {
  display: flex;
  align-items: center;
}

.song-controls-right {
  justify-content: flex-end;
}

.ms-type-badge {
  width: 72px;
  height: 72px;
  object-fit: contain;
}

.style-toggle-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.style-cycle-host {
  display: flex;
  justify-content: center;
  align-items: center;
}

.style-toggle {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.style-toggle img,
.style-cycle-button img {
  width: 148px;
  height: 40px;
  object-fit: contain;
  opacity: 0.58;
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.style-toggle.is-active img,
.style-toggle:hover img,
.style-cycle-button:hover img {
  opacity: 1;
  transform: translateY(-1px);
}

.style-cycle-button {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.style-cycle-button img {
  opacity: 1;
}

.style-cycle-button.is-loading img {
  opacity: 0.52;
 }

.style-table-panel.is-hidden {
  display: none;
}

.style-table-block + .style-table-block {
  margin-top: 14px;
}

.rating-cell {
  font-weight: 800;
  color: #335d96;
}

.rating-d1,
.rating-d1 a {
  color: #F5A623;
}

.rating-d2,
.rating-d2 a {
  color: #6EC6FF;
}

.rating-d3,
.rating-d3 a {
  color: #E53935;
}

.rating-d4,
.rating-d4 a {
  color: #8E44AD;
}

.rating-d5,
.rating-d5 a {
  color: #49C15A;
}

body.game-asc .rating-d1,
body.game-asc .rating-d1 a {
  color: #49C15A;
}

body.game-asc .rating-d2,
body.game-asc .rating-d2 a {
  color: #F5A623;
}

body.game-asc .rating-d3,
body.game-asc .rating-d3 a {
  color: #6EC6FF;
}

body.game-asc .rating-d4,
body.game-asc .rating-d4 a {
  color: #E53935;
}

body.game-asc .rating-d5,
body.game-asc .rating-d5 a {
  color: #8E44AD;
}

.app-song-table-shell {
  overflow: visible;
}

.app-song-table {
  min-width: 0;
  width: 100%;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;
}

.app-song-table th,
.app-song-table td {
  padding: 10px 8px;
  font-size: 13px;
}

.app-song-table thead th:first-child {
  border-top-left-radius: 13px;
}

.app-song-table thead th:last-child {
  border-top-right-radius: 13px;
}

@media (min-width: 881px) {
  .app-song-table tbody tr:nth-child(odd) td {
    background: var(--row-even);
  }

  .app-song-table tbody tr:nth-child(even) td {
    background: var(--row-odd);
  }

  .app-song-table tbody tr:last-child td:first-child {
    border-bottom-left-radius: 13px;
  }

  .app-song-table tbody tr:last-child td:last-child {
    border-bottom-right-radius: 13px;
  }
}

.app-song-table .col-rating,
.app-song-table .rating-cell {
  width: 72px;
  text-align: center;
}

.app-song-table .col-badge,
.app-song-table .song-badge-cell,
.app-song-table .col-crown,
.app-song-table .song-crown-cell,
.app-song-table .col-rank,
.app-song-table .song-rank-cell,
.app-song-table .col-played,
.app-song-table .song-played-cell {
  text-align: center;
}

.app-song-table .col-date,
.app-song-table .song-date-cell {
  white-space: nowrap;
}

.self-row {
  background: var(--self) !important;
}

.rival-row {
  background: var(--rival) !important;
}

.mini-card-grid,
.difficulty-breakdown,
.rank-chip-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.mini-profile-card,
.difficulty-card,
.rank-chip {
  background: var(--row-even);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
}

.mini-profile-card form {
  margin: 0;
}

.difficulty-card dl {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
}

.difficulty-card dl div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.rank-chip {
  text-align: center;
}

.activity-list {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.activity-tight {
  grid-template-columns: 1fr;
}

.activity-card {
  background: var(--row-even);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
}

.activity-meta {
  justify-content: space-between;
  font-size: 13px;
}

.activity-score {
  margin-top: 8px;
  font-size: 24px;
  font-weight: 800;
}

.auth-shell {
  max-width: 540px;
  margin: 20px auto 0;
}

.ghost-button:disabled {
  cursor: default;
  opacity: 0.72;
}

.song-detail-backbar {
  margin-bottom: 10px;
}

.browse-filter-form {
  display: grid;
  gap: 8px;
}

.filter-row {
  display: grid;
  gap: 6px;
  align-content: start;
}

.dynamic-filter-row {
  align-items: start;
}

.main-mode-row {
  justify-content: center;
}

.is-hidden {
  display: none !important;
}

.filter-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #5d6f83;
}

.compact-label {
  margin-right: 2px;
}

.toggle-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.toggle-pill {
  display: inline-flex;
  align-items: center;
  position: relative;
  cursor: pointer;
}

.toggle-pill input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  border: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

.toggle-pill span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--button-bg);
  font-weight: 700;
  font-size: 13px;
}

.toggle-pill.is-selected span {
  background: var(--button-active-bg);
}

.inline-filter-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}

.series-select {
  width: min(420px, 100%);
}

.rating-mode-row {
  justify-content: center;
}

.permanent-filter-row {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

.filter-strip-group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.compact-toggle-row {
  gap: 4px;
}

.inline-field {
  display: grid;
  gap: 4px;
  font-weight: 700;
}

.small-field {
  max-width: 180px;
}

.filter-row-search {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 8px;
}

.search-field {
  min-width: 0;
}

.browse-filter-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.browse-counter-row {
  display: grid;
  grid-template-columns: repeat(7, minmax(68px, 88px));
  justify-content: center;
  gap: 6px 10px;
  padding-top: 2px;
}

.browse-counter-item {
  display: grid;
  gap: 4px;
  justify-items: center;
}

.browse-counter-label {
  font-size: 11px;
  font-weight: 800;
  color: #5d6f83;
}

.browse-counter-value {
  width: 100%;
  padding: 6px 8px;
  border: 1px solid var(--border);
  background: var(--row-even);
  color: var(--text-primary);
  text-align: center;
  font-size: 16px;
  font-weight: 900;
  border-radius: 10px;
}

.filter-clear-link {
  appearance: none;
  border: 0;
  background: transparent;
  color: #5d6f83;
  font: inherit;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 2px;
  border-radius: 8px;
  cursor: pointer;
  opacity: 0.78;
}

.filter-clear-link:hover {
  background: transparent;
  color: var(--link);
  opacity: 1;
  text-decoration: underline;
}

.browse-table-panel {
  padding-top: 14px;
}

.browse-table-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.browse-toolbar-left {
  min-height: 40px;
  display: flex;
  align-items: center;
}

.rival-compare-field {
  max-width: 260px;
}

.browse-style-host {
  justify-content: flex-end;
}

.browse-table-shell {
  overflow-x: auto;
  overflow-y: hidden;
}

.browse-chart-table {
  width: 100%;
  min-width: 980px;
  table-layout: auto;
}

.browse-chart-table.is-public {
  table-layout: fixed;
  min-width: 600px;
}

.browse-chart-table.is-public .col-jacket,
.browse-chart-table.is-public .browse-jacket-table-cell {
  width: 84px;
  max-width: 84px;
}

.browse-chart-table.is-public .col-rating {
  width: 56px;
  max-width: 56px;
}

.browse-chart-table.is-public .col-ms,
.browse-chart-table.is-public .browse-ms-table-cell {
  width: 72px;
  max-width: 72px;
}

.browse-chart-table.is-public .col-index,
.browse-chart-table.is-public .browse-index-cell {
  width: 42px;
  max-width: 42px;
}

.browse-chart-table.is-public .col-players,
.browse-chart-table.is-public .col-topscore {
  width: 100px;
  max-width: 100px;
}

.browse-chart-table th,
.browse-chart-table td {
  padding: 10px 8px;
  font-size: 13px;
  overflow: hidden;
}

.browse-chart-table th,
.browse-chart-table td {
  text-align: center;
}

.browse-chart-table .col-title,
.browse-chart-table .browse-title-table-cell {
  text-align: left;
}

.browse-chart-table .col-index,
.browse-chart-table .browse-index-cell {
  width: 42px;
}

.browse-chart-table .col-jacket,
.browse-chart-table .browse-jacket-table-cell {
  width: 84px;
}

.browse-chart-table .col-rating {
  width: 56px;
}

.browse-chart-table .col-ms,
.browse-chart-table .browse-ms-table-cell {
  width: 72px;
}

.browse-chart-table .col-badge,
.browse-chart-table .col-crown,
.browse-chart-table .col-rank,
.browse-chart-table .col-chain,
.browse-chart-table .col-damage,
.browse-chart-table .col-played,
.browse-chart-table .col-score,
.browse-chart-table .col-topscore,
.browse-chart-table .col-players,
.browse-chart-table .col-date,
.browse-chart-table .col-compare {
  width: 88px;
}

.browse-jacket-square {
  width: 64px;
  height: 64px;
  object-fit: contain;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: #fff;
}

.browse-jacket-frame-wrap {
  position: relative;
  display: inline-grid;
  place-items: center;
}

.browse-rainbow-sweep-frame {
  width: calc(100% + 16px);
  height: calc(100% + 16px);
  object-fit: contain;
}

.browse-title-table-cell {
  min-width: 0;
}

.browse-song-title {
  display: block;
  font-size: 18px;
  font-weight: 800;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.browse-song-title:hover {
  color: var(--link);
}

.browse-song-series {
  color: #4f647d;
  font-size: 12px;
  margin-top: 4px;
}

.browse-difficulty-tag {
  margin-top: 4px;
  color: #5d6f83;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.browse-ms-asset {
  width: 72px;
  height: 72px;
  object-fit: contain;
}

.browse-score-cell,
.browse-topscore-cell,
.browse-chain-cell,
.browse-compare-cell {
  font-weight: 800;
}

.browse-compare-cell strong {
  display: inline;
  font-size: 14px;
}

.score-proof-buttons {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-height: 0;
  margin: 0 0 0 5px;
  vertical-align: -0.08em;
}

.score-proof-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  height: 1em;
  min-width: 14px;
  min-height: 14px;
  max-width: 16px;
  max-height: 16px;
  padding: 0;
  border: 0;
  border-radius: 4px;
  background: transparent;
  opacity: 0.92;
}

.score-proof-button:hover {
  opacity: 1;
  text-decoration: none;
}

.score-proof-button img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.image-preview-popover-shell[hidden] {
  display: none;
}

.image-preview-popover-shell {
  position: fixed;
  inset: 0;
  z-index: 1800;
  pointer-events: none;
}

.image-preview-popover-backdrop {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  pointer-events: auto;
}

.image-preview-popover-backdrop:hover,
.image-preview-popover-backdrop:focus,
.image-preview-popover-backdrop:focus-visible,
.image-preview-popover-backdrop:active {
  background: transparent;
  outline: none;
  box-shadow: none;
}

.image-preview-popover {
  position: fixed;
  left: 50%;
  top: 50%;
  width: auto;
  max-width: calc(100vw - 24px);
  max-height: min(65vh, 760px);
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
  box-shadow: none;
  transform: translate(-50%, -50%);
  pointer-events: auto;
}

.image-preview-popover.is-video {
  width: min(65vw, 960px);
  aspect-ratio: 16 / 9;
  max-height: min(65vh, 760px);
  background: #000;
  box-shadow: 0 22px 60px rgba(8, 12, 24, 0.36);
}

.image-preview-close {
  position: absolute;
  top: 6px;
  right: 6px;
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.5);
  background: rgba(8, 12, 24, 0.76);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  z-index: 2;
}

.image-preview-link {
  display: block;
  width: auto;
  max-width: min(65vw, 960px);
  max-height: min(65vh, 760px);
  cursor: zoom-in;
}

.image-preview-image {
  display: block;
  width: auto;
  max-width: min(65vw, 960px);
  max-height: min(65vh, 760px);
  object-fit: contain;
  border-radius: 6px;
  background: transparent;
  box-shadow: 0 22px 60px rgba(8, 12, 24, 0.28);
}

.image-preview-video,
.image-preview-frame {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: 8px;
  background: #000;
}

.image-preview-video[hidden] {
  display: none;
}

.compare-owner {
  display: block;
  margin-bottom: 2px;
  color: #5f6f82;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.15;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.browse-user-heading {
  margin: 0 0 14px;
}

.browse-user-heading h1 {
  margin: 0;
  font-size: 28px;
  line-height: 1.15;
}

.compare-delta {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  font-weight: 800;
}

.browse-mobile-ms {
  display: none;
}

.browse-mobile-badge {
  display: grid;
  min-height: 36px;
  place-items: center;
  font-weight: 900;
}

.compare-delta.is-up {
  color: #2e7d32;
}

.compare-delta.is-down {
  color: #c62828;
}

.compare-delta.is-even,
.compare-empty {
  color: #6d7d90;
}

#browse-no-results {
  margin-top: 12px;
}

.tier-page-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}

.tier-summary-panel {
  margin-top: 16px;
}

.tier-summary-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, 260px);
  gap: 16px;
  align-items: end;
  margin-bottom: 14px;
}

.tier-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.tier-summary-card {
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--row-even);
}

.tier-summary-card strong {
  display: block;
  margin-top: 6px;
  font-size: 24px;
}

.tier-summary-label {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #5d6f83;
}

.tier-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.tier-requirement-list {
  display: grid;
  gap: 8px;
}

.tier-requirement {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--row-odd);
}

.tier-requirement.is-complete {
  background: #e7f5ea;
}

.tier-requirement-progress {
  font-weight: 800;
}

.tier-star {
  color: #d17b00;
  font-weight: 900;
  margin-right: 4px;
}

.tier-ranking-panel {
  margin-top: 16px;
}

.tier-table {
  min-width: 0;
  table-layout: fixed;
}

.tier-self-tag {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--button-active-bg);
  font-size: 11px;
  font-weight: 800;
}

.song-detail-header {
  margin-bottom: 16px;
}

.app-song-table-shell,
.leaderboard-table-shell {
  overflow: hidden;
}

.app-song-table,
.leaderboard-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.app-song-table th,
.app-song-table td,
.leaderboard-table th,
.leaderboard-table td {
  padding: 10px 8px;
  font-size: 13px;
}

.app-song-table th:nth-child(1),
.app-song-table td:nth-child(1) {
  width: 70px;
  text-align: center;
}

.app-song-table th:nth-child(2),
.app-song-table td:nth-child(2),
.app-song-table th:nth-child(3),
.app-song-table td:nth-child(3),
.app-song-table th:nth-child(4),
.app-song-table td:nth-child(4),
.app-song-table th:nth-child(8),
.app-song-table td:nth-child(8) {
  text-align: center;
}

.app-song-table th:nth-child(9),
.app-song-table td:nth-child(9) {
  white-space: nowrap;
}

.leaderboard-panel {
  margin-top: 16px;
}

.leaderboard-controls {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 16px;
  align-items: end;
  margin-bottom: 12px;
}

.leaderboard-difficulty-field {
  max-width: 280px;
}

.leaderboard-style-bar {
  justify-content: flex-start;
}

.leaderboard-table-panel.is-hidden {
  display: none;
}

.leaderboard-subhead {
  margin-bottom: 10px;
  font-size: 14px;
  font-weight: 800;
  color: #4f647d;
}

.leaderboard-table .col-position,
.leaderboard-table .leaderboard-position-cell,
.leaderboard-table .col-score,
.leaderboard-table .leaderboard-score-cell,
.leaderboard-table .col-rank,
.leaderboard-table .leaderboard-rank-cell,
.leaderboard-table .col-badge,
.leaderboard-table .leaderboard-badge-cell,
.leaderboard-table .col-crown,
.leaderboard-table .leaderboard-crown-cell,
.leaderboard-table .col-played,
.leaderboard-table .leaderboard-played-cell {
  text-align: center;
}

.leaderboard-table .col-date,
.leaderboard-table .leaderboard-date-cell {
  white-space: nowrap;
}

.leaderboard-table-panel[data-board-sort="score"] .col-damage,
.leaderboard-table-panel[data-board-sort="score"] .leaderboard-damage-cell {
  display: none;
}

.leaderboard-table-panel[data-board-sort="max_damage"] .col-score,
.leaderboard-table-panel[data-board-sort="max_damage"] .leaderboard-score-cell {
  display: none;
}

.settings-form {
  max-width: 1220px;
}

.settings-group {
  display: grid;
  gap: 10px;
  padding-bottom: 6px;
}

.settings-switch {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: fit-content;
  cursor: pointer;
  font-weight: 700;
}

.settings-switch input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

.settings-switch-ui {
  position: relative;
  width: 48px;
  height: 28px;
  border-radius: 999px;
  background: #94a7bc;
  border: 1px solid var(--border);
  transition: background 0.18s ease, border-color 0.18s ease;
}

.settings-switch-ui::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.22);
  transition: transform 0.18s ease;
}

.settings-switch input:checked + .settings-switch-ui {
  background: #3f7cc2;
  border-color: #3f7cc2;
}

.settings-switch input:checked + .settings-switch-ui::after {
  transform: translateX(20px);
}

.settings-switch-label {
  color: var(--text-primary);
}

@media (max-width: 1040px) {
  .home-intro,
  .dashboard-hero,
  .song-header,
  .dashboard-columns {
    grid-template-columns: 1fr;
  }

  .filter-bar {
    grid-template-columns: 1fr;
  }

  .song-controls-row {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .song-controls-right {
    justify-content: center;
  }

  .song-header-large {
    grid-template-columns: 1fr;
  }

  .filter-row-search,
  .leaderboard-controls,
  .tier-summary-head,
  .browse-table-toolbar {
    grid-template-columns: 1fr;
  }

  .inline-filter-row,
  .permanent-filter-row {
    justify-content: flex-start;
  }

  .browse-style-host {
    justify-content: flex-start;
  }

  .tier-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .browse-chart-table th,
  .browse-chart-table td {
    padding: 8px 6px;
    font-size: 12px;
  }

  .browse-chart-table.is-personal .col-ms,
  .browse-chart-table.is-personal .col-crown,
  .browse-chart-table.is-personal .col-rank,
  .browse-chart-table.is-personal .col-chain,
  .browse-chart-table.is-personal .col-damage,
  .browse-chart-table.is-personal .col-played,
  .browse-chart-table.is-personal .col-date,
  .browse-chart-table.is-personal .browse-ms-table-cell,
  .browse-chart-table.is-personal .browse-crown-cell,
  .browse-chart-table.is-personal .browse-rank-cell,
  .browse-chart-table.is-personal .browse-chain-cell,
  .browse-chart-table.is-personal .browse-damage-cell,
  .browse-chart-table.is-personal .browse-played-cell,
  .browse-chart-table.is-personal .browse-date-cell {
    display: none;
  }

  .browse-chart-table .col-jacket,
  .browse-chart-table .browse-jacket-table-cell {
    width: 80px;
  }
}

@media (max-width: 820px) {
  .browse-chart-table.is-personal .col-ms,
  .browse-chart-table.is-personal .col-rank,
  .browse-chart-table.is-personal .col-compare,
  .browse-chart-table.is-personal .browse-ms-table-cell,
  .browse-chart-table.is-personal .browse-rank-cell,
  .browse-chart-table.is-personal .browse-compare-cell {
    display: none;
  }

  .browse-song-title {
    font-size: 16px;
  }

  .tier-requirement {
    grid-template-columns: 1fr;
  }

  .browse-counter-row {
    grid-template-columns: repeat(4, minmax(68px, 88px));
  }
}

@media (max-width: 720px) {
  .site-header-inner,
  .page-shell {
    width: min(100% - 16px, 100%);
  }

  .site-header-inner {
    flex-direction: column;
    align-items: stretch;
  }

  .site-nav {
    width: 100%;
    justify-content: center;
    gap: 10px 12px;
  }

  .site-nav a,
  .site-nav button {
    font-size: 14px;
  }

  .score-feed {
    grid-auto-columns: minmax(280px, 90vw);
  }

  .home-card-grid {
    grid-template-columns: 1fr;
  }

  .home-score-card {
    grid-template-columns: 30px 96px minmax(0, 1fr);
    grid-template-rows: 40px minmax(0, 1fr);
    width: min(100%, 420px);
    height: 144px;
  }

  .home-score-jacket {
    width: 84px;
    height: 84px;
  }

  .home-score-jacket img {
    width: 100%;
    height: 100%;
  }

  .home-score-title {
    padding: 0 12px 0 14px;
  }

  .home-score-title span {
    font-size: 18px;
  }

  .home-score-main {
    padding: 8px 12px 10px 6px;
  }

  .home-score-value {
    font-size: 25px;
  }

  .tier-summary-grid {
    grid-template-columns: 1fr;
  }

  .browse-chart-table .col-index,
  .browse-chart-table td:nth-child(1) {
    display: none;
  }

  .style-toggle img,
  .style-cycle-button img {
    width: 132px;
    height: 36px;
  }

  .browse-counter-row {
    grid-template-columns: repeat(3, minmax(68px, 88px));
  }

  .panel,
  .app-panel,
  .empty-panel {
    padding: 14px;
  }

  .song-header-copy h1,
  .profile-profica-overlay h1 {
    overflow-wrap: anywhere;
  }
}

.brand img {
  display: block;
  width: 110px;
  max-width: 100%;
  height: auto;
}

.home-score-accent-stack {
  display: grid;
  justify-items: center;
  align-content: space-between;
  height: 100%;
  padding: 10px 0;
}

.home-score-side-icon {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.home-score-side-placeholder {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.88);
  color: var(--text-primary);
  font-size: 11px;
  font-weight: 900;
  writing-mode: initial;
  transform: none;
}

.browse-sort-head {
  cursor: pointer;
  user-select: none;
}

.browse-sort-head.is-sorted::after {
  content: " ▲";
  font-size: 11px;
}

.browse-sort-head.is-sorted.is-desc::after {
  content: " ▼";
}

.browse-sort-head.is-sorted.is-difference::after {
  content: " Δ";
}

.browse-status-asset,
.table-status-asset {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.browse-rank-asset,
.table-rank-asset {
  width: 40px;
}

.leaderboard-difficulty-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.leaderboard-difficulty-button {
  min-width: 56px;
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--row-even);
  color: var(--text-primary);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.leaderboard-difficulty-button.is-active,
.leaderboard-sort-button.is-active {
  background: var(--button-active-bg);
}

.leaderboard-sort-row {
  display: flex;
  gap: 8px;
}

.tier-top-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(320px, 0.9fr);
  gap: 16px;
  margin-top: 16px;
}

.tier-focus-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, 260px);
  gap: 16px;
  align-items: end;
  margin-bottom: 14px;
}

.tier-focus-title-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.tier-focus-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}

.tier-focus-meta span {
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--row-even);
  font-weight: 800;
}

.tier-focus-tools {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 12px;
}

.tier-requirement-main {
  min-width: 0;
}

.tier-requirement-text-button {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  width: 100%;
  text-align: left;
  color: inherit;
  font: inherit;
}

.tier-requirement-text-button.has-details {
  cursor: pointer;
}

.tier-requirement-details {
  margin-top: 8px;
  display: grid;
  gap: 4px;
  font-size: 12px;
  color: #5d6f83;
}

.tier-ap-total {
  margin-bottom: 14px;
  font-size: 30px;
  font-weight: 900;
}

.users-search-panel,
.users-results-panel {
  margin-top: 16px;
}

.users-results-list {
  display: grid;
  gap: 10px;
}

.user-search-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--row-even);
}

.user-search-main {
  display: grid;
  gap: 4px;
}

.user-search-name {
  font-size: 18px;
  font-weight: 800;
  color: var(--text-primary);
}

.user-search-meta {
  color: #5d6f83;
  font-size: 12px;
  font-weight: 700;
}

.icon-link-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--row-even);
  color: var(--text-primary);
  font-size: 12px;
  font-weight: 800;
}

.icon-link-button:hover {
  text-decoration: none;
  color: var(--link);
}

.summon-toggle {
  display: inline-grid;
  place-items: center;
  position: relative;
}

.summon-toggle input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  border: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

.summon-toggle span {
  width: 24px;
  height: 24px;
  border: 2px solid var(--border);
  border-radius: 999px;
  display: block;
}

.summon-toggle input:checked + span {
  background: #43a047;
  border-color: #43a047;
}

body.theme-dark .user-search-row,
body.theme-dark .tier-focus-meta span,
body.theme-dark .tier-focus-panel,
body.theme-dark .tier-ap-panel {
  background: var(--row-even);
}

@media (max-width: 1040px) {
  .tier-top-grid {
    grid-template-columns: 1fr;
  }
}

/* Latest alignment and app-match overrides */

.home-score-accent {
  align-items: center;
  justify-content: center;
}

.home-score-accent span {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

.home-score-metric-row {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  width: 100%;
}

.home-score-value-side {
  position: absolute;
  top: 50%;
  width: 32px;
  height: 32px;
  object-fit: contain;
  transform: translateY(-50%);
}

.home-score-value-side-left {
  left: 8px;
}

.home-score-value-side-right {
  right: 8px;
}

.browse-table-shell,
.leaderboard-table-shell,
.score-editor-panel {
  overflow-x: auto;
}

.score-editor-form {
  display: grid;
  gap: 18px;
}

.score-editor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px;
}

.score-editor-grid label {
  display: grid;
  gap: 8px;
  font-size: 13px;
  font-weight: 800;
  color: var(--text-primary);
}

.score-editor-grid input,
.score-editor-grid select {
  width: 100%;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--row-even);
  color: var(--text-primary);
  font: inherit;
}

.score-editor-score-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.score-editor-score-row input {
  flex: 1 1 auto;
}

.score-editor-max-toggle {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.score-editor-max-toggle input {
  width: 18px;
  height: 18px;
  min-width: 18px;
  padding: 0;
}

.score-editor-helper {
  margin: 0;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 700;
}

.score-editor-proof-section {
  display: grid;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.score-editor-proof-section label {
  display: grid;
  gap: 8px;
  font-size: 13px;
  font-weight: 800;
  color: var(--text-primary);
}

.score-editor-proof-section input {
  width: 100%;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--row-even);
  color: var(--text-primary);
  font: inherit;
}

.score-editor-proof-status {
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 800;
}

.admin-proof-table-shell {
  overflow-x: auto;
}

.admin-proof-table {
  min-width: 860px;
}

.admin-proof-bulk-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.admin-proof-bulk-actions form {
  margin: 0;
}

.admin-proof-preview-cell {
  width: 132px;
  text-align: center;
}

.admin-proof-preview {
  width: 112px;
  height: 84px;
  object-fit: contain;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--row-even);
}

.admin-proof-song {
  margin-top: 6px;
  font-weight: 900;
}

.admin-proof-submitted-score {
  font-size: 14px;
  font-weight: 800;
}

.admin-proof-meta {
  margin-top: 4px;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-proof-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.admin-proof-actions form {
  margin: 0;
}

.score-editor-error {
  padding: 12px 14px;
  border: 1px solid rgba(178, 42, 42, 0.24);
  border-radius: 14px;
  background: rgba(178, 42, 42, 0.08);
  color: #8d2424;
  font-size: 13px;
  font-weight: 800;
}

.score-editor-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.score-editor-actions-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.danger-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid #8d2424;
  background: #b22a2a;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
}

.danger-button:hover {
  color: #fff;
  text-decoration: none;
}

body.theme-dark .danger-button {
  border-color: #d84a4a;
  background: #9b2323;
}

body.is-score-editor-modal-open {
  overflow: hidden;
  overscroll-behavior: none;
}

.score-editor-modal-overlay[hidden] {
  display: none;
}

.score-editor-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1500;
  display: grid;
  place-items: center;
  padding: 24px;
  box-sizing: border-box;
  min-height: 100vh;
  min-height: 100dvh;
  overscroll-behavior: contain;
  user-select: none;
}

.score-editor-modal-backdrop {
  position: absolute;
  inset: 0;
  display: block;
  margin: 0;
  padding: 0;
  border: 0;
  background: rgba(8, 12, 24, 0.68);
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.score-editor-modal-backdrop:focus,
.score-editor-modal-backdrop:focus-visible {
  outline: none;
  box-shadow: none;
}

.score-editor-modal-dialog {
  position: relative;
  z-index: 1;
  width: min(920px, calc(100vw - 48px));
  max-width: 100%;
  max-height: calc(100vh - 48px);
  max-height: calc(100dvh - 48px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border: 1px solid var(--border);
  border-radius: 24px;
  background: var(--card-bg);
  box-shadow: 0 28px 60px rgba(8, 12, 24, 0.34);
  box-sizing: border-box;
  overflow: hidden;
  overscroll-behavior: contain;
  user-select: text;
}

.score-editor-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--row-even);
  color: var(--text-primary);
}

.score-editor-modal-close {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--ghost-bg);
  color: var(--text-primary);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.score-editor-modal-body {
  overflow: auto;
  padding: 18px;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

.score-editor-modal-body .score-editor-panel {
  margin: 0;
  overflow: visible;
}

.score-editor-modal-loading {
  display: grid;
  place-items: center;
  min-height: 240px;
  color: var(--text-muted);
  font-size: 15px;
  font-weight: 800;
}

@media (max-width: 820px) {
  .score-editor-grid {
    grid-template-columns: 1fr;
  }

  .score-editor-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .score-editor-actions-right {
    justify-content: flex-end;
  }

  .score-editor-modal-overlay {
    place-items: start center;
    padding: 12px;
  }

  .score-editor-modal-dialog {
    width: min(100%, calc(100vw - 24px));
    max-width: calc(100vw - 24px);
    max-height: calc(100vh - 24px);
    max-height: calc(100dvh - 24px);
  }

  .score-editor-modal-body {
    padding: 14px;
  }
}
.app-song-table-shell {
  overflow-x: auto;
  overflow-y: hidden;
}

.browse-chart-table,
.app-song-table,
.leaderboard-table {
  width: 100%;
  table-layout: auto;
}

.app-song-table {
  min-width: 820px;
}

.leaderboard-table {
  min-width: 760px;
}

.browse-chart-table th,
.browse-chart-table td,
.app-song-table th,
.app-song-table td,
.leaderboard-table th,
.leaderboard-table td {
  font-size: 15px;
  text-align: center;
  vertical-align: middle;
}

.browse-chart-table thead .col-title {
  text-align: center;
}

.browse-chart-table tbody .browse-title-table-cell {
  text-align: left;
}

.browse-song-title {
  font-size: 20px;
}

.browse-song-series {
  font-size: 13px;
}

.browse-difficulty-tag,
.compare-delta {
  font-size: 12px;
}

.browse-status-asset,
.table-status-asset {
  width: 36px;
  height: 36px;
}

.browse-rank-asset,
.table-rank-asset {
  width: 44px;
}

.browse-compare-cell strong {
  font-size: 15px;
}

.song-controls-center {
  display: flex;
  justify-content: center;
}

.app-song-table .col-export,
.app-song-table .song-export-cell {
  width: 94px;
  text-align: center;
}

.leaderboard-controls {
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
}

.leaderboard-style-host {
  justify-content: flex-end;
}

.leaderboard-sort-row {
  justify-content: center;
}

.leaderboard-difficulty-buttons {
  justify-content: flex-start;
}

.leaderboard-difficulty-button {
  min-width: 64px;
  font-size: 15px;
  color: #fff;
  border-width: 2px;
}

.leaderboard-difficulty-button.rating-d1 {
  background: linear-gradient(180deg, #f7ba4f 0%, #d98d00 100%);
  border-color: #d48a00;
}

.leaderboard-difficulty-button.rating-d2 {
  background: linear-gradient(180deg, #74d3ff 0%, #238dc8 100%);
  border-color: #1c87c4;
}

.leaderboard-difficulty-button.rating-d3 {
  background: linear-gradient(180deg, #ef6a64 0%, #ba221d 100%);
  border-color: #b0201b;
}

.leaderboard-difficulty-button.rating-d4 {
  background: linear-gradient(180deg, #a76ad7 0%, #6a2c99 100%);
  border-color: #632690;
}

.leaderboard-difficulty-button.rating-d5 {
  background: linear-gradient(180deg, #49c15a 0%, #1f8a37 100%);
  border-color: #1b7b32;
}

body.game-asc .leaderboard-difficulty-button.rating-d1 {
  background: linear-gradient(180deg, #49c15a 0%, #1f8a37 100%);
  border-color: #1b7b32;
}

body.game-asc .leaderboard-difficulty-button.rating-d2 {
  background: linear-gradient(180deg, #f7ba4f 0%, #d98d00 100%);
  border-color: #d48a00;
}

body.game-asc .leaderboard-difficulty-button.rating-d3 {
  background: linear-gradient(180deg, #74d3ff 0%, #238dc8 100%);
  border-color: #1c87c4;
}

body.game-asc .leaderboard-difficulty-button.rating-d4 {
  background: linear-gradient(180deg, #ef6a64 0%, #ba221d 100%);
  border-color: #b0201b;
}

body.game-asc .leaderboard-difficulty-button.rating-d5 {
  background: linear-gradient(180deg, #a76ad7 0%, #6a2c99 100%);
  border-color: #632690;
}

body.game-asc .leaderboard-difficulty-button,
body.game-asc .chart-viewer-difficulty-button {
  color: #fff;
}

.leaderboard-difficulty-button.is-active {
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.7);
}

.tier-focus-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.tier-focus-select-row {
  margin-bottom: 12px;
}

.tier-current-asset {
  width: 72px;
  height: 72px;
  object-fit: contain;
}

.tier-ranking-head {
  align-items: center;
}

.tier-point-table-bar {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}

.tier-point-values-shell {
  margin-top: 12px;
}

.tier-point-values-shell.is-hidden {
  display: none;
}

.tier-requirement-text-button {
  font-weight: 800;
}

.tier-requirement-text-button.has-details::after {
  content: "View";
  display: inline-block;
  margin-left: 8px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6d7d90;
}

.summons-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}

.summons-export-button {
  text-decoration: none;
}

.summons-table {
  width: 100%;
  table-layout: fixed;
}

.summons-table th,
.summons-table td {
  text-align: center;
  vertical-align: middle;
}

.summons-icons-row th {
  padding-bottom: 6px;
  border-bottom: 0;
}

.summons-stone-head img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  margin: 0 auto;
}

.summons-premium-icon {
  width: 24px;
  height: 24px;
  object-fit: contain;
  margin: 0 auto;
}

.summons-premium-head,
.summons-premium-cell {
  width: 48px;
}

.summons-ability-cell {
  text-align: left;
  font-weight: 700;
}

.summons-rate-cell {
  font-weight: 800;
}

.summons-toggle-cell {
  text-align: center;
}

.profile-profica-card {
  position: relative;
  overflow: hidden;
  min-height: 280px;
  margin-bottom: 16px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background:
    var(--profica-base) center/cover no-repeat,
    var(--profica-illust) center/cover no-repeat,
    linear-gradient(180deg, #eef4fa 0%, var(--card-bg) 100%);
  box-shadow: 0 8px 18px rgba(38, 55, 74, 0.08);
}

.profile-profica-overlay {
  display: grid;
  gap: 18px;
  min-height: 280px;
  padding: 22px 24px;
  background: linear-gradient(90deg, rgba(14, 24, 38, 0.72) 0%, rgba(14, 24, 38, 0.52) 38%, rgba(14, 24, 38, 0.18) 100%);
  color: #fff;
}

.profile-profica-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.profile-profica-label {
  display: none;
}

.profile-profica-top h1 {
  margin: 0;
  font-size: 38px;
  line-height: 1.05;
  color: #fff;
  -webkit-text-stroke: 1px rgba(0, 0, 0, 0.45);
  paint-order: stroke fill;
  text-shadow: 0 2px 5px rgba(0, 0, 0, 0.55);
}

.profile-profica-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.profile-profica-metrics {
  margin-top: auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.profile-profica-metrics article {
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(10, 18, 29, 0.66);
  border: 1px solid rgba(255, 255, 255, 0.18);
  min-width: 0;
  overflow: hidden;
}

.profile-profica-metrics span {
  display: block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.8;
}

.profile-profica-metrics strong {
  display: block;
  margin-top: 8px;
  font-size: 28px;
  line-height: 1;
  white-space: nowrap;
  min-width: 0;
}

.profile-stats-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.profile-stats-table {
  width: 100%;
  table-layout: fixed;
}

.profile-stats-table th,
.profile-stats-table td {
  padding: 8px 6px;
  font-size: 13px;
  text-align: center;
  vertical-align: middle;
}

.profile-stats-table .profile-col-scope,
.profile-stats-table td:nth-child(2) {
  text-align: left;
}

.profile-stats-table .profile-col-rating,
.profile-stats-table td:nth-child(1) {
  width: 74px;
}

.profile-stats-table .profile-col-scope,
.profile-stats-table td:nth-child(2) {
  width: 112px;
}

.profile-stats-table .profile-col-average,
.profile-stats-table .profile-col-average-damage,
.profile-stats-table .profile-col-combined-damage {
  width: 110px;
}

.profile-stats-row.profile-row-rating_total {
  cursor: pointer;
  font-weight: 800;
}

.profile-stats-row.profile-row-rating_detail td:nth-child(2) {
  padding-left: 18px;
}

.profile-stats-row.profile-row-overall,
.profile-stats-row.profile-row-difficulty_total {
  background: var(--row-even);
}

body.theme-dark .profile-profica-card {
  border-color: #425a73;
}

body.theme-dark .profile-profica-metrics article {
  background: rgba(7, 12, 19, 0.76);
}

body.theme-dark .summons-export-button,
body.theme-dark .tier-point-values-shell,
body.theme-dark .profile-stats-panel {
  background: var(--card-bg);
}

@media (max-width: 1040px) {
  .leaderboard-controls {
    grid-template-columns: 1fr;
  }

  .leaderboard-difficulty-buttons,
  .leaderboard-sort-row,
  .leaderboard-style-host {
    justify-content: center;
  }

  .summons-topbar {
    flex-direction: column;
    align-items: stretch;
  }
}

/* Current UI alignment, proficard, and embedded summons pass */

body {
  background-color: var(--window-bg);
  background-image: none;
}

.profile-menu-trigger {
  position: relative;
  overflow: visible;
}

.profile-menu-trigger-card {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: transparent;
  overflow: visible;
  isolation: isolate;
  border-color: transparent;
  box-shadow: none;
}

.profile-menu-trigger-card-fill {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background-image:
    var(--menu-profica-illust),
    var(--menu-profica-base);
  background-position:
    right center,
    center center;
  background-size:
    auto 100%,
    cover;
  background-repeat:
    no-repeat,
    no-repeat;
  background-color: var(--ghost-bg);
  z-index: 1;
}

.profile-menu-trigger-card > img:not(.profile-menu-trigger-frame) {
  position: relative;
  z-index: 2;
}

.profile-menu-trigger img.profile-menu-trigger-frame {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%);
  object-fit: contain;
  border: 0;
  border-radius: 0;
  background: transparent;
  pointer-events: none;
  z-index: 3;
}

.tier-detail-select,
.tier-view-row select {
  background: var(--row-even);
  color: var(--text-primary);
  font-weight: 800;
}

body.theme-dark .tier-detail-select,
body.theme-dark .tier-view-row select,
body.theme-dark .tier-detail-select option,
body.theme-dark .tier-view-row select option {
  background: #203041;
  color: #eef5ff;
}

.tier-requirement-progress {
  color: var(--text-primary);
}

.profile-menu-trigger-letter {
  position: absolute;
  right: 6px;
  bottom: 4px;
  z-index: 2;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.55);
}

.settings-grid-form {
  max-width: min(980px, 100%);
}

.settings-profica-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.settings-visual-picker {
  display: grid;
  gap: 10px;
}

.settings-visual-picker h3 {
  margin: 0;
  font-size: 18px;
}

.settings-visual-grid {
  display: grid;
  gap: 12px;
  overflow-x: hidden;
  overflow-y: auto;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--row-even);
  align-items: start;
  align-content: start;
  scrollbar-gutter: stable;
}

.settings-visual-grid-base {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-height: 430px;
}

.settings-visual-grid-illust {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  max-height: 365px;
}

.settings-visual-grid-frame {
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  max-height: 310px;
}

.settings-visual-preview-none {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  border: 1px dashed var(--border);
  border-radius: 14px;
  color: var(--text-muted);
  font-size: 14px;
  font-weight: 700;
  background: var(--panel-bg);
}

.settings-visual-option {
  position: relative;
  display: grid;
  gap: 0;
  cursor: pointer;
  padding: 8px;
  border: 1px solid transparent;
  border-radius: 14px;
  background: transparent;
}

.settings-visual-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.settings-visual-option:has(input:checked) {
  border-color: var(--link);
  background: var(--card-bg);
}

.settings-visual-preview {
  display: block;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  background: var(--card-bg);
}

.settings-visual-preview-frame {
  background: linear-gradient(180deg, rgba(65, 92, 122, 0.12), rgba(65, 92, 122, 0.02));
}

.settings-note {
  margin: 4px 0 0;
  font-size: 13px;
  color: var(--muted);
}

.settings-import-changelog {
  display: grid;
  gap: 6px;
  margin-top: 14px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--row-even);
}

.settings-import-changelog strong {
  font-size: 15px;
  font-weight: 900;
}

.settings-import-changelog a {
  font-weight: 800;
}

.settings-import-changelog .settings-note {
  margin-top: 0;
}

.pair-invite-panel {
  border-color: var(--border);
}

.pair-invite-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.pair-invite-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--row-even);
}

.pair-invite-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.pair-invite-copy strong {
  font-size: 15px;
  font-weight: 900;
}

.pair-invite-copy span {
  color: var(--muted);
  font-weight: 800;
}

.pair-invite-actions {
  justify-content: flex-end;
}

.settings-visual-preview img {
  width: 100%;
  height: auto;
  display: block;
}

.settings-visual-preview-illust {
  aspect-ratio: 876 / 408;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #eef4fa 0%, var(--card-bg) 100%);
}

.settings-visual-preview-illust img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.settings-visual-name {
  display: none;
}

.browse-chart-table,
.app-song-table,
.leaderboard-table,
.profile-stats-table,
.summons-table {
  min-width: 0;
}

.browse-chart-table th,
.browse-chart-table td,
.app-song-table th,
.app-song-table td,
.leaderboard-table th,
.leaderboard-table td {
  font-size: 15px;
  text-align: center;
  vertical-align: middle;
}

.browse-chart-table .col-title,
.app-song-table .col-title,
.leaderboard-table .col-title {
  text-align: center;
}

.browse-title-table-cell,
.leaderboard-player-cell,
.profile-stats-table .profile-col-scope,
.profile-stats-table td:nth-child(2) {
  text-align: left;
}

.browse-ms-table-cell,
.browse-badge-cell,
.browse-crown-cell,
.browse-rank-cell,
.song-badge-cell,
.song-crown-cell,
.song-rank-cell,
.leaderboard-rank-cell,
.leaderboard-badge-cell {
  text-align: center;
}

.browse-ms-asset,
.ms-type-badge,
.browse-status-asset,
.table-status-asset,
.browse-rank-asset,
.table-rank-asset {
  margin: 0 auto;
  object-position: center center;
}

.browse-date-cell,
.song-date-cell,
.leaderboard-date-cell {
  font-size: 12px !important;
  white-space: nowrap;
}

.leaderboard-player-menu {
  vertical-align: middle;
}

.leaderboard-player-trigger {
  width: auto;
  max-width: 100%;
  min-height: 34px;
  height: auto;
  padding: 7px 32px 7px 10px;
  border-color: transparent;
  background: transparent;
  color: var(--link);
  font-size: inherit;
  font-weight: 900;
  line-height: 1.2;
  text-align: left;
  position: relative;
}

.leaderboard-player-trigger::after {
  content: "▾";
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 13px;
  line-height: 1;
}

.leaderboard-player-trigger:hover {
  background: var(--row-even);
  text-decoration: underline;
}

.leaderboard-player-dropdown {
  min-width: 180px;
}

.browse-chain-cell,
.song-chain-cell {
  font-weight: 700;
}

.browse-damage-cell,
.song-damage-cell,
.leaderboard-damage-cell {
  font-weight: 900;
}

.song-detail-header {
  position: relative;
}

.song-header-action {
  position: absolute;
  right: 18px;
  bottom: 18px;
}

.song-controls-row {
  grid-template-columns: 96px auto;
}

.song-controls-right {
  justify-content: flex-end;
}

.leaderboard-heading {
  align-items: center;
}

.leaderboard-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
}

.leaderboard-difficulty-buttons {
  justify-content: flex-start;
}

.leaderboard-sort-row {
  justify-content: flex-end;
  margin-left: auto;
}

.leaderboard-style-host {
  justify-content: flex-end;
}

.tier-focus-meta {
  align-items: stretch;
}

.tier-focus-head-right {
  display: grid;
  justify-items: end;
  gap: 8px;
}

.tier-view-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 800;
}

.tier-view-row select {
  min-width: 220px;
}

.tier-focus-meta span {
  min-width: 132px;
  justify-content: center;
}

.tier-requirement.has-details {
  appearance: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--row-odd);
  box-shadow: none;
  color: inherit;
  font: inherit;
}

.tier-requirement.has-details:hover {
  background: var(--row-even);
}

.tier-requirement-details {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(153, 171, 192, 0.55);
  font-size: 13px;
  line-height: 1.35;
}

.profile-profica-shell {
  display: flex;
  justify-content: center;
  margin-bottom: 16px;
}

.profile-profica-card {
  position: relative;
  width: min(876px, 100%);
  aspect-ratio: 876 / 408;
  min-height: 0;
  margin-bottom: 0;
  border-radius: 24px;
  background: linear-gradient(180deg, #eef4fa 0%, var(--card-bg) 100%);
}

.profile-profica-base,
.profile-profica-illust {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.profile-profica-base {
  object-fit: cover;
}

.profile-profica-illust {
  object-fit: cover;
}

.profile-profica-overlay {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  min-height: 0;
  padding: 24px 28px;
  background: linear-gradient(90deg, rgba(14, 24, 38, 0.68) 0%, rgba(14, 24, 38, 0.42) 42%, rgba(14, 24, 38, 0.12) 100%);
}

.profile-profica-metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.profile-profica-metrics article {
  background: rgba(10, 18, 29, 0.62);
}

.profile-stats-table th,
.profile-stats-table td {
  font-size: 12px;
}

.profile-stats-table .profile-col-rating,
.profile-stats-table td:nth-child(1) {
  width: 82px;
}

.profile-stats-table .profile-col-scope,
.profile-stats-table td:nth-child(2) {
  width: 132px;
}

.profile-stats-table .profile-col-progress,
.profile-stats-table td:nth-child(3),
.profile-stats-table td:nth-child(4),
.profile-stats-table td:nth-child(5),
.profile-stats-table td:nth-child(6),
.profile-stats-table td:nth-child(7) {
  width: 96px;
}

.profile-stats-table .profile-col-average,
.profile-stats-table .profile-col-combined-score,
.profile-stats-table .profile-col-average-damage,
.profile-stats-table .profile-col-combined-damage {
  width: 118px;
}

.profile-summons-panel {
  margin-top: 16px;
}

.summons-topbar h2 {
  margin: 0;
}

.summons-export-button {
  text-decoration: none;
}

.users-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 16px;
  align-items: start;
}

.user-profica-card {
  position: relative;
  display: grid;
}

.user-profica-visual {
  position: relative;
  aspect-ratio: 876 / 408;
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
  background:
    var(--profica-illust) center/cover no-repeat,
    var(--profica-base) center/cover no-repeat,
    linear-gradient(180deg, #eef4fa 0%, var(--card-bg) 100%);
  box-shadow: 0 8px 18px rgba(38, 55, 74, 0.08);
}

.user-profica-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 16px;
  background: linear-gradient(180deg, rgba(14, 24, 38, 0.08) 0%, rgba(14, 24, 38, 0.58) 100%);
  z-index: 2;
  pointer-events: none;
}

.user-profica-overlay strong {
  position: absolute;
  left: 16px;
  bottom: 16px;
  max-width: calc(100% - 32px);
  margin: 0;
  color: #fff;
  font-size: 24px;
  line-height: 1;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
  pointer-events: none;
}

.user-profica-hitbox {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.user-profica-actions {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  display: flex;
  justify-content: flex-start;
  align-self: flex-start;
  pointer-events: auto;
}

.user-profica-actions .you-tag {
  margin-left: 0;
}

.user-profica-menu {
  flex: 0 0 auto;
}

.user-profica-menu .row-actions-trigger {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.46);
  box-shadow: none;
}

.user-profica-menu .row-actions-trigger:hover {
  background: rgba(255, 255, 255, 0.12);
}

.user-profica-menu .row-actions-dropdown {
  background: rgba(10, 18, 29, 0.94);
  border-color: rgba(255, 255, 255, 0.2);
}

.user-profica-menu .row-actions-link {
  color: #f6fbff;
}

.user-profica-menu .row-actions-link:hover,
.user-profica-menu .row-actions-link-button:hover {
  background: rgba(255, 255, 255, 0.08);
}

body.theme-dark .profile-profica-card,
body.theme-dark .user-profica-visual {
  border-color: #425a73;
}

body.theme-dark .tier-requirement.has-details:hover {
  background: #22364a;
}

body.theme-dark .settings-visual-grid {
  background: var(--row-odd);
}

body.theme-dark .settings-visual-option:has(input:checked) {
  background: #22364a;
}

.profile-menu-trigger-letter {
  display: none;
}

.song-detail-backbar {
  margin-bottom: 12px;
}

.back-bubble-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 8px 16px;
  border-radius: 999px;
  text-decoration: none;
}

.you-tag,
.tier-self-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--button-active-bg);
  color: var(--text-primary);
  font-size: 11px;
  font-weight: 800;
  vertical-align: middle;
}

.tier-view-row {
  justify-content: flex-end;
}

.tier-focus-meta span {
  min-width: 0;
}

.settings-grid-form {
  overflow-x: clip;
}

.settings-visual-grid {
  align-content: stretch;
  overflow-anchor: none;
}

.settings-visual-preview {
  aspect-ratio: 876 / 408;
  display: grid;
  place-items: center;
}

.settings-visual-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-stats-table {
  border-collapse: collapse;
  border-spacing: 0;
  background: var(--row-even);
}

.profile-stats-table thead th,
.profile-stats-table tbody td {
  border: 1px solid var(--border);
  border-radius: 0;
}

.profile-stats-table tbody tr,
.profile-stats-table tbody tr:nth-child(even) {
  background: transparent;
}

.profile-stats-table thead th {
  background: var(--header-bg);
}

.profile-stats-table tbody td {
  background: var(--row-even);
}

.profile-stats-table .profile-cell-rating {
  font-weight: 800;
}

.profile-stats-table .profile-cell-scope {
  font-weight: 700;
}

.profile-stats-table .profile-cell-progress {
  padding: 6px 4px;
  line-height: 1.1;
}

.profile-progress-value {
  font-size: 11px;
  font-weight: 800;
}

.profile-progress-left,
.profile-progress-percent {
  margin-top: 2px;
  font-size: 10px;
  font-weight: 700;
}

.profile-stats-table .profile-cell-rank,
.profile-stats-table .profile-cell-stat {
  background: var(--row-odd);
}

.profile-stats-row.profile-row-rating_total .profile-cell-rating,
.profile-stats-row.profile-row-rating_total .profile-cell-scope,
.profile-stats-row.profile-row-rating_detail .profile-cell-rating,
.profile-stats-row.profile-row-rating_detail .profile-cell-scope,
.profile-stats-row.profile-row-overall .profile-cell-rating,
.profile-stats-row.profile-row-overall .profile-cell-scope,
.profile-stats-row.profile-row-difficulty_total .profile-cell-rating,
.profile-stats-row.profile-row-difficulty_total .profile-cell-scope {
  background: var(--row-even);
  color: var(--text-primary);
}

body.theme-dark .profile-stats-table thead th {
  background: var(--header-bg);
}

body.theme-dark .profile-stats-table tbody td {
  background: #1b2a39;
}

@media (max-width: 1040px) {
  .leaderboard-controls {
    grid-template-columns: 1fr;
  }

  .leaderboard-sort-row,
  .leaderboard-style-host,
  .leaderboard-difficulty-buttons {
    justify-content: center;
  }

  .profile-profica-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tier-focus-head-right {
    justify-items: stretch;
  }

  .tier-view-row {
    justify-content: flex-end;
  }
}

@media (max-width: 820px) {
  .settings-profica-stats-grid {
    grid-template-columns: 1fr;
  }

  .settings-visual-grid-base,
  .settings-visual-grid-illust {
    display: grid;
    grid-template-columns: 1fr;
    overflow-x: hidden;
    overflow-y: auto;
    max-height: 260px;
  }

  .settings-visual-option,
  .settings-visual-grid-illust .settings-visual-option {
    flex-basis: auto;
  }

  .profile-profica-overlay {
    padding: 18px;
  }

  .profile-profica-metrics {
    grid-template-columns: 1fr;
  }

  .song-header-action {
    position: static;
    grid-column: 1 / -1;
    justify-self: center;
  }
}

/* Navigation spacing, profile scroll shell, and site chart viewer */

.site-header-inner {
  min-width: 0;
  gap: 28px;
}

.site-nav {
  flex: 1 1 auto;
  min-width: 0;
  justify-content: flex-end;
  gap: 22px;
}

.site-nav a,
.site-nav button {
  font-size: 18px;
  letter-spacing: 0.01em;
}

.user-profica-actions:empty {
  display: none;
}

.profile-profica-card-locked .profile-profica-overlay {
  background: linear-gradient(90deg, rgba(14, 24, 38, 0.74) 0%, rgba(14, 24, 38, 0.52) 46%, rgba(14, 24, 38, 0.22) 100%);
}

.profile-profica-locked-copy {
  display: grid;
  align-content: center;
  gap: 10px;
  max-width: 360px;
  margin-top: 24px;
}

.profile-profica-locked-copy strong {
  font-size: 28px;
  line-height: 1;
}

.profile-profica-locked-copy p {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.35;
}

.profile-private-panel {
  text-align: center;
}

.profile-private-panel h2,
.profile-private-panel p {
  margin: 0;
}

.profile-private-panel p {
  margin-top: 8px;
  color: #5d6f83;
  font-weight: 700;
}

.profile-stats-table-shell {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 8px;
}

.detailed-stats-panel {
  width: min(100%, 1500px);
  margin-inline: auto;
}

.detailed-stats-head {
  align-items: center;
}

.profile-stats-controls,
.detailed-stats-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.profile-pair-play-toggle.is-hidden,
.detailed-pair-play-toggle.is-hidden {
  display: none;
}

.detailed-stats-head h1 {
  margin: 0 0 4px;
}

.detailed-stats-head p {
  margin: 0;
  color: var(--text-muted);
  font-weight: 700;
}

.detailed-stats-table-shell {
  overflow-x: auto;
  overflow-y: auto;
  padding-bottom: 8px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--row-even);
}

.detailed-stats-table {
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 13px;
}

.detailed-stats-table th,
.detailed-stats-table td {
  padding: 8px 10px;
  border-top: 1px solid rgba(153, 171, 192, 0.55);
  text-align: center;
  white-space: nowrap;
}

.detailed-stats-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 12px 10px;
  border-top: 0;
  border-bottom: 1px solid var(--border);
  background: var(--header-bg);
  color: var(--text-primary);
  font-weight: 900;
}

.detailed-stats-table tbody tr:nth-child(odd) {
  background: var(--row-even);
}

.detailed-stats-table tbody tr:nth-child(even) {
  background: var(--row-odd);
}

.detailed-stats-table .detailed-player-cell {
  min-width: 180px;
  text-align: left;
}

.detailed-stats-table .detail-divider {
  width: 2px;
  min-width: 2px;
  padding: 0;
  background: var(--border);
  border-top-color: var(--border);
}

.detailed-rank-none {
  display: inline-grid;
  place-items: center;
  min-width: 28px;
  min-height: 20px;
  font-weight: 900;
}

.profile-stats-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}

.profile-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 18px;
}

.profile-column-toggle.is-active {
  background: var(--button-active-bg);
}

.profile-collapse-toggle:disabled {
  opacity: 0.55;
  cursor: default;
}

.profile-stats-table {
  min-width: 1900px;
}

.profile-stats-table th,
.profile-stats-table td {
  padding: 10px 8px;
  font-size: 13px;
}

.profile-stats-table .profile-col-rating,
.profile-stats-table td:nth-child(1) {
  width: 92px;
}

.profile-stats-table .profile-col-scope,
.profile-stats-table td:nth-child(2) {
  width: 148px;
}

.profile-stats-table .profile-col-progress,
.profile-stats-table td:nth-child(3),
.profile-stats-table td:nth-child(4),
.profile-stats-table td:nth-child(5),
.profile-stats-table td:nth-child(6),
.profile-stats-table td:nth-child(7) {
  width: 108px;
}

.profile-stats-table .profile-col-average,
.profile-stats-table .profile-col-combined-score,
.profile-stats-table .profile-col-average-damage,
.profile-stats-table .profile-col-combined-damage {
  width: 132px;
}

.profile-progress-value {
  font-size: 12px;
}

.profile-progress-left,
.profile-progress-percent {
  font-size: 11px;
}

.profile-stats-divider-row td {
  padding: 14px 10px;
  background: transparent !important;
  border: 0;
}

.profile-stats-divider-row span {
  display: block;
  padding: 10px 14px;
  border-top: 2px solid var(--border);
  border-bottom: 2px solid var(--border);
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-align: center;
}

.profile-stats-panel.is-hide-progress .profile-col-progress,
.profile-stats-panel.is-hide-progress .profile-cell-clear,
.profile-stats-panel.is-hide-progress .profile-cell-pc,
.profile-stats-panel.is-hide-progress .profile-cell-crown,
.profile-stats-panel.is-hide-progress .profile-cell-ac,
.profile-stats-panel.is-hide-progress .profile-cell-max {
  display: none;
}

.profile-stats-panel.is-hide-ranks .profile-col-rank,
.profile-stats-panel.is-hide-ranks .profile-cell-rank {
  display: none;
}

.profile-stats-panel.is-hide-totals .profile-col-average,
.profile-stats-panel.is-hide-totals .profile-col-combined-score,
.profile-stats-panel.is-hide-totals .profile-col-average-damage,
.profile-stats-panel.is-hide-totals .profile-col-combined-damage,
.profile-stats-panel.is-hide-totals .profile-cell-average-score,
.profile-stats-panel.is-hide-totals .profile-cell-combined-score,
.profile-stats-panel.is-hide-totals .profile-cell-average-damage,
.profile-stats-panel.is-hide-totals .profile-cell-combined-damage {
  display: none;
}

.song-header-chart-viewer {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.chart-viewer-song-header {
  margin-bottom: 16px;
}

.chart-viewer-panel {
  display: grid;
  gap: 16px;
}

.chart-viewer-topbar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}

.chart-viewer-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.chart-viewer-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 800;
}

.chart-viewer-topbar h2,
.chart-viewer-topbar p {
  margin: 0;
}

.chart-viewer-topbar p {
  margin-top: 8px;
  font-size: 14px;
  font-weight: 700;
  color: #5d6f83;
}

.chart-viewer-zoom-field {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 800;
}

.chart-viewer-zoom-field input {
  width: 220px;
  direction: rtl;
}

.chart-viewer-zoom-field strong {
  min-width: 32px;
  text-align: right;
}

.chart-viewer-difficulty-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.chart-viewer-difficulty-button {
  min-width: 56px;
  min-height: 42px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: 18px;
  font-weight: 900;
}

.chart-viewer-difficulty-button.is-active {
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.48);
}

.chart-viewer-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.chart-viewer-stage {
  min-width: 0;
}

.chart-viewer-canvas-shell {
  --chart-viewer-surface: #edf3fa;
  position: relative;
  height: clamp(560px, 72vh, 760px);
  min-height: 560px;
  padding: 18px 28px 62px 24px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: linear-gradient(180deg, #f5f9fd 0%, #e4edf6 100%);
}

body.theme-dark .chart-viewer-canvas-shell {
  --chart-viewer-surface: #0f1720;
  background: linear-gradient(180deg, #172432 0%, #101923 100%);
}

.chart-viewer-canvas-shell.is-ems {
  padding-right: 52px;
  padding-bottom: 18px;
}

.chart-viewer-canvas-shell canvas {
  display: block;
  max-width: 100%;
  margin: 0 auto;
  border-radius: 18px;
  border: 1px solid rgba(153, 171, 192, 0.45);
  background: var(--chart-viewer-surface);
}

.chart-viewer-scroll {
  position: absolute;
  display: none;
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  appearance: none;
  -webkit-appearance: none;
}

.chart-viewer-scroll.is-active {
  display: block;
}

.chart-viewer-scroll-horizontal {
  left: 32px;
  width: calc(100% - 84px);
  right: auto;
  bottom: 16px;
  box-sizing: border-box;
}

.chart-viewer-scroll-vertical {
  top: 18px;
  bottom: 18px;
  right: 12px;
  width: 22px;
  writing-mode: vertical-lr;
  direction: ltr;
  -webkit-appearance: slider-vertical;
  appearance: slider-vertical;
}

.chart-viewer-scroll::-webkit-slider-runnable-track,
.chart-viewer-zoom-field input::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 999px;
  background: rgba(153, 171, 192, 0.38);
}

.chart-viewer-scroll::-webkit-slider-thumb,
.chart-viewer-zoom-field input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  margin-top: -5px;
  border-radius: 999px;
  border: 2px solid #dff4ff;
  background: #4bb5ff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22);
}

.chart-viewer-scroll::-moz-range-track,
.chart-viewer-zoom-field input::-moz-range-track {
  height: 8px;
  border: 0;
  border-radius: 999px;
  background: rgba(153, 171, 192, 0.38);
}

.chart-viewer-scroll::-moz-range-progress,
.chart-viewer-zoom-field input::-moz-range-progress {
  background: transparent;
}

.chart-viewer-scroll::-moz-range-thumb,
.chart-viewer-zoom-field input::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border: 2px solid #dff4ff;
  border-radius: 999px;
  background: #4bb5ff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22);
}

.chart-viewer-note-panel {
  min-height: 0;
  padding: 18px 20px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: var(--row-even);
}

.chart-viewer-note-panel h3 {
  margin: 0 0 12px;
  font-size: 18px;
}

.chart-viewer-note-copy {
  display: grid;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
}

.card-draw-panel,
.card-draw-results-panel {
  display: grid;
  gap: 20px;
}

.card-draw-results-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.card-draw-results-head p {
  margin: 8px 0 0;
  color: #5d6f83;
  font-size: 15px;
  line-height: 1.5;
}

.card-draw-form {
  display: grid;
  gap: 18px;
}

.card-draw-control-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 180px));
  gap: 14px;
}

.card-draw-filter-block {
  display: grid;
  gap: 10px;
}

.card-draw-filter-label {
  color: #5d6f83;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.card-draw-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.card-draw-pill {
  position: relative;
  display: inline-flex;
}

.card-draw-pill input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.card-draw-pill span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--row-even);
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  transition: transform 0.16s ease, background 0.16s ease, border-color 0.16s ease;
}

.card-draw-pill input:checked + span {
  background: var(--button-active-bg);
  border-color: #5f89bf;
}

.card-draw-pill span:hover {
  transform: translateY(-1px);
}

.card-draw-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.card-draw-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 18px;
}

.card-draw-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: var(--row-even);
  color: var(--text-primary);
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(38, 55, 74, 0.08);
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.card-draw-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(38, 55, 74, 0.14);
  text-decoration: none;
}

.card-draw-jacket-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  aspect-ratio: 1 / 1;
  background: linear-gradient(180deg, #edf3fa 0%, #dce6f1 100%);
}

.card-draw-jacket {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card-draw-diff-tag {
  position: absolute;
  right: 10px;
  bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(17, 28, 43, 0.82);
  color: #f6fbff;
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}

.card-draw-diff-tag.rating-d1 {
  background: rgba(245, 166, 35, 0.92);
  color: #1f2730;
}

.card-draw-diff-tag.rating-d2 {
  background: rgba(110, 198, 255, 0.95);
  color: #102235;
}

.card-draw-diff-tag.rating-d3 {
  background: rgba(229, 57, 53, 0.94);
  color: #fff7f7;
}

.card-draw-diff-tag.rating-d4 {
  background: rgba(142, 68, 173, 0.94);
  color: #fff7ff;
}

.card-draw-diff-tag.rating-d5 {
  background: rgba(73, 193, 90, 0.94);
  color: #f5fff5;
}

body.game-asc .card-draw-diff-tag.rating-d1 {
  background: rgba(73, 193, 90, 0.94);
  color: #f5fff5;
}

body.game-asc .card-draw-diff-tag.rating-d2 {
  background: rgba(245, 166, 35, 0.92);
  color: #1f2730;
}

body.game-asc .card-draw-diff-tag.rating-d3 {
  background: rgba(110, 198, 255, 0.95);
  color: #102235;
}

body.game-asc .card-draw-diff-tag.rating-d4 {
  background: rgba(229, 57, 53, 0.94);
  color: #fff7f7;
}

body.game-asc .card-draw-diff-tag.rating-d5 {
  background: rgba(142, 68, 173, 0.94);
  color: #fff7ff;
}

.card-draw-card-copy {
  display: grid;
  gap: 6px;
}

.card-draw-card-copy h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.2;
}

.card-draw-series {
  margin: 0;
  min-height: 36px;
  color: #5d6f83;
  font-size: 13px;
  font-weight: 700;
}

.card-draw-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.card-draw-meta-badges {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.card-draw-ms-asset {
  width: 58px;
  height: 58px;
  object-fit: contain;
  flex: 0 0 auto;
}

.card-draw-edition {
  padding: 7px 12px;
  border-radius: 999px;
  background: var(--table-header-bg);
  color: var(--text-primary);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.card-draw-edition-copyright {
  background: #2e4360;
  color: #f3f8fe;
}

.chart-viewer-export-canvas {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

body.theme-dark .chart-viewer-note-panel {
  background: #162230;
}

body.theme-dark .chart-viewer-topbar p,
body.theme-dark .profile-private-panel p {
  color: #b7c7d8;
}

@media (max-width: 1040px) {
  .site-nav {
    gap: 14px;
  }

  .site-nav a,
  .site-nav button {
    font-size: 16px;
  }

  .chart-viewer-topbar {
    flex-direction: column;
    align-items: stretch;
  }

  .chart-viewer-note-panel,
  .chart-viewer-canvas-shell {
    min-height: 0;
    height: auto;
  }

  .card-draw-control-grid {
    grid-template-columns: 1fr;
  }

  .users-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .users-card-grid {
    grid-template-columns: 1fr;
  }
}

/* Compact header, responsive browse/song tables, and row action menus */

.brand img {
  width: auto;
  height: 48px;
}

.site-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 22px;
}

.brand {
  flex: 0 0 auto;
}

.site-header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  margin-left: auto;
}

.site-nav-links {
  display: flex;
  flex: 1 1 auto;
  justify-content: center;
  flex-wrap: nowrap;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
}

.site-nav-menu {
  position: relative;
  display: none;
}

.site-nav-menu summary {
  list-style: none;
}

.site-nav-menu summary::-webkit-details-marker {
  display: none;
}

.site-nav-menu-trigger {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--ghost-bg);
  color: var(--text-primary);
  font-size: 23px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
}

.site-nav-menu-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 30;
  min-width: 210px;
  display: grid;
  gap: 2px;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--card-bg);
  box-shadow: 0 12px 30px rgba(38, 55, 74, 0.16);
}

.site-nav-menu:not([open]) .site-nav-menu-dropdown {
  display: none;
}

.site-nav-menu-dropdown a {
  display: block;
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  color: var(--text-primary);
  font-weight: 700;
}

.site-nav-menu-dropdown a:hover {
  background: var(--row-even);
  text-decoration: none;
}

.app-song-table-shell {
  overflow: visible;
}

.app-song-table .col-actions,
.browse-chart-table .col-actions,
.song-action-cell,
.browse-action-cell {
  width: 54px;
  text-align: center;
}

.row-actions-menu {
  position: relative;
  display: inline-block;
  z-index: 1;
}

.row-actions-menu[open] {
  z-index: 40;
}

.row-actions-trigger {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--ghost-bg);
  color: var(--text-primary);
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
}

.row-actions-trigger::marker,
.row-actions-trigger::-webkit-details-marker {
  display: none;
  content: "";
}

.row-actions-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 112px;
  display: grid;
  gap: 4px;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--card-bg);
  box-shadow: 0 10px 24px rgba(38, 55, 74, 0.14);
  z-index: 41;
}

.row-actions-menu:not([open]) .row-actions-dropdown {
  display: none;
}

.row-actions-link {
  display: block;
  padding: 8px 10px;
  border-radius: 8px;
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 700;
  text-align: left;
}

.row-actions-link:hover {
  background: var(--row-even);
  text-decoration: none;
}

.row-actions-form {
  margin: 0;
}

.row-actions-link-button {
  width: 100%;
  border: 0;
  background: transparent;
  appearance: none;
  cursor: pointer;
  font: inherit;
  text-align: left;
}

.browse-index-cell {
  white-space: nowrap;
}

.browse-table-shell {
  overflow-x: auto;
  overflow-y: visible;
}

.browse-action-cell,
.song-action-cell {
  position: relative;
  overflow: visible !important;
}

.browse-action-cell.is-row-actions-open,
.song-action-cell.is-row-actions-open {
  z-index: 45;
}

.browse-chart-table .browse-table-row.is-row-actions-open,
.app-song-table tbody tr.is-row-actions-open {
  position: relative;
  z-index: 30;
}

.browse-chart-table {
  min-width: 0;
  table-layout: fixed;
}

.browse-chart-table .col-title {
  width: 30%;
}

.browse-song-title {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  line-height: 1.15;
}

.browse-chart-table .col-date,
.browse-chart-table .browse-date-cell {
  white-space: nowrap;
  font-size: 12px;
}

@media (max-width: 760px) {
  .site-header-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    padding: 10px 0;
  }

  .brand img {
    height: 34px;
  }

  .site-header-actions {
    margin-left: 0;
    justify-self: end;
  }

  .site-nav-links {
    display: none;
  }

  .site-nav-menu {
    display: block;
  }

  .site-nav-menu-trigger,
  .profile-menu-trigger {
    width: 40px;
    height: 40px;
  }

  .profile-menu-trigger img {
    width: 24px;
    height: 24px;
  }

  .profile-menu-dropdown,
  .site-nav-menu-dropdown {
    right: 0;
  }
}

@media (max-device-width: 760px), (hover: none) and (pointer: coarse) {
  html,
  body {
    overflow-x: hidden;
  }

  .site-header-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 32px;
    width: 980px;
    min-height: 164px;
    padding: 28px 36px;
  }

  .brand img {
    height: 104px;
  }

  .site-header-actions {
    gap: 28px;
    margin-left: 0;
    justify-self: end;
  }

  .site-nav-links {
    display: none;
  }

  .site-nav-menu {
    display: block;
  }

  .site-nav-menu-trigger,
  .profile-menu-trigger {
    width: 120px;
    height: 120px;
    border-radius: 24px;
  }

  .profile-menu-trigger img {
    width: 72px;
    height: 72px;
  }

  .site-nav-menu-trigger {
    font-size: 68px;
  }

  .profile-menu-dropdown,
  .site-nav-menu-dropdown {
    right: 0;
    min-width: 520px;
    padding: 24px;
    border-radius: 24px;
  }

  .profile-menu-dropdown a,
  .profile-menu-action,
  .site-nav-menu-dropdown a {
    padding: 28px 32px;
    border-radius: 18px;
    font-size: 36px;
  }

  .notification-bubble,
  .menu-notification-bubble {
    min-width: 44px;
    height: 44px;
    padding: 0 12px;
    border-width: 4px;
    font-size: 24px;
  }

  .profile-notification-bubble {
    top: -12px;
    right: -12px;
  }

  .page-shell,
  .site-footer-inner {
    width: 980px;
  }

  .browse-chart-table.is-personal {
    min-width: 0;
    table-layout: auto;
  }
}

@media (max-width: 880px) {
  .browse-table-shell,
  .app-song-table-shell,
  .leaderboard-table-shell {
    overflow: visible;
    border: 0;
    background: transparent;
  }

  .browse-chart-table,
  .app-song-table,
  .leaderboard-table,
  .browse-chart-table thead,
  .app-song-table thead,
  .leaderboard-table thead,
  .browse-chart-table tbody,
  .app-song-table tbody,
  .leaderboard-table tbody {
    display: block;
    width: 100%;
    min-width: 0;
  }

  .browse-chart-table thead,
  .app-song-table thead,
  .leaderboard-table thead {
    display: none;
  }

  .browse-chart-table tbody,
  .app-song-table tbody,
  .leaderboard-table tbody {
    display: grid;
    gap: 12px;
  }

  .browse-chart-table tbody tr,
  .app-song-table tbody tr,
  .leaderboard-table tbody tr {
    display: grid;
    gap: 10px 12px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: var(--row-even);
  }

  .browse-chart-table tbody tr:nth-child(even),
  .app-song-table tbody tr:nth-child(even),
  .leaderboard-table tbody tr:nth-child(even) {
    background: var(--row-even);
  }

  .browse-chart-table td,
  .app-song-table td,
  .leaderboard-table td {
    display: grid;
    gap: 4px;
    padding: 0;
    border: 0;
    overflow: visible;
    text-align: left;
    min-width: 0;
  }

  .browse-chart-table td::before,
  .app-song-table td::before,
  .leaderboard-table td::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #5d6f83;
  }

  .browse-chart-table .browse-table-row.is-hidden {
    display: none !important;
  }

  .browse-chart-table tbody tr {
    grid-template-columns: 74px repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .browse-chart-table .browse-index-cell {
    display: none;
  }

  .browse-chart-table .rating-cell {
    display: none;
  }

  .browse-chart-table .browse-jacket-table-cell {
    display: grid !important;
    grid-column: 1;
    grid-row: 1 / span 6;
    align-self: start;
    justify-items: center;
  }

  .browse-chart-table .browse-jacket-table-cell::before,
  .browse-chart-table .browse-title-table-cell::before,
  .browse-chart-table .browse-ms-table-cell::before,
  .browse-chart-table .browse-action-cell::before {
    display: none;
  }

  .browse-chart-table .browse-title-table-cell {
    grid-column: 2 / -1;
    text-align: left;
  }

  .browse-chart-table .browse-score-cell,
  .browse-chart-table .browse-compare-cell {
    grid-column: 2 / -1;
  }

  .browse-chart-table.is-personal .browse-chain-cell,
  .browse-chart-table.is-personal .browse-damage-cell,
  .browse-chart-table.is-personal .browse-played-cell,
  .browse-chart-table.is-personal .browse-date-cell,
  .browse-chart-table.is-personal .browse-compare-cell {
    display: grid !important;
  }

  .browse-chart-table .browse-ms-table-cell,
  .browse-chart-table .browse-action-cell {
    display: none !important;
  }

  .browse-chart-table .browse-badge-cell,
  .browse-chart-table .browse-crown-cell,
  .browse-chart-table .browse-rank-cell,
  .browse-chart-table.is-personal .browse-badge-cell,
  .browse-chart-table.is-personal .browse-crown-cell,
  .browse-chart-table.is-personal .browse-rank-cell {
    display: none !important;
  }

  .browse-jacket-square {
    width: 74px;
    height: 74px;
  }

  .browse-mobile-ms {
    display: grid;
    justify-items: center;
    margin-top: 8px;
    gap: 8px;
  }

  .browse-mobile-actions {
    display: grid;
    justify-items: center;
  }

  .browse-song-title {
    font-size: 17px;
    line-height: 1.15;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  .browse-ms-table-cell,
  .browse-badge-cell,
  .browse-crown-cell,
  .browse-rank-cell {
    justify-items: start;
  }

  .browse-ms-asset {
    width: 56px;
    height: 56px;
  }

  .browse-mobile-actions .row-actions-menu {
    z-index: 2;
  }

  .browse-chart-table .browse-score-cell,
  .browse-chart-table .browse-compare-cell {
    font-size: 16px;
  }

  .browse-chart-table .browse-score-cell strong,
  .browse-chart-table .browse-compare-cell strong {
    font-size: 18px;
    line-height: 1.05;
  }

  .browse-status-asset {
    width: 32px;
    height: 32px;
  }

  .browse-rank-asset {
    width: 40px;
  }

  .browse-compare-cell strong {
    font-size: 14px;
  }

  .app-song-table tbody tr {
    grid-template-columns: repeat(2, minmax(0, 1fr)) 44px;
    align-items: start;
    padding: 12px;
  }

  .app-song-table .song-action-cell {
    grid-column: 3;
    grid-row: 1 / span 3;
    justify-self: end;
    align-self: start;
  }

  .app-song-table .song-action-cell::before {
    display: none;
  }

  .app-song-table .song-badge-cell,
  .app-song-table .song-crown-cell,
  .app-song-table .song-rank-cell {
    justify-items: start;
  }

  .app-song-table .song-date-cell,
  .leaderboard-table .leaderboard-date-cell {
    white-space: nowrap;
    font-size: 12px;
  }

  .app-song-table td {
    overflow-wrap: anywhere;
  }

  .app-song-table .song-date-cell {
    grid-column: 1 / span 2;
    white-space: normal;
    line-height: 1.15;
    font-size: 11px;
  }

  .leaderboard-table tbody tr {
    grid-template-columns: 40px minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
  }

  .leaderboard-table .leaderboard-position-cell {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border-radius: 0;
    background: transparent;
    font-size: 18px;
    font-weight: 900;
  }

  .leaderboard-table .leaderboard-position-cell::before {
    display: none;
  }

  .leaderboard-table .leaderboard-player-cell {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
  }

  .leaderboard-table .leaderboard-player-cell::before {
    display: none;
  }

  .leaderboard-table .leaderboard-player-cell a {
    display: block;
    flex: 0 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 15px;
    font-weight: 800;
  }

  .leaderboard-table .you-tag {
    margin-left: 0;
    padding: 1px 6px;
    flex: 0 0 auto;
    width: fit-content;
    max-width: max-content;
    justify-self: start;
    align-self: center;
    font-size: 10px;
    line-height: 1.1;
  }

  .leaderboard-table .leaderboard-score-cell {
    grid-column: 3;
    grid-row: 1;
    font-size: 16px;
    font-weight: 900;
    white-space: nowrap;
  }

  .leaderboard-table .leaderboard-date-cell {
    grid-column: 4;
    grid-row: 1;
    justify-self: end;
    align-self: center;
    white-space: nowrap;
    font-size: 11px;
  }

  .leaderboard-table td::before {
    display: none;
  }

  .leaderboard-table .leaderboard-rank-cell {
    display: none;
  }

  .leaderboard-table .leaderboard-badge-cell {
    display: none;
  }

  .leaderboard-table .leaderboard-played-cell {
    display: none;
  }

  .leaderboard-table .leaderboard-damage-cell {
    grid-column: 3;
    grid-row: 1;
    white-space: nowrap;
    font-size: 16px;
    font-weight: 900;
  }

  .leaderboard-table-panel[data-board-sort="score"] .leaderboard-damage-cell {
    display: none;
  }

  .leaderboard-table-panel[data-board-sort="max_damage"] .leaderboard-score-cell {
    display: none;
  }

  .leaderboard-controls {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .leaderboard-style-host,
  .leaderboard-sort-row,
  .leaderboard-difficulty-buttons {
    justify-content: flex-start;
  }

  .song-controls-row {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .song-controls-right {
    justify-content: flex-end;
  }
}

@media (max-width: 720px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .page-shell,
  .app-panel,
  .panel,
  .empty-panel,
  .feed-section,
  .home-card-grid,
  .home-score-card,
  .profile-profica-shell,
  .profile-profica-card,
  .song-group-panel,
  .leaderboard-panel,
  .tier-top-grid,
  .tier-focus-panel,
  .tier-ap-panel,
  .tier-ranking-panel,
  .profile-summons-panel {
    max-width: 100%;
    min-width: 0;
  }

  .home-intro .summary-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
  }

  .home-intro .summary-strip div {
    min-width: 0;
    padding: 10px;
  }

  .home-intro .summary-strip dd {
    font-size: 22px;
  }

  .home-card-grid {
    justify-items: center;
  }

  .home-score-card {
    width: 100%;
    max-width: 420px;
  }

  .song-group-panel {
    overflow: hidden;
  }

  .app-song-table-shell {
    padding-inline: 2px;
  }

  .tier-focus-head {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .tier-focus-head-right {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    justify-items: stretch;
    gap: 10px;
    width: 100%;
  }

  .tier-style-host {
    justify-content: flex-start;
  }

  .tier-view-row {
    justify-content: flex-start;
  }

  .tier-view-row select {
    min-width: 0;
    width: 100%;
  }

  .tier-focus-meta {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .tier-focus-meta span {
    min-width: 0;
    padding: 10px 8px;
    font-size: 12px;
  }

  .profile-profica-card {
    width: min(876px, 100%);
    aspect-ratio: 876 / 408;
    min-height: 0;
  }

  .profile-profica-overlay {
    padding: 12px 14px;
    gap: 8px;
    align-content: space-between;
  }

  .profile-profica-top {
    flex-direction: row;
    align-items: flex-start;
    gap: 8px;
  }

  .profile-profica-top h1 {
    font-size: 24px;
    margin: 0;
  }

  .profile-profica-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    margin-top: auto;
  }

  .profile-profica-metrics article {
    padding: 6px 8px;
    border-radius: 12px;
  }

  .profile-profica-metrics span {
    font-size: 8px;
    letter-spacing: 0.04em;
  }

  .profile-profica-metrics strong {
    margin-top: 4px;
    font-size: 14px;
  }

  .browse-table-shell,
  .app-song-table-shell,
  .leaderboard-table-shell {
    overflow-x: hidden;
    overflow-y: visible;
  }

  .summons-panel .table-shell,
  .profile-summons-panel .table-shell {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .summons-table {
    display: table;
    width: 100%;
    min-width: 720px;
    table-layout: fixed;
  }

  .summons-table thead {
    display: table-header-group;
  }

  .summons-table tbody {
    display: table-row-group;
  }

  .summons-table tbody tr {
    display: table-row;
  }

  .summons-table th,
  .summons-table td {
    display: table-cell;
    font-size: 11px;
    padding: 8px 4px;
  }

  .summons-icons-row th {
    padding-bottom: 4px;
  }

  .summons-premium-head,
  .summons-premium-cell {
    width: 30px;
  }

  .summons-ability-head,
  .summons-ability-cell {
    width: 154px;
    min-width: 154px;
    text-align: left;
    font-size: 11px;
  }

  .summons-rate-head,
  .summons-rate-cell {
    width: 58px;
    min-width: 58px;
    font-size: 11px;
  }

  .summons-stone-head img {
    width: 30px;
    height: 30px;
  }

  .summons-toggle-cell {
    min-width: 42px;
  }

  .summon-toggle span {
    width: 20px;
    height: 20px;
  }

  .summons-premium-icon {
    width: 18px;
    height: 18px;
  }
}

/* -- Site footer -- */
.site-footer {
  border-top: 1px solid var(--border);
  background: var(--header-bg);
  margin-top: 32px;
  padding: 14px 0;
  font-size: 13px;
  color: var(--text-primary);
}

.site-footer-inner {
  width: min(1320px, calc(100% - 24px));
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.site-footer-copy {
  opacity: 0.75;
}

.site-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.site-footer-links a {
  color: var(--link);
  text-decoration: none;
}

.site-footer-links a:hover {
  text-decoration: underline;
}

/* -- Legal pages -- */
.legal-panel h2 {
  margin-top: 24px;
  margin-bottom: 6px;
}

.legal-panel ul {
  margin: 6px 0 0 20px;
  padding: 0;
  line-height: 1.7;
}

/* v6: home import tip and Profica stat layout */
.home-import-tip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0 0 18px;
  padding: 14px 16px;
  border: 1px solid rgba(49, 115, 181, 0.24);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(75, 164, 255, 0.16), rgba(255, 255, 255, 0.86));
  box-shadow: 0 8px 20px rgba(38, 55, 74, 0.08);
  color: var(--text-primary);
}

.home-import-tip div {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}

.home-import-tip strong {
  font-size: 15px;
  font-weight: 900;
}

.home-import-tip span {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-muted);
}

.home-import-tip-close {
  appearance: none;
  border: 0;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: rgba(18, 36, 56, 0.10);
  color: var(--text-primary);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  flex: 0 0 auto;
}

.home-import-tip-close:hover {
  background: rgba(18, 36, 56, 0.18);
}

body.theme-dark .home-import-tip {
  background: linear-gradient(135deg, rgba(75, 164, 255, 0.18), rgba(20, 32, 46, 0.92));
  border-color: rgba(135, 194, 255, 0.24);
}

body.theme-dark .home-news-ticker {
  border-color: rgba(135, 194, 255, 0.20);
  background: #162333;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.20);
}

body.theme-dark .home-news-ticker-item {
  border-bottom-color: rgba(135, 194, 255, 0.15);
}

body.theme-dark .home-news-ticker-time {
  color: #9aa8b8;
}

body.theme-dark .home-news-ticker-part-user {
  color: #8ec4ff;
}

body.theme-dark .home-news-ticker-part-song {
  color: #8ec4ff;
}

body.theme-dark .home-news-ticker-part-chart {
  background: rgba(142, 196, 255, 0.12);
}

body.theme-dark .home-news-ticker-part-score,
body.theme-dark .home-news-ticker-part-placement {
  color: #69dbb0;
}

body.theme-dark .home-news-ticker-part-requirement,
body.theme-dark .home-news-ticker-part-tier {
  color: #d3a1ff;
}

body.theme-dark .home-feed-page-button {
  border-color: rgba(135, 194, 255, 0.22);
  background: #162333;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.20);
}

body.theme-dark .home-import-tip-close {
  background: rgba(255, 255, 255, 0.12);
  color: #f4f8fc;
}

.profile-profica-metrics {
  justify-self: start;
  align-self: end;
  width: min(384px, 44%);
  max-width: 384px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: auto;
}

.profile-profica-metrics article {
  padding: 8px 10px;
}

.profile-profica-metric-tier {
  align-content: start;
  text-align: center;
  justify-items: center;
  gap: 4px;
}

.profile-profica-metric-tier .profile-profica-metric-label {
  width: 100%;
  text-align: center;
}

.profile-profica-tier-icon {
  display: block;
  width: auto;
  height: auto;
  max-width: 32px;
  max-height: 32px;
  margin: 2px auto 0;
  object-fit: contain;
}

@media (max-width: 720px) {
  .home-import-tip {
    align-items: flex-start;
    padding: 12px;
    border-radius: 16px;
  }

  .home-import-tip div {
    display: grid;
    gap: 2px;
  }

  .home-import-tip strong {
    font-size: 13px;
  }

  .home-import-tip span {
    font-size: 12px;
    line-height: 1.25;
  }

  .home-import-tip-close {
    width: 28px;
    height: 28px;
    font-size: 21px;
  }

  .profile-profica-overlay {
    position: relative;
    padding: 9px 10px;
    gap: 6px;
  }

  .profile-profica-top {
    max-width: calc(100% - 118px);
  }

  .profile-profica-top h1 {
    font-size: 20px;
    line-height: 1.05;
    margin: 0;
  }

  .profile-profica-metrics {
    position: absolute;
    left: 8px;
    bottom: 8px;
    width: 112px;
    max-width: 112px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 4px;
    margin: 0;
  }

  .profile-profica-metrics article {
    padding: 3px 5px;
    border-radius: 9px;
  }

  .profile-profica-metrics span {
    font-size: 6px;
    line-height: 1;
    letter-spacing: 0.025em;
  }

  .profile-profica-metrics strong {
    margin-top: 2px;
    font-size: 10px;
    line-height: 1;
  }

  .profile-profica-tier-icon {
    max-width: 18px;
    max-height: 18px;
    margin-top: 1px;
  }
}

/* Shared UI consistency pass */
.toggle-pill span {
  min-height: 40px;
  padding: 0 14px;
  border-width: 1px;
  background: linear-gradient(180deg, #bcc9d6 0%, #acbccd 100%);
  color: var(--text-primary);
  font-weight: 800;
  cursor: pointer;
  transition: transform 0.16s ease, background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.toggle-pill span:hover {
  transform: translateY(-1px);
}

.toggle-pill.is-selected span {
  background: linear-gradient(180deg, #d7e6f8 0%, #c4d7ed 100%);
  border-color: #5f89bf;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.7), 0 8px 18px rgba(64, 92, 124, 0.12);
}

.toggle-pill input:focus-visible + span {
  outline: none;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.7), 0 0 0 3px rgba(95, 137, 191, 0.18);
}

body.theme-dark .toggle-pill span {
  background: linear-gradient(180deg, #223447 0%, #192836 100%);
  border-color: #4d657d;
  color: var(--text-primary);
}

body.theme-dark .toggle-pill.is-selected span {
  background: linear-gradient(180deg, #42617d 0%, #34506a 100%);
  border-color: #89b8ee;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.18), 0 8px 18px rgba(0, 0, 0, 0.22);
}

.home-import-tip-close {
  display: grid;
  place-items: center;
  padding: 0;
  font-size: 20px;
  text-align: center;
}

.profile-profica-actions {
  position: relative;
  z-index: 2;
}

.profile-profica-metric {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 6px;
  align-content: stretch;
  align-items: center;
  justify-items: center;
  min-height: 0;
  text-align: center;
}

.profile-profica-metric-label {
  display: block;
  width: auto;
  max-width: 100%;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
  align-self: end;
  justify-self: center;
}

.profile-profica-metric-value {
  display: block;
  min-width: 0;
  width: auto;
  max-width: 100%;
  margin: 0;
  text-align: center;
  align-self: center;
  justify-self: center;
}

.profile-profica-metrics {
  grid-auto-rows: minmax(0, 1fr);
  overflow: hidden;
}

.profile-profica-metric-tier {
  align-content: start;
  justify-items: center;
  gap: 4px;
}

.profile-profica-tier-icon {
  justify-self: center;
  align-self: center;
  margin: 0 auto;
}

.profica-export-menu .row-actions-trigger {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.46);
  box-shadow: none;
}

.profica-export-menu .row-actions-trigger:hover {
  background: rgba(255, 255, 255, 0.12);
}

.profica-export-menu .row-actions-dropdown {
  background: rgba(10, 18, 29, 0.94);
  border-color: rgba(255, 255, 255, 0.2);
}

.profica-export-menu .row-actions-link {
  color: #f6fbff;
}

.profica-export-menu .row-actions-link:hover {
  background: rgba(255, 255, 255, 0.08);
}

.tier-table .tier-col-player a {
  display: inline-block;
  max-width: 100%;
  vertical-align: middle;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .tier-table {
    table-layout: auto;
  }

  .tier-table .tier-col-reqs {
    display: none;
  }

  .tier-table th,
  .tier-table td {
    padding: 10px 8px;
    font-size: 13px;
  }

  .tier-table .tier-col-rank {
    white-space: nowrap;
    width: 1%;
  }

  .tier-table .tier-col-tier,
  .tier-table .tier-col-accuracy {
    white-space: nowrap;
  }

  .tier-table .you-tag {
    display: none;
  }

  .profile-profica-metrics {
    max-height: calc(100% - 16px);
    align-content: end;
  }

  .profile-profica-metrics .profile-profica-metric {
    max-height: 34px;
    gap: 1px;
    padding-block: 0;
    overflow: hidden;
  }

  .profile-profica-metric-label {
    line-height: 1;
  }

  .profile-profica-metric-value {
    line-height: 0.95;
  }
}

/* Profica export and action menu positioning fixes */
.row-actions-menu[open] {
  z-index: 4000;
}

.row-actions-dropdown {
  position: fixed;
  top: -9999px;
  left: -9999px;
  right: auto;
  max-width: min(220px, calc(100vw - 20px));
  z-index: 4001;
}

.profile-profica-card {
  isolation: isolate;
}

.profile-profica-top {
  min-width: 0;
}

.profile-profica-top > :first-child {
  min-width: 0;
}

.profile-profica-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-left: auto;
  flex: initial;
  justify-content: flex-end;
}

.profica-export-menu,
.profile-profica-menu {
  flex: 0 0 auto;
}

.profile-profica-metrics {
  position: static;
  justify-self: start;
  align-self: end;
  width: min(384px, 44%);
  max-width: 384px;
  height: auto;
  max-height: none;
  margin-top: auto;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: 74px;
  gap: 8px;
  align-content: end;
}

.profile-profica-metrics .profile-profica-metric {
  min-height: 74px;
  height: 74px;
  max-height: 74px;
  padding: 8px 10px;
  gap: 4px;
  overflow: hidden;
}

.profile-profica-metric-label {
  line-height: normal;
}

.profile-profica-metric-value {
  line-height: 1;
}

.profile-profica-export-url {
  position: static;
  display: none;
  max-width: min(420px, calc(100vw - 80px));
  margin-top: 4px;
  color: rgba(238, 245, 255, 0.92);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-text-stroke: 0.6px rgba(0, 0, 0, 0.55);
  paint-order: stroke fill;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.7);
  pointer-events: none;
}

.profile-profica-card.is-exporting .profile-profica-export-url {
  display: block;
}

.profile-profica-card.is-exporting .profile-profica-actions,
.profile-profica-card.is-exporting .profica-export-menu,
.profile-profica-card.is-exporting .profile-profica-menu,
.profile-profica-card.is-exporting .row-actions-menu,
.profile-profica-card.is-exporting .row-actions-trigger,
.profile-profica-card.is-exporting .row-actions-dropdown {
  display: none !important;
}

.profile-profica-card.is-exporting .profile-profica-top {
  max-width: 100% !important;
  padding-right: 0 !important;
}

.profile-profica-card.is-exporting .profile-profica-metric {
  overflow: visible;
}

.profile-profica-card.is-exporting .profile-profica-metric-label,
.profile-profica-card.is-exporting .profile-profica-metric-value {
  width: 100%;
  padding-inline: 3px;
  overflow: visible;
  text-overflow: clip;
  white-space: nowrap;
  text-align: center;
}

@media (max-width: 720px) {
  .profile-profica-top {
    max-width: calc(100% - 118px);
    padding-right: 42px;
  }

  .profile-profica-actions {
    position: static;
    gap: 6px;
  }

  .profica-export-menu,
  .profile-profica-menu {
    position: absolute;
    top: 9px;
    right: 10px;
    margin: 0;
    z-index: 8;
  }

  .user-profica-actions {
    top: 12px;
    left: 12px;
  }

  .user-profica-overlay strong {
    left: 12px;
    bottom: 12px;
    max-width: calc(100% - 24px);
  }

  .profile-profica-export-url {
    max-width: 180px;
    margin-top: 2px;
    font-size: 8px;
  }

  .profile-profica-metrics {
    position: absolute;
    left: 8px;
    top: var(--profile-profica-metrics-top, 54px);
    bottom: auto;
    width: 112px;
    max-width: 112px;
    height: var(--profile-profica-metrics-height, auto);
    max-height: var(--profile-profica-metrics-height, none);
    align-content: stretch;
    grid-template-columns: 1fr;
    grid-auto-rows: var(--profile-profica-metric-height, 1fr);
    gap: 4px;
    margin: 0;
  }

  .profile-profica-metrics .profile-profica-metric {
    min-height: var(--profile-profica-metric-height, 0);
    height: var(--profile-profica-metric-height, auto);
    max-height: var(--profile-profica-metric-height, none);
    padding: 3px 5px;
    gap: 2px;
    overflow: hidden;
  }

  .profile-profica-metric-label {
    line-height: 1.05;
  }

  .profile-profica-metric-value {
    line-height: 1;
  }

  .profile-profica-tier-icon {
    max-width: 24px;
    max-height: 24px;
  }
}


/* Desktop-density mobile override.
   Keep the mobile header/menu behavior, but stop score/browse/leaderboard tables
   from turning into mobile cards or hiding badge/crown/rank columns. */
@media (max-width: 880px) {
  html,
  body {
    overflow-x: hidden;
  }

  .browse-table-shell,
  .app-song-table-shell,
  .leaderboard-table-shell {
    overflow-x: hidden !important;
    overflow-y: visible !important;
    border: 1px solid var(--border);
    background: var(--panel);
  }

  .browse-chart-table,
  .app-song-table,
  .leaderboard-table {
    display: table !important;
    width: 100% !important;
    min-width: 0 !important;
    table-layout: fixed !important;
  }

  .browse-chart-table {
    min-width: 0 !important;
  }

  .browse-chart-table.is-public {
    min-width: 0 !important;
    table-layout: fixed !important;
  }

  .app-song-table,
  .leaderboard-table {
    min-width: 0 !important;
  }

  .browse-chart-table thead,
  .app-song-table thead,
  .leaderboard-table thead {
    display: table-header-group !important;
  }

  .browse-chart-table tbody,
  .app-song-table tbody,
  .leaderboard-table tbody {
    display: table-row-group !important;
  }

  .browse-chart-table tbody tr,
  .app-song-table tbody tr,
  .leaderboard-table tbody tr {
    display: table-row !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .browse-chart-table tbody tr.is-hidden {
    display: none !important;
  }

  .browse-chart-table th,
  .browse-chart-table td,
  .app-song-table th,
  .app-song-table td,
  .leaderboard-table th,
  .leaderboard-table td {
    display: table-cell !important;
    padding: 7px 6px !important;
    border-bottom: 1px solid var(--border);
    text-align: center;
    vertical-align: middle;
    overflow: hidden;
  }

  .browse-chart-table td::before,
  .app-song-table td::before,
  .leaderboard-table td::before {
    display: none !important;
    content: none !important;
  }

  .browse-chart-table .browse-title-table-cell,
  .app-song-table .song-title-cell,
  .leaderboard-table .leaderboard-player-cell {
    text-align: left !important;
  }

  .browse-chart-table .browse-index-cell,
  .browse-chart-table .rating-cell,
  .browse-chart-table .browse-jacket-table-cell,
  .browse-chart-table .browse-title-table-cell,
  .browse-chart-table .browse-ms-table-cell,
  .browse-chart-table .browse-badge-cell,
  .browse-chart-table .browse-crown-cell,
  .browse-chart-table .browse-rank-cell,
  .browse-chart-table .browse-chain-cell,
  .browse-chart-table .browse-damage-cell,
  .browse-chart-table .browse-played-cell,
  .browse-chart-table .browse-date-cell,
  .browse-chart-table .browse-score-cell,
  .browse-chart-table .browse-compare-cell,
  .browse-chart-table .browse-action-cell,
  .browse-chart-table.is-personal .browse-badge-cell,
  .browse-chart-table.is-personal .browse-crown-cell,
  .browse-chart-table.is-personal .browse-rank-cell {
    display: table-cell !important;
  }

  .browse-chart-table.is-personal .col-ms,
  .browse-chart-table.is-personal .browse-ms-table-cell,
  .browse-chart-table.is-personal .col-crown,
  .browse-chart-table.is-personal .browse-crown-cell,
  .browse-chart-table.is-personal .col-rank,
  .browse-chart-table.is-personal .browse-rank-cell,
  .browse-chart-table.is-personal .col-chain,
  .browse-chart-table.is-personal .browse-chain-cell,
  .browse-chart-table.is-personal .col-damage,
  .browse-chart-table.is-personal .browse-damage-cell,
  .browse-chart-table.is-personal .col-played,
  .browse-chart-table.is-personal .browse-played-cell,
  .browse-chart-table.is-personal .col-date,
  .browse-chart-table.is-personal .browse-date-cell {
    display: none !important;
  }

  .browse-mobile-ms,
  .browse-mobile-actions {
    display: none !important;
  }

  .browse-jacket-square {
    width: 58px !important;
    height: 58px !important;
  }

  .browse-song-title {
    font-size: 13px !important;
    line-height: 1.12;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .browse-song-series,
  .browse-difficulty-tag {
    font-size: 10px !important;
    line-height: 1.1;
  }

  .browse-status-asset {
    width: 28px !important;
    height: 28px !important;
  }

  .browse-rank-asset {
    width: 36px !important;
  }

  .browse-ms-asset {
    width: 44px !important;
    height: 44px !important;
  }

  .browse-chart-table .browse-score-cell,
  .browse-chart-table .browse-compare-cell,
  .browse-chart-table .browse-score-cell strong,
  .browse-chart-table .browse-compare-cell strong {
    font-size: 13px !important;
    line-height: 1.05;
  }
}

@media (max-width: 720px) {
  .browse-table-shell,
  .app-song-table-shell,
  .leaderboard-table-shell {
    overflow-x: hidden !important;
    overflow-y: visible !important;
  }
}

@media (max-device-width: 760px), (hover: none) and (pointer: coarse) {
  .site-header-inner,
  .page-shell,
  .site-footer-inner {
    width: 980px;
    max-width: none;
    min-width: 980px;
  }

  .page-shell,
  .site-footer-inner {
    overflow-x: visible;
  }

  .profile-menu-trigger-card {
    width: 120px;
    height: 120px;
    border-radius: 24px;
  }

  .profile-profica-shell {
    width: 100%;
  }

  .profile-profica-card {
    width: 100%;
  }

  .profile-stats-table-shell {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
  }

  .profile-stats-table {
    width: 1900px !important;
    min-width: 1900px !important;
    table-layout: fixed !important;
  }
}
