Difference between revisions of "MediaWiki:Common.css"

From Holdfast: Nations At War
Jump to navigation Jump to search
Line 1: Line 1:
/* CSS placed here will be applied to all skins */
+
/***** Holdfast Wiki – Modern Base Theme ****************************************
body.page-Holdfast_Nations_At_War_Wiki.action-view h1.firstHeading,
+
  Safe, incremental overrides for Vector/Vector-2022. Keep selectors scoped.
body.page-Holdfast_Nations_At_War_Wiki.action-submit h1.firstHeading {
+
*******************************************************************************/
   display: none;
+
 
 +
/* ===== 0) CSS Vars (easy theming) ===== */
 +
:root {
 +
  --hf-font-sans: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Noto Sans", "Helvetica Neue", Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
 +
  --hf-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
 +
 
 +
  --hf-fg: #16181d;
 +
  --hf-fg-muted: #5c6773;
 +
  --hf-bg: #ffffff;
 +
  --hf-bg-subtle: #f6f7f9;
 +
 
 +
  --hf-accent: #2563eb;        /* link blue */
 +
  --hf-accent-visited: #7c3aed;/* visited purple */
 +
  --hf-accent-hover: #1d4ed8;
 +
 
 +
  --hf-border: #e5e7eb;
 +
  --hf-border-strong: #d1d5db;
 +
 
 +
  --hf-h2-bg: #3c553c;        /* your green header bar */
 +
  --hf-h2-fg: #ffffff;
 +
 
 +
  --hf-code-bg: #0f172a;      /* dark code panel */
 +
  --hf-code-fg: #e5e7eb;
 +
 
 +
  --hf-table-header-bg: #f3f4f6;
 +
  --hf-table-row-alt: #fafafa;
 +
 
 +
  --hf-warning: #a16207;
 +
  --hf-error:  #b91c1c;
 +
  --hf-info:    #1d4ed8;
 +
  --hf-success: #15803d;
 +
}
 +
 
 +
/* ===== 1) Base Typography & Layout ===== */
 +
body,
 +
.vector-body {
 +
  color: var(--hf-fg);
 +
  background: var(--hf-bg);
 +
  font-family: var(--hf-font-sans);
 +
  line-height: 1.55;
 +
  -webkit-font-smoothing: antialiased;
 +
  text-rendering: optimizeLegibility;
 +
}
 +
 
 +
.mw-parser-output > p {
 +
  margin: 0.6em 0 0.9em;
 +
  font-size: 0.98rem;
 +
}
 +
 
 +
/* Tighten content width a touch on large screens */
 +
@media (min-width: 1200px) {
 +
  .vector-body .mw-content-container {
 +
    max-width: 980px;
 +
  }
 +
}
 +
 
 +
/* ===== 2) Headings ===== */
 +
.mw-parser-output h1,
 +
.mw-parser-output h2,
 +
.mw-parser-output h3,
 +
.mw-parser-output h4 {
 +
  font-weight: 700;
 +
  letter-spacing: .2px;
 +
}
 +
 
 +
/* Section bar style for H2 */
 +
.mw-parser-output h2 {
 +
  background: var(--hf-h2-bg);
 +
  color: var(--hf-h2-fg);
 +
  border: 1px solid var(--hf-border-strong);
 +
  padding: 0.35em 0.6em;
 +
  margin-top: 1.6em;
 +
  margin-bottom: 0.4em;
 +
  font-variant: small-caps;
 +
}
 +
 
 +
/* Sub-head underline for H3 */
 +
.mw-parser-output h3 {
 +
   border-bottom: 1px solid var(--hf-border);
 +
  padding-bottom: .2em;
 +
  margin-top: 1.2em;
 
}
 
}
  
