/* Consolidated Beatori shared UI styles. */

* {
  box-sizing: border-box;
}

::selection {
  background: rgba(215, 186, 255, 0.24);
  color: #fff;
}

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

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

code {
  padding: 0.15rem 0.4rem;
  border-radius: 0.55rem;
  background: rgba(255, 255, 255, 0.06);
}

.field {
  display: grid;
  gap: 0.45rem;
}

.field label {
  color: var(--text-soft);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.field input::placeholder {
  color: rgba(173, 180, 209, 0.58);
}

.input-group input::placeholder {
  color: rgba(173, 180, 209, 0.58);
}

.field textarea::placeholder {
  color: rgba(173, 180, 209, 0.58);
}

.input-group textarea::placeholder {
  color: rgba(173, 180, 209, 0.58);
}

.validation {
  color: var(--danger);
}

.validation-summary {
  color: var(--danger);
}

.validation-message {
  color: var(--danger);
}

.validation-summary ul {
  margin: 0;
  padding-left: 1rem;
}

body {
  min-height: 100vh;
  color: var(--beatori-text);
  background: var(--beatori-bg-deep);
  font-family: var(--beatori-font-body);
}

.text-muted {
  color: var(--beatori-text-muted);
}

.btn {
  align-items: center;
  border: 1px solid transparent;
  border-radius: var(--beatori-radius-sm);
  display: inline-flex;
  font-weight: 800;
  justify-content: center;
  line-height: 1;
  min-height: 2.45rem;
  padding: 0.65rem 1rem;
  text-decoration: none;
}

.btn-secondary {
  background: var(--beatori-surface-soft);
  border-color: var(--beatori-border);
  color: var(--beatori-text);
}

.btn-danger {
  background: rgba(255, 180, 171, 0.1);
  border-color: rgba(255, 180, 171, 0.24);
  color: var(--beatori-danger);
}

.form-group {
  display: grid;
  gap: 0.45rem;
  margin-bottom: var(--beatori-space-5);
}

.input-group {
  display: grid;
  gap: 0.45rem;
  margin-bottom: var(--beatori-space-5);
}

.form-group label {
  color: var(--beatori-text-muted);
  font-size: 0.92rem;
  font-weight: 800;
}

.input-group label {
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--beatori-text-muted);
  font-size: 0.92rem;
  font-weight: 800;
}

.form-control {
  background: rgba(0, 0, 0, 0.22);
  border: 1px solid var(--beatori-border);
  border-radius: var(--beatori-radius-sm);
  color: var(--beatori-text);
  min-height: 2.65rem;
  padding: 0.75rem 0.85rem;
  width: 100%;
}

.field input {
  width: 100%;
  min-height: 2.65rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--beatori-border);
  border-radius: var(--beatori-radius-sm);
  background: rgba(0, 0, 0, 0.22);
  color: var(--beatori-text);
}

.field select {
  width: 100%;
  min-height: 2.65rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--beatori-border);
  border-radius: var(--beatori-radius-sm);
  background: rgba(0, 0, 0, 0.22);
  color: var(--beatori-text);
}

.field textarea {
  width: 100%;
  min-height: 2.65rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--beatori-border);
  border-radius: var(--beatori-radius-sm);
  background: rgba(0, 0, 0, 0.22);
  color: var(--beatori-text);
}

.input-group input {
  width: 100%;
  min-height: 2.65rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--beatori-border);
  border-radius: var(--beatori-radius-sm);
  background: rgba(0, 0, 0, 0.22);
  color: var(--beatori-text);
}

.input-group select {
  width: 100%;
  min-height: 2.65rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--beatori-border);
  border-radius: var(--beatori-radius-sm);
  background: rgba(0, 0, 0, 0.22);
  color: var(--beatori-text);
}

.input-group textarea {
  width: 100%;
  min-height: 2.65rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--beatori-border);
  border-radius: var(--beatori-radius-sm);
  background: rgba(0, 0, 0, 0.22);
  color: var(--beatori-text);
}

.form-control:focus {
  border-color: var(--beatori-tertiary);
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  outline: none;
}

.field input:focus {
  border-color: var(--beatori-tertiary);
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  outline: none;
}

.field select:focus {
  border-color: var(--beatori-tertiary);
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  outline: none;
}

.field textarea:focus {
  border-color: var(--beatori-tertiary);
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  outline: none;
}

.input-group input:focus {
  border-color: var(--beatori-tertiary);
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  outline: none;
}

.input-group select:focus {
  border-color: var(--beatori-tertiary);
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  outline: none;
}

.input-group textarea:focus {
  border-color: var(--beatori-tertiary);
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  outline: none;
}

.form-control[readonly] {
  opacity: 0.65;
}

select.form-control option {
  background: var(--beatori-surface);
  color: var(--beatori-text);
}

textarea.form-control {
  min-height: 6rem;
  resize: vertical;
}

.text-danger {
  color: var(--beatori-danger);
  font-size: 0.86rem;
}

