Difference between revisions of "MediaWiki:Common.css"

From Holdfast: Nations At War
Jump to navigation Jump to search
 
(67 intermediate revisions by the same user not shown)
Line 1: Line 1:
 +
/*************************************************
 +
* Holdfast Wiki – Global Theme (compact, fixed)
 +
* Banner (top-left) + Dark Left Column + Parchment
 +
*************************************************/
  
 +
/* ===== Variables ===== */
 +
:root{
 +
  --hf-banner-w: 1250px;        /* banner width */
 +
  --hf-banner-h: 300px;        /* banner height */
 +
  --hf-sidebar-w: 200px;        /* actual sidebar width + content offset */
 +
  --hf-parchment: #E1DCCE;      /* base page background */
 +
  --hf-left-top: #2F2D2B;      /* dark column gradient top */
 +
  --hf-left-bot: #1E1E1D;      /* dark column gradient bottom */
 +
}
  
/* Ensure main containers don't overpaint */
+
/* ===== Page background only (no element sizing) =====
#content, .mw-body, .vector-body .mw-body { background: transparent !important; }
+
  Order: 1) banner patch, 2) dark column from top to bottom, 3) parchment fill */
 +
/* ===== Page Background (banner + top dark strip + left column + parchment) ===== */
 +
/* ===== Page Background (banner + extended dark top + dark column + parchment) ===== */
 +
html, body {
 +
  margin: 0 !important;
 +
  background:
 +
    /* 1) Holdfast banner (top-left) */
 +
    url("/Special:FilePath/BannerImage.png") left top no-repeat,
  
 +
    /* 2) Extended dark top gradient (covers full top band behind banner and header) */
 +
    linear-gradient(to right, var(--hf-left-top) 0%, var(--hf-left-bot) 100%) left top no-repeat,
  
/* === Holdfast Banner – anchored top-left === */
+
    /* 3) Vertical dark column for sidebar */
 +
    linear-gradient(to bottom, var(--hf-left-top) 0%, var(--hf-left-bot) 100%) left top repeat-y,
  
/* 1) Create a dedicated region for the banner above the sidebar */
+
    /* 4) Parchment base */
#mw-panel::before,
+
    var(--hf-parchment);
#column-one::before,
+
   background-size:
.mw-sidebar::before {
+
    var(--hf-banner-w) var(--hf-banner-h),   /* banner image */
  content: "";
+
    100% 400px,                              /* dark top bar — extend higher */
   display: block;
+
    var(--hf-sidebar-w) 100%,                /* vertical sidebar column */
   position: absolute;
+
    auto;                                   /* parchment fill */
  top: 0;
+
   background-position:
  left: 0;
+
    left top,
  width: 420px;                /* same width as your sidebar */
+
    left top,
  height: 140px;               /* banner image height */
+
    left top,
   background: url("/wiki/Special:FilePath/BannerImage.png") left top no-repeat;
+
    left top;
   background-size: cover;
+
  background-attachment: fixed, fixed, fixed, fixed;
   z-index: 0;                   /* sits behind sidebar content */
+
  background-repeat: no-repeat, no-repeat, no-repeat, repeat;
  pointer-events: none;        /* never blocks UI */
+
   background-color: var(--hf-parchment);
 +
   z-index: 0;
 
}
 
}
  
/* 2) Push sidebar content down slightly so it doesn’t overlap the banner */
 
#mw-panel,
 
#column-one,
 
.mw-sidebar {
 
  position: relative;
 
  padding-top: 140px;          /* match banner height */
 
}
 
  
/* 3) Ensure the gradient starts below the banner for seamless blending */
 
#mw-panel,
 
#column-one,
 
