Source code

Revision control

Copy as Markdown

Other Tools

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
@namespace html "http://www.w3.org/1999/xhtml";
/* TODO(bug 1845150): Remove notification-message from the host selectors in
* this file */
:host(:is(.anonymous-content-host, notification-message)),
:root {
--in-content-page-color: rgb(21, 20, 26);
--in-content-page-background: var(--background-color-canvas);
--in-content-text-color: var(--in-content-page-color);
--in-content-box-background: var(--background-color-box);
--in-content-box-background-odd: rgba(12, 12, 13, 0.05); /* grey 90 a05 */
--in-content-box-border-color: color-mix(in srgb, currentColor 41%, transparent);
--in-content-box-info-background: #f0f0f4;
--in-content-item-hover: color-mix(in srgb, var(--in-content-primary-button-background) 20%, transparent);
--in-content-item-hover-text: var(--in-content-page-color);
--in-content-item-selected: var(--in-content-primary-button-background);
--in-content-item-selected-text: var(--in-content-primary-button-text-color);
--in-content-icon-color: rgb(91,91,102);
--in-content-accent-color: var(--in-content-primary-button-background);
--in-content-accent-color-active: var(--in-content-primary-button-background-hover);
--in-content-border-hover: var(--grey-90-a50);
--in-content-border-invalid: var(--red-50);
--in-content-border-color: #d7d7db;
--in-content-warning-icon-color: #ffa436;
--in-content-success-icon-color: #2ac3a2;
--in-content-button-text-color: var(--in-content-text-color);
--in-content-button-text-color-hover: var(--in-content-text-color);
--in-content-button-text-color-active: var(--in-content-button-text-color-hover);
--in-content-button-background: color-mix(in srgb, currentColor 7%, transparent);
--in-content-button-background-hover: color-mix(in srgb, currentColor 14%, transparent);
--in-content-button-background-active: color-mix(in srgb, currentColor 21%, transparent);
--in-content-button-border-color: transparent;
--in-content-button-border-color-hover: transparent;
--in-content-button-border-color-active: var(--in-content-button-border-color-hover);
--in-content-primary-button-text-color: rgb(251,251,254);
--in-content-primary-button-text-color-hover: var(--in-content-primary-button-text-color);
--in-content-primary-button-text-color-active: var(--in-content-primary-button-text-color);
--in-content-primary-button-background: #0061e0;
--in-content-primary-button-background-hover: #0250bb;
--in-content-primary-button-background-active: #053e94;
--in-content-primary-button-border-color: transparent;
--in-content-primary-button-border-hover: transparent;
--in-content-primary-button-border-active: transparent;
--in-content-danger-button-background: #e22850;
--in-content-danger-button-background-hover: #c50042;
--in-content-danger-button-background-active: #810220;
--in-content-focus-outline-color: var(--focus-outline-color);
--in-content-focus-outline-width: var(--focus-outline-width);
--in-content-focus-outline-offset: var(--focus-outline-offset);
--in-content-focus-outline-inset: var(--focus-outline-inset);
--in-content-focus-outline: var(--focus-outline);
--in-content-table-background: #f8f8fa;
--in-content-table-border-color: var(--in-content-box-border-color);
--in-content-table-header-background: var(--in-content-primary-button-background);
--in-content-table-header-color: var(--in-content-primary-button-text-color);
--in-content-sidebar-width: 240px;
--dialog-warning-text-color: var(--red-60);
--blue-40: #45a1ff;
--blue-50: #0a84ff;
--blue-60: #0060df;
--grey-30: #d7d7db;
--grey-60: #4a4a4f;
--grey-90-a10: rgba(12, 12, 13, 0.1);
--grey-90-a20: rgba(12, 12, 13, 0.2);
--grey-90-a30: rgba(12, 12, 13, 0.3);
--grey-90-a50: rgba(12, 12, 13, 0.5);
--grey-90-a60: rgba(12, 12, 13, 0.6);
--green-50: #30e60b;
--green-60: #12bc00;
--green-70: #058b00;
--green-80: #006504;
--green-90: #003706;
--orange-50: #ff9400;
--red-40: #ff4f5e;
--red-50: #ff0039;
--red-60: #d70022;
--red-70: #a4000f;
--red-80: #5a0002;
--red-90: #3e0200;
--yellow-50: #ffe900;
--yellow-60: #d7b600;
--yellow-60-a30: rgba(215, 182, 0, 0.3);
--yellow-70: #a47f00;
--yellow-80: #715100;
--yellow-90: #3e2800;
--shadow-10: 0 1px 4px var(--grey-90-a10);
--shadow-30: 0 4px 16px var(--grey-90-a10);
--card-padding: 16px;
--card-shadow: var(--shadow-10);
--card-outline-color: var(--grey-30);
--card-shadow-hover: var(--card-shadow), 0 0 0 5px var(--card-outline-color);
-moz-theme: non-native;
accent-color: var(--in-content-accent-color);
color-scheme: light dark;
}
@media (prefers-color-scheme: dark) {
:host(:is(.anonymous-content-host, notification-message)),
:root {
/* Keep these in sync with:
*
* * nsXPLookAndFeel::GenericDarkColor
* * The default value of browser.display.foreground_color.dark and
* browser.display.background_color.dark
*
* TODO (emilio): Once color-scheme support is complete, perhaps we can
* just replace most of these for system colors and remove all this
* duplication (assuming we honor the preferred color scheme for
* in-content privileged pages and plain-text documents). */
--in-content-page-color: rgb(251,251,254);
--in-content-box-background-odd: rgba(249,249,250,0.05);
--in-content-box-info-background: rgba(249,249,250,0.15);
--in-content-border-color: rgba(249,249,250,0.2);
--in-content-border-hover: rgba(249,249,250,0.3);
--in-content-border-invalid: rgb(255,132,139);
--in-content-warning-icon-color: #ffbd4f;
--in-content-success-icon-color: #54FFBD;
--in-content-icon-color: rgb(251,251,254);
--in-content-primary-button-text-color: rgb(43,42,51);
--in-content-primary-button-background: rgb(0,221,255);
--in-content-primary-button-background-hover: rgb(128,235,255);
--in-content-primary-button-background-active: rgb(170,242,255);
--in-content-danger-button-background: #ff848b;
--in-content-danger-button-background-hover: #ffbdc5;
--in-content-danger-button-background-active: #ffdfe7;
--in-content-table-background: rgb(35, 34, 43);
--card-outline-color: var(--grey-60);
--dialog-warning-text-color: var(--red-40);
scrollbar-color: rgba(249,249,250,.4) rgba(20,20,25,.3);
}
/* For dialogs, use a different background colour. We don't do
* this in forced colors mode, as we should be using system colours then.
*/
@media not (forced-colors) {
:root[dialogroot] {
--in-content-page-background: #42414d;
}
}
}
@media (forced-colors) {
:host(:is(.anonymous-content-host, notification-message)),
:root {
--in-content-page-color: CanvasText;
--in-content-box-background-odd: var(--in-content-box-background);
--in-content-box-border-color: -moz-DialogText;
--in-content-box-info-background: var(--in-content-box-background);
--in-content-item-hover: SelectedItem;
--in-content-item-hover-text: SelectedItemText;
--in-content-item-selected: SelectedItem;
--in-content-item-selected-text: SelectedItemText;
--in-content-icon-color: -moz-DialogText;
--in-content-accent-color: SelectedItem;
--in-content-accent-color-active: SelectedItem;
--in-content-border-hover: ThreeDShadow;
/* This is not great, but there is no suitable keyword for this.
* In theory, we shouldn't be conveying invalid state just with a colour
* change... */
--in-content-border-invalid: ThreeDShadow;
--in-content-border-color: var(--border-color);
--in-content-button-text-color: ButtonText;
--in-content-button-text-color-hover: SelectedItemText;
--in-content-button-text-color-active: SelectedItem;
--in-content-button-background: ButtonFace;
--in-content-button-background-hover: SelectedItem;
--in-content-button-background-active: SelectedItemText;
--in-content-button-border-color: ButtonText;
--in-content-button-border-color-hover: SelectedItemText;
--in-content-button-border-color-active: SelectedItem;
--in-content-primary-button-text-color: ButtonFace;
--in-content-primary-button-text-color-hover: SelectedItemText;
--in-content-primary-button-text-color-active: SelectedItem;
--in-content-primary-button-background: ButtonText;
--in-content-primary-button-background-hover: SelectedItem;
--in-content-primary-button-background-active: SelectedItemText;
--in-content-primary-button-border-color: ButtonFace;
--in-content-primary-button-border-hover: SelectedItemText;
--in-content-primary-button-border-active: SelectedItem;
--in-content-danger-button-background: var(--in-content-primary-button-background);
--in-content-danger-button-background-hover: var(--in-content-primary-button-background-hover);
--in-content-danger-button-background-active: var(--in-content-primary-button-background-active);
--in-content-focus-outline-color: -moz-DialogText;
--in-content-table-border-color: ThreeDDarkShadow;
--in-content-table-background: -moz-Dialog;
--in-content-table-header-background: -moz-Dialog;
--in-content-table-header-color: -moz-DialogText;
--dialog-warning-text-color: -moz-FieldText;
}
}
:root {
appearance: none;
background-color: var(--in-content-page-background);
color: var(--in-content-page-color);
}
:root:not(.system-font-size) {
font-size: var(--font-size-root);
}
html|body {
margin: 0;
}
html|hr {
border-style: solid none none none;
border-color: var(--in-content-border-color);
}
.main-content {
padding: 40px 28px;
overflow: auto;
}
/* tabpanels and tabs */
xul|tabpanels {
appearance: none;
border: none;
padding: 0;
background-color: transparent;
color: inherit;
color-scheme: unset;
}
xul|tabs {
margin-bottom: 10px;
border-bottom: 1px solid var(--in-content-border-color);
background-color: transparent;
color: inherit;
}
xul|tab {
appearance: none;
margin: 0;
padding: 2px 20px 0;
min-height: 44px;
color: inherit;
background-color: transparent;
border-bottom: 2px solid transparent;
transition: background-color 50ms ease 0s;
color-scheme: unset;
}
xul|tab:where(:hover) {
border-bottom-color: var(--in-content-border-color);
background-color: var(--in-content-button-background-hover);
color: var(--in-content-button-text-color-hover);
}
xul|tab:where(:hover:active) {
background-color: var(--in-content-button-background-active);
color: var(--in-content-button-text-color-active);
}
xul|tab[selected] {
color: var(--in-content-accent-color);
border-bottom-color: currentColor;
}
xul|tab[selected]:hover {
background-color: var(--in-content-button-background-hover);
}
xul|tab[selected]:hover:active {
background-color: var(--in-content-button-background-active);
}
@media (forced-colors) {
xul|tab:hover,
xul|tab:hover:active {
border-bottom-color: currentColor;
}
xul|tab[selected]:hover {
color: var(--in-content-button-text-color-hover);
}
xul|tab[selected]:hover:active {
color: var(--in-content-button-text-color-active);
}
}
/* html buttons */
html|button {
font: inherit;
}
/* xul buttons and menulists */
button,
html|select,
html|input[type="color"],
xul|menulist {
appearance: none;
min-height: var(--button-min-height);
color: var(--in-content-button-text-color);
border: 1px solid var(--in-content-button-border-color);
border-radius: 4px;
background-color: var(--in-content-button-background);
font-weight: 400;
padding: .45em 1em;
text-decoration: none;
margin: 4px 8px;
/* Ensure font-size isn't overridden by widget styling (e.g. in forms.css) */
font-size: 1em;
}
button {
font-weight: var(--button-font-weight);
}
/* Small buttons get sized to 6/12px padding (when adding the 1px border) */
button.small-button {
padding: .25em 1em;
font-size: var(--font-size-small);
min-height: 28px;
}
/* Remove margin added by button.css */
xul|button > .button-box > .button-text {
margin: 0;
}
button {
/* Use the same margin of other elements for the alignment */
margin-inline: 4px;
}
::-moz-focus-inner {
border: none;
}
button:focus-visible,
html|select:focus-visible,
html|input:where([type="color"]):focus-visible,
xul|menulist:focus-visible,
xul|tab:focus-visible > .tab-middle > .tab-text {
box-shadow: none;
/* Don't set `var(--in-content-focus-outline)` here to allow more complicated UIs
to use a different color when needed */
outline: var(--in-content-focus-outline-width) solid var(--in-content-focus-outline-color);
outline-offset: var(--in-content-focus-outline-offset);
}
html|select:not([size], [multiple]) {
/* The following padding matches how a menulist is internally spaced.
* 15px is the menulist's standard padding-inline, 3px is for
* the internal label margin, 12px is the dropmarker's width
* and 4px is the dropmarker's margin-inline-end.
*
* [------|---|---label---|dropmarker|----|------]
* 15px 3px 12px 4px 15px
* start-padding background- end-padding
* image-width
*
* Users of this element can change the variable --logical-padding. Other
* variables should adjust automatically.
*/
--logical-padding: 15px;
--start-padding: calc(var(--logical-padding) + 3px);
--end-padding: calc(var(--logical-padding) + 4px);
--background-image-width: 12px;
background-position: right var(--end-padding) center;
background-repeat: no-repeat;
background-size: auto var(--background-image-width);
-moz-context-properties: fill;
fill: currentColor;
font: inherit;
font-weight: 600;
/* See above for some explanation about these values. */
padding-inline-start: var(--start-padding);
padding-inline-end: calc(var(--background-image-width) + var(--end-padding));
text-overflow: ellipsis;
}
html|select:not([size], [multiple]):dir(rtl) {
background-position-x: left var(--end-padding);
}
html|select:not([size], [multiple]) > html|option {
background-color: var(--in-content-box-background);
color: var(--in-content-text-color);
}
html|button:enabled:hover,
html|select:not([size], [multiple]):enabled:hover,
html|input[type="color"]:hover,
xul|button:not([disabled="true"]):hover,
xul|menulist:not([disabled="true"]):hover {
background-color: var(--in-content-button-background-hover);
color: var(--in-content-button-text-color-hover);
border-color: var(--in-content-button-border-color-hover);
}
html|button:enabled:hover:active,
html|select:not([size], [multiple]):enabled:hover:active,
html|input[type="color"]:enabled:hover:active,
xul|button:not([disabled="true"]):hover:active,
xul|button[open],
xul|button[open]:hover,
xul|menulist[open="true"]:not([disabled="true"]) {
background-color: var(--in-content-button-background-active);
color: var(--in-content-button-text-color-active);
border-color: var(--in-content-button-border-color-active);
}
html|button:disabled,
html|select:disabled,
html|input[type="color"]:disabled,
xul|button[disabled="true"],
xul|menulist[disabled="true"] {
opacity: 0.4;
}
html|button[autofocus],
html|button[type="submit"],
xul|button[default],
button.primary {
background-color: var(--in-content-primary-button-background);
color: var(--in-content-primary-button-text-color);
border-color: var(--in-content-primary-button-border-color);
}
html|button[autofocus]:enabled:hover,
html|button[type="submit"]:enabled:hover,
html|button.primary:enabled:hover,
xul|button[default]:not([disabled="true"]):hover,
xul|button.primary:not([disabled="true"]):hover {
background-color: var(--in-content-primary-button-background-hover);
color: var(--in-content-primary-button-text-color-hover);
border-color: var(--in-content-primary-button-border-hover);
}
html|button[autofocus]:enabled:hover:active,
html|button[type="submit"]:enabled:hover:active,
html|button.primary:enabled:hover:active,
xul|button[default]:not([disabled="true"]):hover:active,
xul|button.primary:not([disabled="true"]):hover:active {
background-color: var(--in-content-primary-button-background-active);
color: var(--in-content-primary-button-text-color-active);
border-color: var(--in-content-primary-button-border-active);
}
@media not (forced-colors) {
html|button.semi-transparent:not(.ghost-button, .primary):enabled {
background-color: color-mix(in srgb, currentColor 10%, transparent);
}
html|button.semi-transparent:not(.primary):enabled:hover {
background-color: color-mix(in srgb, currentColor 20%, transparent);
}
html|button.semi-transparent:not(.primary):enabled:hover:active {
background-color: color-mix(in srgb, currentColor 30%, transparent);
}
}
.danger-button {
--in-content-primary-button-background: var(--in-content-danger-button-background);
--in-content-primary-button-background-hover: var(--in-content-danger-button-background-hover);
--in-content-primary-button-background-active: var(--in-content-danger-button-background-active);
--in-content-focus-outline-color: var(--in-content-danger-button-background);
}
@media not (forced-colors) {
html|button.ghost-button {
background-color: transparent;
}
}
html|button.ghost-button:not(.semi-transparent):enabled:hover {
background-color: var(--in-content-button-background-hover);
color: var(--in-content-button-text-color-hover);
}
html|button.ghost-button:not(.semi-transparent):enabled:hover:active {
background-color: var(--in-content-button-background-active);
color: var(--in-content-button-text-color-active);
}
html|button.ghost-button.icon-button {
height: 16px;
width: 16px;
min-width: auto;
background-repeat: no-repeat;
background-size: 16px;
background-position: center;
fill: currentColor;
-moz-context-properties: fill;
}
html|input[type="color"] {
padding: 6px;
width: 50px;
}
xul|menulist[image]::part(icon) {
margin-inline-end: 5px;
}
xul|menulist > xul|menupopup {
appearance: none;
/* Reset native styles on Windows and macOS */
border: none;
background-color: transparent;
--panel-border-color: var(--in-content-box-border-color);
--panel-border-radius: 2px;
--panel-background: var(--in-content-box-background);
--panel-color: var(--in-content-text-color);
--panel-padding: 0;
}
xul|menulist > xul|menupopup xul|menu,
xul|menulist > xul|menupopup xul|menuitem {
appearance: none;
font-size: 1em;
padding-block: 0.2em;
padding-inline: 10px 30px;
}
xul|menulist > xul|menupopup > xul|menu:not([disabled="true"])[_moz-menuactive="true"],
xul|menulist > xul|menupopup > xul|menuitem:not([disabled="true"])[_moz-menuactive="true"] {
color: var(--in-content-item-hover-text);
background-color: var(--in-content-item-hover);
}
xul|menulist > xul|menupopup > xul|menu:not([disabled="true"])[selected="true"],
xul|menulist > xul|menupopup > xul|menuitem:not([disabled="true"])[selected="true"] {
color: var(--in-content-item-selected-text);
background-color: var(--in-content-item-selected);
}
xul|menulist > xul|menupopup > xul|menu[disabled="true"],
xul|menulist > xul|menupopup > xul|menuitem[disabled="true"] {
color: #999;
/* override the [_moz-menuactive="true"] background color from
global/menu.css */
background-color: transparent;
}
xul|menulist > xul|menupopup xul|menuseparator {
appearance: none;
margin: 0;
padding: 0;
border-top: 1px solid var(--in-content-box-border-color);
border-bottom: none;
}
/* textboxes */
html|input:where([type="email"], [type="tel"], [type="text"], [type="password"], [type="url"], [type="number"]),
html|textarea,
xul|search-textbox {
appearance: none;
border: 1px solid var(--in-content-box-border-color);
border-radius: 4px;
color: inherit;
background-color: var(--in-content-box-background);
}
xul|search-textbox {
min-height: var(--input-text-min-height);
padding-inline: 8px;
}
html|input:where([type="email"], [type="tel"], [type="text"], [type="password"], [type="url"], [type="number"]),
html|textarea {
box-sizing: border-box;
font-family: inherit;
font-size: inherit;
padding: .45em;
margin: 2px 4px;
min-height: var(--input-text-min-height);
}
html|textarea {
min-height: auto
}
html|input:where([type="email"], [type="tel"], [type="text"], [type="password"], [type="url"], [type="number"]):focus,
html|textarea:focus,
xul|search-textbox[focused],
xul|tree:focus-visible,
xul|richlistbox:focus-visible {
border-color: transparent;
outline: var(--in-content-focus-outline);
outline-offset: -1px; /* Prevents antialising around the corners */
}
html|input:where([type="email"], [type="tel"], [type="text"], [type="password"], [type="url"], [type="number"]):user-invalid,
html|textarea:user-invalid {
border-color: transparent;
outline: 2px solid var(--in-content-border-invalid);
outline-offset: -1px; /* Prevents antialising around the corners */
}
html|input:where([type="email"], [type="tel"], [type="text"], [type="password"], [type="url"], [type="number"]):disabled,
html|textarea:disabled,
xul|search-textbox[disabled="true"] {
opacity: 0.4;
}
/* Links */
html|a,
.text-link {
cursor: pointer;
color: var(--link-color);
}
html|a:visited {
color: var(--link-color-visited);
}
html|a:hover,
.text-link:hover,
button.text-link:is(:not([disabled="true"]), :enabled):hover {
color: var(--link-color-hover);
}
html|a:hover:active,
.text-link:hover:active,
button.text-link:is(:not([disabled="true"]), :enabled):hover:active {
color: var(--link-color-active);
text-decoration: none;
}
html|a:focus-visible,
.text-link:focus-visible {
outline: var(--focus-outline);
outline-offset: var(--link-focus-outline-offset);
border-radius: 4px;
}
button.text-link {
background-color: transparent !important; /* override hover related background changes */
padding: 0;
border: 0;
font-weight: normal;
min-height: 0;
min-width: 0;
}
/* Checkboxes and radio buttons */
/* Add invisible vertical click-target */
xul|*.radio-check,
xul|*.checkbox-check,
html|input:where([type="checkbox"], [type="radio"]) {
/* TODO Bug 1876537: Make this em-based, probably? */
height: 16px;
width: 16px;
padding: 0;
margin-block: var(--space-xxsmall);
margin-inline: 0 var(--checkbox-margin-inline);
flex-shrink: 0; /* avoid shrinking inside flex container */
}
xul|richlistitem > xul|*.checkbox-check {
margin: 3px 6px;
}
html|*.radio-container-with-text,
html|*.toggle-container-with-text {
display: flex;
align-items: center;
}
xul|radio {
margin-inline-start: 0;
appearance: none;
}
xul|*.radio-label-box {
margin-inline: 0 8px;
padding-inline-start: 0;
}
/* Disabled checkboxes, radios and labels */
xul|checkbox[disabled="true"],
xul|radio[disabled="true"],
xul|label[disabled="true"] {
color: inherit;
}
xul|checkbox[disabled="true"] > .checkbox-label-box,
xul|radio[disabled="true"] > .radio-label-box,
xul|label[disabled="true"] {
opacity: 0.5;
}
/* Category List */
#categories {
appearance: none;
background-color: initial; /* override the background-color set on all richlistboxes in common.inc.css */
margin: 70px 0 0;
border-width: 0;
width: var(--in-content-sidebar-width);
outline: none;
}
@media print {
#categories {
display: none;
}
}
html|*#categories {
box-sizing: border-box;
padding: 1px;
}
#categories > .category {
border: 1px solid var(--in-content-primary-button-border-color);
border-radius: 4px;
min-height: 48px;
appearance: none;
color: inherit;
margin-inline-start: 34px;
padding-inline: 10px;
transition: background-color 150ms;
}
html|*#categories > html|*.category {
border: 1px solid var(--in-content-primary-button-border-color);
background-color: initial;
background-size: 24px;
background-repeat: no-repeat;
background-position-x: 10px;
background-position-y: 12px;
margin-inline-end: 0;
min-width: auto;
padding-inline-start: 34px;
text-align: start;
-moz-context-properties: fill, fill-opacity;
fill: currentColor;
}
html|*#categories > html|*.category:dir(rtl) {
background-position-x: right 10px;
}
#categories > .category:hover {
background-color: var(--in-content-button-background-hover);
color: var(--in-content-button-text-color-hover);
border-color: var(--in-content-button-border-color-hover);
}
#categories > .category:hover:active {
background-color: var(--in-content-button-background-active);
color: var(--in-content-button-text-color-active);
border-color: var(--in-content-button-border-color-active);
}
@media not (forced-colors) {
#categories > .category[selected],
#categories > .category.selected {
color: var(--in-content-accent-color);
}
#categories > .category[selected]:not(:hover) {
/* override richlistitem selected style while letting hover style above apply */
background-color: transparent;
}
#categories > .category[selected]:hover:active,
#categories > .category.selected:hover:active {
color: var(--in-content-accent-color-active);
}
}
@media (forced-colors) {
#categories > .category {
/* The transition causes issues with the text getting a background while
* transitioning and it looks weird. */
transition: none;
/* We need a true transparent but in HCM this would compute to an actual color,
* so select the page's background color instead: */
border-color: var(--in-content-page-background);
}
#categories > .category[selected],
#categories > .category.selected {
background-color: var(--in-content-button-background-hover);
color: var(--in-content-button-text-color-hover);
border-color: var(--in-content-button-border-color-hover);
}
}
#categories[keyboard-navigation="true"]:focus-visible > .category[current],
#categories > .category:focus-visible {
outline: var(--in-content-focus-outline);
outline-offset: var(--in-content-focus-outline-inset);
}
html|*#categories[last-input-type="mouse"] > html|button.category:focus-visible {
outline: none;
}
.category-name {
font-size: 1.07em;
line-height: 1.4em;
padding-inline-start: 9px;
margin: 0;
user-select: none;
}
.category-icon {
width: 24px;
height: 24px;
-moz-context-properties: fill, fill-opacity;
fill: currentColor;
}
.category[selected] > .category-icon,
.category.selected > .category-icon {
fill-opacity: 1;
}
@media (max-width: 830px) {
:root {
--in-content-sidebar-width: 118px;
}
html|*.category:not(.category-no-icon) > html|*.category-name,
.category-icon + .category-name {
display: none;
}
#categories > .category {
padding-inline-start: 12px; /* make category icons align center */
margin-inline-end: 33px;
}
html|*#categories > html|*.category {
width: 48px;
min-width: auto;
box-sizing: border-box;
}
html|*#categories > html|*.category,
/* We need to override the full-width RTL rule, so explicitly specify RTL. */
html|*#categories > html|*.category:dir(rtl) {
background-position: center;
}
.main-content {
padding-inline: 0;
}
.pane-container {
margin-inline-end: 10px;
}
}
/* header */
.header {
margin-inline-end: 4px; /* add the 4px end-margin of other elements */
margin-bottom: 15px;
padding-bottom: 15px;
align-items: baseline;
}
.header-name {
margin: 0;
}
/* List boxes */
html|select[size][multiple],
xul|listheader,
xul|richlistbox {
appearance: none;
margin-inline: 0;
background-color: var(--in-content-box-background);
border: 1px solid var(--in-content-box-border-color);
border-radius: 4px;
color: var(--in-content-text-color);
}
xul|listheader {
border-bottom-left-radius: 0;
border-bottom-right-radius: 0;
overflow: clip; /* Clip border-radius */
}
xul|listheader + xul|richlistbox {
margin-top: 0;
border-top: none;
border-top-left-radius: 0;
border-top-right-radius: 0;
}
html|select[size][multiple] > html|option,
xul|treechildren::-moz-tree-row {
padding: 0.3em;
margin: 0;
border: none;
border-radius: 0;
background-image: none;
}
xul|treechildren::-moz-tree-row(multicol, odd) {
background-color: var(--in-content-box-background-odd);
}
html|select[size][multiple] > html|option:hover,
xul|treechildren::-moz-tree-row(hover) {
background-color: var(--in-content-item-hover);
color: var(--in-content-item-hover-text);
}
xul|richlistbox > xul|richlistitem[selected],
xul|treechildren::-moz-tree-row(selected) {
background-color: var(--in-content-item-selected);
color: var(--in-content-item-selected-text);
}
@media not (forced-colors) {
xul|richlistbox:not(#categories) > xul|richlistitem[selected] {
/* Ensure buttons/menulists inside richlistitems (containers, applications) look OK */
--in-content-button-background: color-mix(in srgb, currentColor 15%, transparent);
--in-content-button-background-hover: color-mix(in srgb, currentColor 30%, transparent);
--in-content-button-background-active: color-mix(in srgb, currentColor 45%, transparent);
--in-content-button-text-color: var(--in-content-item-selected-text);
--in-content-button-text-color-hover: var(--in-content-item-selected-text);
--in-content-button-text-color-active: var(--in-content-button-text-color-hover);
--in-content-focus-outline-color: var(--in-content-item-selected-text);
}
}
xul|richlistitem[selected] xul|menulist:focus-visible {
outline-offset: var(--in-content-focus-outline-inset);
}
/* Use a 2px border so that selected row highlight is still visible behind
an existing forced colors border that uses the background color */
@media (forced-colors) {
xul|treechildren::-moz-tree-row(selected) {
border: 2px solid currentColor;
border-radius: 4px;
}
}
xul|panel[type="autocomplete-richlistbox"] {
background-color: var(--in-content-box-background);
border: 1px solid var(--in-content-box-border-color);
color: var(--in-content-text-color);
}
/* Trees */
xul|tree {
appearance: none;
font-size: 1em;
border: 1px solid var(--in-content-box-border-color);
border-radius: 4px;
background-color: var(--in-content-box-background);
color: inherit;
margin: 0;
}
xul|treecols {
appearance: none;
border: none;
border-top-left-radius: 4px;
border-top-right-radius: 4px;
border-bottom: 1px solid var(--in-content-border-color);
overflow: clip; /* Clip border-radius */
padding: 0;
}
xul|treecol:not([hideheader="true"]),
.tree-columnpicker-button {
appearance: none;
border: none;
border-radius: unset;
background-color: var(--in-content-button-background);
color: var(--in-content-button-text-color, inherit);
padding: 5px 10px;
}
xul|treecol:not([hideheader="true"], [sortable="false"]):hover,
.tree-columnpicker-button:hover {
background-color: var(--in-content-button-background-hover);
color: var(--in-content-button-text-color-hover);
}
xul|treecol:not([hideheader="true"], [sortable="false"]):hover:active,
.tree-columnpicker-button:hover:active {
background-color: var(--in-content-button-background-active);
color: var(--in-content-button-text-color-active);
}
xul|treecol:not([hideheader="true"], :first-child),
.tree-columnpicker-button {
border-inline-start-width: 1px;
border-inline-start-style: solid;
border-image: linear-gradient(transparent 0%, transparent 20%, var(--in-content-box-border-color) 20%, var(--in-content-box-border-color) 80%, transparent 80%, transparent 100%) 1 1;
}
@media (forced-colors) {
xul|treecol:not([hideheader="true"], :first-child),
xul|treecolpicker {
--in-content-box-border-color: var(--in-content-button-border-color);
}
}
xul|treecol[sortDirection]:not([hideheader="true"]) > xul|*.treecol-sortdirection {
list-style-image: url("chrome://global/skin/icons/sort-arrow.svg");
-moz-context-properties: fill;
fill: currentColor;
width: 18px;
height: 18px;
}
xul|treecol[sortDirection="ascending"]:not([hideheader="true"]) > xul|*.treecol-sortdirection {
transform: scaleY(-1);
}
/* This is the only way to increase the height of a tree row unfortunately */
xul|treechildren::-moz-tree-row {
min-height: 2em;
}
xul|treechildren::-moz-tree-cell-text(hover),
xul|treechildren::-moz-tree-twisty(hover),
xul|treechildren::-moz-tree-image(hover) {
color: var(--in-content-item-hover-text);
}
xul|treechildren::-moz-tree-cell-text(selected),
xul|treechildren::-moz-tree-twisty(selected),
xul|treechildren::-moz-tree-image(selected) {
color: var(--in-content-item-selected-text);
}
/* Message bars */
.message-bar {
background-color: var(--in-content-box-info-background);
border-radius: 4px;
min-height: 32px;
align-items: center;
padding: 4px;
}
.message-bar-description {
margin: 2px 0;
line-height: 1.25;
}
.message-bar-description.rtl-locale {
direction: rtl;
text-align: match-parent;
}
/* The message-bar-button styles have extra specificity to override
* the defaults for buttons. */
.message-bar-content > .message-bar-button {
background-color: var(--grey-90-a10);
border: none;
border-radius: 2px;
height: 24px;
margin-inline-start: 8px;
padding: 0 8px;
}
.message-bar-content > .message-bar-button:hover {
background-color: var(--grey-90-a20);
}
.message-bar-content > .message-bar-button:hover:active {
background-color: var(--grey-90-a30);
}
.message-bar-icon {
width: 24px;
height: 24px;
padding: 4px;
margin-inline-end: 4px;
-moz-context-properties: fill;
fill: currentColor;
}
/* Warning styles */
.message-bar-warning {
background-color: var(--yellow-50);
color: var(--yellow-90);
}
.message-bar-warning > .message-bar-icon {
}
input[type="text"][warning]:enabled:not(:focus) {
border-color: var(--yellow-60);
box-shadow: 0 0 0 1px var(--yellow-60), 0 0 0 4px var(--yellow-60-a30);
}
/* Cards */
.card {
background: var(--in-content-box-background);
/* Needed for high-contrast where the border will appear. */
border: 1px solid transparent;
border-radius: 4px;
box-shadow: var(--card-shadow);
margin: 0 0 8px;
/* Remove the border from the overall padding. */
padding: calc(var(--card-padding) - 1px);
transition: box-shadow 150ms;
}
.card:not(.card-no-hover):hover {
box-shadow: var(--card-shadow-hover);
}
.card-heading-image {
border-top-left-radius: 4px;
border-top-right-radius: 4px;
margin: -16px -16px 16px;
}
.card-heading-image:dir(rtl) {
transform: scaleX(-1);
}
/* Sidebar footer links */
.sidebar-footer-list {
list-style-type: none;
margin-block: 0 36px;
margin-inline: 34px 0;
padding: 0;
}
.sidebar-footer-link {
height: 36px;
cursor: default;
border: 1px solid var(--in-content-button-border-color);
border-radius: 4px;
display: flex;
align-items: center;
}
@media (forced-colors) {
.sidebar-footer-link {
/* We need a true transparent but in HCM this would compute to an actual color,
* so select the page's background color instead: */
border-color: var(--in-content-page-background);
}
}
.sidebar-footer-link,
.sidebar-footer-link:visited {
/* Override link style for :hover and :hover:active states */
text-decoration: none !important;
color: inherit;
}
xul|*.sidebar-footer-link {
display: flex;
align-items: center;
}
.sidebar-footer-link:hover {
background-color: var(--in-content-button-background-hover);
color: var(--in-content-button-text-color-hover);
border-color: var(--in-content-button-border-color-hover);
}
.sidebar-footer-link:hover:active:not([disabled]) {
background-color: var(--in-content-button-background-active);
color: var(--in-content-button-text-color-active);
border-color: var(--in-content-button-border-color-active);
}
.sidebar-footer-link:focus-visible {
outline: var(--in-content-focus-outline);
outline-offset: var(--in-content-focus-outline-inset);
}
.sidebar-footer-icon {
-moz-context-properties: fill, fill-opacity;
fill: currentColor;
width: 16px;
height: 16px;
margin: 10px;
margin-inline-start: 13px;
}
.sidebar-footer-label {
font-size: .9em;
margin: 0 4px;
user-select: none;
}
@media (max-width: 830px) {
.sidebar-footer-list {
margin-inline-start: 40px;
align-items: flex-start;
}
.sidebar-footer-link {
width: 36px;
height: 36px;
padding-inline-start: 0;
margin-inline-start: 1px;
}
.sidebar-footer-icon {
margin-inline-start: 10px;
}
.sidebar-footer-label {
display: none;
}
}
/* Icon helper classes */
xul|*.help-icon {
list-style-image: url("chrome://global/skin/icons/help.svg");
}
xul|*.addons-icon {
}
/* Back button */
.back-button {
-moz-context-properties: fill;
fill: currentColor;
background-image: url("chrome://global/skin/icons/arrow-left.svg");
background-repeat: no-repeat;
background-position: center;
min-width: auto;
width: 32px;
margin-block: 0;
margin-inline-start: 0;
}
.back-button:-moz-locale-dir(rtl),
.back-button:dir(rtl) {
transform: scaleX(-1);
}
/* Adjust vertical margins for buttons in dialogs. We do this here because
* this sheet gets inserted into the Shadow DOM for the button box in the dialog,
* so can actually affect the button styling that way. */
:host(dialog[subdialog]) .dialog-button-box > button {
margin: 0 4px;
min-width: auto;
}