$frontpage-content-breakpoint: 42rem;
html.front-page {
> body {
@supports (display: grid) {
display: grid;
grid-template-rows: auto auto 1fr;
}
}
.masthead {
margin-block-end: 0;
a {
color: white;
}
}
.page-content {
padding-block-start: 4rem;
> .wrapper {
display: grid;
grid-template-columns: 1fr minmax(auto, 65rem) 1fr;
margin: 0;
padding: 0 1.5rem;
max-width: 100%;
--grid-column: 2;
> * {
grid-column: var(--grid-column);
}
}
}
.frontpage-background {
background: var(--color-masthead-background) url(../images/site/clouds-bw.webp);
background-blend-mode: screen;
background-size: cover;
background-repeat: no-repeat;
background-position: bottom;
backdrop-filter: blur(3px);
> header.masthead {
background: var(--gradient-masthead-shine);
}
}
.intro-lede {
max-width: 24em;
padding: 2rem 8rem 0 1rem;
grid-area: lede;
font-size: 1.5rem;
@media (min-width: $on-laptop) {
padding: 4rem 0 3rem 4rem;
font-size: 1.75rem;
}
}
.intro {
--remainder: calc((100vw - 65rem) / 2);
--offset: 1rem;
font-family: var(--font-headline);
line-height: 1.4;
color: #eeeeec;
display: grid;
grid-template: ". lede planes ." "badge badge badge badge";
grid-template-columns: var(--remainder) auto 1fr var(--remainder);
padding: 0;
.planes {
--planes-height: 5rem;
--planes-offset: 2.5rem;
grid-area: planes;
background: url(../images/site/planes.svg) no-repeat right calc(100% - var(--planes-offset));
background-size: auto var(--planes-height);
grid-row: 1 / -1;
grid-column: 1 / -2;
margin-inline-end: 1rem;
@media screen and (min-width: $content-width) {
margin-inline-end: 0;
}
}
@supports (clip-path: polygon(0 0, 0 0, 0 0, 0 0)) or (-webkit-clip-path: polygon(0 0, 0 0, 0 0, 0 0)) {}
.side-left {
padding: 3rem 1rem 1rem;
text-align: center;
@media screen and (min-width: $content-width) {
padding: 1rem;
p {
max-width: 35ex;
}
}
}
.intro-image {
position: relative;
margin-block-start: 2rem;
.screenshot {
margin: 0.5rem 0 0;
max-height: 12rem;
overflow: hidden;
display: block;
}
&:before {
z-index: 100;
content: "";
position: absolute;
width: 100%;
height: 100%;
box-shadow: inset 0px -20px 15px -15px rgba(0, 0, 0, 0.2);
pointer-events: none;
}
}
p:first-child:last-child {
margin: 0 0.5rem;
}
.grid > div {
padding-bottom: 0;
}
ul, li {
margin: 0;
padding: 0;
list-style: none;
display: inline;
}
%btn {
display: inline-block;
background: #eeeeec;
border-radius: 6px;
box-shadow: 0 3px 0 rgba(46, 61, 86, 1);
color: #3e5375;
font-size: 18px;
line-height: 1.33;
margin: 10px 10px 20px 0px;
padding: 10px 16px;
&:hover {
text-decoration: none;
background: var(--color-background);
color: var(--color-text);
}
}
li a {
@extend %btn;
}
li.with-img img {
vertical-align: top;
margin: (-1px) 2px 0 0;
}
}
.intro-text {
padding: 0 0 2rem;
h2 {
font-size: 2rem;
&:not(:first-child) {
padding-block-start: 2rem;
}
}
h3 {
font-size: 1.5rem;
&:not(:first-child) {
padding-block-start: 1.5rem;
}
}
@media (min-width: $on-laptop) {
h2 {
font-size: 2.953125rem;
&:not(:first-child) {
padding-block-start: 2.5rem;
}
}
h3 {
font-size: 1.828125rem;
&:not(:first-child) {
padding-block-start: 2rem;
}
}
}
.audience-list {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
grid-gap: 1rem 2rem;
padding: 0.5rem 1rem;
strong {
display: block;
}
@media (max-width: 32rem) {
grid-template-columns: auto;
}
}
.using-cockpit {
columns: 20rem 2;
column-gap: 2rem;
}
}
footer.footer-cockpit {
margin-block-start: 0;
}
.badge {
grid-area: badge;
text-align: right;
position: relative;
inset-block-start: var(--offset);
&-new,
&-version,
&-date {
transition: all 300ms;
font-size: 0.9rem;
@media (prefers-reduced-motion: reduce) {
transition: none;
}
}
&-new {
font-weight: inherit;
}
&-version {
font-size: 1.4rem;
font-weight: bold;
color: var(--color-link);
}
a {
--offset1: var(--offset);
--offset2: var(--offset);
transition: background 500ms, clip-path 500ms;
// Badge color is defined with the other colors in site.scss
background: var(--color-badge);
display: block;
padding: 1.5rem 0 1.25rem;
padding: calc((var(--offset) + 0.5vw) * 1.125) 1rem calc((var(--offset) + 0.25vw) * 1);
text-decoration: none !important;
color: var(--color-text);
clip-path: polygon(0 calc(100% - var(--offset1)), 0 calc(100% - var(--offset2)), 100% 100%, 100% 0);
display: grid;
grid-template-columns: 1fr auto var(--remainder);
grid-template-rows: 33%;
align-items: baseline;
grid-gap: 0 0.5rem;
@media (prefers-reduced-motion: reduce) {
transition: none;
}
@media (max-width: $frontpage-content-breakpoint) {
--offset1: calc(100% - 1.5rem);
--offset2: 0.5rem;
}
&:hover {
background: var(--color-badge-hover);
> span {
opacity: 1;
}
> .badge-version {
text-decoration: underline;
}
}
}
}
}
.distro-logos {
display: grid;
align-items: center;
grid-gap: 2.5rem 5rem;
grid-template-columns: repeat(auto-fit, minmax(7rem, 1fr));
margin: 3rem 2rem 4rem;
> li {
margin: 0;
padding: 0;
flex: 1 1 12rem;
list-style: none;
> a {
filter: grayscale(1) contrast(50%) brightness(125%);
transition: 300ms all;
@media (prefers-reduced-motion: reduce) {
transition: none;
}
&:hover {
opacity: 1;
filter: grayscale(0);
}
}
}
img {
max-height: 3rem;
max-width: 100%;
}
}
.footerlinks {
background: var(--color-grey-light);
padding: 2rem 0;
margin: 4rem 0 2rem;
clip-path: polygon(0 32px, 0 calc(100% - 32px), 100% 100%, 100% 0);
display: grid;
grid-template-columns: repeat(auto-fit, minmax(auto, calc(var(--content-width) / 3)));
justify-content: center;
align-items: center;
dl a,
dt {
padding: 5px 20px;
}
dt {
font-weight: bold;
a {
margin: (-5px) -20px;
}
}
dd {
a {
padding-inline-start: 30px;
}
}
@extend %link;
}
.screenshots {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));
align-items: center;
&:hover {
> .screenshot {
transition: opacity 100ms ease-in-out;
@media (prefers-reduced-motion: reduce) {
transition: none;
}
}
> :not(:hover) {
opacity: 0.75;
transition-duration: 200ms;
@media (prefers-reduced-motion: reduce) {
transition: none;
}
}
}
> .screenshot {
opacity: 1;
margin: 0.5rem;
box-shadow: none;
&, > img {
transition: all 100ms ease-in-out;
@media (prefers-reduced-motion: reduce) {
transition: none;
}
}
&:hover {
z-index: 2;
outline-offset: 0;
cursor: pointer;
> img {
outline: 2px solid hsl(var(--color-link-base), 40%);
transform: scale(125%);
transition-duration: 200ms;
box-shadow: 0 0.125rem 1rem hsla(0, 0, 0%, 50%);
}
}
}
}