.mw-sidebar {
 
  background: linear-gradient(to bottom, #2F2D2B 140px, #1E1E1D 100%) !important;
 
}
 
  
/* 4) If your banner has transparent edges, smooth transition into gradient */
+
/* ===== Keep site chrome transparent so the page bg shows ===== */
#mw-panel::after {
+
#mw-page-base, #mw-head-base, #mw-head, .vector-header-container,
  content: "";
+
#mw-panel, #column-one, .mw-sidebar { background: transparent !important; }
  position: absolute;
+
 
  top: 130px;
+
/* ===== Content is opaque parchment so the dark column doesn't bleed ===== */
  left: 0;
+
#content, .mw-body, .vector-body .mw-body,
  width: 420px;
+
.mw-workspace-container, .mw-content-container{
  height: 20px;
+
   background: var(--hf-parchment) !important;
   background: linear-gradient(to bottom, rgba(47,45,43,0.3), rgba(30,30,29,0));
+
   position: relative;
   pointer-events: none;
 
 
   z-index: 1;
 
   z-index: 1;
 
}
 
}
  
 +
/* ===== Layout: single source of truth for widths/offsets ===== */
 +
#mw-panel, .mw-sidebar, #column-one{ width: var(--hf-sidebar-w) !important; box-sizing: border-box; }
 +
#content, .mw-body, .vector-body, .mw-content-container{ margin-left: var(--hf-sidebar-w) !important; }
  
 
+
/* ===== Sidebar: flat, compact; let background show through ===== */
/***** UNIVERSAL LEFT SIDEBAR STYLING (works across common skins) *****/
 
 
 
/* 1) Pick up the left column container across skins */
 
#mw-panel,                     /* Vector/Vector-legacy */
 
#column-one,                  /* Monobook / Modern */
 
.skin-timeless .ts-sidebar,    /* Timeless */
 
.citizen-drawer,              /* Citizen */
 
.mw-sidebar,                  /* Generic sidebars */
 
.skin-minerva .menu {          /* Minerva (mobile) */
 
  background: transparent !important; /* let the page background show through */
 
  color: #EEEDEB !important;
 
  border-right: none !important;
 
}
 
 
 
/* 2) Kill inner backgrounds so the gradient shows */
 
 
#mw-panel .vector-menu,
 
#mw-panel .vector-menu,
 +
#mw-panel .vector-main-menu,
 
#mw-panel .vector-menu-content,
 
#mw-panel .vector-menu-content,
 
#mw-panel .vector-menu-content-list,
 
#mw-panel .vector-menu-content-list,
#column-one .portlet,
+
#column-one .portlet, #column-one .pBody{
#column-one .pBody,
+
   background: transparent !important; border: 0 !important; padding: 0; margin: 0;
.skin-timeless .ts-sidebar * ,
 
.citizen-drawer *,
 
.mw-sidebar *,
 
.skin-minerva .menu * {
 
   background: transparent !important;
 
  color: inherit !important;
 
 
}
 
}
  
/* 3) Links inside the sidebar */
+
#mw-panel, .mw-sidebar, #column-one{ color: #EEEDEB !important; padding: 10px 8px 24px; }
#mw-panel a,
 
#column-one a,
 
.skin-timeless .ts-sidebar a,
 
.citizen-drawer a,
 
.mw-sidebar a,
 
.skin-minerva .menu a {
 
  color: #EEEDEB !important;
 
  text-decoration: none;
 
}
 
#mw-panel a:hover,
 
#column-one a:hover,
 
.skin-timeless .ts-sidebar a:hover,
 
.citizen-drawer a:hover,
 
.mw-sidebar a:hover,
 
.skin-minerva .menu a:hover {
 
  color: #5A65EA !important;
 
  text-decoration: underline;
 
}
 
  
/* 4) Section headers in the sidebar (common title elements) */
 
 
#mw-panel .portal .portal-title,
 
#mw-panel .portal .portal-title,
 
#mw-panel .vector-menu-heading,
 
#mw-panel .vector-menu-heading,
#column-one h3,
+
#column-one h3, .mw-sidebar h2{
.skin-timeless .ts-sidebar .ts-portlet h2,
+
   background: #63635B !important; color: #EEEDEB !important;
.citizen-drawer .drawer__section-title,
+
   padding: 5px 8px; margin: 12px 4px 4px; border: 0 !important;
