Jump to content

Template:OOOInfoBox/styles.css: Difference between revisions

From Out of Ore Wiki
No edit summary
Tag: Manual revert
mNo edit summary
Line 1: Line 1:
/* OOO infobox TemplateStyles + night-mode friendly
/* OOO InfoBox clean game-wiki style
   - Uses skin tokens with fallbacks
   Theme safe (light / dark / OS)
   - Sets color whenever background is set
   Compatible with MediaWiki TemplateStyles
  - Keeps border colors as literals to avoid TemplateStyles color warnings
*/
*/


/* Base box */
/* ------------------------------------------------ */
/* BASE BOX                                        */
/* ------------------------------------------------ */
 
.ooo-infobox {
.ooo-infobox {
   width: 300px;
   width: 300px;
   border-width: 1px;
   border: 1px solid #a2a9b1;
  border-style: solid;
   border-radius: 10px;
   border-color: #a2a9b1; /* literal to avoid linter warning */
   border-collapse: separate;
   border-collapse: separate;
   border-spacing: 0;
   border-spacing: 0;
   background: var(--background-color-base, #ffffff);
   background: var(--background-color-base, #ffffff);
   color: var(--color-base, #202122);
   color: var(--color-base, #202122);
   font-size: 90%;
   font-size: 90%;
  overflow: hidden;
   box-shadow: 0 2px 10px rgba(0,0,0,.08);
   box-shadow: 0 2px 10px rgba(0,0,0,.08);
   border-radius: 12px;
 
   overflow: hidden;
  float: right;
   clear: right;
   margin: 0 0 1em 1em;
}
}


/* Links (optional; remove to let skin handle them) */
/* ------------------------------------------------ */
/* LINKS                                            */
/* ------------------------------------------------ */
 
.ooo-infobox a { color: var(--color-progressive, #36c); }
.ooo-infobox a { color: var(--color-progressive, #36c); }
.ooo-infobox a:hover { color: var(--color-progressive--hover, #447ff5); }
.ooo-infobox a:hover { color: var(--color-progressive--hover, #447ff5); }


/* Title bar */
/* ------------------------------------------------ */
.ooo-infobox .ooo-infobox__title {
/* TITLE                                            */
/* ------------------------------------------------ */
 
.ooo-infobox__title {
   text-align: center;
   text-align: center;
   font-weight: 800;
   font-weight: 700;
   font-size: 112%;
   font-size: 115%;
   letter-spacing: .2px;
   letter-spacing: .3px;
   background: var(--background-color-neutral, #f5f5f5);
 
   color: #cea141; /* NMC accent */
   background: var(--ooo-accent);
   color: #ffffff;
 
   padding: 12px 10px;
   padding: 12px 10px;
  border-top: 1px solid #a2a9b1;    /* literal */
 
   border-bottom: 1px solid #a2a9b1; /* literal */
   border-bottom: 1px solid #a2a9b1;
}
}


/* Image region */
/* ------------------------------------------------ */
.ooo-infobox .ooo-infobox__image {
/* IMAGE                                            */
/* ------------------------------------------------ */
 
.ooo-infobox__image {
   text-align: center;
   text-align: center;
   padding: 12px;
   padding: 12px;
   background: var(--background-color-neutral-subtle, #f8f9fa);
   background: var(--background-color-neutral-subtle, #f8f9fa);
  color: var(--color-base, #202122);
}
}
.ooo-infobox .ooo-infobox__image img {
 
.ooo-infobox__image img {
   max-width: 100%;
   max-width: 100%;
   height: auto;
   height: auto;
  border-radius: 6px;
}
}


/* Caption */
/* ------------------------------------------------ */
.ooo-infobox .ooo-infobox__caption {
/* CAPTION                                          */
/* ------------------------------------------------ */
 
.ooo-infobox__caption {
   text-align: center;
   text-align: center;
   font-style: italic;
   font-style: italic;
  line-height: 1.35;
  padding: 6px 12px 12px;
   color: var(--color-subtle, #54595d);
   color: var(--color-subtle, #54595d);
  padding: 8px 12px 12px;
  line-height: 1.35;
   background: var(--background-color-neutral-subtle, #f8f9fa);
   background: var(--background-color-neutral-subtle, #f8f9fa);
   border-bottom: 1px solid #a2a9b1; /* literal */
 
   border-bottom: 1px solid #a2a9b1;
}
}


/* Table rows/cells */
/* ------------------------------------------------ */
/* TABLE CELLS                                      */
/* ------------------------------------------------ */
 
.ooo-infobox th,
.ooo-infobox th,
.ooo-infobox td {
.ooo-infobox td {
   padding: 9px 12px;
   padding: 8px 12px;
   vertical-align: top;
   vertical-align: top;
}
}
.ooo-infobox th {
.ooo-infobox th {
   width: 46%;
   width: 46%;
Line 73: Line 103:
}
}


/* Zebra striping (set color alongside background) */
/* ------------------------------------------------ */
/* ZEBRA ROWS                                      */
/* ------------------------------------------------ */
 
.ooo-infobox tr:nth-child(even) td,
.ooo-infobox tr:nth-child(even) td,
.ooo-infobox tr:nth-child(even) th {
.ooo-infobox tr:nth-child(even) th {
   background: var(--background-color-neutral-subtle, #f8f9fa);
   background: rgba(0,0,0,.02);
  color: var(--color-base, #202122);
}
}


/* Group headers */
/* ------------------------------------------------ */
/* GROUP HEADERS                                    */
/* ------------------------------------------------ */
 
.ooo-infobox__group th {
.ooo-infobox__group th {
   text-align: center;
   text-align: center;
   font-weight: 800;
   font-weight: 700;
   padding: 10px 12px;
  font-size: 95%;
   background: var(--background-color-neutral, #eaecf0);
  letter-spacing: .3px;
 
   padding: 9px 12px;
 
   background: var(--background-color-neutral-subtle, #f8f9fa);
   color: var(--color-base, #202122);
   color: var(--color-base, #202122);
   border-top: 1px solid #a2a9b1;   /* literal */
 
   border-bottom: 1px solid #a2a9b1; /* literal */
   border-top: 1px solid #a2a9b1;
   border-bottom: 1px solid #a2a9b1;
}
}


/* Helper text */
/* ------------------------------------------------ */
.ooo-infobox .ooo-infobox__muted {
/* MUTED TEXT                                      */
/* ------------------------------------------------ */
 
.ooo-infobox__muted {
   color: var(--color-subtle, #54595d);
   color: var(--color-subtle, #54595d);
}
}


/* --------- Night mode: forced (explicit user toggle) ---------
/* ------------------------------------------------ */
  Wrapped in @media screen to avoid affecting print styles.
/* ALIGNMENT OPTIONS                                */
*/
/* ------------------------------------------------ */
 
.ooo-infobox--left {
  float: left;
  clear: left;
  margin: 0 1em 1em 0;
}
 
.ooo-infobox--none {
  float: none;
  margin: 0 0 1em 0;
}
 
.ooo-infobox--center {
  float: none;
  margin: 0 auto 1em;
  display: block;
}
 
/* ------------------------------------------------ */
/* MOBILE                                          */
/* ------------------------------------------------ */
 
@media (max-width: 640px) {
  .ooo-infobox,
  .ooo-infobox--left,
  .ooo-infobox--none,
  .ooo-infobox--center {
    float: none;
    margin: 0 0 1em 0;
    width: 100%;
  }
}
 
/* ------------------------------------------------ */
/* NIGHT MODE (FORCED)                              */
/* ------------------------------------------------ */
 
@media screen {
@media screen {
  html.skin-theme-clientpref-night .ooo-infobox {
    border-color: #3a3a3a; /* literals for borders */
    background: var(--background-color-base, #1b1b1d);
    color: var(--color-base, #eaecf0);
  }
  html.skin-theme-clientpref-night .ooo-infobox a {
    color: var(--color-progressive, #6aa9ff);
  }
  html.skin-theme-clientpref-night .ooo-infobox a:hover {
    color: var(--color-progressive--hover, #8fbdff);
  }


  html.skin-theme-clientpref-night .ooo-infobox .ooo-infobox__title {
html.skin-theme-clientpref-night .ooo-infobox {
    background: var(--background-color-neutral, #252527);
  border-color: #3a3a3a;
    color: #cea141;
  background: var(--background-color-base, #1b1b1d);
    border-top-color: #3a3a3a;
  color: var(--color-base, #eaecf0);
    border-bottom-color: #3a3a3a;
}
  }
 
html.skin-theme-clientpref-night .ooo-infobox__title {
  background: var(--ooo-accent);
  color: #ffffff;
}
 
html.skin-theme-clientpref-night .ooo-infobox__image,
html.skin-theme-clientpref-night .ooo-infobox__caption {
  background: var(--background-color-neutral-subtle, #222325);
}


  html.skin-theme-clientpref-night .ooo-infobox .ooo-infobox__image,
html.skin-theme-clientpref-night .ooo-infobox__group th {
  html.skin-theme-clientpref-night .ooo-infobox .ooo-infobox__caption,
  background: var(--background-color-neutral, #2a2b2e);
  html.skin-theme-clientpref-night .ooo-infobox tr:nth-child(even) td,
  border-color: #3a3a3a;
  html.skin-theme-clientpref-night .ooo-infobox tr:nth-child(even) th {
}
    background: var(--background-color-neutral-subtle, #222325);
    color: var(--color-base, #eaecf0);
  }


  html.skin-theme-clientpref-night .ooo-infobox .ooo-infobox__caption,
html.skin-theme-clientpref-night .ooo-infobox th {
  html.skin-theme-clientpref-night .ooo-infobox__group th {
  color: var(--color-emphasized, #f1f2f3);
    border-bottom-color: #3a3a3a;
}
  }


  html.skin-theme-clientpref-night .ooo-infobox__group th {
html.skin-theme-clientpref-night .ooo-infobox__muted {
    background: var(--background-color-neutral, #2a2b2e);
  color: var(--color-subtle, #a2a9b1);
    color: var(--color-base, #eaecf0);
}
    border-top-color: #3a3a3a;
  }


  html.skin-theme-clientpref-night .ooo-infobox th {
    color: var(--color-emphasized, #f1f2f3);
  }
  html.skin-theme-clientpref-night .ooo-infobox .ooo-infobox__muted {
    color: var(--color-subtle, #a2a9b1);
  }
}
}


/* --------- Night mode: automatic (follow OS preference) --------- */
/* ------------------------------------------------ */
/* NIGHT MODE (OS AUTO)                             */
/* ------------------------------------------------ */
 
@media (prefers-color-scheme: dark) {
@media (prefers-color-scheme: dark) {
  html.skin-theme-clientpref-os .ooo-infobox {
    border-color: #3a3a3a;
    background: var(--background-color-base, #1b1b1d);
    color: var(--color-base, #eaecf0);
  }
  html.skin-theme-clientpref-os .ooo-infobox a {
    color: var(--color-progressive, #6aa9ff);
  }
  html.skin-theme-clientpref-os .ooo-infobox a:hover {
    color: var(--color-progressive--hover, #8fbdff);
  }


  html.skin-theme-clientpref-os .ooo-infobox .ooo-infobox__title {
html.skin-theme-clientpref-os .ooo-infobox {
    background: var(--background-color-neutral, #252527);
  border-color: #3a3a3a;
    color: #cea141;
  background: var(--background-color-base, #1b1b1d);
    border-top-color: #3a3a3a;
  color: var(--color-base, #eaecf0);
    border-bottom-color: #3a3a3a;
}
  }


  html.skin-theme-clientpref-os .ooo-infobox .ooo-infobox__image,
html.skin-theme-clientpref-os .ooo-infobox__title {
   html.skin-theme-clientpref-os .ooo-infobox .ooo-infobox__caption,
   background: var(--ooo-accent);
  html.skin-theme-clientpref-os .ooo-infobox tr:nth-child(even) td,
  color: #ffffff;
  html.skin-theme-clientpref-os .ooo-infobox tr:nth-child(even) th {
}
    background: var(--background-color-neutral-subtle, #222325);
    color: var(--color-base, #eaecf0);
  }


  html.skin-theme-clientpref-os .ooo-infobox .ooo-infobox__caption,
html.skin-theme-clientpref-os .ooo-infobox__image,
  html.skin-theme-clientpref-os .ooo-infobox__group th {
html.skin-theme-clientpref-os .ooo-infobox__caption {
    border-bottom-color: #3a3a3a;
  background: var(--background-color-neutral-subtle, #222325);
  }
}


  html.skin-theme-clientpref-os .ooo-infobox__group th {
html.skin-theme-clientpref-os .ooo-infobox__group th {
    background: var(--background-color-neutral, #2a2b2e);
  background: var(--background-color-neutral, #2a2b2e);
    color: var(--color-base, #eaecf0);
  border-color: #3a3a3a;
    border-top-color: #3a3a3a;
}
  }


  html.skin-theme-clientpref-os .ooo-infobox th {
html.skin-theme-clientpref-os .ooo-infobox th {
    color: var(--color-emphasized, #f1f2f3);
  color: var(--color-emphasized, #f1f2f3);
  }
  html.skin-theme-clientpref-os .ooo-infobox .ooo-infobox__muted {
    color: var(--color-subtle, #a2a9b1);
  }
}
}


/* Default: float right */
html.skin-theme-clientpref-os .ooo-infobox__muted {
.ooo-infobox { float: right; clear: right; margin: 0 0 1em 1em; }
  color: var(--color-subtle, #a2a9b1);
}


/* Overrides (use via |align=...) */
.ooo-infobox--left  { float: left;  clear: left;  margin: 0 1em 1em 0; }
.ooo-infobox--none  { float: none;  margin: 0 0 1em 0; }
.ooo-infobox--center { float: none;  margin: 0 auto 1em; display: block; }
/* Mobile: unfloat so it doesn’t squeeze text */
@media (max-width: 640px) {
  .ooo-infobox,
  .ooo-infobox--left,
  .ooo-infobox--none,
  .ooo-infobox--center { float: none; margin: 0 0 1em 0; width: 100%; }
}
}

Revision as of 20:32, 4 March 2026

/* OOO InfoBox — clean game-wiki style
   Theme safe (light / dark / OS)
   Compatible with MediaWiki TemplateStyles
*/

/* ------------------------------------------------ */
/* BASE BOX                                         */
/* ------------------------------------------------ */

.ooo-infobox {
  width: 300px;
  border: 1px solid #a2a9b1;
  border-radius: 10px;
  border-collapse: separate;
  border-spacing: 0;

  background: var(--background-color-base, #ffffff);
  color: var(--color-base, #202122);

  font-size: 90%;
  overflow: hidden;

  box-shadow: 0 2px 10px rgba(0,0,0,.08);

  float: right;
  clear: right;
  margin: 0 0 1em 1em;
}

/* ------------------------------------------------ */
/* LINKS                                            */
/* ------------------------------------------------ */

.ooo-infobox a { color: var(--color-progressive, #36c); }
.ooo-infobox a:hover { color: var(--color-progressive--hover, #447ff5); }

/* ------------------------------------------------ */
/* TITLE                                            */
/* ------------------------------------------------ */

.ooo-infobox__title {
  text-align: center;
  font-weight: 700;
  font-size: 115%;
  letter-spacing: .3px;

  background: var(--ooo-accent);
  color: #ffffff;

  padding: 12px 10px;

  border-bottom: 1px solid #a2a9b1;
}

/* ------------------------------------------------ */
/* IMAGE                                            */
/* ------------------------------------------------ */

.ooo-infobox__image {
  text-align: center;
  padding: 12px;

  background: var(--background-color-neutral-subtle, #f8f9fa);
}

.ooo-infobox__image img {
  max-width: 100%;
  height: auto;
  border-radius: 6px;
}

/* ------------------------------------------------ */
/* CAPTION                                          */
/* ------------------------------------------------ */

.ooo-infobox__caption {
  text-align: center;
  font-style: italic;
  line-height: 1.35;

  padding: 6px 12px 12px;

  color: var(--color-subtle, #54595d);
  background: var(--background-color-neutral-subtle, #f8f9fa);

  border-bottom: 1px solid #a2a9b1;
}

/* ------------------------------------------------ */
/* TABLE CELLS                                      */
/* ------------------------------------------------ */

.ooo-infobox th,
.ooo-infobox td {
  padding: 8px 12px;
  vertical-align: top;
}

.ooo-infobox th {
  width: 46%;
  font-weight: 600;
  color: var(--color-emphasized, #101418);
}

/* ------------------------------------------------ */
/* ZEBRA ROWS                                       */
/* ------------------------------------------------ */

.ooo-infobox tr:nth-child(even) td,
.ooo-infobox tr:nth-child(even) th {
  background: rgba(0,0,0,.02);
}

/* ------------------------------------------------ */
/* GROUP HEADERS                                    */
/* ------------------------------------------------ */

.ooo-infobox__group th {
  text-align: center;
  font-weight: 700;
  font-size: 95%;
  letter-spacing: .3px;

  padding: 9px 12px;

  background: var(--background-color-neutral-subtle, #f8f9fa);
  color: var(--color-base, #202122);

  border-top: 1px solid #a2a9b1;
  border-bottom: 1px solid #a2a9b1;
}

/* ------------------------------------------------ */
/* MUTED TEXT                                       */
/* ------------------------------------------------ */

.ooo-infobox__muted {
  color: var(--color-subtle, #54595d);
}

/* ------------------------------------------------ */
/* ALIGNMENT OPTIONS                                */
/* ------------------------------------------------ */

.ooo-infobox--left {
  float: left;
  clear: left;
  margin: 0 1em 1em 0;
}

.ooo-infobox--none {
  float: none;
  margin: 0 0 1em 0;
}

.ooo-infobox--center {
  float: none;
  margin: 0 auto 1em;
  display: block;
}

/* ------------------------------------------------ */
/* MOBILE                                           */
/* ------------------------------------------------ */

@media (max-width: 640px) {
  .ooo-infobox,
  .ooo-infobox--left,
  .ooo-infobox--none,
  .ooo-infobox--center {
    float: none;
    margin: 0 0 1em 0;
    width: 100%;
  }
}

/* ------------------------------------------------ */
/* NIGHT MODE (FORCED)                              */
/* ------------------------------------------------ */

@media screen {

html.skin-theme-clientpref-night .ooo-infobox {
  border-color: #3a3a3a;
  background: var(--background-color-base, #1b1b1d);
  color: var(--color-base, #eaecf0);
}

html.skin-theme-clientpref-night .ooo-infobox__title {
  background: var(--ooo-accent);
  color: #ffffff;
}

html.skin-theme-clientpref-night .ooo-infobox__image,
html.skin-theme-clientpref-night .ooo-infobox__caption {
  background: var(--background-color-neutral-subtle, #222325);
}

html.skin-theme-clientpref-night .ooo-infobox__group th {
  background: var(--background-color-neutral, #2a2b2e);
  border-color: #3a3a3a;
}

html.skin-theme-clientpref-night .ooo-infobox th {
  color: var(--color-emphasized, #f1f2f3);
}

html.skin-theme-clientpref-night .ooo-infobox__muted {
  color: var(--color-subtle, #a2a9b1);
}

}

/* ------------------------------------------------ */
/* NIGHT MODE (OS AUTO)                             */
/* ------------------------------------------------ */

@media (prefers-color-scheme: dark) {

html.skin-theme-clientpref-os .ooo-infobox {
  border-color: #3a3a3a;
  background: var(--background-color-base, #1b1b1d);
  color: var(--color-base, #eaecf0);
}

html.skin-theme-clientpref-os .ooo-infobox__title {
  background: var(--ooo-accent);
  color: #ffffff;
}

html.skin-theme-clientpref-os .ooo-infobox__image,
html.skin-theme-clientpref-os .ooo-infobox__caption {
  background: var(--background-color-neutral-subtle, #222325);
}

html.skin-theme-clientpref-os .ooo-infobox__group th {
  background: var(--background-color-neutral, #2a2b2e);
  border-color: #3a3a3a;
}

html.skin-theme-clientpref-os .ooo-infobox th {
  color: var(--color-emphasized, #f1f2f3);
}

html.skin-theme-clientpref-os .ooo-infobox__muted {
  color: var(--color-subtle, #a2a9b1);
}

}