:root {
  --ra-bg: #f8f9fa;
  --ra-page: #ffffff;
  --ra-text: #202122;
  --ra-muted: #54595d;
  --ra-line: #a2a9b1;
  --ra-line-soft: #c8ccd1;
  --ra-blue: #0645ad;
  --ra-blue-visited: #0b0080;
  --ra-red: #b32424;
  --ra-red-soft: #fff4f4;
  --ra-green-soft: #f5fff5;
  --ra-blue-soft: #f5faff;
  --ra-yellow-soft: #fffaf0;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  background: var(--ra-bg);
  color: var(--ra-text);
  font-family: sans-serif;
  font-size: 14px;
  line-height: 1.6;
}

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

a:visited {
  color: var(--ra-blue-visited);
}

a:hover {
  text-decoration: underline;
}

.ra-shell {
  min-height: 100vh;
}

/* Header: clean encyclopedia style */
.ra-header {
  background: #ffffff;
  border-bottom: 1px solid var(--ra-line);
}

.ra-header-inner {
  max-width: 1520px;
  margin: 0 auto;
  padding: 10px 18px;
  display: grid;
  grid-template-columns: 260px minmax(260px, 1fr) auto;
  gap: 18px;
  align-items: center;
}

.ra-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ra-text);
}

.ra-brand:hover {
  text-decoration: none;
}

.ra-brand-mark {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
}

.ra-brand-mark img {
  width: 38px;
  height: 38px;
  display: block;
}

.ra-brand-wordmark {
  display: block;
  width: 178px;
  max-width: 100%;
  height: auto;
}

.ra-brand-tagline {
  display: block;
  margin-top: 1px;
  color: var(--ra-muted);
  font-size: 11px;
}

/* Search */
.ra-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  max-width: 680px;
  width: 100%;
}

.ra-search input {
  min-width: 0;
  border: 1px solid var(--ra-line);
  border-right: 0;
  border-radius: 2px 0 0 2px;
  padding: 8px 10px;
  background: #fff;
  color: var(--ra-text);
  font-size: 14px;
  outline: none;
}

.ra-search input:focus {
  border-color: #36c;
  box-shadow: inset 0 0 0 1px #36c;
}

.ra-search button {
  border: 1px solid var(--ra-line);
  border-radius: 0 2px 2px 0;
  padding: 8px 12px;
  background: #f8f9fa;
  color: var(--ra-text);
  font-weight: 600;
  cursor: pointer;
}

.ra-search button:hover {
  background: #eaecf0;
}

.ra-usernav {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  white-space: nowrap;
  font-size: 13px;
}

/* Main layout */
.ra-layout {
  max-width: 1520px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 0;
}

/* Sidebar: Wikipedia-like */
.ra-sidebar {
  padding: 18px 16px 24px 18px;
  border-right: 1px solid #eaecf0;
}

.ra-sidebar-card {
  margin-bottom: 18px;
}

.ra-sidebar-title {
  color: var(--ra-muted);
  border-bottom: 1px solid #eaecf0;
  font-size: 12px;
  margin-bottom: 6px;
  padding-bottom: 3px;
}

.ra-sidebar-card a {
  display: block;
  padding: 3px 0;
  font-size: 13px;
}

/* Content */
.ra-content {
  min-width: 0;
  padding: 18px 20px 28px;
}

.ra-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0;
  margin-bottom: 0;
  border-bottom: 1px solid var(--ra-line);
}

.ra-tabs a {
  display: inline-flex;
  padding: 7px 11px;
  border: 1px solid transparent;
  border-bottom: 0;
  background: transparent;
  color: var(--ra-blue);
  font-size: 13px;
}

.ra-tabs a.is-active {
  color: var(--ra-text);
  background: #fff;
  border-color: var(--ra-line);
  border-bottom-color: #fff;
  margin-bottom: -1px;
  font-weight: 600;
}

.ra-article {
  background: var(--ra-page);
  border: 1px solid var(--ra-line);
  border-top: 0;
  box-shadow: none;
}

.ra-article-header {
  padding: 22px 24px 10px;
}

.ra-article-kicker {
  display: none;
}

.ra-title {
  margin: 0;
  color: var(--ra-text);
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 34px;
  line-height: 1.25;
  font-weight: normal;
  border-bottom: 1px solid var(--ra-line);
}

.ra-tagline {
  margin-top: 6px;
  color: var(--ra-muted);
  font-size: 13px;
}

.ra-body {
  padding: 16px 24px 26px;
}

.ra-body h2 {
  margin-top: 1.3em;
  padding-bottom: 2px;
  border-bottom: 1px solid var(--ra-line);
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 22px;
  line-height: 1.3;
  font-weight: normal;
}

.ra-body h3 {
  font-size: 17px;
}

.ra-body p,
.ra-body li {
  color: var(--ra-text);
}

.toc,
#toc {
  border: 1px solid var(--ra-line);
  background: #f8f9fa;
  padding: 10px;
}

.wikitable {
  border: 1px solid var(--ra-line);
  border-collapse: collapse;
  background: #f8f9fa;
}

.wikitable th {
  background: #eaecf0;
}

.wikitable th,
.wikitable td {
  border: 1px solid var(--ra-line);
  padding: 0.35em 0.55em;
}

.infobox {
  border: 1px solid var(--ra-line) !important;
  background: #f8f9fa !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.catlinks {
  border: 1px solid var(--ra-line) !important;
  background: #f8f9fa !important;
  padding: 10px !important;
  margin-top: 18px;
}

/* Footer */
.ra-footer {
  margin-top: 18px;
  color: var(--ra-muted);
  border-top: 1px solid #eaecf0;
  padding: 14px 2px;
  font-size: 12px;
}

.ra-footer strong {
  color: var(--ra-text);
  display: block;
}

/* Main Page Wikipedia-style */
body.page-Main_Page .ra-article-header {
  display: none;
}

body.page-Main_Page .ra-body {
  padding: 18px 24px 26px;
}

body.page-Main_Page .ra-body .mw-parser-output > p:first-child {
  display: none;
}