.mw-sidebar h2 {
+
   font: 700 10px/1.4 "Helvetica Neue", Helvetica, Arial, sans-serif; letter-spacing: .2px;
   background: #63635B !important;   /* muted block behind group titles */
 
  color: #EEEDEB !important;
 
  border-radius: 4px;
 
   padding: 6px 8px;
 
  margin: 12px 8px 6px;
 
   font-weight: 700;
 
 
}
 
}
  
/* 5) List items spacing */
+
#mw-panel .vector-menu-content-list, #column-one .pBody ul{ list-style: none; padding: 0; margin: 6px 0 0; }
#mw-panel .vector-menu-content-list > li,
+
#mw-panel .vector-menu-content-list > li, #column-one .pBody ul li{ padding: 3px 6px; line-height: 1.35; }
#column-one .pBody ul li,
+
 
.skin-timeless .ts-sidebar li,
+
#mw-panel a, #column-one a, .mw-sidebar a{
.citizen-drawer li,
+
   display: block; padding: 2px 4px;
.mw-sidebar li {
+
  color: #EEEDEB !important; text-decoration: none;
   padding: 2px 8px;
+
  font: 400 10px/1.35 "Helvetica Neue", Helvetica, Arial, sans-serif;
 
}
 
}
 +
#mw-panel a:hover, #column-one a:hover, .mw-sidebar a:hover{
 +
  background: rgba(255,255,255,0.08); color: #EEEDEB !important; text-decoration: none;
 +
}
 +
 +
/* Optional thin group divider */
 +
#mw-panel .portal, #column-one .portlet{ margin-top: 10px; padding-top: 6px; border-top: 1px solid rgba(217,215,209,0.12); }
 +
#mw-panel .portal:first-child, #column-one .portlet:first-child{ border-top: 0; margin-top: 0; padding-top: 0; }
  
/* Sidebar group headers */
+
/* Discord button (flat) */
#mw-panel .portal .portal-title,
+
#mw-panel a.external[href*="discord"]{
#mw-panel .vector-menu-heading,
+
   background: #5A65EA; color: #fff !important;
#column-one h3,
+
   display: inline-block; padding: 8px 10px; margin: 6px 0 10px;
.skin-timeless .ts-sidebar .ts-portlet h2,
+
   border-radius: 4px; border: 1px solid rgba(0,0,0,0.15);
.citizen-drawer .drawer__section-title,
+
   font: 700 11px/1 "Helvetica Neue", Helvetica, Arial, sans-serif;
.mw-sidebar h2 {
 
   background: #63635B !important;   /* muted block behind titles */
 
  color: #EEEDEB !important;
 
   border-radius: 4px;
 
  padding: 6px 10px;
 
  margin: 14px 8px 6px;
 
   font-weight: 700;
 
  text-transform: none;
 
  letter-spacing: .2px;
 
   border: none !important;
 
 
}
 
}
 +
#mw-panel a.external[href*="discord"]:hover{ background: #545DD9; }
  
/* List spacing & baseline */
+
/* ===== Branding: Holdfast compass logo ===== */
#mw-panel .vector-menu-content-list > li,
+
#p-logo a, .mw-wiki-logo{
#column-one .pBody ul li,
+
  background: url("/Special:FilePath/Holdfast_Logo_White_Gold_Compass.png") center/contain no-repeat !important;
.skin-timeless .ts-sidebar li,
+
   width: 150px !important; height: 150px !important; display: block;
.citizen-drawer li,
 
.mw-sidebar li {
 
   padding: 3px 10px;
 
  line-height: 1.35;
 
 
}
 
}
 +
#p-logo-text, .mw-wiki-logo-text{ display: none !important; }
  