body::before {
  content: none;
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background: none;
  background-size: 80px 80px, 80px 80px, 100% 100%;
  mask-image: linear-gradient(180deg, #000, transparent 80%);
  opacity: 0.45;
  -webkit-mask-image: linear-gradient(180deg, #000, transparent 80%);
}

body::after {
  content: none;
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background: none;
  background-size: 260px 260px;
  opacity: 0.16;
}

summary:focus-visible {
  outline: 0;
  box-shadow: var(--beatori-focus-ring);
  outline-offset: 2px;
}

label:focus-visible {
  outline: 0;
  box-shadow: var(--beatori-focus-ring);
  outline-offset: 2px;
}

button:active {
  transform: scale(0.98);
}

.btn:active {
  transform: scale(0.98);
}

h1 {
  margin: 0;
  font-family: var(--beatori-font-display);
  letter-spacing: 0;
  font-weight: 700;
}

h2 {
  margin: 0;
  font-family: var(--beatori-font-display);
  letter-spacing: 0;
  font-weight: 700;
}

h3 {
  margin: 0;
  font-family: var(--beatori-font-display);
  letter-spacing: 0;
  font-weight: 700;
}

h4 {
  margin: 0;
  font-family: var(--beatori-font-display);
  letter-spacing: 0;
  font-weight: 700;
}

h5 {
  margin: 0;
  font-family: var(--beatori-font-display);
  letter-spacing: 0;
  font-weight: 700;
}

h6 {
  margin: 0;
  font-family: var(--beatori-font-display);
  letter-spacing: 0;
  font-weight: 700;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color 180ms ease,
  background 180ms ease,
  border-color 180ms ease,
  box-shadow 180ms ease,
  transform 180ms ease,
  filter 180ms ease;
}

button {
  font: inherit;
  cursor: pointer;
  transition: color 180ms ease,
  background 180ms ease,
  border-color 180ms ease,
  box-shadow 180ms ease,
  transform 180ms ease,
  filter 180ms ease;
}

a:focus-visible {
  outline-offset: 2px;
  outline: 0;
  box-shadow: var(--beatori-focus-ring);
}

button:focus-visible {
  outline-offset: 2px;
  outline: 0;
  box-shadow: var(--beatori-focus-ring);
}

input:focus-visible {
  outline-offset: 2px;
  outline: 0;
  box-shadow: var(--beatori-focus-ring);
}

select:focus-visible {
  outline-offset: 2px;
  outline: 0;
  box-shadow: var(--beatori-focus-ring);
}

textarea:focus-visible {
  outline-offset: 2px;
  outline: 0;
  box-shadow: var(--beatori-focus-ring);
}

input:hover {
  border-color: var(--border-strong);
}

select:hover {
  border-color: var(--border-strong);
}

textarea:hover {
  border-color: var(--border-strong);
}

.btn-primary {
  border-color: transparent;
  gap: 0.625rem;
  font-family: var(--beatori-font-body);
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--grad-primary);
  color: #fff;
  border-radius: var(--r-input);
  box-shadow: var(--glow-violet-md);
  border: 0;
}

.btn-primary:hover {
  background: linear-gradient(135deg, var(--beatori-primary-strong), var(--beatori-primary));
  color: #fff;
  transform: translateY(-2px);
  filter: none;
  box-shadow: var(--glow-violet-lg), 0 0 20px rgba(189, 156, 255, 0.34), 0 0 10px rgba(255, 255, 255, 0.16);
}

input {
  font: inherit;
  transition: color 180ms ease,
  background 180ms ease,
  border-color 180ms ease,
  box-shadow 180ms ease,
  transform 180ms ease,
  filter 180ms ease;
  border-color: var(--border-subtle);
  border-radius: var(--r-input);
  background: var(--bg-band-deep);
  color: var(--text-primary);
  border: 1px solid var(--border-subtle);
  font-size: 0.875rem;
}

select {
  font: inherit;
  transition: color 180ms ease,
  background 180ms ease,
  border-color 180ms ease,
  box-shadow 180ms ease,
  transform 180ms ease,
  filter 180ms ease;
  border-color: var(--border-subtle);
  border-radius: var(--r-input);
  background: var(--bg-band-deep);
  color: var(--text-primary);
  border: 1px solid var(--border-subtle);
  font-size: 0.875rem;
}

textarea {
  font: inherit;
  resize: vertical;
  transition: color 180ms ease,
  background 180ms ease,
  border-color 180ms ease,
  box-shadow 180ms ease,
  transform 180ms ease,
  filter 180ms ease;
  border-color: var(--border-subtle);
  border-radius: var(--r-input);
  background: var(--bg-band-deep);
  color: var(--text-primary);
  border: 1px solid var(--border-subtle);
  font-size: 0.875rem;
}

input:focus {
  border-color: var(--violet-400);
  box-shadow: 0 0 0 3px rgba(139, 60, 247, 0.16);
}

select:focus {
  border-color: var(--violet-400);
  box-shadow: 0 0 0 3px rgba(139, 60, 247, 0.16);
}

textarea:focus {
  border-color: var(--violet-400);
  box-shadow: 0 0 0 3px rgba(139, 60, 247, 0.16);
}

.ph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  line-height: 1;
}

body.has-mobile-menu-open {
  overflow: hidden;
}

