MediaWiki:Common.css: Difference between revisions
Appearance
m global styiling prep |
mNo edit summary |
||
| Line 43: | Line 43: | ||
margin: 0; | margin: 0; | ||
background: var(--ooo-tab-arrow-bg); | background: var(--ooo-tab-arrow-bg); | ||
color: var(--ooo-tab-arrow-color); | |||
} | |||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow::before { | |||
content:""; | |||
position:absolute; | |||
inset:-6px; | |||
} | } | ||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow--prev { inset-inline-start: 2px; } | .ooo-infobox-tabwrap--scroll .ooo-tab-arrow--prev { inset-inline-start: 2px; } | ||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow--next { inset-inline-end: 2px; } | .ooo-infobox-tabwrap--scroll .ooo-tab-arrow--next { inset-inline-end: 2px; } | ||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover { background: var(--ooo-tab-arrow-bg-hover); } | |||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:disabled { opacity:.4; cursor: default; box-shadow: none; } | .ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover { | ||
background: var(--ooo-tab-arrow-bg-hover); | |||
} | |||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:disabled { | |||
opacity:.4; | |||
cursor: default; | |||
box-shadow: none; | |||
} | |||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow.is-hidden { display: none; } | .ooo-infobox-tabwrap--scroll .ooo-tab-arrow.is-hidden { display: none; } | ||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow__icon { display: block; } | .ooo-infobox-tabwrap--scroll .ooo-tab-arrow__icon { display: block; } | ||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:focus-visible { outline: none; box-shadow: var(--ooo-tab-arrow-focus); } | |||
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:focus-visible { | |||
outline: none; | |||
box-shadow: var(--ooo-tab-arrow-focus); | |||
} | |||
/* Dark theme — explicit client preference */ | /* Dark theme — explicit client preference */ | ||
| Line 60: | Line 77: | ||
--ooo-tab-arrow-color: var(--color-base, #eaecf0); | --ooo-tab-arrow-color: var(--color-base, #eaecf0); | ||
} | } | ||
html.skin-theme-clientpref-night .ooo-infobox-tabwrap--scroll .ooo-tab-arrow { | html.skin-theme-clientpref-night .ooo-infobox-tabwrap--scroll .ooo-tab-arrow { | ||
border-color: #3a3a3a; | border-color: #3a3a3a; | ||
| Line 65: | Line 83: | ||
box-shadow: 0 1px 2px rgba(0,0,0,.35); | box-shadow: 0 1px 2px rgba(0,0,0,.35); | ||
} | } | ||
html.skin-theme-clientpref-night .ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover { | html.skin-theme-clientpref-night .ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover { | ||
background: var(--background-color-neutral-subtle, #222325); | background: var(--background-color-neutral-subtle, #222325); | ||
| Line 74: | Line 93: | ||
--ooo-tab-arrow-color: var(--color-base, #eaecf0); | --ooo-tab-arrow-color: var(--color-base, #eaecf0); | ||
} | } | ||
html.skin-theme-clientpref-os .ooo-infobox-tabwrap--scroll .ooo-tab-arrow { | html.skin-theme-clientpref-os .ooo-infobox-tabwrap--scroll .ooo-tab-arrow { | ||
border-color: #3a3a3a; | border-color: #3a3a3a; | ||
| Line 79: | Line 99: | ||
box-shadow: 0 1px 2px rgba(0,0,0,.35); | box-shadow: 0 1px 2px rgba(0,0,0,.35); | ||
} | } | ||
html.skin-theme-clientpref-os .ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover { | html.skin-theme-clientpref-os .ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover { | ||
background: var(--background-color-neutral-subtle, #222325); | background: var(--background-color-neutral-subtle, #222325); | ||
| Line 89: | Line 110: | ||
content: ""; | content: ""; | ||
display: inline-block; | display: inline-block; | ||
width: 20px; height: 20px; | width: 20px; | ||
height: 20px; | |||
background-color: currentColor !important; | background-color: currentColor !important; | ||
background: none !important; | background: none !important; | ||
-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M7 1L5.6 2.5 13 10l-7.4 7.5L7 19l9-9z'/></svg>") no-repeat center / contain; | -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M7 1L5.6 2.5 13 10l-7.4 7.5L7 19l9-9z'/></svg>") no-repeat center / contain; | ||
mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M7 1L5.6 2.5 13 10l-7.4 7.5L7 19l9-9z'/></svg>") no-repeat center / contain; | mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M7 1L5.6 2.5 13 10l-7.4 7.5L7 19l9-9z'/></svg>") no-repeat center / contain; | ||
} | } | ||
.tabber__header__prev:after { | .tabber__header__prev:after { | ||
-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M13 1l1.4 1.5L7 10l7.4 7.5L13 19l-9-9z'/></svg>") no-repeat center / contain; | -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M13 1l1.4 1.5L7 10l7.4 7.5L13 19l-9-9z'/></svg>") no-repeat center / contain; | ||
| Line 104: | Line 124: | ||
} | } | ||
.ooo-infobox-tabwrap--scroll .tabber__header { | |||
.ooo-infobox-tabwrap--scroll .tabber__header { color: var(--ooo-tab-arrow-color); } | color: var(--ooo-tab-arrow-color); | ||
} | |||
@media (max-width: 640px) { | @media (max-width: 640px) { | ||
.ooo-infobox-tabwrap, | .ooo-infobox-tabwrap, | ||
| Line 119: | Line 139: | ||
} | } | ||
.ooo-infobox-tabwrap .tabber__header { | .ooo-infobox-tabwrap .tabber__header { | ||
border-bottom: 0 !important; | border-bottom: 0 !important; | ||
| Line 125: | Line 144: | ||
} | } | ||
.ooo-infobox-tabwrap .tabber__tabs::after { | .ooo-infobox-tabwrap .tabber__tabs::after { | ||
content: none !important; | content: none !important; | ||
} | } | ||
.ooo-infobox-tabwrap .tabber__tab--active { | .ooo-infobox-tabwrap .tabber__tab--active { | ||
box-shadow: none !important; | box-shadow: none !important; | ||
margin-bottom: 0 !important; | margin-bottom: 0 !important; | ||
} | } | ||
.ooo-infobox-tabwrap .tabber__tabs { | .ooo-infobox-tabwrap .tabber__tabs { | ||
margin-bottom: 0px !important; | margin-bottom: 0px !important; | ||
} | } | ||
/* ===== OOO Headings ===== */ | /* ===== OOO Headings ===== */ | ||
| Line 169: | Line 183: | ||
border: 1px solid var(--ooo-border); | border: 1px solid var(--ooo-border); | ||
border-collapse: collapse; | border-collapse: collapse; | ||
width: 100%; | |||
font-size: 0.95rem; | |||
} | } | ||
| Line 175: | Line 191: | ||
color: var(--ooo-accent); | color: var(--ooo-accent); | ||
text-align: left; | text-align: left; | ||
padding: 8px; | padding: 8px 10px; | ||
font-weight: 600; | |||
border: none; | border: none; | ||
} | } | ||
.wikitable td { | .wikitable td { | ||
padding: 8px; | padding: 8px 10px; | ||
border-top: 1px solid var(--ooo-border); | border-top: 1px solid var(--ooo-border); | ||
} | |||
.wikitable tr:hover td { | |||
background: rgba(255,122,0,0.05); | |||
} | } | ||
Revision as of 13:05, 3 March 2026
/* CSS placed here will be applied to all skins */
/* ===== OOO Tab Scroll — minimal, production-safe ===== */
/* Theme tokens (tweak freely) */
:root {
--ooo-tab-arrow-size: 22px;
--ooo-tab-arrow-offset: -0.1rem;
--ooo-tab-arrow-color: #2a4b8d; /* light mode icon color */
--ooo-tab-arrow-bg: #fff;
--ooo-tab-arrow-bg-hover: #f5f5f5;
--ooo-tab-arrow-border: #a2a9b1;
--ooo-tab-arrow-shadow: 0 1px 2px rgba(0,0,0,.1);
--ooo-tab-arrow-focus: 0 0 0 2px rgba(51,102,204,.35);
/* OOO Design Tokens */
--ooo-accent: #ff7a00;
--ooo-border: #2b2b2b;
--ooo-bg-block: #161616;
}
/* Wrapper must be positioned (JS also enforces if needed) */
.ooo-infobox-tabwrap--scroll { position: relative; }
/* Our injected arrow buttons (use currentColor for icon) */
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow {
position: absolute;
top: var(--ooo-tab-arrow-offset);
inline-size: var(--ooo-tab-arrow-size);
block-size: var(--ooo-tab-arrow-size);
border-radius: 999px;
border: 1px solid var(--ooo-tab-arrow-border);
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
z-index: 2;
box-sizing: border-box;
appearance: none;
font: inherit;
text-shadow: none;
box-shadow: var(--ooo-tab-arrow-shadow);
padding: 0;
margin: 0;
background: var(--ooo-tab-arrow-bg);
color: var(--ooo-tab-arrow-color);
}
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow::before {
content:"";
position:absolute;
inset:-6px;
}
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow--prev { inset-inline-start: 2px; }
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow--next { inset-inline-end: 2px; }
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover {
background: var(--ooo-tab-arrow-bg-hover);
}
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:disabled {
opacity:.4;
cursor: default;
box-shadow: none;
}
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow.is-hidden { display: none; }
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow__icon { display: block; }
.ooo-infobox-tabwrap--scroll .ooo-tab-arrow:focus-visible {
outline: none;
box-shadow: var(--ooo-tab-arrow-focus);
}
/* Dark theme — explicit client preference */
html.skin-theme-clientpref-night .ooo-infobox-tabwrap--scroll {
--ooo-tab-arrow-color: var(--color-base, #eaecf0);
}
html.skin-theme-clientpref-night .ooo-infobox-tabwrap--scroll .ooo-tab-arrow {
border-color: #3a3a3a;
background: var(--background-color-neutral, #2a2b2e);
box-shadow: 0 1px 2px rgba(0,0,0,.35);
}
html.skin-theme-clientpref-night .ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover {
background: var(--background-color-neutral-subtle, #222325);
}
/* Dark theme — follow OS */
@media (prefers-color-scheme: dark) {
html.skin-theme-clientpref-os .ooo-infobox-tabwrap--scroll {
--ooo-tab-arrow-color: var(--color-base, #eaecf0);
}
html.skin-theme-clientpref-os .ooo-infobox-tabwrap--scroll .ooo-tab-arrow {
border-color: #3a3a3a;
background: var(--background-color-neutral, #2a2b2e);
box-shadow: 0 1px 2px rgba(0,0,0,.35);
}
html.skin-theme-clientpref-os .ooo-infobox-tabwrap--scroll .ooo-tab-arrow:hover {
background: var(--background-color-neutral-subtle, #222325);
}
}
/* ===== TabberNeue header arrows — use currentColor via mask ===== */
.tabber__header__next:after,
.tabber__header__prev:after {
content: "";
display: inline-block;
width: 20px;
height: 20px;
background-color: currentColor !important;
background: none !important;
-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M7 1L5.6 2.5 13 10l-7.4 7.5L7 19l9-9z'/></svg>") no-repeat center / contain;
mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M7 1L5.6 2.5 13 10l-7.4 7.5L7 19l9-9z'/></svg>") no-repeat center / contain;
}
.tabber__header__prev:after {
-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M13 1l1.4 1.5L7 10l7.4 7.5L13 19l-9-9z'/></svg>") no-repeat center / contain;
mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='currentColor' d='M13 1l1.4 1.5L7 10l7.4 7.5L13 19l-9-9z'/></svg>") no-repeat center / contain;
}
.ooo-infobox-tabwrap--scroll .tabber__header {
color: var(--ooo-tab-arrow-color);
}
@media (max-width: 640px) {
.ooo-infobox-tabwrap,
.ooo-infobox-tabwrap--left,
.ooo-infobox-tabwrap--none,
.ooo-infobox-tabwrap--center {
float: none;
width: 100%;
margin: 0 0 1em 0;
}
}
.ooo-infobox-tabwrap .tabber__header {
border-bottom: 0 !important;
box-shadow: none !important;
}
.ooo-infobox-tabwrap .tabber__tabs::after {
content: none !important;
}
.ooo-infobox-tabwrap .tabber__tab--active {
box-shadow: none !important;
margin-bottom: 0 !important;
}
.ooo-infobox-tabwrap .tabber__tabs {
margin-bottom: 0px !important;
}
/* ===== OOO Headings ===== */
.mw-body h1,
.mw-body h2,
.mw-body h3 {
border: none !important;
font-weight: 600;
letter-spacing: .3px;
}
.mw-body h2 {
border-left: 4px solid var(--ooo-accent);
padding-left: 10px;
margin-top: 32px;
}
.mw-body h3 {
margin-top: 24px;
}
/* ===== OOO Styled Wikitable ===== */
.wikitable {
background: var(--ooo-bg-block);
border: 1px solid var(--ooo-border);
border-collapse: collapse;
width: 100%;
font-size: 0.95rem;
}
.wikitable th {
background: #202020;
color: var(--ooo-accent);
text-align: left;
padding: 8px 10px;
font-weight: 600;
border: none;
}
.wikitable td {
padding: 8px 10px;
border-top: 1px solid var(--ooo-border);
}
.wikitable tr:hover td {
background: rgba(255,122,0,0.05);
}