MediaWiki:Timeless.css

From Helbreath Portal
Revision as of 22:37, 20 August 2025 by Mikus (talk | contribs)

Note: After publishing, you may have to bypass your browser's cache to see the changes.

  • Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
  • Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
  • Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
  • Opera: Press Ctrl-F5.
/* === DARK OLD-SCHOOL 2D THEME (charcoal + brass) ===========================
   Paleta: węgiel (#0f1012–#181a1d), stal (#2a2c2f), mosiądz (#c9a14a),
   pergamin akcent (#ddd2b4). Płaskie cienie, brak szkła, miękkie przejścia.
=========================================================================== */

/* ZMIENNE (łatwa zmiana kolorów) */
:root {
  --bg-0: #0f1012;        /* tło bazowe */
  --bg-1: #141518;        /* warstwa */
  --bg-2: #181a1d;        /* container */
  --steel-1: #2a2c2f;     /* linie / ramki */
  --steel-2: #3a3c40;     /* linie jaśniejsze */
  --ink: #e4e4e4;         /* tekst */
  --muted: #b9b9b9;       /* tekst wtórny */
  --brass: #c9a14a;       /* mosiężny akcent */
  --brass-2: #ad8635;     /* ciemniejszy mosiądz */
  --emerald: #1f8a70;     /* dodatkowy akcent (linki/aktywne) */
  --paper: #ddd2b4;       /* delikatny akcent pergaminowy */
  --warn: #d4685e;        /* linki do brakujących stron */
  --radius: 12px;
  --shadow-1: 0 1px 0 rgba(0,0,0,.6), 0 6px 14px rgba(0,0,0,.45);
  --inset-1: inset 0 1px 0 rgba(255,255,255,.035), inset 0 -1px 0 rgba(0,0,0,.5);
  --tr: 220ms cubic-bezier(.22,.61,.36,1); /* old-school ease */
}

/* Subtelna "ziarnistość" 2D (bez obrazków) */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: -1;
  background-image:
    radial-gradient(transparent 60%, rgba(0,0,0,.3)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.015) 0 2px, transparent 2px 4px),
    linear-gradient(180deg, var(--bg-0), var(--bg-1));
  opacity: .95;
  pointer-events: none;
}

/* GLOBAL */
html, body, #mw-wrapper, #mw-content-container {
  background: transparent !important;
  color: var(--ink) !important;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
}

/* HEADER – płaski, stalowo-mosiężny */
#mw-header-container {
  background: linear-gradient(180deg, var(--bg-1) 0%, var(--bg-2) 100%) !important;
  border-bottom: 1px solid var(--steel-1) !important;
  box-shadow: var(--shadow-1) !important;
}

/* LINKI – oldschool: mosiądz + zieleń */
a { color: var(--emerald) !important; text-decoration: none; transition: color var(--tr), text-shadow var(--tr); }
a:visited { color: #74c7a4 !important; }
a.new { color: var(--warn) !important; }
a:hover { color: #ffffff !important; text-shadow: 0 0 6px rgba(31,138,112,.6); }

/* CENTRALNE LOGO (bez szkła, 2D) */
#custom-top-logo {
  display: block !important;
  margin: 20px auto !important;
  width: 460px !important;
  height: 250px !important;
  background-size: contain !important;
  image-rendering: -webkit-optimize-contrast;
  position: relative !important;
  z-index: 1000 !important;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.45));
}

/* SIDEBAR – kompakt, stal z mosiężnymi akcentami */
#mw-site-navigation, #mw-related-navigation {
  background: linear-gradient(180deg, #202224, #1a1c1f) !important;
  border-right: 1px solid var(--steel-1);
  box-shadow: 4px 0 18px rgba(0,0,0,.25);
  padding-top: 0 !important;
  border-radius: 0 var(--radius) var(--radius) 0 !important;
}

#mw-site-navigation .sidebar-chunk, #mw-related-navigation .sidebar-chunk {
  background: rgba(26,28,31,.9) !important;
  padding: 4px 6px;
  border-radius: 10px;
  box-shadow: var(--inset-1);
  transition: transform var(--tr), background var(--tr);
}
#mw-site-navigation .sidebar-chunk:hover,
#mw-related-navigation .sidebar-chunk:hover { transform: translateX(1px); }

#mw-site-navigation .sidebar-heading, #mw-related-navigation .sidebar-heading {
  color: #fff !important;
  background: linear-gradient(180deg, #232529, #1c1e22) !important;
  padding: 4px 6px;
  border-left: 3px solid var(--brass);
  border-radius: 8px;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}

#mw-site-navigation a, #mw-related-navigation a {
  color: #d3d3d3 !important;
  display: block;
  padding: 4px 6px;
  border-radius: 8px;
  transition: background var(--tr), color var(--tr), transform var(--tr);
}
#mw-site-navigation a:hover, #mw-related-navigation a:hover {
  color: #fff !important;
  background: rgba(45,47,51,.75) !important;
  transform: translateX(2px);
}

/* CONTENT – płaski panel ze stalową ramką */
#mw-content {
  background: var(--bg-2) !important;
  border: 1px solid var(--steel-1);
  border-radius: 14px;
  padding: 2em;
  box-shadow: var(--shadow-1);
  transition: box-shadow var(--tr), transform var(--tr);
}
#mw-content:hover { box-shadow: 0 1px 0 rgba(0,0,0,.6), 0 10px 24px rgba(0,0,0,.5); }