:root {
  --background: var(--beatori-bg);
  --background-deep: var(--beatori-bg-deep);
  --surface-low: var(--beatori-surface-low);
  --surface: var(--beatori-surface);
  --surface-high: var(--beatori-surface-high);
  --surface-highest: var(--beatori-surface-highest);
  --surface-glass: var(--beatori-surface-glass);
  --surface-glass-strong: var(--beatori-surface-glass-strong);
  --surface-soft: var(--beatori-surface-soft);
  --surface-softer: var(--beatori-surface-softer);
  --border: var(--beatori-border);
  --text: var(--beatori-text);
  --text-muted: var(--beatori-text-muted);
  --text-soft: var(--beatori-text-soft);
  --primary: var(--beatori-primary);
  --primary-strong: var(--beatori-primary-strong);
  --primary-ink: var(--beatori-primary-ink);
  --tertiary: var(--beatori-tertiary);
  --tertiary-deep: var(--beatori-tertiary-deep);
  --success: var(--beatori-success);
  --warning: var(--beatori-warning);
  --danger: var(--beatori-danger);
  --grade-sss: var(--beatori-grade-sss, #fbbf24);
  --grade-ss: var(--beatori-grade-ss, #fbbf24);
  --grade-s: var(--beatori-grade-s, #fbbf24);
  --grade-a: var(--beatori-grade-a, #ffffff);
  --grade-b: var(--beatori-grade-b, #22c55e);
  --grade-c: var(--beatori-grade-c, #34d399);
  --grade-d: var(--beatori-grade-d, #f97316);
  --grade-fail: var(--beatori-grade-fail, #ef4444);
  --shadow: var(--beatori-shadow);
  --shadow-soft: var(--beatori-shadow-soft);
  --font-display: var(--beatori-font-display);
  --font-body: var(--beatori-font-body);
  --beatori-purple-glow: rgba(168, 85, 247, 0.4);
  --beatori-public-grid-line: rgba(255, 255, 255, 0.018);
  --beatori-public-grid-line-soft: rgba(255, 255, 255, 0.014);
  --status-open: #34d399;
  --status-ingame: #facc15;
  --status-full: #f87171;
  --status-ready: #34d399;
  --glow-cyan-sm: 0 0 10px rgba(45, 212, 255, 0.4);
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --font-script: "Caveat", "Pacifico", cursive;
  --beatori-surface-highest: #33206c;
  --beatori-surface-glass: rgba(20, 10, 46, 0.72);
  --beatori-surface-glass-strong: rgba(20, 10, 46, 0.88);
  --beatori-surface-soft: rgba(193, 139, 255, 0.075);
  --beatori-surface-softer: rgba(193, 139, 255, 0.045);
  --beatori-border-soft: var(--border-subtle);
  --beatori-text-soft: var(--text-secondary);
  --beatori-primary-muted: var(--violet-300);
  --beatori-tertiary-deep: var(--cyan-300);
  --beatori-success: var(--status-open);
  --beatori-warning: var(--status-ingame);
  --beatori-danger: var(--status-full);
  --beatori-radius-sm: var(--r-sm);
  --beatori-radius-md: var(--r-md);
  --beatori-radius-lg: var(--r-lg);
  --beatori-shadow-soft: var(--shadow-card);
  --beatori-shadow: var(--glow-violet-md);
  --beatori-card-shadow: var(--shadow-card);
  --beatori-button-primary-shadow: var(--glow-violet-md);
  --beatori-focus-ring: 0 0 0 2px rgba(45, 212, 255, 0.72), 0 0 24px rgba(139, 60, 247, 0.35);
  --violet-glow: #5b6cff;
  --grad-rank: linear-gradient(135deg, #ffd166 0%, #8b7cff 100%);
  --grad-visualizer: linear-gradient(90deg, #38bdf8 0%, #6d5dfc 58%, #a78bfa 100%);
  --beatori-surface-low: var(--bg-surface-1);
  --beatori-secondary: var(--violet-300);
  --beatori-tertiary: var(--cyan-400);
  --bg-surface-1: #0d0a1d;
  --bg-surface-2: #121026;
  --bg-surface-3: #1d153a;
  --grad-hero-text: linear-gradient(100deg, #f1ecff 0%, #c7a6ff 46%, #a56cff 100%);
  --grad-surface: linear-gradient(160deg, rgba(20, 16, 42, 0.58) 0%, rgba(8, 7, 19, 0.78) 100%);
  --glow-violet-sm: 0 0 10px rgba(165, 108, 255, 0.34);
  --shadow-card: 0 14px 44px rgba(0, 0, 0, 0.28), 0 0 0 1px var(--border-subtle) inset;
  --glass-bg: var(--grad-surface);
  --violet-500: #8b3cf7;
  --violet-400: #a45cff;
  --violet-300: #c18bff;
  --magenta-500: #e0249a;
  --magenta-400: #ff4db8;
  --gold-400: #ffb627;
  --gold-300: #ffd166;
  --glow-violet-lg: 0 0 48px rgba(139, 60, 247, 0.5);
  --glow-magenta-md: 0 0 24px rgba(224, 36, 154, 0.5);
  --r-pill: 999px;
  --beatori-bg: var(--bg-base);
  --beatori-bg-deep: var(--bg-base);
  --beatori-surface: var(--surface-card);
  --beatori-surface-high: var(--surface-card-2);
  --beatori-border: var(--border-subtle);
  --beatori-border-strong: var(--border-strong);
  --beatori-text: var(--text-primary);
  --beatori-text-secondary: var(--text-secondary);
  --beatori-text-muted: var(--text-tertiary);
  --beatori-primary: var(--violet-500);
  --beatori-primary-strong: var(--purple-300);
  --grad-band-edge: linear-gradient(180deg, transparent 0%, var(--bg-base) 100%);
  --r-section: 0;
  --r-card: 16px;
  --r-card-lg: 20px;
  --r-input: 12px;
  --font-mono: "JetBrains Mono", "Cascadia Mono", Consolas, monospace;
  --border-strong: rgba(80, 200, 255, 0.25);
  --bg-base: #0a1024;
  --pink-300: #ff8ad4;
  --cyan-400: #2dd4ff;
  --cyan-300: #7de8ff;
  --text-primary: #eaf0ff;
  --text-secondary: #9db0d8;
  --text-tertiary: #5c6b95;
  --border-subtle: rgba(120, 180, 255, 0.1);
  --grad-primary: linear-gradient(180deg, #7c3aed 0%, #6d28d9 100%);
  --glow-violet-md: 0 0 24px rgba(124, 58, 237, 0.5);
  --bg-band-violet: #0a1024;
  --bg-band-deep: #060a18;
  --surface-card: rgba(16, 26, 56, 0.55);
  --surface-card-2: rgba(22, 35, 74, 0.68);
  --grad-headline: linear-gradient(120deg, #9d5cff 0%, #2dd4ff 100%);
  --bg-void: #060a18;
  --bg-surface: #101a38;
  --bg-elevated: #16234a;
  --purple-600: #6d28d9;
  --purple-500: #7c3aed;
  --purple-400: #9d5cff;
  --purple-300: #bd9cff;
  --cyan-500: #18b4e0;
  --amber-400: #ffb627;
  --amber-300: #ffd166;
  --pink-400: #ff4db8;
  --border-tech: rgba(45, 212, 255, 0.4);
  --glow-cyan-md: 0 0 24px rgba(45, 212, 255, 0.42);
  --glow-amber-md: 0 0 20px rgba(255, 182, 39, 0.36);
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  scroll-padding-top: 92px;
  max-width: 100%;
  overflow-x: hidden;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--beatori-font-body);
  line-height: 1.5;
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
  color: var(--text-primary);
  background: var(--bg-void);
  max-width: 100%;
  overflow-x: hidden;
}

.field-validation-error
,.validation-summary-errors {
  color: var(--danger);
}

.field-validation-valid
,.validation-summary-valid {
  display: none;
}

.input-validation-error {
  border-color: rgba(255, 180, 171, 0.35);
}

@media (max-width: 768px) {
html {
    scroll-padding-top: 82px;
  }
}

@media (max-width: 480px) {
html {
    scroll-padding-top: 76px;
  }
}

@media (prefers-reduced-motion: reduce) {
html {
    scroll-behavior: auto;
  }

  * {
    animation: none;
    transition: none;
  }

  *::before {
    animation: none;
    transition: none;
  }

  *::after {
    animation: none;
    transition: none;
  }
}

/* Admin design system. Shared app components live in Beatori.Server.UI. */

.beatori-admin-body,
.beatori-auth-body {
  --bg-void: #060A18;
  --bg-base: #0A1024;
  --bg-surface: #101A38;
  --bg-elevated: #16234A;
  --purple-600: #6D28D9;
  --purple-500: #7C3AED;
  --purple-400: #9D5CFF;
  --purple-300: #BD9CFF;
  --cyan-500: #18B4E0;
  --cyan-400: #2DD4FF;
  --cyan-300: #7DE8FF;
  --amber-400: #FFB627;
  --amber-300: #FFD166;
  --text-primary: #EAF0FF;
  --text-secondary: #9DB0D8;
  --text-tertiary: #5C6B95;
  --border-subtle: rgba(120, 180, 255, 0.10);
  --border-strong: rgba(80, 200, 255, 0.25);
  --border-tech: rgba(45, 212, 255, 0.40);
  --glow-purple: 0 0 20px rgba(124, 58, 237, 0.45);
  --ok: #34D399;
  --warn: #FFB627;
  --danger: #F87171;
  --font-display: "Archivo", sans-serif;
  --font-mono: "JetBrains Mono", monospace;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --r-card: 14px;
  --r-control: 10px;
  --r-pill: 999px;
  --beatori-font-body: var(--font-display);
  --beatori-font-display: var(--font-display);
  --beatori-bg: var(--bg-void);
  --beatori-bg-deep: var(--bg-void);
  --beatori-surface: var(--bg-surface);
  --beatori-surface-high: var(--bg-elevated);
  --beatori-surface-glass: var(--bg-surface);
  --beatori-surface-glass-strong: var(--bg-base);
  --beatori-border: var(--border-subtle);
  --beatori-border-strong: var(--border-strong);
  --beatori-text: var(--text-primary);
  --beatori-text-secondary: var(--text-secondary);
  --beatori-text-muted: var(--text-tertiary);
  --beatori-primary: var(--purple-500);
  --beatori-primary-strong: var(--purple-300);
  --beatori-tertiary: var(--cyan-300);
  --beatori-radius-sm: var(--r-control);
  --beatori-radius-lg: var(--r-card);
  --beatori-motion: 160ms var(--ease);
}

.beatori-admin-body {
  color: var(--text-secondary);
  background: var(--bg-void);
  font-family: var(--font-display);
  font-size: 14px;
}

.beatori-admin-body a,
.beatori-admin-body button,
.beatori-admin-body input,
.beatori-admin-body select,
.beatori-admin-body textarea {
  font-family: inherit;
}

.beatori-admin-body .btn,
.beatori-admin-body .beatori-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 40px;
  padding: 9px 20px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-control);
  background: transparent;
  color: var(--text-primary);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1;
  text-decoration: none;
  text-transform: none;
  transition: color 160ms var(--ease), background 160ms var(--ease), border-color 160ms var(--ease), box-shadow 160ms var(--ease), filter 160ms var(--ease), transform 160ms var(--ease);
}

.beatori-admin-body .btn:hover,
.beatori-admin-body .beatori-button:hover {
  transform: translateY(-1px);
}

.beatori-admin-body .btn-primary,
.beatori-admin-body .beatori-button-primary,
.beatori-admin-body .beatori-u-064 {
  min-height: 40px;
  padding: 9px 22px;
  border-color: transparent;
  background: linear-gradient(180deg, var(--purple-500), var(--purple-600));
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 700;
  box-shadow: var(--glow-purple), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.beatori-admin-body .admin-topbar-action,
.beatori-admin-body .beatori-u-016 .btn-primary {
  min-height: 44px;
  padding: 11px 20px;
  font-size: 14px;
}

.beatori-admin-body .btn-primary:hover,
.beatori-admin-body .beatori-button-primary:hover,
.beatori-admin-body .beatori-u-064:hover {
  color: var(--text-primary);
  filter: brightness(1.08);
  transform: translateY(-1px);
}

.beatori-admin-body .beatori-button-danger,
.beatori-admin-body .btn-danger {
  border-color: var(--danger);
  background: rgba(248, 113, 113, 0.12);
  color: var(--danger);
  font-size: 13px;
  font-weight: 700;
}

.beatori-admin-body .btn-danger:hover,
.beatori-admin-body .beatori-button-danger:hover {
  background: rgba(248, 113, 113, 0.16);
  color: var(--danger);
}

.beatori-admin-body .btn.beatori-u-015,
.beatori-admin-body .btn.beatori-u-033,
.beatori-admin-body .btn.beatori-u-035 {
  background: transparent;
  border-color: var(--border-strong);
  color: var(--text-primary);
}

.beatori-admin-body .btn.beatori-u-015:hover,
.beatori-admin-body .btn.beatori-u-033:hover,
.beatori-admin-body .btn.beatori-u-035:hover {
  background: rgba(45, 212, 255, 0.08);
  border-color: var(--cyan-400);
  color: var(--cyan-300);
}

.beatori-admin-body .btn.beatori-u-059,
.beatori-admin-body .admin-reset-link {
  min-height: 40px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
}

.beatori-admin-body .btn.beatori-u-059:hover,
.beatori-admin-body .admin-reset-link:hover {
  color: var(--cyan-300);
  text-decoration: underline;
  transform: none;
}

.beatori-admin-body .admin-icon-button {
  width: 32px;
  height: 32px;
  min-height: 32px;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--text-tertiary);
  font-size: 16px;
}

.beatori-admin-body .admin-icon-button:hover {
  background: rgba(45, 212, 255, 0.10);
  color: var(--cyan-300);
  transform: none;
}

.beatori-admin-body .admin-icon-button.danger:hover {
  background: rgba(248, 113, 113, 0.10);
  color: var(--danger);
}

.beatori-admin-body .form-group,
.beatori-admin-body .input-group {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.beatori-admin-body .form-group label,
.beatori-admin-body .input-group label {
  margin: 0;
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.beatori-admin-body .form-control,
.beatori-admin-body input:not([type="checkbox"]):not([type="radio"]),
.beatori-admin-body select,
.beatori-admin-body textarea {
  width: 100%;
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-control);
  background: var(--bg-void);
  color: var(--text-primary);
  font-size: 14px;
  box-shadow: none;
}

.beatori-admin-body textarea,
.beatori-admin-body textarea.form-control {
  min-height: 132px;
  padding-block: 12px;
  resize: vertical;
}

.beatori-admin-body input::placeholder,
.beatori-admin-body textarea::placeholder {
  color: var(--text-tertiary);
}

.beatori-admin-body .form-control:focus,
.beatori-admin-body input:not([type="checkbox"]):not([type="radio"]):focus,
.beatori-admin-body select:focus,
.beatori-admin-body textarea:focus {
  border-color: var(--cyan-400);
  box-shadow: 0 0 0 3px rgba(45, 212, 255, 0.15);
  outline: 0;
}

.beatori-admin-body select {
  appearance: none;
  padding-right: 40px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--cyan-300) 50%),
    linear-gradient(135deg, var(--cyan-300) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 19px,
    calc(100% - 12px) 19px;
  background-repeat: no-repeat;
  background-size: 6px 6px, 6px 6px;
}

.beatori-admin-body input[type="checkbox"] {
  appearance: none;
  display: inline-grid;
  width: 18px;
  height: 18px;
  margin: 0;
  place-items: center;
  border: 1px solid var(--border-strong);
  border-radius: 5px;
  background: var(--bg-void);
  cursor: pointer;
}

.beatori-admin-body input[type="checkbox"]:checked {
  border-color: var(--purple-400);
  background: linear-gradient(180deg, var(--purple-500), var(--purple-600));
  box-shadow: 0 0 12px rgba(124, 58, 237, 0.36);
}

.beatori-admin-body input[type="checkbox"]:checked::after {
  content: "";
  width: 8px;
  height: 4px;
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff;
  transform: rotate(-45deg) translateY(-1px);
}

.beatori-admin-body .admin-form-container {
  margin: 24px 0;
  padding: 24px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-card);
  background: var(--bg-surface);
  box-shadow: none;
}

.beatori-admin-body .admin-card,
.beatori-admin-body .login-container .login-card,
.beatori-admin-body .access-denied-card {
  padding: 24px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-card);
  background: var(--bg-surface);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
}

.beatori-admin-body .admin-modal {
  width: min(680px, calc(100vw - 32px));
  max-height: min(760px, calc(100vh - 32px));
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-card);
  background: var(--bg-surface);
  color: var(--text-secondary);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55), var(--glow-purple);
}

.beatori-admin-body .admin-modal::backdrop {
  background: rgba(6, 10, 24, 0.72);
}

.beatori-admin-body .admin-modal-header,
.beatori-admin-body .admin-modal-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border-subtle);
}

.beatori-admin-body .admin-modal-actions {
  justify-content: flex-end;
  border-top: 1px solid var(--border-subtle);
  border-bottom: 0;
}

.beatori-admin-body .admin-modal-header h2 {
  color: var(--text-primary);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 800;
}

.beatori-admin-body .admin-modal-header p {
  margin: 4px 0 0;
  color: var(--text-secondary);
  font-size: 13px;
}

.beatori-admin-body .admin-modal-body {
  max-height: calc(100vh - 190px);
  overflow: auto;
  padding: 20px;
}

.beatori-admin-body .admin-modal .admin-icon-button {
  flex: 0 0 auto;
}

.beatori-admin-body .login-container,
.beatori-admin-body .access-denied-container {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 32px;
  background: var(--bg-void);
}

.beatori-admin-body .login-container .login-card,
.beatori-admin-body .access-denied-container .access-denied-card {
  width: min(100%, 420px);
  padding: 32px;
}

.beatori-admin-body .access-denied-container .access-denied-card {
  display: grid;
  gap: 16px;
  text-align: center;
}

.beatori-admin-body .access-denied-card h1 {
  color: var(--danger);
}

.beatori-admin-body .access-denied-card p {
  color: var(--text-secondary);
}

.beatori-admin-body .access-denied-card .actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}

.beatori-admin-body .admin-brand-logo {
  width: 30px;
  height: 30px;
  padding: 5px;
  border-radius: 9px;
  background: linear-gradient(180deg, var(--purple-500), var(--purple-600));
  box-shadow: var(--glow-purple);
  filter: none;
}

.beatori-admin-body .brand-text {
  color: var(--text-primary);
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
}

.beatori-admin-body .admin-brand-subtitle {
  color: var(--cyan-400);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
}

.beatori-admin-body .alert-panel {
  margin-bottom: 16px;
  padding: 12px 14px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-control);
  background: rgba(45, 212, 255, 0.08);
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 600;
}

.beatori-admin-body .alert-panel.success {
  border-color: rgba(52, 211, 153, 0.34);
  background: rgba(52, 211, 153, 0.10);
  color: var(--ok);
}

.beatori-admin-body .alert-panel.error,
.beatori-admin-body .text-danger {
  color: var(--danger);
}

.beatori-admin-body .admin-code-textarea {
  min-height: 28rem;
  font-family: var(--font-mono);
}

.beatori-admin-body .filters-grid {
  display: grid;
  align-items: end;
  gap: 16px;
  grid-template-columns: minmax(0, 2fr) minmax(220px, 1fr) auto auto;
}

.beatori-admin-body .filter-checks {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
  min-height: 44px;
  color: var(--text-primary);
}

.beatori-admin-body .filter-checks label,
.beatori-admin-body label.beatori-u-011,
.beatori-admin-body label.beatori-u-012,
.beatori-admin-body label.beatori-u-045,
.beatori-admin-body label.beatori-u-106,
.beatori-admin-body label.beatori-u-111,
.beatori-admin-body label.beatori-u-120 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  cursor: pointer;
}

.beatori-admin-body .admin-filter-actions {
  display: flex;
  align-items: end;
  gap: 12px;
}

.beatori-admin-body .card-stats-grid,
.beatori-admin-body .admin-stat-grid,
.beatori-admin-body .beatori-u-094 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.beatori-admin-body .stat-card {
  position: relative;
  overflow: hidden;
  padding: 18px 20px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-card);
  background: var(--bg-surface);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
  transition: border-color 160ms var(--ease), box-shadow 160ms var(--ease), transform 160ms var(--ease);
}