/* Links default + hover */
+
/* ===== Typography: Helvetica Neue (14px main / 10px sidebar) ===== */
#mw-panel a,
+
html, body, .mw-body, .vector-body, .mw-content-text, #content,
#column-one a,
+
.vector-header-container, .vector-menu, .vector-menu-content, .vector-menu-heading,
.skin-timeless .ts-sidebar a,
+
#p-logo-text, #firstHeading, .mw-parser-output, .mw-parser-output p,
.citizen-drawer a,
+
.mw-parser-output li, .mw-parser-output td, .mw-parser-output th{
.mw-sidebar a {
+
   font-family: "Helvetica Neue", Helvetica, Arial, sans-serif !important;
   color: #EEEDEB !important;
+
   font-size: 14px !important; line-height: 1.55;
   text-decoration: none;
+
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
 +
  font-weight: 400; letter-spacing: .2px; color: #16181D;
 
}
 
}
#mw-panel a:hover,
+
 
#column-one a:hover,
+
.mw-parser-output h1, .mw-parser-output h2, .mw-parser-output h3,
.skin-timeless .ts-sidebar a:hover,
+
.mw-parser-output h4, .mw-parser-output h5{
.citizen-drawer a:hover,
+
   font-family: "Helvetica Neue", Helvetica, Arial, sans-serif !important;
.mw-sidebar a:hover {
+
   font-weight: 600 !important; letter-spacing: .3px;
   color: #5A65EA !important;                 /* cobalt hover */
 
   text-decoration: underline;
 
 
}
 
}
  
/* Active page highlight */
+
/* Code blocks keep monospace */
#mw-panel .vector-menu-content-list > li.selected > a,
+
code, pre, .mw-code{ font-family: "Courier New", Courier, monospace !important; }
#column-one .pBody ul li.selected > a,
+
 
.mw-sidebar li.selected > a {
+
/* ===== Align page tabs with content edge (Vector legacy + Vector-2022) ===== */
  background: rgba(255,255,255,0.08);
+
:root {
  border-radius: 4px;
+
   --hf-content-pad: 16px; /* left inner padding of the content column */
   display: block;
 
  padding: 3px 8px;
 
 
}
 
}
  
/* Thin separators between groups (optional, subtle) */
+
/* Your content gets this padding; keep it explicit so we can reuse it */
#mw-panel .portal,
+
#content, .mw-body, .mw-content-container {
#column-one .portlet,
+
   padding-left: var(--hf-content-pad);
.mw-sidebar .sidebar-chunk {
 
   border-top: 1px solid rgba(217,215,209,0.15);
 
  margin-top: 10px;
 
  padding-top: 6px;
 
 
}
 
}
  
/* “Chat on Discord” button (left column card) */
+
/* 1) Legacy Vector (tabs live in #left-navigation / #right-navigation) */
#mw-panel .discord-button,       /* if you wrapped it in a class */
+
#mw-head #left-navigation,
#mw-panel a.external[href*="discord"] {
+
#mw-head #right-navigation {
   background: #5A65EA;
+
   position: relative;
   color: #FFFFFF !important;
+
   left: calc(var(--hf-sidebar-w) + var(--hf-content-pad)) !important;
   display: inline-block;
+
   margin-left: 0 !important; /* nuke any default margin */
  padding: 8px 10px;
 
  border-radius: 8px;
 
  font-weight: 700;
 
  border: 1px solid rgba(0,0,0,0.15);
 
 
}
 
}
#mw-panel .discord-button:hover,
+
 
#mw-panel a.external[href*="discord"]:hover {
+
/* Also zero margins on the tab lists themselves so they don't re-offset */
  background: #545DD9;
+
#mw-head #p-views,
   text-decoration: none;
+
#mw-head .vectorTabs,
 +
#mw-head .vector-menu-tabs {
 +
   margin-left: 0 !important;
 
}
 
}
  
/* Clean edge between sidebar and content */
+
/* 2) Vector-2022 (tabs / page tools bar) */
#mw-panel { box-shadow: 1px 0 0 rgba(217,215,209,0.25) inset; }
+
.vector-header-container .vector-page-toolbar,
 
+
.vector-header-container .vector-menu-tabs {
/* Tidy sidebar scrollbar on desktop WebKit */
+
  position: relative;
#mw-panel::-webkit-scrollbar { width: 10px; }
+
  left: calc(var(--hf-sidebar-w) + var(--hf-content-pad)) !important;
#mw-panel::-webkit-scrollbar-track { background: transparent; }
+
   margin-left: 0 !important;
#mw-panel::-webkit-scrollbar-thumb {
+
  z-index: 5; /* stay above the banner image */
   background: rgba(255,255,255,0.12); border-radius: 8px;
 
 
}
 
}
#mw-panel::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.22); }
 

