MediaWiki:Timeless.css: Difference between revisions
From Helbreath Portal
No edit summary |
No edit summary Tag: Reverted |
||
| Line 1: | Line 1: | ||
/* === | /* === 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. | |||
=========================================================================== */ | |||
/* GLOBAL | /* 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 { | html, body, #mw-wrapper, #mw-content-container { | ||
background: | background: transparent !important; | ||
color: | color: var(--ink) !important; | ||
font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif; | font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif; | ||
} | } | ||
/* HEADER- | /* HEADER – płaski, stalowo-mosiężny */ | ||
#mw-header-container { | #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 { | #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 | /* SIDEBAR – kompakt, stal z mosiężnymi akcentami */ | ||
#mw-site-navigation, #mw-related-navigation { | #mw-site-navigation, #mw-related-navigation { | ||
background: linear-gradient(180deg, # | background: linear-gradient(180deg, #202224, #1a1c1f) !important; | ||
border-right: 1px solid var(--steel-1); | |||
box-shadow: 4px 0 18px rgba(0,0,0,.25); | |||
border-right: 1px solid | |||
box-shadow: | |||
padding-top: 0 !important; | padding-top: 0 !important; | ||
border-radius: 0 | border-radius: 0 var(--radius) var(--radius) 0 !important; | ||
} | } | ||
#mw-site-navigation .sidebar-chunk, #mw-related-navigation .sidebar-chunk { | #mw-site-navigation .sidebar-chunk, #mw-related-navigation .sidebar-chunk { | ||
background: rgba( | background: rgba(26,28,31,.9) !important; | ||
padding: 4px 6px; | |||
padding: | |||
border-radius: 10px; | border-radius: 10px; | ||
box-shadow: inset | box-shadow: var(--inset-1); | ||
transition: | 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 { | #mw-site-navigation .sidebar-heading, #mw-related-navigation .sidebar-heading { | ||
color: # | color: #fff !important; | ||
background: | background: linear-gradient(180deg, #232529, #1c1e22) !important; | ||
padding: | padding: 4px 6px; | ||
border- | border-left: 3px solid var(--brass); | ||
border-radius: 8px; | |||
text-shadow: 0 1px 2px rgba(0,0,0, | text-shadow: 0 1px 2px rgba(0,0,0,.6); | ||
} | } | ||
#mw-site-navigation a, #mw-related-navigation a { | #mw-site-navigation a, #mw-related-navigation a { | ||
color: # | color: #d3d3d3 !important; | ||
display: block; | display: block; | ||
padding: | padding: 4px 6px; | ||
border-radius: 8px; | border-radius: 8px; | ||
transition: | transition: background var(--tr), color var(--tr), transform var(--tr); | ||
} | } | ||
#mw-site-navigation a:hover, #mw-related-navigation a:hover { | #mw-site-navigation a:hover, #mw-related-navigation a:hover { | ||
color: # | color: #fff !important; | ||
background | background: rgba(45,47,51,.75) !important; | ||
transform: translateX(2px); | |||
transform: translateX( | |||
} | } | ||
/* CONTENT | /* CONTENT – płaski panel ze stalową ramką */ | ||
#mw-content { | #mw-content { | ||
background: | background: var(--bg-2) !important; | ||
border: 1px solid var(--steel-1); | |||
border-radius: 14px; | border-radius: 14px; | ||
padding: 2em; | padding: 2em; | ||
box-shadow: | box-shadow: var(--shadow-1); | ||
transition: | 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 */ | /* FOOTER – prosto i równo */ | ||
#mw-footer { | #mw-footer { | ||
background: linear-gradient( | 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-top: 1px solid | |||
color: | |||
box-shadow: inset 0 1px | |||
border-radius: 12px 12px 0 0; | border-radius: 12px 12px 0 0; | ||
padding: 12px 16px; | padding: 12px 16px; | ||
} | } | ||
/* | /* SPIS TREŚCI – stal + mosiądz */ | ||
#toc { | #toc { | ||
background: | background: #1c1e21 !important; | ||
border: 1px solid var(--steel-2); | |||
border: | border-left: 3px solid var(--brass); | ||
border-radius: 10px; | border-radius: 10px; | ||
padding: 8px 10px; | padding: 8px 10px; | ||
box-shadow: 0 | box-shadow: var(--inset-1), 0 6px 16px rgba(0,0,0,.35); | ||
} | } | ||
#toc h2 { color: # | #toc h2 { color: #fff !important; text-shadow: 0 1px 2px rgba(0,0,0,.6); } | ||
#toc ul li a { color: # | #toc ul li a { color: #cfcfcf !important; transition: color var(--tr), transform var(--tr); } | ||
#toc ul li a:hover { color: # | #toc ul li a:hover { color: #fff !important; transform: translateX(2px); } | ||
/* | /* FORMULARZE – 2D, wytłaczane */ | ||
input[type="text"], textarea, select { | input[type="text"], textarea, select { | ||
background: | background: #1c1e21 !important; | ||
color: # | color: #fff !important; | ||
border: 1px solid | border: 1px solid var(--steel-2) !important; | ||
border-radius: 10px; | border-radius: 10px; | ||
padding: | padding: 8px 10px; | ||
box-shadow: inset | box-shadow: var(--inset-1); | ||
transition: | transition: border-color var(--tr), box-shadow var(--tr), transform var(--tr); | ||
} | } | ||
input:focus, textarea:focus, select:focus { | input:focus, textarea:focus, select:focus { | ||
outline: none !important; | outline: none !important; | ||
border-color: | border-color: var(--brass) !important; | ||
box-shadow: 0 0 | box-shadow: 0 0 0 3px rgba(201,161,74,.2); | ||
transform: translateY(-1px); | |||
} | } | ||
/* | /* PRZYCISKI – mosiądz (hover/pressed + ripple-ish) */ | ||
input[type="submit"], | .mw-ui-button, input[type="submit"], button { | ||
background: linear-gradient( | position: relative; | ||
overflow: hidden; | |||
background: linear-gradient(180deg, var(--brass), var(--brass-2)) !important; | |||
color: # | color: #151515 !important; | ||
border: | border: 1px solid #7b6127 !important; | ||
border-radius: 12px; | border-radius: 12px; | ||
padding: | padding: 9px 18px; | ||
cursor: pointer; | cursor: pointer; | ||
box-shadow: 0 | text-shadow: 0 1px 0 rgba(255,255,255,.25); | ||
transition: | 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); | |||
} | } | ||
input[type="submit"]:hover, | .mw-ui-button:hover, input[type="submit"]:hover, button:hover { | ||
transform: translateY(-1px); | 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 | /* SEARCH */ | ||
#simpleSearch, #mw-searchInput { | #simpleSearch, #mw-searchInput { | ||
background: | background: #1c1e21 !important; | ||
color: # | color: #fff !important; | ||
border: 1px solid | border: 1px solid var(--steel-2) !important; | ||
border-radius: 10px; | border-radius: 10px; | ||
padding: 6px 10px; | padding: 6px 10px; | ||
box-shadow: inset | box-shadow: var(--inset-1); | ||
transition: | transition: border-color var(--tr), box-shadow var(--tr), transform var(--tr); | ||
} | } | ||
#simpleSearch input:focus, #mw-searchInput:focus { | #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 { | 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 { | th, td { | ||
background: #1e2023 !important; | |||
border: 1px solid var(--steel-2) !important; | |||
padding: 8px 10px; | |||
} | } | ||
th { | 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; | |||
} | } | ||
Revision as of 22:37, 20 August 2025
/* === 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;
}