.beatori-admin-body .stat-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: var(--stat-accent, var(--cyan-400));
}

.beatori-admin-body .stat-card:hover {
  border-color: var(--border-strong);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35), 0 0 18px rgba(45, 212, 255, 0.12);
  transform: translateY(-2px);
}

.beatori-admin-body .stat-card.total {
  --stat-accent: var(--cyan-400);
}

.beatori-admin-body .stat-card.published {
  --stat-accent: var(--ok);
}

.beatori-admin-body .stat-card.hidden {
  --stat-accent: var(--text-tertiary);
}

.beatori-admin-body .stat-card.official {
  --stat-accent: var(--purple-400);
}

.beatori-admin-body .stat-card.permission {
  --stat-accent: var(--amber-400);
}

.beatori-admin-body .stat-card.uploaded {
  --stat-accent: var(--cyan-300);
}

.beatori-admin-body .stat-card h3,
.beatori-admin-body .stat-label {
  margin: 0;
  color: var(--text-tertiary);
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1;
  text-transform: uppercase;
}

.beatori-admin-body .stat-card .value,
.beatori-admin-body .stat-value {
  display: block;
  margin-top: 8px;
  color: var(--cyan-300);
  font-family: var(--font-mono);
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
}

.beatori-admin-body .admin-table-container {
  width: 100%;
  max-width: 1600px;
  overflow-x: auto;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-card);
  background: var(--bg-base);
  box-shadow: none;
}

