:root {
  color-scheme: light;

  --font-sans:
    'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial,
    'Apple Color Emoji', 'Segoe UI Emoji';

  --ink: #0f172a;
  --bg: #f6f8fc;
  --surface: #ffffff;

  --muted: rgba(15, 23, 42, 0.72);
  --subtle: rgba(15, 23, 42, 0.62);

  --border: rgba(15, 23, 42, 0.14);
  --border-strong: rgba(15, 23, 42, 0.22);

  --brand-1: #22c1c3;
  --brand-1-rgb: 34 193 195;
  --brand-2: #6366f1;
  --brand-2-rgb: 99 102 241;
  --brand-gradient: linear-gradient(135deg,
    var(--brand-1) 0%,
    var(--brand-2) 100%);
  --brand-gradient-soft-border: linear-gradient(135deg,
    rgb(var(--brand-1-rgb) / 0.28),
    rgb(var(--brand-2-rgb) / 0.32));
  --brand-hover-fill: rgb(var(--brand-1-rgb) / 0.18);
  --brand-hover-shadow: rgb(var(--brand-1-rgb) / 0.28);
  --brand-ambient-light-start: rgb(var(--brand-1-rgb) / 0.09);
  --brand-ambient-light-end: rgb(var(--brand-2-rgb) / 0.09);
  --brand-ambient-dark-start: rgb(var(--brand-1-rgb) / 0.14);
  --brand-ambient-dark-end: rgb(var(--brand-2-rgb) / 0.14);

  --btn-dark: linear-gradient(180deg,
      rgba(30, 41, 59, 1) 0%,
      rgba(15, 23, 42, 1) 100%);

  --danger: #ef4444;
  --warning: #f59e0b;
  --info: #3b82f6;
  --love: #ec4899;

  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.12);
  --shadow-md: 0 14px 35px rgba(15, 23, 42, 0.18);

  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 18px;

  --ring: 0 0 0 3px rgb(var(--brand-2-rgb) / 0.22);
  --home-featured-collapsed: clamp(220px, calc(100svh - 150px), 555px);
}

html[data-theme='dark'] {
  color-scheme: dark;

  --ink: rgba(226, 232, 240, 0.92);
  --bg: #0b1220;
  --surface: rgba(15, 23, 42, 0.92);

  --muted: rgba(226, 232, 240, 0.74);
  --subtle: rgba(226, 232, 240, 0.6);

  --border: rgba(148, 163, 184, 0.22);
  --border-strong: rgba(148, 163, 184, 0.32);

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.45);
  --shadow-md: 0 18px 45px rgba(0, 0, 0, 0.55);

  --ring: 0 0 0 3px rgb(var(--brand-2-rgb) / 0.32);
  --love: #f472b6;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  height: auto;
  min-height: 100%;
}

html {
  background: var(--bg);
}

body {
  margin: 0;
  font-family: var(--font-sans);
  line-height: 1.45;
  color: var(--ink);
  background: transparent;
  -webkit-overflow-scrolling: touch;
}

html {
  background-image:
    radial-gradient(900px 520px at 10% 0%,
      var(--brand-ambient-light-start),
      transparent 60%),
    radial-gradient(760px 520px at 90% 0%,
      var(--brand-ambient-light-end),
      transparent 55%);
  background-attachment: fixed;
  background-repeat: no-repeat;
}

html[data-theme='dark'] {
  background-image:
    radial-gradient(900px 520px at 10% 0%,
      var(--brand-ambient-dark-start),
      transparent 60%),
    radial-gradient(760px 520px at 90% 0%,
      var(--brand-ambient-dark-end),
      transparent 55%);
}

@media (max-width: 700px) {

  html {
    background: var(--bg);
  }

  body {
    background: transparent;
  }

  html[data-theme='dark'] {
    background: #0b1220;
  }
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

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

h1,
h2,
h3 {
  line-height: 1.15;
}

h1 {
  font-size: 1.4rem;
  margin: 0;
}

h2 {
  font-size: 1.15rem;
  margin: 0 0 0.75rem 0;
}

h3 {
  font-size: 1rem;
  margin: 0 0 0.5rem 0;
}

main {
  max-width: 980px;
  margin: 0 auto;
  padding: 1.25rem;
}

header {
  position: sticky;
  top: 12px;
  z-index: 10;
  backdrop-filter: none;
  background: var(--brand-gradient);
  border: 1px solid #0f172a;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  margin: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1.1rem;
}

header h1 a {
  display: inline-block;
  font-weight: 900;
  font-size: 1.7rem;
  letter-spacing: 0.06em;
  text-decoration: none;
  color: #0f172a;
  padding: 0 0.2rem;
  border-radius: var(--radius-sm);
  transition:
    box-shadow 140ms ease,
    transform 140ms ease;
}

header h1 a:hover {
  text-decoration: none;
  background: var(--brand-hover-fill);
  box-shadow: inset 0 -0.55em 0 var(--brand-hover-shadow);
  transform: translateY(-1px);
}

navbar {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  flex-wrap: wrap;
  color: #0f172a;
  font-size: 0.9rem;
}

navbar .nav-toggle-label {
  margin-left: auto;
}

navbar .nav-mobile-search {
  display: none;
}

.container>.nav-search-toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.container>.nav-mobile-search-panel {
  display: none;
}

navbar .nav-panel {
  display: none;
}

navbar .nav-panel-backdrop {
  display: none;
}

navbar .nav-toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

navbar .nav-toggle-label {
  display: none;
  width: 40px;
  height: 40px;
  position: relative;
  border-radius: 10px;
  border: 1px solid rgba(226, 232, 240, 0.18);
  background:
    linear-gradient(rgba(15, 23, 42, 0.78), rgba(15, 23, 42, 0.68)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  box-shadow:
    0 14px 28px rgba(2, 6, 23, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition:
    transform 140ms ease,
    box-shadow 140ms ease,
    border-color 140ms ease,
    background 140ms ease;
}

navbar .nav-toggle-label:hover {
  transform: translateY(-1px);
  box-shadow:
    0 16px 32px rgba(2, 6, 23, 0.46),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

navbar .nav-toggle-label:focus-visible {
  outline: none;
  box-shadow: var(--ring);
  border-color: var(--brand-2);
}

navbar .nav-toggle-label:active {
  transform: translateY(0);
}

navbar .nav-toggle-label .nav-toggle-bar {
  display: block;
  width: 17px;
  height: 2px;
  background: rgba(226, 232, 240, 0.9);
  border-radius: 999px;
}

navbar .nav-toggle-label .nav-toggle-count {
  position: absolute;
  display: grid;
  place-items: center;
  min-width: 1.4rem;
  height: 1.4rem;
  padding: 0 0.28rem;
  border: 2px solid #000;
  background: #dc2626;
  color: #fff;
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  box-shadow:
    0 10px 18px rgba(15, 23, 42, 0.18),
    0 0 0 1px rgba(255, 255, 255, 0.16);
  pointer-events: none;
  transition: opacity 140ms ease, visibility 140ms ease;
}

navbar .nav-toggle-label .nav-toggle-count-alert {
  right: 0;
  top: 0;
  transform: translate(50%, -50%);
}

navbar .nav-toggle-label .nav-toggle-count-activity {
  right: 0;
  top: auto;
  bottom: 0;
  transform: translate(50%, 50%);
  background: #2563eb;
  box-shadow:
    0 10px 18px rgba(37, 99, 235, 0.28),
    0 0 0 1px rgba(255, 255, 255, 0.16);
}

header navbar {
  flex: 1;
  min-width: 0;
  position: relative;
}

header navbar .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex: 1;
  flex-wrap: wrap;
  min-width: 0;
}

header navbar .nav-search {
  margin-left: auto;
}

.nav-search {
  position: relative;
  display: inline-flex;
  align-items: center;
  margin-left: 0.35rem;
}

.nav-search::before {
  content: '';
  position: absolute;
  left: 12px;
  width: 16px;
  height: 16px;
  pointer-events: none;
  opacity: 0.6;
  background-repeat: no-repeat;
  background-size: 16px 16px;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D'http%3A//www.w3.org/2000/svg'%20viewBox%3D'0%200%2024%2024'%20fill%3D'none'%20stroke%3D'%230f172a'%20stroke-width%3D'2'%20stroke-linecap%3D'round'%20stroke-linejoin%3D'round'%3E%3Ccircle%20cx%3D'11'%20cy%3D'11'%20r%3D'7'/%3E%3Cpath%20d%3D'M21%2021l-4.3-4.3'/%3E%3C/svg%3E");
}

html[data-theme='dark'] .nav-search::before {
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D'http%3A//www.w3.org/2000/svg'%20viewBox%3D'0%200%2024%2024'%20fill%3D'none'%20stroke%3D'%23e2e8f0'%20stroke-width%3D'2'%20stroke-linecap%3D'round'%20stroke-linejoin%3D'round'%3E%3Ccircle%20cx%3D'11'%20cy%3D'11'%20r%3D'7'/%3E%3Cpath%20d%3D'M21%2021l-4.3-4.3'/%3E%3C/svg%3E");
}

.nav-search-input {
  width: 220px;
  max-width: 40vw;
  height: 34px;
  padding: 0 0.7rem 0 2.15rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #ffffff;
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}

html[data-theme='dark'] .nav-search-input {
  background: rgba(15, 23, 42, 0.72);
  border-color: var(--border);
  color: var(--ink);
}

html[data-theme='dark'] input::placeholder,
html[data-theme='dark'] textarea::placeholder {
  color: rgba(226, 232, 240, 0.55);
}

.nav-actions {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}

.nav-actions .nav-font-control {
  flex: 0 0 auto;
}

.nav-actions .nav-color-control {
  flex: 0 0 auto;
}

.nav-actions .nav-search {
  margin-left: 0;
}

.btn-nav.btn-icon {
  width: 34px;
  padding: 0;
}

.nav-theme-toggle {
  display: inline-flex;
}

.nav-theme-toggle .theme-icon {
  width: 18px;
  height: 18px;
}

.nav-mobile-search .nav-search-icon {
  width: 18px;
  height: 18px;
}

.nav-theme-toggle .icon-sun {
  display: none;
}

.nav-font-control {
  position: relative;
  display: inline-flex;
}

.nav-color-control {
  position: relative;
  display: inline-flex;
}

.nav-actions .nav-font-control::before,
.nav-actions .nav-color-control::before,
.nav-actions .nav-font-control::after,
.nav-actions .nav-color-control::after {
  position: absolute;
  left: 50%;
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 140ms ease,
    transform 140ms ease;
}

.nav-actions .nav-font-control::before,
.nav-actions .nav-color-control::before {
  content: '';
  top: calc(100% + 3px);
  width: 10px;
  height: 10px;
  border-right: 1px solid transparent;
  border-bottom: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.94), rgba(15, 23, 42, 0.94)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  transform: translate(-50%, -4px) rotate(45deg);
  z-index: 45;
}

.nav-actions .nav-font-control::after,
.nav-actions .nav-color-control::after {
  content: attr(data-tooltip);
  top: calc(100% + 10px);
  padding: 0.38rem 0.62rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.94), rgba(15, 23, 42, 0.94)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
  color: rgba(248, 250, 252, 0.98);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  white-space: nowrap;
  transform: translate(-50%, -4px);
  z-index: 46;
}

.nav-actions .nav-font-control:not(.is-open):hover::before,
.nav-actions .nav-font-control:not(.is-open):hover::after,
.nav-actions .nav-font-control:not(.is-open):focus-within::before,
.nav-actions .nav-font-control:not(.is-open):focus-within::after,
.nav-actions .nav-color-control:not(.is-open):hover::before,
.nav-actions .nav-color-control:not(.is-open):hover::after,
.nav-actions .nav-color-control:not(.is-open):focus-within::before,
.nav-actions .nav-color-control:not(.is-open):focus-within::after {
  opacity: 1;
}

.content_main .cred-compact {
  position: relative;
  display: inline-flex;
  align-items: center;
  transition: color 140ms ease, opacity 140ms ease;
}

.content_main .cred-compact[data-tooltip]::before,
.content_main .cred-compact[data-tooltip]::after {
  position: absolute;
  left: 50%;
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 140ms ease,
    transform 140ms ease;
}

.content_main .cred-compact[data-tooltip]::before {
  content: '';
  top: calc(100% + 3px);
  width: 10px;
  height: 10px;
  border-right: 1px solid transparent;
  border-bottom: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.94), rgba(15, 23, 42, 0.94)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  transform: translate(-50%, -4px) rotate(45deg);
  z-index: 45;
}

.content_main .cred-compact[data-tooltip]::after {
  content: attr(data-tooltip);
  top: calc(100% + 10px);
  padding: 0.38rem 0.62rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.94), rgba(15, 23, 42, 0.94)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
  color: rgba(248, 250, 252, 0.98);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  white-space: nowrap;
  transform: translate(-50%, -4px);
  z-index: 46;
}

.content_main .cred-compact:hover,
.content_main .cred-compact:focus-visible {
  color: var(--brand-2);
}

.content_main .cred-compact:hover::before,
.content_main .cred-compact:hover::after,
.content_main .cred-compact:focus-visible::before,
.content_main .cred-compact:focus-visible::after {
  opacity: 1;
}

.content_main .users-cred-compact {
  margin-left: auto;
  opacity: 0.75;
  font-weight: 900;
}

.nav-actions .nav-font-control:not(.is-open):hover::before,
.nav-actions .nav-font-control:not(.is-open):focus-within::before,
.nav-actions .nav-color-control:not(.is-open):hover::before,
.nav-actions .nav-color-control:not(.is-open):focus-within::before {
  transform: translate(-50%, 0) rotate(45deg);
}

.nav-actions .nav-font-control:not(.is-open):hover::after,
.nav-actions .nav-font-control:not(.is-open):focus-within::after,
.nav-actions .nav-color-control:not(.is-open):hover::after,
.nav-actions .nav-color-control:not(.is-open):focus-within::after {
  transform: translate(-50%, 0);
}

.nav-font-picker {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-sm);
  color: #0f172a;
  overflow: hidden;
}

.nav-font-picker-label {
  display: none;
}

.nav-color-picker {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-sm);
  color: #0f172a;
  overflow: hidden;
}

.nav-color-picker-label {
  display: none;
}

.nav-font-picker:focus-within {
  box-shadow: var(--ring);
  border-color: var(--brand-2);
}

.nav-color-picker:focus-within {
  box-shadow: var(--ring);
  border-color: var(--brand-2);
}

.nav-font-picker-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95rem;
  font-weight: 900;
  letter-spacing: -0.08em;
  line-height: 1;
}

.nav-color-picker-chip {
  display: inline-flex;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--brand-gradient);
  border: 1px solid rgba(15, 23, 42, 0.14);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.nav-font-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 45;
  display: none;
  min-width: 176px;
  padding: 0.45rem;
  border-radius: 22px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.18);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.nav-color-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 45;
  display: none;
  min-width: 196px;
  padding: 0.45rem;
  border-radius: 22px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.18);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.nav-font-control.is-open .nav-font-menu {
  display: grid;
  gap: 0.3rem;
}

.nav-color-control.is-open .nav-color-menu {
  display: grid;
  gap: 0.3rem;
}

.nav-font-option {
  display: inline-flex;
  width: 100%;
  min-height: 34px;
  align-items: center;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: #0f172a;
  font: inherit;
  font-weight: 800;
  text-align: left;
  cursor: pointer;
}

.nav-color-option {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) 24px;
  width: 100%;
  min-height: 38px;
  align-items: center;
  column-gap: 0.7rem;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: #0f172a;
  font: inherit;
  font-weight: 800;
  text-align: left;
  cursor: pointer;
}

.nav-font-option:hover,
.nav-font-option:focus-visible {
  outline: none;
  background: rgba(241, 245, 249, 0.96);
  border-color: rgba(148, 163, 184, 0.26);
}

.nav-color-option:hover,
.nav-color-option:focus-visible {
  outline: none;
  background: rgba(241, 245, 249, 0.96);
  border-color: rgba(148, 163, 184, 0.26);
}

.nav-font-option.is-active {
  border-color: transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.94)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.nav-color-option.is-active {
  border-color: transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.94)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.nav-color-option-swatch {
  display: inline-flex;
  grid-column: 1;
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: linear-gradient(135deg, var(--nav-color-start), var(--nav-color-end));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.nav-color-option-label {
  grid-column: 2;
  min-width: 0;
  width: 100%;
  text-align: center;
}

html[data-theme='dark'] .nav-theme-toggle .icon-moon {
  display: none;
}

html[data-theme='dark'] .nav-theme-toggle .icon-sun {
  display: block;
}

html[data-theme='dark'] .nav-font-picker {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

html[data-theme='dark'] .nav-color-picker {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

html[data-theme='dark'] .nav-font-menu {
  border-color: rgba(148, 163, 184, 0.2);
  background: rgba(15, 23, 42, 0.92);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.48);
}

html[data-theme='dark'] .nav-color-menu {
  border-color: rgba(148, 163, 184, 0.2);
  background: rgba(15, 23, 42, 0.92);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.48);
}

html[data-theme='dark'] .nav-font-option {
  color: var(--ink);
}

html[data-theme='dark'] .nav-color-option {
  color: var(--ink);
}

html[data-theme='dark'] .nav-font-option:hover,
html[data-theme='dark'] .nav-font-option:focus-visible {
  background: rgba(30, 41, 59, 0.92);
  border-color: rgba(148, 163, 184, 0.24);
}

html[data-theme='dark'] .nav-color-option:hover,
html[data-theme='dark'] .nav-color-option:focus-visible {
  background: rgba(30, 41, 59, 0.92);
  border-color: rgba(148, 163, 184, 0.24);
}

html[data-theme='dark'] .nav-font-option.is-active {
  background:
    linear-gradient(rgba(15, 23, 42, 0.94), rgba(15, 23, 42, 0.94)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.34);
}

html[data-theme='dark'] .nav-color-option.is-active {
  background:
    linear-gradient(rgba(15, 23, 42, 0.94), rgba(15, 23, 42, 0.94)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.34);
}

.nav-search-input:focus {
  outline: none;
  box-shadow: var(--ring);
  border-color: var(--brand-2);
}

navbar a {
  color: #0f172a;
  text-decoration: none;
}

navbar a:hover {
  color: #0f172a;
  text-decoration: none;
}

header nav {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  white-space: nowrap;
}

.container {
  min-height: 100svh;
  display: grid;
  gap: 12px;
  padding: 12px;
  --home-sticky-top: 92px;
  grid-template-rows: auto 1fr;
  align-content: start;
  grid-template-areas:
    'header header'
    'content menu';
  grid-template-columns: 1fr 340px;
}

body.is-auth-page .container {
  grid-template-areas:
    'header'
    'content';
  grid-template-columns: 1fr;
}

.container div.header {
  grid-area: header;
}

.container div.menu-wrap {
  grid-area: menu;
}

body.is-auth-page .container div.menu-wrap {
  display: none;
}

.menu-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  align-self: start;
  width: 100%;
}

body.is-logged-out .menu-wrap {
  position: sticky;
  top: 92px;
}

.menu-wrap>.nav-card {
  display: none;
}

.content_left .bulletin-card.bulletin-card-mobile {
  display: none;
}

.menu-wrap .bulletin-card.bulletin-card-desktop {
  display: block;
}

.container div.content {
  grid-area: content;
}

.header {
  position: sticky;
  top: 12px;
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.9rem 1.1rem;
  border: 1px solid #0f172a;
  border-radius: var(--radius-lg);
  backdrop-filter: none;
  background: var(--brand-gradient);
  box-shadow: var(--shadow-md);
  transition:
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    backdrop-filter 180ms ease,
    -webkit-backdrop-filter 180ms ease;
}

.header p {
  margin: 0;
  display: flex;
  align-items: center;
}

.header p a {
  display: inline-block;
  font-weight: 900;
  font-size: 1.7rem;
  letter-spacing: 0.06em;
  text-decoration: none;
  color: #0f172a;
  padding: 0 0.2rem;
  border-radius: var(--radius-sm);
  transition:
    box-shadow 140ms ease,
    transform 140ms ease;
}

.header p .nav-title-link {
  display: inline-flex;
  align-items: center;
  padding: 0;
  line-height: 1;
}

.header p .nav-title-image {
  display: none;
  width: auto;
  height: 34px;
  max-width: min(44vw, 240px);
}

.header p .nav-title-image-newsprint {
  display: none;
}

.header p .nav-title-text {
  display: inline-block;
  color: inherit;
  line-height: 1;
}

.header p .nav-title-image-default {
  display: block;
}

html[data-color-theme='newsprint'] .header p .nav-title-image-default {
  display: none;
}

html[data-color-theme='newsprint'] .header p .nav-title-image-newsprint {
  display: block;
}

.header p .nav-title-text {
  display: none;
}

.header p .nav-title-text.nav-title-text-forced {
  display: inline-block;
}

.header p a:hover {
  text-decoration: none;
  background: var(--brand-hover-fill);
  box-shadow: inset 0 -0.55em 0 var(--brand-hover-shadow);
  transform: translateY(-1px);
}

.header navbar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: nowrap;
  width: 100%;
  justify-content: flex-start;
}

.header navbar .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex: 1;
  flex-wrap: wrap;
  min-width: 0;
}

.header navbar .nav-search {
  margin-left: auto;
}

.header navbar .nav-search-input {
  width: 240px;
}

@media (max-width: 980px) {
  html[data-color-theme='newsprint'] .header p .nav-title-image-default {
    display: block;
  }

  html[data-color-theme='newsprint'] .header p .nav-title-image-newsprint {
    display: none;
  }

  .header {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0.75rem;
    z-index: 50;
    isolation: isolate;
    transition: none;
  }

  .header::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 0;
    border: 1px solid transparent;
    border-radius: inherit;
    pointer-events: none;
    opacity: 0;
    transition: none;
  }

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

  body.mobile-header-scrolled .header {
    border-color: transparent;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  body.mobile-header-scrolled .header::before {
    border-color: rgba(248, 250, 252, 0.16);
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.62), rgba(15, 23, 42, 0.5));
    box-shadow:
      0 14px 34px rgba(0, 0, 0, 0.26),
      inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(22px) saturate(165%);
    -webkit-backdrop-filter: blur(22px) saturate(165%);
    opacity: 1;
  }

  body.mobile-header-scrolled .header p a {
    color: #f8fafc;
  }

  body.mobile-header-scrolled .header p a:hover {
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 -0.55em 0 rgba(255, 255, 255, 0.12);
  }

  body.mobile-header-scrolled .header p .nav-title-image-default {
    display: none;
  }

  body.mobile-header-scrolled .header p .nav-title-image-newsprint {
    display: block;
  }

  .header p {
    grid-column: 2;
    justify-self: center;
    text-align: center;
  }

  .header p .nav-title-image {
    height: 28px;
    max-width: min(52vw, 210px);
  }

  .header navbar {
    display: contents;
  }

  navbar .nav-toggle-label {
    display: inline-flex;
    grid-column: 1;
    grid-row: 1;
    margin-left: 0;
    justify-self: start;
  }

  navbar .nav-panel {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 41;
    width: min(280px, calc(100vw - 56px));
    padding: 1rem;
    border-right: 1px solid rgba(15, 23, 42, 0.12);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 247, 250, 0.98));
    box-shadow: 16px 0 40px rgba(15, 23, 42, 0.2);
    opacity: 1;
    overflow: auto;
    transform: translateX(-104%);
    transition: transform 180ms ease;
  }

  navbar .nav-mobile-search {
    display: inline-flex;
    grid-column: 3;
    grid-row: 1;
    width: 40px;
    min-width: 40px;
    max-width: 40px;
    height: 40px;
    min-height: 40px;
    max-height: 40px;
    aspect-ratio: 1 / 1;
    flex: 0 0 40px;
    align-items: center;
    justify-content: center;
    justify-self: end;
    position: relative;
    z-index: 2;
    padding: 0;
    border-radius: 50%;
    border: 1px solid rgba(226, 232, 240, 0.18);
    background:
      linear-gradient(rgba(15, 23, 42, 0.78), rgba(15, 23, 42, 0.68)) padding-box,
      var(--brand-gradient-soft-border) border-box;
    color: #f8fafc !important;
    box-shadow:
      0 14px 28px rgba(2, 6, 23, 0.38),
      inset 0 1px 0 rgba(255, 255, 255, 0.05);
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    transition: none;
  }

  navbar .nav-mobile-search .nav-search-icon {
    color: #f8fafc;
  }

  .container>.nav-mobile-search-panel {
    display: block;
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transform: translateY(-8px);
    margin: -4px 12px 0 12px;
    padding: 0 0.85rem;
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.14);
    transition:
      max-height 180ms ease,
      opacity 180ms ease,
      transform 180ms ease;
  }

  .container>.nav-search-toggle:checked~.nav-mobile-search-panel {
    max-height: 96px;
    opacity: 1;
    transform: translateY(0);
  }

  .nav-mobile-search-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.55rem;
    padding: 0.75rem 0 0.85rem;
  }

  .nav-mobile-search-form .nav-mobile-search-input {
    width: 100%;
    max-width: none;
    height: 40px;
  }

  .nav-mobile-search-submit {
    height: 40px;
    padding: 0 0.95rem;
    border-radius: 999px;
  }

  navbar .nav-mobile-search:hover,
  navbar .nav-mobile-search:focus-visible,
  .nav-mobile-search-submit:hover,
  .nav-mobile-search-submit:focus-visible {
    background: var(--btn-dark);
    border-color: #0f172a;
    transform: none;
    text-decoration: none;
  }

  body.mobile-header-scrolled navbar .nav-mobile-search,
  body.mobile-header-scrolled navbar .nav-mobile-search:hover,
  body.mobile-header-scrolled navbar .nav-mobile-search:focus-visible {
    border: 1px solid rgba(226, 232, 240, 0.18);
    background:
      linear-gradient(rgba(15, 23, 42, 0.78), rgba(15, 23, 42, 0.68)) padding-box,
      var(--brand-gradient-soft-border) border-box;
    color: #f8fafc !important;
    box-shadow:
      0 14px 28px rgba(2, 6, 23, 0.38),
      inset 0 1px 0 rgba(255, 255, 255, 0.05);
    transition: none;
  }

  body.mobile-header-scrolled navbar .nav-mobile-search .nav-search-icon {
    color: #f8fafc;
  }

  navbar .nav-panel-backdrop {
    position: fixed;
    inset: 0;
    z-index: 40;
    background: rgba(15, 23, 42, 0.34);
    opacity: 0;
    pointer-events: none;
    transition: opacity 180ms ease;
  }

  navbar .nav-toggle:checked+.nav-toggle-label+.nav-panel {
    transform: translateX(0);
  }

  navbar .nav-toggle:checked+.nav-toggle-label+.nav-panel+.nav-panel-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  .header navbar .nav-links {
    display: none;
  }

  .header navbar .nav-search {
    margin-left: 0;
  }

  .header navbar .nav-search,
  .header navbar .nav-search-input {
    width: 100%;
    max-width: none;
  }

  .header navbar .nav-actions {
    display: none;
  }

  .header navbar .nav-actions .nav-search {
    order: 1;
    width: 100%;
  }

  .header navbar .nav-actions .nav-theme-toggle {
    order: 2;
    align-self: center;
  }

  html[data-theme='dark'] navbar .nav-panel {
    border-color: rgba(226, 232, 240, 0.12);
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(17, 24, 39, 0.98));
    box-shadow: 18px 0 42px rgba(2, 6, 23, 0.58);
  }

  html[data-theme='dark'] navbar .nav-panel-backdrop {
    background: rgba(2, 6, 23, 0.52);
  }

  html[data-theme='dark'] body.mobile-header-scrolled .header {
    border-color: transparent;
    background: transparent;
    box-shadow: none;
  }

  html[data-theme='dark'] body.mobile-header-scrolled .header::before {
    border-color: rgba(226, 232, 240, 0.12);
    background: linear-gradient(180deg, rgba(2, 6, 23, 0.72), rgba(2, 6, 23, 0.58));
    box-shadow:
      0 18px 40px rgba(0, 0, 0, 0.54),
      inset 0 1px 0 rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(22px) saturate(165%);
    -webkit-backdrop-filter: blur(22px) saturate(165%);
  }

  html[data-theme='dark'] body.mobile-header-scrolled navbar .nav-mobile-search,
  html[data-theme='dark'] body.mobile-header-scrolled navbar .nav-mobile-search:hover,
  html[data-theme='dark'] body.mobile-header-scrolled navbar .nav-mobile-search:focus-visible {
    border-color: rgba(226, 232, 240, 0.18);
    background:
      linear-gradient(rgba(15, 23, 42, 0.78), rgba(15, 23, 42, 0.68)) padding-box,
      var(--brand-gradient-soft-border) border-box;
    color: #f8fafc !important;
    box-shadow:
      0 14px 28px rgba(2, 6, 23, 0.38),
      inset 0 1px 0 rgba(255, 255, 255, 0.05);
    transition: none;
  }
}

navbar .nav-auth-card {
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  padding: 1.15rem;
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  text-align: center;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.16);
}

html[data-theme='dark'] navbar .nav-auth-card {
  background:
    linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.nav-side-menu {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 100%;
  min-height: 100%;
}

.nav-side-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.nav-side-head-user {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  flex: 1 1 auto;
  min-width: 0;
  padding: 0.25rem 0.35rem;
  margin: -0.25rem -0.35rem;
  border-radius: 14px;
  color: inherit;
  text-decoration: none;
  transition:
    background 140ms ease,
    box-shadow 140ms ease;
}

.nav-side-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #0f172a;
}

.nav-side-head-user .nav-side-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-transform: none;
  letter-spacing: 0.02em;
}

.nav-side-head-user:hover {
  background: rgba(255, 255, 255, 0.55);
  text-decoration: none;
}

.nav-side-head-user:focus-visible {
  outline: none;
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.22);
}

.nav-side-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  background: rgba(255, 255, 255, 0.72);
  color: #0f172a;
  cursor: pointer;
  font-size: 1.25rem;
  line-height: 1;
  box-shadow: var(--shadow-sm);
}

.nav-side-user {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 0.95rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.nav-side-username {
  min-width: 0;
  font-weight: 800;
  color: #0f172a;
}

.nav-side-links {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.nav-side-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-height: 48px;
  padding: 0.85rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  background: rgba(255, 255, 255, 0.82);
  color: #0f172a;
  font-weight: 800;
  letter-spacing: 0.02em;
  box-shadow: var(--shadow-sm);
  transition:
    background 140ms ease,
    border-color 140ms ease,
    transform 140ms ease,
    box-shadow 140ms ease;
}

.nav-side-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.45rem;
  height: 1.45rem;
  padding: 0 0.35rem;
  border-radius: 999px;
  background: #0f172a;
  color: #f8fafc;
  font-size: 0.68rem;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 6px 12px rgba(15, 23, 42, 0.16);
}

.nav-side-indicator.is-alert {
  border: 2px solid #000;
  background: #dc2626;
  color: #fff;
  box-shadow:
    0 10px 18px rgba(220, 38, 38, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.12);
}

.nav-side-indicator.is-activity {
  border: 2px solid #000;
  background: #2563eb;
  color: #fff;
  box-shadow:
    0 10px 18px rgba(37, 99, 235, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.12);
}

.nav-side-link:hover {
  background: color-mix(in srgb, var(--brand-1) 12%, rgba(255, 255, 255, 0.94));
  border-color: color-mix(in srgb, var(--brand-2) 26%, rgba(15, 23, 42, 0.12));
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
  text-decoration: none;
}

.nav-side-link.is-active {
  border-color: transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.94)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.14);
}

.nav-side-actions {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-top: auto;
  margin-bottom: 0.85rem;
}

.nav-side-actions .nav-side-theme-toggle {
  width: 100%;
  justify-content: center;
  position: relative;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}

.nav-side-actions .nav-font-control,
.menu-wrap>.nav-card .nav-font-control {
  align-self: stretch;
  width: 100%;
}

.nav-side-actions .nav-color-control,
.menu-wrap>.nav-card .nav-color-control {
  align-self: stretch;
  width: 100%;
}

.nav-side-actions .nav-font-picker,
.menu-wrap>.nav-card .nav-font-picker {
  width: 100%;
  height: 40px;
  justify-content: center;
  position: relative;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  border-radius: 12px;
  border: 1px solid #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5;
  box-shadow: var(--shadow-sm);
}

.nav-side-actions .nav-color-picker,
.menu-wrap>.nav-card .nav-color-picker {
  width: 100%;
  height: 40px;
  justify-content: center;
  position: relative;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  border-radius: 12px;
  border: 1px solid #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5;
  box-shadow: var(--shadow-sm);
}

.nav-side-actions .nav-font-picker-label,
.menu-wrap>.nav-card .nav-font-picker-label {
  display: inline-flex;
  width: 100%;
  justify-content: center;
  text-align: center;
}

.nav-side-actions .nav-font-picker-icon,
.menu-wrap>.nav-card .nav-font-picker-icon {
  position: absolute;
  left: 0.9rem;
  top: 50%;
  transform: translateY(-50%);
  flex: 0 0 auto;
}

.nav-side-actions .nav-font-menu,
.menu-wrap>.nav-card .nav-font-menu {
  top: auto;
  bottom: calc(100% + 10px);
  left: 50%;
  right: auto;
  transform: translateX(-50%);
}

.nav-side-actions .nav-color-menu,
.menu-wrap>.nav-card .nav-color-menu {
  top: auto;
  bottom: calc(100% + 10px);
  left: 50%;
  right: auto;
  transform: translateX(-50%);
}

html[data-theme='dark'] .nav-side-actions .nav-font-picker,
html[data-theme='dark'] .menu-wrap>.nav-card .nav-font-picker {
  border-color: #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5;
}

html[data-theme='dark'] .nav-side-actions .nav-color-picker,
html[data-theme='dark'] .menu-wrap>.nav-card .nav-color-picker {
  border-color: #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5;
}

.nav-side-actions .nav-color-picker-label,
.menu-wrap>.nav-card .nav-color-picker-label {
  display: inline-flex;
  width: 100%;
  justify-content: center;
  text-align: center;
}

.nav-side-actions .nav-color-picker-chip,
.menu-wrap>.nav-card .nav-color-picker-chip {
  position: absolute;
  left: 0.9rem;
  top: 50%;
  transform: translateY(-50%);
  flex: 0 0 auto;
  border-color: rgba(255, 255, 255, 0.72);
}

.nav-side-actions .nav-side-theme-toggle .theme-icon {
  position: absolute;
  left: 0.9rem;
  top: 50%;
  transform: translateY(-50%);
}

.nav-side-actions .nav-side-theme-toggle .nav-theme-toggle-label {
  width: 100%;
  text-align: center;
}

.nav-side-actions .btn-primary,
.nav-side-actions .btn-primary:hover,
.nav-side-actions .btn-primary:visited {
  color: #f5f5f5;
}

html[data-theme='dark'] .nav-side-actions .btn-primary,
html[data-theme='dark'] .nav-side-actions .btn-primary:hover,
html[data-theme='dark'] .nav-side-actions .btn-primary:visited {
  color: #f5f5f5;
}

html[data-theme='dark'] .nav-side-title,
html[data-theme='dark'] .nav-side-close,
html[data-theme='dark'] .nav-side-username,
html[data-theme='dark'] .nav-side-link {
  color: #f8fafc;
}

html[data-theme='dark'] .nav-side-head-user:hover {
  background: rgba(15, 23, 42, 0.52);
}

html[data-theme='dark'] .nav-side-head-user:focus-visible {
  background: rgba(15, 23, 42, 0.68);
  box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.28);
}

html[data-theme='dark'] .nav-side-close,
html[data-theme='dark'] .nav-side-user,
html[data-theme='dark'] .nav-side-link {
  background: rgba(15, 23, 42, 0.68);
  border-color: rgba(226, 232, 240, 0.12);
}

html[data-theme='dark'] .nav-side-link:hover {
  background: color-mix(in srgb, var(--brand-1) 14%, rgba(15, 23, 42, 0.84));
  border-color: color-mix(in srgb, var(--brand-2) 28%, rgba(226, 232, 240, 0.14));
}

html[data-theme='dark'] .nav-side-link.is-active {
  border-color: transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.9), rgba(15, 23, 42, 0.9)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 12px 26px rgba(2, 6, 23, 0.36);
}

html[data-theme='dark'] .nav-side-indicator {
  background: #f8fafc;
  color: #0f172a;
  box-shadow: 0 6px 12px rgba(2, 6, 23, 0.32);
}

html[data-theme='dark'] .nav-side-indicator.is-alert {
  border: 2px solid #000;
  background: #dc2626;
  color: #fff;
  box-shadow:
    0 10px 18px rgba(220, 38, 38, 0.28),
    0 0 0 1px rgba(15, 23, 42, 0.18);
}

html[data-theme='dark'] .nav-side-indicator.is-activity {
  border: 2px solid #000;
  background: #2563eb;
  color: #fff;
  box-shadow:
    0 10px 18px rgba(37, 99, 235, 0.28),
    0 0 0 1px rgba(15, 23, 42, 0.18);
}

navbar .nav-auth-card.is-auth {
  padding: 0.9rem;
  min-height: 260px;
  min-width: 306px;
}

navbar .nav-auth-card .title_login {
  margin: 0 0 1.75rem 0;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

navbar .nav-auth-card.is-auth .title_login {
  justify-content: center;
  text-align: center;
  padding-bottom: 0.4rem;
  margin-bottom: 0.45rem;
  border-bottom: 1px dashed rgba(15, 23, 42, 0.12);
}

html[data-theme='dark'] navbar .nav-auth-card.is-auth .title_login {
  border-bottom-color: var(--border);
}

navbar .nav-auth-card .title_login a,
navbar .nav-auth-card .title_login .title_text {
  display: inline-block;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 0.9rem;
  letter-spacing: 0.12em;
  color: rgba(15, 23, 42, 0.78);
}

html[data-theme='dark'] navbar .nav-auth-card .title_login a,
html[data-theme='dark'] navbar .nav-auth-card .title_login .title_text {
  color: var(--ink);
}

navbar .nav-auth-card .title_login .user-summary {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}

navbar .nav-auth-card .title_login .user-name {
  font-size: 1rem;
  font-weight: 900;
  color: rgba(15, 23, 42, 0.9);
}

html[data-theme='dark'] navbar .nav-auth-card .title_login .user-name {
  color: var(--ink);
}

navbar .nav-auth-card .title_login .avatar,
navbar .nav-auth-card .title_login .avatar-initial {
  width: 50px;
  height: 50px;
  border-radius: 999px;
  border: 0;
  background: #ffffff;
  box-shadow: none;
}

html[data-theme='dark'] navbar .nav-auth-card .title_login .avatar,
html[data-theme='dark'] navbar .nav-auth-card .title_login .avatar-initial {
  background: rgba(15, 23, 42, 0.6);
}

navbar .nav-auth-card .title_login .avatar-initial {
  background: rgba(255, 255, 255, 0.65);
  color: rgba(15, 23, 42, 0.9);
  font-size: 1.3rem;
}

navbar .nav-auth-card .title_login .login-avatar {
  width: 62px;
  height: 62px;
  padding: 3px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-gradient);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
}

navbar .nav-auth-card .signup-form {
  gap: 1rem;
  width: 100%;
  max-width: 280px;
  margin: 0 auto;
}

navbar .nav-auth-card .form-group {
  width: 100%;
  text-align: left;
}

navbar .nav-auth-card .form-group label {
  color: rgba(15, 23, 42, 0.68);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
}

html[data-theme='dark'] navbar .nav-auth-card .form-group label {
  color: var(--subtle);
}

navbar .nav-auth-card input[type='text'],
navbar .nav-auth-card input[type='password'],
navbar .nav-auth-card input[type='email'] {
  width: 100%;
  max-width: none;
  padding: 0.55rem 0.7rem;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.18);
  background: #ffffff;
  color: #111827 !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
  -webkit-text-fill-color: #111827;
}

html[data-theme='dark'] navbar .nav-auth-card input[type='text'],
html[data-theme='dark'] navbar .nav-auth-card input[type='password'],
html[data-theme='dark'] navbar .nav-auth-card input[type='email'] {
  background: rgba(15, 23, 42, 0.72);
  border-color: var(--border);
  color: var(--ink) !important;
  box-shadow: var(--shadow-sm);
  -webkit-text-fill-color: var(--ink);
}

navbar .nav-auth-card input:focus {
  border-color: var(--brand-2);
  box-shadow: var(--ring);
}

navbar .nav-auth-card .btn-primary {
  width: 100%;
  margin: 0.6rem 0 0;
  height: 38px;
  border-radius: 12px;
  border: 1px solid #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5 !important;
  font-weight: 900;
  letter-spacing: 0.04em;
  box-shadow: var(--shadow-sm);
}

navbar .nav-auth-card.is-auth .btn-primary {
  margin-top: 0.25rem;
  height: 34px;
  border-radius: 11px;
  letter-spacing: 0.08em;
  background: linear-gradient(180deg, #0f172a 0%, #1f2937 100%);
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.18);
}

navbar .nav-auth-card a.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 38px;
  line-height: normal;
  text-decoration: none;
}

navbar .nav-auth-card .btn-secondary {
  background: #ffffff;
  color: #111827 !important;
  border-color: rgba(15, 23, 42, 0.18);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

html[data-theme='dark'] navbar .nav-auth-card .btn-secondary {
  background: rgba(226, 232, 240, 0.08);
  border-color: rgba(226, 232, 240, 0.18);
  color: var(--ink) !important;
  box-shadow: var(--shadow-sm);
}

navbar .nav-auth-card.is-auth .btn-secondary {
  background: #f8fafc;
  border-color: rgba(15, 23, 42, 0.12);
  color: rgba(15, 23, 42, 0.9) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.7),
    0 6px 12px rgba(15, 23, 42, 0.08);
}

html[data-theme='dark'] navbar .nav-auth-card.is-auth .btn-secondary {
  background: rgba(226, 232, 240, 0.08);
  border-color: rgba(226, 232, 240, 0.18);
  color: var(--ink) !important;
  box-shadow: var(--shadow-sm);
}

navbar .nav-auth-card .btn-primary:hover {
  background: linear-gradient(180deg,
      rgba(51, 65, 85, 1) 0%,
      rgba(15, 23, 42, 1) 100%);
  transform: none;
}

navbar .nav-auth-card .form-footer {
  margin-top: 0.85rem;
  text-align: center;
  color: rgba(15, 23, 42, 0.62);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

html[data-theme='dark'] navbar .nav-auth-card .form-footer {
  color: var(--subtle);
}

navbar .nav-auth-card .form-footer a {
  color: #2563eb;
  font-weight: 900;
  text-decoration: none;
  display: inline-block;
  margin-top: 0.15rem;
}

html[data-theme='dark'] navbar .nav-auth-card .form-footer a {
  color: var(--brand-2);
}

html[data-theme='dark'] navbar .nav-toggle-label {
  border-color: rgba(226, 232, 240, 0.18);
  background:
    linear-gradient(rgba(15, 23, 42, 0.78), rgba(15, 23, 42, 0.68)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  box-shadow:
    0 14px 28px rgba(2, 6, 23, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

html[data-theme='dark'] navbar .nav-toggle-label:hover {
  box-shadow:
    0 16px 32px rgba(2, 6, 23, 0.46),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

html[data-theme='dark'] navbar .nav-toggle-label .nav-toggle-bar {
  background: rgba(226, 232, 240, 0.9);
}

html[data-theme='dark'] navbar .nav-toggle-label .nav-toggle-count {
  border-color: #000;
  background: #dc2626;
  color: #fff;
  box-shadow:
    0 12px 20px rgba(2, 6, 23, 0.42),
    0 0 0 1px rgba(255, 255, 255, 0.06);
}

html[data-theme='dark'] navbar .nav-toggle-label .nav-toggle-count-activity {
  background: #2563eb;
  color: #fff;
  box-shadow:
    0 12px 20px rgba(37, 99, 235, 0.28),
    0 0 0 1px rgba(15, 23, 42, 0.38);
}

.btn-nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 34px;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5 !important;
  font-weight: 700;
  font-size: 0.8rem;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
  transition:
    transform 120ms ease,
    background 120ms ease,
    border-color 120ms ease;
}

html[data-theme='dark'] .page-head .btn-nav,
html[data-theme='dark'] .btn-nav.modal-trigger {
  border-color: transparent;
  background: var(--brand-gradient);
  color: #0f172a !important;
  box-shadow: var(--shadow-sm);
}

.btn-nav:hover {
  background: #4b5563;
  border-color: #0f172a;
  transform: translateY(-1px);
  text-decoration: none;
}

.btn-nav.btn-danger {
  border: 1px solid color-mix(in srgb, var(--danger) 35%, transparent);
  background: color-mix(in srgb, var(--danger) 10%, transparent);
  color: var(--danger) !important;
}

.btn-nav.btn-danger:hover {
  background: var(--danger);
  border-color: var(--danger);
  color: #fff !important;
}

.btn-nav.pill-action {
  height: 28px;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a !important;
  -webkit-text-fill-color: currentColor;
  font-weight: 800;
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: var(--shadow-sm);
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    background 140ms ease;
}

html[data-theme='dark'] .btn-nav.pill-action {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink) !important;
}

.btn-nav.pill-action:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn-nav.pill-action:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.btn-nav.pill-action:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

.playlist-user-pill.btn-nav.pill-action {
  height: 22px;
  padding: 0 0.6rem;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  vertical-align: middle;
}

.playlist-song-link.btn-nav.pill-action {
  height: 22px;
  padding: 0 0.6rem;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  vertical-align: middle;
  text-transform: none;
  max-width: min(520px, 80vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.content_main .profile-playlist-meta {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  width: 100%;
  min-width: 0;
}

.content_main .profile-playlist-meta-separator {
  color: var(--border-strong);
}

.content_main .profile-playlist-meta-text {
  min-width: 0;
  flex: 1 1 auto;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.content_main .profile-playlist-meta .playlist-favorite-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.32rem;
  min-height: 22px;
  padding: 0.12rem 0.5rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.58), rgba(15, 23, 42, 0.58)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-sm);
  white-space: nowrap;
  vertical-align: middle;
  color: #fbcfe8;
  margin-left: auto;
  flex: 0 0 auto;
}

.content_main .profile-playlist-meta .playlist-favorite-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 12px;
  height: 12px;
  line-height: 0;
  color: #f472b6;
}

.content_main .profile-playlist-meta .playlist-favorite-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.content_main .profile-playlist-meta .playlist-favorite-count {
  font-size: 0.74rem;
  font-weight: 900;
  color: rgba(248, 250, 252, 0.96);
}

html[data-theme='dark'] .content_main .profile-playlist-meta .playlist-favorite-badge {
  background:
    linear-gradient(rgba(0, 0, 0, 0.62), rgba(0, 0, 0, 0.62)) padding-box,
    var(--brand-gradient-soft-border) border-box;
}

.content_main .playlist-section .profile-playlist-row {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
}

.content_main .playlist-section .profile-playlist-copy {
  flex: 1 1 auto;
  min-width: 0;
}

.content_main .playlist-section .rating-list li {
  position: relative;
  padding-right: 4.5rem;
}

.content_main .playlist-section .profile-playlist-desc {
  display: block;
  color: var(--subtle);
  margin-top: 0.1rem;
}

.content_main .playlist-section .profile-playlist-favorite-pill {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.32rem;
  min-height: 22px;
  padding: 0.12rem 0.5rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-sm);
  white-space: nowrap;
  vertical-align: middle;
  color: #fbcfe8;
  flex: 0 0 auto;
  margin-left: 0;
}

.content_main .playlist-section .profile-playlist-favorite-pill .playlist-favorite-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 12px;
  height: 12px;
  line-height: 0;
  color: #f472b6;
}

.content_main .playlist-section .profile-playlist-favorite-pill .playlist-favorite-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.content_main .playlist-section .profile-playlist-favorite-pill .playlist-favorite-count {
  font-size: 0.74rem;
  font-weight: 900;
  color: rgba(248, 250, 252, 0.96);
}

html[data-theme='dark'] .content_main .playlist-section .profile-playlist-favorite-pill {
  background: rgba(0, 0, 0, 0.62);
  border-color: rgba(255, 255, 255, 0.2);
}

.rating-extra-link.btn-nav.pill-action {
  height: 22px;
  padding: 0 0.6rem;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  vertical-align: middle;
  text-transform: none;
  max-width: min(520px, 80vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.pagination-bar {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.7);
  box-shadow: var(--shadow-sm);
}

html[data-theme='dark'] .pagination-bar {
  background: rgba(15, 23, 42, 0.55);
}

.pagination-meta {
  font-weight: 800;
  font-size: 0.85rem;
  color: var(--ink);
  white-space: nowrap;
}

.pagination-form {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0;
}

.pagination-label {
  font-size: 0.8rem;
  color: var(--muted);
  white-space: nowrap;
}

.pagination-select {
  height: 32px;
  padding: 0 0.55rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  font-weight: 700;
}

html[data-theme='dark'] .pagination-select {
  background: rgba(15, 23, 42, 0.72);
  border-color: rgba(226, 232, 240, 0.2);
  color: var(--ink);
  color-scheme: dark;
}

html[data-theme='dark'] .pagination-select option {
  background: var(--surface);
  color: var(--ink);
}

.pagination-btn.is-disabled {
  opacity: 0.5;
  pointer-events: none;
}

html[data-theme='dark'] .page-head .btn-nav:hover,
html[data-theme='dark'] .btn-nav.modal-trigger:hover {
  background: var(--brand-gradient);
  border-color: transparent;
}

.menu {
  padding: 1rem;
  border: 1px solid #0f172a;
  border-radius: var(--radius-lg);
  background: var(--brand-gradient);
  box-shadow: var(--shadow-md);
  position: sticky;
  top: 92px;
  align-self: start;
  max-height: none;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
}

.menu.is-auth {
  position: static;
  top: auto;
}

.menu .signup-container,
.menu .activity-card,
.menu .bulletin-card,
.menu-wrap>.bulletin-card {
  width: 100%;
  max-width: 520px;
  margin: 0;
  padding: 1.15rem;
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  text-align: center;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.16);
}

html[data-theme='dark'] .menu .signup-container,
html[data-theme='dark'] .menu .activity-card,
html[data-theme='dark'] .menu .bulletin-card,
html[data-theme='dark'] .menu-wrap>.bulletin-card,
html[data-theme='dark'] .content_left .signup-container,
html[data-theme='dark'] .content_left .activity-card,
html[data-theme='dark'] .content_left .bulletin-card {
  background:
    linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.modal-toggle {
  position: fixed;
  top: 0;
  left: 0;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  visibility: hidden;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 180ms ease,
    visibility 0s linear 180ms;
  z-index: 2001;
}

.modal {
  pointer-events: none;
}

.modal-card {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.98);
  width: min(420px, 92vw);
  max-height: min(720px, 92vh);
  overflow: auto;
  background: #ffffff;
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-md);
  padding: 1.1rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 180ms ease,
    transform 180ms ease,
    visibility 0s linear 180ms;
  z-index: 2002;
}

.modal-card textarea {
  overscroll-behavior: contain;
}

.modal-toggle:checked~.modal .modal-backdrop {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s;
}

.modal-toggle:checked~.modal {
  pointer-events: auto;
  visibility: visible;
}

.modal-toggle:checked~.modal .modal-card {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(-50%, -50%) scale(1);
  transition-delay: 0s;
}

.modal-comment-edit {
  z-index: 2005;
}

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

.modal-title {
  margin: 0;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.85rem;
  color: rgba(15, 23, 42, 0.7);
}

.modal-close {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  position: relative;
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.2);
  cursor: pointer;
  font-size: 0;
  line-height: 0;
  background: rgba(15, 23, 42, 0.05);
}

.modal-close::before {
  content: '×';
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 1.25rem;
  line-height: 1;
  font-weight: 500;
  transform: translate(-0.01em, -0.06em);
}

html[data-theme='dark'] .modal-close {
  border-color: var(--border);
  background: transparent;
  color: var(--ink);
}

.modal-copy {
  margin: 0 0 0.9rem 0;
  color: rgba(15, 23, 42, 0.8);
}

.mb-search-result-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.6rem;
}

.mb-search-result-title {
  min-width: 0;
  font-weight: 900;
  color: var(--ink);
}

.mb-search-result-source {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  padding: 0.16rem 0.48rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.1;
  text-transform: uppercase;
  white-space: nowrap;
}

.mb-search-result-source.is-local {
  color: #9a3412;
  border-color: rgba(217, 119, 6, 0.24);
  background: linear-gradient(180deg, rgba(254, 243, 199, 0.92), rgba(255, 247, 237, 0.94));
}

html[data-theme='dark'] .modal-card {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

html[data-theme='dark'] .modal-card #bulletin-type {
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  border-color: rgba(226, 232, 240, 0.24);
  color: var(--ink);
  color-scheme: dark;
}

html[data-theme='dark'] .modal-card #bulletin-type option {
  background: var(--surface);
  color: var(--ink);
}

html[data-theme='dark'] .modal-title {
  color: var(--subtle);
}

html[data-theme='dark'] .modal-copy {
  color: var(--muted);
}

html[data-theme='dark'] .mb-search-result-source.is-local {
  color: #fcd34d;
  border-color: rgba(245, 158, 11, 0.32);
  background: linear-gradient(180deg, rgba(146, 64, 14, 0.32), rgba(120, 53, 15, 0.44));
}

html[data-theme='dark'] .modal-close {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(226, 232, 240, 0.08);
  color: var(--ink);
}

.modal-card .form-group {
  margin: 0.6rem 0 0.8rem 0;
}

.modal-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.6rem;
}

.modal-secondary {
  background: rgba(239, 68, 68, 0.16);
  border-color: rgba(239, 68, 68, 0.55);
  color: #b91c1c !important;
}

.modal-secondary:hover {
  background: rgba(239, 68, 68, 0.3);
  border-color: rgba(239, 68, 68, 0.75);
  color: #991b1b !important;
}

html[data-theme='dark'] .modal-secondary,
html[data-theme='dark'] .modal-secondary:hover {
  background: rgba(239, 68, 68, 0.2);
  border-color: rgba(239, 68, 68, 0.65);
  color: rgba(254, 226, 226, 0.95) !important;
}

.menu .bulletin-card .modal-trigger,
.menu-wrap>.bulletin-card .modal-trigger {
  display: block;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin: 0 auto 0.4rem;
  align-self: center;
  height: 28px;
  padding: 5px 0.6rem 0;
  font-size: 0.72rem;
}

.menu .signup-container.is-auth {
  padding: 0.9rem;
  min-height: 260px;
  min-width: 306px;
}

.menu .activity-card,
.menu .bulletin-card,
.menu .title_login {
  margin: 0 0 1.75rem 0;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.menu .signup-container.is-auth .title_login {
  justify-content: center;
  text-align: center;
  padding-bottom: 0.4rem;
  margin-bottom: 0.45rem;
  border-bottom: 1px dashed rgba(15, 23, 42, 0.12);
}

.menu .title_login a,
.menu .title_login .title_text {
  display: inline-block;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 0.9rem;
  letter-spacing: 0.12em;
  color: rgba(15, 23, 42, 0.78);
}

.menu .title_login a {
  text-decoration: none;
}

.auth-panel-close,
.auth-panel-backdrop {
  display: none;
}

.menu .title_login .auth-title {
  display: none;
}

.menu .title_login .auth-title.is-active {
  display: inline-block;
}

.menu .title_login .user-summary {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}

.menu .title_login .user-name {
  font-size: 1rem;
  font-weight: 900;
  color: rgba(15, 23, 42, 0.9);
}

.menu .title_login .avatar,
.menu .title_login .avatar-initial {
  width: 50px;
  height: 50px;
  border-radius: 999px;
  border: 0;
  background: #ffffff;
  box-shadow: none;
}

html[data-theme='dark'] .menu .title_login .avatar,
html[data-theme='dark'] .menu .title_login .avatar-initial {
  background: rgba(15, 23, 42, 0.6);
}

.menu .title_login .avatar-initial {
  background: rgba(255, 255, 255, 0.65);
  color: rgba(15, 23, 42, 0.9);
  font-size: 1.3rem;
}

.menu .title_login .login-avatar {
  width: 62px;
  height: 62px;
  padding: 3px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-gradient);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
}

.menu .signup-container .signup-form {
  gap: 1rem;
  width: 100%;
  max-width: 280px;
  margin: 0 auto;
}

.menu .signup-container .auth-form {
  display: none;
}

.menu .signup-container .auth-form.is-active {
  display: flex;
}

.menu .signup-container .form-group {
  width: 100%;
  text-align: left;
}

.menu .signup-container .form-group label {
  color: rgba(15, 23, 42, 0.68);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
}

html[data-theme='dark'] .menu .signup-container .form-group label {
  color: var(--subtle);
}

.menu .signup-container input[type='text'],
.menu .signup-container input[type='password'],
.menu .signup-container input[type='email'] {
  width: 100%;
  max-width: none;
  padding: 0.55rem 0.7rem;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.18);
  background: #ffffff;
  color: #111827 !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
  -webkit-text-fill-color: #111827;
}

html[data-theme='dark'] .menu .signup-container input[type='text'],
html[data-theme='dark'] .menu .signup-container input[type='password'],
html[data-theme='dark'] .menu .signup-container input[type='email'] {
  background: rgba(15, 23, 42, 0.72);
  border-color: var(--border);
  color: var(--ink) !important;
  box-shadow: var(--shadow-sm);
  -webkit-text-fill-color: var(--ink);
}

html[data-theme='dark'] .menu .title_login a,
html[data-theme='dark'] .menu .title_login .title_text {
  color: var(--ink);
}

html[data-theme='dark'] .menu .signup-container.is-auth .title_login {
  border-bottom-color: var(--border);
}

html[data-theme='dark'] .menu .title_login .user-name {
  color: var(--ink);
}

.menu .signup-container input:focus {
  border-color: var(--brand-2);
  box-shadow: var(--ring);
}

.menu .signup-container .btn-primary {
  width: 100%;
  margin: 0.6rem 0 0;
  height: 38px;
  border-radius: 12px;
  border: 1px solid #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5 !important;
  font-weight: 900;
  letter-spacing: 0.04em;
  box-shadow: var(--shadow-sm);
}

.menu .signup-container.is-auth .btn-primary {
  margin-top: 0.25rem;
  height: 34px;
  border-radius: 11px;
  letter-spacing: 0.08em;
  background: linear-gradient(180deg, #0f172a 0%, #1f2937 100%);
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.18);
}

.menu .signup-container a.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 38px;
  line-height: normal;
  text-decoration: none;
}

.menu .signup-container .btn-secondary {
  background: #ffffff;
  color: #111827 !important;
  border-color: rgba(15, 23, 42, 0.18);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

html[data-theme='dark'] .menu .signup-container .btn-secondary {
  background: rgba(226, 232, 240, 0.08);
  border-color: rgba(226, 232, 240, 0.18);
  color: var(--ink) !important;
  box-shadow: var(--shadow-sm);
}

.menu .signup-container.is-auth .btn-secondary {
  background: #f8fafc;
  border-color: rgba(15, 23, 42, 0.12);
  color: rgba(15, 23, 42, 0.9) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.7),
    0 6px 12px rgba(15, 23, 42, 0.08);
}

html[data-theme='dark'] .menu .signup-container.is-auth .btn-secondary {
  background: rgba(226, 232, 240, 0.08);
  border-color: rgba(226, 232, 240, 0.18);
  color: var(--ink) !important;
  box-shadow: var(--shadow-sm);
}

.menu .signup-container .btn-secondary:hover {
  background: #f8fafc;
}

html[data-theme='dark'] .menu .signup-container .btn-secondary:hover {
  background: rgba(226, 232, 240, 0.14);
}

.menu .signup-container .btn-primary.btn-secondary:hover {
  background: #f5f5f5;
}

html[data-theme='dark'] .menu .signup-container .btn-primary.btn-secondary:hover {
  background: rgba(226, 232, 240, 0.14);
}

.menu .signup-container .btn-primary:hover {
  background: linear-gradient(180deg,
      rgba(51, 65, 85, 1) 0%,
      rgba(15, 23, 42, 1) 100%);
  transform: none;
}

.menu .signup-container .form-footer {
  margin-top: 0.85rem;
  text-align: center;
  color: rgba(15, 23, 42, 0.62);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

html[data-theme='dark'] .menu .signup-container .form-footer {
  color: var(--subtle);
}

.menu .signup-container .form-footer a {
  color: #2563eb;
  font-weight: 900;
  text-decoration: none;
  display: inline-block;
  margin-top: 0.15rem;
}

html[data-theme='dark'] .menu .signup-container .form-footer a {
  color: var(--brand-2);
}

.title_search,
.title_new {
  margin: 0.75rem 0 0.5rem 0;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--subtle);
  font-weight: 800;
}

.content {
  display: grid;
  grid-template-areas:
    'content_left content_main'
    'content_bottom content_bottom';
  grid-template-columns: 340px 1fr;
  min-width: 0;
  gap: 12px;
}

body.is-logged-out .content {
  grid-template-areas:
    'content_main'
    'content_bottom';
  grid-template-columns: 1fr;
}

.content-bottom {
  grid-area: content_bottom;
  min-width: 0;
}

.content-bottom .pagination-bar {
  margin-top: 0;
}

.content_left {
  grid-area: content_left;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  gap: 5px;
}

body.is-logged-out .content_left {
  display: none;
}

body.is-logged-out .menu {
  position: static;
  top: auto;
  width: 100%;
  max-width: none;
}

body.is-logged-out .menu .signup-container {
  max-width: none;
}

.content_left .signup-container,
.content_left .activity-card,
.content_left .bulletin-card {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 1.15rem;
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  text-align: center;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.16);
}

.content_left .signup-container .title_search,
.content_left .signup-container .title_new,
.content_left .activity-card .title_search,
.content_left .bulletin-card .title_search {
  margin: 0 0 0.35rem 0;
  font-size: 0.9rem;
}

.content_left .activity-card .activity-header {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 0.65rem;
  margin-bottom: 0.35rem;
}

.content_left .signup-container .alerts-header {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 0.65rem;
  margin-bottom: 0.35rem;
}

.content_left .bulletin-card .bulletin-header,
.menu .bulletin-card .bulletin-header,
.menu-wrap>.bulletin-card .bulletin-header {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 0.65rem;
  margin-bottom: 0.75rem;
  min-height: 28px;
}

.sidebar-viewall-row {
  display: flex;
  justify-content: center;
  margin-top: 0.5rem;
}

.sidebar-count-corner {
  position: absolute;
  right: 0;
  top: 0;
}

.content_left .bulletin-card .bulletin-header .title_search,
.menu .bulletin-card .bulletin-header .title_search,
.menu-wrap>.bulletin-card .bulletin-header .title_search {
  margin: 0;
  grid-column: 2;
  justify-self: center;
  display: inline-flex;
  align-items: center;
}

.content_left .bulletin-card .bulletin-add,
.menu .bulletin-card .bulletin-add,
.menu-wrap>.bulletin-card .bulletin-add {
  position: absolute;
  left: 0;
  top: 0;
  margin: 0;
  font-size: 0.7rem;
  text-decoration: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 28px;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a !important;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  -webkit-text-fill-color: currentColor;
  box-shadow: var(--shadow-sm);
  transform: none;
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    background 140ms ease;
}

html[data-theme='dark'] .content_left .bulletin-card .bulletin-add,
html[data-theme='dark'] .menu .bulletin-card .bulletin-add,
html[data-theme='dark'] .menu-wrap>.bulletin-card .bulletin-add {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink) !important;
}

.content_left .bulletin-card .bulletin-add:hover,
.menu .bulletin-card .bulletin-add:hover,
.menu-wrap>.bulletin-card .bulletin-add:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.content_left .bulletin-card .bulletin-add:active,
.menu .bulletin-card .bulletin-add:active,
.menu-wrap>.bulletin-card .bulletin-add:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.content_left .bulletin-card .bulletin-add:focus-visible,
.menu .bulletin-card .bulletin-add:focus-visible,
.menu-wrap>.bulletin-card .bulletin-add:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

.menu .bulletin-card .modal-trigger.bulletin-add,
.menu-wrap>.bulletin-card .modal-trigger.bulletin-add {
  width: auto;
  margin: 0;
  align-self: auto;
  padding: 0 0.75rem;
}

.content_left .signup-container .alerts-header .title_search {
  margin: 0;
  grid-column: 2;
  justify-self: center;
  display: inline-flex;
  align-items: center;
}

.content_left .signup-container .alerts-viewall {
  position: static;
  grid-column: 3;
  justify-self: end;
  margin: 0;
  font-size: 0.7rem;
  text-decoration: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  flex-wrap: nowrap;
  height: 28px;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  -webkit-text-fill-color: currentColor;
  box-shadow: var(--shadow-sm);
  transform: none;
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    background 140ms ease;
}

html[data-theme='dark'] .content_left .signup-container .alerts-viewall {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

.content_left .signup-container .alerts-viewall:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.content_left .signup-container .alerts-viewall:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.content_left .signup-container .alerts-viewall:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

.content_left .activity-card .activity-header .title_search {
  margin: 0;
  grid-column: 2;
  justify-self: center;
  display: inline-flex;
  align-items: center;
}

.content_left .activity-card .activity-viewall,
.page-head .activity-viewall {
  position: static;
  grid-column: 3;
  justify-self: end;
  margin: 0;
  font-size: 0.7rem;
  text-decoration: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  flex-wrap: nowrap;
  height: 28px;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  -webkit-text-fill-color: currentColor;
  box-shadow: var(--shadow-sm);
  transform: none;
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    background 140ms ease;
}

.content_left .bulletin-card .bulletin-viewall,
.menu .bulletin-card .bulletin-viewall,
.menu-wrap>.bulletin-card .bulletin-viewall {
  position: static;
  grid-column: 3;
  justify-self: end;
  margin: 0;
  font-size: 0.7rem;
  text-decoration: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  flex-wrap: nowrap;
  height: 28px;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  -webkit-text-fill-color: currentColor;
  box-shadow: var(--shadow-sm);
  transform: none;
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    background 140ms ease;
}

html[data-theme='dark'] .content_left .bulletin-card .bulletin-viewall,
html[data-theme='dark'] .menu .bulletin-card .bulletin-viewall,
html[data-theme='dark'] .menu-wrap>.bulletin-card .bulletin-viewall {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

.content_left .bulletin-card .bulletin-viewall:hover,
.menu .bulletin-card .bulletin-viewall:hover,
.menu-wrap>.bulletin-card .bulletin-viewall:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.content_left .bulletin-card .bulletin-viewall:active,
.menu .bulletin-card .bulletin-viewall:active,
.menu-wrap>.bulletin-card .bulletin-viewall:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.content_left .bulletin-card .bulletin-viewall:focus-visible,
.menu .bulletin-card .bulletin-viewall:focus-visible,
.menu-wrap>.bulletin-card .bulletin-viewall:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

html[data-theme='dark'] .content_left .activity-card .activity-viewall,
html[data-theme='dark'] .page-head .activity-viewall {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

.content_left .activity-card .activity-viewall:hover,
.page-head .activity-viewall:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.content_left .activity-card .activity-viewall:active,
.page-head .activity-viewall:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.content_left .activity-card .activity-viewall:focus-visible,
.page-head .activity-viewall:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

.content_left .signup-container .title_search,
.content_left .signup-container .title_new,
.content_left .activity-card .title_search,
.content_left .bulletin-card .title_search,
.menu .bulletin-card .title_search,
.menu-wrap>.bulletin-card .title_search {
  display: inline-block;
  color: transparent;
  background-image: var(--brand-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_left .activity-card .activity-viewall.title_search {
  color: rgba(15, 23, 42, 0.92) !important;
  background-image: none !important;
  -webkit-text-fill-color: currentColor !important;
}

html[data-theme='dark'] .content_left .activity-card .activity-viewall.title_search {
  color: var(--ink) !important;
}

.sidebar-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.25rem;
}

.sidebar-item {
  font-size: 0.85rem;
  color: var(--subtle);
  line-height: 1.3;
  display: block;
  align-items: initial;
  justify-content: initial;
  gap: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  margin: 0;
  padding: 0.2rem 0;
  border-radius: 0;
  cursor: default;
}

.sidebar-link {
  color: inherit;
  text-decoration: none;
}

.sidebar-link:hover {
  text-decoration: underline;
}

.sidebar-meta {
  display: inline-block;
  margin-left: 0.5rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--subtle);
  white-space: nowrap;
}

.content_left .sidebar-item {
  font-size: 0.88rem;
}

.menu .bulletin-card .title_search,
.menu-wrap>.bulletin-card .title_search {
  font-size: 0.9rem;
}

.menu .bulletin-card .sidebar-item,
.menu-wrap>.bulletin-card .sidebar-item {
  font-size: 0.88rem;
  text-align: left;
  min-width: 0;
}

.content_left .bulletin-card .sidebar-item {
  min-width: 0;
}

.menu .bulletin-card .sidebar-list,
.menu-wrap>.bulletin-card .sidebar-list {
  text-align: left;
}

.content_left .activity-card .sidebar-list,
.content_left .activity-card .sidebar-item,
.menu .activity-card .sidebar-list,
.menu .activity-card .sidebar-item {
  text-align: left;
}

.content_left .signup-container .sidebar-list,
.content_left .signup-container .sidebar-item {
  text-align: left;
}

.content_left .signup-container .alerts-count,
.menu .signup-container .alerts-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.45em;
  height: 1.45em;
  padding: 0 0.45em;
  margin-left: 0.5rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  color: var(--ink);
  -webkit-text-fill-color: currentColor;
  font-weight: 900;
  font-size: 0.85rem;
  line-height: 1;
  vertical-align: middle;
}

.sidebar-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-width: 1.45em;
  height: 1.45em;
  padding: 0 0.45em;
  margin-left: 0;
  margin-right: 0.5rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  background-image: none;
  color: var(--ink);
  -webkit-text-fill-color: currentColor;
  background-clip: border-box;
  -webkit-background-clip: border-box;
  font-weight: 900;
  font-size: 0.85rem;
  line-height: 1;
  vertical-align: middle;
}

.content_left .signup-container .title_search,
.menu .signup-container .title_search {
  display: inline-flex;
  align-items: center;
}

.content_left .signup-container .sidebar-item,
.menu .signup-container .sidebar-item {
  color: rgba(15, 23, 42, 0.78);
  font-weight: 800;
  font-size: 0.83rem;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
  padding-left: 0.9rem;
  padding-right: 0.35rem;
}

.alerts-list .sidebar-item {
  color: rgba(15, 23, 42, 0.78);
  font-weight: 800;
  font-size: 0.83rem;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
  padding-left: 0.9rem;
  padding-right: 0.35rem;
}

html[data-theme='dark'] .alerts-list .sidebar-item {
  color: var(--ink);
  opacity: 0.9;
}

.content_left .activity-card .sidebar-item,
.menu .activity-card .sidebar-item,
.activity-list .sidebar-item {
  color: rgba(15, 23, 42, 0.78);
  font-weight: 800;
  font-size: 0.9rem;
  text-transform: none;
  letter-spacing: normal;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
}

.content_left .activity-card,
.menu .activity-card,
.activity-list,
.content_left .activity-card .sidebar-link,
.menu .activity-card .sidebar-link,
.activity-list .sidebar-link {
  text-transform: none !important;
  letter-spacing: normal !important;
}

.content_left .activity-card .activity-item,
.menu .activity-card .activity-item,
.activity-list .activity-item {
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.content_left .activity-card .activity-item>.sidebar-link,
.menu .activity-card .activity-item>.sidebar-link,
.activity-list .activity-item>.sidebar-link {
  background: transparent !important;
}

.content_left .activity-card .sidebar-link,
.menu .activity-card .sidebar-link,
.activity-list .sidebar-link {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  display: block;
}

.content_left .activity-card .activity-pill-link,
.menu .activity-card .activity-pill-link,
.activity-list .activity-pill-link {
  --marquee-gap: 1.5rem;
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  display: block;
}

.content_left .activity-card .activity-pill-static,
.menu .activity-card .activity-pill-static,
.activity-list .activity-pill-static {
  color: inherit;
  text-decoration: none;
}

.content_left .activity-card .activity-pill-track,
.menu .activity-card .activity-pill-track,
.activity-list .activity-pill-track {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: var(--marquee-gap, 1.5rem);
  min-width: max-content;
  transform: translateX(0);
}

.content_left .activity-card .activity-pill-text,
.menu .activity-card .activity-pill-text,
.activity-list .activity-pill-text {
  flex: 0 0 auto;
  display: block;
  min-width: max-content;
  white-space: nowrap;
}

.content_left .activity-card .activity-pill-link.is-read .activity-pill-track,
.menu .activity-card .activity-pill-link.is-read .activity-pill-track,
.activity-list .activity-pill-link.is-read .activity-pill-track {
  display: block;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}

.content_left .activity-card .activity-pill-link.is-read .activity-pill-text,
.menu .activity-card .activity-pill-link.is-read .activity-pill-text,
.activity-list .activity-pill-link.is-read .activity-pill-text {
  display: block;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.content_left .activity-card .activity-pill-link.is-marquee .activity-pill-track,
.menu .activity-card .activity-pill-link.is-marquee .activity-pill-track,
.activity-list .activity-pill-link.is-marquee .activity-pill-track {
  will-change: transform;
  animation: pill-marquee-loop var(--marquee-duration, 9s) linear infinite;
}

.content_left .activity-card .activity-pill-link.btn-nav,
.menu .activity-card .activity-pill-link.btn-nav {
  font-size: 0.8rem;
}

.content_left .signup-container .sidebar-link,
.menu .signup-container .sidebar-link,
.alerts-list .sidebar-link {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
}

.content_left .signup-container .alert-pill-link.btn-nav,
.menu .signup-container .alert-pill-link.btn-nav,
.alerts-list .alert-pill-link.btn-nav {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  min-height: 38px;
  height: auto;
  padding: 0.45rem 0.9rem;
  border-radius: 12px;
  font-size: 0.8rem;
  line-height: 1.25;
  text-transform: none;
  letter-spacing: normal;
  overflow: hidden;
  white-space: nowrap;
}

.content_left .signup-container .alert-pill-text,
.menu .signup-container .alert-pill-text,
.alerts-list .alert-pill-text {
  display: inline-block;
  min-width: max-content;
  transform: translateX(0);
}

.content_left .signup-container .alert-pill-link.is-read .alert-pill-text,
.menu .signup-container .alert-pill-link.is-read .alert-pill-text,
.alerts-list .alert-pill-link.is-read .alert-pill-text {
  flex: 1 1 auto;
  display: block;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.content_left .signup-container .alert-pill-link.is-marquee .alert-pill-text,
.menu .signup-container .alert-pill-link.is-marquee .alert-pill-text,
.alerts-list .alert-pill-link.is-marquee .alert-pill-text {
  will-change: transform;
  animation: pill-marquee var(--marquee-duration, 6s) ease-in-out infinite alternate;
}

.content_left .signup-container .sidebar-meta,
.menu .signup-container .sidebar-meta,
.alerts-list .sidebar-meta {
  flex: 0 0 auto;
  margin-left: auto;
}

.content_left .signup-container .alert-actions,
.menu .signup-container .alert-actions,
.alerts-list .alert-actions {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  flex: 0 0 auto;
}

.content_left .signup-container .alert-actions .sidebar-meta,
.menu .signup-container .alert-actions .sidebar-meta,
.alerts-list .alert-actions .sidebar-meta {
  margin-left: 0;
}

.alert-delete-form {
  display: inline-flex;
  margin: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 120ms ease-in-out;
}

.content_left .signup-container .sidebar-item:hover .alert-delete-form,
.menu .signup-container .sidebar-item:hover .alert-delete-form,
.alerts-list .sidebar-item:hover .alert-delete-form,
.content_left .signup-container .sidebar-item:focus-within .alert-delete-form,
.menu .signup-container .sidebar-item:focus-within .alert-delete-form,
.alerts-list .sidebar-item:focus-within .alert-delete-form {
  opacity: 1;
  pointer-events: auto;
}

.alert-delete-btn {
  appearance: none;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--subtle);
  border-radius: 10px;
  width: 28px;
  height: 28px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.alert-delete-btn:hover {
  color: var(--ink);
  border-color: var(--border-strong);
}

.alert-delete-btn:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--brand-1) 42%, transparent);
  outline-offset: 2px;
}

.activity-list .sidebar-meta {
  flex: 0 0 auto;
}

html[data-theme='dark'] .content_left .signup-container .sidebar-item,
html[data-theme='dark'] .menu .signup-container .sidebar-item {
  color: var(--ink);
  opacity: 0.9;
}

html[data-theme='dark'] .content_left .activity-card .sidebar-item,
html[data-theme='dark'] .menu .activity-card .sidebar-item,
html[data-theme='dark'] .activity-list .sidebar-item {
  color: var(--ink);
  opacity: 0.9;
}

.activity-list .sidebar-meta {
  margin-left: 0;
}

.content_left .signup-container .alert-username,
.menu .signup-container .alert-username,
.content_left .activity-card .alert-username,
.menu .activity-card .alert-username,
.activity-list .alert-username,
.alerts-list .alert-username {
  color: var(--brand-1);
  font-weight: 900;
  display: inline-block;
  line-height: 1;
  padding: 0.12em 0.5em;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  vertical-align: middle;
  white-space: nowrap;
  overflow: hidden;
}

.content_left .signup-container .alert-username,
.menu .signup-container .alert-username,
.content_left .activity-card .alert-username,
.menu .activity-card .alert-username {
  max-width: 9.5rem;
}

.activity-list .alert-username,
.alerts-list .alert-username {
  max-width: 14rem;
}

.alert-username .pill-text {
  display: inline-block;
  transform: translateX(0);
}

.alert-username.is-marquee .pill-text {
  will-change: transform;
  animation: pill-marquee var(--marquee-duration, 6s) ease-in-out infinite alternate;
}

@keyframes pill-marquee {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(calc(-1 * var(--marquee-distance, 0px)));
  }
}

@keyframes pill-marquee-loop {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(calc(-1 * var(--marquee-distance, 0px)));
  }
}

@media (prefers-reduced-motion: reduce) {
  .alert-username.is-marquee .pill-text,
  .alert-pill-link.is-marquee .alert-pill-text,
  .activity-pill-link.is-marquee .activity-pill-track {
    animation: none;
  }
}

.content_left .signup-container .sidebar-link .alert-username,
.menu .signup-container .sidebar-link .alert-username,
.alerts-list .sidebar-link .alert-username,
.content_left .activity-card .sidebar-link .alert-username,
.menu .activity-card .sidebar-link .alert-username,
.activity-list .sidebar-link .alert-username {
  color: var(--brand-1);
}

.activity-item {
  --activity-primary: var(--brand-1);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-follow {
  --activity-primary: var(--brand-1);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-unfollow {
  --activity-primary: var(--brand-2);
  --activity-secondary: var(--brand-1);
}

.activity-item.action-rating_create {
  --activity-primary: var(--info);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-rating_edit {
  --activity-primary: var(--warning);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-rating_delete {
  --activity-primary: var(--danger);
  --activity-secondary: var(--warning);
}

.activity-item.action-rating_view {
  --activity-primary: var(--brand-2);
  --activity-secondary: var(--info);
}

.activity-item.action-rating_like {
  --activity-primary: var(--love);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-rating_unlike {
  --activity-primary: var(--danger);
  --activity-secondary: var(--love);
}

.activity-item.action-rating_reaction {
  --activity-primary: var(--brand-1);
  --activity-secondary: var(--info);
}

.activity-item.action-rating_category_downvote {
  --activity-primary: var(--danger);
  --activity-secondary: var(--love);
}

.activity-item.action-playlist_favorite {
  --activity-primary: var(--love);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-playlist_unfavorite {
  --activity-primary: var(--danger);
  --activity-secondary: var(--love);
}

.activity-item.action-bulletin_post {
  --activity-primary: var(--brand-1);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-profile_comment_add {
  --activity-primary: var(--info);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-profile_comment_edit {
  --activity-primary: var(--warning);
  --activity-secondary: var(--brand-2);
}

.activity-item.action-profile_comment_delete {
  --activity-primary: var(--danger);
  --activity-secondary: var(--warning);
}

.activity-item.action-profile_update {
  --activity-primary: var(--brand-2);
  --activity-secondary: var(--brand-1);
}

.content_left .activity-card .activity-item .alert-username,
.menu .activity-card .activity-item .alert-username,
.activity-list .activity-item .alert-username {
  color: var(--activity-primary);
  border-color: color-mix(in srgb, var(--activity-primary) 38%, var(--border));
  background: color-mix(in srgb, var(--activity-primary) 14%, var(--surface));
}

.content_left .activity-card .activity-item .alert-username.is-secondary,
.menu .activity-card .activity-item .alert-username.is-secondary,
.activity-list .activity-item .alert-username.is-secondary {
  color: var(--activity-secondary);
  border-color: color-mix(in srgb,
      var(--activity-secondary) 38%,
      var(--border));
  background: color-mix(in srgb, var(--activity-secondary) 14%, var(--surface));
}

.content_left .activity-card .activity-item .activity-verb,
.menu .activity-card .activity-item .activity-verb,
.activity-list .activity-item .activity-verb {
  color: var(--activity-primary);
  font-weight: 900;
}

.content_left .signup-container .alert-username.is-secondary,
.menu .signup-container .alert-username.is-secondary,
.content_left .activity-card .alert-username.is-secondary,
.menu .activity-card .alert-username.is-secondary,
.activity-list .alert-username.is-secondary {
  color: var(--brand-2);
}

.content_left .signup-container .sidebar-link .alert-username.is-secondary,
.menu .signup-container .sidebar-link .alert-username.is-secondary,
.content_left .activity-card .sidebar-link .alert-username.is-secondary,
.menu .activity-card .sidebar-link .alert-username.is-secondary,
.activity-list .sidebar-link .alert-username.is-secondary {
  color: var(--brand-2);
}

.alert-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--danger);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--danger) 55%, transparent);
  animation: alert-heartbeat 1.25s ease-in-out infinite;
  flex: 0 0 auto;
}

.alert-dot.is-read {
  background: transparent;
  box-shadow: none;
  animation: none;
  opacity: 0;
}

@keyframes alert-heartbeat {
  0% {
    transform: scale(0.9);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--danger) 50%, transparent);
  }

  55% {
    transform: scale(1.2);
    box-shadow: 0 0 0 8px color-mix(in srgb, var(--danger) 0%, transparent);
  }

  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--danger) 0%, transparent);
  }
}

.flash-messages {
  margin-bottom: 14px;
  padding: 10px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  text-align: center;
}

.flash-message+.flash-message {
  margin-top: 6px;
}

.flash-message {
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--border);
  color: var(--ink);
  white-space: pre-line;
}

.flash-message.error {
  border-color: var(--danger);
}

.flash-message.success {
  border-color: var(--brand-1);
}

.sidebar-item+.sidebar-item {
  border-top: 1px dashed rgba(15, 23, 42, 0.12);
}

html[data-theme='dark'] .sidebar-item+.sidebar-item {
  border-top-color: rgba(226, 232, 240, 0.18);
}

.sidebar-toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.sidebar-collapsible {
  max-height: 3.6rem;
  overflow: hidden;
  transition: max-height 200ms ease;
}

.sidebar-collapsible.sidebar-static {
  max-height: none;
  overflow: visible;
}

.content_left #alerts-toggle+.sidebar-collapsible {
  max-height: 7.2rem;
}

.content_left #alerts-toggle:checked+.sidebar-collapsible {
  max-height: 999px;
}

.activity-card .sidebar-collapsible {
  max-height: 20rem;
}

.bulletin-card .sidebar-collapsible {
  max-height: 18rem;
  overflow: hidden;
}

.bulletin-item {
  margin: 0;
}

.bulletin-item>summary {
  cursor: pointer;
  user-select: none;
  list-style: none;
}

.bulletin-item>summary::-webkit-details-marker {
  display: none;
}

.bulletin-link {
  cursor: pointer;
  display: block;
  width: 100%;
}

.bulletin-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
  width: 100%;
  min-width: 0;
}

.bulletin-summary-left {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
}

.bulletin-summary-right {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex: 0 0 auto;
}

.bulletin-by {
  color: var(--subtle);
  font-weight: 800;
  font-size: 0.78rem;
  white-space: nowrap;
}

.bulletin-type {
  --flair-color: var(--brand-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  border: 2px solid transparent;
  background:
    linear-gradient(color-mix(in srgb, var(--flair-color) 16%, var(--surface)),
      color-mix(in srgb, var(--flair-color) 16%, var(--surface))) padding-box,
    linear-gradient(135deg, var(--flair-color), var(--flair-color)) border-box;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--flair-color);
  -webkit-text-fill-color: currentColor;
}

.bulletin-type-text {
  position: relative;
  top: -0.5px;
}

.bulletin-type.flair-poll {
  --flair-color: var(--info);
}

.bulletin-type.flair-praise {
  --flair-color: var(--brand-1);
}

.bulletin-type.flair-critique {
  --flair-color: var(--warning);
}

.bulletin-type.flair-show-tell {
  --flair-color: var(--love);
}

.bulletin-type.flair-rating-highlight {
  --flair-color: var(--brand-2);
}

.bulletin-type.flair-rating-challenge {
  --flair-color: var(--danger);
}

.bulletin-item>summary:hover .bulletin-type {
  opacity: 0.92;
}

.bulletin-link:hover .bulletin-type {
  opacity: 0.92;
}

.bulletin-message {
  margin-top: 0.25rem;
  color: var(--subtle);
}

.bulletin-title {
  margin-top: 0.25rem;
  font-weight: 900;
  color: var(--ink);
  font-size: 0.86rem;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bulletin-poll-fields {
  display: grid;
  gap: 0.75rem;
}

.bulletin-poll-fields[hidden] {
  display: none;
}

.bulletin-poll-option-row {
  margin-bottom: 0;
}

.bulletin-poll-option-input-row {
  display: grid;
  gap: 0.55rem;
}

.bulletin-poll-actions {
  display: flex;
  justify-content: flex-start;
}

.bulletin-poll-remove-option {
  justify-self: flex-start;
}

.bulletin-poll-actions .btn-nav[disabled] {
  opacity: 0.5;
  pointer-events: none;
}

.bulletin-poll {
  margin-top: 1rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--line);
}

.bulletin-poll-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.bulletin-poll-label,
.bulletin-poll-total {
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--subtle);
}

.bulletin-poll-options {
  display: grid;
  gap: 0.65rem;
}

.bulletin-poll-form {
  margin: 0;
}

.bulletin-poll-option {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.9rem 1rem;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  color: var(--text);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
  transition:
    border-color 0.18s ease,
    background 0.18s ease,
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.bulletin-poll-option:hover,
.bulletin-poll-option:focus-visible {
  border-color: color-mix(in srgb, var(--brand-2) 55%, var(--line));
  background: color-mix(in srgb, var(--brand-2) 10%, var(--surface));
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
}

.bulletin-poll-option:active {
  transform: translateY(1px);
}

.bulletin-poll-option.is-selected {
  border-color: color-mix(in srgb, var(--brand-2) 75%, var(--line));
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--brand-1) 16%, var(--surface)),
      color-mix(in srgb, var(--brand-2) 16%, var(--surface))
    );
}

.bulletin-poll-option-text {
  min-width: 0;
  text-align: left;
}

.bulletin-poll-option-count {
  flex: 0 0 auto;
  min-width: 2.2rem;
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  text-align: center;
}

.bulletin-delete-form {
  flex: 0 0 auto;
}

.sidebar-list .bulletin-delete-form {
  display: none;
}

.sidebar-list .bulletin-summary:hover .bulletin-delete-form,
.sidebar-list .bulletin-summary:focus-within .bulletin-delete-form {
  display: inline-flex;
}

.sidebar-list .bulletin-link:hover .bulletin-delete-form,
.sidebar-list .bulletin-link:focus-within .bulletin-delete-form {
  display: inline-flex;
}

.bulletin-delete,
.activity-delete {
  appearance: none;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--subtle);
  border-radius: 10px;
  width: 28px;
  height: 28px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.bulletin-delete:hover,
.activity-delete:hover {
  color: var(--ink);
  border-color: var(--border-strong);
}

.activity-delete-form {
  display: inline-block;
  margin-left: 0.35rem;
}

.sidebar-toggle:checked+.sidebar-collapsible {
  max-height: 999px;
}

.sidebar-toggle-label {
  margin-top: 0.35rem;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(15, 23, 42, 0.55);
  background-image: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}

.content_left .signup-container .sidebar-toggle-label,
.content_left .activity-card .sidebar-toggle-label,
.menu .bulletin-card .sidebar-toggle-label,
.menu-wrap>.bulletin-card .sidebar-toggle-label {
  color: var(--subtle);
  background-image: none;
  -webkit-text-fill-color: currentColor;
}

.sidebar-toggle-label:hover {
  opacity: 0.85;
}

.content_main .activity-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin: 0.6rem 0 0.9rem 0;
  width: min(720px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.content_main .profile-slider-shell .profile-slider-btn {
  display: none;
}

.content_main .activity-tabs-mobile-shell {
  display: flex;
  align-items: center;
  gap: 8px;
  width: min(720px, 100%);
  margin: 0.6rem auto 0.9rem auto;
}

.content_main .activity-tabs-mobile-shell .activity-tabs {
  margin: 0;
  flex: 1;
}

.content_main .activity-tabs-slide-btn {
  display: none;
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  background: rgba(255, 255, 255, 0.82);
  color: rgba(15, 23, 42, 0.82);
  box-shadow: var(--shadow-sm);
}

.content_main .activity-tabs-slide-icon {
  font-size: 1.35rem;
  line-height: 1;
  font-weight: 900;
}

.content_main .activity-tabs-slide-btn:disabled {
  opacity: 0.35;
}

.content_main .activity-tabs-slide-btn.is-hidden {
  display: none !important;
}

html[data-theme='dark'] .content_main .activity-tabs-slide-btn {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

@media (max-width: 980px) {
  .content_main .activity-tabs-mobile-shell {
    width: 100%;
    justify-content: center;
  }

  .content_main .activity-tabs-mobile-shell.is-scrollable .activity-tabs-slide-btn {
    display: inline-flex;
  }

  .content_main .activity-tabs.activity-tabs-single-row-mobile {
    flex-wrap: nowrap;
    justify-content: center;
    overflow-x: auto;
    overflow-y: hidden;
    width: 100%;
    padding-bottom: 2px;
    scrollbar-width: none;
  }

  .content_main .activity-tabs-mobile-shell.is-scrollable .activity-tabs.activity-tabs-single-row-mobile {
    justify-content: flex-start;
  }

  .content_main .activity-tabs.activity-tabs-single-row-mobile::-webkit-scrollbar {
    display: none;
  }

  .content_main .activity-tabs.activity-tabs-single-row-mobile .activity-tab {
    flex: 0 0 auto;
    white-space: nowrap;
  }
}

@media (max-width: 820px) and (hover: hover) and (pointer: fine) {
  .content_main .profile-slider-shell {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
  }

  .content_main .profile-slider-shell.is-scrollable .profile-slider-btn {
    display: inline-flex;
  }

  .content_main .profile-slider-shell .profile-slider-track {
    flex: 1 1 auto;
    min-width: 0;
  }

  .content_main .profile-slider-shell .profile-slider-track.profile-top-four-grid,
  .content_main .profile-slider-shell .profile-slider-track.profile-preview-grid {
    margin: 0;
  }
}

.also-rated-tabs-shell {
  display: flex;
  align-items: center;
  gap: 8px;
  width: min(720px, 100%);
  margin: 0.6rem auto 0.9rem auto;
  justify-content: center;
}

.also-rated-tabs-shell .activity-tabs {
  margin: 0;
  flex: 1;
  min-width: 0;
}

.also-rated-slide-btn {
  display: none;
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  background: rgba(255, 255, 255, 0.82);
  color: rgba(15, 23, 42, 0.82);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
}

.also-rated-slide-btn:disabled {
  opacity: 0.35;
  cursor: default;
}

html[data-theme='dark'] .also-rated-slide-btn {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

@media (max-width: 980px) {
  .also-rated-tabs-shell {
    width: 100%;
    justify-content: center;
    padding-inline: 4px;
    box-sizing: border-box;
  }

  .also-rated-slide-btn {
    display: none;
  }

  .also-rated-tabs-shell .activity-tabs.activity-tabs-single-row-mobile {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    justify-content: center;
    width: 100%;
    box-sizing: border-box;
    padding-inline: 4px;
    padding-bottom: 2px;
  }

  .also-rated-tabs-shell.is-scrollable .also-rated-slide-btn {
    display: inline-flex;
  }

  .also-rated-tabs-shell.is-scrollable .activity-tabs.activity-tabs-single-row-mobile {
    justify-content: flex-start;
  }

  .also-rated-tabs-shell .activity-tabs.activity-tabs-single-row-mobile::-webkit-scrollbar {
    display: none;
  }

  .also-rated-tabs-shell .activity-tabs.activity-tabs-single-row-mobile .activity-tab {
    flex: 0 0 auto;
    white-space: nowrap;
  }
}

.browse-toolbar-stack {
  display: flex;
  flex-direction: column;
}

.activity-genre-form {
  display: inline-flex;
  align-items: center;
  margin: 0.75rem 0 0;
}

.activity-genre-form select {
  min-width: 180px;
}

@media (min-width: 981px) {
  .browse-toolbar-stack .browse-page-head-browse {
    order: 1;
  }

  .browse-toolbar-stack .browse-auth-guest {
    order: 2;
  }

  .browse-toolbar-stack .browse-tabs-row {
    order: 3;
  }

  .browse-toolbar-stack .browse-mobile-controls {
    order: 0;
  }
}

@media (max-width: 980px) {
  .browse-toolbar-stack .browse-auth-guest {
    order: 1;
  }

  .browse-toolbar-stack .browse-mobile-controls {
    order: 2;
  }

  .browse-toolbar-stack .browse-page-head-browse {
    order: 3;
  }

  .browse-toolbar-stack .browse-tabs-row {
    order: 4;
  }

  .activity-genre-form {
    width: 100%;
    justify-content: flex-start;
  }

  .activity-genre-form select {
    width: 100%;
    min-width: 0;
  }
}

.content_main .browse-tabs-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 12px;
  row-gap: 10px;
  width: 100%;
  margin: 0.6rem 0 0.9rem 0;
}

.content_main .browse-tabs-row .browse-tabs-mobile-shell {
  grid-column: 2;
  width: auto;
  min-width: 0;
  margin: 0;
}

.content_main .browse-mobile-controls {
  display: none;
}

.content_main .browse-tabs-row .activity-tabs {
  grid-column: 2;
  width: auto;
  margin: 0;
  justify-content: center;
}

.content_main .browse-tabs-row .order-form {
  grid-column: 1;
  justify-self: start;
  display: inline-flex;
  align-items: center;
}

.content_main .browse-tabs-row .order-form select {
  width: auto;
  max-width: none;
  height: 34px;
  padding: 0 0.75rem;
  border-radius: 999px;
}

@media (max-width: 980px) {
  .content_main .browse-mobile-controls {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    column-gap: 0.75rem;
    margin: 0 0 0.6rem 0;
  }

  .content_main .browse-mobile-controls .browse-order-mobile {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
  }

  .content_main .browse-mobile-controls .browse-order-mobile select {
    width: auto;
    max-width: none;
    height: 34px;
    padding: 0 0.75rem;
    border-radius: 999px;
  }

  .content_main .browse-mobile-controls .browse-add-mobile {
    justify-self: end;
    height: 38px;
    padding: 0 0.9rem;
    border-radius: 12px;
    font-size: 0.8rem;
  }

  .content_main .page-head .browse-page-head-right {
    display: none;
  }

  .content_main .browse-tabs-row .browse-order-desktop {
    display: none;
  }

  .content_main .browse-tabs-row {
    grid-template-columns: 1fr;
    min-width: 0;
  }

  .content_main .browse-tabs-row .browse-tabs-mobile-shell {
    grid-column: 1;
    grid-row: 1;
    width: 100%;
    min-width: 0;
  }

  .content_main .browse-tabs-row .activity-tabs {
    width: 100%;
    min-width: 0;
  }

  .content_main .browse-tabs-mobile-shell .activity-tabs-slide-btn {
    display: inline-flex;
  }
}

.content_main .activity-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 34px;
  padding: 0 0.9rem;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.2);
  background: rgba(255, 255, 255, 0.7);
  color: rgba(15, 23, 42, 0.8);
  cursor: pointer;
  font-weight: 800;
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-decoration: none;
}

html[data-theme='dark'] .content_main .activity-tab:not(.is-active) {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(15, 23, 42, 0.55);
  color: var(--ink);
}

.content_main .activity-tab:hover {
  text-decoration: none;
  transform: translateY(-1px);
}

html[data-theme='dark'] .content_main .activity-tab:not(.is-active):hover {
  background: rgba(226, 232, 240, 0.14);
}

html[data-theme='dark'] .content_main .activity-tab.is-active {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

html[data-theme='dark'] .content_main .favorites-tabs .activity-tab,
html[data-theme='dark'] .content_main .favorites-tabs .activity-tab:not(.is-active),
html[data-theme='dark'] .content_main .favorites-tabs .activity-tab.is-active {
  color: #fff;
}

.content_main .activity-tab.is-active {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  color: rgba(15, 23, 42, 0.92);
}

.content_main .activity-list {
  width: min(720px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.activity-content-bottom {
  box-sizing: border-box;
  padding-inline: 1.25rem;
}

.activity-content-bottom .pagination-bar {
  width: min(760px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.browse-content-bottom {
  box-sizing: border-box;
  padding-inline: 1.25rem;
}

.home-content-bottom,
.playlists-content-bottom,
.charts-content-bottom {
  box-sizing: border-box;
  padding-inline: 1.25rem;
}

.bulletin-content-bottom,
.users-content-bottom,
.alerts-content-bottom,
.profile-media-content-bottom {
  box-sizing: border-box;
  padding-inline: 1.25rem;
}

.home-content-bottom .pagination-bar,
.playlists-content-bottom .pagination-bar,
.charts-content-bottom .pagination-bar {
  width: min(760px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.bulletin-content-bottom .pagination-bar {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.alerts-content-bottom .pagination-bar {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.users-content-bottom .pagination-bar {
  width: min(800px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.profile-media-content-bottom .pagination-bar {
  width: min(768px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.also-rated-content-bottom {
  box-sizing: border-box;
  padding-inline: 1.25rem;
}

@media (min-width: 981px) {
  .activity-content-bottom {
    width: calc(100% - 352px);
    margin-left: 352px;
  }

  .browse-content-bottom {
    width: calc(100% - 352px);
    margin-left: 352px;
  }

  .home-content-bottom,
  .playlists-content-bottom,
  .charts-content-bottom {
    width: calc(100% - 352px);
    margin-left: 352px;
  }

  .bulletin-content-bottom,
  .users-content-bottom,
  .alerts-content-bottom,
  .profile-media-content-bottom {
    width: calc(100% - 352px);
    margin-left: 352px;
  }

  .also-rated-content-bottom {
    width: calc(100% - 352px);
    margin-left: 352px;
  }
}

.rating-list-toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.rating-list-toggle-wrap {
  display: flex;
  flex-direction: column;
  min-height: var(--home-featured-collapsed);
  height: var(--home-featured-collapsed);
}

.rating-list-collapsible {
  max-height: var(--home-featured-collapsed);
  overflow: hidden;
  transition: max-height 200ms ease;
}

.rating-list-toggle:checked+.rating-list-toggle-wrap .rating-list-collapsible {
  max-height: 9999px;
}

.rating-list-toggle:checked+.rating-list-toggle-wrap {
  height: auto;
}

.rating-list-toggle-label {
  margin-top: 0.6rem;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(15, 23, 42, 0.55);
  background-image: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  justify-content: center;
  width: 100%;
}

.rating-list-toggle-label .show-less {
  display: none;
}

.rating-list-toggle:checked+.rating-list-toggle-wrap .rating-list-toggle-label .show-more {
  display: none;
}

.rating-list-toggle:checked+.rating-list-toggle-wrap .rating-list-toggle-label .show-less {
  display: inline;
}

.rating-list-toggle-label:hover {
  opacity: 0.85;
}

.rating-list-toggle-wrap-trim {
  min-height: 0;
  height: auto;
}

.rating-list-toggle-trim:not(:checked)+.rating-list-toggle-wrap-trim .rating-list-trim>li:nth-child(n + 4) {
  display: none;
}

.sidebar-toggle-label .show-less {
  display: none;
}

.sidebar-toggle:checked~.sidebar-toggle-label .show-more {
  display: none;
}

.sidebar-toggle:checked~.sidebar-toggle-label .show-less {
  display: inline;
}

.content_main {
  grid-area: content_main;
  padding: 1.25rem;
  min-width: 0;
  min-height: 0;
  border: 2px solid transparent;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-md);
}

html[data-theme='dark'] .content_main {
  background:
    linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main.ratings-container,
.content_main.gradient-container {
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .content_main.ratings-container,
html[data-theme='dark'] .content_main.gradient-container {
  background:
    linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main.ratings-home {
  align-self: start;
}

.content_main.landing-home {
  align-self: stretch;
  width: 100%;
  border: 2px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  overflow: hidden;
}

.landing-shell {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  width: 100%;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

.landing-shell .home-tabs {
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
}

.landing-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  align-items: start;
  gap: 1.25rem;
  padding: 1.35rem;
  border-radius: 28px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgb(var(--brand-1-rgb) / 0.26), transparent 34%),
    radial-gradient(circle at bottom right, rgb(var(--brand-2-rgb) / 0.22), transparent 38%),
    linear-gradient(135deg,
      rgba(10, 30, 52, 0.96),
      rgba(20, 38, 66, 0.94) 44%,
      rgb(var(--brand-1-rgb) / 0.18) 76%,
      rgb(var(--brand-2-rgb) / 0.24) 100%);
  box-shadow: 0 26px 64px rgba(15, 23, 42, 0.2);
}

.landing-hero-copy-stack {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  min-width: 0;
}

.landing-hero-copy,
.landing-preview {
  position: relative;
  z-index: 1;
}

.landing-preview {
  min-width: 0;
}

.landing-kicker,
.landing-section-label {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 0.9rem;
  border-radius: 999px;
  border: 1px solid rgb(var(--brand-1-rgb) / 0.42);
  background: linear-gradient(135deg, rgba(2, 6, 23, 0.78), rgb(var(--brand-1-rgb) / 0.14));
  color: #d7f6ff;
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.landing-title {
  margin: 0.8rem 0 0;
  max-width: 13ch;
  color: #f8fbff;
  font-size: clamp(2.3rem, 4vw, 4.2rem);
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.landing-subtitle {
  margin: 0.45rem 0 0;
  max-width: 60ch;
  color: rgba(225, 236, 255, 0.9);
  font-size: 1rem;
  line-height: 1.7;
}

.landing-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, max-content));
  align-items: center;
  gap: 0.65rem;
  margin-top: 1.1rem;
}

.landing-actions .btn-nav.pill-action {
  min-height: 38px;
  justify-content: center;
  padding-inline: 1.05rem;
  font-size: 0.76rem;
  letter-spacing: 0.05em;
}

.landing-primary-action {
  background:
    linear-gradient(rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.9)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a !important;
}

.landing-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  margin-top: 1rem;
}

.landing-stat-card,
.landing-feature-card,
.landing-step-card,
.landing-instruction-card {
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
}

.landing-stat-card {
  display: grid;
  min-height: 0;
  grid-template-columns: 36px minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: start;
  column-gap: 0.8rem;
  row-gap: 0.12rem;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(9, 24, 49, 0.72), rgba(8, 20, 41, 0.6));
  backdrop-filter: blur(10px);
}

.landing-stat-card .landing-stat-icon {
  display: inline-flex;
  grid-row: 1 / span 2;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid rgb(var(--brand-1-rgb) / 0.34);
  background: rgb(var(--brand-1-rgb) / 0.12);
  color: #ecfeff;
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
}

.landing-stat-svg {
  width: 19px;
  height: 19px;
}

.landing-stat-card strong {
  align-self: start;
  color: #f8fbff;
  font-size: 1rem;
  line-height: 1.18;
}

.landing-stat-card > span:not(.landing-stat-icon) {
  grid-column: 2;
  margin-top: 0;
  color: rgba(210, 224, 247, 0.88);
  font-size: 0.86rem;
  line-height: 1.45;
}

.landing-preview {
  display: grid;
  align-content: center;
  gap: 1rem;
  min-height: 100%;
}

.landing-preview-backdrop {
  position: absolute;
  inset: 8% 10% 6% 16%;
  border-radius: 32px;
  background:
    radial-gradient(circle at center, rgb(var(--brand-1-rgb) / 0.24), transparent 45%),
    radial-gradient(circle at bottom right, rgb(var(--brand-2-rgb) / 0.2), transparent 52%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.15), transparent);
  filter: blur(18px);
  pointer-events: none;
}

.landing-preview-card {
  position: relative;
  z-index: 1;
  border-radius: 26px;
  border: 1px solid rgb(var(--brand-1-rgb) / 0.3);
  background:
    linear-gradient(160deg,
      rgba(10, 20, 36, 0.92),
      rgba(18, 34, 58, 0.9) 55%,
      rgb(var(--brand-2-rgb) / 0.3) 100%);
  box-shadow:
    0 20px 46px rgba(2, 6, 23, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.landing-preview-card-main {
  overflow: hidden;
}

.landing-preview-art {
  position: relative;
  min-height: 250px;
  padding: 1rem;
  background:
    radial-gradient(circle at top left, rgb(var(--brand-1-rgb) / 0.28), transparent 28%),
    linear-gradient(180deg, rgba(15, 23, 42, 0.02), rgba(15, 23, 42, 0.36));
}

.landing-preview-art img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: cover;
  border-radius: 22px;
  border: 1px solid rgb(var(--brand-1-rgb) / 0.35);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.9), rgba(30, 41, 59, 0.92));
}

.landing-preview-type,
.landing-preview-score,
.landing-preview-example,
.landing-preview-mini-label,
.landing-preview-mini-rank {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 0.8rem;
  border-radius: 999px;
  border: 1px solid rgb(var(--brand-1-rgb) / 0.32);
  background: rgba(2, 6, 23, 0.7);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.landing-preview-example {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  justify-content: center;
  text-align: center;
  color: #ffffff;
}

.landing-preview-type {
  top: 1.8rem;
  left: 1.8rem;
  color: rgb(var(--brand-1-rgb));
}

.landing-preview-score {
  top: 1.8rem;
  right: 1.8rem;
  color: rgb(var(--brand-2-rgb));
}

html[data-color-theme='newsprint'] .landing-preview-type {
  color: rgb(var(--brand-2-rgb));
}

.landing-preview-art .rating-card-reactions {
  position: absolute;
  right: 24px;
  bottom: 24px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 54px;
  min-height: 54px;
  padding: 0.4rem 0.55rem;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  background: rgba(15, 23, 42, 0.42);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  box-shadow:
    0 12px 28px rgba(15, 23, 42, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  flex-wrap: nowrap;
  gap: 6px;
  max-width: calc(100% - 100px);
  white-space: nowrap;
  pointer-events: none;
}

.landing-preview-art .rating-emoji {
  font-size: 1.35rem;
  opacity: 1;
  line-height: 1;
}

.landing-preview-art .rating-card-owner {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  pointer-events: none;
}

.landing-preview-art .rating-card-owner .avatar-wrap {
  width: 46px;
  height: 46px;
  padding: 2px;
  background: var(--brand-gradient);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.24);
}

.landing-preview-art .avatar-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 999px;
  overflow: hidden;
  text-decoration: none;
}

.landing-preview-art .avatar-wrap .avatar,
.landing-preview-art .avatar-wrap .avatar-initial {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  box-shadow: none;
}

.landing-preview-art .avatar-wrap .avatar-initial {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  background: rgba(255, 255, 255, 0.92);
  color: #0f172a;
  -webkit-text-fill-color: currentColor;
  transform: translateY(0);
  font-size: 1.3rem;
}

html[data-theme='dark'] .landing-preview-art .avatar-wrap .avatar-initial {
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

.landing-preview-art .rating-card-owner .rating-owner {
  margin: 0;
  max-width: calc(100% - 56px);
  padding: 0.38rem 0.64rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.5);
  color: rgba(248, 250, 252, 0.92);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.landing-preview-body {
  display: grid;
  gap: 0.4rem;
  padding: 1rem 1.1rem 1.15rem;
}

.landing-preview-owner {
  color: #6ee7ff;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.landing-preview-title {
  color: #f8fbff;
  font-size: 1.28rem;
  font-weight: 900;
  letter-spacing: -0.03em;
}

.landing-preview-title span {
  color: rgba(207, 220, 243, 0.8);
  font-weight: 700;
}

.landing-preview-metrics {
  color: rgba(213, 227, 247, 0.82);
  font-size: 0.92rem;
}

.landing-preview-card-side {
  padding: 1rem;
  justify-self: center;
  width: 100%;
}

.landing-preview-mini-head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

.landing-preview-mini-label {
  position: static;
  color: #d7f6ff;
}

.landing-preview-mini-rank {
  position: static;
  min-width: 36px;
  padding: 0;
  color: #ffffff;
}

.landing-preview-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.9rem;
}

.landing-preview-mini-slot {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 82px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 0.9rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.landing-preview-mini-slot.is-diamond {
  grid-column: 1 / -1;
  background: linear-gradient(135deg, rgba(103, 232, 249, 0.42), rgba(59, 130, 246, 0.38), rgba(224, 231, 255, 0.3));
}

.landing-preview-mini-slot.is-platinum {
  background: linear-gradient(135deg, rgba(242, 250, 255, 0.78), rgba(168, 196, 228, 0.62), rgba(120, 152, 196, 0.54));
}

.landing-preview-mini-slot.is-gold {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.48), rgba(217, 119, 6, 0.36), rgba(254, 240, 138, 0.28));
}

.landing-preview-mini-slot.is-silver {
  background: linear-gradient(135deg, rgba(190, 198, 210, 0.46), rgba(122, 135, 155, 0.34), rgba(222, 228, 236, 0.3));
}

.landing-preview-mini-slot.is-bronze {
  background: linear-gradient(135deg, rgba(217, 119, 6, 0.5), rgba(146, 64, 14, 0.38), rgba(253, 186, 116, 0.26));
}

.landing-section {
  padding: 1.2rem;
  border-radius: 24px;
  background:
    linear-gradient(180deg,
      rgba(255, 255, 255, 0.9),
      rgb(var(--brand-1-rgb) / 0.05) 52%,
      rgb(var(--brand-2-rgb) / 0.08) 100%);
  border: 1px solid rgb(var(--brand-1-rgb) / 0.16);
}

.landing-feed-section {
  background:
    radial-gradient(circle at top left, rgb(var(--brand-1-rgb) / 0.12), transparent 34%),
    radial-gradient(circle at bottom right, rgb(var(--brand-2-rgb) / 0.14), transparent 42%),
    linear-gradient(180deg,
      rgba(255, 255, 255, 0.94),
      rgb(var(--brand-1-rgb) / 0.08) 48%,
      rgb(var(--brand-2-rgb) / 0.12) 100%);
  border-color: rgb(var(--brand-1-rgb) / 0.22);
}

.landing-section-head {
  display: grid;
  gap: 0.6rem;
  margin-bottom: 1rem;
}

.landing-section-head h2 {
  margin: 0;
  padding-left: 0.42rem;
  color: #0f172a;
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.landing-steps,
.landing-feature-grid,
.landing-instructions-grid {
  display: grid;
  gap: 0.95rem;
}

.landing-steps {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.landing-feature-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.landing-step-card,
.landing-feature-card,
.landing-instruction-card {
  padding: 1rem 1.05rem;
  background:
    linear-gradient(180deg,
      rgba(255, 255, 255, 0.98),
      rgb(var(--brand-1-rgb) / 0.04) 100%);
}

.landing-step-number {
  display: inline-flex;
  margin-bottom: 0.7rem;
  color: var(--brand-2);
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: 0.12em;
}

.landing-step-card h3,
.landing-feature-card h3 {
  margin: 0;
  color: #0f172a;
  font-size: 1.02rem;
}

.landing-step-card p,
.landing-feature-card p,
.landing-instruction-card p {
  margin: 0.55rem 0 0;
  color: #334155;
  line-height: 1.62;
  font-size: 0.95rem;
}

.landing-instruction-card strong {
  display: block;
  color: #0f172a;
  font-size: 1rem;
}

html[data-theme='dark'] .content_main.landing-home {
  background:
    linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .landing-section {
  background:
    linear-gradient(180deg,
      rgba(11, 19, 35, 0.96),
      rgb(var(--brand-1-rgb) / 0.1) 100%);
  border-color: rgb(var(--brand-1-rgb) / 0.18);
}

html[data-theme='dark'] .landing-feed-section {
  background:
    radial-gradient(circle at top left, rgb(var(--brand-1-rgb) / 0.18), transparent 36%),
    radial-gradient(circle at bottom right, rgb(var(--brand-2-rgb) / 0.16), transparent 44%),
    linear-gradient(180deg,
      rgba(11, 19, 35, 0.98),
      rgb(var(--brand-1-rgb) / 0.14) 52%,
      rgb(var(--brand-2-rgb) / 0.16) 100%);
  border-color: rgb(var(--brand-1-rgb) / 0.24);
}

html[data-theme='dark'] .landing-section-head h2,
html[data-theme='dark'] .landing-step-card h3,
html[data-theme='dark'] .landing-feature-card h3,
html[data-theme='dark'] .landing-instruction-card strong {
  color: #f8fbff;
}

html[data-theme='dark'] .landing-step-card,
html[data-theme='dark'] .landing-feature-card,
html[data-theme='dark'] .landing-instruction-card {
  background:
    linear-gradient(180deg,
      rgba(17, 26, 46, 0.96),
      rgb(var(--brand-2-rgb) / 0.1) 100%);
  border-color: rgb(var(--brand-1-rgb) / 0.14);
}

html[data-theme='dark'] .landing-step-card p,
html[data-theme='dark'] .landing-feature-card p,
html[data-theme='dark'] .landing-instruction-card p {
  color: rgba(210, 223, 244, 0.84);
}

@media (max-width: 980px) {
  .landing-hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.7rem;
  }

  .landing-hero-copy-stack {
    display: contents;
  }

  .landing-hero-copy-top {
    order: 1;
  }

  .landing-preview {
    order: 3;
    gap: 0.75rem;
    margin-top: 0.15rem;
  }

  .landing-hero-copy-bottom {
    order: 2;
  }

  .landing-hero-copy-top,
  .landing-hero-copy-bottom {
    width: min(100%, 620px);
    text-align: center;
  }

  .landing-kicker {
    margin-inline: auto;
  }

  .landing-title {
    margin-inline: auto;
    max-width: 100%;
  }

  .landing-subtitle {
    margin-inline: auto;
    margin-top: 0.35rem;
  }

  .landing-stats,
  .landing-steps,
  .landing-feature-grid,
  .landing-instructions-grid {
    grid-template-columns: 1fr;
  }

  .landing-stats {
    grid-template-columns: 1fr;
    width: min(100%, 620px);
    margin-inline: auto;
    text-align: left;
  }
}

@media (min-width: 981px) and (max-width: 1360px) {
  .content_main.landing-home {
    max-width: 980px;
  }

  .landing-hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.7rem;
    padding: 1.1rem;
  }

  .landing-hero-copy-stack {
    display: contents;
  }

  .landing-hero-copy-top {
    order: 1;
  }

  .landing-preview {
    order: 3;
    gap: 0.8rem;
    margin-top: 0.15rem;
  }

  .landing-hero-copy-bottom {
    order: 2;
  }

  .landing-hero-copy-top,
  .landing-hero-copy-bottom {
    width: min(100%, 620px);
    text-align: center;
  }

  .landing-kicker {
    margin-inline: auto;
  }

  .landing-title {
    margin-inline: auto;
    max-width: 100%;
    font-size: clamp(2rem, 3.2vw, 3rem);
  }

  .landing-subtitle {
    margin-inline: auto;
    max-width: 48ch;
    font-size: 0.96rem;
    line-height: 1.6;
    margin-top: 0.35rem;
  }

  .landing-actions {
    gap: 0.55rem;
  }

  .landing-actions .btn-nav {
    height: 40px;
    padding-inline: 0.8rem;
  }

  .landing-stats {
    grid-template-columns: 1fr;
    width: min(100%, 620px);
    margin-inline: auto;
    text-align: left;
    gap: 0.7rem;
  }

  .landing-stat-card {
    padding: 0.8rem 0.9rem;
  }

  .landing-preview {
    width: min(100%, 720px);
    justify-self: center;
  }

  .landing-preview-card {
    border-radius: 22px;
  }

  .landing-preview-art {
    min-height: 216px;
    padding: 0.85rem;
  }

  .landing-preview-art img {
    min-height: 186px;
    border-radius: 18px;
  }

  .landing-preview-type,
  .landing-preview-score,
  .landing-preview-example {
    min-height: 32px;
    padding-inline: 0.7rem;
    font-size: 0.7rem;
  }

  .landing-preview-type,
  .landing-preview-score {
    top: 1.4rem;
  }

  .landing-preview-type {
    left: 1.4rem;
  }

  .landing-preview-score {
    right: 1.4rem;
  }

  .landing-preview-art .rating-card-owner {
    left: 18px;
    right: 18px;
    bottom: 18px;
  }

  .landing-preview-art .rating-card-reactions {
    right: 18px;
    bottom: 18px;
  }

  .landing-preview-art .rating-card-owner .avatar-wrap {
    width: 40px;
    height: 40px;
  }

  .landing-preview-art .avatar-wrap .avatar-initial {
    font-size: 1.05rem;
  }

  .landing-preview-art .rating-card-owner .rating-owner {
    max-width: calc(100% - 50px);
    padding: 0.34rem 0.55rem;
    font-size: 0.66rem;
  }

  .landing-preview-art .rating-card-reactions {
    min-width: 48px;
    min-height: 48px;
    padding: 0.34rem 0.46rem;
  }

  .landing-preview-art .rating-emoji {
    font-size: 1.15rem;
  }

  .landing-preview-body {
    padding: 0.9rem 1rem 1rem;
  }

  .landing-preview-title {
    font-size: 1.12rem;
  }

  .landing-preview-metrics {
    font-size: 0.84rem;
    line-height: 1.45;
  }

  .landing-preview-card-side {
    padding: 0.9rem;
  }

  .landing-preview-mini-grid {
    gap: 0.6rem;
  }

  .landing-preview-mini-slot {
    min-height: 72px;
    font-size: 0.8rem;
  }

  .landing-section {
    padding: 1rem;
  }

  .landing-steps,
  .landing-feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

@media (max-width: 640px) {
  .landing-hero,
  .landing-section {
    padding: 1rem;
    border-radius: 22px;
  }

  .landing-preview-art {
    min-height: 210px;
  }

  .landing-preview-art img {
    min-height: 180px;
  }

  .landing-actions {
    flex-direction: column;
  }

  .landing-actions .btn-nav {
    width: 100%;
    justify-content: center;
  }
}

.content_main .title_search {
  margin: 0 0 0.85rem 0;
  font-size: 1.1rem;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--ink);
  font-weight: 900;
}

.page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin: 0 0 0.85rem 0;
}

.page-head .title_search {
  margin: 0;
}

.page-head .btn-nav {
  height: 38px;
  padding: 0 0.9rem;
  border-radius: 12px;
}

.page-head-right {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}

.copy-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.copy-link-btn[data-copy-icon-button] {
  width: 38px;
  min-width: 38px;
  padding: 0;
}

.copy-link-icon {
  width: 17px;
  height: 17px;
  display: block;
}

.copy-link-btn[data-copy-state='success'] {
  border-color: rgba(34, 197, 94, 0.5);
  background: rgba(34, 197, 94, 0.14);
  color: rgba(22, 163, 74, 0.98) !important;
}

.copy-link-btn[data-copy-state='error'] {
  border-color: rgba(239, 68, 68, 0.5);
  background: rgba(239, 68, 68, 0.14);
  color: rgba(220, 38, 38, 0.98) !important;
}

html[data-theme='dark'] .copy-link-btn[data-copy-state='success'] {
  border-color: rgba(74, 222, 128, 0.44);
  background: rgba(34, 197, 94, 0.18);
  color: rgba(134, 239, 172, 0.98) !important;
}

html[data-theme='dark'] .copy-link-btn[data-copy-state='error'] {
  border-color: rgba(248, 113, 113, 0.44);
  background: rgba(239, 68, 68, 0.18);
  color: rgba(254, 202, 202, 0.98) !important;
}

.page-head-title-group {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-width: 0;
  flex-wrap: wrap;
}

.sr-only {
  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;
}

.page-head .order-form {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
}

.page-head .order-form select {
  width: auto;
  max-width: none;
  height: 34px;
  padding: 0 0.75rem;
  border-radius: 999px;
}

html[data-theme='dark'] .order-form select {
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  border-color: rgba(226, 232, 240, 0.24);
  color: var(--ink);
  color-scheme: dark;
}

html[data-theme='dark'] .order-form select option {
  background: var(--surface);
  color: var(--ink);
}

@media (max-width: 980px) {
  .page-head {
    justify-content: center;
  }

  .page-head.page-head-split-mobile {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    justify-content: stretch;
    gap: 0.75rem;
  }

  .page-head.page-head-split-mobile .title_search {
    text-align: left;
  }

  .page-head.page-head-split-mobile .page-head-right {
    justify-content: flex-end;
    min-width: 0;
  }

  .page-head.page-head-split-mobile .order-form {
    justify-content: flex-end;
  }
}

input,
select,
textarea,
button {
  font: inherit;
}

input[type='text'],
input[type='email'],
input[type='password'],
input[type='file'],
select,
textarea {
  width: 100%;
  max-width: 520px;
  border-radius: 12px;
  border: 1px solid #0f172a;
  background: #f5f5f5;
  color: var(--ink);
  padding: 0.55rem 0.75rem;
  transition:
    border-color 120ms ease,
    background 120ms ease,
    box-shadow 120ms ease;
}

html[data-theme='dark'] input[type='text'],
html[data-theme='dark'] input[type='email'],
html[data-theme='dark'] input[type='password'],
html[data-theme='dark'] input[type='file'],
html[data-theme='dark'] select,
html[data-theme='dark'] textarea {
  border-color: var(--border-strong);
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

input[type='file'] {
  padding: 0.45rem 0.6rem;
}

textarea {
  resize: vertical;
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: rgba(34, 193, 195, 0.85);
  box-shadow: var(--ring);
}

input::placeholder,
textarea::placeholder {
  color: rgba(0, 0, 0, 0.5);
}

select:required:invalid {
  color: var(--subtle);
}

select option {
  color: var(--ink);
}

select option[disabled] {
  color: var(--subtle);
}

html[data-theme='dark'] input::placeholder,
html[data-theme='dark'] textarea::placeholder {
  color: rgba(226, 232, 240, 0.55);
}

input.search {
  max-width: none;
}

button,
.btn-primary,
.btn-auth,
.btn-submit,
.btn-update,
.btn-danger,
.btn-cancel,
.btn-done {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  height: 38px;
  padding: 0 0.9rem;
  border-radius: 12px;
  border: 1px solid #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5;
  text-decoration: none;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition:
    transform 120ms ease,
    background 120ms ease,
    border-color 120ms ease;
}

button:hover,
.btn-primary:hover,
.btn-auth:hover,
.btn-submit:hover,
.btn-update:hover,
.btn-danger:hover,
.btn-cancel:hover,
.btn-done:hover {
  transform: translateY(-1px);
  background: #4b5563;
  border-color: #0f172a;
  text-decoration: none;
}

.btn-submit:disabled,
.btn-submit.is-loading {
  opacity: 0.85;
  cursor: wait;
  transform: none;
  pointer-events: none;
}

.btn-submit:disabled:hover,
.btn-submit.is-loading:hover {
  transform: none;
  background: var(--btn-dark);
}

.btn-submit.is-loading::after {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  animation: btn-spin 0.8s linear infinite;
}

@keyframes btn-spin {
  to {
    transform: rotate(360deg);
  }
}

button:active,
.btn-primary:active,
.btn-auth:active,
.btn-submit:active,
.btn-update:active,
.btn-danger:active,
.btn-cancel:active,
.btn-done:active {
  transform: translateY(0);
}

.btn-cancel {
  border: 1px solid rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.08);
  color: rgba(239, 68, 68, 0.95);
}

.btn-danger {
  border: 1px solid rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.08);
  color: rgba(239, 68, 68, 0.95);
}

.btn-cancel:hover {
  background: #dc2626;
  border-color: #dc2626;
  color: #fff;
  text-decoration: none;
}

.btn-danger:hover {
  background: #dc2626;
  border-color: #dc2626;
  color: #fff;
  text-decoration: none;
}

.btn-done {
  border: 1px solid rgba(34, 197, 94, 0.35);
  background: rgba(34, 197, 94, 0.08);
  color: rgba(22, 163, 74, 0.95);
}

.btn-done:hover {
  background: #22c55e;
  border-color: #22c55e;
  color: #fff;
  text-decoration: none;
}

.btn-follow {
  font-weight: 700;
  font-size: 0.9rem;
  height: 44px;
  padding: 0 1.1rem;
}

ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

li {
  background: var(--surface);
  color: var(--ink);
  margin: 0.6rem 0;
  padding: 0.75rem 0.9rem;
  border-radius: 12px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
  transition:
    background 140ms ease,
    border-color 140ms ease,
    transform 120ms ease,
    box-shadow 140ms ease;
}

li:hover {
  background: rgba(99, 102, 241, 0.08);
  border-color: rgba(99, 102, 241, 0.28);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.content_main .comment-list li:hover {
  background: var(--surface);
  border-color: var(--border);
  box-shadow: var(--shadow-sm);
  transform: none;
}

.content_main .comment-list li {
  cursor: default;
}

.rating-item-left {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.rating-hero {
  width: min(420px, 100%);
  margin: 0 auto 1rem auto;
  position: relative;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

.rating-hero .rating-card-art {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgb(var(--brand-1-rgb) / 0.22), transparent 52%),
    linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgb(var(--brand-2-rgb) / 0.28));
}

.rating-hero .rating-card-art::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('/static/no_img.png') center / clamp(120px, 28%, 220px) no-repeat;
  opacity: 0.9;
  pointer-events: none;
}

.rating-hero .rating-card-art img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.rating-hero .rating-card-art.is-empty {
  background:
    linear-gradient(135deg,
      rgba(2, 6, 23, 0.98),
      rgb(var(--brand-1-rgb) / 0.22) 46%,
      rgb(var(--brand-2-rgb) / 0.3) 100%);
}

.rating-hero .rating-card-art.is-empty::before {
  content: none;
}

.rating-hero .rating-card-art.is-empty .rating-card-art-default {
  position: relative;
  z-index: 1;
  width: min(52%, 220px);
  height: auto;
  object-fit: contain;
  opacity: 0.92;
  filter: drop-shadow(0 14px 28px rgba(0, 0, 0, 0.34));
}

.rating-hero .rating-card-art::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.06), rgba(15, 23, 42, 0.32));
  pointer-events: none;
}

.rating-hero .rating-card-art.is-empty::after {
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.12), rgba(15, 23, 42, 0.4));
}

.rating-hero .rating-card-art-label {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  padding: 0.38rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-md);
  font-size: 0.96rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(248, 250, 252, 0.92);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.rating-hero-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 1 / 1;
}

.rating-hero-emoji {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  min-width: 54px;
  height: 54px;
  padding: 0 0.5rem;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(15, 23, 42, 0.56);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-md);
  font-size: 1.8rem;
  line-height: 1;
  white-space: nowrap;
}

.rating-hero-percent {
  display: none;
}

.rating-hero-percent.is-score-high {
  color: #4ade80;
}

.rating-hero-percent.is-score-mid {
  color: #fde047;
}

.rating-hero-percent.is-score-low {
  color: #fb923c;
}

.rating-hero-percent.is-score-poor {
  color: #f87171;
}

.rating-cover-wrap {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  flex: 0 0 auto;
}

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

.rating-item-text {
  min-width: 0;
  display: block;
  width: 100%;
  text-align: left;
}

.rating-item-text strong {
  font-weight: 800;
}

.rating-subject-line {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  width: 100%;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.rating-subject-name {
  display: inline-flex;
  align-items: center;
  font-weight: 700;
}

.rating-subject-artist {
  display: inline-flex;
  align-items: center;
  color: var(--subtle);
  font-weight: 600;
}

.rating-item-text small {
  color: var(--subtle);
}

.rating-item-text .rating-owner {
  display: block;
  margin-bottom: 0.2rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background-image: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_main.ratings-container .rating-item-actions {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
  min-width: 0;
}

.content_main.ratings-container .rating-list .rating-item-actions {
  align-self: center;
}

.content_main.ratings-container .rating-action-menu {
  position: relative;
  display: inline-block;
  z-index: 1;
}

.content_main.ratings-container .rating-action-menu[open] {
  z-index: 6;
}

.content_main.ratings-container .rating-action-menu>summary {
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
}

.content_main.ratings-container .rating-action-menu>summary::-webkit-details-marker {
  display: none;
}

.content_main.ratings-container .rating-action-menu>summary::marker {
  content: '';
}

.content_main.ratings-container .rating-action-menu-toggle {
  width: 34px;
  min-width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.24);
  background: rgba(15, 23, 42, 0.34);
  color: #ffffff;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  user-select: none;
  line-height: 0;
}

.content_main.ratings-container .rating-action-menu-toggle:hover,
.content_main.ratings-container .rating-action-menu[open] .rating-action-menu-toggle {
  background: rgba(15, 23, 42, 0.46);
  border-color: rgba(15, 23, 42, 0.3);
}

.content_main.ratings-container .rating-action-menu-icon {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  gap: 3px;
}

.content_main.ratings-container .rating-action-menu-dot {
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: currentColor;
  flex: 0 0 auto;
}

.content_main.ratings-container .rating-action-menu-panel {
  position: absolute;
  right: 0;
  bottom: calc(100% + 8px);
  min-width: 132px;
  padding: 0.35rem;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.16), 0 2px 8px rgba(15, 23, 42, 0.08);
  display: grid;
  gap: 4px;
  overflow: hidden;
  transform-origin: bottom right;
}

.content_main.ratings-container .rating-action-menu:not([open]) .rating-action-menu-panel {
  display: none;
}

.content_main.ratings-container .rating-action-menu-panel form {
  display: block;
  width: 100%;
  margin: 0;
}

.content_main.ratings-container .rating-action-menu-item {
  width: 100%;
  height: 36px;
  min-height: 36px;
  padding: 0.6rem 0.75rem;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 800;
  line-height: 1.1;
  text-align: left;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  box-shadow: none;
  transform: none;
  transition: background 120ms ease, color 120ms ease;
}

.content_main.ratings-container .rating-action-menu-item:hover,
.content_main.ratings-container .rating-action-menu-item:focus-visible,
.content_main.ratings-container .rating-action-menu-item:active {
  background: rgba(15, 23, 42, 0.08);
  text-decoration: none;
  outline: none;
  transform: none;
  box-shadow: none;
}

.content_main.ratings-container .rating-action-menu-item.is-danger {
  color: #b91c1c;
}

.content_main.ratings-container .rating-action-menu-item.is-danger:hover,
.content_main.ratings-container .rating-action-menu-item.is-danger:focus-visible,
.content_main.ratings-container .rating-action-menu-item.is-danger:active {
  background: rgba(239, 68, 68, 0.12);
}

html[data-theme='dark'] .content_main.ratings-container .rating-action-menu-toggle {
  border-color: rgba(226, 232, 240, 0.24);
  background: rgba(226, 232, 240, 0.1);
  color: var(--ink);
}

html[data-theme='dark'] .content_main.ratings-container .rating-action-menu-toggle:hover,
html[data-theme='dark'] .content_main.ratings-container .rating-action-menu[open] .rating-action-menu-toggle {
  background: rgba(226, 232, 240, 0.16);
  border-color: rgba(226, 232, 240, 0.34);
}

html[data-theme='dark'] .content_main.ratings-container .rating-action-menu-panel {
  border-color: rgba(148, 163, 184, 0.28);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(11, 18, 32, 0.97));
}

html[data-theme='dark'] .content_main.ratings-container .rating-action-menu-item:hover {
  background: rgba(226, 232, 240, 0.1);
}

html[data-theme='dark'] .content_main.ratings-container .rating-action-menu-item.is-danger {
  color: #fca5a5;
}

html[data-theme='dark'] .content_main.ratings-container .rating-action-menu-item.is-danger:hover {
  background: rgba(239, 68, 68, 0.16);
}

li a {
  height: 30px;
  padding: 0 0.65rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background: var(--brand-gradient);
  color: #fff;
  font-size: 0.82rem;
  line-height: 30px;
  text-decoration: none;
}

li a:hover {
  background: var(--brand-hover-fill);
  border-color: rgb(var(--brand-2-rgb) / 0.28);
}

li button {

html[data-theme='dark'] li:hover {
  background: rgb(var(--brand-2-rgb) / 0.16);
  border-color: rgb(var(--brand-2-rgb) / 0.32);
}
  height: 30px;
  min-width: 30px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.08);
  color: rgba(239, 68, 68, 0.95);
  font-size: 1.1rem;
  margin: 0;
}

li button:hover {
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.55);
}

.signup-container {
  max-width: 440px;
  margin: 1.25rem auto;
  padding: 1.1rem;
  border-radius: var(--radius-lg);
  border: 1px solid #0f172a;
  background: #bcbaba;
  box-shadow: var(--shadow-md);
}

.signup-container h2 {
  margin: 0 0 1rem 0;
}

.signup-form {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

[data-auth-panel][hidden] {
  display: none !important;
}

[data-auth-toggle-root][data-auth-mode='login'] [data-auth-panel='signup'],
[data-auth-toggle-root][data-auth-mode='signup'] [data-auth-panel='login'] {
  display: none !important;
}

[data-auth-toggle-root][data-auth-mode='login'] [data-auth-panel='login'],
[data-auth-toggle-root][data-auth-mode='signup'] [data-auth-panel='signup'] {
  display: flex;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.form-group label {
  color: var(--ink);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 800;
}

.form-help {
  margin: 0;
  color: var(--subtle);
  font-size: 0.78rem;
  line-height: 1.4;
}

.form-help-focus-only {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateY(-2px);
  transition:
    max-height 140ms ease,
    opacity 140ms ease,
    transform 140ms ease;
}

.form-group:focus-within .form-help-focus-only {
  max-height: 4rem;
  opacity: 1;
  transform: translateY(0);
}

.form-footer {
  margin: 0.4rem 0 0 0;
  text-align: center;
  color: var(--subtle);
  font-size: 0.96rem;
}

.form-footer a {
  color: var(--info);
  text-decoration: none;
  font-weight: 700;
}

.form-footer a:hover {
  text-decoration: underline;
}

.content_main.auth-page-main {
  align-self: start;
  min-height: calc(100svh - var(--home-sticky-top) - 24px);
}

.auth-page-shell {
  width: min(100%, 560px);
  margin: 0 auto;
}

body.is-auth-page .content_main.auth-page-main {
  width: 100%;
}

body.is-auth-page .auth-page-shell {
  padding-top: 0.4rem;
}

.auth-page-head {
  margin-bottom: 1rem;
}

.auth-page-card {
  padding: 1.15rem;
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-md);
}

html[data-theme='dark'] .auth-page-card {
  background:
    linear-gradient(rgba(15, 23, 42, 0.92), rgba(15, 23, 42, 0.92)) padding-box,
    var(--brand-gradient) border-box;
}

.auth-page-form {
  width: min(100%, 360px);
  margin: 0 auto;
}

.auth-page-submit {
  width: 100%;
  justify-content: center;
  height: 40px;
  border-radius: 12px;
  border: 1px solid #0f172a;
  background: var(--btn-dark);
  color: #f5f5f5 !important;
  font-weight: 900;
  letter-spacing: 0.04em;
  box-shadow: var(--shadow-sm);
}

.auth-page-footer {
  margin-top: 0.2rem;
}

@media (max-width: 980px) {
  .auth-page-shell {
    width: 100%;
  }

  .auth-page-card {
    padding: 1rem;
  }
}

.avatar,
.avatar-initial {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
}

.avatar {
  object-fit: cover;
}

.avatar-initial {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 0.85rem;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.06);
}

.content_main.ratings-container .avatar-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  width: 52px;
  height: 52px;
  padding: 1px;
  border-radius: 999px;
  border: 2px solid transparent;
  background: var(--brand-gradient);
  box-shadow: var(--shadow-sm);
}

.content_main.ratings-container .avatar-wrap .avatar,
.content_main.ratings-container .avatar-wrap .avatar-initial {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  border: 0;
  box-shadow: none;
}

.content_main.ratings-container .avatar-wrap .avatar {
  object-fit: cover;
}

.content_main.ratings-container .avatar-wrap {
  text-decoration: none;
}

.content_main.ratings-container .avatar-wrap:hover {
  text-decoration: none;
}

.content_main.ratings-container .avatar-wrap .avatar-initial {
  text-decoration: none;
  line-height: 1;
  background: rgba(255, 255, 255, 0.92);
  color: #0f172a;
  -webkit-text-fill-color: currentColor;
}

html[data-theme='dark'] .content_main.ratings-container .avatar-wrap .avatar-initial {
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

.content_main.ratings-container .avatar-wrap .avatar-initial {
  transform: translateY(0);
  font-size: 1.3rem;
}

.link-plain {
  color: var(--subtle) !important;
  text-decoration: none;
}

.link-plain:hover {
  text-decoration: underline;
}

.profile-card {
  max-width: 420px;
  padding: 1rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.05);
  box-shadow: var(--shadow-md);
}

.avatar-large {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.8rem;
}

.avatar-large img,
.avatar-large .avatar-placeholder {
  width: 104px;
  height: 104px;
  border-radius: 999px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
  object-fit: cover;
}

.avatar-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 2.2rem;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.06);
}

.profile-line {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.25rem;
  margin: 0.5rem 0;
}

.profile-label {
  color: var(--subtle);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 800;
}

.profile-value {
  font-weight: 700;
}

.profile-value-about {
  font-size: smaller;
  font-weight: 700;
}

.profile-actions {
  display: flex;
  gap: 0.6rem;
  margin-bottom: 0.7rem;
}

.rating-alt {
  max-width: 980px;
  margin: 0 auto;
  padding: 1.25rem;
}

.content_main .rating-alt {
  max-width: none;
  margin: 0;
  padding: 0;
}

.rating-summary {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 1rem;
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.12);
}

.rating-summary-top {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  position: relative;
}

.rating-summary-top .summary-main {
  width: 100%;
  min-width: 0;
  display: flex;
  justify-content: center;
}

.rating-summary-top.has-share-action .summary-main {
  padding-right: 0;
}

.rating-summary-top.has-action-pair .summary-main {
  padding-right: 0;
}

.rating-summary-top.has-rating-like .summary-main {
  padding-left: 0;
}

.rating-summary-top .rating-card-actions {
  position: absolute;
  top: 0;
  right: 0;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
}

.rating-summary-top .rating-like-row {
  margin-top: 0;
  margin-left: 0;
}

.rating-summary-top .rating-card-actions .rating-like-row {
  position: static;
}

.rating-share-btn[data-copy-icon-button] {
  width: 36px;
  min-width: 36px;
  height: 36px;
  border-radius: 12px;
}

@media (max-width: 640px) {
  .rating-summary-top.has-share-action .summary-main {
    padding-right: 52px;
  }

  .rating-summary-top.has-action-pair .summary-main {
    padding-right: 94px;
  }

  .rating-summary-top.has-rating-like .summary-main {
    padding-left: 52px;
  }
}

.page-head.rating-detail-head {
  position: relative;
  justify-content: center;
  min-height: 38px;
}

.page-head.rating-detail-head .title_search {
  width: 100%;
  text-align: center;
}

.page-head.rating-detail-head .rating-detail-add-action {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

.page-head.rating-detail-head .page-head-right {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  gap: 8px;
  flex-wrap: nowrap;
}

.page-head.rating-detail-head .rating-percent {
  position: static;
  transform: none;
}

.rating-summary-main {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.rating-summary-content,
.rating-summary-header-block {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.rating-summary-header-block {
  position: relative;
}

.rating-summary-owner-row {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.45rem;
  max-width: 100%;
  margin: 0 0 0.18rem 0;
  padding: 0.3rem 0.65rem 0.3rem 0.32rem;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.rating-summary-header-block-owner-corner {
  padding-top: 2.15rem;
}

.rating-summary-header-block-owner-corner .rating-summary-owner-row {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
}

.rating-summary-top.has-rating-like .rating-summary-header-block-owner-corner .rating-summary-owner-row {
  left: 0;
}

.rating-summary-owner-row .avatar-wrap {
  flex-shrink: 0;
}

.rating-summary-owner-row .rating-owner {
  color: transparent;
  font-weight: 800;
  letter-spacing: 0.01em;
  background-image: var(--brand-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

html[data-theme='dark'] .rating-summary-owner-row {
  background: rgba(15, 23, 42, 0.82);
  border-color: rgba(148, 163, 184, 0.22);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.32);
}

@media (max-width: 640px) {
  .rating-summary-owner-row {
    padding: 0.22rem 0.5rem 0.22rem 0.24rem;
    gap: 0.32rem;
    font-size: 0.82rem;
  }

  .rating-summary-owner-row .avatar,
  .rating-summary-owner-row .avatar-initial {
    width: 20px;
    height: 20px;
    font-size: 0.65rem;
  }

  .rating-summary-owner-row .rating-owner {
    font-size: 0.78rem;
  }

  .rating-summary-header-block-owner-corner {
    padding-top: 1.75rem;
  }
}

.rating-summary-kicker {
  text-align: center;
  font-size: 1.02rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--subtle);
  margin-bottom: 2px;
}

.rating-summary-title {
  margin: 0;
  text-align: center;
}

.rating-summary-count {
  margin: 6px 0 0 0;
  text-align: center;
  color: var(--subtle);
}

.rating-summary-overall {
  justify-content: center;
  margin: 0 0 8px 0;
}

@media (max-width: 900px) {
  .rating-summary-top {
    align-items: center;
    gap: 0.65rem;
  }

  .rating-summary-top.has-share-action .summary-main,
  .rating-summary-top.has-action-pair .summary-main,
  .rating-summary-top.has-rating-like .summary-main {
    padding-left: 0;
    padding-right: 0;
  }

  .rating-summary-top .summary-main {
    display: flex;
    justify-content: center;
  }

  .rating-summary-content,
  .rating-summary-header-block {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .rating-summary-header-block-owner-corner .rating-summary-owner-row,
  .rating-summary-top.has-rating-like .rating-summary-header-block-owner-corner .rating-summary-owner-row {
    left: 0;
  }

  .summary-pills-compact {
    justify-content: center;
    width: 100%;
  }
}

@media (max-width: 640px) {
  .page-head.rating-detail-head {
    justify-content: center;
    gap: 0.55rem;
  }

  .page-head.rating-detail-head .rating-percent {
    display: none;
  }

  .page-head.rating-detail-head .page-head-right {
    display: none;
  }

  .page-head.rating-detail-head .rating-detail-add-action {
    position: static;
    transform: none;
  }

  .rating-hero-percent {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 4;
    display: inline-flex;
    min-width: 48px;
    height: 40px;
    align-items: center;
    justify-content: center;
    padding: 0 0.62rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(15, 23, 42, 0.72);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
    font-size: 1rem;
    font-weight: 900;
    line-height: 1;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
    pointer-events: none;
  }

  .rating-video-card {
    padding: 0.75rem;
    margin-bottom: 0.75rem;
    border-radius: 22px;
  }

  .rating-detail-card {
    padding: 0.75rem;
    border-radius: 22px;
  }

  .rating-summary {
    padding: 0.85rem;
    border-radius: 20px;
    gap: 0.75rem;
  }

  .rating-summary-top {
    align-items: center;
    gap: 0.65rem;
  }

  .rating-summary-top.has-share-action .summary-main,
  .rating-summary-top.has-action-pair .summary-main,
  .rating-summary-top.has-rating-like .summary-main {
    padding-left: 0;
    padding-right: 0;
  }

  .rating-summary-top .summary-main {
    display: flex;
    justify-content: center;
  }

  .rating-summary-content,
  .rating-summary-header-block {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .rating-summary-header-block-owner-corner {
    padding-top: 2.85rem;
  }

  .rating-summary-header-block-owner-corner .rating-summary-owner-row,
  .rating-summary-top.has-rating-like .rating-summary-header-block-owner-corner .rating-summary-owner-row {
    left: 0;
  }

  .rating-summary-top .rating-card-actions {
    top: 0;
    right: 0;
  }

  .rating-summary-kicker {
    font-size: 0.82rem;
    margin-bottom: 0.15rem;
  }

  .rating-summary .title {
    font-size: 1.45rem;
    line-height: 1.12;
  }

  .summary-pills {
    gap: 0.45rem;
  }

  .summary-pills-compact {
    margin-top: 0.65rem;
    justify-content: center;
    width: 100%;
  }

  .summary-pills-separator {
    display: none;
  }

  .rating-summary .pill {
    min-height: 36px;
    padding: 0.4rem 0.62rem;
    font-size: 0.86rem;
  }

  .rating-extras {
    align-items: stretch;
  }

  .rating-extra-pill {
    width: 100%;
    max-width: 100%;
    border-radius: 22px;
    padding: 0.7rem 0.8rem;
    gap: 0.28rem;
    flex-direction: column;
  }

  .rating-extra-pill b {
    max-width: 100%;
  }

  .rating-extra-pill .pill-link,
  .rating-extra-pill .pill-info-text {
    font-size: 0.82rem;
    line-height: 1.35;
  }
}

@media (max-width: 700px) and (hover: none) and (pointer: coarse) {
  .rating-video-card.has-mobile-youtube-fallback .rating-video-frame-wrap {
    display: none;
  }

  .rating-video-card.has-mobile-youtube-fallback .rating-video-mobile-link {
    display: flex;
    min-height: 78px;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    border-radius: 20px;
    border: 1px solid transparent;
    background:
      linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
      var(--brand-gradient) border-box;
    color: #0f172a;
    font-weight: 900;
    text-decoration: none;
    box-shadow: var(--shadow-sm);
  }

  html[data-theme='dark'] .rating-video-card.has-mobile-youtube-fallback .rating-video-mobile-link {
    background:
      linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
      var(--brand-gradient) border-box;
    color: var(--ink);
  }
}

html[data-theme='dark'] .rating-summary {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.rating-summary .title {
  margin: 0;
  font-size: 1.25rem;
}

.divider {
  color: var(--subtle);
  margin: 0 0.45rem;
}

.subject {
  color: var(--ink);
  opacity: 0.95;
}

.summary-pills {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
}

.summary-pills-compact {
  gap: 0.35rem;
  margin-top: 0.55rem;
  justify-content: center;
  width: 100%;
}

.summary-pills-compact .pill {
  padding: 0.2rem 0.48rem;
  font-size: 0.75rem;
}

.summary-pills-separator {
  color: var(--subtle);
  font-size: 0.8rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
}

.rating-extras {
  width: 100%;
  margin-top: 0.65rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.55rem;
}

.rating-extra-pill {
  max-width: min(860px, 94vw);
  justify-content: center;
  flex-wrap: wrap;
  text-align: center;
}

.rating-extra-info {
  text-align: center;
  max-width: min(720px, 92vw);
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.06);
  padding: 0.35rem 0.6rem;
  font-size: 0.85rem;
  color: var(--subtle);
}

.pill b {
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}

.pill-link {
  color: inherit;
  text-decoration: none;
  display: inline;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.pill-link:hover {
  text-decoration: underline;
}

.pill-info-text {
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
  display: inline;
}

.rating-summary .pill {
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
  color: rgba(15, 23, 42, 0.7);
}

html[data-theme='dark'] .rating-summary .pill {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--muted);
}

.rating-details {
  margin-top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.rating-comments-card {
  max-width: 980px;
  margin: 1.5rem auto 0 auto;
}

.rating-comments-card .rating-comment-form {
  margin-top: 12px;
}

.rating-comments-card .rating-comment-form textarea {
  max-width: none;
}

.rating-comments-card .rating-comment-form .modal-actions {
  width: 100%;
  margin-top: 0.55rem;
  justify-content: flex-end;
  flex-wrap: nowrap;
}

.rating-comments-card .rating-comment-form .modal-actions .btn-nav {
  margin-left: auto;
}

.rating-detail-card {
  max-width: 980px;
  margin: 0 auto;
}

.rating-video-card {
  max-width: 980px;
  margin: 0 auto 1.15rem auto;
}

.rating-video-frame-wrap {
  border-radius: 22px;
}

.rating-video-mobile-link {
  display: none;
}

.rating-video-mobile-link-icon {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
}

.rating-detail-card .rating-alt {
  max-width: none;
  margin: 0;
  padding: 0;
}

.rating-comments-card.comments-section {
  margin-top: 1.5rem;
}

.rating-comments-spacer {
  height: 1.25rem;
}

.detail-item {
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-sm);
  padding: 1rem;
}

html[data-theme='dark'] .detail-item {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
}

.detail-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.4rem;
}

.detail-right {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.detail-vote-row {
  display: flex;
  justify-content: flex-start;
}

.detail-footer {
  margin-top: 0.6rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.detail-reactions-right {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.detail-footer .emoji-picker-panel {
  top: auto;
  bottom: calc(100% + 8px);
}

.detail-footer .rating-reactions-bottom {
  margin-top: 0;
}

.detail-score {
  border-radius: 10px;
  border: 1px solid rgb(var(--brand-1-rgb) / 0.28);
  background: rgb(var(--brand-1-rgb) / 0.14);
  color: var(--ink);
  padding: 0.2rem 0.5rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

.category-vote {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.cat-vote-btn {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.7);
  color: var(--ink);
  cursor: pointer;
  font-weight: 900;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-sm);
}

html[data-theme='dark'] .cat-vote-btn {
  background: rgba(15, 23, 42, 0.55);
  border-color: rgba(226, 232, 240, 0.18);
  color: var(--ink);
}

.cat-vote-btn:hover {
  transform: translateY(-1px);
}

.cat-vote-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.cat-vote-btn.is-active {
  border: 1px solid transparent;
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
}

.cat-vote-btn.is-up.is-active {
  color: var(--brand-1);
}

.cat-vote-btn.is-down.is-active {
  color: var(--danger);
}

.cat-vote-score {
  min-width: 18px;
  text-align: center;
  font-weight: 900;
  color: var(--subtle);
  font-variant-numeric: tabular-nums;
}

.cat-vote-score.is-up {
  color: var(--brand-1);
}

.cat-vote-score.is-down {
  color: var(--danger);
}

html[data-theme='dark'] .detail-score {
  background: rgb(var(--brand-1-rgb) / 0.2);
  border-color: rgb(var(--brand-1-rgb) / 0.32);
}

.detail-item .reason {
  margin: 0;
  color: var(--ink);
  opacity: 0.92;
  white-space: pre-wrap;
}

.rating-alt .rating-reactions {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.rating-alt .rating-reactions-bottom {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.6rem;
}

.rating-reactions-live {
  flex-wrap: wrap;
}

.rating-reaction-pill {
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.7);
  color: var(--ink);
  border-radius: 999px;
  padding: 0.22rem 0.5rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

html[data-theme='dark'] .rating-reaction-pill {
  background: rgba(15, 23, 42, 0.55);
  border-color: rgba(226, 232, 240, 0.18);
}

.rating-reaction-pill:hover {
  transform: translateY(-1px);
}

.rating-reaction-pill:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.rating-reaction-pill.is-active {
  border: 1px solid transparent;
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
}

.rating-reaction-pill .reaction-count {
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  color: var(--subtle);
}

.emoji-picker {
  position: relative;
}

.emoji-picker>summary {
  list-style: none;
}

.emoji-picker>summary::-webkit-details-marker {
  display: none;
}

.emoji-picker-trigger {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.7);
  color: var(--ink);
  cursor: pointer;
  font-weight: 900;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-sm);
  user-select: none;
}

html[data-theme='dark'] .emoji-picker-trigger {
  background: rgba(15, 23, 42, 0.55);
  border-color: rgba(226, 232, 240, 0.18);
}

.emoji-picker-trigger.is-disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.rating-emoji-field label {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.rating-emoji-required {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.14rem 0.52rem;
  border-radius: 999px;
  border: 1px solid rgba(99, 102, 241, 0.24);
  background: rgba(99, 102, 241, 0.12);
  color: rgba(79, 70, 229, 0.95);
  font-size: 0.63rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.rating-emoji-helper {
  margin: -0.08rem 0 0.18rem;
  color: var(--subtle);
  font-size: 0.84rem;
  line-height: 1.35;
}

.rating-emoji-picker {
  width: 100%;
}

.rating-emoji-picker > summary {
  display: flex;
}

.rating-emoji-trigger {
  width: 100%;
  height: auto;
  min-height: 84px;
  padding: 1rem 1.1rem;
  align-items: center;
  border-radius: 22px;
  justify-content: flex-start;
  gap: 0.95rem;
  border: 1px dashed rgba(99, 102, 241, 0.28);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(246, 248, 252, 0.92));
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.rating-emoji-copy {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 56px;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0.08rem;
}

.rating-emoji-chip {
  flex: 0 0 auto;
  width: 56px;
  height: 56px;
  border-radius: 18px;
  border: 1px dashed rgba(99, 102, 241, 0.22);
  background: rgba(99, 102, 241, 0.08);
  color: rgba(15, 23, 42, 0.5);
  font-size: 1.8rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.rating-emoji-title {
  color: rgba(15, 23, 42, 0.9);
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.01em;
  line-height: 1;
}

.rating-emoji-note {
  color: var(--subtle);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.rating-emoji-picker .emoji-picker-panel {
  left: 0;
  right: auto;
  width: min(320px, 100%);
}

.rating-emoji-field.is-selected .rating-emoji-trigger {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.95)) padding-box,
    var(--brand-gradient) border-box;
}

.rating-emoji-field.is-selected .rating-emoji-chip {
  border-style: solid;
  border-color: rgba(99, 102, 241, 0.22);
  background: rgba(99, 102, 241, 0.1);
  color: var(--ink);
}

html[data-theme='dark'] .rating-emoji-required {
  border-color: rgba(129, 140, 248, 0.28);
  background: rgba(99, 102, 241, 0.18);
  color: #c7d2fe;
}

html[data-theme='dark'] .rating-emoji-trigger {
  border-color: rgba(129, 140, 248, 0.24);
  background: linear-gradient(180deg, rgba(30, 41, 59, 0.78), rgba(17, 24, 39, 0.82));
  box-shadow: 0 16px 30px rgba(2, 6, 23, 0.3);
}

html[data-theme='dark'] .rating-emoji-chip {
  border-color: rgba(129, 140, 248, 0.22);
  background: rgba(15, 23, 42, 0.7);
  color: rgba(226, 232, 240, 0.56);
}

html[data-theme='dark'] .rating-emoji-title {
  color: var(--ink);
}

html[data-theme='dark'] .rating-emoji-field.is-selected .rating-emoji-trigger {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .rating-emoji-field.is-selected .rating-emoji-chip {
  border-color: rgba(129, 140, 248, 0.24);
  background: rgba(99, 102, 241, 0.16);
  color: var(--ink);
}

.emoji-picker-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 50;
  min-width: 220px;
  max-width: 280px;
  max-height: 240px;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow-md);
  display: grid;
  grid-template-columns: repeat(7, 28px);
  gap: 6px;
  align-content: start;
}

.emoji-option {
  border: 1px solid transparent;
  background: transparent;
  border-radius: 10px;
  cursor: pointer;
  width: 28px;
  height: 28px;
  font-size: 1.1rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.emoji-option:hover {
  border-color: var(--border);
  background: rgba(56, 189, 248, 0.12);
}

.rating-actions {
  margin-top: 1rem;
}

.rating-form {
  max-width: 760px;
  padding: 1.1rem 1.1rem 1.25rem;
  margin: 0.25rem auto 0;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.65);
  box-shadow: var(--shadow-md);
}

.rating-form .form-field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-bottom: 0.95rem;
}

.rating-form label {
  color: rgba(15, 23, 42, 0.7);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 900;
}

.rating-form label.btn-nav {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: none;
  color: inherit;
}

.rating-form select,
.rating-form input[type='text'],
.rating-form input[type='url'],
.rating-form textarea {
  width: 100%;
  max-width: none;
}

.rating-form input[type='file'] {
  width: auto;
  max-width: 100%;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.rating-form .form-field.is-file {
  align-items: center;
  text-align: center;
}

.rating-form .form-field .auth-hint {
  margin: 0;
}

.rating-form select,
.rating-form input[type='text'],
.rating-form input[type='url'],
.rating-form textarea {
  color: rgba(15, 23, 42, 0.92) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(15, 23, 42, 0.18) !important;
  border-radius: 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.rating-form select {
  text-align: center;
  text-align-last: center;
}

.rating-form select:hover,
.rating-form input[type='text']:hover,
.rating-form input[type='url']:hover,
.rating-form textarea:hover {
  border-color: rgba(15, 23, 42, 0.28) !important;
}

.rating-form select:focus,
.rating-form input[type='text']:focus,
.rating-form input[type='url']:focus,
.rating-form textarea:focus {
  outline: none;
  border-color: rgba(59, 130, 246, 0.75) !important;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18);
}

.rating-form textarea::placeholder,
.rating-form input[type='text']::placeholder,
.rating-form input[type='url']::placeholder {
  color: rgba(15, 23, 42, 0.45);
}

html[data-theme='dark'] .rating-form {
  background: var(--surface);
  border-color: var(--border);
}

html[data-theme='dark'] .rating-form label {
  color: var(--subtle);
}

html[data-theme='dark'] .rating-form .rating-title {
  color: var(--ink);
}

html[data-theme='dark'] .rating-form select,
html[data-theme='dark'] .rating-form input[type='text'],
html[data-theme='dark'] .rating-form input[type='url'],
html[data-theme='dark'] .rating-form textarea {
  color: var(--ink) !important;
  background: transparent !important;
  border-color: var(--border) !important;
  box-shadow: none;
}

html[data-theme='dark'] .rating-form select {
  background: color-mix(in srgb, var(--surface) 88%, transparent) !important;
  color-scheme: dark;
}

html[data-theme='dark'] .rating-form select option {
  background: var(--surface);
  color: var(--ink);
}

html[data-theme='dark'] .rating-form textarea::placeholder,
html[data-theme='dark'] .rating-form input[type='text']::placeholder,
html[data-theme='dark'] .rating-form input[type='url']::placeholder {
  color: var(--subtle);
}

.rating-form input[type='text']:-webkit-autofill,
.rating-form input[type='text']:-webkit-autofill:hover,
.rating-form input[type='text']:-webkit-autofill:focus,
.rating-form input[type='text']:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px rgba(255, 255, 255, 0.08) inset !important;
  -webkit-text-fill-color: rgba(15, 23, 42, 0.92) !important;
}

html[data-theme='dark'] .rating-form input[type='text']:-webkit-autofill,
html[data-theme='dark'] .rating-form input[type='text']:-webkit-autofill:hover,
html[data-theme='dark'] .rating-form input[type='text']:-webkit-autofill:focus,
html[data-theme='dark'] .rating-form input[type='text']:-webkit-autofill:active,
html[data-theme='dark'] .rating-form input[type='url']:-webkit-autofill,
html[data-theme='dark'] .rating-form input[type='url']:-webkit-autofill:hover,
html[data-theme='dark'] .rating-form input[type='url']:-webkit-autofill:focus,
html[data-theme='dark'] .rating-form input[type='url']:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px transparent inset !important;
  -webkit-text-fill-color: var(--ink) !important;
}

.rating-form .rating-block {
  padding-top: 0.9rem;
  margin-top: 0.9rem;
  border-top: 1px solid rgba(15, 23, 42, 0.12);
}

html[data-theme='dark'] .rating-form .rating-block {
  border-top-color: rgba(226, 232, 240, 0.18);
}

.rating-form .rating-block:first-of-type {
  padding-top: 0;
  margin-top: 0.2rem;
  border-top: none;
}

.rating-form .rating-title {
  margin: 0;
  text-align: center;
  color: rgba(15, 23, 42, 0.92);
  font-weight: 900;
  font-size: 1rem;
  letter-spacing: 0.02em;
}

.rating-form .rating-buttons {
  justify-content: center;
}

.rating-form .rating-reason-label {
  display: block;
  margin-top: 0.6rem;
}

.rating-form textarea {
  margin-top: 0.35rem;
  min-height: 96px;
}

.rating-form .form-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  margin-top: 1rem;
}

@media (max-width: 980px) {
  .rating-form {
    padding: 1rem;
  }

  .rating-form .rating-buttons {
    gap: 0.35rem;
  }

  .rating-form .rating-buttons label {
    min-width: 38px;
    height: 34px;
    border-radius: 10px;
  }
}

.rating-form .btn-submit,
.rating-form .btn-cancel {
  margin-top: 0;
}

.auth-hint {
  color: var(--subtle);
  font-style: italic;
}

.auth-hint-add-rating {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.65rem;
  margin: 0 0 0.85rem 0;
  font-style: normal;
  color: var(--subtle);
  font-size: 0.92rem;
}

.auth-hint-add-rating .auth-hint-or {
  font-weight: 700;
  text-transform: lowercase;
}

.auth-hint-add-rating .btn-nav {
  text-decoration: none;
}

@media (max-width: 980px) {
  body.auth-panel-modal-open {
    overflow: hidden;
  }

  .container div.header {
    margin: 0 4px;
  }

  .container {
    gap: 6px;
    padding: 8px;
    grid-template-areas:
      'header'
      'menu'
      'content';
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 1fr;
    align-content: start;
  }

  .menu {
    position: static;
    top: auto;
    max-height: none;
    overflow: visible;
    border-left: none;
    border-bottom: 1px solid var(--border);
    align-items: stretch;
    width: 100%;
  }

  .menu-wrap {
    display: none;
  }

  body.auth-panel-modal-open .menu-wrap {
    display: block;
  }

  .header navbar>.nav-links,
  .header navbar>.nav-actions {
    display: none;
  }

  .content {
    grid-template-areas:
      'content_main'
      'content_bottom'
      'content_left';
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 0;
  }

  .content_left {
    display: block;
    height: 0;
    min-height: 0;
    overflow: hidden;
    padding: 0;
    border: none;
  }

  .content_left>.signup-container,
  .content_left>.activity-card,
  .content_left>.bulletin-card {
    display: none;
  }
}

.menu-wrap>.nav-card {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 1.15rem;
  border-radius: var(--radius-lg);
  border: 2px solid transparent;
  text-align: center;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.16);
}

html[data-theme='dark'] .menu-wrap>.nav-card {
  background:
    linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.menu-wrap>.nav-card .nav-card-body {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  align-items: center;
}

.menu-wrap>.nav-card .nav-card-search,
.menu-wrap>.nav-card .nav-search-input {
  width: 100%;
  max-width: none;
}

.menu-wrap>.nav-card .nav-card-links {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  width: 100%;
}

.menu-wrap>.nav-card .nav-card-links .btn-nav {
  width: 100%;
}

.mobile-tab-bar {
  display: none;
}

.mobile-fab-add,
.mobile-back-top {
  display: none;
}

body.has-mobile-tabbar .mobile-fab-add,
body.is-logged-out.mobile-header-scrolled .mobile-back-top {
  position: fixed;
  right: max(24px, calc(12px + env(safe-area-inset-right, 0px)));
  bottom: max(24px, env(safe-area-inset-bottom, 0px));
  z-index: 31;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.35);
  text-decoration: none;
  transition:
    transform 140ms ease,
    box-shadow 140ms ease,
    filter 140ms ease;
}

body.has-mobile-tabbar .mobile-fab-add:hover,
body.is-logged-out .mobile-back-top:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.42);
  text-decoration: none;
  color: #0f172a;
}

body.has-mobile-tabbar .mobile-fab-add:focus-visible,
body.is-logged-out .mobile-back-top:focus-visible {
  outline: 2px solid rgba(99, 102, 241, 0.85);
  outline-offset: 3px;
}

body.has-mobile-tabbar .mobile-fab-add:active,
body.is-logged-out .mobile-back-top:active {
  transform: translateY(0);
}

body.has-mobile-tabbar .mobile-fab-add.is-active {
  filter: brightness(0.92);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.28);
}

.mobile-fab-add-icon,
.mobile-back-top-icon {
  width: 26px;
  height: 26px;
}

html[data-theme='dark'] body.has-mobile-tabbar .mobile-fab-add,
html[data-theme='dark'] body.is-logged-out .mobile-back-top {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
  box-shadow: 0 14px 32px rgba(2, 6, 23, 0.65);
}

html[data-theme='dark'] body.has-mobile-tabbar .mobile-fab-add:hover,
html[data-theme='dark'] body.is-logged-out .mobile-back-top:hover {
  color: var(--ink);
  box-shadow: 0 18px 40px rgba(2, 6, 23, 0.72);
}

body.is-add-page.has-mobile-tabbar .mobile-fab-add {
  display: none;
}

@media (min-width: 981px) {
  body.has-mobile-tabbar:not(.is-add-page) .content {
    padding-bottom: 80px;
  }
}

.rating-form-edit-lock input#rating_name_display {
  cursor: not-allowed;
  opacity: 0.92;
}

.rating-form-edit-lock .modal,
.rating-form-edit-lock .modal-toggle {
  display: none !important;
}

.mobile-tab-link {
  text-decoration: none;
}

[data-nav-href]:not(a):not(button) {
  cursor: pointer;
}

.mobile-tab-icon {
  width: 18px;
  height: 18px;
}

.mobile-tab-badge {
  position: absolute;
  top: 0.45rem;
  right: calc(50% - 1.15rem);
  min-width: 1.1rem;
  height: 1.1rem;
  padding: 0 0.24rem;
  border-radius: 999px;
  background: #0f172a;
  color: #f8fafc;
  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1.1rem;
  text-align: center;
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.2);
}

@media (max-width: 980px) {
  body.has-mobile-tabbar .container {
    min-height: auto;
  }

  body.has-mobile-tabbar .content {
    padding-bottom: 92px;
  }

  body.has-mobile-tabbar:not(.is-add-page) .content {
    padding-bottom: calc(92px + 72px);
  }

  body.has-mobile-back-top .content {
    padding-bottom: 96px;
  }

  .mobile-tab-bar {
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: max(8px, env(safe-area-inset-bottom, 0px));
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.45rem;
    padding: 0.45rem;
    border-radius: 18px;
    border: 1px solid rgba(248, 250, 252, 0.08);
    background: rgba(0, 0, 0, 0.94);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.3);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  body.has-mobile-tabbar.mobile-header-scrolled .mobile-tab-bar {
    border-color: rgba(248, 250, 252, 0.16);
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.62), rgba(15, 23, 42, 0.5));
    box-shadow:
      0 14px 34px rgba(0, 0, 0, 0.26),
      inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(22px) saturate(165%);
    -webkit-backdrop-filter: blur(22px) saturate(165%);
  }

  body.has-mobile-tabbar .mobile-fab-add {
    right: max(16px, calc(12px + env(safe-area-inset-right, 0px)));
    bottom: calc(max(8px, env(safe-area-inset-bottom, 0px)) + 86px);
  }

  body.is-logged-out .mobile-back-top {
    right: max(16px, calc(12px + env(safe-area-inset-right, 0px)));
    bottom: max(18px, env(safe-area-inset-bottom, 0px));
  }

  .mobile-tab-link {
    position: relative;
    min-height: 60px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.35rem 0.25rem;
    border-radius: 14px;
    border: 1px solid transparent;
    background: transparent;
    color: rgba(248, 250, 252, 0.74);
    transition:
      background 140ms ease,
      color 140ms ease,
      transform 140ms ease;
  }

  navbar .nav-mobile-search:hover,
  navbar .nav-mobile-search:focus-visible,
  .nav-mobile-search-submit:hover,
  .nav-mobile-search-submit:focus-visible {
    background: var(--btn-dark);
    border-color: #0f172a;
    transform: none;
    text-decoration: none;
  }

  .auth-panel-backdrop {
    position: fixed;
    inset: 0;
    z-index: 2001;
    border: 0;
    padding: 0;
    background: rgba(15, 23, 42, 0.45);
    opacity: 0;
    pointer-events: none;
    transition: opacity 180ms ease;
  }

  body.auth-panel-modal-open .auth-panel-backdrop {
    display: block;
    opacity: 1;
    pointer-events: auto;
  }

  .menu .signup-container#auth-panel {
    position: relative;
  }

  body.auth-panel-modal-open .menu .signup-container#auth-panel {
    position: fixed;
    top: 50%;
    left: 50%;
    z-index: 2002;
    width: min(420px, calc(100vw - 24px));
    max-width: calc(100vw - 24px);
    max-height: min(92vh, 720px);
    margin: 0;
    overflow: auto;
    transform: translate(-50%, -50%);
    overscroll-behavior: contain;
    box-shadow: var(--shadow-md);
  }

  .auth-panel-close {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 1;
    width: 34px;
    height: 34px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.2);
    background: rgba(15, 23, 42, 0.05);
    color: rgba(15, 23, 42, 0.82);
    font-size: 1.35rem;
    line-height: 1;
  }

  body.auth-panel-modal-open .auth-panel-close {
    display: inline-flex;
  }

  .menu .signup-container#auth-panel .title_login {
    padding-right: 2.5rem;
  }

  html[data-theme='dark'] .auth-panel-close {
    border-color: rgba(226, 232, 240, 0.18);
    background: rgba(226, 232, 240, 0.08);
    color: var(--ink);
  }

  .mobile-tab-link:hover {
    color: #f8fafc;
    background: color-mix(in srgb, var(--brand-1) 14%, rgba(15, 23, 42, 0.86));
    border-color: color-mix(in srgb, var(--brand-2) 24%, rgba(226, 232, 240, 0.12));
    text-decoration: none;
  }

  .mobile-tab-link.is-active {
    color: #f8fafc;
    border-color: transparent;
    background:
      linear-gradient(rgba(15, 23, 42, 0.92), rgba(15, 23, 42, 0.92)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: 0 12px 24px rgba(2, 6, 23, 0.42);
  }

  .mobile-tab-label {
    font-size: 0.72rem;
    line-height: 1;
  }

  .menu .signup-container,
  .menu .activity-card,
  .menu .bulletin-card,
  .menu-wrap>.bulletin-card {
    max-width: none;
    width: 100%;
  }

  html[data-theme='dark'] body.has-mobile-tabbar.mobile-header-scrolled .mobile-tab-bar {
    border-color: rgba(226, 232, 240, 0.12);
    background: linear-gradient(180deg, rgba(2, 6, 23, 0.72), rgba(2, 6, 23, 0.58));
    box-shadow:
      0 18px 40px rgba(0, 0, 0, 0.54),
      inset 0 1px 0 rgba(255, 255, 255, 0.04);
  }

  html[data-theme='dark'] .container>.nav-mobile-search-panel {
    border-color: rgba(226, 232, 240, 0.12);
    background: rgba(15, 23, 42, 0.96);
    box-shadow: 0 18px 36px rgba(2, 6, 23, 0.52);
  }

  html[data-theme='dark'] .mobile-tab-link {
    color: rgba(226, 232, 240, 0.74);
  }

  html[data-theme='dark'] .mobile-tab-link:hover {
    color: #f8fafc;
    background: color-mix(in srgb, var(--brand-1) 14%, rgba(15, 23, 42, 0.86));
    border-color: color-mix(in srgb, var(--brand-2) 24%, rgba(226, 232, 240, 0.12));
  }

  html[data-theme='dark'] .mobile-tab-link.is-active {
    color: #f8fafc;
    border-color: transparent;
    background:
      linear-gradient(rgba(15, 23, 42, 0.92), rgba(15, 23, 42, 0.92)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: 0 12px 24px rgba(2, 6, 23, 0.42);
  }

  html[data-theme='dark'] .mobile-tab-badge {
    background: #f8fafc;
    color: #0f172a;
    box-shadow: 0 4px 10px rgba(2, 6, 23, 0.42);
  }

  a,
  button,
  label,
  input[type='button'],
  input[type='submit'],
  input[type='reset'] {
    -webkit-tap-highlight-color: transparent;
  }

  [data-nav-href]:not(a):not(button) {
    -webkit-tap-highlight-color: transparent;
  }

  li[data-nav-href]:hover,
  li[data-nav-href]:active {
    background: var(--surface);
    border-color: var(--border);
    box-shadow: var(--shadow-sm);
    transform: none;
  }

  .content_main.ratings-container .rating-list>li:hover,
  .content_main.ratings-container .rating-list>li:active {
    background:
      linear-gradient(#ffffff, #ffffff) padding-box,
      var(--brand-gradient) border-box;
    border-color: transparent;
    box-shadow: none;
    transform: none;
  }

  html[data-theme='dark'] .content_main.ratings-container .rating-list>li:hover,
  html[data-theme='dark'] .content_main.ratings-container .rating-list>li:active {
    background:
      linear-gradient(var(--surface), var(--surface)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: none;
  }

.content_main.ratings-container .rating-list>li.is-owner:hover,
.content_main.ratings-container .rating-list>li.is-owner:active {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgb(var(--brand-1-rgb) / 0.16) 52%, rgb(var(--brand-2-rgb) / 0.2) 100%) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 12px 28px rgb(var(--brand-2-rgb) / 0.14);
  transform: none;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner:hover,
html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner:active {
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.94) 0%, rgb(var(--brand-1-rgb) / 0.28) 52%, rgb(var(--brand-2-rgb) / 0.36) 100%) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.55);
}

  .content_main.gradient-container .playlist-card-list li:hover,
  .content_main.gradient-container .playlist-card-list li:active,
  .content_main .playlist-card-list li:hover,
  .content_main .playlist-card-list li:active {
    background:
      linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
      var(--brand-gradient) border-box;
    border-color: transparent;
    box-shadow: none;
    transform: none;
  }

  html[data-theme='dark'] .content_main .playlist-card-list li:hover,
  html[data-theme='dark'] .content_main .playlist-card-list li:active {
    background:
      linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: none;
  }

  .btn-nav:hover,
  .btn-nav:active {
    background: var(--btn-dark);
    border-color: #0f172a;
    transform: none;
    text-decoration: none;
  }

  .btn-nav.pill-action:hover,
  .btn-nav.pill-action:active {
    background:
      linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
      var(--brand-gradient) border-box;
    border-color: transparent;
    box-shadow: var(--shadow-sm);
  }

  .btn-nav.btn-danger:hover,
  .btn-nav.btn-danger:active {
    background: color-mix(in srgb, var(--danger) 10%, transparent);
    border-color: color-mix(in srgb, var(--danger) 35%, transparent);
    color: var(--danger) !important;
  }

  html[data-theme='dark'] .page-head .btn-nav:hover,
  html[data-theme='dark'] .page-head .btn-nav:active,
  html[data-theme='dark'] .btn-nav.modal-trigger:hover,
  html[data-theme='dark'] .btn-nav.modal-trigger:active {
    background: var(--brand-gradient);
    border-color: transparent;
  }

  html[data-theme='dark'] .btn-nav.pill-action:hover,
  html[data-theme='dark'] .btn-nav.pill-action:active {
    background:
      linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
      var(--brand-gradient) border-box;
    color: var(--ink) !important;
  }

  .btn-primary:hover,
  .btn-primary:active,
  .btn-auth:hover,
  .btn-auth:active,
  .btn-submit:hover,
  .btn-submit:active,
  .btn-update:hover,
  .btn-update:active,
  .btn-cancel:hover,
  .btn-cancel:active,
  .btn-danger:hover,
  .btn-danger:active,
  .btn-done:hover,
  .btn-done:active {
    transform: none;
    text-decoration: none;
  }

  .btn-primary:hover,
  .btn-primary:active,
  .btn-auth:hover,
  .btn-auth:active,
  .btn-submit:hover,
  .btn-submit:active,
  .btn-update:hover,
  .btn-update:active {
    background: var(--btn-dark);
    border-color: #0f172a;
  }

  .btn-cancel:hover,
  .btn-cancel:active,
  .btn-danger:hover,
  .btn-danger:active {
    background: rgba(239, 68, 68, 0.08);
    border-color: rgba(239, 68, 68, 0.35);
    color: rgba(239, 68, 68, 0.95);
  }

  .btn-done:hover,
  .btn-done:active {
    background: rgba(34, 197, 94, 0.08);
    border-color: rgba(34, 197, 94, 0.35);
    color: rgba(22, 163, 74, 0.95);
  }

  .modal-secondary:hover,
  .modal-secondary:active {
    background: rgba(239, 68, 68, 0.16);
    border-color: rgba(239, 68, 68, 0.55);
    color: #b91c1c !important;
  }

  html[data-theme='dark'] .modal-secondary:hover,
  html[data-theme='dark'] .modal-secondary:active {
    background: rgba(239, 68, 68, 0.2);
    border-color: rgba(239, 68, 68, 0.65);
    color: rgba(254, 226, 226, 0.95) !important;
  }

  .heart-btn:hover,
  .heart-btn:active,
  .cat-vote-btn:hover,
  .cat-vote-btn:active,
  .rating-reaction-pill:hover,
  .rating-reaction-pill:active {
    transform: none;
  }

  .content_main .comment-edit-btn:hover,
  .content_main .comment-edit-btn:active {
    background: rgba(15, 23, 42, 0.06);
  }

  html[data-theme='dark'] .content_main .comment-edit-btn:hover,
  html[data-theme='dark'] .content_main .comment-edit-btn:active {
    background: rgba(226, 232, 240, 0.08);
  }

  .content_main .comment-remove-btn:hover,
  .content_main .comment-remove-btn:active,
  .btn-remove-avatar:hover,
  .btn-remove-avatar:active {
    background: rgba(239, 68, 68, 0.08);
    border-color: rgba(239, 68, 68, 0.35);
    color: rgba(239, 68, 68, 0.95);
  }

  .alert-delete-btn:hover,
  .alert-delete-btn:active,
  .bulletin-delete:hover,
  .bulletin-delete:active,
  .activity-delete:hover,
  .activity-delete:active {
    color: var(--subtle);
    border-color: var(--border);
  }

  .mobile-tab-link:not(.is-active):hover,
  .mobile-tab-link:not(.is-active):active {
    color: rgba(248, 250, 252, 0.74);
    background: transparent;
    border-color: transparent;
    transform: none;
    text-decoration: none;
  }

  html[data-theme='dark'] .mobile-tab-link:not(.is-active):hover,
  html[data-theme='dark'] .mobile-tab-link:not(.is-active):active {
    color: rgba(226, 232, 240, 0.74);
    background: transparent;
    border-color: transparent;
  }

  body.has-mobile-tabbar .mobile-fab-add:hover,
  body.has-mobile-tabbar .mobile-fab-add:active {
    transform: none;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.35);
    color: #0f172a;
  }

  html[data-theme='dark'] body.has-mobile-tabbar .mobile-fab-add:hover,
  html[data-theme='dark'] body.has-mobile-tabbar .mobile-fab-add:active {
    color: var(--ink);
    box-shadow: 0 14px 32px rgba(2, 6, 23, 0.65);
  }
}

.rating-buttons {
  display: flex;
  gap: 0.5rem;
  margin: 1rem 0;
  flex-wrap: wrap;
}

.rating-buttons input[type='radio'] {
  display: none;
}

.rating-buttons label {
  background: #374151;
  color: white;
  padding: 0.6rem 1rem;
  min-width: 50px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
  border-radius: 4px;
  user-select: none;
}

.rating-buttons label[for$='1']:hover,
.rating-buttons label[for$='2']:hover {
  background: #fde047;
  transform: scale(1.05);
}

.rating-buttons label[for$='3']:hover {
  background: #facc15;
  transform: scale(1.05);
}

.rating-buttons label[for$='4']:hover {
  background: #eab308;
  transform: scale(1.05);
}

.rating-buttons label[for$='5']:hover {
  background: #f59e0b;
  transform: scale(1.05);
}

.rating-buttons label[for$='6']:hover {
  background: #f9842c;
  transform: scale(1.05);
}

.rating-buttons label[for$='7']:hover {
  background: #f97316;
  transform: scale(1.05);
}

.rating-buttons label[for$='8']:hover {
  background: #ea580c;
  transform: scale(1.05);
}

.rating-buttons label[for$='9']:hover {
  background: #ef4444;
  transform: scale(1.05);
}

.rating-buttons label[for$='10']:hover {
  background: #dc2626;
  transform: scale(1.05);
}

.rating-buttons input[type='radio']:checked+label {
  font-weight: bold;
}

.rating-buttons input[type='radio']:checked+label[for$='1'],
.rating-buttons input[type='radio']:checked+label[for$='2'] {
  background: #fde047;
}

.rating-buttons input[type='radio']:checked+label[for$='3'] {
  background: #facc15;
}

.rating-buttons input[type='radio']:checked+label[for$='4'] {
  background: #eab308;
}

.rating-buttons input[type='radio']:checked+label[for$='5'] {
  background: #f59e0b;
}

.rating-buttons input[type='radio']:checked+label[for$='6'] {
  background: #f9842c;
}

.rating-buttons input[type='radio']:checked+label[for$='7'] {
  background: #f97316;
}

.rating-buttons input[type='radio']:checked+label[for$='8'] {
  background: #ea580c;
}

.rating-buttons input[type='radio']:checked+label[for$='9'] {
  background: #ef4444;
}

.rating-buttons input[type='radio']:checked+label[for$='10'] {
  background: #dc2626;
}

.content_main .profile-stack {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: center;
}

.content_main .playlist-modal-scope {
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  overflow: visible;
}

.content_main .profile-card.playlist-section {
  order: 4;
}

.content_main .profile-card.comments-section {
  order: 5;
}

.content_main .profile-flash {
  max-width: 520px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 2px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.88)) padding-box,
    var(--brand-gradient) border-box;
  color: #dc2626;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.14);
  margin: 0 auto 12px auto;
  font-size: 0.9rem;
  font-weight: 800;
}

html[data-theme='dark'] .content_main .profile-flash {
  background:
    linear-gradient(rgba(15, 23, 42, 0.82), rgba(15, 23, 42, 0.82)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.content_main .profile-flash.is-success {
  color: #16a34a;
}

.content_main .profile-card {
  max-width: 800px;
  width: 100%;
  margin: 0 auto;
  background:
    linear-gradient(rgba(255, 255, 255, 0.65), rgba(255, 255, 255, 0.65)) padding-box,
    var(--brand-gradient) border-box;
  border: 1px solid transparent;
  box-shadow: var(--shadow-md);
}

html[data-theme='dark'] .content_main .profile-card {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  border-color: transparent;
}

.content_main .comments-section .comments-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.content_main .comments-empty-state {
  display: block;
  margin: 0.72rem 0 0 0.72rem;
  text-align: left;
}

.content_main .card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.content_main .card-head .card-head-left {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.content_main .card-head .card-head-right {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
}

.content_main .profile-card > .card-head .profile-label,
.content_main .profile-media-panel > .card-head .profile-label,
.content_main .profile-top-four-card .playlist-songs-title .profile-label,
.content_main .comments-section .comments-head .profile-label {
  position: relative;
  z-index: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0.1rem 0.72rem;
  color: rgba(248, 250, 252, 0.96);
  -webkit-text-fill-color: currentColor;
  text-shadow: none;
}

.content_main .profile-card > .card-head .profile-label::before,
.content_main .profile-media-panel > .card-head .profile-label::before,
.content_main .profile-top-four-card .playlist-songs-title .profile-label::before,
.content_main .comments-section .comments-head .profile-label::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(0, 0, 0, 0.88), rgba(0, 0, 0, 0.88)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  pointer-events: none;
  box-shadow:
    0 10px 22px rgba(2, 6, 23, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.content_main .profile-card > .card-head .profile-label .profile-label-text,
.content_main .profile-media-panel > .card-head .profile-label .profile-label-text,
.content_main .profile-top-four-card .playlist-songs-title .profile-label .profile-label-text,
.content_main .comments-section .comments-head .profile-label .profile-label-text {
  position: relative;
  z-index: 1;
  color: rgba(248, 250, 252, 0.96);
  -webkit-text-fill-color: currentColor;
  text-shadow: none;
}

.content_main .comments-section .comments-head .profile-label .profile-label-text {
  color: #fff;
}

.content_main .playlist-songs-head {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 10px;
  row-gap: 16px;
  align-items: center;
}

.content_main .playlist-songs-head .playlist-songs-title {
  grid-column: 1;
  grid-row: 2;
}

.content_main .playlist-songs-card .playlist-songs-title .profile-label {
  color: #fff;
  -webkit-text-fill-color: currentColor;
}

.content_main .playlist-songs-head .playlist-songs-add {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
}

.content_main .playlist-songs-head .playlist-songs-count {
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
}

.content_main .playlist-detail-card,
.content_main .playlist-songs-card {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.content_main .playlist-back-row {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: flex-start;
}

.content_main .playlist-detail-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.content_main .playlist-detail-headline {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.content_main .playlist-detail-title {
  margin: 0;
  color: var(--ink);
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: 0.01em;
  line-height: 1.15;
}

.content_main .playlist-detail-meta {
  margin: 0;
  color: var(--subtle);
  font-weight: 800;
}

.content_main .playlist-detail-desc {
  margin: 0.75rem auto 0 auto;
  width: min(100%, 760px);
  max-width: 100%;
  text-align: center;
  text-wrap: balance;
  color: var(--muted);
  font-weight: 700;
}

.content_main .playlist-detail-actions {
  flex: 0 0 auto;
  margin-top: 2px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.content_main .playlist-detail-actions form {
  margin: 0;
}


.content_main .playlist-songs-card .playlist-song-delete-form {
  position: absolute;
  top: 10px;
  right: 12px;
  display: none;
  margin: 0;
}

.content_main .playlist-songs-card .rating-item-text strong {
  color: #fff;
}

.content_main .playlist-card-list li .playlist-owner-actions {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 4;
  display: inline-flex;
  align-items: flex-start;
}

.content_main .playlist-card-list .rating-action-menu {
  position: relative;
  display: inline-block;
  z-index: 1;
}

.content_main .playlist-card-list .rating-action-menu[open] {
  z-index: 8;
}

.content_main .playlist-card-list .rating-action-menu > summary {
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
}

.content_main .playlist-card-list .rating-action-menu > summary::-webkit-details-marker {
  display: none;
}

.content_main .playlist-card-list .rating-action-menu > summary::marker {
  content: '';
}

.content_main .playlist-card-list .rating-action-menu-toggle {
  width: 34px;
  min-width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(15, 23, 42, 0.82);
  color: rgba(248, 250, 252, 0.96);
  box-shadow: var(--shadow-md);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  user-select: none;
  line-height: 0;
}

.content_main .playlist-card-list .rating-action-menu-icon {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  gap: 3px;
}

.content_main .playlist-card-list .rating-action-menu-dot {
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: currentColor;
  flex: 0 0 auto;
}

.content_main .playlist-card-list .rating-action-menu-toggle:hover,
.content_main .playlist-card-list .rating-action-menu[open] .rating-action-menu-toggle {
  background: rgba(15, 23, 42, 0.92);
  border-color: rgba(255, 255, 255, 0.42);
}

.content_main .playlist-card-list .rating-action-menu-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  bottom: auto;
  min-width: 132px;
  padding: 0.35rem;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.16), 0 2px 8px rgba(15, 23, 42, 0.08);
  display: grid;
  gap: 4px;
  overflow: hidden;
  transform-origin: top right;
}

.content_main .playlist-card-list .rating-action-menu:not([open]) .rating-action-menu-panel {
  display: none;
}

.content_main .playlist-card-list .rating-action-menu-panel form {
  display: block;
  width: 100%;
  margin: 0;
}

.content_main .playlist-card-list .rating-action-menu-item {
  width: 100%;
  height: 36px;
  min-height: 36px;
  padding: 0.6rem 0.75rem;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 800;
  line-height: 1.1;
  text-align: left;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  box-shadow: none;
  transform: none;
  transition: background 120ms ease, color 120ms ease;
}

.content_main .playlist-card-list .rating-action-menu-item:hover,
.content_main .playlist-card-list .rating-action-menu-item:focus-visible,
.content_main .playlist-card-list .rating-action-menu-item:active {
  background: rgba(15, 23, 42, 0.08);
  text-decoration: none;
  outline: none;
  transform: none;
  box-shadow: none;
}

.content_main .playlist-card-list .rating-action-menu-item.is-danger {
  color: #b91c1c;
}

.content_main .playlist-card-list .rating-action-menu-item.is-danger:hover,
.content_main .playlist-card-list .rating-action-menu-item.is-danger:focus-visible,
.content_main .playlist-card-list .rating-action-menu-item.is-danger:active {
  background: rgba(239, 68, 68, 0.12);
}

html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-toggle {
  border-color: rgba(226, 232, 240, 0.24);
  background: rgba(226, 232, 240, 0.1);
  color: var(--ink);
}

html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-toggle:hover,
html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu[open] .rating-action-menu-toggle {
  background: rgba(226, 232, 240, 0.16);
  border-color: rgba(226, 232, 240, 0.34);
}

html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-panel {
  border-color: rgba(148, 163, 184, 0.28);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(11, 18, 32, 0.97));
}

html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-item:hover,
html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-item:focus-visible,
html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-item:active {
  background: rgba(226, 232, 240, 0.1);
}

html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-item.is-danger {
  color: #fca5a5;
}

html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-item.is-danger:hover,
html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-item.is-danger:focus-visible,
html[data-theme='dark'] .content_main .playlist-card-list .rating-action-menu-item.is-danger:active {
  background: rgba(239, 68, 68, 0.18);
}

.content_main .playlist-songs-card .rating-list li:hover .playlist-song-delete-form,
.content_main .playlist-songs-card .rating-list li:focus-within .playlist-song-delete-form {
  display: inline-flex;
}

.content_main .profile-top-four-card {
  max-width: 800px;
  margin: 0 auto;
}

.content_main.gradient-container .profile-top-four-card .profile-top-four-slot:not(.is-diamond-rank):not(.is-platinum-rank):not(.is-gold-rank):not(.is-bronze-rank) {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(244, 247, 255, 0.78));
  border-color: rgba(99, 102, 241, 0.14);
  box-shadow:
    0 12px 26px rgba(15, 23, 42, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

html[data-theme='dark'] .content_main.gradient-container .profile-top-four-card .profile-top-four-slot:not(.is-diamond-rank):not(.is-platinum-rank):not(.is-gold-rank):not(.is-bronze-rank) {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.82), rgba(15, 23, 42, 0.68));
  border-color: rgba(148, 163, 184, 0.16);
  box-shadow:
    0 14px 30px rgba(2, 6, 23, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.content_main .playlist-edit-preview {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
  margin-top: 0.9rem;
}

.content_main .playlist-edit-preview img {
  width: min(180px, 100%);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
}

.content_main .playlist-edit-remove-image {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--subtle);
  font-size: 0.92rem;
  font-weight: 600;
}

.content_main .playlist-edit-remove-image input {
  margin: 0;
}

.content_main .profile-top-four-card .playlist-songs-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.content_main .profile-top-four-card .playlist-songs-title {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.content_main .profile-top-four-card .playlist-songs-count {
  flex: 0 0 auto;
  align-self: center;
}

.content_main .profile-top-four-card .playlist-songs-head + .profile-top-four-slider-shell {
  margin-top: 12px;
}

.content_main .profile-card > .card-head + .profile-preview-slider-shell,
.content_main .profile-media-panel > .card-head + .profile-preview-slider-shell {
  margin-top: 12px;
}

.admin-page-head {
  align-items: center;
  width: min(800px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.admin-page-actions {
  align-items: center;
}

.admin-page-actions .btn-nav {
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.14);
}

.admin-page-copy,
.admin-section-copy,
.admin-empty {
  margin-top: 0;
}

.admin-section-copy-standalone {
  margin-bottom: 0;
}

.content_main .profile-card.admin-panel-card {
  --admin-shell-bg-start: color-mix(in srgb, var(--surface) 80%, var(--brand-1) 20%);
  --admin-shell-bg-end: color-mix(in srgb, var(--surface) 74%, var(--brand-2) 26%);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: clamp(0.95rem, 0.85rem + 0.4vw, 1.15rem);
  margin-top: 14px;
  padding: clamp(1rem, 0.94rem + 0.9vw, 1.35rem);
  overflow: hidden;
  border-radius: 24px;
  background:
    linear-gradient(145deg, var(--admin-shell-bg-start), var(--admin-shell-bg-end)) padding-box,
    linear-gradient(135deg,
      rgb(var(--brand-1-rgb) / 0.36),
      rgb(var(--brand-2-rgb) / 0.42)) border-box;
  border: 1px solid transparent;
  box-shadow:
    0 22px 48px rgb(var(--brand-2-rgb) / 0.12),
    0 12px 28px rgb(var(--brand-1-rgb) / 0.08);
}

.content_main .profile-card.admin-panel-card > * {
  position: relative;
  z-index: 1;
}

html[data-theme='dark'] .content_main .profile-card.admin-panel-card {
  --admin-shell-bg-start: color-mix(in srgb, var(--surface) 86%, var(--brand-1) 14%);
  --admin-shell-bg-end: color-mix(in srgb, var(--surface) 78%, var(--brand-2) 22%);
  background:
    linear-gradient(145deg, var(--admin-shell-bg-start), var(--admin-shell-bg-end)) padding-box,
    linear-gradient(135deg,
      rgb(var(--brand-1-rgb) / 0.34),
      rgb(var(--brand-2-rgb) / 0.28)) border-box;
  box-shadow:
    0 24px 56px rgba(0, 0, 0, 0.46),
    0 12px 28px rgb(var(--brand-2-rgb) / 0.16);
}

.admin-title {
  margin-top: 0;
}

.admin-login-card {
  padding: clamp(1rem, 0.92rem + 1vw, 1.45rem);
}

.admin-login-form {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 0;
}

.admin-login-form input {
  flex: 1 1 240px;
  min-width: min(100%, 240px);
}

.admin-login-form .btn-nav {
  min-height: 42px;
  border-radius: 12px;
  padding: 0 1rem;
}

.admin-summary-panel {
  padding-top: 0.95rem;
}

.admin-summary-pills {
  justify-content: flex-start;
  margin-top: 12px;
}

.admin-summary-pills .pill {
  font-weight: 800;
}

.admin-tabs-in-card {
  order: -1;
}

.admin-search-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  width: min(680px, 100%);
  margin: 0 auto;
}

.admin-search-input {
  width: 100%;
  min-width: 0;
  height: 42px;
  border-radius: 12px;
}

.admin-search-submit,
.admin-search-clear {
  min-height: 38px;
  border-radius: 12px;
  padding: 0 0.9rem;
}

.admin-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.55rem;
  height: 1.3rem;
  padding: 0 0.38rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  color: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

html[data-theme='dark'] .admin-tab-count {
  background: rgba(226, 232, 240, 0.12);
}

.admin-tabs .activity-tab.is-active .admin-tab-count {
  background: rgb(var(--brand-1-rgb) / 0.16);
}

html[data-theme='dark'] .admin-tabs .activity-tab.is-active .admin-tab-count {
  background: rgb(var(--brand-1-rgb) / 0.24);
}

.admin-jump-links {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
  margin-top: 14px;
}

.admin-section-head {
  align-items: center;
  margin: 0;
}

.admin-section-head .profile-label {
  min-height: 32px;
  padding: 0.14rem 0.78rem;
}

.admin-section-head .profile-label .profile-label-text {
  font-size: 0.9rem;
  letter-spacing: 0.07em;
}

.admin-section-tools {
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
}

.admin-section-count {
  min-width: 34px;
  height: 34px;
  padding: 0 0.52rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.32);
  border: 1px solid rgba(255, 255, 255, 0.46);
  box-shadow:
    0 14px 30px rgba(78, 130, 162, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.66);
  color: rgba(15, 23, 42, 0.82);
  font-size: 0.82rem;
}

html[data-theme='dark'] .admin-section-count {
  background: rgba(15, 23, 42, 0.5);
  border-color: rgba(148, 163, 184, 0.28);
  box-shadow:
    0 14px 30px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  color: rgba(248, 250, 252, 0.96);
}

.admin-user-list,
.admin-rating-list {
  margin-top: 0;
}

.admin-user-item {
  min-width: 0;
}

.admin-user-card {
  width: 100%;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px 14px;
}

.admin-user-main {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1 1 auto;
  min-width: 0;
}

.admin-user-identity {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  min-width: 0;
}

.admin-user-pill {
  max-width: min(100%, 320px);
  justify-content: flex-start;
  font-size: 0.9rem;
  font-weight: 900;
  letter-spacing: 0.01em;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.1),
    0 10px 24px rgba(15, 23, 42, 0.22);
}

.admin-user-pill:hover,
.admin-user-pill:focus-visible {
  text-decoration: none;
}

.admin-user-meta {
  margin-left: 0;
  color: rgba(15, 23, 42, 0.82);
  font-size: 0.92rem;
  font-weight: 800;
  white-space: nowrap;
}

html[data-theme='dark'] .admin-user-meta {
  color: rgba(248, 250, 252, 0.96);
  -webkit-text-stroke: 0.45px rgba(15, 23, 42, 0.42);
  text-shadow:
    0 1px 0 rgba(15, 23, 42, 0.72),
    0 0 1px rgba(15, 23, 42, 0.82),
    0 0 12px rgba(15, 23, 42, 0.2);
}

.admin-user-card .admin-record-actions {
  width: auto;
  margin-top: 0;
  margin-left: auto;
  align-self: auto;
}

.admin-user-cred-modal-form .admin-search-input {
  width: 100%;
  min-width: 0;
}

.admin-user-cred-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.admin-user-cred-input-row .btn-nav {
  flex: 0 0 auto;
}

.admin-user-cred-modal-copy {
  margin-bottom: 1rem;
}

.admin-rating-list {
  display: grid;
  gap: 10px;
  padding: 0;
  list-style: none;
}

.admin-rating-item {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
  padding: 0.8rem 0.9rem;
}

.admin-record-title,
.admin-inline-link {
  color: var(--ink);
  font-weight: 800;
  text-decoration: none;
}

.admin-record-main {
  min-width: 0;
  flex: 1 1 auto;
  width: 100%;
}

.admin-record-main-tight {
  padding-right: 0;
}

.admin-record-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: flex-start;
  gap: 10px 14px;
  container-type: inline-size;
}

.admin-record-copy {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px 14px;
  flex-wrap: wrap;
}

.admin-record-title:hover,
.admin-record-title:focus-visible,
.admin-inline-link:hover,
.admin-inline-link:focus-visible {
  color: var(--brand-2);
}

.admin-record-pill {
  flex: 0 1 auto;
  max-width: min(100%, 420px);
  justify-content: flex-start;
  font-size: 0.9rem;
  font-weight: 900;
  letter-spacing: 0.01em;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.1),
    0 10px 24px rgba(15, 23, 42, 0.22);
}

.admin-record-pill:hover,
.admin-record-pill:focus-visible {
  text-decoration: none;
}

.admin-record-meta {
  margin: 0.35rem 0 0;
  color: rgba(15, 23, 42, 0.78);
  font-size: 0.94rem;
  line-height: 1.5;
}

html[data-theme='dark'] .admin-record-meta {
  color: rgba(248, 250, 252, 0.96);
  -webkit-text-stroke: 0.4px rgba(15, 23, 42, 0.38);
  text-shadow:
    0 1px 0 rgba(15, 23, 42, 0.7),
    0 0 1px rgba(15, 23, 42, 0.8),
    0 0 12px rgba(15, 23, 42, 0.2);
}

.admin-record-meta-inline {
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.38rem;
  flex-wrap: wrap;
  flex: 1 1 15rem;
  min-width: min(100%, 13rem);
}

.admin-record-meta-sep {
  color: rgba(15, 23, 42, 0.42);
}

html[data-theme='dark'] .admin-record-meta-sep {
  color: rgba(226, 232, 240, 0.78);
}

.admin-inline-pill {
  height: 28px;
  padding: 0 0.75rem;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.01em;
  text-transform: none;
  white-space: nowrap;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.1),
    0 10px 24px rgba(15, 23, 42, 0.18);
}

.admin-inline-pill:hover,
.admin-inline-pill:focus-visible {
  text-decoration: none;
}

.admin-record-message {
  margin-top: 0.7rem;
  color: rgba(15, 23, 42, 0.86);
  font-weight: 650;
  line-height: 1.5;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
}

html[data-theme='dark'] .admin-record-message {
  color: rgba(248, 250, 252, 0.96);
  -webkit-text-stroke: 0.35px rgba(15, 23, 42, 0.34);
  text-shadow:
    0 1px 0 rgba(15, 23, 42, 0.65),
    0 0 1px rgba(15, 23, 42, 0.72),
    0 0 12px rgba(15, 23, 42, 0.18);
}

.admin-record-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  width: 100%;
  margin-top: auto;
  align-self: stretch;
}

.admin-record-actions-inline {
  justify-content: flex-end;
}

.admin-record-actions-top {
  width: auto;
  margin-top: 0;
  align-self: flex-start;
  flex: 0 0 auto;
  gap: 6px;
  flex-wrap: nowrap;
}

@container (max-width: 510px) {
  .admin-record-meta-inline {
    flex: 0 0 100%;
    min-width: 0;
  }
}

.btn-nav.admin-record-open {
  height: 34px;
  padding: 0 0.75rem;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--brand-2) 35%, transparent);
  background: color-mix(in srgb, var(--brand-2) 10%, transparent);
  color: var(--brand-2) !important;
}

.btn-nav.admin-record-open:hover {
  background: var(--brand-gradient);
  border-color: transparent;
  color: #0f172a !important;
}

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

.admin-record-actions .btn-nav,
.admin-record-actions form .btn-nav {
  width: 116px;
  justify-content: center;
  border-radius: 14px;
}


.admin-record-actions-top .btn-nav,
.admin-record-actions-top form .btn-nav,
.admin-record-icon-btn {
  width: 34px;
  min-width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 12px;
}

.admin-record-actions-top .admin-record-edit {
  width: auto;
  min-width: 64px;
  padding: 0 0.75rem;
}

.admin-record-open-icon {
  width: 16px;
  height: 16px;
  display: block;
}

.admin-record-delete-glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  line-height: 1;
  position: relative;
}

.admin-record-delete-glyph::before {
  content: '×';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -54%);
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1;
}

@media (max-width: 840px) {
  .admin-login-form,
  .admin-rating-item {
    flex-direction: column;
  }

  .admin-search-form {
    grid-template-columns: 1fr;
  }

  .admin-search-submit,
  .admin-search-clear {
    width: 100%;
    justify-content: center;
  }

  .admin-section-tools {
    width: 100%;
    justify-content: space-between;
  }

  .admin-record-head {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .admin-record-copy {
    gap: 8px 12px;
  }

  .admin-record-meta-inline {
    justify-content: flex-start;
  }

  .admin-record-actions-top {
    width: auto;
    justify-content: flex-end;
  }

  .admin-user-main {
    align-items: center;
    width: auto;
  }

  .admin-user-card {
    align-items: center;
  }

  .admin-user-meta {
    width: auto;
    margin-left: auto;
  }

  .admin-user-card .admin-record-actions {
    align-self: auto;
    margin-left: 0;
  }

  .admin-record-actions {
    align-self: stretch;
  }

  .admin-record-actions-inline {
    justify-content: flex-end;
  }
}

.content_main .profile-top-four-note {
  margin: 0 0 14px 0;
  color: var(--subtle);
  font-weight: 800;
}

.content_main .profile-top-four-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.content_main .profile-top-four-slot {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  justify-content: flex-start;
  min-height: 0;
  aspect-ratio: 1 / 1;
  padding: 52px 12px 12px;
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow-sm);
}

html[data-theme='dark'] .content_main .profile-top-four-slot {
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.72);
}

.content_main .profile-top-four-slot.is-filled {
  cursor: default;
  gap: 0;
  padding: 12px;
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    border-color 140ms ease;
}

.content_main .profile-top-four-slot.is-filled.has-song-link {
  cursor: pointer;
}

.content_main .profile-top-four-add-slot {
  cursor: pointer;
  user-select: none;
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    border-color 140ms ease;
}

.content_main .profile-top-four-slot.is-filled:hover,
.content_main .profile-top-four-slot.is-filled:focus-within,
.content_main .profile-top-four-add-slot:hover,
.content_main .profile-top-four-add-slot:focus-visible {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
  border-color: rgb(var(--brand-1-rgb) / 0.42);
}

.content_main .profile-top-four-slot.is-empty {
  padding: 12px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  border: 1px dashed transparent;
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-empty {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main .profile-top-four-rank {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 3;
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 11px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.24);
  overflow: hidden;
}

html[data-theme='dark'] .content_main .profile-top-four-rank {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 22px rgba(2, 6, 23, 0.48);
}

.content_main .profile-top-four-rank-value {
  display: inline-block;
  color: #0f172a;
  -webkit-text-fill-color: currentColor;
  font-size: 0.88rem;
  font-weight: 900;
  line-height: 1;
}

html[data-theme='dark'] .content_main .profile-top-four-rank-value {
  color: var(--ink);
}

.content_main .profile-top-four-cover {
  width: 100%;
  min-height: 0;
  flex: 1 1 auto;
  margin: 0;
  border-radius: 17px 17px 0 0;
  overflow: hidden;
  background: rgba(15, 23, 42, 0.08);
}

html[data-theme='dark'] .content_main .profile-top-four-cover {
  background: rgba(255, 255, 255, 0.08);
}

.content_main .profile-image-shell {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.content_main .profile-image-shell::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(135deg, rgba(34, 211, 238, 0.2), rgba(99, 102, 241, 0.16)),
    linear-gradient(135deg, rgba(255, 255, 255, 0.75), rgba(226, 232, 240, 0.88)),
    url('/static/no_img.png') center / 42% no-repeat;
  opacity: 1;
  transition: opacity 180ms ease;
}

html[data-theme='dark'] .content_main .profile-image-shell::before {
  background:
    linear-gradient(135deg, rgba(34, 211, 238, 0.18), rgba(99, 102, 241, 0.14)),
    linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(30, 41, 59, 0.86)),
    url('/static/no_img.png') center / 42% no-repeat;
}

.content_main .profile-image-shell.is-loaded::before {
  opacity: 0;
}

.content_main .profile-loading-image {
  position: relative;
  z-index: 1;
  opacity: 0;
  transition: opacity 180ms ease;
}

.content_main .profile-loading-image.is-loaded {
  opacity: 1;
}

.content_main .profile-top-four-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.content_main .profile-top-four-copy,
.content_main .profile-top-four-empty-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
}

.content_main .profile-top-four-media-card {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  width: 100%;
  min-height: 0;
  margin-top: auto;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid transparent;
  color: inherit;
  text-decoration: none;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
}

html[data-theme='dark'] .content_main .profile-top-four-media-card {
  background:
    linear-gradient(rgba(2, 6, 23, 0.68), rgba(2, 6, 23, 0.68)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.32);
}

.content_main .profile-top-four-title {
  color: var(--ink);
  font-size: 0.98rem;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.content_main .profile-top-four-copy {
  align-items: center;
  margin-top: 0;
  padding: 0.58rem 0.66rem;
  text-align: center;
}

.content_main .profile-top-four-artist,
.content_main .profile-top-four-empty-copy small {
  color: var(--subtle);
  font-weight: 700;
  line-height: 1.2;
}

.content_main .profile-top-four-empty-copy {
  flex: 1 1 auto;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 0 0.3rem;
}

.content_main .profile-top-four-empty-copy strong {
  color: var(--ink);
}

.content_main .profile-top-four-delete-form {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  display: none;
  margin: 0;
}

.content_main .profile-top-four-delete-form .bulletin-delete {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  padding: 0;
  line-height: 1;
  text-align: center;
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(15, 23, 42, 0.78);
  color: rgba(255, 255, 255, 0.96);
  font-size: 1.15rem;
  font-weight: 700;
  box-shadow:
    0 10px 24px rgba(2, 6, 23, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.content_main .profile-top-four-delete-form .top-four-delete-glyph {
  display: inline-block;
  line-height: 1;
  transform: translate(0.75px, -1px);
}

.content_main .profile-top-four-delete-form .bulletin-delete:hover,
.content_main .profile-top-four-delete-form .bulletin-delete:focus-visible,
.content_main .profile-top-four-delete-form .bulletin-delete:active {
  color: #ef4444 !important;
  border-color: rgba(239, 68, 68, 0.55) !important;
}

html[data-theme='dark'] .content_main .profile-top-four-delete-form .bulletin-delete {
  border-color: rgba(255, 255, 255, 0.22);
  background: rgba(2, 6, 23, 0.86);
  color: rgba(255, 255, 255, 0.98);
}

.content_main .profile-top-four-slot:hover .profile-top-four-delete-form,
.content_main .profile-top-four-slot:focus-within .profile-top-four-delete-form {
  display: inline-flex;
}

@media (max-width: 640px) {
  .content_main .profile-top-four-grid {
    grid-auto-flow: column;
    grid-auto-columns: minmax(228px, calc(80vw - 20px));
    grid-template-columns: none;
    overflow-x: auto;
    overflow-y: visible;
    padding: 2px 4px 8px;
    margin: 0 -4px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    overscroll-behavior-x: contain;
  }

  .content_main .profile-top-four-grid::-webkit-scrollbar {
    display: none;
  }

  .content_main .profile-top-four-slot {
    scroll-snap-align: start;
  }
}

.content_main .profile-preview-grid {
  --profile-preview-columns: 4;
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(var(--profile-preview-columns), minmax(0, 1fr));
  gap: 12px;
}

.content_main .profile-preview-grid.is-count-1 {
  --profile-preview-columns: 1;
}

.content_main .profile-preview-grid.is-count-2 {
  --profile-preview-columns: 2;
}

.content_main .profile-preview-grid.is-count-3 {
  --profile-preview-columns: 3;
}

.content_main .profile-preview-grid.is-count-4 {
  --profile-preview-columns: 4;
}

.content_main .profile-preview-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  overflow: hidden;
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    border-color 140ms ease;
}

html[data-theme='dark'] .content_main .profile-preview-card {
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.72);
}

.content_main .profile-preview-card:hover,
.content_main .profile-preview-card:focus-within {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
  border-color: rgba(34, 211, 238, 0.42);
}

.content_main .profile-preview-cover {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  overflow: hidden;
  background: rgba(15, 23, 42, 0.08);
}

html[data-theme='dark'] .content_main .profile-preview-cover {
  background: rgba(255, 255, 255, 0.08);
}

.content_main .profile-preview-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.content_main .profile-preview-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-width: 0;
  text-align: center;
}

.content_main .profile-preview-title {
  color: var(--ink);
  font-size: 0.96rem;
  font-weight: 900;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.content_main .profile-preview-subtitle {
  color: var(--subtle);
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.content_main .profile-preview-favorite-pill {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.32rem;
  min-height: 22px;
  padding: 0.12rem 0.5rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-sm);
  white-space: nowrap;
  color: #fbcfe8;
}

.content_main .profile-preview-favorite-pill .playlist-favorite-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 12px;
  height: 12px;
  line-height: 0;
  color: #f472b6;
}

.content_main .profile-preview-favorite-pill .playlist-favorite-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.content_main .profile-preview-favorite-pill .playlist-favorite-count {
  font-size: 0.74rem;
  font-weight: 900;
  color: rgba(248, 250, 252, 0.96);
}

html[data-theme='dark'] .content_main .profile-preview-favorite-pill {
  background: rgba(0, 0, 0, 0.62);
  border-color: rgba(255, 255, 255, 0.2);
}

.content_main.gradient-container .profile-preview-percent {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 0.4rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(15, 23, 42, 0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
  font-weight: 900;
  font-size: 1rem;
  color: rgba(248, 250, 252, 0.96);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  pointer-events: none;
}

html[data-theme='dark'] .content_main.gradient-container .profile-preview-percent {
  border-color: rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.55);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
  color: rgba(248, 250, 252, 0.98);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

.content_main.gradient-container .profile-preview-percent.is-score-high {
  color: #4ade80;
}

.content_main.gradient-container .profile-preview-percent.is-score-mid {
  color: #fde047;
}

.content_main.gradient-container .profile-preview-percent.is-score-low {
  color: #fb923c;
}

.content_main.gradient-container .profile-preview-percent.is-score-poor {
  color: #f87171;
}

html[data-theme='dark'] .content_main.gradient-container .profile-preview-percent.is-score-high {
  color: #86efac;
}

html[data-theme='dark'] .content_main.gradient-container .profile-preview-percent.is-score-mid {
  color: #fef08a;
}

html[data-theme='dark'] .content_main.gradient-container .profile-preview-percent.is-score-low {
  color: #fdba74;
}

html[data-theme='dark'] .content_main.gradient-container .profile-preview-percent.is-score-poor {
  color: #fca5a5;
}

@media (max-width: 820px) {
  .content_main .profile-preview-grid {
    grid-auto-flow: column;
    grid-auto-columns: minmax(168px, calc(76vw - 24px));
    grid-template-columns: none;
    overflow-x: auto;
    overflow-y: visible;
    padding: 2px 4px 8px;
    margin: 0 -4px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    overscroll-behavior-x: contain;
  }

  .content_main .profile-preview-grid::-webkit-scrollbar {
    display: none;
  }

  .content_main .profile-preview-card {
    scroll-snap-align: start;
  }

  .content_main .profile-preview-grid.is-count-1 {
    grid-auto-columns: minmax(0, 100%);
  }
}

.content_main .section-viewall {
  margin-top: 0.65rem;
  display: flex;
  justify-content: flex-end;
}

.content_main .viewall-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 28px;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a !important;
  -webkit-text-fill-color: currentColor;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: var(--shadow-sm);
  transition:
    transform 120ms ease,
    box-shadow 140ms ease,
    background 140ms ease;
  cursor: pointer;
  text-decoration: none;
}

html[data-theme='dark'] .content_main .viewall-link {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink) !important;
}

.content_main .viewall-link:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
  text-decoration: none;
}

.content_main .viewall-link:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.content_main .viewall-link:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

.modal-card.modal-card-wide {
  width: min(760px, 92vw);
}

body.has-youtube-player-open {
  overflow: hidden;
}

.youtube-player-modal[hidden] {
  display: none !important;
}

.youtube-player-modal {
  position: fixed;
  inset: 0;
  z-index: 2100;
  display: grid;
  place-items: center;
  padding: 18px;
  pointer-events: none;
}

.youtube-player-modal.is-open {
  pointer-events: auto;
}

.youtube-player-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.6);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
  cursor: pointer;
}

.youtube-player-modal.is-open .youtube-player-backdrop {
  opacity: 1;
  pointer-events: auto;
}

.youtube-player-card {
  position: relative;
  top: auto;
  left: auto;
  width: min(900px, 96vw);
  max-height: min(92vh, 860px);
  overflow: visible;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: scale(0.98);
  transition:
    opacity 180ms ease,
    transform 180ms ease,
    visibility 0s linear 180ms;
}

.youtube-player-modal.is-open .youtube-player-card {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: scale(1);
  transition-delay: 0s;
}

.youtube-player-frame-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 18px;
  overflow: hidden;
  background: #000;
  box-shadow: 0 16px 36px rgba(2, 6, 23, 0.28);
}

.youtube-player-inline-close {
  position: absolute;
  top: 50%;
  right: 12px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.82);
  color: #fff;
  font-size: 1.6rem;
  line-height: 1;
  transform: translateY(-50%);
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(2, 6, 23, 0.28);
  opacity: 1;
  visibility: visible;
  transition:
    opacity 160ms ease,
    visibility 0s linear 0s,
    background-color 160ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .youtube-player-inline-close {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition-delay: 6000ms, 6200ms, 0s;
  }

  .youtube-player-frame-wrap:hover .youtube-player-inline-close,
  .youtube-player-frame-wrap:focus-within .youtube-player-inline-close,
  .youtube-player-inline-close:focus-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition-delay: 0s, 0s, 0s;
  }
}

.youtube-player-inline-close:hover,
.youtube-player-inline-close:active {
  transform: translateY(-50%);
}

.youtube-player-inline-close-glyph {
  display: block;
  line-height: 1;
  transform: translateY(-1px);
}

.youtube-player-inline-close:focus-visible {
  outline: none;
  background: rgba(15, 23, 42, 0.94);
}

.youtube-player-frame {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: #000;
}

html[data-theme='dark'] .youtube-player-card {
  background:
    linear-gradient(rgba(15, 23, 42, 0.96), rgba(15, 23, 42, 0.96)) padding-box,
    var(--brand-gradient) border-box;
}

@media (max-width: 640px) {
  .youtube-player-modal {
    padding: 10px;
  }

  .youtube-player-card {
    width: min(100%, 100vw - 20px);
    padding: 0.85rem;
  }

  .youtube-player-inline-close {
    top: 50%;
    right: 10px;
    width: 34px;
    height: 34px;
    font-size: 1.4rem;
  }
}

@media (max-width: 980px) {
  .modal.modal-keyboard-safe {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    overflow-y: auto;
    padding:
      calc(env(safe-area-inset-top, 0px) + 12px)
      8px
      calc(env(safe-area-inset-bottom, 0px) + 12px);
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
  }

  .modal.modal-keyboard-safe .modal-card.modal-card-keyboard-safe {
    position: relative;
    top: auto;
    left: auto;
    width: min(420px, 100%);
    max-height: calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 24px);
    margin: 0 auto;
    transform: scale(0.98);
  }

  .modal-toggle:checked~.modal.modal-keyboard-safe .modal-card.modal-card-keyboard-safe {
    transform: scale(1);
  }
}

.content_main .card-head .rating-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 0.4rem;
  border-radius: 999px;
  background: rgb(var(--brand-2-rgb) / 0.12);
  border: 1px solid rgb(var(--brand-2-rgb) / 0.28);
  font-weight: 900;
  font-size: 0.85rem;
  color: rgba(15, 23, 42, 0.75);
  letter-spacing: 0;
}

html[data-theme='dark'] .content_main .card-head .rating-count {
  background: rgb(var(--brand-2-rgb) / 0.22);
  border-color: rgb(var(--brand-2-rgb) / 0.38);
  color: var(--ink);
}

.content_main.gradient-container .rating-list:not(.admin-rating-list) li {
  position: relative;
  padding-right: 4.25rem;
}

.content_main.gradient-container .rating-list .rating-percent {
  position: absolute;
  top: 10px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 0.4rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.78), rgba(15, 23, 42, 0.78)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
  font-weight: 900;
  font-size: 1rem;
  color: rgba(248, 250, 252, 0.96);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  pointer-events: none;
}

html[data-theme='dark'] .content_main.gradient-container .rating-list .rating-percent {
  background:
    linear-gradient(rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.55)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
  color: rgba(248, 250, 252, 0.98);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

.content_main .comment-item {
  position: relative;
  display: flex;
  align-items: stretch;
  gap: 8px;
  padding-right: 0;
  padding-bottom: 0;
  border-radius: 10px;
  transition:
    background 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease;
}

.content_main .comment-list,
.content_main .comment-children {
  list-style: none;
  padding: 0;
}

.content_main .comment-list {
  margin: 0;
}

.content_main .comment-thread {
  display: block;
  align-items: stretch;
  justify-content: initial;
  gap: 0;
  cursor: default;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  --comment-nest-offset: 1.5rem;
  scroll-margin-top: 92px;
}

.content_main .comment-thread.is-comment-focused > .comment-item {
  background: color-mix(in srgb, rgb(var(--brand-2-rgb)) 10%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, rgb(var(--brand-2-rgb)) 34%, transparent);
}

html[data-theme='dark'] .content_main .comment-thread.is-comment-focused > .comment-item {
  background: color-mix(in srgb, rgb(var(--brand-2-rgb)) 18%, rgba(15, 23, 42, 0.35));
  box-shadow: 0 0 0 1px color-mix(in srgb, rgb(var(--brand-2-rgb)) 46%, rgba(148, 163, 184, 0.16));
}

.content_main .comment-list > .comment-thread {
  margin: 0.75rem 0;
  padding: 0.95rem 1rem 0.85rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.content_main .comment-children > .comment-thread {
  margin: 0.55rem 0 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.content_main .comment-children > .comment-thread:hover {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  transform: none;
}

.content_main .comment-children {
  margin: 0.1rem 0 0 var(--comment-nest-offset);
  padding-left: 0.65rem;
  border-left: 1px solid rgb(var(--brand-2-rgb) / 0.18);
}

.content_main .comment-children.is-flat-thread {
  margin-left: calc((var(--comment-avatar-size, 36px) + var(--comment-avatar-gap, 10px)) * -1);
  padding-left: 0;
  border-left: 0;
  width: calc(100% + var(--comment-avatar-size, 36px) + var(--comment-avatar-gap, 10px));
  max-width: none;
}

.content_main .comment-replies-shell > .comment-children.is-flat-thread {
  margin-left: var(--comment-nest-offset);
  padding-left: 0.65rem;
  border-left: 1px solid rgb(var(--brand-2-rgb) / 0.18);
  width: auto;
  max-width: 100%;
}

.content_main .comment-thread .comment-thread {
  --comment-nest-offset: 1.15rem;
}

.content_main .comment-thread .comment-thread .comment-thread {
  --comment-nest-offset: 0.8rem;
}

.content_main .comment-thread .comment-thread .comment-thread .comment-thread {
  --comment-nest-offset: 0.5rem;
}

.content_main .comment-thread .comment-thread .comment-thread .comment-thread .comment-thread {
  --comment-nest-offset: 0.35rem;
}

html[data-theme='dark'] .content_main .comment-children {
  border-left-color: rgba(148, 163, 184, 0.22);
}

.content_main .comment-thread.is-flat-thread > .comment-item {
  padding-right: 0;
  padding-bottom: 0;
  flex-wrap: wrap;
  row-gap: 0.35rem;
}

.content_main .comment-thread.is-flat-thread > .comment-item > .comment-content {
  flex: 1 1 100%;
}

.content_main .comment-thread.is-flat-thread > .comment-item > .comment-actions {
  position: static;
  margin-left: auto;
  order: 2;
}

.content_main .comment-thread.is-flat-thread > .comment-item > .comment-time {
  position: static;
  margin-left: 0;
  order: 3;
  width: 100%;
  text-align: right;
}

.content_main .comment-item:hover {
  transform: none;
}

.content_main .comment-content {
  --comment-avatar-size: 36px;
  --comment-avatar-gap: 10px;
  display: flex;
  align-items: flex-start;
  gap: var(--comment-avatar-gap);
  flex: 1 1 auto;
  min-width: 0;
}

.content_main .comment-avatar-link {
  width: var(--comment-avatar-size);
  height: var(--comment-avatar-size);
  flex: 0 0 var(--comment-avatar-size);
  aspect-ratio: 1 / 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--brand-gradient);
  border: 0;
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  line-height: 0;
}

.content_main .comment-avatar-link .comment-avatar {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  object-fit: cover;
  display: block;
  border: 0;
  box-shadow: none;
}

.content_main .comment-avatar-link .comment-avatar-initial {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 0.85rem;
  color: #0f172a;
  background: rgba(255, 255, 255, 0.92);
  -webkit-text-fill-color: currentColor;
  border: 0;
  box-shadow: none;
}

html[data-theme='dark'] .content_main .comment-avatar-link .comment-avatar-initial {
  background: rgba(15, 23, 42, 0.72);
  color: var(--ink);
}

.content_main .comment-avatar-link:hover {
  text-decoration: none;
}

.content_main .comment-body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 0.3rem;
  min-width: 0;
  width: 100%;
}

.content_main .comment-control-row {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 0.12rem;
}

.content_main .comment-head-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  width: 100%;
}

.content_main .comment-username {
  font-weight: 800;
  font-size: 0.85rem;
}

.content_main .comment-username-link {
  flex: 1 1 auto;
  min-width: 0;
  text-decoration: none;
  color: inherit;
  background: transparent;
  border: 0;
  padding: 0;
  height: auto;
  line-height: normal;
  border-radius: 0;
  filter: none;
}

.content_main .comment-username-link:hover {
  text-decoration: underline;
  filter: none;
}

.content_main .comment-text {
  flex: 1 1 auto;
  min-width: 0;
  color: var(--ink);
  font-size: 0.95rem;
  word-break: break-word;
}

.content_main .comment-text-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 0.75rem;
  width: 100%;
  min-width: 0;
}

.content_main .comment-reply-preview {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: nowrap;
  padding: 0.42rem 0.62rem;
  border-left: 2px solid rgb(var(--brand-2-rgb) / 0.68);
  border-radius: 10px;
  background: rgb(var(--brand-2-rgb) / 0.06);
  min-width: 0;
  overflow: hidden;
  text-decoration: none;
}

.content_main .comment-reply-preview-user {
  color: rgb(var(--brand-2-rgb));
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  flex: 0 0 auto;
}

.content_main .comment-reply-preview-text {
  color: var(--ink);
  font-size: 0.8rem;
  line-height: 1.34;
  opacity: 0.84;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

html[data-theme='dark'] .content_main .comment-reply-preview {
  background: rgb(var(--brand-2-rgb) / 0.13);
  border-left-color: rgb(var(--brand-2-rgb) / 0.84);
}

.content_main .comment-reply-focus-link {
  cursor: pointer;
  transition:
    background 140ms ease,
    box-shadow 140ms ease,
    border-color 140ms ease,
    transform 140ms ease;
}

.content_main .comment-reply-focus-link:hover,
.content_main .comment-reply-focus-link:focus-visible {
  text-decoration: none;
  transform: translateY(-1px);
  background: rgb(var(--brand-2-rgb) / 0.12);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.1);
}

html[data-theme='dark'] .content_main .comment-reply-focus-link:hover,
html[data-theme='dark'] .content_main .comment-reply-focus-link:focus-visible {
  background: rgb(var(--brand-2-rgb) / 0.2);
}

.content_main .comment-mention {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 0.7rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: #0f172a;
  -webkit-text-fill-color: currentColor;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  margin-right: 0.35rem;
  text-decoration: none;
  vertical-align: middle;
  box-shadow: var(--shadow-sm);
}

html[data-theme='dark'] .content_main .comment-mention {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

.content_main .comment-mention:hover {
  text-decoration: underline;
  box-shadow: var(--shadow-md);
}

.content_main .comment-replies-shell {
  display: block;
  margin-top: 0;
  margin-left: auto;
}

.content_main .comment-replies-shell > summary {
  list-style: none;
}

.content_main .comment-replies-shell > summary::-webkit-details-marker {
  display: none;
}

.content_main .comment-replies-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 26px;
  padding: 0.18rem 0.34rem 0.18rem 0.62rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, rgb(var(--brand-2-rgb)) 28%, transparent);
  background: color-mix(in srgb, rgb(var(--brand-2-rgb)) 10%, transparent);
  box-shadow: 0 5px 12px rgba(15, 23, 42, 0.08);
  color: rgb(var(--brand-2-rgb));
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  cursor: pointer;
  user-select: none;
  transition:
    background 140ms ease,
    border-color 140ms ease,
    transform 140ms ease,
    box-shadow 140ms ease,
    color 140ms ease;
}

.content_main .comment-replies-toggle:hover,
.content_main .comment-replies-shell > summary:focus-visible .comment-replies-toggle,
.content_main .comment-replies-bottom-toggle:focus-visible {
  background: color-mix(in srgb, rgb(var(--brand-2-rgb)) 16%, transparent);
  border-color: color-mix(in srgb, rgb(var(--brand-2-rgb)) 46%, transparent);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
  transform: translateY(-1px);
}

.content_main .comment-replies-toggle-count {
  display: inline-flex;
  min-width: 1.45rem;
  min-height: 1.45rem;
  padding: 0 0.42rem;
  justify-content: center;
  align-items: center;
  border-radius: 999px;
  background: rgb(var(--brand-2-rgb));
  color: #ffffff;
  font-size: 0.71rem;
  font-weight: 900;
  letter-spacing: 0;
  box-shadow: 0 5px 12px rgba(15, 23, 42, 0.16);
}

.content_main .comment-replies-shell[open] > summary {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 0.55rem;
}

.content_main .comment-replies-footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.55rem;
}

.content_main .comment-replies-bottom-toggle {
  appearance: none;
  font-family: inherit;
}

html[data-theme='dark'] .content_main .comment-replies-toggle {
  border-color: color-mix(in srgb, rgb(var(--brand-2-rgb)) 35%, rgba(226, 232, 240, 0.12));
  background: color-mix(in srgb, rgb(var(--brand-2-rgb)) 16%, rgba(15, 23, 42, 0.34));
  box-shadow: 0 8px 18px rgba(2, 6, 23, 0.22);
}

html[data-theme='dark'] .content_main .comment-replies-toggle:hover,
html[data-theme='dark'] .content_main .comment-replies-shell > summary:focus-visible .comment-replies-toggle,
html[data-theme='dark'] .content_main .comment-replies-bottom-toggle:focus-visible {
  background: color-mix(in srgb, rgb(var(--brand-2-rgb)) 24%, rgba(15, 23, 42, 0.42));
  border-color: color-mix(in srgb, rgb(var(--brand-2-rgb)) 58%, rgba(226, 232, 240, 0.12));
}

html[data-theme='dark'] .content_main .comment-replies-toggle-count {
  color: #0f172a;
  box-shadow: 0 8px 18px rgba(2, 6, 23, 0.26);
}

.content_main .comment-replies-shell[open] > .comment-replies-toggle .comment-replies-toggle-show,
.content_main .comment-replies-shell:not([open]) > .comment-replies-toggle .comment-replies-toggle-hide {
  display: none;
}

.content_main .comment-reply-shell {
  display: block;
  margin-top: 0;
  width: auto;
}

.content_main .comment-reply-shell > summary {
  list-style: none;
}

.content_main .comment-reply-shell > summary::-webkit-details-marker {
  display: none;
}

.content_main .comment-reply-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 0 0.55rem;
  border-radius: 999px;
  border: 1px solid rgb(var(--brand-2-rgb) / 0.22);
  background: rgb(var(--brand-2-rgb) / 0.08);
  color: rgb(var(--brand-2-rgb));
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  cursor: pointer;
  user-select: none;
}

html[data-theme='dark'] .content_main .comment-reply-btn {
  border-color: rgb(var(--brand-2-rgb) / 0.26);
  background: rgb(var(--brand-2-rgb) / 0.14);
  color: rgb(var(--brand-2-rgb));
}

.content_main .comment-reply-shell[open] .comment-reply-btn {
  background: rgb(var(--brand-2-rgb) / 0.14);
}

html[data-theme='dark'] .content_main .comment-reply-shell[open] .comment-reply-btn {
  background: rgb(var(--brand-2-rgb) / 0.22);
}

.content_main .comment-reply-shell[open] > summary {
  display: block;
  height: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

.content_main .comment-control-row > .comment-reply-shell {
  flex: 0 0 auto;
}

.content_main .comment-control-row > .comment-reply-shell[open] {
  flex: 1 1 100%;
  width: 100%;
}

.content_main .comment-control-row > .comment-replies-shell {
  flex: 0 0 auto;
}

.content_main .comment-control-row > .comment-replies-shell[open] {
  flex: 1 1 100%;
  width: 100%;
  margin-left: 0;
}

.content_main .comment-reply-form {
  margin-top: 0.6rem;
  width: 100%;
}

.content_main .comment-reply-form-row {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.6rem;
  width: 100%;
}

.content_main .comment-reply-context {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: nowrap;
  padding: 0.55rem 0.75rem;
  border-left: 3px solid rgb(var(--brand-2-rgb) / 0.72);
  border-radius: 10px;
  background: rgb(var(--brand-2-rgb) / 0.08);
  min-width: 0;
  overflow: hidden;
  text-decoration: none;
}

.content_main .comment-reply-context-user {
  color: rgb(var(--brand-2-rgb));
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  flex: 0 0 auto;
}

.content_main .comment-reply-context-text {
  color: var(--ink);
  font-size: 0.82rem;
  line-height: 1.35;
  opacity: 0.88;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.content_main .comment-reply-context-mention {
  color: rgb(var(--brand-2-rgb));
  font-weight: 800;
  margin-right: 0.25rem;
}

html[data-theme='dark'] .content_main .comment-reply-context {
  background: rgb(var(--brand-2-rgb) / 0.14);
  border-left-color: rgb(var(--brand-2-rgb) / 0.82);
}

.content_main .comment-reply-form .form-group {
  flex: 1 1 auto;
  width: 100%;
  margin-bottom: 0;
}

.content_main .comment-reply-form textarea {
  width: 100%;
  max-width: none;
  display: block;
  min-height: 72px;
  resize: vertical;
}

.content_main .comment-reply-actions {
  flex: 0 0 auto;
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
  margin-top: 0;
  align-self: stretch;
}

.content_main .comment-reply-actions .btn-nav {
  height: 36px;
}

.content_main .comment-remove-form {
  margin: 0;
}

.content_main .comment-actions {
  position: absolute;
  top: 6px;
  right: 6px;
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.content_main .comment-head-row .comment-actions {
  position: static;
  top: auto;
  right: auto;
  margin-left: 0;
  flex: 0 0 auto;
}

.content_main .comments-section .comment-actions {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: none;
}

.content_main .comment-action-menu {
  position: relative;
  display: inline-block;
  z-index: 1;
}

.content_main .comment-action-menu[open] {
  z-index: 6;
}

.content_main .comment-action-menu > summary {
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
}

.content_main .comment-action-menu > summary::-webkit-details-marker {
  display: none;
}

.content_main .comment-action-menu > summary::marker {
  content: '';
}

.content_main .comment-action-menu-toggle {
  width: 28px;
  min-width: 28px;
  height: 28px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.24);
  background: rgba(15, 23, 42, 0.34);
  color: #ffffff;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  user-select: none;
  line-height: 0;
}

.content_main .comment-action-menu-toggle:hover,
.content_main .comment-action-menu[open] .comment-action-menu-toggle {
  background: rgba(15, 23, 42, 0.46);
  border-color: rgba(15, 23, 42, 0.3);
}

.content_main .comment-action-menu-icon {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  gap: 3px;
}

.content_main .comment-action-menu-dot {
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: currentColor;
  flex: 0 0 auto;
}

.content_main .comment-action-menu-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 132px;
  padding: 0.35rem;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.16), 0 2px 8px rgba(15, 23, 42, 0.08);
  display: grid;
  gap: 4px;
  overflow: hidden;
  transform-origin: top right;
}

.content_main .comment-action-menu:not([open]) .comment-action-menu-panel {
  display: none;
}

.content_main .comment-action-menu-panel form {
  display: block;
  width: 100%;
  margin: 0;
}

.content_main .comment-action-menu-item {
  width: 100%;
  min-height: 36px;
  padding: 0.6rem 0.75rem;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 800;
  line-height: 1.1;
  text-align: left;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  box-shadow: none;
  transform: none;
  transition: background 120ms ease, color 120ms ease;
}

.content_main .comment-action-menu-item:hover,
.content_main .comment-action-menu-item:focus-visible,
.content_main .comment-action-menu-item:active {
  background: rgba(15, 23, 42, 0.08);
  text-decoration: none;
  outline: none;
  transform: none;
  box-shadow: none;
}

.content_main .comment-action-menu-item.is-danger {
  color: #b91c1c;
}

.content_main .comment-action-menu-item.is-danger:hover,
.content_main .comment-action-menu-item.is-danger:focus-visible,
.content_main .comment-action-menu-item.is-danger:active {
  background: rgba(239, 68, 68, 0.12);
}

html[data-theme='dark'] .content_main .comment-action-menu-toggle {
  border-color: rgba(226, 232, 240, 0.24);
  background: rgba(226, 232, 240, 0.1);
  color: var(--ink);
}

html[data-theme='dark'] .content_main .comment-action-menu-toggle:hover,
html[data-theme='dark'] .content_main .comment-action-menu[open] .comment-action-menu-toggle {
  background: rgba(226, 232, 240, 0.16);
  border-color: rgba(226, 232, 240, 0.34);
}

html[data-theme='dark'] .content_main .comment-action-menu-panel {
  border-color: rgba(148, 163, 184, 0.28);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(11, 18, 32, 0.97));
}

html[data-theme='dark'] .content_main .comment-action-menu-item:hover,
html[data-theme='dark'] .content_main .comment-action-menu-item:focus-visible,
html[data-theme='dark'] .content_main .comment-action-menu-item:active {
  background: rgba(226, 232, 240, 0.1);
}

html[data-theme='dark'] .content_main .comment-action-menu-item.is-danger {
  color: #fca5a5;
}

html[data-theme='dark'] .content_main .comment-action-menu-item.is-danger:hover,
html[data-theme='dark'] .content_main .comment-action-menu-item.is-danger:focus-visible,
html[data-theme='dark'] .content_main .comment-action-menu-item.is-danger:active {
  background: rgba(239, 68, 68, 0.16);
}

.content_main .comment-edit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 22px;
  padding: 0 0.45rem;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.2);
  background: rgba(15, 23, 42, 0.06);
  color: rgba(15, 23, 42, 0.8);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
}

html[data-theme='dark'] .content_main .comment-edit-btn {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(226, 232, 240, 0.08);
  color: var(--ink);
}

.content_main .comment-edit-btn:hover {
  background: rgba(15, 23, 42, 0.12);
}

html[data-theme='dark'] .content_main .comment-edit-btn:hover {
  background: rgba(226, 232, 240, 0.14);
}

.content_main .comment-remove-btn {
  width: 22px;
  height: 22px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.08);
  color: rgba(239, 68, 68, 0.95);
  font-size: 1rem;
  font-weight: 800;
  line-height: 0.8;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  text-align: center;
}

.content_main .comments-section .comment-remove-btn {
  font-size: 0;
}

.content_main .comments-section .comment-remove-btn::before {
  content: '\00d7';
  display: block;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1;
  transform: translateY(-0.5px);
}

.content_main .comment-remove-btn:hover {
  background: #dc2626;
  border-color: #dc2626;
  color: #fff;
}

.content_main .comment-time {
  position: static;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  flex: 0 0 auto;
  font-size: 0.75rem;
  color: var(--subtle);
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  text-align: right;
}

@media (max-width: 640px) {
  .content_main .comment-children {
    margin-left: min(var(--comment-nest-offset), 1.25rem);
    padding-left: 0.7rem;
  }

  .content_main .comment-children.is-flat-thread {
    margin-left: calc((var(--comment-avatar-size, 36px) + var(--comment-avatar-gap, 10px)) * -1);
    padding-left: 0;
  }
}

@media (max-width: 520px) {
  .content_main .comment-item {
    padding-right: 0;
    padding-bottom: 0.55rem;
    flex-wrap: wrap;
    row-gap: 0.35rem;
  }

  .content_main .comment-item > .comment-content {
    flex: 1 1 100%;
  }

  .content_main .comment-item > .comment-actions {
    position: static;
    margin-left: auto;
    order: 2;
  }

  .content_main .comment-item > .comment-time {
    position: static;
    margin-left: 0;
    order: 3;
    width: 100%;
    text-align: right;
  }

  .content_main .comment-content {
    --comment-avatar-size: 32px;
    --comment-avatar-gap: 0.7rem;
  }

  .content_main .comment-text-row {
    grid-template-columns: minmax(0, 1fr) auto;
    column-gap: 0.6rem;
    row-gap: 0.35rem;
  }

  .content_main .comment-time {
    margin-left: auto;
  }

  .content_main .comment-control-row {
    gap: 0.5rem;
  }

  .content_main .comment-avatar-link {
    flex-basis: var(--comment-avatar-size);
  }
}

.content_main .profile-top-four-slot:not(.is-diamond-rank):not(.is-platinum-rank):not(.is-gold-rank):not(.is-bronze-rank),
.content_main .profile-preview-card,
.content_main .profile-card .rating-list>li {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.9)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main.gradient-container .profile-top-four-card .profile-top-four-slot:not(.is-diamond-rank):not(.is-platinum-rank):not(.is-gold-rank):not(.is-bronze-rank) {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.9)) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .content_main .profile-top-four-slot:not(.is-diamond-rank):not(.is-platinum-rank):not(.is-gold-rank):not(.is-bronze-rank),
html[data-theme='dark'] .content_main .profile-preview-card,
html[data-theme='dark'] .content_main .profile-card .rating-list>li {
  background:
    linear-gradient(rgba(15, 23, 42, 0.76), rgba(15, 23, 42, 0.76)) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .content_main.gradient-container .profile-top-four-card .profile-top-four-slot:not(.is-diamond-rank):not(.is-platinum-rank):not(.is-gold-rank):not(.is-bronze-rank) {
  background:
    linear-gradient(rgba(15, 23, 42, 0.76), rgba(15, 23, 42, 0.76)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main .profile-top-four-slot.is-diamond-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(224, 247, 255, 0.99) 0%, rgba(103, 232, 249, 0.9) 54%, rgba(37, 99, 235, 0.8) 100%);
  --top-four-shell-border: linear-gradient(135deg, #ecfeff 0%, #bae6fd 32%, #67e8f9 66%, #2563eb 100%);
  --top-four-text-gradient: linear-gradient(135deg, #ffffff 0%, #67e8f9 42%, #2563eb 100%);
  --top-four-shell-shadow: rgba(14, 116, 144, 0.16);
  --top-four-shell-shadow-hover: rgba(14, 116, 144, 0.22);
  --top-four-cover-border: rgba(103, 232, 249, 0.38);
}

.content_main .profile-top-four-slot.is-platinum-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(255, 255, 255, 0.99) 0%, rgba(196, 181, 253, 0.9) 54%, rgba(100, 116, 139, 0.78) 100%);
  --top-four-shell-border: linear-gradient(135deg, #ffffff 0%, #dbeafe 34%, #c4b5fd 68%, #64748b 100%);
  --top-four-text-gradient: linear-gradient(135deg, #ffffff 0%, #c4b5fd 42%, #475569 100%);
  --top-four-shell-shadow: rgba(99, 102, 241, 0.16);
  --top-four-shell-shadow-hover: rgba(99, 102, 241, 0.22);
  --top-four-cover-border: rgba(196, 181, 253, 0.36);
}

.content_main .profile-top-four-slot.is-gold-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(254, 243, 199, 0.99) 0%, rgba(245, 158, 11, 0.92) 54%, rgba(146, 64, 14, 0.82) 100%);
  --top-four-shell-border: linear-gradient(135deg, #fde68a 0%, #f59e0b 52%, #92400e 100%);
  --top-four-text-gradient: linear-gradient(135deg, #fef3c7 0%, #f59e0b 48%, #92400e 100%);
  --top-four-shell-shadow: rgba(180, 83, 9, 0.16);
  --top-four-shell-shadow-hover: rgba(180, 83, 9, 0.22);
  --top-four-cover-border: rgba(245, 158, 11, 0.36);
}

.content_main .profile-top-four-slot.is-bronze-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(253, 230, 138, 0.98) 0%, rgba(194, 120, 58, 0.9) 52%, rgba(120, 53, 15, 0.84) 100%);
  --top-four-shell-border: linear-gradient(135deg, #fcd34d 0%, #b45309 52%, #7c2d12 100%);
  --top-four-text-gradient: linear-gradient(135deg, #fde68a 0%, #d97706 48%, #7c2d12 100%);
  --top-four-shell-shadow: rgba(146, 64, 14, 0.16);
  --top-four-shell-shadow-hover: rgba(146, 64, 14, 0.22);
  --top-four-cover-border: rgba(180, 83, 9, 0.34);
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-diamond-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(224, 247, 255, 0.92) 0%, rgba(103, 232, 249, 0.76) 54%, rgba(37, 99, 235, 0.94) 100%);
  --top-four-shell-border: linear-gradient(135deg, rgba(236, 254, 255, 0.98) 0%, rgba(186, 230, 253, 0.98) 32%, rgba(103, 232, 249, 0.98) 66%, rgba(37, 99, 235, 0.98) 100%);
  --top-four-text-gradient: linear-gradient(135deg, #ffffff 0%, #67e8f9 42%, #93c5fd 100%);
  --top-four-shell-shadow: rgba(0, 0, 0, 0.58);
  --top-four-shell-shadow-hover: rgba(0, 0, 0, 0.64);
  --top-four-cover-border: rgba(103, 232, 249, 0.48);
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-platinum-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(241, 245, 249, 0.92) 0%, rgba(196, 181, 253, 0.76) 54%, rgba(71, 85, 105, 0.96) 100%);
  --top-four-shell-border: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(219, 234, 254, 0.98) 34%, rgba(196, 181, 253, 0.98) 68%, rgba(100, 116, 139, 0.98) 100%);
  --top-four-text-gradient: linear-gradient(135deg, #ffffff 0%, #c4b5fd 44%, #cbd5e1 100%);
  --top-four-shell-shadow: rgba(79, 70, 229, 0.32);
  --top-four-shell-shadow-hover: rgba(79, 70, 229, 0.4);
  --top-four-cover-border: rgba(196, 181, 253, 0.46);
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-gold-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(254, 243, 199, 0.92) 0%, rgba(245, 158, 11, 0.8) 54%, rgba(146, 64, 14, 0.96) 100%);
  --top-four-shell-border: linear-gradient(135deg, rgba(253, 230, 138, 0.98) 0%, rgba(245, 158, 11, 0.98) 52%, rgba(146, 64, 14, 0.98) 100%);
  --top-four-text-gradient: linear-gradient(135deg, #fef3c7 0%, #f59e0b 48%, #fdba74 100%);
  --top-four-shell-shadow: rgba(0, 0, 0, 0.58);
  --top-four-shell-shadow-hover: rgba(0, 0, 0, 0.64);
  --top-four-cover-border: rgba(245, 158, 11, 0.44);
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-bronze-rank {
  --top-four-shell-fill: linear-gradient(135deg, rgba(120, 53, 15, 0.98) 0%, rgba(180, 83, 9, 0.9) 52%, rgba(67, 20, 7, 0.98) 100%);
  --top-four-shell-border: linear-gradient(135deg, rgba(253, 230, 138, 0.98) 0%, rgba(217, 119, 6, 0.98) 52%, rgba(124, 45, 18, 0.98) 100%);
  --top-four-text-gradient: linear-gradient(135deg, #fde68a 0%, #f59e0b 48%, #ea580c 100%);
  --top-four-shell-shadow: rgba(0, 0, 0, 0.58);
  --top-four-shell-shadow-hover: rgba(0, 0, 0, 0.64);
  --top-four-cover-border: rgba(217, 119, 6, 0.44);
}

.content_main .profile-top-four-slot.is-diamond-rank,
.content_main .profile-top-four-slot.is-platinum-rank,
.content_main .profile-top-four-slot.is-gold-rank,
.content_main .profile-top-four-slot.is-bronze-rank {
  border: 1px solid transparent;
  background:
    var(--top-four-shell-fill) padding-box,
    var(--top-four-shell-border) border-box;
  box-shadow: 0 14px 32px var(--top-four-shell-shadow);
}

.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-diamond-rank,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-platinum-rank,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-gold-rank,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-bronze-rank {
  border: 1px solid transparent;
  background:
    var(--top-four-shell-fill) padding-box,
    var(--top-four-shell-border) border-box;
  box-shadow: 0 14px 32px var(--top-four-shell-shadow);
}

.content_main .profile-top-four-slot.is-diamond-rank:hover,
.content_main .profile-top-four-slot.is-diamond-rank:focus-within,
.content_main .profile-top-four-slot.is-platinum-rank:hover,
.content_main .profile-top-four-slot.is-platinum-rank:focus-within,
.content_main .profile-top-four-slot.is-gold-rank:hover,
.content_main .profile-top-four-slot.is-gold-rank:focus-within,
.content_main .profile-top-four-slot.is-bronze-rank:hover,
.content_main .profile-top-four-slot.is-bronze-rank:focus-within {
  box-shadow: 0 16px 36px var(--top-four-shell-shadow-hover);
}

.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-diamond-rank:hover,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-diamond-rank:focus-within,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-platinum-rank:hover,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-platinum-rank:focus-within,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-gold-rank:hover,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-gold-rank:focus-within,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-bronze-rank:hover,
.content_main.gradient-container .profile-top-four-card .profile-top-four-slot.is-bronze-rank:focus-within {
  box-shadow: 0 16px 36px var(--top-four-shell-shadow-hover);
}

.content_main .profile-top-four-slot.is-diamond-rank .profile-top-four-rank,
.content_main .profile-top-four-slot.is-platinum-rank .profile-top-four-rank,
.content_main .profile-top-four-slot.is-gold-rank .profile-top-four-rank,
.content_main .profile-top-four-slot.is-bronze-rank .profile-top-four-rank {
  background:
    linear-gradient(rgba(0, 0, 0, 0.96), rgba(0, 0, 0, 0.96)) padding-box,
    var(--top-four-shell-border) border-box;
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-diamond-rank .profile-top-four-rank,
html[data-theme='dark'] .content_main .profile-top-four-slot.is-platinum-rank .profile-top-four-rank,
html[data-theme='dark'] .content_main .profile-top-four-slot.is-gold-rank .profile-top-four-rank,
html[data-theme='dark'] .content_main .profile-top-four-slot.is-bronze-rank .profile-top-four-rank {
  background:
    linear-gradient(rgba(2, 6, 23, 0.84), rgba(2, 6, 23, 0.84)) padding-box,
    var(--top-four-shell-border) border-box;
}

.content_main .profile-top-four-slot.is-diamond-rank .profile-top-four-rank-value,
.content_main .profile-top-four-slot.is-diamond-rank .profile-top-four-title,
.content_main .profile-top-four-slot.is-diamond-rank .profile-top-four-empty-copy strong,
.content_main .profile-top-four-slot.is-platinum-rank .profile-top-four-rank-value,
.content_main .profile-top-four-slot.is-platinum-rank .profile-top-four-title,
.content_main .profile-top-four-slot.is-platinum-rank .profile-top-four-empty-copy strong,
.content_main .profile-top-four-slot.is-gold-rank .profile-top-four-rank-value,
.content_main .profile-top-four-slot.is-gold-rank .profile-top-four-title,
.content_main .profile-top-four-slot.is-gold-rank .profile-top-four-empty-copy strong,
.content_main .profile-top-four-slot.is-bronze-rank .profile-top-four-rank-value,
.content_main .profile-top-four-slot.is-bronze-rank .profile-top-four-title,
.content_main .profile-top-four-slot.is-bronze-rank .profile-top-four-empty-copy strong {
  color: transparent;
  background-image: var(--top-four-text-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_main .profile-top-four-slot.is-filled .profile-top-four-copy {
  align-items: center;
  padding: 0.58rem 0.66rem;
  text-align: center;
}

.content_main .profile-top-four-slot.is-filled .profile-top-four-title {
  color: rgba(15, 23, 42, 0.96);
  background-image: none;
  -webkit-text-fill-color: currentColor;
  text-shadow: none;
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-filled .profile-top-four-title {
  color: rgba(248, 250, 252, 0.98);
}

.content_main .profile-top-four-slot.is-filled .profile-top-four-artist {
  color: rgba(15, 23, 42, 0.74);
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-filled .profile-top-four-artist {
  color: rgba(226, 232, 240, 0.82);
}

html:not([data-theme='dark']) .content_main .profile-top-four-slot.is-empty .profile-top-four-empty-copy {
  padding: 0.85rem 0.7rem;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

html:not([data-theme='dark']) .content_main .profile-top-four-slot.is-empty .profile-top-four-empty-copy strong {
  color: #0f172a;
  background-image: none;
  -webkit-text-fill-color: currentColor;
}

html:not([data-theme='dark']) .content_main .profile-top-four-slot.is-empty .profile-top-four-empty-copy small {
  color: rgba(15, 23, 42, 0.78);
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-empty .profile-top-four-empty-copy {
  padding: 0.85rem 0.7rem;
  border-radius: 16px;
  background: rgba(2, 6, 23, 0.44);
  border: 1px solid rgba(148, 163, 184, 0.16);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-empty .profile-top-four-empty-copy strong {
  color: rgba(248, 250, 252, 0.98);
  background-image: none;
  -webkit-text-fill-color: currentColor;
}

html[data-theme='dark'] .content_main .profile-top-four-slot.is-empty .profile-top-four-empty-copy small {
  color: rgba(226, 232, 240, 0.8);
}

.content_main .profile-top-four-slot.is-diamond-rank .profile-top-four-cover,
.content_main .profile-top-four-slot.is-platinum-rank .profile-top-four-cover,
.content_main .profile-top-four-slot.is-gold-rank .profile-top-four-cover,
.content_main .profile-top-four-slot.is-bronze-rank .profile-top-four-cover {
  border: 1px solid var(--top-four-cover-border);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.profile-card-split {
  display: flex;
  width: 100%;
  max-width: 800px;
}

.rating-like-row {
  margin-top: 0.75rem;
  display: flex;
  justify-content: flex-end;
}

.heart-btn {
  width: 36px;
  min-width: 36px;
  height: 36px;
  padding: 0;
  aspect-ratio: 1 / 1;
  flex: 0 0 36px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.2);
  background: rgba(255, 255, 255, 0.7);
  color: rgba(15, 23, 42, 0.85);
  cursor: pointer;
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  appearance: none;
  -webkit-appearance: none;
}

.heart-btn .heart-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  line-height: 0;
  flex: 0 0 auto;
}

.heart-btn .heart-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

html[data-theme='dark'] .heart-btn {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(15, 23, 42, 0.55);
  color: var(--ink);
}

.heart-btn:hover {
  transform: translateY(-1px);
}

.heart-btn.is-liked {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--love);
}

html[data-theme='dark'] .heart-btn.is-liked {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--love);
}

.content_main .music-section {
  width: 100%;
}

.content_main .playlist-section {
  width: 100%;
}

.content_main .profile-info {
  position: relative;
  display: flex;
}

.content_main .profile-header {
  justify-content: flex-start;
  text-align: left;
}

.content_main .profile-header.has-profile-action .profile-identity {
  padding-right: 0;
}

.content_main .profile-identity {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin-right: auto;
  width: 100%;
}

.content_main .profile-identity-top {
  --profile-identity-top-min-height: 88px;
  --profile-stats-max-width: 100%;
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  min-height: var(--profile-identity-top-min-height);
}

.content_main .profile-identity-main {
  display: flex;
  align-items: center;
  gap: 1rem;
  min-width: 0;
  max-width: calc(50% - 18px);
}

.content_main .profile-header .avatar-large {
  margin-bottom: 0;
  flex: 0 0 auto;
  align-self: center;
}

.content_main .profile-header .avatar-large.profile-image-shell {
  width: 104px;
  height: 104px;
  border-radius: 999px;
}

.content_main .profile-header .avatar-large.profile-image-shell::before {
  content: none;
}

.content_main .profile-follow {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  margin: -6px;
  padding: 6px;
  pointer-events: auto;
}

.content_main .profile-edit-shortcut {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  height: 34px;
  padding: 0 0.8rem;
  pointer-events: auto;
}

.content_main .profile-edit-shortcut-icon {
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
}

.content_main .profile-follow {
  margin: -6px;
}

.content_main .profile-follow button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  pointer-events: auto;
}

.follow-tab-toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.profile-media-tab-toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.content_main .follow-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  width: min(520px, 100%);
  margin: 0 auto;
}

.content_main .follow-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 240px;
  min-width: 0;
  height: 34px;
  padding: 0 0.9rem;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.2);
  background: rgba(255, 255, 255, 0.7);
  color: rgba(15, 23, 42, 0.8);
  cursor: pointer;
  font-weight: 800;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

@media (max-width: 980px) {
  .content_main .follow-tabs {
    flex-wrap: nowrap;
  }

  .content_main .follow-tab {
    flex: 1 1 0;
    min-width: 0;
  }
}

html[data-theme='dark'] .content_main .follow-tab {
  border-color: rgba(226, 232, 240, 0.18);
  background: rgba(15, 23, 42, 0.55);
  color: var(--ink);
}

#follow-tab-following:checked~.follow-tabs label[for='follow-tab-following'],
#follow-tab-followers:checked~.follow-tabs label[for='follow-tab-followers'] {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  color: rgba(15, 23, 42, 0.92);
}

html[data-theme='dark'] #follow-tab-following:checked~.follow-tabs label[for='follow-tab-following'],
html[data-theme='dark'] #follow-tab-followers:checked~.follow-tabs label[for='follow-tab-followers'] {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

.content_main .follow-panels {
  margin-top: 0.8rem;
  width: min(520px, 100%);
  margin-left: auto;
  margin-right: auto;
}

.content_main .profile-media-panels {
  margin-top: 0.2rem;
}

.content_main .profile-media-panel {
  display: none;
}

#profile-media-tab-ratings:checked~.profile-media-panels .profile-media-panel-ratings {
  display: block;
}

#profile-media-tab-playlists:checked~.profile-media-panels .profile-media-panel-playlists {
  display: block;
}

#profile-media-tab-favorites:checked~.profile-media-panels .profile-media-panel-favorites {
  display: block;
}

#profile-media-tab-ratings:checked~.profile-media-tabs label[for='profile-media-tab-ratings'],
#profile-media-tab-playlists:checked~.profile-media-tabs label[for='profile-media-tab-playlists'],
#profile-media-tab-favorites:checked~.profile-media-tabs label[for='profile-media-tab-favorites'] {
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
  color: rgba(15, 23, 42, 0.92);
}

html[data-theme='dark'] #profile-media-tab-ratings:checked~.profile-media-tabs label[for='profile-media-tab-ratings'],
html[data-theme='dark'] #profile-media-tab-playlists:checked~.profile-media-tabs label[for='profile-media-tab-playlists'],
html[data-theme='dark'] #profile-media-tab-favorites:checked~.profile-media-tabs label[for='profile-media-tab-favorites'] {
  background:
    linear-gradient(rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.72)) padding-box,
    var(--brand-gradient) border-box;
  color: var(--ink);
}

.content_main .follow-panel {
  display: none;
}

#follow-tab-following:checked~.follow-panels .follow-panel-following {
  display: block;
}

#follow-tab-followers:checked~.follow-panels .follow-panel-followers {
  display: block;
}

.content_main .follow-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.content_main .follow-item {
  display: block;
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  cursor: default;
}

.content_main .follow-item:hover {
  transform: none;
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

.content_main .follow-user-link {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  padding: 0.6rem 0.75rem;
  height: auto;
  line-height: normal;
  border-radius: 12px;
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-sm);
  transition:
    transform 120ms ease,
    box-shadow 140ms ease;
}

html[data-theme='dark'] .content_main .follow-user-link {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main .follow-user-link:hover {
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.content_main .follow-username {
  font-weight: 900;
}

.content_main .profile-identity-text {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  min-width: 0;
  align-self: center;
}

.content_main .profile-cred {
  display: flex;
  align-items: center;
  gap: 6px;
}

.content_main .profile-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.1rem;
  row-gap: 0.55rem;
  flex-wrap: wrap;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: fit-content;
  max-width: min(100%, var(--profile-stats-max-width));
}

.content_main .profile-stat-link {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.24rem;
  min-width: 84px;
  padding: 0.46rem 0.72rem;
  margin: 0;
  color: inherit;
  text-decoration: none;
  line-height: 1.1;
  text-align: center;
  border-radius: 10px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.78)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  box-shadow: var(--shadow-sm);
  transition: opacity 140ms ease, transform 140ms ease, box-shadow 140ms ease;
}

.content_main .profile-stat-link:hover {
  text-decoration: none;
  opacity: 1;
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

html[data-theme='dark'] .content_main .profile-stat-link {
  background:
    linear-gradient(rgba(15, 23, 42, 0.78), rgba(15, 23, 42, 0.78)) padding-box,
    var(--brand-gradient-soft-border) border-box;
}

.content_main .profile-stat-link:focus-visible {
  outline: none;
  box-shadow: var(--ring);
  border-radius: 10px;
}

.content_main .profile-stat-value {
  font-size: 1.38rem;
  font-weight: 900;
  letter-spacing: 0.01em;
  color: var(--ink);
}

.content_main .profile-stat-label {
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--subtle);
}

.content_main .profile-about-inline {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  margin-top: 0.12rem;
  width: 100%;
  min-width: 0;
  align-self: center;
  text-align: center;
}

.content_main .profile-about-inline .profile-value-about {
  display: inline-block;
  max-width: min(100%, 56ch);
  padding: 0.45rem 0.8rem;
  border-radius: 14px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.84), rgba(255, 255, 255, 0.84)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  border: 1px solid transparent;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

html[data-theme='dark'] .content_main .profile-about-inline .profile-value-about {
  background:
    linear-gradient(rgba(15, 23, 42, 0.56), rgba(15, 23, 42, 0.56)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  border-color: transparent;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
}

.content_main .profile-mobile-shortcuts {
  display: none;
}


.content_main .profile-identity-top.is-stacked {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  gap: 0.75rem;
  min-height: 0;
}

.content_main .profile-identity-top.is-stacked .profile-identity-main {
  max-width: none;
}

.content_main .profile-identity-top.is-stacked .profile-stats {
  position: static;
  left: auto;
  top: auto;
  transform: none;
  gap: 0.9rem;
  justify-content: center;
  width: 100%;
  max-width: none;
  margin: 0 auto;
}

@media (max-width: 980px) {
  .content_main .profile-stack {
    gap: 8px;
  }

  .content_main .profile-stats {
    display: none !important;
  }

  .content_main .profile-mobile-shortcuts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.72rem;
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
  }

  .content_main .profile-mobile-shortcut {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    min-width: 0;
    min-height: 52px;
    padding: 0.86rem 0.94rem;
    border-radius: 18px;
    border: 1px solid transparent;
    background:
      linear-gradient(rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.94)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
    color: var(--ink);
    text-decoration: none;
  }

  .content_main .profile-mobile-shortcut:hover,
  .content_main .profile-mobile-shortcut:active {
    color: var(--ink);
    text-decoration: none;
  }

  .content_main .profile-mobile-shortcut-label {
    min-width: 0;
    font-size: 0.84rem;
    font-weight: 800;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    white-space: nowrap;
    color: var(--ink);
  }

  .content_main .profile-mobile-shortcut-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    min-width: 1.4rem;
    height: 1.4rem;
    padding: 0 0.3rem;
    border-radius: 999px;
    background: var(--brand-gradient);
    color: #eff6ff;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    line-height: 1.4rem;
    text-align: center;
    box-shadow: 0 6px 12px rgb(var(--brand-2-rgb) / 0.2);
    flex: 0 0 auto;
  }

  html[data-theme='dark'] .content_main .profile-mobile-shortcut {
    background:
      linear-gradient(rgba(15, 23, 42, 0.82), rgba(15, 23, 42, 0.82)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: 0 12px 28px rgba(2, 6, 23, 0.4);
    color: var(--ink);
  }

  .content_main .profile-header .avatar-large {
    width: 84px;
    height: 84px;
  }

  .content_main .profile-header .avatar-large img,
  .content_main .profile-header .avatar-large .avatar-placeholder {
    width: 84px;
    height: 84px;
  }

  .content_main .profile-header .avatar-large .avatar-placeholder {
    font-size: 2.1rem;
  }

  .content_main .profile-identity-top {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    min-height: var(--profile-identity-top-min-height) !important;
    padding-top: 0 !important;
  }

  .content_main .profile-identity-main {
    display: flex !important;
    align-items: center !important;
    flex: 0 1 auto !important;
    min-width: 0 !important;
    max-width: calc(50% - 18px) !important;
    width: auto !important;
    gap: 0.75rem !important;
  }

  .content_main .profile-stat-link {
    min-width: 58px;
    gap: 0.14rem;
  }

  .content_main .profile-stat-value {
    font-size: 1.02rem;
  }

  .content_main .profile-stat-label {
    font-size: 0.72rem;
  }
}

@media (max-width: 640px) {
  .content_main .profile-header.has-profile-action .profile-identity {
    padding-right: 0;
    padding-top: 0;
  }

  .content_main .profile-identity-top {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
  }

  .content_main .profile-identity-main {
    flex: 0 1 auto !important;
    max-width: calc(50% - 18px) !important;
    width: auto !important;
    justify-content: flex-start !important;
    align-self: center !important;
  }

  .content_main .profile-header.has-profile-action .profile-identity-main {
    padding-right: 0;
  }

  .content_main .profile-header .avatar-large {
    align-self: center;
    width: 84px;
    height: 84px;
  }

  .content_main .profile-header .avatar-large img,
  .content_main .profile-header .avatar-large .avatar-placeholder {
    width: 84px;
    height: 84px;
  }

  .content_main .profile-header .avatar-large .avatar-placeholder {
    font-size: 2.1rem;
  }

  .content_main .profile-identity-text {
    align-self: center;
    align-items: flex-start;
    text-align: left;
  }

  .content_main .profile-stats {
    display: none !important;
  }

}

.content_main .profile-username {
  font-weight: 900;
  background-image: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_main .profile-edit-card {
  flex-direction: column;
  gap: 0.85rem;
  align-items: center;
  text-align: left;
}

.content_main .profile-edit-actions {
  margin-top: 0.75rem;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.content_main .profile-edit-card .profile-label {
  display: block;
  margin-bottom: 0.35rem;
}

.content_main .profile-edit-field {
  width: min(520px, 100%);
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.content_main .profile-edit-input {
  width: 100%;
  max-width: none;
  display: block;
  min-height: 72px;
  resize: vertical;
}

.content_main .profile-edit-input.is-compact {
  min-height: 48px;
}

.btn-remove-avatar {
  position: absolute;
  top: 100px;
  right: 190px;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.08);
  color: rgba(239, 68, 68, 0.95);
  font-size: 1.2rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

.btn-remove-avatar:hover {
  background: #dc2626;
  border-color: #dc2626;
  color: #fff;
}

.btn-remove-avatar .btn-remove-icon {
  display: inline-block;
  transform: translateY(-1px);
}

.content_main .profile-title {
  text-align: center;
}

.content_main .avatar-large .avatar-placeholder {
  background: rgba(15, 23, 42, 0.06);
  color: var(--ink);
  border: 1px solid var(--border);
}

.content_main .profile-section-title {
  margin: 0 0 0.6rem 0;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 900;
  color: var(--subtle);
}

.content_main .profile-upload-form {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  align-items: center;
  text-align: center;
  position: relative;
}

.content_main .edit-profile-form {
  width: 100%;
  max-width: 800px;
}

.content_main .profile-upload-form input[type='file'] {
  width: min(420px, 100%);
}

.content_main .profile-upload-form .btn-remove-avatar {
  top: auto;
  right: -20px;
  bottom: -10px;
}

.content_main .profile-actions {
  align-items: center;
  justify-content: flex-start;
  margin: 0.25rem 0 0 0;
  flex-wrap: wrap;
}

.content_main.ratings-container .rating-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px;
  justify-items: center;
}

.content_main.ratings-container .rating-list li {
  position: relative;
  overflow: hidden;
  padding: 0;
  border-radius: 20px;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  width: 100%;
  max-width: min(1080px, 100%);
}

.content_main.ratings-container .rating-list .rating-card-art {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 220px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.22), transparent 52%),
    linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(51, 65, 85, 0.86));
}

.content_main.ratings-container .rating-list .rating-card-art::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('/static/no_img.png') center / clamp(120px, 28%, 220px) no-repeat;
  opacity: 0.9;
  pointer-events: none;
}

.content_main.ratings-container .rating-list .rating-card-art img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.content_main.ratings-container .rating-list .rating-card-art.is-empty {
  background: linear-gradient(135deg, rgba(2, 6, 23, 0.98), rgba(15, 23, 42, 0.94));
}

.content_main.ratings-container .rating-list .rating-card-art.is-empty::before {
  content: none;
}

.content_main.ratings-container .rating-list .rating-card-art.is-empty .rating-card-art-default {
  position: relative;
  z-index: 1;
  width: min(52%, 220px);
  height: auto;
  object-fit: contain;
  opacity: 0.92;
  filter: drop-shadow(0 14px 28px rgba(0, 0, 0, 0.34));
}

.content_main.ratings-container .rating-list .rating-card-art::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.06), rgba(15, 23, 42, 0.32));
  pointer-events: none;
}

.content_main.ratings-container .rating-list .rating-card-art.is-empty::after {
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.12), rgba(15, 23, 42, 0.4));
}

.content_main.ratings-container .rating-list .rating-card-owner {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  pointer-events: none;
}

.content_main.ratings-container .rating-list .rating-card-reactions {
  position: absolute;
  right: 24px;
  bottom: 24px;
  min-width: 54px;
  min-height: 54px;
  padding: 0.4rem 0.55rem;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  background: rgba(15, 23, 42, 0.42);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  box-shadow:
    0 12px 28px rgba(15, 23, 42, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: nowrap;
  gap: 6px;
  max-width: calc(100% - 100px);
  white-space: nowrap;
  pointer-events: none;
}

.content_main.ratings-container .rating-list .rating-card-reactions.is-single {
  justify-content: center;
  min-width: 56px;
  padding-left: 0.45rem;
  padding-right: 0.45rem;
}

.content_main.ratings-container .rating-list .rating-card-owner .avatar-wrap {
  width: 46px;
  height: 46px;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.24);
}

.content_main.ratings-container .rating-list .rating-card-owner .rating-owner {
  margin: 0;
  max-width: calc(100% - 56px);
  padding: 0.38rem 0.64rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.5);
  color: rgba(248, 250, 252, 0.92);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-text-fill-color: currentColor;
}

.content_main.ratings-container .rating-list .rating-card-art-label {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  padding: 0.38rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-md);
  font-size: 0.92rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(248, 250, 252, 0.92);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.content_main.ratings-container .rating-list .rating-card-body {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  flex: 1;
  min-width: 0;
  padding: 0.95rem 1rem 1rem;
}

.content_main.ratings-container .rating-list>li {
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main.ratings-container .rating-list>li:hover {
  background:
    linear-gradient(rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.88)) padding-box,
    var(--brand-gradient) border-box;
  border-color: transparent;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.14);
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li:hover {
  background:
    linear-gradient(rgba(15, 23, 42, 0.82), rgba(15, 23, 42, 0.82)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.content_main.ratings-container .rating-list>li.is-owner {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgb(var(--brand-1-rgb) / 0.12) 52%, rgb(var(--brand-2-rgb) / 0.16) 100%) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 12px 28px rgb(var(--brand-2-rgb) / 0.14);
}

.content_main.ratings-container .rating-list>li.is-owner:hover {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 1) 0%, rgb(var(--brand-1-rgb) / 0.18) 52%, rgb(var(--brand-2-rgb) / 0.24) 100%) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 14px 32px rgb(var(--brand-2-rgb) / 0.18);
}

.content_main.ratings-container .rating-list>li.is-owner .rating-card-art::after {
  background: linear-gradient(to bottom, rgb(var(--brand-1-rgb) / 0.05), rgb(var(--brand-2-rgb) / 0.28));
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner {
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.94) 0%, rgb(var(--brand-1-rgb) / 0.22) 52%, rgb(var(--brand-2-rgb) / 0.28) 100%) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.55);
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner:hover {
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.96) 0%, rgb(var(--brand-1-rgb) / 0.3) 52%, rgb(var(--brand-2-rgb) / 0.38) 100%) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner .rating-card-art::after {
  background: linear-gradient(to bottom, rgb(var(--brand-1-rgb) / 0.08), rgb(var(--brand-2-rgb) / 0.4));
}

.content_main.ratings-container .rating-list .rating-item-left {
  flex: 1;
  width: 100%;
  gap: 0.4rem;
  padding-right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.content_main.ratings-container .rating-list .rating-header {
  display: none;
}

.mobile-home-topbar-strip {
  display: none;
}

.mobile-home-topbar-strip .home-mobile-shortcuts {
  display: none;
}

@media (max-width: 980px) {
  body.has-home-mobile-shortcuts.home-mobile-shortcuts-visible navbar .nav-toggle-label .nav-toggle-count {
    opacity: 0;
    visibility: hidden;
  }

  body.has-home-mobile-shortcuts .content {
    grid-template-areas:
      'mobile_top'
      'content_main'
      'content_bottom'
      'content_left';
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto 0;
  }

  body.has-home-mobile-shortcuts .content > .mobile-home-topbar-strip {
    display: block;
    grid-area: mobile_top;
  }

  .mobile-home-topbar-strip .home-mobile-shortcuts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.72rem;
    width: calc(100% - 8px);
    margin: 0 4px;
  }

  .mobile-home-topbar-strip .home-mobile-shortcut {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    min-width: 0;
    min-height: 52px;
    padding: 0.86rem 1rem;
    border-radius: 18px;
    border: 1px solid transparent;
    background:
      linear-gradient(rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.94)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
    color: var(--ink);
    text-decoration: none;
  }

  .mobile-home-topbar-strip .home-mobile-shortcut:hover,
  .mobile-home-topbar-strip .home-mobile-shortcut:active {
    color: var(--ink);
    text-decoration: none;
  }

  .mobile-home-topbar-strip .home-mobile-shortcut-label {
    min-width: 0;
    font-size: 0.84rem;
    font-weight: 800;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    white-space: nowrap;
  }

  .mobile-home-topbar-strip .home-mobile-shortcut-count {
    flex-shrink: 0;
    min-width: 1.4rem;
    height: 1.4rem;
    padding: 0 0.34rem;
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 800;
    line-height: 1.4rem;
    text-align: center;
    box-shadow: 0 6px 12px rgba(15, 23, 42, 0.16);
  }

  .mobile-home-topbar-strip .home-mobile-shortcut-count.is-alert {
    background: linear-gradient(135deg, #fb7185 0%, #e11d48 100%);
    color: #fff1f2;
  }

  .mobile-home-topbar-strip .home-mobile-shortcut-count.is-activity {
    background: linear-gradient(135deg, #60a5fa 0%, #4f46e5 100%);
    color: #eff6ff;
  }

  html[data-theme='dark'] .mobile-home-topbar-strip .home-mobile-shortcut {
    background:
      linear-gradient(rgba(15, 23, 42, 0.82), rgba(15, 23, 42, 0.82)) padding-box,
      var(--brand-gradient) border-box;
    box-shadow: 0 12px 28px rgba(2, 6, 23, 0.4);
    color: var(--ink);
  }
}

.content_main.ratings-container .rating-list .rating-owner {
  margin: 0;
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background-image: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_main.ratings-container .rating-list .rating-item-actions {
  width: 100%;
  margin-left: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-end;
  gap: 6px;
  align-self: auto;
}

.content_main.ratings-container .rating-list li.is-owner .rating-item-actions {
  width: 100%;
  margin-left: 0;
  align-self: auto;
  flex-direction: row;
  align-items: flex-end;
  justify-content: flex-end;
  gap: 8px;
}

.content_main.ratings-container .rating-list .rating-item-text {
  font-size: 1.05rem;
  line-height: 1.35;
}

.content_main.ratings-container .rating-list .rating-title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 0.75rem;
  width: 100%;
}

.content_main.ratings-container .rating-list .rating-subject-line {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.2rem;
  margin: 0;
  min-width: 0;
  width: auto;
  line-height: 1;
}

.content_main.ratings-container:not(.charts-page) .rating-list .rating-subject-name {
  display: inline-flex;
  align-items: center;
  font-size: clamp(1.08rem, 1.35vw, 1.2rem);
  font-weight: 900;
  letter-spacing: 0.01em;
  margin-right: 0;
  padding: 0.14rem 0.5rem;
  border: 0;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.88);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  box-shadow: none;
  line-height: 1;
}

.content_main.ratings-container:not(.charts-page) .rating-list .rating-subject-name-text {
  display: inline-block;
  line-height: 1;
  color: transparent;
  background-image: var(--brand-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_main.ratings-container .rating-list .rating-subject-artist {
  display: inline-flex;
  align-items: center;
  align-self: center;
  line-height: 1;
}

.content_main.ratings-container .rating-list .rating-card-meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 0.85rem;
  width: 100%;
}

.content_main.ratings-container .rating-list .rating-card-meta-copy {
  min-width: 0;
}

.content_main.ratings-container .rating-list .rating-item-genre-row {
  margin: 0 0 0.36rem 0;
}

.content_main.ratings-container .rating-list .rating-item-genre-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.28rem;
  padding: 0.22rem 0.58rem;
  border-radius: 999px;
  background: rgba(2, 6, 23, 0.66);
  border: 1px solid rgba(96, 165, 250, 0.2);
  color: rgba(224, 231, 255, 0.88);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1;
}

.content_main.ratings-container .rating-list .rating-item-genre-pill b {
  color: #ffffff;
  font-weight: 900;
}

.content_main.ratings-container .rating-list .rating-item-metrics {
  display: block;
  min-width: 0;
  margin: 0;
  padding-left: 0.5rem;
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.94);
}

html[data-theme='light'] .content_main.ratings-container .rating-list .rating-item-metrics {
  color: rgba(15, 23, 42, 0.82);
}

.content_main.ratings-container .rating-list .rating-item-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: start;
  justify-self: end;
  width: auto;
  min-width: 88px;
  padding: 0.24rem 0.62rem;
  border-radius: 999px;
  border: 1px solid rgba(29, 78, 216, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(239, 246, 255, 0.96));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 2px rgba(15, 23, 42, 0.08);
  white-space: nowrap;
  text-align: center;
  font-size: 0.82rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  color: #1d4ed8;
  background-clip: border-box;
  -webkit-text-fill-color: currentColor;
}

html:not([data-theme='dark']) .content_main.ratings-container .rating-list>li.is-owner .rating-item-count {
  min-width: 0;
  padding: 0.22rem 0.58rem;
  border-radius: 999px;
  border: 1px solid rgba(29, 78, 216, 0.18);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.58), rgba(239, 246, 255, 0.84));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
  color: #1e40af;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  -webkit-text-fill-color: currentColor;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-item-count {
  border-color: rgba(103, 232, 249, 0.18);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.76), rgba(30, 41, 59, 0.9));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 1px 2px rgba(0, 0, 0, 0.24);
  color: #bfdbfe;
}

html[data-theme='dark'] .content_main.ratings-container:not(.charts-page) .rating-list .rating-subject-name {
  background: rgba(0, 0, 0, 0.88);
  box-shadow: none;
}

@media (max-width: 700px) {
  .content_main.ratings-container .rating-list .rating-card-art {
    aspect-ratio: 16 / 10;
    min-height: 164px;
  }

  .content_main.ratings-container .rating-list .rating-card-owner {
    left: 12px;
    right: 12px;
    bottom: 12px;
  }

  .content_main.ratings-container .rating-list .rating-card-reactions {
    right: 12px;
    bottom: 12px;
    min-width: 50px;
    min-height: 50px;
    padding: 0.35rem 0.5rem;
    max-width: none;
    flex-wrap: nowrap;
    gap: 7px;
  }

  .content_main.ratings-container .rating-list .rating-card-owner .avatar-wrap {
    width: 44px;
    height: 44px;
  }

  .content_main.ratings-container .rating-list .rating-card-owner .rating-owner {
    max-width: calc(100% - 54px);
    font-size: 0.68rem;
  }

  .content_main.ratings-container .rating-list .rating-card-body {
    padding: 0.95rem 1rem 1rem;
  }

  .content_main.ratings-container .rating-list .rating-item-text {
    width: 100%;
  }

  .content_main.ratings-container .rating-list .rating-title-row {
    gap: 0.55rem;
  }

  .content_main.ratings-container:not(.charts-page) .rating-list .rating-subject-name {
    font-size: 1.06rem;
  }

  .content_main.ratings-container .rating-list .rating-item-count {
    min-width: 76px;
  }

  .content_main.ratings-container .rating-list .rating-card-meta {
    gap: 0.6rem;
  }

  .content_main.ratings-container .rating-list .rating-item-metrics {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.94);
  }

  .content_main.ratings-container .rating-list .rating-item-count {
    font-size: 0.74rem;
  }

  .content_main.ratings-container .rating-list .rating-item-actions {
    width: 100%;
    margin-left: 0;
    align-items: flex-end;
    justify-content: flex-end;
    align-self: auto;
  }

  .content_main.ratings-container .rating-list li.is-owner .rating-item-actions {
    width: 100%;
    margin-left: 0;
    align-self: auto;
    flex-direction: row;
    justify-content: flex-end;
    gap: 8px;
  }

  .content_main.ratings-container .rating-list .rating-percent {
    top: 12px;
    right: 12px;
    z-index: 2;
  }

  .content_main.ratings-container .rating-list .rating-reactions {
    position: static;
    width: auto;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-top: 0.55rem;
    gap: 8px;
  }

  .content_main.ratings-container .rating-list li.is-owner .rating-percent,
  .content_main.ratings-container .rating-list li.is-owner .rating-reactions {
    opacity: 1;
    visibility: visible;
  }
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-card-art {
  background:
    radial-gradient(circle at top left, rgba(148, 163, 184, 0.16), transparent 54%),
    linear-gradient(135deg, rgba(0, 0, 0, 0.96), rgba(15, 23, 42, 0.9));
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-card-art.is-empty {
  background: linear-gradient(135deg, rgba(0, 0, 0, 0.99), rgba(15, 23, 42, 0.96));
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-card-owner .rating-owner {
  background: rgba(0, 0, 0, 0.62);
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-card-art::after {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.4));
}

html[data-theme='dark'] .rating-hero .rating-card-art-label,
html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-card-art-label {
  background: rgba(0, 0, 0, 0.62);
  border-color: rgba(255, 255, 255, 0.2);
}

html[data-theme='dark'] .rating-hero .rating-card-art.is-empty {
  background: linear-gradient(135deg, rgba(2, 6, 23, 0.98), rgba(15, 23, 42, 0.94));
}

html[data-theme='dark'] .rating-hero .rating-card-art::after {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.4));
}

.content_main.ratings-container .rating-list .rating-item-text small {
  font-size: 0.95rem;
}

.content_main.ratings-container .rating-list .rating-owner-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
}

.content_main.ratings-container .rating-list .rating-owner-inline .rating-owner-name {
  background-image: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_main.ratings-container .rating-list .rating-owner-inline .rating-owner-separator,
.content_main.ratings-container .rating-list .rating-owner-inline .rating-owner-emoji {
  background: none;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  -webkit-text-fill-color: var(--ink);
  color: var(--ink);
  letter-spacing: normal;
  text-transform: none;
}

.content_main.ratings-container .also-rated-list-simple .rating-item-left {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
}

.content_main.ratings-container .also-rated-list-simple>li {
  padding: 1.2rem 3.2rem 1.2rem 1rem;
  min-height: 118px;
}

.content_main.ratings-container .also-rated-list-simple {
  gap: 6px;
}

.content_main.ratings-container .also-rated-list-simple .rating-item-text {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.24rem;
}

.content_main.ratings-container .search-rating-results > li {
  min-height: 146px;
}

.content_main.ratings-container .search-rating-results .rating-item-left {
  gap: 1rem;
}

.content_main.ratings-container .search-rating-results .rating-cover-wrap {
  width: 80px;
  height: 80px;
  border-radius: 18px;
}

.content_main.ratings-container .search-playlist-results > li {
  min-height: 146px;
}

.content_main.ratings-container .search-playlist-results .rating-item-left {
  gap: 1rem !important;
}

.content_main.ratings-container .search-playlist-results .rating-cover-wrap {
  width: 80px;
  height: 80px;
  border-radius: 18px;
}

.content_main.ratings-container .also-rated-list-simple .rating-owner {
  margin: 0;
}

.content_main.ratings-container .also-rated-list-simple .rating-card-meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 0.85rem;
  width: 100%;
}

.content_main.ratings-container .also-rated-list-simple .search-playlist-favorite-badge {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.36rem;
  min-height: 34px;
  padding: 0.38rem 0.62rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: var(--shadow-sm);
  white-space: nowrap;
  color: var(--subtle);
}

.content_main.ratings-container .also-rated-list-simple .search-playlist-favorite-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  line-height: 0;
  color: #f472b6;
}

.content_main.ratings-container .also-rated-list-simple .search-playlist-favorite-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.content_main.ratings-container .also-rated-list-simple .search-playlist-favorite-count {
  font-size: 0.88rem;
  font-weight: 900;
  color: var(--subtle);
}

html[data-theme='dark'] .content_main.ratings-container .also-rated-list-simple .search-playlist-favorite-badge {
  background: rgba(15, 23, 42, 0.68);
}

.content_main.ratings-container .rating-list .rating-percent {
  position: absolute;
  top: 12px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 0.4rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(15, 23, 42, 0.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
  font-weight: 900;
  font-size: 1rem;
  color: rgba(248, 250, 252, 0.96);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
  pointer-events: none;
  z-index: 2;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-percent {
  border-color: rgba(255, 255, 255, 0.16);
  background: rgba(0, 0, 0, 0.58);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.45);
  color: rgba(248, 250, 252, 0.98);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

.content_main.ratings-container .rating-list .rating-reactions {
  position: static;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 0.55rem;
  width: auto;
}

.content_main.ratings-container .rating-list .rating-emoji {
  font-size: 1.35rem;
  opacity: 1;
  line-height: 1;
}

.content_main .rating-list li.is-owner .rating-percent,
.content_main .rating-list li.is-owner .rating-reactions {
  opacity: 1;
  visibility: visible;
}

.rating-detail-head .rating-percent {
  font-weight: 900;
  font-size: 1.06rem;
  letter-spacing: 0.02em;
  color: rgba(248, 250, 252, 0.96);
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(15, 23, 42, 0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

html[data-theme='dark'] .rating-detail-head .rating-percent {
  border-color: rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.52);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
  color: rgba(248, 250, 252, 0.98);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}

.content_main.ratings-container .rating-list .rating-percent.is-score-high,
.content_main.gradient-container .rating-list .rating-percent.is-score-high,
.rating-detail-head .rating-percent.is-score-high {
  color: #4ade80;
}

.content_main.ratings-container .rating-list .rating-percent.is-score-mid,
.content_main.gradient-container .rating-list .rating-percent.is-score-mid,
.rating-detail-head .rating-percent.is-score-mid {
  color: #fde047;
}

.content_main.ratings-container .rating-list .rating-percent.is-score-low,
.content_main.gradient-container .rating-list .rating-percent.is-score-low,
.rating-detail-head .rating-percent.is-score-low {
  color: #fb923c;
}

.content_main.ratings-container .rating-list .rating-percent.is-score-poor,
.content_main.gradient-container .rating-list .rating-percent.is-score-poor,
.rating-detail-head .rating-percent.is-score-poor {
  color: #f87171;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-percent.is-score-high,
html[data-theme='dark'] .content_main.gradient-container .rating-list .rating-percent.is-score-high,
html[data-theme='dark'] .rating-detail-head .rating-percent.is-score-high {
  color: #86efac;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-percent.is-score-mid,
html[data-theme='dark'] .content_main.gradient-container .rating-list .rating-percent.is-score-mid,
html[data-theme='dark'] .rating-detail-head .rating-percent.is-score-mid {
  color: #fef08a;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-percent.is-score-low,
html[data-theme='dark'] .content_main.gradient-container .rating-list .rating-percent.is-score-low,
html[data-theme='dark'] .rating-detail-head .rating-percent.is-score-low {
  color: #fdba74;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list .rating-percent.is-score-poor,
html[data-theme='dark'] .content_main.gradient-container .rating-list .rating-percent.is-score-poor,
html[data-theme='dark'] .rating-detail-head .rating-percent.is-score-poor {
  color: #fca5a5;
}

.content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-high {
  color: #4ade80;
}

.content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-mid {
  color: #fde047;
}

.content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-low {
  color: #fb923c;
}

.content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-poor {
  color: #f87171;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-high {
  color: #86efac;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-mid {
  color: #fef08a;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-low {
  color: #fdba74;
}

html[data-theme='dark'] .content_main.ratings-container .rating-list>li.is-owner .rating-percent.is-score-poor {
  color: #fca5a5;
}

.charts-content-bottom .pagination-bar {
  width: min(1080px, 100%);
}

.content_main.charts-page .charts-toolbar-stack {
  margin-bottom: 0.25rem;
}

.content_main.charts-page .charts-tabs-row {
  margin-bottom: 1rem;
}

.content_main.charts-page .activity-genre-form select {
  width: min(220px, 100%);
  min-width: 0;
}

.content_main.charts-page .chart-rating-list {
  gap: 18px;
}

.content_main.charts-page .chart-rating-list>li {
  position: relative;
  isolation: isolate;
  --chart-shell-gap: clamp(82px, 7vw, 96px);
  max-width: min(1080px, 100%);
  padding: var(--chart-shell-gap);
  overflow: hidden;
  border: 2px solid transparent;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgb(147, 197, 253) 0%, rgb(96, 165, 250) 48%, rgb(29, 78, 216) 100%) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-sm);
}

.content_main.charts-page .chart-bg-emojis {
  --chart-bg-emoji-size: clamp(44px, 6vw, 72px);
  --chart-bg-rain-speed: 14s;
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

.content_main.charts-page .chart-bg-emoji {
  position: absolute;
  display: block;
  width: var(--chart-bg-emoji-size);
  aspect-ratio: 1 / 1;
  opacity: var(--chart-bg-emoji-opacity, 0.28);
  background-image: var(--chart-bg-emoji-gradient, linear-gradient(135deg, var(--chart-rank-emoji-accent-start) 0%, var(--chart-rank-emoji-accent-end) 100%));
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-mask-image: var(--chart-bg-emoji-url);
  mask-image: var(--chart-bg-emoji-url);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  filter: drop-shadow(0 6px 14px rgba(15, 23, 42, 0.24));
  transform-origin: center;
  will-change: transform;
}

.content_main.charts-page .chart-bg-emoji:nth-child(1) {
  top: -108px;
  left: -8%;
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite 0s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(2) {
  top: -92px;
  left: -2%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.03);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -6s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(3) {
  top: -118px;
  left: 4%;
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -12s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(4) {
  top: -100px;
  left: 10%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.04);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -3s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(5) {
  top: -112px;
  left: 18%;
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -9s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(6) {
  top: -88px;
  left: 26%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.05);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -15s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(7) {
  top: -120px;
  left: 34%;
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -1.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(8) {
  top: -98px;
  left: 42%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.04);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -7.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(9) {
  top: -110px;
  left: 46%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.04);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -13.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(10) {
  top: -86px;
  left: 52%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.05);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -4.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(11) {
  top: -116px;
  left: 58%;
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -10.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(12) {
  top: -96px;
  left: 64%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.05);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -16.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(13) {
  top: -122px;
  left: 70%;
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -2.25s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(14) {
  top: -90px;
  left: 76%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.05);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -8.25s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(15) {
  top: -114px;
  left: 82%;
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -14.25s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(16) {
  top: -102px;
  left: 88%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.06);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -5.25s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(17) {
  top: -124px;
  left: 94%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.06);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -11.25s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(18) {
  top: -94px;
  left: 100%;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.06);
  animation: chart-bg-track-top var(--chart-bg-rain-speed) linear infinite -17.25s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(19) {
  top: calc(var(--chart-shell-gap) - 28px);
  left: -110px;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.04);
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -3.75s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(20) {
  top: calc(var(--chart-shell-gap) + 2px);
  left: -92px;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.05);
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -9.75s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(21) {
  top: calc(var(--chart-shell-gap) + 34px);
  left: -104px;
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -15.75s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(22) {
  top: calc(var(--chart-shell-gap) + 66px);
  left: -88px;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.05);
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -6.75s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(23) {
  top: calc(var(--chart-shell-gap) + 98px);
  left: -114px;
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -12.75s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(24) {
  top: calc(var(--chart-shell-gap) + 130px);
  left: -96px;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.05);
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -0.75s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(25) {
  top: calc(var(--chart-shell-gap) + 162px);
  left: -106px;
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -4.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(26) {
  top: calc(var(--chart-shell-gap) + 194px);
  left: -90px;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.06);
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -10.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(27) {
  top: calc(var(--chart-shell-gap) + 226px);
  left: -112px;
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -16.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(28) {
  top: calc(var(--chart-shell-gap) + 258px);
  left: -94px;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.06);
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -7.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(29) {
  top: calc(var(--chart-shell-gap) + 290px);
  left: -108px;
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -13.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(30) {
  top: calc(var(--chart-shell-gap) + 322px);
  left: -98px;
  opacity: calc(var(--chart-bg-emoji-opacity, 0.12) - 0.06);
  animation: chart-bg-track-side var(--chart-bg-rain-speed) linear infinite -1.5s;
}

.content_main.charts-page .chart-bg-emoji:nth-child(n) {
  width: var(--chart-bg-emoji-size);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li {
  background:
    linear-gradient(135deg, rgb(30, 64, 175) 0%, rgb(30, 58, 138) 52%, rgb(30, 41, 59) 100%) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-bg-emoji {
  filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.22));
}

.content_main.charts-page .chart-rating-list>li:hover,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li:hover {
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.14);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank {
  background:
    linear-gradient(135deg, rgba(253, 230, 138, 0.98) 0%, rgba(251, 191, 36, 0.88) 48%, rgba(180, 83, 9, 0.44) 100%) padding-box,
    linear-gradient(135deg, #fde68a 0%, #f59e0b 52%, #92400e 100%) border-box;
  box-shadow: 0 12px 28px rgba(180, 83, 9, 0.14);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank:hover {
  background:
    linear-gradient(135deg, rgba(252, 211, 77, 0.98) 0%, rgba(251, 191, 36, 0.94) 48%, rgba(194, 65, 12, 0.52) 100%) padding-box,
    linear-gradient(135deg, #fde68a 0%, #ea580c 52%, #7c2d12 100%) border-box;
  box-shadow: 0 14px 32px rgba(180, 83, 9, 0.18);
}

.content_main.charts-page .chart-rating-list>li.is-second-rank {
  background:
    linear-gradient(135deg, rgba(226, 232, 240, 0.99) 0%, rgba(203, 213, 225, 0.94) 48%, rgba(71, 85, 105, 0.42) 100%) padding-box,
    linear-gradient(135deg, #e2e8f0 0%, #94a3b8 52%, #475569 100%) border-box;
  box-shadow: 0 12px 28px rgba(71, 85, 105, 0.14);
}

.content_main.charts-page .chart-rating-list>li.is-second-rank:hover {
  background:
    linear-gradient(135deg, rgba(203, 213, 225, 1) 0%, rgba(226, 232, 240, 0.98) 48%, rgba(51, 65, 85, 0.5) 100%) padding-box,
    linear-gradient(135deg, #f8fafc 0%, #94a3b8 52%, #334155 100%) border-box;
  box-shadow: 0 14px 32px rgba(71, 85, 105, 0.18);
}

.content_main.charts-page .chart-rating-list>li.is-third-rank {
  background:
    linear-gradient(135deg, rgba(243, 225, 208, 0.99) 0%, rgba(216, 169, 126, 0.94) 48%, rgba(107, 66, 38, 0.48) 100%) padding-box,
    linear-gradient(135deg, #e3c3a4 0%, #b87333 52%, #6b4226 100%) border-box;
  box-shadow: 0 12px 28px rgba(120, 68, 34, 0.14);
}

.content_main.charts-page .chart-rating-list>li.is-third-rank:hover {
  background:
    linear-gradient(135deg, rgba(232, 196, 163, 0.99) 0%, rgba(198, 128, 65, 0.96) 48%, rgba(107, 66, 38, 0.56) 100%) padding-box,
    linear-gradient(135deg, #f0d5bb 0%, #c68041 52%, #6b4226 100%) border-box;
  box-shadow: 0 14px 32px rgba(120, 68, 34, 0.18);
}

.content_main.charts-page .chart-card-shell {
  position: relative;
  z-index: 2;
  overflow: hidden;
  border-radius: 20px;
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-sm);
  min-width: 0;
}

@keyframes chart-bg-track-top {
  0% { transform: translate3d(0, 0, 0) rotate(-9deg) scale(1); }
  100% { transform: translate3d(980px, 820px, 0) rotate(-9deg) scale(1); }
}

@keyframes chart-bg-track-top-reverse {
  0% { transform: translate3d(0, 0, 0) rotate(10deg) scale(0.96); }
  50% { transform: translate3d(332px, 252px, 0) rotate(2deg) scale(1.03); }
  100% { transform: translate3d(900px, 760px, 0) rotate(-6deg) scale(0.98); }
}

@keyframes chart-bg-track-side {
  0% { transform: translate3d(0, 0, 0) rotate(-9deg) scale(1); }
  100% { transform: translate3d(980px, 820px, 0) rotate(-9deg) scale(1); }
}

@keyframes chart-bg-track-side-reverse {
  0% { transform: translate3d(0, 0, 0) rotate(12deg) scale(0.94); }
  50% { transform: translate3d(368px, 266px, 0) rotate(3deg) scale(1.03); }
  100% { transform: translate3d(940px, 710px, 0) rotate(-8deg) scale(0.99); }
}

@keyframes chart-bg-track-bottom {
  0% { transform: translate3d(0, 0, 0) rotate(8deg) scale(0.96); }
  50% { transform: translate3d(164px, 18px, 0) rotate(-1deg) scale(1.03); }
  100% { transform: translate3d(520px, 72px, 0) rotate(-8deg) scale(0.98); }
}

@keyframes chart-bg-track-bottom-reverse {
  0% { transform: translate3d(0, 0, 0) rotate(-10deg) scale(0.94); }
  50% { transform: translate3d(176px, 16px, 0) rotate(2deg) scale(1.02); }
  100% { transform: translate3d(540px, 74px, 0) rotate(8deg) scale(1); }
}

html[data-theme='dark'] .content_main.charts-page .chart-card-shell {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main.charts-page .chart-rating-list>li:hover .chart-card-shell {
  background:
    linear-gradient(rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.88)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.14);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li:hover .chart-card-shell {
  background:
    linear-gradient(rgba(15, 23, 42, 0.82), rgba(15, 23, 42, 0.82)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(255, 251, 235, 0.98) 0%, rgba(255, 246, 196, 0.96) 52%, rgba(254, 240, 138, 0.9) 100%) padding-box,
    linear-gradient(135deg, #fde68a 0%, #f59e0b 52%, #92400e 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-top-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 251, 235, 0.08) 0%, rgba(217, 119, 6, 0.18) 48%, rgba(120, 53, 15, 0.34) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(255, 251, 235, 1) 0%, rgba(255, 248, 214, 0.98) 52%, rgba(253, 224, 71, 0.94) 100%) padding-box,
    linear-gradient(135deg, #fde68a 0%, #ea580c 52%, #7c2d12 100%) border-box;
  box-shadow: 0 12px 28px rgba(180, 83, 9, 0.16);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 251, 235, 0.1) 0%, rgba(234, 88, 12, 0.2) 48%, rgba(124, 45, 18, 0.38) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-second-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(248, 250, 252, 0.98) 0%, rgba(241, 245, 249, 0.96) 52%, rgba(226, 232, 240, 0.9) 100%) padding-box,
    linear-gradient(135deg, #e2e8f0 0%, #94a3b8 52%, #475569 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-second-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(148, 163, 184, 0.18) 48%, rgba(51, 65, 85, 0.32) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 1) 0%, rgba(248, 250, 252, 0.98) 52%, rgba(226, 232, 240, 0.94) 100%) padding-box,
    linear-gradient(135deg, #f8fafc 0%, #94a3b8 52%, #334155 100%) border-box;
  box-shadow: 0 12px 28px rgba(71, 85, 105, 0.16);
}

.content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(148, 163, 184, 0.22) 48%, rgba(30, 41, 59, 0.36) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-third-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(250, 241, 233, 0.98) 0%, rgba(240, 220, 201, 0.96) 52%, rgba(214, 181, 152, 0.9) 100%) padding-box,
    linear-gradient(135deg, #e3c3a4 0%, #b87333 52%, #6b4226 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-third-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(248, 230, 215, 0.08) 0%, rgba(184, 115, 51, 0.18) 48%, rgba(107, 66, 38, 0.34) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(252, 245, 239, 1) 0%, rgba(243, 225, 208, 0.98) 52%, rgba(198, 151, 113, 0.94) 100%) padding-box,
    linear-gradient(135deg, #f0d5bb 0%, #c68041 52%, #6b4226 100%) border-box;
  box-shadow: 0 12px 28px rgba(120, 68, 34, 0.16);
}

.content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(251, 237, 226, 0.1) 0%, rgba(198, 128, 65, 0.2) 48%, rgba(107, 66, 38, 0.38) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank {
  background:
    linear-gradient(135deg, rgba(69, 39, 5, 0.92) 0%, rgba(120, 53, 15, 0.9) 52%, rgba(41, 24, 1, 0.96) 100%) padding-box,
    linear-gradient(135deg, rgba(253, 224, 71, 0.98) 0%, rgba(245, 158, 11, 0.98) 52%, rgba(180, 83, 9, 0.98) 100%) border-box;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.55);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:hover {
  background:
    linear-gradient(135deg, rgba(94, 47, 8, 0.94) 0%, rgba(146, 64, 14, 0.92) 52%, rgba(55, 27, 4, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(254, 240, 138, 1) 0%, rgba(251, 191, 36, 1) 52%, rgba(194, 65, 12, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank {
  background:
    linear-gradient(135deg, rgba(71, 85, 105, 0.94) 0%, rgba(51, 65, 85, 0.92) 52%, rgba(15, 23, 42, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(226, 232, 240, 0.98) 0%, rgba(148, 163, 184, 0.98) 52%, rgba(71, 85, 105, 0.98) 100%) border-box;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.55);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:hover {
  background:
    linear-gradient(135deg, rgba(100, 116, 139, 0.96) 0%, rgba(71, 85, 105, 0.94) 52%, rgba(30, 41, 59, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(248, 250, 252, 1) 0%, rgba(148, 163, 184, 1) 52%, rgba(51, 65, 85, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank {
  background:
    linear-gradient(135deg, rgba(88, 55, 33, 0.96) 0%, rgba(117, 74, 43, 0.94) 52%, rgba(52, 31, 18, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(227, 195, 164, 0.98) 0%, rgba(184, 115, 51, 0.98) 52%, rgba(107, 66, 38, 0.98) 100%) border-box;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.55);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank:hover {
  background:
    linear-gradient(135deg, rgba(111, 68, 39, 0.96) 0%, rgba(145, 90, 52, 0.94) 52%, rgba(67, 40, 23, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(240, 213, 187, 1) 0%, rgba(198, 128, 65, 1) 52%, rgba(107, 66, 38, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(72, 38, 6, 0.96) 0%, rgba(101, 46, 11, 0.94) 52%, rgba(52, 27, 4, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(253, 224, 71, 0.98) 0%, rgba(245, 158, 11, 0.98) 52%, rgba(180, 83, 9, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(253, 224, 71, 0.08) 0%, rgba(180, 83, 9, 0.2) 48%, rgba(69, 26, 3, 0.42) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(94, 47, 8, 0.96) 0%, rgba(129, 57, 14, 0.94) 52%, rgba(65, 31, 5, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(254, 240, 138, 1) 0%, rgba(251, 191, 36, 1) 52%, rgba(194, 65, 12, 0.98) 100%) border-box;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.58);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(254, 240, 138, 0.1) 0%, rgba(217, 119, 6, 0.22) 48%, rgba(124, 45, 18, 0.46) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(71, 85, 105, 0.96) 0%, rgba(51, 65, 85, 0.94) 52%, rgba(30, 41, 59, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(226, 232, 240, 0.98) 0%, rgba(148, 163, 184, 0.98) 52%, rgba(71, 85, 105, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.07) 0%, rgba(148, 163, 184, 0.18) 48%, rgba(15, 23, 42, 0.42) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(100, 116, 139, 0.96) 0%, rgba(71, 85, 105, 0.94) 52%, rgba(30, 41, 59, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(248, 250, 252, 1) 0%, rgba(148, 163, 184, 1) 52%, rgba(51, 65, 85, 0.98) 100%) border-box;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.58);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(191, 219, 254, 0.22) 48%, rgba(30, 41, 59, 0.46) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(94, 58, 35, 0.96) 0%, rgba(122, 77, 46, 0.94) 52%, rgba(58, 35, 20, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(227, 195, 164, 0.98) 0%, rgba(184, 115, 51, 0.98) 52%, rgba(107, 66, 38, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(248, 230, 215, 0.07) 0%, rgba(184, 115, 51, 0.18) 48%, rgba(67, 40, 23, 0.44) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(111, 68, 39, 0.96) 0%, rgba(145, 90, 52, 0.94) 52%, rgba(67, 40, 23, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(240, 213, 187, 1) 0%, rgba(198, 128, 65, 1) 52%, rgba(107, 66, 38, 0.98) 100%) border-box;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.58);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(251, 237, 226, 0.08) 0%, rgba(198, 128, 65, 0.22) 48%, rgba(107, 66, 38, 0.48) 100%);
}

.content_main.charts-page .chart-rank-shell {
  position: absolute;
  top: clamp(18px, 2.1vw, 24px);
  left: clamp(18px, 2.1vw, 24px);
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: clamp(40px, 4vw, 52px);
  height: clamp(40px, 4vw, 52px);
  padding: 0 0.5rem;
  overflow: hidden;
  border-radius: 16px;
  border: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(239, 246, 255, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    0 8px 18px rgba(15, 23, 42, 0.18);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(255, 251, 235, 0.98) 0%, rgba(254, 240, 138, 0.94) 52%, rgba(245, 158, 11, 0.76) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(255, 251, 235, 1) 0%, rgba(253, 224, 71, 0.96) 52%, rgba(234, 88, 12, 0.84) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-second-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(226, 232, 240, 0.96) 52%, rgba(148, 163, 184, 0.8) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(255, 255, 255, 1) 0%, rgba(226, 232, 240, 0.98) 52%, rgba(100, 116, 139, 0.86) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-third-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(250, 241, 233, 0.98) 0%, rgba(216, 169, 126, 0.94) 52%, rgba(161, 94, 49, 0.8) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(252, 245, 239, 1) 0%, rgba(203, 143, 93, 0.96) 52%, rgba(145, 81, 42, 0.86) 100%);
}

.content_main.charts-page .chart-rank-shell::before {
  content: '';
  position: absolute;
  inset: 4px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.68), rgba(30, 41, 59, 0.82));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  pointer-events: none;
}

.content_main.charts-page .chart-rank-value {
  position: relative;
  z-index: 1;
  display: block;
  font-size: 1.04rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--ink);
  text-shadow: none;
  filter: none;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rank-shell {
  border: 2px solid transparent;
  background:
    linear-gradient(#000000, #000000) padding-box,
    var(--brand-gradient) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rank-shell::before {
  display: none;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rank-value {
  color: rgba(248, 250, 252, 0.98);
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-top-rank .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #fde68a 0%, #f59e0b 52%, #92400e 100%) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #fde68a 0%, #ea580c 52%, #7c2d12 100%) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #ecfeff 0%, #bae6fd 32%, #67e8f9 66%, #2563eb 100%) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #f0f9ff 0%, #7dd3fc 32%, #22d3ee 66%, #1d4ed8 100%) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-second-rank .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #e2e8f0 0%, #94a3b8 52%, #475569 100%) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #f8fafc 0%, #94a3b8 52%, #334155 100%) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #e3c3a4 0%, #b87333 52%, #6b4226 100%) border-box;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #f0d5bb 0%, #c68041 52%, #6b4226 100%) border-box;
}

.content_main.charts-page .chart-rating-list .chart-rating-percent {
  top: clamp(18px, 2vw, 24px);
  right: clamp(18px, 2.1vw, 24px);
  position: absolute;
  z-index: 3;
  pointer-events: none;
  display: block;
  height: auto;
  min-height: 0;
}

.content_main.charts-page .chart-rating-list .chart-rating-percent-text {
  display: inline-block;
  font-size: clamp(1.14rem, 1.82vw, 1.4rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
  user-select: none;
  text-align: right;
  text-shadow: none;
  color: transparent;
  background-image: var(--brand-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list .chart-rating-percent {
  padding: 0.34rem 0.56rem;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.88);
}

.content_main.charts-page .chart-rating-list>li.is-top-rank .chart-rank-value {
  background: linear-gradient(135deg, #fef3c7 0%, #f59e0b 48%, #92400e 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #fff7d6 0%, #f59e0b 44%, #7c2d12 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-second-rank .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #94a3b8 48%, #334155 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #cbd5e1 44%, #1e293b 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-third-rank .chart-rank-value {
  background: linear-gradient(135deg, #f8e6d7 0%, #b87333 48%, #6b4226 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #fbede2 0%, #c68041 44%, #6b4226 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rank-footer {
  position: absolute;
  left: clamp(12px, 1.7vw, 20px);
  right: clamp(18px, 2.2vw, 28px);
  bottom: clamp(12px, 1.7vw, 20px);
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  pointer-events: none;
}

.content_main.charts-page .chart-rating-list > li {
  --chart-rank-emoji-accent-start: #93c5fd;
  --chart-rank-emoji-accent-end: #1d4ed8;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #dbeafe 0%, #60a5fa 44%, #1d4ed8 100%);
}

.content_main.charts-page .chart-rating-list > li.is-diamond-rank {
  --chart-rank-emoji-accent-start: #67e8f9;
  --chart-rank-emoji-accent-end: #1d4ed8;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #ecfeff 0%, #7dd3fc 38%, #22d3ee 68%, #2563eb 100%);
}

.content_main.charts-page .chart-rating-list > li.is-platinum-rank {
  --chart-rank-emoji-accent-start: #c4b5fd;
  --chart-rank-emoji-accent-end: #475569;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 34%, #c4b5fd 68%, #475569 100%);
}

.content_main.charts-page .chart-rating-list > li.is-top-rank:not(.is-diamond-rank) {
  --chart-rank-emoji-accent-start: #fcd34d;
  --chart-rank-emoji-accent-end: #b45309;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #fef3c7 0%, #fbbf24 42%, #f59e0b 68%, #92400e 100%);
}

.content_main.charts-page .chart-rating-list > li.is-second-rank:not(.is-platinum-rank) {
  --chart-rank-emoji-accent-start: #cbd5e1;
  --chart-rank-emoji-accent-end: #475569;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #ffffff 0%, #e2e8f0 42%, #94a3b8 70%, #334155 100%);
}

.content_main.charts-page .chart-rating-list > li.is-third-rank {
  --chart-rank-emoji-accent-start: #d9a87a;
  --chart-rank-emoji-accent-end: #8b5a2b;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #f8e6d7 0%, #d9a87a 42%, #b87333 68%, #6b4226 100%);
}

.content_main.charts-page .chart-rating-list > li.is-diamond-rank {
  --chart-bg-emoji-opacity: 0.82;
}

.content_main.charts-page .chart-rating-list > li.is-platinum-rank {
  --chart-bg-emoji-opacity: 0.78;
}

.content_main.charts-page .chart-rating-list > li.is-top-rank:not(.is-diamond-rank) {
  --chart-bg-emoji-opacity: 0.8;
}

.content_main.charts-page .chart-rating-list > li.is-second-rank:not(.is-platinum-rank) {
  --chart-bg-emoji-opacity: 0.76;
}

.content_main.charts-page .chart-rating-list > li.is-third-rank {
  --chart-bg-emoji-opacity: 0.78;
}

.content_main.charts-page .chart-rank-name {
  display: inline-flex;
  align-items: center;
  font-size: clamp(1.02rem, 1.62vw, 1.26rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
  user-select: none;
  margin-left: auto;
  text-align: right;
}

.content_main.charts-page .chart-rank-name-text {
  display: inline-block;
  color: transparent;
  background-image: var(--brand-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rank-name {
  padding: 0.34rem 0.58rem;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.88);
}

.content_main.charts-page .chart-rating-list .rating-card-art-label {
  text-shadow: none;
}

.content_main.charts-page .chart-rating-list .chart-card-art-label-text {
  display: inline-block;
  color: transparent;
  background-image: var(--brand-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.content_main.charts-page .chart-rating-list .rating-subject-name {
  display: inline-block;
}

.content_main.charts-page .chart-rating-list .chart-subject-name-text {
  display: inline-block;
  color: transparent;
  background-image: var(--brand-gradient);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

html:not([data-theme='dark']) .content_main.charts-page .chart-rating-list .rating-subject-name {
  display: inline-block;
  padding: 0.16rem 0.54rem;
  line-height: 1;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.88);
}

.content_main.ratings-container.charts-page .rating-list .chart-rank-reactions {
  position: static;
  min-width: auto;
  min-height: auto;
  width: auto;
  max-width: none;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
  justify-content: flex-start;
  flex: 0 0 auto;
}

html:not([data-theme='dark']) .content_main.ratings-container.charts-page .rating-list .chart-rank-reactions {
  padding: 0.26rem 0.48rem;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.88);
}

.content_main.ratings-container.charts-page .rating-list .chart-rank-reactions.is-single {
  min-width: auto;
  justify-content: flex-start;
  padding-left: 0;
  padding-right: 0;
}

html:not([data-theme='dark']) .content_main.ratings-container.charts-page .rating-list .chart-rank-reactions.is-single {
  padding-left: 0.4rem;
  padding-right: 0.4rem;
}

.content_main.ratings-container.charts-page .rating-list .chart-rank-reactions .chart-rank-emoji {
  display: inline-block;
  width: 3.8rem;
  height: 3.8rem;
  background-image: linear-gradient(135deg, var(--chart-rank-emoji-accent-start) 0%, var(--chart-rank-emoji-accent-end) 100%);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-mask-image: var(--chart-emoji-url);
  mask-image: var(--chart-emoji-url);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  filter: none;
}

html:not([data-theme='dark']) .content_main.ratings-container.charts-page .rating-list .chart-rank-reactions .chart-rank-emoji {
  filter: drop-shadow(0 2px 4px rgba(15, 23, 42, 0.16));
}

.content_main.charts-page .chart-rank-name.is-diamond .chart-rank-name-text,
.content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-card-art-label-text,
.content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-subject-name-text,
.content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #ffffff 0%, #67e8f9 42%, #2563eb 100%);
}

.content_main.charts-page .chart-rank-name.is-platinum .chart-rank-name-text,
.content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-card-art-label-text,
.content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-subject-name-text,
.content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #ffffff 0%, #c4b5fd 42%, #475569 100%);
}

.content_main.charts-page .chart-rank-name.is-gold .chart-rank-name-text,
.content_main.charts-page .chart-rating-list>li.is-top-rank:not(.is-diamond-rank) .chart-card-art-label-text,
.content_main.charts-page .chart-rating-list>li.is-top-rank:not(.is-diamond-rank) .chart-subject-name-text,
.content_main.charts-page .chart-rating-list>li.is-top-rank:not(.is-diamond-rank) .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #fef3c7 0%, #f59e0b 48%, #92400e 100%);
}

.content_main.charts-page .chart-rank-name.is-silver .chart-rank-name-text,
.content_main.charts-page .chart-rating-list>li.is-second-rank:not(.is-platinum-rank) .chart-card-art-label-text,
.content_main.charts-page .chart-rating-list>li.is-second-rank:not(.is-platinum-rank) .chart-subject-name-text,
.content_main.charts-page .chart-rating-list>li.is-second-rank:not(.is-platinum-rank) .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #ffffff 0%, #94a3b8 48%, #334155 100%);
}

.content_main.charts-page .chart-rank-name.is-bronze .chart-rank-name-text,
.content_main.charts-page .chart-rating-list>li.is-third-rank .chart-card-art-label-text,
.content_main.charts-page .chart-rating-list>li.is-third-rank .chart-subject-name-text,
.content_main.charts-page .chart-rating-list>li.is-third-rank .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #f8e6d7 0%, #b87333 48%, #6b4226 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-name.is-diamond .chart-rank-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-card-art-label-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-subject-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #ecfeff 0%, #67e8f9 44%, #bfdbfe 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-name.is-platinum .chart-rank-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-card-art-label-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-subject-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #ffffff 0%, #ddd6fe 48%, #bfdbfe 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-name.is-gold .chart-rank-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:not(.is-diamond-rank) .chart-card-art-label-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:not(.is-diamond-rank) .chart-subject-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:not(.is-diamond-rank) .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #fef3c7 0%, #fbbf24 48%, #f97316 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-name.is-silver .chart-rank-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:not(.is-platinum-rank) .chart-card-art-label-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:not(.is-platinum-rank) .chart-subject-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:not(.is-platinum-rank) .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #ffffff 0%, #cbd5e1 48%, #94a3b8 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-name.is-bronze .chart-rank-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-card-art-label-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-subject-name-text,
html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-rating-percent-text {
  background-image: linear-gradient(135deg, #f8e6d7 0%, #d69a58 48%, #b87333 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list > li.is-diamond-rank {
  --chart-rank-emoji-accent-start: #ecfeff;
  --chart-rank-emoji-accent-end: #67e8f9;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #ecfeff 0%, #67e8f9 40%, #38bdf8 68%, #1d4ed8 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list > li.is-platinum-rank {
  --chart-rank-emoji-accent-start: #ffffff;
  --chart-rank-emoji-accent-end: #bfdbfe;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #ffffff 0%, #ddd6fe 40%, #bfdbfe 70%, #64748b 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list > li.is-top-rank:not(.is-diamond-rank) {
  --chart-rank-emoji-accent-start: #fef3c7;
  --chart-rank-emoji-accent-end: #f97316;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #fef3c7 0%, #fbbf24 40%, #f97316 70%, #9a3412 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list > li.is-second-rank:not(.is-platinum-rank) {
  --chart-rank-emoji-accent-start: #ffffff;
  --chart-rank-emoji-accent-end: #94a3b8;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #ffffff 0%, #cbd5e1 40%, #94a3b8 70%, #475569 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list > li.is-third-rank {
  --chart-rank-emoji-accent-start: #f8e6d7;
  --chart-rank-emoji-accent-end: #b87333;
  --chart-bg-emoji-gradient: linear-gradient(135deg, #f8e6d7 0%, #d69a58 40%, #b87333 70%, #8b5a2b 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(120, 53, 15, 0.96) 0%, rgba(180, 83, 9, 0.94) 52%, rgba(69, 26, 3, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(146, 64, 14, 0.98) 0%, rgba(217, 119, 6, 0.96) 52%, rgba(124, 45, 18, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(148, 163, 184, 0.96) 0%, rgba(100, 116, 139, 0.94) 52%, rgba(30, 41, 59, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(203, 213, 225, 0.98) 0%, rgba(148, 163, 184, 0.96) 52%, rgba(51, 65, 85, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(145, 90, 52, 0.96) 0%, rgba(184, 115, 51, 0.94) 52%, rgba(88, 55, 33, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(168, 104, 58, 0.98) 0%, rgba(198, 128, 65, 0.96) 52%, rgba(107, 66, 38, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank .chart-rank-value {
  background: linear-gradient(135deg, #fef3c7 0%, #fbbf24 48%, #f97316 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-top-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #fffbeb 0%, #fcd34d 44%, #fb923c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #cbd5e1 48%, #94a3b8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-second-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #e2e8f0 44%, #cbd5e1 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank .chart-rank-value {
  background: linear-gradient(135deg, #f8e6d7 0%, #d69a58 48%, #b87333 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-third-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #fff1e4 0%, #e3c3a4 44%, #d69a58 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank {
  background:
    linear-gradient(135deg, rgba(186, 230, 253, 0.99) 0%, rgba(125, 211, 252, 0.94) 48%, rgba(37, 99, 235, 0.52) 100%) padding-box,
    linear-gradient(135deg, #ecfeff 0%, #bae6fd 32%, #67e8f9 66%, #2563eb 100%) border-box;
  box-shadow: 0 12px 28px rgba(14, 116, 144, 0.14);
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover {
  background:
    linear-gradient(135deg, rgba(125, 211, 252, 0.99) 0%, rgba(103, 232, 249, 0.98) 48%, rgba(29, 78, 216, 0.6) 100%) padding-box,
    linear-gradient(135deg, #f0f9ff 0%, #7dd3fc 32%, #22d3ee 66%, #1d4ed8 100%) border-box;
  box-shadow: 0 14px 32px rgba(14, 116, 144, 0.18);
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank {
  background:
    linear-gradient(135deg, rgba(224, 231, 255, 0.99) 0%, rgba(221, 214, 254, 0.94) 48%, rgba(100, 116, 139, 0.5) 100%) padding-box,
    linear-gradient(135deg, #ffffff 0%, #dbeafe 34%, #c4b5fd 68%, #64748b 100%) border-box;
  box-shadow: 0 12px 28px rgba(99, 102, 241, 0.14);
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover {
  background:
    linear-gradient(135deg, rgba(196, 181, 253, 0.99) 0%, rgba(196, 181, 253, 0.96) 48%, rgba(71, 85, 105, 0.58) 100%) padding-box,
    linear-gradient(135deg, #ffffff 0%, #e0f2fe 34%, #c4b5fd 68%, #475569 100%) border-box;
  box-shadow: 0 14px 32px rgba(99, 102, 241, 0.18);
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(248, 254, 255, 0.99) 0%, rgba(239, 246, 255, 0.97) 54%, rgba(186, 230, 253, 0.92) 100%) padding-box,
    linear-gradient(135deg, #ecfeff 0%, #bae6fd 32%, #67e8f9 66%, #2563eb 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(103, 232, 249, 0.18) 54%, rgba(37, 99, 235, 0.32) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(250, 254, 255, 1) 0%, rgba(244, 247, 255, 0.98) 54%, rgba(125, 211, 252, 0.94) 100%) padding-box,
    linear-gradient(135deg, #f0f9ff 0%, #7dd3fc 32%, #22d3ee 66%, #1d4ed8 100%) border-box;
  box-shadow: 0 12px 28px rgba(14, 116, 144, 0.16);
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(34, 211, 238, 0.2) 54%, rgba(29, 78, 216, 0.36) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.99) 0%, rgba(244, 248, 255, 0.98) 54%, rgba(224, 231, 255, 0.92) 100%) padding-box,
    linear-gradient(135deg, #ffffff 0%, #dbeafe 34%, #c4b5fd 68%, #64748b 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(196, 181, 253, 0.18) 54%, rgba(71, 85, 105, 0.32) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 1) 0%, rgba(247, 250, 255, 0.99) 54%, rgba(199, 210, 254, 0.94) 100%) padding-box,
    linear-gradient(135deg, #ffffff 0%, #e0f2fe 34%, #c4b5fd 68%, #475569 100%) border-box;
  box-shadow: 0 12px 28px rgba(99, 102, 241, 0.16);
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(221, 214, 254, 0.2) 54%, rgba(51, 65, 85, 0.36) 100%);
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #ecfeff 0%, #bae6fd 32%, #67e8f9 66%, #2563eb 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #f0f9ff 0%, #7dd3fc 32%, #22d3ee 66%, #1d4ed8 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #ffffff 0%, #dbeafe 34%, #c4b5fd 68%, #64748b 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-rank-shell {
  background:
    linear-gradient(#000000, #000000) padding-box,
    linear-gradient(135deg, #ffffff 0%, #e0f2fe 34%, #c4b5fd 68%, #475569 100%) border-box;
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #67e8f9 42%, #2563eb 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #22d3ee 40%, #1d4ed8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #c4b5fd 42%, #475569 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #ddd6fe 44%, #334155 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank {
  background:
    linear-gradient(135deg, rgba(8, 47, 73, 0.96) 0%, rgba(30, 58, 138, 0.92) 46%, rgba(6, 78, 99, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(224, 242, 254, 0.98) 0%, rgba(125, 211, 252, 0.98) 34%, rgba(34, 211, 238, 0.98) 68%, rgba(59, 130, 246, 0.98) 100%) border-box;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.55);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(224, 242, 254, 0.08) 0%, rgba(34, 211, 238, 0.18) 46%, rgba(8, 47, 73, 0.44) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover {
  background:
    linear-gradient(135deg, rgba(14, 116, 144, 0.96) 0%, rgba(37, 99, 235, 0.94) 46%, rgba(8, 145, 178, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(240, 249, 255, 1) 0%, rgba(103, 232, 249, 1) 34%, rgba(34, 211, 238, 1) 68%, rgba(96, 165, 250, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(240, 249, 255, 0.1) 0%, rgba(103, 232, 249, 0.2) 46%, rgba(29, 78, 216, 0.48) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank {
  background:
    linear-gradient(135deg, rgba(94, 111, 140, 0.95) 0%, rgba(76, 90, 133, 0.93) 46%, rgba(30, 41, 59, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(191, 219, 254, 0.98) 34%, rgba(196, 181, 253, 0.98) 68%, rgba(100, 116, 139, 0.98) 100%) border-box;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.55);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(196, 181, 253, 0.18) 46%, rgba(30, 41, 59, 0.44) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover {
  background:
    linear-gradient(135deg, rgba(126, 145, 177, 0.96) 0%, rgba(95, 110, 152, 0.94) 46%, rgba(51, 65, 85, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(255, 255, 255, 1) 0%, rgba(219, 234, 254, 1) 34%, rgba(196, 181, 253, 1) 68%, rgba(71, 85, 105, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-card-art::after {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(221, 214, 254, 0.22) 46%, rgba(51, 65, 85, 0.48) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(12, 74, 110, 0.96) 0%, rgba(30, 64, 175, 0.94) 46%, rgba(8, 145, 178, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(224, 242, 254, 0.98) 0%, rgba(125, 211, 252, 0.98) 34%, rgba(34, 211, 238, 0.98) 68%, rgba(59, 130, 246, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(14, 116, 144, 0.96) 0%, rgba(37, 99, 235, 0.94) 46%, rgba(14, 165, 233, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(240, 249, 255, 1) 0%, rgba(103, 232, 249, 1) 34%, rgba(34, 211, 238, 1) 68%, rgba(96, 165, 250, 0.98) 100%) border-box;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.58);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(107, 123, 151, 0.96) 0%, rgba(88, 102, 134, 0.94) 46%, rgba(37, 49, 66, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(191, 219, 254, 0.98) 34%, rgba(196, 181, 253, 0.98) 68%, rgba(100, 116, 139, 0.98) 100%) border-box;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-card-shell {
  background:
    linear-gradient(135deg, rgba(126, 145, 177, 0.96) 0%, rgba(95, 110, 152, 0.94) 46%, rgba(51, 65, 85, 0.98) 100%) padding-box,
    linear-gradient(135deg, rgba(255, 255, 255, 1) 0%, rgba(219, 234, 254, 1) 34%, rgba(196, 181, 253, 1) 68%, rgba(71, 85, 105, 0.98) 100%) border-box;
  box-shadow: 0 12px 28px rgba(79, 70, 229, 0.32);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(103, 232, 249, 0.96) 0%, rgba(34, 211, 238, 0.94) 52%, rgba(30, 58, 138, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(125, 211, 252, 0.98) 0%, rgba(34, 211, 238, 0.96) 52%, rgba(37, 99, 235, 0.98) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-rank-shell {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.96) 0%, rgba(191, 219, 254, 0.94) 52%, rgba(129, 140, 248, 0.9) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-rank-shell {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(219, 234, 254, 0.96) 52%, rgba(167, 139, 250, 0.92) 100%);
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank .chart-rank-value {
  background: linear-gradient(135deg, #ecfeff 0%, #67e8f9 44%, #bfdbfe 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-diamond-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #f0f9ff 0%, #22d3ee 44%, #93c5fd 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #ddd6fe 48%, #bfdbfe 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme='dark'] .content_main.charts-page .chart-rating-list>li.is-platinum-rank:hover .chart-rank-value {
  background: linear-gradient(135deg, #ffffff 0%, #ede9fe 44%, #dbeafe 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.content_main.charts-page .chart-card-link-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0.38rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(29, 78, 216, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(239, 246, 255, 0.96));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 2px rgba(15, 23, 42, 0.08);
  white-space: nowrap;
  text-align: center;
  font-size: 0.76rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #1d4ed8;
}

.content_main.charts-page .chart-empty-state {
  width: min(1080px, 100%);
  margin: 0 auto;
  padding: 1.25rem 1.25rem 1.25rem 1.5rem;
  border-radius: 20px;
  border: 2px solid transparent;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: var(--shadow-sm);
}

.content_main.charts-page .chart-empty-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0.35rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(29, 78, 216, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(239, 246, 255, 0.96));
  color: #1d4ed8;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.content_main.charts-page .chart-empty-state p {
  margin: 0.8rem 0 0;
  color: var(--subtle);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-shell {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.78), rgba(30, 41, 59, 0.94));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 10px 22px rgba(0, 0, 0, 0.42);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-shell::before {
  background: linear-gradient(180deg, rgba(2, 6, 23, 0.74), rgba(15, 23, 42, 0.9));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

html[data-theme='dark'] .content_main.charts-page .chart-rank-value {
  color: #e2e8f0;
  text-shadow: none;
  filter: none;
}

html[data-theme='dark'] .content_main.charts-page .chart-card-link-pill,
html[data-theme='dark'] .content_main.charts-page .chart-empty-kicker {
  border-color: rgba(103, 232, 249, 0.18);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.76), rgba(30, 41, 59, 0.9));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 1px 2px rgba(0, 0, 0, 0.24);
  color: #bfdbfe;
}

html[data-theme='dark'] .content_main.charts-page .chart-empty-state {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.42);
}

@media (max-width: 700px) {
  .content_main.charts-page .chart-rating-list {
    gap: 14px;
  }

  .content_main.charts-page .chart-rating-list>li {
    --chart-shell-gap: 56px;
    padding: 56px;
  }

  .content_main.charts-page .chart-bg-emojis {
    --chart-bg-emoji-size: clamp(22px, 6.4vw, 34px);
  }

  .content_main.charts-page .chart-bg-emoji {
    display: block;
  }

  .content_main.charts-page .chart-rank-shell {
    top: 12px;
    left: 12px;
    min-width: 36px;
    height: 36px;
    border-radius: 12px;
    padding: 0 0.42rem;
  }

  .content_main.charts-page .chart-rank-shell::before {
    inset: 3px;
    border-radius: 10px;
  }

  .content_main.charts-page .chart-rank-value {
    font-size: 0.96rem;
  }

  .content_main.charts-page .chart-rank-name {
    font-size: 0.94rem;
    letter-spacing: 0.14em;
  }

  .content_main.charts-page .chart-rank-footer {
    left: 10px;
    right: 14px;
    bottom: 10px;
    gap: 0.55rem;
  }

  .content_main.ratings-container.charts-page .rating-list .chart-rank-reactions {
    gap: 0.18rem;
  }

  .content_main.ratings-container.charts-page .rating-list .chart-rank-reactions .chart-rank-emoji {
    width: 2.3rem;
    height: 2.3rem;
  }

  html:not([data-theme='dark']) .content_main.ratings-container.charts-page .rating-list .chart-rank-reactions {
    padding: 0.18rem 0.34rem;
  }

  html:not([data-theme='dark']) .content_main.ratings-container.charts-page .rating-list .chart-rank-reactions.is-single {
    padding-left: 0.28rem;
    padding-right: 0.28rem;
  }

  .content_main.charts-page .chart-rating-list .chart-rating-percent {
    top: 12px;
    right: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
  }

  .content_main.charts-page .chart-rating-list .chart-rating-percent-text {
    font-size: 1.04rem;
    letter-spacing: 0.14em;
  }

  .content_main.charts-page .chart-card-link-pill {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .content_main.charts-page .chart-bg-emoji {
    animation: none;
    transform: none;
  }
}

.content_main .playlist-card-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px;
}

.content_main.gradient-container .rating-list.playlist-card-list li,
.content_main .playlist-card-list li {
  width: 100%;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  padding: 0;
  padding-right: 0;
  border-radius: 20px;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  border: 2px solid transparent;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.86)) padding-box,
    var(--brand-gradient) border-box;
}

html[data-theme='dark'] .content_main.gradient-container .rating-list.playlist-card-list li,
html[data-theme='dark'] .content_main .playlist-card-list li {
  background:
    linear-gradient(rgba(15, 23, 42, 0.86), rgba(15, 23, 42, 0.86)) padding-box,
    var(--brand-gradient) border-box;
}

.content_main .playlist-card-list li:hover {
  background:
    linear-gradient(rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.88)) padding-box,
    var(--brand-gradient) border-box;
  border-color: transparent;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.14);
}

html[data-theme='dark'] .content_main .playlist-card-list li:hover {
  background:
    linear-gradient(rgba(15, 23, 42, 0.82), rgba(15, 23, 42, 0.82)) padding-box,
    var(--brand-gradient) border-box;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.55);
}

.content_main .playlist-card-list .rating-card-art {
  align-self: stretch;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 220px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.22), transparent 52%),
    linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(51, 65, 85, 0.86));
}

.content_main .playlist-card-list .rating-card-art::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('/static/no_img.png') center / clamp(120px, 28%, 220px) no-repeat;
  opacity: 0.9;
  pointer-events: none;
}

.content_main .playlist-card-list .rating-card-art img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.content_main .playlist-card-list .rating-card-art.is-empty {
  background: linear-gradient(135deg, rgba(2, 6, 23, 0.98), rgba(15, 23, 42, 0.94));
}

.content_main .playlist-card-list .rating-card-art.is-empty::before {
  content: none;
}

.content_main .playlist-card-list .rating-card-art.is-empty .rating-card-art-default {
  position: relative;
  z-index: 1;
  width: min(52%, 220px);
  height: auto;
  object-fit: contain;
  opacity: 0.92;
  filter: drop-shadow(0 14px 28px rgba(0, 0, 0, 0.34));
}

.content_main .playlist-card-list .rating-card-art::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.06), rgba(15, 23, 42, 0.32));
  pointer-events: none;
}

.content_main .playlist-card-list .rating-card-art.is-empty::after {
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.12), rgba(15, 23, 42, 0.4));
}

.content_main .playlist-card-list .rating-card-art-label {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  padding: 0.38rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-md);
  font-size: 0.92rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(248, 250, 252, 0.92);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.content_main .playlist-card-list .playlist-favorite-badge {
  position: absolute;
  bottom: 14px;
  right: 14px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  min-height: 38px;
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(15, 23, 42, 0.58), rgba(15, 23, 42, 0.58)) padding-box,
    var(--brand-gradient-soft-border) border-box;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-md);
  color: #fbcfe8;
  pointer-events: none;
}

.content_main .playlist-card-list .playlist-favorite-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  line-height: 0;
  color: #f472b6;
}

.content_main .playlist-card-list .playlist-favorite-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.content_main .playlist-card-list .playlist-favorite-count {
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  color: rgba(248, 250, 252, 0.96);
}

html[data-theme='dark'] .content_main .playlist-card-list .playlist-favorite-badge {
  background:
    linear-gradient(rgba(0, 0, 0, 0.62), rgba(0, 0, 0, 0.62)) padding-box,
    var(--brand-gradient-soft-border) border-box;
}

html[data-theme='dark'] .content_main .playlist-card-list .rating-card-art-label {
  background: rgba(0, 0, 0, 0.62);
  border-color: rgba(255, 255, 255, 0.2);
}

.content_main .playlist-card-list .rating-card-body {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  flex: 1;
  min-width: 0;
  padding: 0.95rem 1rem 1rem;
}

.content_main .playlist-card-list .rating-item-left {
  flex: 1;
  width: 100%;
  gap: 0.4rem;
  padding-right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.content_main .playlist-card-list .rating-item-text {
  width: 100%;
  display: block;
}

.content_main .playlist-card-list .playlist-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
}

.content_main .playlist-card-list .playlist-title-row strong {
  flex: 1;
  min-width: 0;
}

.content_main .playlist-card-list .playlist-inline-owner {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
  color: var(--subtle);
  font-weight: 500;
  flex-shrink: 0;
  text-align: right;
  white-space: normal;
}

.content_main .playlist-card-list .rating-card-meta {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.6rem;
}

.content_main .playlist-card-list .rating-item-metrics {
  color: var(--subtle);
  line-height: 1.45;
}


.content_main .playlist-card-list .rating-item-actions {
  width: 100%;
  margin-left: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
}

.content_main .playlist-card-list .rating-item-actions small {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.content_main .playlist-page-list .rating-item-actions {
  justify-content: flex-end;
}

@media (max-width: 700px) {
  .content_main .playlist-card-list .rating-card-art {
    aspect-ratio: 16 / 10;
    min-height: 164px;
  }

  .content_main .playlist-card-list .playlist-favorite-badge {
    bottom: 12px;
    right: 12px;
    min-height: 34px;
    padding: 0.38rem 0.6rem;
  }

}