.ra-wiki-welcome {
  width: 100%;
  border: 1px solid var(--ra-line);
  background: #f8f9fa;
  margin-bottom: 12px;
  border-collapse: collapse;
}

.ra-wiki-welcome td {
  padding: 16px;
  vertical-align: middle;
}

.ra-wiki-welcome-left {
  width: 70%;
  text-align: center;
}

.ra-wiki-welcome-right {
  width: 30%;
  border-left: 1px solid var(--ra-line);
  background: #ffffff;
}

.ra-wiki-title {
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 32px;
  line-height: 1.25;
}

.ra-wiki-subtitle {
  margin-top: 4px;
  font-size: 15px;
}

.ra-wiki-actions {
  margin-top: 10px;
}

.ra-wiki-layout {
  width: 100%;
  border-spacing: 10px;
  border-collapse: separate;
}

.ra-wiki-maincol {
  width: 65%;
  vertical-align: top;
}

.ra-wiki-sidecol {
  width: 35%;
  vertical-align: top;
}

.ra-wiki-box {
  border: 1px solid var(--ra-line);
  background: #ffffff;
  padding: 12px;
  margin-bottom: 12px;
}

.ra-wiki-box-featured {
  background: var(--ra-blue-soft);
}

.ra-wiki-box-side {
  background: #f8f9fa;
}

.ra-wiki-box-title {
  margin: -12px -12px 10px;
  padding: 6px 10px;
  border-bottom: 1px solid var(--ra-line);
  background: #eaecf0;
  font-size: 16px;
  font-weight: bold;
}

.ra-wiki-box-featured .ra-wiki-box-title {
  background: #d8ecff;
}

.ra-wiki-more {
  margin-top: 8px;
  font-weight: bold;
}

.ra-wiki-topic-table {
  width: 100%;
  border-collapse: collapse;
}

.ra-wiki-topic-table td {
  width: 50%;
  vertical-align: top;
  border: 1px solid #eaecf0;
  padding: 10px;
  background: #fff;
}

.ra-wiki-topic-table span {
  color: var(--ra-muted);
  font-size: 13px;
}

/* Keep old landing/fandom classes neutral if any remain */
.ra-fandom-home,
.ra-landing,
.ra-home-hero,
.ra-mainpage {
  all: unset;
}

/* Mobile */
@media (max-width: 900px) {
  .ra-header-inner {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .ra-search {
    max-width: none;
  }

  .ra-usernav {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .ra-layout {
    grid-template-columns: 1fr;
  }

  .ra-sidebar {
    border-right: 0;
    border-bottom: 1px solid #eaecf0;
    padding: 12px 18px;
  }

  .ra-sidebar-card {
    margin-bottom: 12px;
  }

  .ra-content {
    padding: 12px;
  }

  .ra-wiki-welcome,
  .ra-wiki-welcome tbody,
  .ra-wiki-welcome tr,
  .ra-wiki-welcome td,
  .ra-wiki-layout,
  .ra-wiki-layout tbody,
  .ra-wiki-layout tr,
  .ra-wiki-layout td,
  .ra-wiki-topic-table,
  .ra-wiki-topic-table tbody,
  .ra-wiki-topic-table tr,
  .ra-wiki-topic-table td {
    display: block;
    width: 100% !important;
  }

  .ra-wiki-welcome-right {
    border-left: 0;
    border-top: 1px solid var(--ra-line);
  }

  .ra-wiki-layout {
    border-spacing: 0;
  }

  .ra-wiki-title {
    font-size: 28px;
  }
}

/* =========================================================
   Roovet Articles — Article Page Polish
   Keeps the Wikipedia-style look, but improves readability.
   ========================================================= */

/* Better reading width on article pages */
.ra-body .mw-parser-output {
  max-width: 1180px;
}

.ra-body p {
  margin: 0.55em 0 0.9em;
}

.ra-body ul,
.ra-body ol {
  margin-top: 0.35em;
  margin-bottom: 1em;
}

.ra-body blockquote {
  margin: 1em 0;
  padding: 0.65em 1em;
  border-left: 4px solid #c8ccd1;
  background: #f8f9fa;
  color: #202122;
}

/* Better article images/thumbs */
.thumbinner {
  border: 1px solid #a2a9b1 !important;
  background: #f8f9fa !important;
  padding: 4px !important;
}

.thumbcaption {
  color: #54595d;
  font-size: 12px;
  line-height: 1.45;
}

/* Better references/citations */
.reference {
  font-size: 0.82em;
  font-weight: 600;
}

.references {
  font-size: 13px;
  line-height: 1.55;
}

.references li {
  margin-bottom: 0.45em;
}

.mw-references-wrap {
  padding-top: 4px;
}

/* Better standard tables */
.ra-body table.wikitable {
  margin: 1em 0;
  font-size: 14px;
}

.ra-body table.wikitable caption {
  font-weight: bold;
  text-align: left;
  padding: 0.35em 0;
}

/* Better category box */
.catlinks {
  font-size: 13px;
}

.catlinks a {
  font-weight: 500;
}

/* Better notice templates */
.ra-notice {
  margin: 0.75em 0 1em;
  padding: 0.75em 0.9em;
  border: 1px solid #a2a9b1;
  background: #f8f9fa;
  line-height: 1.55;
}

.ra-notice b {
  color: #202122;
}

.ra-notice-verified {
  border-color: #8abf9a;
  background: #f5fff5;
}

.ra-notice-warning {
  border-color: #d6b656;
  background: #fffaf0;
}

.ra-notice-badge {
  display: inline-block;
  margin-right: 0.5em;
  padding: 0.15em 0.45em;
  border: 1px solid currentColor;
  border-radius: 2px;
  font-size: 11px;
  font-weight: bold;
  text-transform: uppercase;
}

.ra-notice-verified .ra-notice-badge {
  color: #236b36;
}

.ra-notice-warning .ra-notice-badge {
  color: #806000;
}

.ra-inline-source-needed {
  color: #b32424;
  font-size: 0.82em;
  font-weight: bold;
  white-space: nowrap;
}

.ra-inline-source-needed::before {
  content: "[";
}

.ra-inline-source-needed::after {
  content: "]";
}

/* Article header template */
.ra-article-intro {
  margin: 0.2em 0 1.1em;
  padding: 1em;
  border: 1px solid #a2a9b1;
  background: #f8f9fa;
}

.ra-article-intro-kicker {
  color: #54595d;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ra-article-intro-title {
  margin-top: 0.15em;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 26px;
  line-height: 1.25;
}

.ra-article-intro-summary {
  margin-top: 0.45em;
  color: #202122;
}

.ra-article-intro-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45em;
  margin-top: 0.7em;
}

.ra-article-intro-meta span {
  padding: 0.18em 0.5em;
  border: 1px solid #c8ccd1;
  background: #fff;
  font-size: 12px;
}

/* Quality box */
.ra-quality-box {
  clear: both;
  margin: 1em 0;
  padding: 0.85em;
  border: 1px solid #a2a9b1;
  background: #f8f9fa;
}

.ra-quality-title {
  font-weight: bold;
  font-size: 15px;
  border-bottom: 1px solid #c8ccd1;
  padding-bottom: 0.25em;
  margin-bottom: 0.45em;
}

.ra-quality-text {
  color: #202122;
}

.ra-quality-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4em;
  margin-top: 0.65em;
}