.beatori-admin-body .admin-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.beatori-admin-body .admin-table thead tr {
  height: 48px;
  background: var(--bg-surface);
}

.beatori-admin-body .admin-table th {
  position: relative;
  padding: 0 16px;
  border: 0;
  border-bottom: 1px solid var(--border-strong);
  color: var(--purple-300);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-align: left;
  text-transform: uppercase;
  white-space: nowrap;
}

.beatori-admin-body .admin-th-control {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: space-between;
}

.beatori-admin-body .admin-sort-button,
.beatori-admin-body .admin-column-filter {
  min-height: 28px;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  box-shadow: none;
}

.beatori-admin-body .admin-sort-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.beatori-admin-body .admin-column-filter {
  width: 28px;
  border-radius: 8px;
  color: var(--text-tertiary);
  font-size: 15px;
}

.beatori-admin-body .admin-column-filter:hover,
.beatori-admin-body .admin-column-filter.is-active {
  background: rgba(45, 212, 255, 0.10);
  color: var(--cyan-300);
  transform: none;
}

.beatori-admin-body .admin-column-filter-menu {
  position: fixed;
  z-index: 1000;
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-control);
  background: var(--bg-elevated);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.46), 0 0 18px rgba(45, 212, 255, 0.10);
}

.beatori-admin-body .admin-column-filter-menu[hidden],
.beatori-admin-body [hidden] {
  display: none !important;
}

