fune/browser/components/firefoxview/firefoxview.css

1052 lines
23 KiB
CSS

/* 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/. */
:host,
:root {
--content-area-padding-inline: 24px;
--content-area-padding-block: 16px;
--header-spacing: 40px;
--footer-spacing: 80px;
--success-fill-color: #2AC3A2;
--success-background-color: #87FFD1;
--success-box-text-color: #15141A;
--details-grid-column: 1;
--recently-closed-tabs-grid-row: 2;
--colorways-grid-column: 2;
--colorways-grid-row: 1 / 3;
--colorways-figure-size: 225px;
--colorways-figure-margin: 0 0 1.5em;
--colorways-grid-template-areas:
"colorways-figure"
"colorways-header"
"colorways-description"
"colorways-button";
--colorways-grid-template-columns: auto;
--colorways-grid-template-rows: auto auto auto 1fr;
--colorways-figure-display: flex;
--colorways-header-flex-direction: column;
--info-icon-background-color: #0090ED;
}
:root {
/* align the base font-size on root element with that of <body>
so rem-based layout widths and break-points behave predictably */
font-size: 15px;
/* override --in-content-page-background from common-shared.css */
background-color: transparent;
--fxview-background-color: var(--newtab-background-color, var(--in-content-page-background));
--fxview-element-background-hover: color-mix(in srgb, var(--fxview-background-color) 90%, currentColor);
--fxview-element-background-active: color-mix(in srgb, var(--fxview-background-color) 80%, currentColor);
--fxview-text-primary-color: var(--newtab-text-primary-color, var(--in-content-page-color));
--fxview-text-color-hover: var(--newtab-text-primary-color);
--fxview-contrast-border: color-mix(in hsl, currentColor 45%, transparent);
--fxview-extra-contrast-border: color-mix(in hsl, currentColor 85%, transparent);
--in-content-zap-gradient: linear-gradient(var(--fxview-extra-contrast-border), var(--fxview-extra-contrast-border));
--card-border-zap-gradient: var(--in-content-zap-gradient);
--fxview-text-secondary-color: color-mix(in srgb, currentColor 70%, transparent);
--newtab-background-color-secondary: #FFF;
/* ensure utility button hover states match those of the rest of the page */
--in-content-button-background-hover: var(--fxview-element-background-hover);
--in-content-button-background-active: var(--fxview-element-background-active);
--in-content-button-text-color-hover: var(--fxview-text-color-hover);
}
body {
display: flex;
justify-content: center;
padding-block: var(--header-spacing) var(--footer-spacing);
padding-inline: var(--content-area-padding-inline);
max-width: 96rem;
margin-inline: auto;
background-color: var(--fxview-background-color);
color: var(--newtab-text-primary-color);
}
:root:not([lwt-newtab]) {
--in-content-zap-gradient: linear-gradient(90deg, #9059FF 0%, #FF4AA2 52.08%, #FFBD4F 100%);
}
@media (prefers-color-scheme: dark) {
:root {
--fxview-element-background-hover: color-mix(in srgb, var(--fxview-background-color) 80%, white);
--fxview-element-background-active: color-mix(in srgb, var(--fxview-background-color) 60%, white);
--newtab-background-color-secondary: #42414d;
}
}
@media (prefers-contrast) {
:root {
--fxview-element-background-hover: ButtonText;
--fxview-element-background-active: ButtonText;
--fxview-text-color-hover: ButtonFace;
--fxview-text-secondary-color: currentColor;
}
}
h1 {
color: var(--fxview-text-primary-color);
font-weight: 600;
font-size: 1.5em;
}
.content-container {
padding-inline: var(--content-area-padding-inline);
padding-block: var(--content-area-padding-block);
}
#logo-container {
flex: 0 0 auto;
}
body > main {
flex: 1 1 auto;
display: grid;
grid-template-columns: 2fr 1fr;
grid-template-rows: max-content 1fr;
}
body > main > details {
grid-column: var(--details-grid-column);
}
@media (max-width: 76rem) {
:host,
:root {
--content-area-padding-inline: 12px;
}
.brand-logo > .brand-feature-name {
display: none;
}
}
@media (max-width: 65rem) {
:root {
--recently-closed-tabs-grid-row: 3;
--details-grid-column: 1 / -1;
--colorways-grid-column: 1 / -1;
--colorways-grid-row: 2;
--colorways-grid-template-areas:
"colorways-header colorways-figure"
"colorways-description colorways-figure"
"colorways-button colorways-figure";
--colorways-grid-template-columns: 1fr var(--colorways-figure-size);
--colorways-grid-template-rows: min-content min-content 1fr;
--colorways-header-flex-direction: row;
--colorways-figure-margin: 0;
}
}
@media (max-width: 45rem) {
:host,
:root {
--header-spacing: 16px;
--footer-spacing: 16px;
--colorways-grid-template-areas:
"colorways-header"
"colorways-description"
"colorways-button";
--colorways-grid-template-columns: auto;
--colorways-grid-template-rows: auto;
--colorways-figure-display: none;
--colorways-header-flex-direction: column;
}
}
@media (max-width: 28rem) {
body {
flex-wrap: wrap;
}
}
.brand-logo {
display: flex;
justify-content: space-between;
align-items: center;
font-size: 1.75em;
white-space: nowrap;
}
.brand-logo > .brand-icon {
display: inline-block;
background: url("chrome://branding/content/about-logo.png") no-repeat center;
background-size: 32px;
min-width: 40px;
height: 32px;
}
.brand-logo > .brand-feature-name {
margin-inline-start: 8px;
flex: 1 1 auto;
font-weight: 600;
}
#colorways:not([hidden]) {
display: grid;
grid-column: var(--colorways-grid-column);
grid-row: var(--colorways-grid-row);
grid-template-areas: var(--colorways-grid-template-areas);
grid-template-columns: var(--colorways-grid-template-columns);
grid-template-rows: var(--colorways-grid-template-rows);
justify-items: start;
align-items: start;
padding-inline: calc(2 * var(--content-area-padding-inline));
padding-block: calc(2 * var(--content-area-padding-block));
}
#colorways > header {
grid-area: colorways-header;
display: flex;
flex-direction: var(--colorways-header-flex-direction);
align-items: flex-start;
flex-wrap: wrap;
}
#colorways-collection-description {
grid-area: colorways-description;
}
#colorways-collection-description,
#colorways-button {
margin: 0.4em 0;
}
#colorways-button {
grid-area: colorways-button;
}
#colorways-collection-title {
margin: 0;
margin-top: 0.3em;
margin-inline-end: 0.5em;
padding: 0;
}
#colorways-collection-expiry-date {
display: inline-block;
background: var(--card-border-zap-gradient);
background-origin: border-box;
border: 1px solid transparent;
border-radius: 1.5em;
margin: 0.8em 0;
}
#colorways-collection-expiry-date > span {
display: inline-block;
background: var(--fxview-background-color);
border-radius: 1.5em;
padding: .3em 1em;
}
#colorways > figure {
display: var(--colorways-figure-display);
grid-area: colorways-figure;
align-items: center;
justify-content: center;
width: var(--colorways-figure-size);
height: var(--colorways-figure-size);
margin: var(--colorways-figure-margin);
}
#colorways-collection-figure {
max-width: var(--colorways-figure-size);
max-height: var(--colorways-figure-size);
object-fit: scale-down;
}
[hidden] {
display: none !important;
}
button.ghost-button,
button.ghost-button:not(.semi-transparent):enabled:is(:hover, :active) {
color: inherit;
}
@media (prefers-contrast) {
button.ghost-button:not(.semi-transparent):enabled:is(:hover, :active) {
background-color: ButtonText;
color: ButtonFace;
}
}
button.primary {
white-space: nowrap;
min-width: fit-content;
}
button.close {
background-image: url(chrome://global/skin/icons/close.svg);
-moz-context-properties: fill;
fill: currentColor;
}
.card,
.synced-tab-a,
.synced-tab-li-placeholder,
.empty-container {
background-color: var(--newtab-background-color-secondary);
border: 1px solid var(--fxview-contrast-border);
}
#collapsible-tabs-container,
#tabpickup-tabs-container {
margin-block-start: 0.5em;
}
.empty-container {
border-radius: 4px;
}
.error-state {
text-align: center;
padding-block: 0 1.3em;
padding-inline: 1em;
border: 1px solid var(--fxview-contrast-border);
border-radius: 4px;
}
.error-state > h3 {
font-weight: 600;
display: inline-block;
margin-bottom: 0;
}
.placeholder-content {
color: var(--fxview-text-secondary-color);
display: flex;
padding: 1.8em 1.1em;
}
#recently-closed-empty-image,
#tab-pickup-empty-image {
margin-inline-end: 1.1em;
-moz-context-properties: fill, stroke, fill-opacity;
fill: var(--fxview-background-color);
stroke: var(--fxview-text-primary-color);
fill-opacity: 0.07;
}
@media (prefers-color-scheme: dark) {
#recently-closed-empty-image,
#tab-pickup-empty-image {
fill: var(--newtab-background-color-secondary);
fill-opacity: 0.15;
}
}
.placeholder-text {
margin: 0;
}
.placeholder-header {
margin-block: 0 0.27em;
font-weight: 600;
}
.placeholder-body {
margin-block: 0;
line-height: 1.3em;
}
.page-section-header {
column-gap: 16px;
cursor: pointer;
display: grid;
grid-template-columns: auto 1fr;
grid-template-rows: 1fr auto;
grid-template-areas:
"twisty head"
"none desc";
list-style-type: none;
position: relative;
z-index: 1;
}
@media (prefers-contrast) {
.page-section-header {
color: WindowText;
}
.page-section-header:focus-visible {
box-shadow: none;
outline: var(--in-content-focus-outline);
outline-offset: var(--in-content-focus-outline-offset);
}
}
.page-section-header > h1 {
grid-area: head;
margin: 0;
padding-block: 4px;
}
/* the twisty is just an ornament; the whole summary parent node is clickable */
.page-section-header > .twisty {
background-image: url("chrome://global/skin/icons/arrow-right.svg");
display: inline-block;
grid-area: twisty;
align-self: center;
justify-self: start;
padding-block: 4px;
padding-inline: 8px;
fill: currentColor;
border-radius: 4px;
margin-block: 0;
}
[dir="rtl"] .page-section-header > .twisty {
background-image: url("chrome://global/skin/icons/arrow-left.svg");
}
@media (prefers-contrast) {
.page-section-header > .twisty {
border: 1px solid ButtonText;
}
}
details[open] > .page-section-header > .twisty {
background-image: url("chrome://global/skin/icons/arrow-down.svg");
}
.page-section-header:hover > .twisty {
background-color: var(--fxview-element-background-hover);
color: var(--fxview-text-color-hover);
}
.page-section-header:hover:active > .twisty {
background-color: var(--fxview-element-background-active);
}
.page-section-header > .section-description {
grid-area: desc;
margin-block: 4px 8px;
font-weight: inherit;
font-size: inherit;
line-height: inherit;
}
.card-body {
display: flex;
flex-grow: 1;
align-content: space-between;
align-items: center;
gap: 8px;
}
@media only screen and (max-width: 45rem) {
.card-body {
flex-wrap: wrap;
}
}
.card-body > button.primary {
margin-inline-start: 0;
z-index: 1;
}
.card-body > .step-content,
.zap-card > button.close {
z-index: 1;
}
.setup-step {
padding: var(--card-padding);
margin-block: 0.5em 1em;
}
/* Bug 1770534 - Only use the zap-gradient for built-in, color-neutral themes */
.zap-card {
border: none;
position: relative;
}
.zap-card::before {
content: "";
position: absolute;
inset: 0;
border: 1px solid transparent;
border-radius: 4px;
background-origin: border-box;
background-image: var(--card-border-zap-gradient);
mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
mask-composite: exclude;
}
.setup-step > h2 {
margin-block: 0 8px;
}
.setup-step > .card-body {
margin-block: 8px;
padding-block: 8px;
}
.setup-step > .card-body > .step-content {
flex: 1 1 auto;
}
.setup-step > footer {
display: flex;
flex-direction: column;
margin-block: 0 8px;
}
.step-progress {
background-color: #E0E0E6;
border-radius: 8px;
border-style: none;
height: 8px;
margin-block: 0 8px;
margin-inline: 0 2px;
}
.step-progress::-moz-progress-bar {
background-color: var(--success-fill-color);
border-radius: 8px;
}
@media (prefers-contrast) {
.step-progress {
background-color: SelectedItemText;
border: 1px solid SelectedItem;
}
.step-progress::-moz-progress-bar {
background-color: SelectedItem;
}
}
.message-box {
display: flex;
align-items: center;
margin-block: 8px;
gap: 8px;
}
.message-content {
flex: 1 1 auto;
}
.message-content > .message-header {
font-size: 1em;
margin-block: 0 0.33em;
}
.message-content > .message-description {
margin-block: 0 0.33em;
}
.confirmation-message-box {
background-color: var(--success-background-color);
color: var(--success-box-text-color);
border-color: var(--success-fill-color);
}
.confirmation-message-box > .message-content {
text-align: center;
}
.confirmation-message-box > .message-content > .message-header {
font-size: inherit;
display: inline;
}
/* ensure we get the local color values as container doesnt change color with theme */
.confirmation-message-box > .icon-button {
color: inherit;
}
.confirmation-message-box > button.icon-button:enabled:is(:hover, :active) {
background-color: color-mix(in srgb, var(--success-background-color) 90%, currentColor);
}
@media (prefers-contrast) {
.confirmation-message-box > button.icon-button {
border-color: ButtonText;
}
.confirmation-message-box > button.icon-button:enabled:is(:hover, :active) {
background-color: ButtonText;
color: ButtonFace;
}
}
#tab-pickup-container {
grid-row: 1;
}
/* 117px is the total height of the collapsible-tabs-container; setting that size
for the second row stabilizes the layout so it doesn't shift when collapsibled */
#recently-closed-tabs-container {
grid-row: var(--recently-closed-tabs-grid-row);
display: grid;
grid-template-rows: max-content 117px;
}
#recently-closed-tabs-container > p {
margin-top: 0;
}
.synced-tabs-container.loading > .card,
.synced-tabs-container.loading > tab-pickup-list,
.synced-tabs-container.loading > .placeholder-content,
.synced-tabs-container:not(.loading) > .loading-content {
display: none;
}
.synced-tabs-container > .loading-content {
text-align: center;
color: var(--fxview-text-secondary-color);
margin-top: 40px;
padding: 20px 16px 16px;
}
.closed-tabs-list {
padding-inline-start: 0;
margin-block-start: 0;
display: grid;
grid-template-columns: min-content repeat(5, 1fr) repeat(2, min-content);
column-gap: 8px;
row-gap: 8px;
}
.closed-tab-li {
display: grid;
grid-template-columns: subgrid;
grid-column: span 8;
margin-block-end: 0.5em;
border-radius: 4px;
align-items: center;
}
.closed-tab-li-main {
display: grid;
grid-template-columns: subgrid;
grid-column: span 7;
padding: 0.5em;
cursor: pointer;
align-items: center;
user-select: none;
border-radius: 4px;
}
@media (prefers-contrast) {
.closed-tab-li-main,
.closed-tab-li-dismiss {
color: ButtonText;
border-radius: 4px;
border: 1px solid ButtonText;
}
}
@media not (prefers-contrast) {
.closed-tab-li-main:hover {
background-color: var(--fxview-element-background-hover);
color: var(--fxview-text-color-hover);
}
}
.closed-tab-li-main:hover .closed-tab-li-title {
text-decoration-line: underline;
}
.closed-tab-li-main:active {
background-color: var(--fxview-element-background-active);
color: var(--fxview-text-color-hover);
}
.closed-tab-li-main:focus-visible {
box-shadow: none;
outline: var(--in-content-focus-outline);
outline-offset: var(--in-content-focus-outline-offset);
border-radius: 4px;
}
.closed-tab-li-title {
padding-inline-start: 10px;
font-weight: 500;
grid-column: span 3;
}
.closed-tab-li-url {
padding-inline-start: 8px;
text-decoration-line: underline;
grid-column: span 2;
}
.closed-tab-li-time {
white-space: nowrap;
text-align: end;
}
.closed-tab-li-dismiss {
background-image: url("chrome://global/skin/icons/close.svg");
background-repeat: no-repeat;
background-position: center;
background-color: transparent;
color: var(--fxview-text-secondary-color);
-moz-context-properties: fill;
fill: var(--fxview-text-secondary-color);
min-width: 33px;
padding: 0.5em;
margin: 0;
cursor: pointer;
user-select: none;
}
.closed-tab-li-dismiss:hover {
background-color: var(--in-content-button-background-hover);
fill: var(--in-content-button-text-color-hover);
}
.tab-link,
.tab-link:hover,
.tab-link:active,
.tab-link:hover:active,
.tab-link:visited {
color: inherit;
text-decoration: none;
}
@media (prefers-contrast) {
.tab-link {
border-color: FieldText;
}
.tab-link,
.tab-link:hover,
.tab-link:active,
.tab-link:hover:active,
.tab-link:visited {
color: LinkText;
}
}
.closed-tab-li-url,
.closed-tab-li-time,
.synced-tab-li-device,
.synced-tab-li-url,
.synced-tab-li-time {
font-weight: 400;
color: var(--fxview-text-secondary-color);
}
.closed-tab-li-title,
.closed-tab-li-url,
.synced-tab-li:not(:first-child) > .synced-tab-a > .synced-tab-li-title,
.synced-tab-li-device {
overflow: hidden;
}
.closed-tab-li-title,
.synced-tab-li:not(:first-child) > .synced-tab-a > .synced-tab-li-title,
.synced-tab-li-device {
text-overflow: ellipsis;
white-space: nowrap;
}
.synced-tab-li-url,
.closed-tab-li-url {
word-break: break-word;
}
.synced-tabs-list {
padding: 0;
margin-block-start: 0;
list-style: none;
display: grid;
grid-template-columns: 4fr 4fr;
column-gap: 16px;
row-gap: 8px;
grid-template-areas:
"first second"
"first third";
}
@media only screen and (max-width: 43rem) {
.synced-tabs-list {
grid-template-columns: 1fr;
grid-template-areas:
"first"
"second"
"third";
}
body {
flex-flow: column;
}
#logo-container .brand-logo {
justify-content: center;
}
}
.synced-tab-a,
.synced-tab-li-placeholder {
box-sizing: border-box;
border-radius: 4px;
padding: 7px;
display: grid;
column-gap: 8px;
row-gap: 2px;
align-items: center;
grid-template-columns: min-content repeat(2, 1fr) minmax(min-content, auto);
grid-template-rows: auto 1fr auto;
grid-template-areas:
"favicon title title title"
"favicon domain domain domain"
"favicon device device time";
height: 100%;
}
.synced-tab-a:hover {
box-shadow: 0px 2px 14px var(--fxview-contrast-border);
}
.synced-tab-li:not(:first-child) > .synced-tab-a {
align-content: center;
}
@media only screen and (max-width: 60rem) {
.synced-tab-li > .synced-tab-a,
.synced-tab-li-placeholder {
grid-template-areas:
"favicon title title title"
"favicon domain domain domain"
"favicon device device device";
}
.synced-tab-li:not(:first-child) > .synced-tab-a > .synced-tab-li-time {
display: none;
}
}
.synced-tab-li-placeholder {
row-gap: 1em;
grid-template-areas:
"favicon title title title"
"favicon domain domain domain";
grid-template-rows: auto auto;
}
.li-placeholder-favicon {
grid-area: favicon;
align-self: start;
width: 16px;
height: 16px;
}
.li-placeholder-title {
grid-area: title;
height: .8em;
margin-block: .1em; /* simulate line-height */
width: 100%;
}
.li-placeholder-domain {
grid-area: domain;
height: .6em;
margin-block: .1em; /* simulate line-height */
width: 100%;
}
.li-placeholder-favicon,
.li-placeholder-title,
.li-placeholder-domain {
display: inline-block;
background-color: currentColor; opacity: 0.08;
border-radius: 4px;
}
.synced-tab-li:first-child {
grid-area: first;
}
.synced-tab-li:first-child > .synced-tab-a {
padding: 15px;
grid-template-columns: repeat(4, 1fr);
grid-template-rows: auto auto 1fr auto;
grid-template-areas:
"favicon badge badge badge"
"title title title title"
"domain domain domain domain"
"device device device time";
row-gap: 4px;
}
.synced-tab-li:nth-child(2) {
grid-area: second;
}
.synced-tab-li:nth-child(3) {
grid-area: third;
}
.synced-tab-li-url,
.synced-tab-li-device,
.synced-tab-li:not(:first-child) > .synced-tab-a > .synced-tab-li-title {
font-size: .85em;
}
.synced-tab-li-time {
font-size: .75em;
}
.synced-tab-li-url {
text-decoration-line: underline;
grid-area: domain;
align-self: start;
}
.synced-tab-li-title {
grid-area: title;
font-weight: 500;
}
.synced-tab-li:first-child > .synced-tab-a > .synced-tab-li-title {
color: inherit;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
align-self: start;
}
.synced-tab-li-device {
grid-area: device;
}
.synced-tab-li-time {
grid-area: time;
justify-self: end;
align-self: end;
white-space: nowrap;
}
.synced-tab-li:first-child > .synced-tab-a > .synced-tab-li-time {
align-self: center;
}
.synced-tab-li .favicon {
grid-area: favicon;
align-self: start;
}
@media (prefers-contrast) {
.synced-tab-li .favicon {
color: LinkText;
}
}
.synced-tab-li .icon {
vertical-align: bottom;
margin-inline-end: 5px;
}
.icon {
background-position: center center;
background-repeat: no-repeat;
display: inline-block;
-moz-context-properties: fill;
fill: currentColor;
}
.history {
background-image: url('chrome://browser/skin/history.svg');
}
.phone {
background-image: url('chrome://browser/skin/device-phone.svg');
}
.desktop {
background-image: url('chrome://browser/skin/device-desktop.svg');
}
.tablet {
background-image: url('chrome://browser/skin/device-tablet.svg');
}
.synced-tabs {
background-image: url('chrome://browser/skin/synced-tabs.svg');
}
.info {
background-image: url('chrome://global/skin/icons/info-filled.svg');
}
.error-state > .info {
vertical-align: text-top;
margin-inline-end: 7px;
margin-top: 1px;
color: var(--info-icon-background-color);
}
.favicon {
background-size: cover;
-moz-context-properties: fill;
fill: currentColor;
}
.favicon, .icon, .synced-tab-li-favicon {
width: 16px;
height: 16px;
}
.sync {
background-image: url(chrome://browser/skin/sync.svg);
background-size: cover;
height: 19px;
width: 19px;
color: var(--fxview-text-secondary-color);
}
@keyframes syncRotate {
from { transform: rotate(0); }
to { transform: rotate(360deg); }
}
@media (prefers-reduced-motion: no-preference) {
.sync {
animation: syncRotate 0.8s linear infinite;
}
}
.last-active-badge {
height: 1.25em;
background-color: #E3FFF3;
grid-area: badge;
border-radius: 2em;
justify-self: end;
text-align: center;
padding: 0.3em 1em;
font-size: 0.75em;
}
.synced-tab-li:not(:first-child) .last-active-badge {
display: none;
}
.dot {
height: 8px;
width: 8px;
background-color: var(--success-fill-color);
border-radius: 50%;
display: inline-block;
}
.badge-text {
font-weight: 400;
letter-spacing: 0.02em;
margin-inline-start: 4px;
color: #000000;
}
@media (prefers-contrast) {
.last-active-badge {
border: 1px solid CanvasText;
background-color: Canvas;
}
.dot {
background-color: FieldText;
}
.badge-text {
color: FieldText;
}
}