.ra-quality-row span {
  background: #fff;
  border: 1px solid #c8ccd1;
  padding: 0.18em 0.5em;
  font-size: 12px;
}

/* Profile boxes */
.ra-profilebox {
  float: right;
  clear: right;
  width: 300px;
  margin: 0 0 1em 1em;
  border: 1px solid #a2a9b1;
  border-collapse: collapse;
  background: #f8f9fa;
  font-size: 13px;
}

.ra-profilebox caption {
  padding: 0.45em;
  background: #eaecf0;
  border: 1px solid #a2a9b1;
  border-bottom: 0;
  font-size: 18px;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-weight: normal;
}

.ra-profilebox th,
.ra-profilebox td {
  border: 1px solid #c8ccd1;
  padding: 0.45em 0.55em;
  vertical-align: top;
}

.ra-profilebox th {
  width: 35%;
  background: #eaecf0;
  text-align: left;
}

.ra-profilebox-type {
  text-align: center !important;
  background: #f1f3f5 !important;
  font-weight: bold;
}

.ra-profilebox-image {
  text-align: center;
  background: #fff;
}

.ra-profilebox-image img {
  max-width: 100%;
  height: auto;
}

/* Article footer note */
.ra-article-footer-note {
  clear: both;
  margin-top: 1.5em;
  padding: 0.75em 0.9em;
  border: 1px solid #c8ccd1;
  background: #f8f9fa;
  color: #54595d;
  font-size: 13px;
}

/* Make template documentation pages readable */
body.page-Template_Roovet_article_header pre,
body.page-Template_Roovet_person_profile pre,
body.page-Template_Roovet_organization_profile pre,
body.page-Template_Roovet_quality pre {
  white-space: pre-wrap;
  border: 1px solid #c8ccd1;
  background: #f8f9fa;
  padding: 0.75em;
}

/* Mobile article polish */
@media (max-width: 760px) {
  .ra-profilebox {
    float: none;
    width: 100%;
    margin: 0 0 1em;
  }

  .ra-article-intro-meta,
  .ra-quality-row {
    display: block;
  }

  .ra-article-intro-meta span,
  .ra-quality-row span {
    display: block;
    margin-top: 0.35em;
  }

  .ra-body {
    padding-left: 16px;
    padding-right: 16px;
  }
}


/* =========================================================
   Roovet Articles — Strong Article Detail Upgrade
   Applies to normal article pages, not just template pages.
   ========================================================= */

body.ns-0:not(.page-Main_Page) .ra-article {
  background: #ffffff;
}