.beatori-admin-body .admin-column-filter-menu label {
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.beatori-admin-body .admin-table tbody tr {
  min-height: 56px;
  border-bottom: 1px solid var(--border-subtle);
  transition: background 160ms var(--ease);
}

.beatori-admin-body .admin-table tbody tr:hover {
  background: rgba(124, 58, 237, 0.06);
}

.beatori-admin-body .admin-table td {
  padding: 12px 16px;
  border: 0;
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 500;
  vertical-align: middle;
}

.beatori-admin-body .admin-table td:first-child,
.beatori-admin-body .admin-table strong {
  color: var(--text-primary);
  font-weight: 700;
}

.beatori-admin-body .admin-table th:last-child,
.beatori-admin-body .admin-table td:last-child {
  text-align: right;
}

.beatori-admin-body .admin-table th:last-child .admin-th-control {
  justify-content: flex-end;
}

.beatori-admin-body .admin-table-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1600px;
  gap: 16px;
  padding: 14px 4px 0;
  color: var(--text-tertiary);
  font-size: 12px;
  font-weight: 600;
}

.beatori-admin-body .admin-table-pagination {
  display: flex;
  align-items: center;
  gap: 10px;
}

.beatori-admin-body .admin-table-pagination .admin-icon-button:disabled {
  opacity: 0.35;
  pointer-events: none;
}