/* Make custom [Show/Hide] toggles look like links */
+
/* ===== 3) Links ===== */
span[class^="mw-customtoggle-"] {
+
.mw-parser-output a,
   color: #0645ad;               /* standard MediaWiki link blue */
+
a.mw-selflink {
 +
  color: var(--hf-accent);
 +
  text-decoration: none;
 +
}
 +
.mw-parser-output a:hover {
 +
  color: var(--hf-accent-hover);
 +
  text-decoration: underline;
 +
}
 +
.mw-parser-output a:visited {
 +
  color: var(--hf-accent-visited);
 +
}
 +
 
 +
/* ===== 4) TOC ===== */
 +
.toc,
 +
.mw-table-of-contents {
 +
   background: var(--hf-bg-subtle);
 +
  border: 1px solid var(--hf-border);
 +
  border-radius: 8px;
 +
  padding: 0.6em 0.8em;
 +
}
 +
.tocnumber { color: var(--hf-fg-muted); }
 +
 
 +
/* ===== 5) Collapsible [show]/[hide] – make it link-blue ===== */
 +
.mw-collapsible-toggle,
 +
.mw-collapsible-toggle .mw-collapsible-text {
 +
  color: var(--hf-accent);
 
   cursor: pointer;
 
   cursor: pointer;
 +
}
 +
.mw-collapsible-toggle:hover .mw-collapsible-text {
 
   text-decoration: underline;
 
   text-decoration: underline;
  font-weight: normal;
 
 
}
 
}
span[class^="mw-customtoggle-"]:hover {
+
 
   color: #0b0080;               /* darker hover like links */
+
/* If you’re using mw-collapsible mw-collapsed on sections */
 +
.mw-collapsible .mw-collapsible-content {
 +
  padding-top: .4em;
 +
}
 +
 
 +
/* ===== 6) Tables ===== */
 +
.wikitable,
 +
table.wikitable.sortable {
 +
  width: 100%;
 +
  border: 1px solid var(--hf-border);
 +
  border-collapse: separate;
 +
  border-spacing: 0;
 +
  border-radius: 10px;
 +
  overflow: hidden;
 +
  background: #fff;
 +
  font-size: 0.95rem;
 +
}
 +
.wikitable > tr > th,
 +
.wikitable > * > tr > th {
 +
  background: var(--hf-table-header-bg);
 +
  font-weight: 700;
 +
  border-bottom: 1px solid var(--hf-border-strong);
 +
  padding: 0.55em 0.6em;
 +
}
 +
.wikitable > tr > td,
 +
.wikitable > * > tr > td {
 +
  border-top: 1px solid var(--hf-border);
 +
  padding: 0.5em 0.6em;
 +
}
 +
.wikitable tr:nth-child(even) td {
 +
  background: var(--hf-table-row-alt);
 +
}
 +
 
 +
/* Sort arrows breathing room */
 +
.wikitable.sortable th {
 +
  white-space: nowrap;
 +
}
 +
 
 +
/* ===== 7) Infobox / Navbox (generic) ===== */
 +
.infobox,
 +
.navbox,
 +
.mw-infobox {
 +
  border: 1px solid var(--hf-border);
 +
  border-radius: 10px;
 +
  background: #fff;
 +
  padding: 0;
 +
  overflow: hidden;
 +
}
 +
.infobox .infobox-header,
 +
.navbox .navbox-title {
 +
  background: var(--hf-table-header-bg);
 +
  font-weight: 700;
 +
  padding: 0.6em 0.75em;
 +
  border-bottom: 1px solid var(--hf-border);
 +
}
 +
.infobox td,
 +
.infobox th {
 +
  padding: 0.5em 0.75em !important;
 +
  border-top: 1px solid var(--hf-border);
 +
}
 +
 
 +
/* ===== 8) Notices / Admonitions ===== */
 +
.hf-notice {
 +
  border-left: 4px solid var(--hf-info);
 +
  background: #eef4ff;
 +
  padding: 0.7em 0.9em;
 +
  margin: 1em 0;
 +
  border-radius: 6px;
 +
}
 +
.hf-notice.warn { border-left-color: var(--hf-warning); background: #fff7e6; }
 +
.hf-notice.error{ border-left-color: var(--hf-error);  background: #ffefef; }
 +
.hf-notice.ok  { border-left-color: var(--hf-success); background: #ecfdf3; }
 +
 
 +
/* Usage in wikitext:
 +
<div class="hf-notice warn">Watch out…</div>
 +
*/
 +
 
 +
/* ===== 9) Code Blocks – dark theme ===== */
 +
pre, code, .mw-code,
 +
pre .mw-code,
 +
.syntaxhighlight, pre.mw-code {
 +
  font-family: var(--hf-font-mono);
 +
}
 +
pre,
 +
pre.mw-code,
 +
.syntaxhighlight {
 +
  background: var(--hf-code-bg) !important;
 +
  color: var(--hf-code-fg) !important;
 +
  border: 1px solid #0b1220 !important;
 +
  border-radius: 10px;
 +
  padding: 0.8em 1em !important;
 +
  overflow: auto;
 +
}
 +
 
 +
/* Inline code */
 +
code {
 +
  background: #0b1220;
 +
  color: var(--hf-code-fg);
 +
  padding: 0.05em 0.35em;
 +
  border-radius: 4px;
 +
}
 +
 
 +
/* ===== 10) Buttons / Links-as-buttons ===== */
 +
.hf-btn,
 +
a.hf-btn {
 +
  display: inline-block;
 +
  background: var(--hf-accent);
 +
  color: #fff !important;
 +
  padding: 0.45em 0.75em;
 +
  border-radius: 8px;
 +
  border: 1px solid transparent;
 +
  text-decoration: none !important;
 +
  font-weight: 600;
 +
}
 +
.hf-btn:hover { background: var(--hf-accent-hover); }
 +
.hf-btn.ghost {
 +
  background: transparent;
 +
   color: var(--hf-accent) !important;
 +
  border-color: var(--hf-accent);
 +
}
 +
 
 +
/* ===== 11) Images / Thumbs ===== */
 +
.thumb,
 +
.mw-halign-left .thumb,
 +
.mw-halign-right .thumb {
 +
  border: 1px solid var(--hf-border);
 +
  border-radius: 10px;
 +
  overflow: hidden;
 +
  background: #fff;
 +
}
 +
.thumb .thumbcaption {
 +
  background: var(--hf-bg-subtle);
 +
  border-top: 1px solid var(--hf-border);
 +
  padding: 0.4em 0.6em;
 +
}
 +
 
 +
/* ===== 12) Cleanup odds & ends ===== */
 +
/* Make “External links” icons less loud */
 +
.mw-parser-output .external { padding-right: 0.1em; }
 +
 
 +
/* Reduce overly large firstHeading margins without hiding the title */
 +
.mw-page-title-main {
 +
  margin-bottom: 0.2em;
 +
}
 +
 
 +
/* Optional: soften category box */
 +
.catlinks {
 +
  background: var(--hf-bg-subtle);
 +
  border: 1px solid var(--hf-border);
 +
  border-radius: 8px;
 +
  padding: .3em .6em;
 
}
 
}

Revision as of 19:06, 24 September 2025

/***** Holdfast Wiki – Modern Base Theme ****************************************
   Safe, incremental overrides for Vector/Vector-2022. Keep selectors scoped.
*******************************************************************************/

/* ===== 0) CSS Vars (easy theming) ===== */
:root {
  --hf-font-sans: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Noto Sans", "Helvetica Neue", Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
  --hf-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  --hf-fg: #16181d;
  --hf-fg-muted: #5c6773;
  --hf-bg: #ffffff;
  --hf-bg-subtle: #f6f7f9;

  --hf-accent: #2563eb;        /* link blue */
  --hf-accent-visited: #7c3aed;/* visited purple */
  --hf-accent-hover: #1d4ed8;

  --hf-border: #e5e7eb;
  --hf-border-strong: #d1d5db;

  --hf-h2-bg: #3c553c;         /* your green header bar */
  --hf-h2-fg: #ffffff;

  --hf-code-bg: #0f172a;       /* dark code panel */
  --hf-code-fg: #e5e7eb;

  --hf-table-header-bg: #f3f4f6;
  --hf-table-row-alt: #fafafa;

  --hf-warning: #a16207;
  --hf-error:   #b91c1c;
  --hf-info:    #1d4ed8;
  --hf-success: #15803d;
}

/* ===== 1) Base Typography & Layout ===== */
body,
.vector-body {
  color: var(--hf-fg);
  background: var(--hf-bg);
  font-family: var(--hf-font-sans);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.mw-parser-output > p {
  margin: 0.6em 0 0.9em;
  font-size: 0.98rem;
}

/* Tighten content width a touch on large screens */
@media (min-width: 1200px) {
  .vector-body .mw-content-container {
    max-width: 980px;
  }
}

/* ===== 2) Headings ===== */
.mw-parser-output h1,
.mw-parser-output h2,
.mw-parser-output h3,
.mw-parser-output h4 {
  font-weight: 700;
  letter-spacing: .2px;
}

/* Section bar style for H2 */
.mw-parser-output h2 {
  background: var(--hf-h2-bg);
  color: var(--hf-h2-fg);
  border: 1px solid var(--hf-border-strong);
  padding: 0.35em 0.6em;
  margin-top: 1.6em;
  margin-bottom: 0.4em;
  font-variant: small-caps;
}

/* Sub-head underline for H3 */
.mw-parser-output h3 {
  border-bottom: 1px solid var(--hf-border);
  padding-bottom: .2em;
  margin-top: 1.2em;
}

/* ===== 3) Links ===== */
.mw-parser-output a,
a.mw-selflink {
  color: var(--hf-accent);
  text-decoration: none;
}
.mw-parser-output a:hover {
  color: var(--hf-accent-hover);
  text-decoration: underline;
}
.mw-parser-output a:visited {
  color: var(--hf-accent-visited);
}

/* ===== 4) TOC ===== */
.toc,
.mw-table-of-contents {
  background: var(--hf-bg-subtle);
  border: 1px solid var(--hf-border);
  border-radius: 8px;
  padding: 0.6em 0.8em;
}
.tocnumber { color: var(--hf-fg-muted); }

/* ===== 5) Collapsible [show]/[hide] – make it link-blue ===== */
.mw-collapsible-toggle,
.mw-collapsible-toggle .mw-collapsible-text {
  color: var(--hf-accent);
  cursor: pointer;
}
.mw-collapsible-toggle:hover .mw-collapsible-text {
  text-decoration: underline;
}

/* If you’re using mw-collapsible mw-collapsed on sections */
.mw-collapsible .mw-collapsible-content {
  padding-top: .4em;
}

/* ===== 6) Tables ===== */
.wikitable,
table.wikitable.sortable {
  width: 100%;
  border: 1px solid var(--hf-border);
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  font-size: 0.95rem;
}
.wikitable > tr > th,
.wikitable > * > tr > th {
  background: var(--hf-table-header-bg);
  font-weight: 700;
  border-bottom: 1px solid var(--hf-border-strong);
  padding: 0.55em 0.6em;
}
.wikitable > tr > td,
.wikitable > * > tr > td {
  border-top: 1px solid var(--hf-border);
  padding: 0.5em 0.6em;
}
.wikitable tr:nth-child(even) td {
  background: var(--hf-table-row-alt);
}

/* Sort arrows breathing room */
.wikitable.sortable th {
  white-space: nowrap;
}

/* ===== 7) Infobox / Navbox (generic) ===== */
.infobox,
.navbox,
.mw-infobox {
  border: 1px solid var(--hf-border);
  border-radius: 10px;
  background: #fff;
  padding: 0;
  overflow: hidden;
}
.infobox .infobox-header,
.navbox .navbox-title {
  background: var(--hf-table-header-bg);
  font-weight: 700;
  padding: 0.6em 0.75em;
  border-bottom: 1px solid var(--hf-border);
}
.infobox td,
.infobox th {
  padding: 0.5em 0.75em !important;
  border-top: 1px solid var(--hf-border);
}

/* ===== 8) Notices / Admonitions ===== */
.hf-notice {
  border-left: 4px solid var(--hf-info);
  background: #eef4ff;
  padding: 0.7em 0.9em;
  margin: 1em 0;
  border-radius: 6px;
}
.hf-notice.warn { border-left-color: var(--hf-warning); background: #fff7e6; }
.hf-notice.error{ border-left-color: var(--hf-error);   background: #ffefef; }
.hf-notice.ok   { border-left-color: var(--hf-success); background: #ecfdf3; }

/* Usage in wikitext:
<div class="hf-notice warn">Watch out…</div>
*/

/* ===== 9) Code Blocks – dark theme ===== */
pre, code, .mw-code,
pre .mw-code,
.syntaxhighlight, pre.mw-code {
  font-family: var(--hf-font-mono);
}
pre,
pre.mw-code,
.syntaxhighlight {
  background: var(--hf-code-bg) !important;
  color: var(--hf-code-fg) !important;
  border: 1px solid #0b1220 !important;
  border-radius: 10px;
  padding: 0.8em 1em !important;
  overflow: auto;
}

/* Inline code */
code {
  background: #0b1220;
  color: var(--hf-code-fg);
  padding: 0.05em 0.35em;
  border-radius: 4px;
}

/* ===== 10) Buttons / Links-as-buttons ===== */
.hf-btn,
a.hf-btn {
  display: inline-block;
  background: var(--hf-accent);
  color: #fff !important;
  padding: 0.45em 0.75em;
  border-radius: 8px;
  border: 1px solid transparent;
  text-decoration: none !important;
  font-weight: 600;
}
.hf-btn:hover { background: var(--hf-accent-hover); }
.hf-btn.ghost {
  background: transparent;
  color: var(--hf-accent) !important;
  border-color: var(--hf-accent);
}

/* ===== 11) Images / Thumbs ===== */
.thumb,
.mw-halign-left .thumb,
.mw-halign-right .thumb {
  border: 1px solid var(--hf-border);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}
.thumb .thumbcaption {
  background: var(--hf-bg-subtle);
  border-top: 1px solid var(--hf-border);
  padding: 0.4em 0.6em;
}

/* ===== 12) Cleanup odds & ends ===== */
/* Make “External links” icons less loud */
.mw-parser-output .external { padding-right: 0.1em; }

/* Reduce overly large firstHeading margins without hiding the title */
.mw-page-title-main {
  margin-bottom: 0.2em;
}

/* Optional: soften category box */
.catlinks {
  background: var(--hf-bg-subtle);
  border: 1px solid var(--hf-border);
  border-radius: 8px;
  padding: .3em .6em;
}