Latest revision as of 23:51, 10 October 2025

/*************************************************
 * Holdfast Wiki – Global Theme (compact, fixed)
 * Banner (top-left) + Dark Left Column + Parchment
 *************************************************/

/* ===== Variables ===== */
:root{
  --hf-banner-w: 1250px;        /* banner width */
  --hf-banner-h: 300px;         /* banner height */
  --hf-sidebar-w: 200px;        /* actual sidebar width + content offset */
  --hf-parchment: #E1DCCE;      /* base page background */
  --hf-left-top: #2F2D2B;       /* dark column gradient top */
  --hf-left-bot: #1E1E1D;       /* dark column gradient bottom */
}

/* ===== Page background only (no element sizing) =====
   Order: 1) banner patch, 2) dark column from top to bottom, 3) parchment fill */
/* ===== Page Background (banner + top dark strip + left column + parchment) ===== */
/* ===== Page Background (banner + extended dark top + dark column + parchment) ===== */
html, body {
  margin: 0 !important;
  background:
    /* 1) Holdfast banner (top-left) */
    url("/Special:FilePath/BannerImage.png") left top no-repeat,

    /* 2) Extended dark top gradient (covers full top band behind banner and header) */
    linear-gradient(to right, var(--hf-left-top) 0%, var(--hf-left-bot) 100%) left top no-repeat,

    /* 3) Vertical dark column for sidebar */
    linear-gradient(to bottom, var(--hf-left-top) 0%, var(--hf-left-bot) 100%) left top repeat-y,

    /* 4) Parchment base */
    var(--hf-parchment);
  background-size:
    var(--hf-banner-w) var(--hf-banner-h),   /* banner image */
    100% 400px,                              /* dark top bar — extend higher */
    var(--hf-sidebar-w) 100%,                /* vertical sidebar column */
    auto;                                   /* parchment fill */
  background-position:
    left top,
    left top,
    left top,
    left top;
  background-attachment: fixed, fixed, fixed, fixed;
  background-repeat: no-repeat, no-repeat, no-repeat, repeat;
  background-color: var(--hf-parchment);
  z-index: 0;
}



/* ===== Keep site chrome transparent so the page bg shows ===== */
#mw-page-base, #mw-head-base, #mw-head, .vector-header-container,
#mw-panel, #column-one, .mw-sidebar { background: transparent !important; }

/* ===== Content is opaque parchment so the dark column doesn't bleed ===== */
#content, .mw-body, .vector-body .mw-body,
.mw-workspace-container, .mw-content-container{
  background: var(--hf-parchment) !important;
  position: relative;
  z-index: 1;
}

/* ===== Layout: single source of truth for widths/offsets ===== */
#mw-panel, .mw-sidebar, #column-one{ width: var(--hf-sidebar-w) !important; box-sizing: border-box; }
#content, .mw-body, .vector-body, .mw-content-container{ margin-left: var(--hf-sidebar-w) !important; }

/* ===== Sidebar: flat, compact; let background show through ===== */
#mw-panel .vector-menu,
#mw-panel .vector-main-menu,
#mw-panel .vector-menu-content,
#mw-panel .vector-menu-content-list,
#column-one .portlet, #column-one .pBody{
  background: transparent !important; border: 0 !important; padding: 0; margin: 0;
}

#mw-panel, .mw-sidebar, #column-one{ color: #EEEDEB !important; padding: 10px 8px 24px; }

#mw-panel .portal .portal-title,
#mw-panel .vector-menu-heading,
#column-one h3, .mw-sidebar h2{
  background: #63635B !important; color: #EEEDEB !important;
  padding: 5px 8px; margin: 12px 4px 4px; border: 0 !important;
  font: 700 10px/1.4 "Helvetica Neue", Helvetica, Arial, sans-serif; letter-spacing: .2px;
}

