MediaWiki:Templates.css
Appearance
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)
- Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5.
/* MediaWiki:Templates.css */
/* WARNING: THIS FILE IS @IMPORT BY COMMON.CSS */
/* ------------------------------------------------------------------------- */
/* ANCHOR: CORE TEMPLATE STYLES */
/* THE BELOW APPLIES TO ALL BOXES FLOATING TO THE RIGHT OF ARTICLES */
/* Body for templates */
.template-table {
float: right;
max-width: 280px;
width: auto;
word-wrap:break-word;
overflow-wrap: break-word;
box-sizing: border-box;
border: 1px solid;
border-color: var(--template-border-color);
padding: 6px;
margin-left: 12px;
}
/* Title row */
.template-title {
text-align: center;
font-size: 1.2em;
font-weight: bold;
padding: 4px;
}
@media (max-width: 680px) {
.template-table {
float: none !important;
margin: 0 auto !important;
width: 100% !important;
max-width: 100% !important;
display: table !important;
}
}
/* Generic divider for template boxes */
.template-divider {
margin: 14px 0;
border: none;
border-top: 1px solid;
border-top-color: var(--template-border-color);
}
/* TEMPLATE LISTS STYLING WITH ICONS */
/* Base styling for all template lists */
.template-list {
margin: 0;
padding-left: 1em;
list-style-type: none;
}
/* Countries */
.template-list-country li {
padding: 2px 0;
}
/* Languages */
.template-list-language li {
list-style-type: '\1F5E3\FE0F '; /* 🗣️ speaking head */
padding: 2px 0;
}
/* Websites */
.template-list-website li {
list-style-type: '\1F517 '; /* 🔗 link symbol */
/* Alternatives: \1F310 (🌐 globe), \1F578\FE0F (🕸️ spider web) */
padding: 2px 0;
}
/* ------------------------------------------------------------------------- */
/* ANCHOR: FLOATING BADGE TEMPLATES */
/* Outer container for the floating badge */
.floating-badge {
float: right;
margin: 1px;
border-radius: 8px;
overflow: hidden; /* rounded corners clip inner content */
width: 238px;
clear: right;
}
/* Table used for layout */
.floating-badge-table {
width: 100%;
border-spacing: 0;
color: var(--light-text);
font-size: 0.9em;
line-height: 1.3;
}
/* Left cell: Icon */
.floating-badge-logo {
width: 45px;
text-align: center;
padding: 4px 1px 4px 4px;
vertical-align: middle;
white-space: nowrap; /* keep the icon cell from wrapping */
}
/* Right cell: Text */
.floating-badge-info {
text-align: left !important;
padding: 4px;
vertical-align: middle;
white-space: normal; /* allow wrapping */
word-wrap: break-word;
}
/* Mobile styles */
/* By viewport */
@media screen and (max-width: 660px) {
.floating-badge {
float: none;
width: auto;
margin: 0.5em 0;
border-radius: 4px;
overflow: clip;
}
.floating-badge-table
{ width: 100%; }
.floating-badge-logo
{ display: none; }
.floating-badge-info {
text-align: center;
padding: 8px;
}
}
/* By skin */
.skin-minerva .floating-badge {
float: none;
border: none;
width: auto;
margin: 0.2em 0;
overflow: clip;
}
.skin-minerva .floating-badge-table
{ border: none !important; }
.floating-badge-info
{ text-align: center; }
/* SPECIFIC FLOATING BADGE COLORS */
.badge-lua
{ background: var(--template-color-lua); }
.badge-visual-editor
{ background: var(--template-color-ve); }
/* ------------------------------------------------------------------------- */
/* ANCHOR: OTHER TEMPLATE STYLES */
/* Hatnote templates */
.hatnote {
font-style: italic;
padding: 4px;
border: 1px dashed;
border-color: var(--template-border-color);
}
/* Highlight templates: Aggressively highlighted box */
.template-highlight {
border: 1px solid rgb(170, 170, 170);
background-color: var(--highlight-background);
padding: 4px;
}
/* Module:SocialMedia icons: Make the image black, then shift its hue to green */
.external-social img {
filter: brightness(0) saturate(100%) invert(34%) sepia(100%) saturate(300%) hue-rotate(100deg) brightness(90%) contrast(85%);
}
/* ------------------------------------------------------------------------- */
/* ANCHOR: TEMPLATE:Person */
/* Person template image carousel */
.template-title-person {
background-color: var(--general-link-color);
color: white;
text-align: center;
font-weight: bold;
}
.person-portrait-carousel {
text-align: center;
padding: 0;
}
/* Container has fixed size to maintain consistent template layout */
.carousel-container {
position: relative;
margin: 0 auto;
padding: 0;
height: 340px; /* Dictates container size */
width: 100%; /* Responsive base */
max-width: 280px; /* Match template-table max-width */
box-sizing: border-box;
overflow: visible; /* Allow 3D effects to extend outside container */
}
/* Navigation arrows */
.carousel-nav {
position: absolute;
top: 50%;
transform: translateY(-50%);
cursor: pointer;
font-size: 2.8rem;
padding: 4px 10px;
opacity: 0.8;
z-index: 20;
color: var(--general-link-color);
transition: opacity 0.2s ease;
}
/* Arrow positioning in relation to center */
.carousel-prev {
left: -5px;
}
.carousel-next {
right: -5px;
}
.carousel-nav:hover {
opacity: 1;
color: var(--hover-link-color);
}
.carousel-images {
position: relative;
width: 220px; /* Match the image width from Lua template */
height: 100%;
margin: 0 auto;
perspective: 800px;
}
.carousel-item {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
transition: all 0.75s cubic-bezier(0.45, 0.05, 0.55, 0.95); /* Enhanced easing for orbital effect */
transform-style: preserve-3d;
backface-visibility: hidden;
display: flex;
align-items: center;
justify-content: center;
}
/* Center images within the container */
.carousel-item img {
display: block;
max-width: 100%;
max-height: 100%;
margin: 0 auto;
}
/* Visible item (current slide) */
.carousel-item.carousel-visible {
z-index: 10;
opacity: 1;
transform: translateX(0) scale(1);
}
/* Hidden items (not in view) */
.carousel-item.carousel-hidden {
opacity: 0.3;
transform: scale(0.7);
}
/* Left position (previous slide) */
.carousel-item.carousel-left {
z-index: 5;
transform: translateX(-60px) translateZ(-80px) rotateY(20deg) scale(0.82);
opacity: 0.6;
}
/* Right position (next slide) */
.carousel-item.carousel-right {
z-index: 5;
transform: translateX(60px) translateZ(-80px) rotateY(-20deg) scale(0.82);
opacity: 0.6;
}
/* Two-image orbital effect classes */
.carousel-item.carousel-orbital-1 {
z-index: 10;
opacity: 1;
transform-origin: left center;
transform: translateX(-5px) translateY(0px) scale(0.95);
}
.carousel-item.carousel-orbital-2 {
z-index: 5;
opacity: 0.7;
transform: translateX(30px) translateY(15px) rotateY(-10deg) scale(0.85);
}
/* Orbital animations for 2-image carousel with smooth circular motion (13-point precision) */
@keyframes orbital-forward {
/* Front to back animation - smooth path with faster initial separation */
0% { transform: translateX(-5px) translateY(0px) scale(0.95); opacity: 1; z-index: 10; }
7.69% { transform: translateX(2px) translateY(-12px) scale(0.93); opacity: 0.95; z-index: 10; }
15.38% { transform: translateX(8px) translateY(-20px) scale(0.915); opacity: 0.9; z-index: 10; }
23.08% { transform: translateX(14px) translateY(-24px) scale(0.9); opacity: 0.85; z-index: 10; }
30.77% { transform: translateX(19px) translateY(-25px) scale(0.89); opacity: 0.82; z-index: 10; }
38.46% { transform: translateX(23px) translateY(-24px) scale(0.88); opacity: 0.8; z-index: 10; }
46.15% { transform: translateX(26px) translateY(-20px) scale(0.87); opacity: 0.78; z-index: 10; }
53.85% { transform: translateX(28px) translateY(-12px) rotateY(-4deg) scale(0.865); opacity: 0.76; z-index: 10; }
61.54% { transform: translateX(29px) translateY(-5px) rotateY(-6deg) scale(0.86); opacity: 0.74; z-index: 10; }
69.23% { transform: translateX(30px) translateY(2px) rotateY(-8deg) scale(0.855); opacity: 0.72; z-index: 5; }
76.92% { transform: translateX(30px) translateY(7px) rotateY(-9deg) scale(0.853); opacity: 0.71; z-index: 5; }
84.62% { transform: translateX(30px) translateY(12px) rotateY(-10deg) scale(0.851); opacity: 0.705; z-index: 5; }
100% { transform: translateX(30px) translateY(15px) rotateY(-10deg) scale(0.85); opacity: 0.7; z-index: 5; }
}
@keyframes orbital-backward {
/* Back to front animation - smooth path with faster initial separation */
0% { transform: translateX(30px) translateY(15px) rotateY(-10deg) scale(0.85); opacity: 0.7; z-index: 5; }
7.69% { transform: translateX(22px) translateY(22px) rotateY(-8deg) scale(0.865); opacity: 0.76; z-index: 5; }
15.38% { transform: translateX(15px) translateY(25px) rotateY(-6deg) scale(0.88); opacity: 0.82; z-index: 5; }
23.08% { transform: translateX(8px) translateY(23px) rotateY(-4deg) scale(0.895); opacity: 0.85; z-index: 5; }
30.77% { transform: translateX(4px) translateY(21px) rotateY(-2deg) scale(0.905); opacity: 0.87; z-index: 5; }
38.46% { transform: translateX(0px) translateY(18px) scale(0.915); opacity: 0.89; z-index: 5; }
46.15% { transform: translateX(-3px) translateY(14px) scale(0.925); opacity: 0.91; z-index: 5; }
53.85% { transform: translateX(-5px) translateY(10px) scale(0.93); opacity: 0.93; z-index: 10; }
61.54% { transform: translateX(-6px) translateY(7px) scale(0.935); opacity: 0.945; z-index: 10; }
69.23% { transform: translateX(-6px) translateY(5px) scale(0.94); opacity: 0.96; z-index: 10; }
76.92% { transform: translateX(-6px) translateY(3px) scale(0.945); opacity: 0.975; z-index: 10; }
84.62% { transform: translateX(-5px) translateY(1px) scale(0.948); opacity: 0.99; z-index: 10; }
100% { transform: translateX(-5px) translateY(0px) scale(0.95); opacity: 1; z-index: 10; }
}
/* Animation classes with optimized timing to reduce lag perception */
.carousel-item.orbital-animating-forward {
animation: orbital-forward 0.6s cubic-bezier(0.23, 1, 0.32, 1) forwards; /* Faster initial separation */
}
.carousel-item.orbital-animating-backward {
animation: orbital-backward 0.6s cubic-bezier(0.23, 1, 0.32, 1) forwards; /* Faster initial separation */
}
.carousel-label {
text-align: center;
margin-top: 5px;
font-weight: bold;
}
/* REVIEW: LEGACY STYLING */
.template-people {
float: right;
border: 1px solid;
border-color: var(--template-border-color);
max-width: 160px;
padding: 4px;
padding-bottom: 10px;
margin-left: 10px
}
/* ------------------------------------------------------------------------- */
/* ANCHOR: TEMPLATE:TLD */
.template-title-tld { background-color: var(--template-color-tld); }
.tld-logo {
text-align: center;
padding: 10px 0;
}
.tld-logo img {
max-width: 150px; /* Capped width */
height: auto;
}
/* TEMPLATE:TLD FLAIRS */
/* Flair row base styling */
/* Dummy flair to enable pseudo-element decoration */
.tld-flair {
position: relative;
padding: 5px 0;
text-align: center;
border-bottom: 1px solid #ccc;
}
/* Geographic TLD flair */
.tld-flair.tld-template-subtype-geotld:before {
content: "geoTLD";
font-family: "Helvetica Neue", Helvetica, sans-serif;
font-size: 1.4em;
color: #006064;
background: rgba(0, 128, 128, 0.1);
padding: 2px 5px;
border-radius: 3px;
}
/* Brand TLD flair */
.tld-flair.tld-template-subtype-brandtld:before {
content: "dotBrand";
font-family: "Montserrat", sans-serif;
font-size: 1.4em;
font-weight: bold;
color: var(--light-text);
background: linear-gradient(135deg, #0D47A1, #1976D2);
padding: 2px 5px;
border-radius: 4px;
}
/* Sponsored TLD flair */
.tld-flair.tld-template-subtype-sponsored:before {
content: "Sponsored TLD";
font-family: "Merriweather", serif;
font-size: 1.4em;
font-style: italic;
color: #c64e2a;
background: linear-gradient(135deg, rgba(255,223,0,0.12), rgba(255,193,7,0.12));
padding: 2px 5px;
border-radius: 3px;
}
/* Legacy TLD flair */
.tld-flair.tld-template-subtype-legacytld:before {
content: "Legacy TLD";
font-family: "Times New Roman", serif;
font-size: 1.4em;
text-transform: uppercase;
color: #7d6767;
background: linear-gradient(135deg, #f5f5dc, #f0e68c);
padding: 2px 5px;
border-radius: 3px;
}
/* 2012 nGTLD Round flair */
.tld-flair.tld-template-subtype-ngtld-round-2012:before {
content: "gTLD Round: 2012";
font-family: "Trebuchet MS", sans-serif;
font-size: 1.4em;
font-weight: bold;
color: #1B5E20;
background: linear-gradient(135deg, rgba(178,223,219,0.15), rgba(128,203,196,0.15));
padding: 2px 5px;
border-radius: 3px;
}
/* IDN TLD flairs base */
.tld-flair.tld-template-idn-gtld:before, .tld-flair.tld-template-idn-cctld:before {
font-family: "Noto Sans", sans-serif;
font-size: 1.4em;
font-weight: 500;
color: #1976D2;
background: linear-gradient(135deg, rgba(33,150,243,0.15), rgba(33,150,243,0.05));
padding: 2px 5px;
border-radius: 3px;
margin-right: 0.5em;
}
/* IDN gTLD flair customization */
.tld-flair.tld-template-idn-gtld:before
{ content: "IDN / gTLD"; }
/* IDN ccTLD flair customization */
.tld-flair.tld-template-idn-cctld:before
{ content: "IDN / ccTLD"; }
/* ------------------------------------------------------------------------- */
/* ANCHOR: CENTERED TEMPLATE STYLES */
/* Base styles for all template boxes */
.icannwiki-signal, .icannwiki-warning, .icannwiki-danger {
display: flex;
justify-content: center;
align-items: center;
text-align: center;
height: auto;
width: 60%;
margin: 0 auto;
padding: 10px;
/* Common border styles */
border: 2px solid;
border-left-width: 16px;
}
/* Common link styles */
.icannwiki-signal a, .icannwiki-warning a, .icannwiki-danger a
{ font-weight: bold; }
/* Template-specific colors - day mode */
.icannwiki-signal {
background-color: color-mix(in srgb, white 95%, var(--signal-color) 5%);
border-color: var(--signal-color);
}
.icannwiki-signal a
{ color: var(--signal-color); }
.icannwiki-warning {
background-color: color-mix(in srgb, white 95%, var(--warning-color) 5%);
border-color: var(--warning-color);
}
.icannwiki-warning a
{ color: var(--warning-color); }
.icannwiki-danger {
background-color: color-mix(in srgb, white 95%, var(--danger-color) 5%);
border-color: var(--danger-color);
}
.icannwiki-danger a
{ color: var(--danger-color); }
/* Dark mode */
@media screen and (prefers-color-scheme: dark) {
/* Common */
html.skin-theme-clientpref-os .icannwiki-signal
{ background-color: color-mix(in srgb, var(--dark-base) 90%, var(--signal-color) 10%); }
html.skin-theme-clientpref-os .icannwiki-warning
{ background-color: color-mix(in srgb, var(--dark-base) 90%, var(--warning-color) 10%); }
html.skin-theme-clientpref-os .icannwiki-danger
{ background-color: color-mix(in srgb, var(--dark-base) 90%, var(--danger-color) 10%); }
/* Signal template */
html.skin-theme-clientpref-os .icannwiki-signal
{ border-color: color-mix(in srgb, var(--signal-color) 80%, black 20%); }
html.skin-theme-clientpref-os .icannwiki-signal a
{ color: color-mix(in srgb, var(--signal-color) 70%, white 30%); }
/* Warning template */
html.skin-theme-clientpref-os .icannwiki-warning { border-color: color-mix(in srgb, var(--warning-color) 80%, black 20%); }
html.skin-theme-clientpref-os .icannwiki-warning a
{ color: color-mix(in srgb, var(--warning-color) 70%, white 30%); }
/* Danger template */
html.skin-theme-clientpref-os .icannwiki-danger
{ border-color: color-mix(in srgb, var(--danger-color) 80%, black 20%); }
html.skin-theme-clientpref-os .icannwiki-danger a
{ color: color-mix(in srgb, var(--danger-color) 70%, white 30%); }
}
@media screen {
/* Common */
html.skin-theme-clientpref-night .icannwiki-signal
{ background-color: color-mix(in srgb, var(--dark-base) 90%, var(--signal-color) 10%); }
html.skin-theme-clientpref-night .icannwiki-warning
{ background-color: color-mix(in srgb, var(--dark-base) 90%, var(--warning-color) 10%); }
html.skin-theme-clientpref-night .icannwiki-danger
{ background-color: color-mix(in srgb, var(--dark-base) 90%, var(--danger-color) 10%); }
/* Signal template */
html.skin-theme-clientpref-night .icannwiki-signal
{ border-color: color-mix(in srgb, var(--signal-color) 80%, black 20%); }
html.skin-theme-clientpref-night .icannwiki-signal a
{ color: color-mix(in srgb, var(--signal-color) 70%, white 30%); }
/* Warning template */
html.skin-theme-clientpref-night .icannwiki-warning
{ border-color: color-mix(in srgb, var(--warning-color) 80%, black 20%); }
html.skin-theme-clientpref-night .icannwiki-warning a
{ color: color-mix(in srgb, var(--warning-color) 70%, white 30%); }
/* Danger template */
html.skin-theme-clientpref-night .icannwiki-danger
{ border-color: color-mix(in srgb, var(--danger-color) 80%, black 20%); }
html.skin-theme-clientpref-night .icannwiki-danger a
{ color: color-mix(in srgb, var(--danger-color) 70%, white 30%); }
}