body.ns-0:not(.page-Main_Page) .ra-article-header {
  background: linear-gradient(180deg, #ffffff 0%, #f8f9fa 100%);
  border-bottom: 1px solid #a2a9b1;
  padding: 22px 26px 14px;
}

body.ns-0:not(.page-Main_Page) .ra-title {
  font-size: 38px;
  line-height: 1.18;
}

body.ns-0:not(.page-Main_Page) .ra-tagline {
  display: inline-block;
  margin-top: 8px;
  padding: 3px 7px;
  border: 1px solid #c8ccd1;
  background: #f8f9fa;
  color: #54595d;
  font-size: 12px;
}

body.ns-0:not(.page-Main_Page) .ra-body {
  padding-top: 20px;
}

body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p:first-of-type {
  font-size: 16px;
  line-height: 1.72;
}

body.ns-0:not(.page-Main_Page) .ra-body h2 {
  margin-top: 1.55em;
  padding-bottom: 3px;
  border-bottom: 1px solid #a2a9b1;
  color: #202122;
}

body.ns-0:not(.page-Main_Page) .ra-body h2 .mw-headline {
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-weight: normal;
}

body.ns-0:not(.page-Main_Page) .ra-body h3 {
  margin-top: 1.25em;
  color: #202122;
  font-size: 18px;
}

body.ns-0:not(.page-Main_Page) .ra-body a {
  font-weight: 500;
}

body.ns-0:not(.page-Main_Page) .ra-tabs {
  margin-bottom: 0;
}

body.ns-0:not(.page-Main_Page) .ra-tabs a {
  background: #f8f9fa;
}

body.ns-0:not(.page-Main_Page) .ra-tabs a.is-active {
  background: #ffffff;
}

body.ns-0:not(.page-Main_Page) .ra-footer {
  margin-top: 16px;
}

/* More visible Roovet profile box */
.ra-profilebox {
  box-shadow: 0 2px 0 rgba(0,0,0,.02);
}

.ra-profilebox caption {
  background: #d8ecff;
  color: #202122;
}

.ra-profilebox-type {
  background: #f8f9fa !important;
  color: #54595d;
}

/* Make Roovet editorial boxes stand out */
.ra-article-intro {
  border-left: 4px solid #36c;
  background: #f8fbff;
}

.ra-article-intro-title {
  color: #202122;
}

.ra-quality-box {
  border-left: 4px solid #72777d;
}

.ra-notice-verified {
  border-left: 4px solid #2a7b3f;
}

.ra-notice-warning {
  border-left: 4px solid #b8860b;
}


/* =========================================================
   Roovet Articles — Infobox + TOC Upgrade
   ========================================================= */

/* Compact TOC like a real encyclopedia */
.ra-body #toc,
.ra-body .toc {
  display: table !important;
  width: auto !important;
  min-width: 260px;
  max-width: 360px;
  margin: 0.75em 1.25em 1em 0 !important;
  padding: 0 !important;
  border: 1px solid #a2a9b1 !important;
  background: #f8f9fa !important;
  font-size: 13px;
}

.ra-body #toc .toctitle,
.ra-body .toc .toctitle {
  padding: 0.45em 0.65em;
  border-bottom: 1px solid #c8ccd1;
  background: #eaecf0;
  text-align: left;
}

.ra-body #toc ul,
.ra-body .toc ul {
  padding: 0.45em 1.2em 0.65em;
}

/* Better person/profile infobox */
.ra-profilebox {
  float: right;
  clear: right;
  width: 320px;
  margin: 0 0 1.15em 1.35em;
  border: 1px solid #a2a9b1;
  border-collapse: separate;
  border-spacing: 0;
  background: #ffffff;
  font-size: 13px;
  box-shadow: 0 2px 8px rgba(32,33,34,.08);
}

.ra-profilebox caption {
  padding: 0.62em 0.7em;
  border: 1px solid #a2a9b1;
  border-bottom: 0;
  background: linear-gradient(180deg, #f8f9fa 0%, #eaecf0 100%);
  color: #202122;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 21px;
  line-height: 1.2;
  font-weight: normal;
  text-align: center;
}

.ra-profilebox th,
.ra-profilebox td {
  border-top: 1px solid #c8ccd1;
  padding: 0.52em 0.65em;
  vertical-align: top;
}

.ra-profilebox th {
  width: 34%;
  background: #f1f3f5;
  color: #202122;
  text-align: left;
  font-weight: bold;
}

.ra-profilebox td {
  background: #ffffff;
}

.ra-profilebox-photo {
  padding: 0 !important;
  background: #111827 !important;
  text-align: center;
}

.ra-profilebox-photo img {
  display: block;
  width: 100%;
  max-width: 320px;
  height: auto;
  margin: 0 auto;
}

.ra-profilebox-photo-placeholder {
  display: grid;
  place-items: center;
  height: 230px;
  background:
    radial-gradient(circle at top right, rgba(215,25,32,.32), transparent 36%),
    linear-gradient(135deg, #111827, #2d3748);
}

.ra-profilebox-photo-placeholder span {
  display: grid;
  place-items: center;
  width: 96px;
  height: 96px;
  border-radius: 999px;
  background: #d71920;
  color: #ffffff;
  font-size: 38px;
  font-weight: 900;
  letter-spacing: -0.06em;
  box-shadow: 0 12px 28px rgba(0,0,0,.25);
}

.ra-profilebox-type {
  background: #202122 !important;
  color: #ffffff !important;
  text-align: center !important;
  letter-spacing: .02em;
}

/* Improve standard imported infoboxes too */
.infobox {
  float: right;
  clear: right;
  width: 320px;
  margin: 0 0 1.15em 1.35em;
  border: 1px solid #a2a9b1 !important;
  background: #ffffff !important;
  box-shadow: 0 2px 8px rgba(32,33,34,.08) !important;
}

.infobox caption,
.infobox-title,
.infobox-above {
  background: #eaecf0 !important;
  color: #202122 !important;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 20px !important;
  font-weight: normal !important;
}

/* Hide visible parser/Lua error fragments if old pages still have them while we clean them */
.mw-parser-output > p:has(.error),
.mw-parser-output .error {
  border: 1px solid #b32424;
  background: #fff4f4;
  color: #b32424;
  padding: 0.45em 0.6em;
}

/* Mobile */
@media (max-width: 760px) {
  .ra-profilebox,
  .infobox {
    float: none;
    width: 100%;
    margin: 0 0 1em 0;
  }

  .ra-body #toc,
  .ra-body .toc {
    display: block !important;
    max-width: none;
    width: 100% !important;
    margin-right: 0 !important;
  }
}


/* =========================================================
   Roovet Articles — Final Infobox + TOC Fix
   ========================================================= */

/* Compact TOC */
.ra-body #toc,
.ra-body .toc {
  display: table !important;
  width: auto !important;
  min-width: 260px;
  max-width: 360px;
  margin: 0.75em 1.25em 1em 0 !important;
  padding: 0 !important;
  border: 1px solid #a2a9b1 !important;
  background: #f8f9fa !important;
  font-size: 13px;
}

.ra-body #toc .toctitle,
.ra-body .toc .toctitle {
  padding: 0.45em 0.65em;
  border-bottom: 1px solid #c8ccd1;
  background: #eaecf0;
  text-align: left;
}

.ra-body #toc ul,
.ra-body .toc ul {
  padding: 0.45em 1.2em 0.65em;
}

/* Better Roovet person infobox */
.ra-profilebox {
  float: right;
  clear: right;
  width: 330px;
  margin: 0 0 1.15em 1.35em;
  border: 1px solid #a2a9b1;
  border-collapse: separate;
  border-spacing: 0;
  background: #ffffff;
  font-size: 13px;
  box-shadow: 0 2px 9px rgba(32,33,34,.10);
}

.ra-profilebox caption {
  padding: 0.7em 0.75em;
  border: 1px solid #a2a9b1;
  border-bottom: 0;
  background: linear-gradient(180deg, #f8f9fa 0%, #eaecf0 100%);
  color: #202122;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 22px;
  line-height: 1.18;
  font-weight: normal;
  text-align: center;
}

.ra-profilebox th,
.ra-profilebox td {
  border-top: 1px solid #c8ccd1;
  padding: 0.54em 0.65em;
  vertical-align: top;
}

.ra-profilebox th {
  width: 36%;
  background: #f1f3f5;
  color: #202122;
  text-align: left;
  font-weight: bold;
}

.ra-profilebox td {
  background: #ffffff;
}

.ra-profilebox-photo {
  padding: 0 !important;
  background: #111827 !important;
  text-align: center;
}

.ra-profilebox-photo img {
  display: block;
  width: 100%;
  max-width: 330px;
  height: auto;
  margin: 0 auto;
}

.ra-profilebox-caption {
  padding: 0.45em 0.65em;
  background: #f8f9fa;
  color: #54595d;
  border-top: 1px solid #c8ccd1;
  font-size: 12px;
  line-height: 1.45;
}

.ra-profilebox-photo-placeholder {
  display: grid;
  place-items: center;
  height: 230px;
  background:
    radial-gradient(circle at top right, rgba(215,25,32,.32), transparent 36%),
    linear-gradient(135deg, #111827, #2d3748);
}

.ra-profilebox-photo-placeholder span {
  display: grid;
  place-items: center;
  width: 96px;
  height: 96px;
  border-radius: 999px;
  background: #d71920;
  color: #ffffff;
  font-size: 38px;
  font-weight: 900;
  letter-spacing: -0.06em;
  box-shadow: 0 12px 28px rgba(0,0,0,.25);
}

.ra-profilebox-type {
  background: #202122 !important;
  color: #ffffff !important;
  text-align: center !important;
  letter-spacing: .02em;
}

/* Better standard imported infoboxes too */
.infobox {
  float: right;
  clear: right;
  width: 330px;
  margin: 0 0 1.15em 1.35em;
  border: 1px solid #a2a9b1 !important;
  background: #ffffff !important;
  box-shadow: 0 2px 9px rgba(32,33,34,.10) !important;
}

.infobox caption,
.infobox-title,
.infobox-above {
  background: #eaecf0 !important;
  color: #202122 !important;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 20px !important;
  font-weight: normal !important;
}

/* Lua/parser error blocks should be obvious only if something remains after cleanup */
.mw-parser-output .error {
  border: 1px solid #b32424;
  background: #fff4f4;
  color: #b32424;
  padding: 0.45em 0.6em;
}

/* Mobile */
@media (max-width: 760px) {
  .ra-profilebox,
  .infobox {
    float: none;
    width: 100%;
    margin: 0 0 1em 0;
  }

  .ra-body #toc,
  .ra-body .toc {
    display: block !important;
    max-width: none;
    width: 100% !important;
    margin-right: 0 !important;
  }
}


/* =========================================================
   Roovet Articles — Layout repair for infobox pages
   ========================================================= */

:root {
  --ra-infobox-width: 360px;
  --ra-infobox-gap: 26px;
}

/* Bigger, prettier infobox */
.ra-profilebox,
.infobox {
  float: right;
  clear: right;
  width: var(--ra-infobox-width);
  margin: 0 0 1.15em var(--ra-infobox-gap);
  border: 1px solid #a2a9b1 !important;
  background: #fff !important;
  box-shadow: 0 2px 10px rgba(32,33,34,.08) !important;
}

.ra-profilebox caption {
  padding: 0.7em 0.8em;
  border: 1px solid #a2a9b1;
  border-bottom: 0;
  background: linear-gradient(180deg, #f8f9fa 0%, #eaecf0 100%);
  color: #202122;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 23px;
  line-height: 1.15;
  font-weight: normal;
  text-align: center;
}

.ra-profilebox th,
.ra-profilebox td {
  border-top: 1px solid #c8ccd1;
  padding: 0.56em 0.7em;
  vertical-align: top;
}

.ra-profilebox th {
  width: 37%;
  background: #f1f3f5;
  text-align: left;
  font-weight: 700;
}

.ra-profilebox td {
  background: #fff;
}

.ra-profilebox-photo {
  padding: 0 !important;
  background: #111827 !important;
  text-align: center;
}

.ra-profilebox-photo img {
  display: block;
  width: 100%;
  max-width: var(--ra-infobox-width);
  height: auto;
  margin: 0 auto;
}

.ra-profilebox-caption {
  padding: 0.5em 0.7em;
  background: #f8f9fa;
  color: #54595d;
  border-top: 1px solid #c8ccd1;
  font-size: 12px;
  line-height: 1.45;
}

.ra-profilebox-photo-placeholder {
  display: grid;
  place-items: center;
  height: 250px;
  background:
    radial-gradient(circle at top right, rgba(215,25,32,.32), transparent 36%),
    linear-gradient(135deg, #111827, #2d3748);
}

.ra-profilebox-photo-placeholder span {
  display: grid;
  place-items: center;
  width: 100px;
  height: 100px;
  border-radius: 999px;
  background: #d71920;
  color: #fff;
  font-size: 40px;
  font-weight: 900;
  letter-spacing: -0.06em;
}

.ra-profilebox-type {
  background: #202122 !important;
  color: #fff !important;
  text-align: center !important;
  letter-spacing: .02em;
}

/* Make content actually flow beside the infobox */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-notice,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-intro,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-quality-box,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > #toc,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .toc {
  max-width: calc(100% - var(--ra-infobox-width) - var(--ra-infobox-gap) - 6px);
}

/* DO NOT clear the infobox here or you get the giant blank space */
.ra-quality-box,
.ra-article-footer-note {
  clear: none !important;
}

/* Put the quality box under the lead area naturally */
.ra-quality-box {
  margin-top: 1em;
}

/* Compact TOC */
.ra-body #toc,
.ra-body .toc {
  display: table !important;
  width: auto !important;
  min-width: 260px;
  max-width: 360px;
  margin: 0.8em 1.2em 1em 0 !important;
  padding: 0 !important;
  border: 1px solid #a2a9b1 !important;
  background: #f8f9fa !important;
  font-size: 13px;
}

.ra-body #toc .toctitle,
.ra-body .toc .toctitle {
  padding: 0.45em 0.65em;
  border-bottom: 1px solid #c8ccd1;
  background: #eaecf0;
  text-align: left;
}

.ra-body #toc ul,
.ra-body .toc ul {
  padding: 0.45em 1.2em 0.65em;
}

/* Better lead paragraph */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p:first-of-type {
  font-size: 17px;
  line-height: 1.75;
}

/* Mobile */
@media (max-width: 860px) {
  .ra-profilebox,
  .infobox {
    float: none;
    width: 100%;
    margin: 0 0 1em 0;
  }

  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-notice,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-intro,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-quality-box,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > #toc,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .toc {
    max-width: 100%;
  }
}


/* =========================================================
   Roovet Articles — Surgical article-flow repair
   ========================================================= */

:root {
  --ra-infobox-width: 360px;
  --ra-infobox-gap: 26px;
}

.ra-profilebox,
.infobox {
  float: right;
  clear: right;
  width: var(--ra-infobox-width);
  margin: 0 0 1.15em var(--ra-infobox-gap);
}

/* Keep text on the left side of the infobox */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-notice,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-intro,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > #toc,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .toc {
  max-width: calc(100% - var(--ra-infobox-width) - var(--ra-infobox-gap) - 8px);
}

/* Do not let editorial boxes clear the profilebox and create blank white space */
.ra-quality-box,
.ra-article-footer-note {
  clear: none !important;
}

/* Quality box should behave like a normal content box */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-quality-box {
  max-width: calc(100% - var(--ra-infobox-width) - var(--ra-infobox-gap) - 8px);
}

/* Compact TOC */
.ra-body #toc,
.ra-body .toc {
  display: table !important;
  width: auto !important;
  min-width: 260px;
  max-width: 360px;
  margin: 0.8em 1.2em 1em 0 !important;
  padding: 0 !important;
  border: 1px solid #a2a9b1 !important;
  background: #f8f9fa !important;
  font-size: 13px;
}

.ra-body #toc .toctitle,
.ra-body .toc .toctitle {
  padding: 0.45em 0.65em;
  border-bottom: 1px solid #c8ccd1;
  background: #eaecf0;
  text-align: left;
}

.ra-body #toc ul,
.ra-body .toc ul {
  padding: 0.45em 1.2em 0.65em;
}

/* Mobile reset */
@media (max-width: 860px) {
  .ra-profilebox,
  .infobox {
    float: none;
    width: 100%;
    margin: 0 0 1em 0;
  }

  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-notice,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-intro,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-quality-box,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > #toc,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .toc {
    max-width: 100%;
  }
}


/* =========================================================
   Roovet Articles — Preserve-content article layout fix
   ========================================================= */

:root {
  --ra-infobox-width: 360px;
  --ra-infobox-gap: 26px;
}

/* Hide generated Scribunto/Lua/parser error boxes while old imported templates are being retired */
.mw-parser-output .error,
.mw-parser-output .scribunto-error,
.mw-parser-output .mw-ext-cite-error,
.mw-parser-output .lua-error {
  display: none !important;
}

/* Do not leave empty red boxes after hiding parser errors */
.mw-parser-output p:empty,
.mw-parser-output div:empty {
  display: none !important;
}

/* Main infobox */
.ra-profilebox,
.infobox {
  float: right;
  clear: right;
  width: var(--ra-infobox-width);
  margin: 0 0 1.15em var(--ra-infobox-gap);
  border: 1px solid #a2a9b1 !important;
  background: #fff !important;
  box-shadow: 0 2px 10px rgba(32,33,34,.08) !important;
}

.ra-profilebox caption {
  padding: 0.7em 0.8em;
  border: 1px solid #a2a9b1;
  border-bottom: 0;
  background: linear-gradient(180deg, #f8f9fa 0%, #eaecf0 100%);
  color: #202122;
  font-family: Georgia, "Linux Libertine", "Times New Roman", serif;
  font-size: 23px;
  line-height: 1.15;
  font-weight: normal;
  text-align: center;
}

.ra-profilebox th,
.ra-profilebox td {
  border-top: 1px solid #c8ccd1;
  padding: 0.56em 0.7em;
  vertical-align: top;
}

.ra-profilebox th {
  width: 37%;
  background: #f1f3f5;
  text-align: left;
  font-weight: 700;
}

.ra-profilebox td {
  background: #fff;
}

.ra-profilebox-photo {
  padding: 0 !important;
  background: #111827 !important;
  text-align: center;
}

.ra-profilebox-photo img {
  display: block;
  width: 100%;
  max-width: var(--ra-infobox-width);
  height: auto;
  margin: 0 auto;
}

.ra-profilebox-caption {
  padding: 0.5em 0.7em;
  background: #f8f9fa;
  color: #54595d;
  border-top: 1px solid #c8ccd1;
  font-size: 12px;
  line-height: 1.45;
}

.ra-profilebox-type {
  background: #202122 !important;
  color: #fff !important;
  text-align: center !important;
  letter-spacing: .02em;
}

/* Let article body flow beside infobox */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-notice,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-intro,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > #toc,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .toc {
  max-width: calc(100% - var(--ra-infobox-width) - var(--ra-infobox-gap) - 8px);
}

/* Quality box goes lower and should not force blank space beside the infobox */
.ra-quality-box,
.ra-article-footer-note {
  clear: both !important;
  max-width: 100% !important;
}

/* Compact TOC */
.ra-body #toc,
.ra-body .toc {
  display: table !important;
  width: auto !important;
  min-width: 260px;
  max-width: 360px;
  margin: 0.8em 1.2em 1em 0 !important;
  padding: 0 !important;
  border: 1px solid #a2a9b1 !important;
  background: #f8f9fa !important;
  font-size: 13px;
}

.ra-body #toc .toctitle,
.ra-body .toc .toctitle {
  padding: 0.45em 0.65em;
  border-bottom: 1px solid #c8ccd1;
  background: #eaecf0;
  text-align: left;
}

.ra-body #toc ul,
.ra-body .toc ul {
  padding: 0.45em 1.2em 0.65em;
}

/* Mobile reset */
@media (max-width: 860px) {
  .ra-profilebox,
  .infobox {
    float: none;
    width: 100%;
    margin: 0 0 1em 0;
  }

  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-notice,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-intro,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > #toc,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .toc {
    max-width: 100%;
  }
}


/* =========================================================
   Roovet Articles — Final Lua red-mark cleanup
   ========================================================= */

/* Neutralize parser/Lua error styling if an old imported template still outputs one */
.mw-parser-output .error,
.mw-parser-output .scribunto-error,
.mw-parser-output .lua-error,
.mw-parser-output .mw-ext-cite-error {
  border: 0 !important;
  background: transparent !important;
  color: inherit !important;
  padding: 0 !important;
  margin: 0 !important;
  font: inherit !important;
}

/* If an error element is empty after JS cleanup, hide it */
.mw-parser-output .error:empty,
.mw-parser-output .scribunto-error:empty,
.mw-parser-output .lua-error:empty,
.mw-parser-output .mw-ext-cite-error:empty {
  display: none !important;
}

/* Remove red borders/backgrounds from paragraphs/divs that only got styled because of parser errors */
.mw-parser-output p:has(.error),
.mw-parser-output div:has(.error),
.mw-parser-output p:has(.scribunto-error),
.mw-parser-output div:has(.scribunto-error) {
  border: 0 !important;
  background: transparent !important;
  color: inherit !important;
  padding: 0 !important;
}

/* Keep real article text normal even if a hidden error was injected near it */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p {
  color: #202122 !important;
}

/* Remove empty red boxes left after hiding text */
.mw-parser-output p:empty,
.mw-parser-output div:empty {
  display: none !important;
}


/* =========================================================
   Roovet Articles — Final article width repair
   ========================================================= */

/*
   Let normal article content use full width again.
   The infobox float already makes text wrap naturally beside it.
   Do not force every paragraph to stay half-page forever.
*/
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > dl,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > blockquote,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > h2,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > h3,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > h4,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-notice,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-intro,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-quality-box,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .ra-article-footer-note,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > .toc,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > #toc {
  max-width: none !important;
}

/* Keep infobox floating right, but let article body naturally wrap around it */
.ra-profilebox,
.infobox {
  float: right;
  clear: right;
  width: var(--ra-infobox-width, 360px);
  margin: 0 0 1.15em var(--ra-infobox-gap, 26px);
}

/* Full-width sections should resume after the infobox where appropriate */
body.ns-0:not(.page-Main_Page) .ra-body h2,
body.ns-0:not(.page-Main_Page) .ra-body .references,
body.ns-0:not(.page-Main_Page) .ra-body .mw-references-wrap,
body.ns-0:not(.page-Main_Page) .ra-body .catlinks {
  clear: both;
}

/* Keep the first few intro/editorial boxes from forcing big blank columns */
.ra-article-intro,
.ra-notice,
.ra-quality-box {
  clear: none !important;
}

/* Remove leftover empty red outlines from old Lua/parser fragments */
.mw-parser-output .error,
.mw-parser-output .scribunto-error,
.mw-parser-output .lua-error,
.mw-parser-output .mw-ext-cite-error,
.mw-parser-output .mw-parser-output-error {
  display: none !important;
  border: 0 !important;
  background: transparent !important;
  color: inherit !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* If a paragraph/div only existed to hold an error, hide the empty shell */
.mw-parser-output p:has(> .error:only-child),
.mw-parser-output div:has(> .error:only-child),
.mw-parser-output p:has(> .scribunto-error:only-child),
.mw-parser-output div:has(> .scribunto-error:only-child) {
  display: none !important;
}

/* Neutralize any old red parser-error wrapper that survived */
.mw-parser-output p[style*="border"],
.mw-parser-output div[style*="border"] {
  border-color: transparent !important;
}

/* Keep actual article text normal */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p {
  color: #202122 !important;
}

/* Mobile remains single column */
@media (max-width: 860px) {
  .ra-profilebox,
  .infobox {
    float: none;
    width: 100%;
    margin: 0 0 1em 0;
  }

  body.ns-0:not(.page-Main_Page) .ra-body h2,
  body.ns-0:not(.page-Main_Page) .ra-body .references,
  body.ns-0:not(.page-Main_Page) .ra-body .mw-references-wrap,
  body.ns-0:not(.page_Main_Page) .ra-body .catlinks {
    clear: none;
  }
}


/* =========================================================
   Roovet Articles — Safe Polish Pass
   No article content changes. Skin-only improvements.
   ========================================================= */

/* General article readability */
.ra-body .mw-parser-output {
  max-width: none;
}

.ra-body .mw-parser-output p {
  margin-top: 0.55em;
  margin-bottom: 0.9em;
}

.ra-body .mw-parser-output h2 {
  margin-top: 1.65em;
}

.ra-body .mw-parser-output h3 {
  margin-top: 1.25em;
  border-bottom: 0;
}

/* Make section edit links less huge and less distracting */
.mw-editsection {
  font-family: sans-serif;
  font-size: 13px;
  font-weight: normal;
  margin-left: 0.35em;
}

.mw-editsection,
.mw-editsection a {
  color: #54595d !important;
}

.mw-editsection a:hover {
  color: #0645ad !important;
}

/* References */
.references {
  font-size: 13px;
  line-height: 1.55;
  column-gap: 2em;
}

.references li {
  margin-bottom: 0.45em;
}

.reference {
  font-size: 0.82em;
  font-weight: 600;
}

.mw-references-wrap {
  margin-top: 0.7em;
  padding-top: 0.4em;
}

/* External links */
.ra-body a.external,
.ra-body a.extiw {
  word-break: break-word;
}

/* Category pages */
body.ns-14 .ra-body .mw-parser-output,
body.page-Special_Categories .ra-body .mw-parser-output {
  max-width: none;
}

#mw-pages,
#mw-subcategories,
#mw-category-media,
.category,
.mw-category {
  border: 1px solid #a2a9b1;
  background: #f8f9fa;
  padding: 12px;
  margin-top: 12px;
}

.mw-category-columns {
  column-gap: 2em;
}

.mw-category-group h3 {
  margin: 0.65em 0 0.25em;
  padding: 0.15em 0.35em;
  background: #eaecf0;
  border: 1px solid #c8ccd1;
  font-family: sans-serif;
  font-size: 15px;
  font-weight: bold;
}

/* Search pages */
body.mw-special-Search .ra-body,
body.page-Special_Search .ra-body {
  background: #fff;
}

.searchresults {
  margin-top: 1em;
}

.mw-search-result {
  margin-bottom: 1.05em;
  padding-bottom: 1em;
  border-bottom: 1px solid #eaecf0;
}

.mw-search-result-heading {
  font-size: 17px;
  font-weight: bold;
}

.searchresult {
  color: #202122;
  line-height: 1.55;
}

.mw-search-result-data {
  color: #54595d;
  font-size: 12px;
}

#searchText,
#powersearch {
  border: 1px solid #a2a9b1;
  background: #f8f9fa;
  padding: 12px;
}

/* Special pages and lists */
.mw-specialpages-table,
.specialpages,
.mw-allpages-table {
  border: 1px solid #a2a9b1;
  background: #f8f9fa;
  padding: 12px;
}

.mw-allpages-chunk,
.mw-prefixindex-list {
  column-gap: 2em;
}

/* Recent changes */
.mw-changeslist {
  border: 1px solid #a2a9b1;
  background: #fff;
  padding: 10px;
}

.mw-changeslist-line {
  padding: 0.25em 0;
  border-bottom: 1px solid #eaecf0;
}

/* Tables */
.ra-body table.wikitable {
  margin: 1em 0;
}

.ra-body table.wikitable caption {
  padding: 0.35em 0;
  font-weight: bold;
  text-align: left;
}

/* Thumbnails */
.thumbinner {
  border: 1px solid #a2a9b1 !important;
  background: #f8f9fa !important;
  padding: 4px !important;
}

.thumbcaption {
  color: #54595d;
  font-size: 12px;
  line-height: 1.45;
}

/* Infobox safety */
.ra-profilebox,
.infobox {
  max-width: 100%;
}

.ra-profilebox td,
.infobox td {
  word-break: normal;
  overflow-wrap: anywhere;
}

/* Keep article text full-width when infobox has ended */
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > p,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ul,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > ol,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > dl,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > blockquote,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > h2,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > h3,
body.ns-0:not(.page-Main_Page) .ra-body .mw-parser-output > h4 {
  max-width: none !important;
}

/* Clean parser-error remnants without hiding real article content */
.mw-parser-output .error,
.mw-parser-output .scribunto-error,
.mw-parser-output .lua-error,
.mw-parser-output .mw-ext-cite-error,
.mw-parser-output .mw-parser-output-error {
  display: none !important;
}

/* Empty containers after cleanup */
.mw-parser-output p:empty,
.mw-parser-output div:empty {
  display: none !important;
}

/* Main page keeps Wikipedia portal style */
body.page-Main_Page .ra-body {
  padding: 18px 24px 26px;
}

/* Footer polish */
.ra-footer {
  clear: both;
}

.ra-footer span {
  display: block;
  max-width: 900px;
}

/* Mobile polish */
@media (max-width: 900px) {
  html,
  body {
    font-size: 15px;
  }

  .ra-header-inner {
    padding: 10px 12px;
  }

  .ra-brand-wordmark {
    width: 165px;
  }

  .ra-content {
    padding: 10px;
  }

  .ra-article-header {
    padding: 18px 16px 8px;
  }

  .ra-body {
    padding: 14px 16px 22px;
  }

  .ra-title {
    font-size: 30px;
  }

  .ra-tabs {
    justify-content: flex-start;
    overflow-x: auto;
    white-space: nowrap;
  }

  .ra-sidebar {
    display: grid;
    grid-template-columns: 1fr;
  }

  .ra-sidebar-card a {
    display: inline-block;
    margin-right: 10px;
  }

  .references {
    columns: auto !important;
  }

  .mw-category-columns,
  .mw-allpages-chunk,
  .mw-prefixindex-list {
    columns: auto !important;
  }
}

/* Very small screens */
@media (max-width: 520px) {
  .ra-search {
    grid-template-columns: 1fr;
  }

  .ra-search input,
  .ra-search button {
    border: 1px solid #a2a9b1;
    border-radius: 2px;
  }

  .ra-usernav {
    font-size: 12px;
  }

  .ra-profilebox,
  .infobox {
    font-size: 12px;
  }

  .ra-profilebox caption {
    font-size: 19px;
  }
}


/* Safe no-Lua series/navigation box */
.ra-series-box {
  clear: right;
  margin: 1em 0;
  border: 1px solid #a2a9b1;
  background: #f8f9fa;
  font-size: 13px;
}

.ra-series-title {
  padding: 0.45em 0.7em;
  border-bottom: 1px solid #c8ccd1;
  background: #eaecf0;
  font-weight: bold;
}

.ra-series-grid {
  padding: 0.6em 0.85em;
}

.ra-series-grid ul {
  margin: 0.25em 0 0.25em 1.3em;
}


/* Roovet Articles short description, similar to Wikipedia article subtitles */
.ra-short-description {
    display: block;
    margin: -0.35rem 0 1.1rem;
    color: #54595d;
    font-size: 0.94rem;
    line-height: 1.45;
    font-style: normal;
    max-width: 760px;
}

.ra-content .ra-short-description:first-child {
    margin-top: 0;
}

/* Roovet Articles short description, similar to Wikipedia article subtitles */
.ra-short-description {
    display: block;
    margin: -0.35rem 0 1.1rem;
    color: #54595d;
    font-size: 0.94rem;
    line-height: 1.45;
    font-style: normal;
    max-width: 780px;
}

/* Short descriptions are now JSON-LD/entity metadata only. */
.ra-short-description {
    display: none !important;
}
