Source code

Revision control

Copy as Markdown

Other Tools

@use 'sass:math';
$primary-blue: rgb(0, 97, 224);
$primary-green: rgb(0, 128, 120);
$primary-blue-dark: rgb(0, 221, 255);
$primary-text-color-dark: rgb(43, 42, 51);
// -------------------------------------------------------------------------- //
$blue-40: #45A1FF;
$blue-50: #0A84FF;
$grey-30: #D7D7DB;
$grey-60: #4A4A4F;
$grey-90: #0C0C0D;
$red-60: #D70022;
$yellow-50: #FFE900;
$grey-90-10: rgba($grey-90, 0.1);
$grey-90-20: rgba($grey-90, 0.2);
$blue-40-40: rgba($blue-40, 0.4);
$blue-50-30: rgba($blue-50, 0.3);
$black: #000;
$black-10: rgba($black, 0.1);
$black-15: rgba($black, 0.15);
$black-20: rgba($black, 0.2);
$black-30: rgba($black, 0.3);
$black-40: rgba($black, 0.4);
// -------------------------------------------------------------------------- //
// Other colors
$white: #FFF;
$status-green: #058B00;
$status-dark-green: #7C6;
$bookmark-icon-fill: #0A84FF;
$download-icon-fill: #12BC00;
$pocket-icon-fill: #EF4056;
$email-input-invalid: rgba($red-60, 0.3);
$newtab-wordmark-default-color: #20123A;
$newtab-wordmark-darktheme-color: rgb(251, 251, 254);
$in-content-page-color: rgb(21, 20, 26);
$in-content-page-color-dark: rgb(251, 251, 254);
// -------------------------------------------------------------------------- //
// These colors should match the colors in the default themes
// (toolkit/mozapps/extensions/...). Note that they could get replaced by other
// themes. The color set in --tabpanel-background-color (tabs.inc.css) should
// match these colors here to avoid flashing.
$in-content-page-background: #F9F9FB;
$in-content-page-background-dark: #2B2A33;
$newtab-background-secondary: #FFF;
$newtab-background-secondary-dark: rgb(66, 65, 77);
// Mirrors $newtab-background-secondary with 20% opacity
$newtab-background-card: rgba(255, 255, 255, 80%);
$newtab-background-card-dark: rgb(66, 65, 77, 80%);
$photon-easing: cubic-bezier(0.07, 0.95, 0, 1);
$border-radius: 3px;
$border-radius-new: 8px;
// Grid related styles
$base-gutter: 32px;
$section-horizontal-padding: 25px;
$section-vertical-padding: 10px;
$section-spacing: 40px - $section-vertical-padding * 2;
$grid-unit: 96px; // 1 top site
// New Tab Experience grid unit needs to be smaller, but for now we are changing
// this UI with a pref, so requires duplication.
$grid-unit-small: 80px; // 1 top site
$icon-size: 16px;
$smaller-icon-size: 12px;
$larger-icon-size: 32px;
$searchbar-width-small: ($grid-unit * 2 + $base-gutter * 1) - 24px; // 200px
$searchbar-width-medium: ($grid-unit * 4 + $base-gutter * 3) - 120px; // 360px
$searchbar-width-large: ($grid-unit * 6 + $base-gutter * 5) - 136px; // 600px
$searchbar-width-largest: ($grid-unit * 6 + $base-gutter * 5) - 16px; // 720px
$wrapper-default-width: $grid-unit * 2 + $base-gutter * 1 + $section-horizontal-padding * 2; // 2 top sites
$wrapper-max-width-medium: $grid-unit * 4 + $base-gutter * 3 + $section-horizontal-padding * 2; // 4 top sites
$wrapper-max-width-large: $grid-unit * 6 + $base-gutter * 5 + $section-horizontal-padding * 2; // 6 top sites
$wrapper-max-width-widest: $grid-unit * 8 + $base-gutter * 7 + $section-horizontal-padding * 2; // 8 top sites
$wrapper-max-width-weather: $grid-unit * 12 + $base-gutter * 7 + $section-horizontal-padding * 2; // Weather visible
$wrapper-max-width-ultra-wide: $grid-unit * 14 + $base-gutter * 7 + $section-horizontal-padding * 2; // 8 top sites 4 stories
// For the breakpoints, we need to add space for the scrollbar to avoid weird
// layout issues when the scrollbar is visible. 16px is wide enough to cover all
// OSes and keeps it simpler than a per-OS value.
$scrollbar-width: 16px;
// Breakpoints
// If updating these breakpoints, don't forget to update uses of DSImage, which
// might choose the right image src to use depending on the viewport size.
$break-point-small: 510px;
$break-point-medium: $wrapper-max-width-medium + $base-gutter * 2 + $scrollbar-width; // 610px
// A temporary breakpoint for a new layout experiment.
$break-point-layout-variant: 724px;
$break-point-large: $wrapper-max-width-large + $base-gutter * 2 + $scrollbar-width; // 866px
$break-point-widest: $wrapper-max-width-widest + $base-gutter * 2 + $scrollbar-width; // 1122px
// temporary breakpoint for sections experiment
$break-point-sections-variant: 1310px + $base-gutter * 2 + $scrollbar-width;
$break-point-weather: $wrapper-max-width-weather + $base-gutter * 2 + $scrollbar-width; // 1506px
$break-point-ultra-wide: $wrapper-max-width-ultra-wide + $base-gutter * 2 + $scrollbar-width; // 1698px
$section-title-font-size: 17px;
$card-width: $grid-unit-small * 2 + $base-gutter;
$card-height: 266px;
$card-preview-image-height: 122px;
$card-title-margin: 2px;
$card-text-line-height: 19px;
// Larger cards for wider screens:
$card-width-large: 309px;
$card-height-large: 370px;
$card-preview-image-height-large: 155px;
// Compact cards for Highlights
$card-height-compact: 160px;
$card-preview-image-height-compact: 108px;
$topic-margin-top: 12px;
$context-menu-button-size: 27px;
$context-menu-button-boxshadow: 0 2px $grey-90-10;
$context-menu-shadow: 0 5px 10px $black-30, 0 0 0 1px $black-20;
$context-menu-font-size: 14px;
$context-menu-border-radius: 5px;
$context-menu-outer-padding: 5px;
$context-menu-item-padding: 3px 12px;
$error-fallback-font-size: 12px;
$error-fallback-line-height: 1.5;
$textbox-shadow-size: 4px;
$customize-menu-slide-bezier: cubic-bezier(0.46, 0.03, 0.52, 0.96);
$customize-menu-expand-bezier: cubic-bezier(0.82, 0.085, 0.395, 0.895);
$customize-menu-border-tint: 1px solid rgba(0, 0, 0, 15%);
@mixin fade-in {
box-shadow: inset $inner-box-shadow, $shadow-primary;
transition: box-shadow 150ms;
}
@mixin fade-in-card {
box-shadow: $shadow-primary;
transition: box-shadow 150ms;
}
@mixin ds-focus {
border: 0;
outline: var(--focus-outline);
}
@mixin context-menu-button {
.context-menu-button {
background-clip: padding-box;
background-color: var(--newtab-button-background);
background-image: url('chrome://global/skin/icons/more.svg');
background-position: 50.1%;
border: 0;
outline: $border-primary;
outline-width: 0;
border-radius: 100%;
box-shadow: $context-menu-button-boxshadow;
cursor: pointer;
color: var(--button-text-color);
fill: var(--newtab-button-text);
height: $context-menu-button-size;
inset-inline-end: math.div(-$context-menu-button-size, 2);
opacity: 0;
position: absolute;
top: math.div(-$context-menu-button-size, 2);
transform: scale(0.25);
transition-duration: 150ms;
transition-property: transform, opacity;
width: $context-menu-button-size;
&:is(:active, :focus-visible, :hover) {
opacity: 1;
transform: scale(1);
}
&:is(:hover) {
background-color: var(--newtab-button-hover-background);
}
&:is(:focus-visible) {
outline-color: var(--newtab-button-focus-border);
background-color: var(--newtab-button-focus-background);
outline-width: 4px;
}
&:is(:active) {
background-color: var(--newtab-button-active-background);
}
}
}
@mixin context-menu-button-hover {
.context-menu-button {
opacity: 1;
transform: scale(1);
transition-delay: 333ms;
}
}
@mixin context-menu-open-middle {
.context-menu {
margin-inline-end: auto;
margin-inline-start: auto;
inset-inline-end: auto;
inset-inline-start: -$base-gutter;
}
}
@mixin context-menu-open-left {
.context-menu {
margin-inline-end: 5px;
margin-inline-start: auto;
inset-inline-end: 0;
inset-inline-start: auto;
}
}
@mixin flip-icon {
&:dir(rtl) {
transform: scaleX(-1);
}
}