.beatori-admin-body .status-pill,
.beatori-admin-body .source-pill,
.beatori-admin-body .pill,
.beatori-admin-body .beatori-u-021,
.beatori-admin-body .beatori-u-069,
.beatori-admin-body .beatori-u-071,
.beatori-admin-body .beatori-u-073 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 24px;
  padding: 4px 12px;
  border: 1px solid var(--ok);
  border-radius: var(--r-pill);
  background: rgba(52, 211, 153, 0.12);
  color: var(--ok);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.beatori-admin-body .status-pill.hidden,
.beatori-admin-body .status-pill.dismissed,
.beatori-admin-body .status-pill.missing,
.beatori-admin-body .beatori-u-071 {
  border-color: rgba(92, 107, 149, 0.46);
  background: rgba(92, 107, 149, 0.10);
  color: var(--text-tertiary);
}

.beatori-admin-body .status-pill.pending {
  border-color: var(--warn);
  background: rgba(255, 182, 39, 0.12);
  color: var(--warn);
}

.beatori-admin-body .source-pill,
.beatori-admin-body .source-pill.user-uploaded,
.beatori-admin-body .source-pill.useruploaded {
  border-color: var(--cyan-400);
  background: rgba(45, 212, 255, 0.10);
  color: var(--cyan-300);
}

.beatori-admin-body .source-pill.official {
  border-color: var(--purple-400);
  background: rgba(124, 58, 237, 0.14);
  color: var(--purple-300);
}