/* FOOTER – prosto i równo */
#mw-footer {
  background: linear-gradient(180deg, #1c1e21, #17191c) !important;
  border-top: 1px solid var(--steel-1);
  color: var(--muted) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.025);
  border-radius: 12px 12px 0 0;
  padding: 12px 16px;
}

/* SPIS TREŚCI – stal + mosiądz */
#toc {
  background: #1c1e21 !important;
  border: 1px solid var(--steel-2);
  border-left: 3px solid var(--brass);
  border-radius: 10px;
  padding: 8px 10px;
  box-shadow: var(--inset-1), 0 6px 16px rgba(0,0,0,.35);
}
#toc h2 { color: #fff !important; text-shadow: 0 1px 2px rgba(0,0,0,.6); }
#toc ul li a { color: #cfcfcf !important; transition: color var(--tr), transform var(--tr); }
#toc ul li a:hover { color: #fff !important; transform: translateX(2px); }

/* FORMULARZE – 2D, wytłaczane */
input[type="text"], textarea, select {
  background: #1c1e21 !important;
  color: #fff !important;
  border: 1px solid var(--steel-2) !important;
  border-radius: 10px;
  padding: 8px 10px;
  box-shadow: var(--inset-1);
  transition: border-color var(--tr), box-shadow var(--tr), transform var(--tr);
}
input:focus, textarea:focus, select:focus {
  outline: none !important;
  border-color: var(--brass) !important;
  box-shadow: 0 0 0 3px rgba(201,161,74,.2);
  transform: translateY(-1px);
}

/* PRZYCISKI – mosiądz (hover/pressed + ripple-ish) */
.mw-ui-button, input[type="submit"], button {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, var(--brass), var(--brass-2)) !important;
  color: #151515 !important;
  border: 1px solid #7b6127 !important;
  border-radius: 12px;
  padding: 9px 18px;
  cursor: pointer;
  text-shadow: 0 1px 0 rgba(255,255,255,.25);
  box-shadow: 0 2px 0 #7b6127, 0 8px 18px rgba(0,0,0,.45);
  transition: transform var(--tr), box-shadow var(--tr), filter var(--tr);
}
.mw-ui-button:hover, input[type="submit"]:hover, button:hover {
  transform: translateY(-1px);
  box-shadow: 0 3px 0 #7b6127, 0 12px 24px rgba(0,0,0,.5);
  filter: brightness(1.03);
}
.mw-ui-button:active, input[type="submit"]:active, button:active {
  transform: translateY(1px);
  box-shadow: 0 1px 0 #7b6127, 0 6px 14px rgba(0,0,0,.45) inset;
}

/* Delikatny efekt “ripple” bez JS */
.mw-ui-button::after, input[type="submit"]::after, button::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(circle at var(--x,50%) var(--y,50%),
                              rgba(255,255,255,.18), transparent 60%);
  opacity: 0; transition: opacity 400ms ease;
}
.mw-ui-button:hover::after, input[type="submit"]:hover::after, button:hover::after { opacity: .35; }
.mw-ui-button:active::after, input[type="submit"]:active::after, button:active::after { opacity: .5; }
/* Ustawienie pozycji ripple przez CSS zmienne z :hover (fallback – środek) */
.mw-ui-button:hover, input[type="submit"]:hover, button:hover { --x: 50%; --y: 50%; }

/* SEARCH */
#simpleSearch, #mw-searchInput {
  background: #1c1e21 !important;
  color: #fff !important;
  border: 1px solid var(--steel-2) !important;
  border-radius: 10px;
  padding: 6px 10px;
  box-shadow: var(--inset-1);
  transition: border-color var(--tr), box-shadow var(--tr), transform var(--tr);
}
#simpleSearch input:focus, #mw-searchInput:focus {
  box-shadow: 0 0 0 3px rgba(201,161,74,.22) !important;
  border-color: var(--brass) !important;
  transform: translateY(-1px);
}

/* TABELKI – stal + przejścia na hover wiersza */
table {
  background: var(--bg-2) !important;
  border: 1px solid var(--steel-1) !important;
  border-radius: 8px;
  border-collapse: collapse !important;
  color: var(--ink) !important;
  overflow: hidden;
}
th, td {
  background: #1e2023 !important;
  border: 1px solid var(--steel-2) !important;
  padding: 8px 10px;
}
th {
  background: #23262a !important;
  color: #f1f1f1 !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.6);
}
tr:nth-child(even) td { background: #1b1d20 !important; }
tbody tr { transition: background var(--tr); }
tbody tr:hover td { background: #24272b !important; }

/* NAGŁÓWEK STRONY – mosiężna linia + subtelna poświata */
#mw-firstheading,
#mw-content-container .firstHeading,
#mw-content-container .mw-first-heading {
  border-bottom: 3px solid var(--brass) !important;
  padding-bottom: 6px;
  box-shadow: 0 6px 16px rgba(201,161,74,.25);
}

/* Małe detale – separator sekcji */
hr {
  border: none;
  border-top: 1px solid var(--steel-1);
  margin: 1.5em 0;
  opacity: .85;
}

/* Dostępność: focus ring dla linków i elementów interaktywnych */
a:focus, button:focus, .mw-ui-button:focus, input:focus, select:focus, textarea:focus {
  outline: 2px solid rgba(201,161,74,.55);
  outline-offset: 2px;
  border-radius: 8px;
}