#mw-panel .vector-menu-content-list, #column-one .pBody ul{ list-style: none; padding: 0; margin: 6px 0 0; }
#mw-panel .vector-menu-content-list > li, #column-one .pBody ul li{ padding: 3px 6px; line-height: 1.35; }

#mw-panel a, #column-one a, .mw-sidebar a{
  display: block; padding: 2px 4px;
  color: #EEEDEB !important; text-decoration: none;
  font: 400 10px/1.35 "Helvetica Neue", Helvetica, Arial, sans-serif;
}
#mw-panel a:hover, #column-one a:hover, .mw-sidebar a:hover{
  background: rgba(255,255,255,0.08); color: #EEEDEB !important; text-decoration: none;
}

/* Optional thin group divider */
#mw-panel .portal, #column-one .portlet{ margin-top: 10px; padding-top: 6px; border-top: 1px solid rgba(217,215,209,0.12); }
#mw-panel .portal:first-child, #column-one .portlet:first-child{ border-top: 0; margin-top: 0; padding-top: 0; }

/* Discord button (flat) */
#mw-panel a.external[href*="discord"]{
  background: #5A65EA; color: #fff !important;
  display: inline-block; padding: 8px 10px; margin: 6px 0 10px;
  border-radius: 4px; border: 1px solid rgba(0,0,0,0.15);
  font: 700 11px/1 "Helvetica Neue", Helvetica, Arial, sans-serif;
}
#mw-panel a.external[href*="discord"]:hover{ background: #545DD9; }

/* ===== Branding: Holdfast compass logo ===== */
#p-logo a, .mw-wiki-logo{
  background: url("/Special:FilePath/Holdfast_Logo_White_Gold_Compass.png") center/contain no-repeat !important;
  width: 150px !important; height: 150px !important; display: block;
}
#p-logo-text, .mw-wiki-logo-text{ display: none !important; }

/* ===== Typography: Helvetica Neue (14px main / 10px sidebar) ===== */
html, body, .mw-body, .vector-body, .mw-content-text, #content,
.vector-header-container, .vector-menu, .vector-menu-content, .vector-menu-heading,
#p-logo-text, #firstHeading, .mw-parser-output, .mw-parser-output p,
.mw-parser-output li, .mw-parser-output td, .mw-parser-output th{
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-size: 14px !important; line-height: 1.55;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  font-weight: 400; letter-spacing: .2px; color: #16181D;
}

.mw-parser-output h1, .mw-parser-output h2, .mw-parser-output h3,
.mw-parser-output h4, .mw-parser-output h5{
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-weight: 600 !important; letter-spacing: .3px;
}

/* Code blocks keep monospace */
code, pre, .mw-code{ font-family: "Courier New", Courier, monospace !important; }

/* ===== Align page tabs with content edge (Vector legacy + Vector-2022) ===== */
:root {
  --hf-content-pad: 16px; /* left inner padding of the content column */
}

/* Your content gets this padding; keep it explicit so we can reuse it */
#content, .mw-body, .mw-content-container {
  padding-left: var(--hf-content-pad);
}

/* 1) Legacy Vector (tabs live in #left-navigation / #right-navigation) */
#mw-head #left-navigation,
#mw-head #right-navigation {
  position: relative;
  left: calc(var(--hf-sidebar-w) + var(--hf-content-pad)) !important;
  margin-left: 0 !important; /* nuke any default margin */
}

/* Also zero margins on the tab lists themselves so they don't re-offset */
#mw-head #p-views,
#mw-head .vectorTabs,
#mw-head .vector-menu-tabs {
  margin-left: 0 !important;
}

/* 2) Vector-2022 (tabs / page tools bar) */
.vector-header-container .vector-page-toolbar,
.vector-header-container .vector-menu-tabs {
  position: relative;
  left: calc(var(--hf-sidebar-w) + var(--hf-content-pad)) !important;
  margin-left: 0 !important;
  z-index: 5; /* stay above the banner image */
}