.beatori-admin-body .source-pill.permission {
  border-color: var(--amber-400);
  background: rgba(255, 182, 39, 0.12);
  color: var(--amber-300);
}

.beatori-admin-body .difficulty-chip,
.beatori-admin-body .beatori-u-100 {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 3px 8px;
  border: 0;
  border-radius: 6px;
  background: var(--bg-elevated);
  color: var(--cyan-300);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0;
}

.beatori-admin-body .beatori-u-016 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 28px;
}

.beatori-admin-body .beatori-u-017,
.beatori-admin-body .beatori-u-029,
.beatori-admin-body .beatori-u-070,
.beatori-admin-body .beatori-u-108,
.beatori-admin-body .beatori-u-109,
.beatori-admin-body .beatori-u-116 {
  color: var(--text-secondary);
}

.beatori-admin-body .beatori-u-018 {
  display: flex;
  align-items: center;
  gap: 12px;
}

.beatori-admin-body .admin-title-cell,
.beatori-admin-body .admin-title-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.beatori-admin-body .admin-title-row {
  gap: 8px;
  flex-wrap: wrap;
}

.beatori-admin-body .admin-title-lines {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.beatori-admin-body .admin-muted {
  color: var(--text-secondary);
  font-size: 12px;
}

.beatori-admin-body .beatori-u-020,
.beatori-admin-body .beatori-u-022,
.beatori-admin-body .admin-chip-list,
.beatori-admin-body .admin-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.beatori-admin-body .beatori-u-022,
.beatori-admin-body .admin-actions {
  justify-content: flex-end;
}

.beatori-admin-body .beatori-u-097,
.beatori-admin-body .beatori-u-098,
.beatori-admin-body .beatori-u-019,
.beatori-admin-body .admin-cover,
.beatori-admin-body .admin-cover-placeholder {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  object-fit: cover;
}

.beatori-admin-body .beatori-u-098,
.beatori-admin-body .admin-cover-placeholder {
  border: 1px solid var(--border-subtle);
  background: var(--bg-elevated);
}

.beatori-admin-body .admin-empty-state,
.beatori-admin-body .beatori-u-037,
.beatori-admin-body .beatori-u-101 {
  display: grid;
  justify-items: center;
  gap: 12px;
  padding: 64px 24px;
  color: var(--text-secondary);
  background: transparent;
  border: 0;
  box-shadow: none;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
}

.beatori-admin-body .admin-empty-state .ph {
  color: var(--text-tertiary);
  font-size: 40px;
}

.markdown-editor {
  display: grid;
  gap: 12px;
}

.markdown-editor-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.markdown-editor-toolbar .btn {
  min-width: 40px;
}

.markdown-editor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
}

.markdown-editor-grid textarea {
  min-height: 28rem;
}

.markdown-preview {
  min-height: 28rem;
  padding: 16px;
  overflow: auto;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-card);
  background: var(--bg-void);
  color: var(--text-secondary);
}

.beatori-admin-body .email-template-workspace {
  display: grid;
  grid-template-columns: minmax(320px, 0.8fr) minmax(0, 1.15fr) minmax(360px, 0.95fr);
  gap: 16px;
  align-items: start;
}

.beatori-admin-body .email-template-workspace .admin-form-container {
  margin: 0;
}

.beatori-admin-body .email-template-panel-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.beatori-admin-body .email-template-panel-heading h2 {
  color: var(--text-primary);
  font-size: 20px;
  font-weight: 800;
}

.beatori-admin-body .email-template-panel-heading p {
  margin: 4px 0 0;
  color: var(--text-secondary);
  font-size: 13px;
}

.beatori-admin-body .email-template-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}

.beatori-admin-body .email-token-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 20px;
}

.beatori-admin-body .email-preview-subject {
  display: grid;
  gap: 4px;
  margin-bottom: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-control);
  background: var(--bg-void);
}

.beatori-admin-body .email-preview-subject span {
  color: var(--text-tertiary);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.beatori-admin-body .email-preview-subject strong {
  color: var(--text-primary);
  font-size: 14px;
}

.beatori-admin-body .email-preview-frame {
  width: 100%;
  height: 620px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-card);
  background: var(--bg-void);
}

.beatori-admin-body .email-preview-text {
  margin-top: 12px;
  color: var(--text-secondary);
  font-size: 13px;
}

.beatori-admin-body .email-preview-text summary {
  cursor: pointer;
}

.beatori-admin-body .email-preview-text pre {
  overflow: auto;
  margin: 8px 0 0;
  padding: 12px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-control);
  background: var(--bg-void);
  color: var(--text-secondary);
  font-family: var(--font-mono);
  font-size: 12px;
  white-space: pre-wrap;
}

.beatori-admin-body ::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.beatori-admin-body ::-webkit-scrollbar-track {
  background: transparent;
}

.beatori-admin-body ::-webkit-scrollbar-thumb {
  border-radius: var(--r-pill);
  background: var(--border-strong);
}

@media (max-width: 1280px) {
  .beatori-admin-body .filters-grid {
    grid-template-columns: 1fr;
  }

  .beatori-admin-body .email-template-workspace {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .beatori-admin-body .beatori-u-016 {
    display: grid;
  }

  .markdown-editor-grid {
    grid-template-columns: 1fr;
  }

  .beatori-admin-body .email-preview-frame {
    height: 520px;
  }
}
