Jump to content

MediaWiki:Templates.css

From ICANNWiki

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%); }
}