mirror of
https://github.com/iv-org/invidious.git
synced 2025-07-04 20:48:31 +00:00
1420 lines
23 KiB
CSS
1420 lines
23 KiB
CSS
/*
|
|
f* Common attributes
|
|
*/
|
|
:root {
|
|
--sans-serif: ui-rounded, "Hiragino Maru Gothic ProN", "Quicksand",
|
|
"Comfortaa", "Manjari", "Arial Rounded MT", "Arial Rounded MT Bold",
|
|
"Calibri", source-sans-pro, sans-serif;
|
|
--monospace: ui-monospace, "Cascadia Code", "Source Code Pro", "Menlo",
|
|
"Consolas", "DejaVu Sans Mono", monospace;
|
|
|
|
/** Gap between sections */
|
|
--gap: 2rem;
|
|
|
|
/** Gap between parts in a section */
|
|
--secondary-gap: 0.6rem;
|
|
|
|
/** Radius for rounded corners */
|
|
--radius: 0.3rem;
|
|
|
|
/** Border size */
|
|
--border-width: 0.2rem;
|
|
}
|
|
|
|
*,
|
|
*::before,
|
|
*::after {
|
|
box-sizing: border-box;
|
|
}
|
|
|
|
html,
|
|
body {
|
|
font-family: var(--sans-serif);
|
|
background-color: var(--bg-color);
|
|
color: var(--fg-color);
|
|
overflow-wrap: break-word;
|
|
word-wrap: break-word;
|
|
max-width: 100%;
|
|
}
|
|
|
|
body,
|
|
input,
|
|
textarea {
|
|
font-size: 1rem;
|
|
}
|
|
|
|
p {
|
|
line-height: 1.6;
|
|
max-width: 50em;
|
|
}
|
|
|
|
h1,
|
|
h2,
|
|
h3,
|
|
h4,
|
|
button,
|
|
input,
|
|
textarea,
|
|
label {
|
|
line-height: 1;
|
|
}
|
|
|
|
h1,
|
|
h2,
|
|
h3,
|
|
h4,
|
|
h5,
|
|
p {
|
|
unicode-bidi: plaintext;
|
|
text-align: start;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
h1 {
|
|
font-size: 1.4em;
|
|
}
|
|
|
|
h2 {
|
|
font-size: 1.3em;
|
|
}
|
|
|
|
h2 {
|
|
font-size: 1.2em;
|
|
}
|
|
|
|
.container h1 {
|
|
padding: 0 var(--secondary-gap);
|
|
}
|
|
}
|
|
|
|
a {
|
|
text-decoration: none;
|
|
color: currentcolor;
|
|
transition:
|
|
opacity 96ms ease-in-out,
|
|
color 96ms ease-in-out,
|
|
text-decoration-color 96ms ease-in-out,
|
|
outline-width 96ms ease-in-out;
|
|
}
|
|
|
|
p a {
|
|
text-decoration-line: underline;
|
|
text-decoration-color: var(--secondary-bg-color);
|
|
text-decoration-thickness: var(--border-width);
|
|
}
|
|
|
|
body > footer a {
|
|
text-decoration-line: underline;
|
|
text-decoration-color: var(--secondary-bg-color);
|
|
text-decoration-thickness: var(--border-width);
|
|
}
|
|
|
|
nav ul li > a {
|
|
padding: var(--secondary-gap);
|
|
border-radius: var(--radius);
|
|
}
|
|
|
|
.menu a {
|
|
padding: var(--secondary-gap);
|
|
width: 100%;
|
|
height: 100%;
|
|
display: block;
|
|
}
|
|
|
|
a:hover,
|
|
a:focus {
|
|
color: var(--accent-color);
|
|
}
|
|
|
|
a:hover,
|
|
a:active {
|
|
text-decoration-color: var(--accent-bg-color);
|
|
}
|
|
|
|
a:focus {
|
|
outline: var(--border-width) solid var(--secondary-bg-color);
|
|
outline-offset: calc(var(--secondary-gap) / 3);
|
|
border-radius: calc(var(--radius) / 2);
|
|
text-decoration: none;
|
|
}
|
|
|
|
a:active {
|
|
outline: var(--border-width) solid var(--accent-bg-color);
|
|
outline-offset: calc(var(--secondary-gap) / 3);
|
|
}
|
|
|
|
body > footer a:hover,
|
|
body > footer a:focus {
|
|
color: var(--accent-bg-color);
|
|
text-decoration-color: var(--accent-bg-color);
|
|
}
|
|
|
|
nav ul li > a:hover,
|
|
nav ul li > a:focus {
|
|
outline: var(--border-width) solid var(--secondary-bg-color);
|
|
outline-offset: calc(var(--secondary-gap) / 3);
|
|
}
|
|
|
|
nav ul li > a:active {
|
|
outline: var(--border-width) solid var(--accent-bg-color);
|
|
outline-offset: calc(var(--secondary-gap) / 3);
|
|
}
|
|
|
|
textarea {
|
|
background-color: var(--secondary-bg-color);
|
|
border: var(--border-width) solid var(--secondary-bg-color);
|
|
border-radius: var(--radius);
|
|
}
|
|
|
|
/* Make images easier to work with */
|
|
img,
|
|
picture {
|
|
max-width: 100%;
|
|
display: block;
|
|
}
|
|
|
|
hr {
|
|
border: none;
|
|
border-top: 1px solid var(--secondary-color);
|
|
border-bottom: 1px solid black;
|
|
}
|
|
|
|
select,
|
|
input[type="text"],
|
|
input[type="search"],
|
|
input[type="password"],
|
|
input[type="number"],
|
|
textarea {
|
|
font-size: inherit;
|
|
padding: var(--secondary-gap);
|
|
color: var(--fg-color);
|
|
background-color: var(--secondary-bg-color);
|
|
border: 1px solid var(--secondary-bg-color);
|
|
box-shadow: unset;
|
|
border-radius: var(--radius);
|
|
}
|
|
|
|
/** TODO reduce this selector */
|
|
fieldset div:has(input[type="checkbox"]):not(.control-group),
|
|
fieldset div:has(input[type="radio"]):not(.control-group) {
|
|
padding: var(--secondary-gap);
|
|
border-radius: var(--radius);
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
fieldset div:has(input[type="checkbox"]:checked + label),
|
|
fieldset div:has(input[type="radio"]:checked + label) {
|
|
background-color: var(--secondary-bg-color);
|
|
}
|
|
|
|
input[type="checkbox"],
|
|
input[type="radio"] {
|
|
min-width: 1em;
|
|
min-height: 1em;
|
|
}
|
|
|
|
fieldset {
|
|
border: var(--border-width) solid var(--secondary-bg-color);
|
|
border-radius: var(--radius);
|
|
margin: var(--gap) 0;
|
|
padding: var(--secondary-gap);
|
|
}
|
|
|
|
textarea:not([cols]) {
|
|
min-width: 20em;
|
|
}
|
|
|
|
textarea:not([rows]) {
|
|
min-height: 10em;
|
|
}
|
|
|
|
label {
|
|
cursor: pointer;
|
|
}
|
|
|
|
legend {
|
|
font-size: 1em;
|
|
background-color: var(--secondary-bg-color);
|
|
border-radius: var(--radius);
|
|
padding: var(--secondary-gap) calc(var(--secondary-gap) * 2);
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
/*
|
|
* Footer
|
|
*/
|
|
|
|
body > footer {
|
|
padding: calc(var(--gap) * 2) 0;
|
|
display: grid;
|
|
grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
|
|
grid-gap: var(--gap);
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
body > footer {
|
|
grid-template-columns: 1fr;
|
|
padding: var(--secondary-gap);
|
|
grid-gap: var(--secondary-gap);
|
|
}
|
|
}
|
|
|
|
nav {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
nav ul {
|
|
list-style: none;
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
padding: 0;
|
|
margin: 0;
|
|
align-items: flex-start;
|
|
}
|
|
|
|
nav ul li {
|
|
border-radius: var(--radius);
|
|
min-width: 1.5em;
|
|
min-height: 1.5em;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
|
|
nav ul li.selected {
|
|
background-color: var(--secondary-bg-color);
|
|
font-weight: bold;
|
|
}
|
|
|
|
body > footer nav > ul {
|
|
flex-direction: column;
|
|
align-items: flex-start;
|
|
gap: 0;
|
|
}
|
|
|
|
body > footer nav > ul > li {
|
|
padding: var(--secondary-gap) 0;
|
|
}
|
|
|
|
fieldset > select,
|
|
span > select {
|
|
color: rgb(49 49 51);
|
|
}
|
|
|
|
/**
|
|
* Main content container
|
|
*/
|
|
#contents {
|
|
min-height: 100vh;
|
|
}
|
|
|
|
.container {
|
|
margin-right: auto;
|
|
margin-left: auto;
|
|
max-width: 100%;
|
|
}
|
|
|
|
@media (min-width: 36em) {
|
|
.container {
|
|
max-width: 31.875em;
|
|
padding-right: 0;
|
|
padding-left: 0;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 48em) {
|
|
.container {
|
|
max-width: 43.75em;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 64em) {
|
|
.container {
|
|
max-width: 60em;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 80em) {
|
|
.container {
|
|
max-width: 75em;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 96em) {
|
|
.container {
|
|
max-width: 90em;
|
|
}
|
|
}
|
|
|
|
body > header {
|
|
padding: var(--secondary-gap) 0;
|
|
opacity: 0.7;
|
|
transition: opacity 240ms ease-in-out;
|
|
}
|
|
|
|
body > header:hover,
|
|
body > header:focus-within {
|
|
opacity: 1;
|
|
}
|
|
|
|
time {
|
|
font-style: italic;
|
|
font-size: 0.95em;
|
|
text-wrap: nowrap;
|
|
cursor: help;
|
|
}
|
|
|
|
/**
|
|
* Formatting for raw text blocks (comments, description)
|
|
*/
|
|
.raw-text {
|
|
white-space: pre-wrap;
|
|
}
|
|
|
|
.deleted {
|
|
background-color: rgb(255 0 0 / 50%);
|
|
}
|
|
|
|
.underlined {
|
|
border-bottom: 0.125rem solid;
|
|
margin-bottom: 1.25rem;
|
|
}
|
|
|
|
/* A flex container */
|
|
.flexible {
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
.flex-left {
|
|
display: flex;
|
|
flex: 1 1 auto;
|
|
flex-flow: row wrap;
|
|
justify-content: flex-start;
|
|
}
|
|
|
|
.flex-right {
|
|
display: flex;
|
|
flex: 2 0 auto;
|
|
flex-flow: row nowrap;
|
|
justify-content: flex-end;
|
|
}
|
|
|
|
/*
|
|
* Channel page
|
|
*/
|
|
|
|
.title {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
gap: var(--secondary-gap);
|
|
margin: var(--secondary-gap) 0;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.title {
|
|
flex-direction: column;
|
|
}
|
|
}
|
|
|
|
.channel-profile {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--secondary-gap);
|
|
}
|
|
|
|
#channel-name {
|
|
margin: 0;
|
|
}
|
|
|
|
.profile-pic {
|
|
border-radius: 50%;
|
|
}
|
|
|
|
.channel-profile > h3 {
|
|
font-size: 1.17em;
|
|
font-weight: bold;
|
|
vertical-align: middle;
|
|
text-wrap: nowrap;
|
|
}
|
|
|
|
.channel-profile > h4 {
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
}
|
|
|
|
.channel-profile > img {
|
|
width: 2rem;
|
|
height: auto;
|
|
border-radius: 50%;
|
|
}
|
|
|
|
body a.channel-owner {
|
|
background-color: var(--accent-bg-color);
|
|
border-radius: var(--radius);
|
|
padding: 0 calc(var(--secondary-gap) * 2);
|
|
}
|
|
|
|
body a.channel-owner:hover {
|
|
color: var(--fg-color);
|
|
}
|
|
|
|
.creator-heart-container {
|
|
display: inline-block;
|
|
padding: 0 0.4375rem 0.375rem 0;
|
|
margin: 0 -0.4375rem -0.25rem 0;
|
|
}
|
|
|
|
.creator-heart {
|
|
display: inline-block;
|
|
position: relative;
|
|
width: 1rem;
|
|
height: 1rem;
|
|
border: 0.125rem none;
|
|
}
|
|
|
|
.creator-heart-background-hearted {
|
|
width: 1em;
|
|
height: 1em;
|
|
padding: 0;
|
|
position: relative;
|
|
}
|
|
|
|
.creator-heart-small-hearted {
|
|
position: absolute;
|
|
right: -0.4375rem;
|
|
bottom: -0.25rem;
|
|
}
|
|
|
|
.creator-heart-small-container {
|
|
display: block;
|
|
position: relative;
|
|
width: 0.8125rem;
|
|
height: 0.8125rem;
|
|
color: rgb(255 0 0);
|
|
}
|
|
|
|
.menu {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
margin: var(--gap) 0;
|
|
}
|
|
|
|
.menu li {
|
|
padding: 0;
|
|
}
|
|
|
|
nav.filters {
|
|
margin: var(--gap) 0;
|
|
}
|
|
|
|
.feed-menu {
|
|
display: flex;
|
|
justify-content: center;
|
|
flex-wrap: wrap;
|
|
gap: var(--secondary-gap);
|
|
margin: var(--gap) 0;
|
|
}
|
|
|
|
.feed-menu li {
|
|
text-align: center;
|
|
background-color: var(--secondary-bg-color);
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
.loading {
|
|
display: inline-block;
|
|
animation: spin 2s linear infinite;
|
|
}
|
|
|
|
.subscription-menu {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
margin: var(--gap) 0;
|
|
}
|
|
|
|
.subscription-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.subscribe {
|
|
background-color: var(--accent-bg-color);
|
|
}
|
|
|
|
.unsubscribe {
|
|
background-color: var(--secondary-bg-color);
|
|
}
|
|
|
|
.history-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.header-group {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.playlist-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
}
|
|
|
|
.playlist-meta {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
margin: var(--gap) 0;
|
|
}
|
|
|
|
.playlist-meta ul {
|
|
list-style: none;
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
.playlist-restricted {
|
|
height: 20em;
|
|
padding-right: 0.625rem;
|
|
}
|
|
|
|
/*
|
|
* Watch
|
|
*/
|
|
.watch-meta {
|
|
opacity: 0.6;
|
|
transition: opacity 96ms ease-in-out;
|
|
}
|
|
|
|
.watch-meta:hover,
|
|
.watch-meta:focus-within {
|
|
opacity: 1;
|
|
}
|
|
|
|
.watch-meta nav ul {
|
|
flex-direction: column;
|
|
align-items: flex-start;
|
|
}
|
|
|
|
.watch-meta nav li {
|
|
padding: 0;
|
|
}
|
|
|
|
.watch {
|
|
display: grid;
|
|
grid-template-columns: 1fr 3fr 1fr;
|
|
grid-gap: var(--gap);
|
|
max-width: 100%;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.watch {
|
|
grid-template-columns: 1fr;
|
|
padding: 0 var(--secondary-gap);
|
|
}
|
|
}
|
|
|
|
.watch:has(details[open]) {
|
|
grid-template-columns: 3fr 1fr;
|
|
}
|
|
|
|
/* Initially hide the content of the details section */
|
|
details[open] ~ .watch-meta {
|
|
display: block;
|
|
}
|
|
|
|
/* Hide the grid item when the details box is closed */
|
|
details:not([open]) ~ .watch-meta {
|
|
display: none;
|
|
}
|
|
|
|
.watch-context {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: flex-start;
|
|
}
|
|
|
|
.watch-context nav ul {
|
|
flex-direction: column;
|
|
}
|
|
|
|
.video-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
}
|
|
|
|
.listen {
|
|
display: flex;
|
|
align-items: center;
|
|
font-size: 1.25em;
|
|
}
|
|
|
|
.video-meta {
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
justify-content: space-between;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.video-meta {
|
|
flex-direction: column;
|
|
}
|
|
}
|
|
|
|
.video-interaction-meta {
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
padding-inline: var(--secondary-gap);
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.video-interaction-meta {
|
|
padding-inline: 0;
|
|
}
|
|
}
|
|
|
|
.content-meta {
|
|
list-style: none;
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
/*
|
|
* Buttons
|
|
*/
|
|
|
|
button {
|
|
background-color: transparent;
|
|
border: none;
|
|
}
|
|
|
|
button,
|
|
*[role="button"],
|
|
*[type="submit"],
|
|
summary {
|
|
line-height: 1;
|
|
font-size: inherit;
|
|
color: currentcolor;
|
|
border: unset;
|
|
border-radius: var(--radius);
|
|
padding: var(--secondary-gap) calc(var(--secondary-gap) * 2);
|
|
transition: outline-width 96ms ease-in-out;
|
|
outline-width: 0;
|
|
outline-style: solid;
|
|
outline-color: var(--secondary-bg-color);
|
|
outline-offset: calc(var(--border-width) / 1.5);
|
|
white-space: nowrap;
|
|
}
|
|
|
|
/** prevent inner elements from being click targets */
|
|
button > *,
|
|
*[role="button"] > *,
|
|
*[type="submit"] > * {
|
|
pointer-events: none;
|
|
}
|
|
|
|
button:focus,
|
|
*[role="button"]:focus,
|
|
*[type="submit"]:focus,
|
|
*[type="number"]:focus,
|
|
summary:focus,
|
|
select:focus {
|
|
outline-width: var(--border-width);
|
|
}
|
|
|
|
button:active,
|
|
*[role="button"]:active,
|
|
*[type="submit"]:active,
|
|
*[type="number"]:active,
|
|
summary:active,
|
|
select:active {
|
|
transform: translate(0.125rem 0.125rem);
|
|
outline-color: var(--accent-bg-color);
|
|
}
|
|
|
|
button:hover,
|
|
*[role="button"]:hover,
|
|
*[type="submit"]:hover,
|
|
*[type="number"]:hover,
|
|
summary:hover,
|
|
select:hover {
|
|
outline-width: var(--border-width);
|
|
}
|
|
|
|
a[role="button"] {
|
|
text-decoration: none;
|
|
color: currentcolor;
|
|
}
|
|
|
|
button.pure-button-primary,
|
|
a.pure-button-primary,
|
|
.channel-owner:hover,
|
|
.channel-owner:focus {
|
|
background-color: var(--accent-bg-color);
|
|
}
|
|
|
|
.primary,
|
|
.pure-button-primary {
|
|
font-weight: bold;
|
|
background-color: var(--accent-bg-color);
|
|
}
|
|
|
|
.secondary,
|
|
.pure-button-secondary {
|
|
color: var(--secondary-color);
|
|
background-color: var(--secondary-bg-color);
|
|
}
|
|
|
|
.pure-button-primary:hover,
|
|
.pure-button-primary:focus {
|
|
border-color: var(--accent-color);
|
|
background-color: var(--accent-bg-color);
|
|
}
|
|
|
|
.secondary:hover,
|
|
.secondary:focus,
|
|
.pure-button-secondary:hover,
|
|
.pure-button-secondary:focus {
|
|
border-color: var(--secondary-color);
|
|
background-color: var(--secondary-bg-color);
|
|
}
|
|
|
|
.button-container {
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
align-items: center;
|
|
}
|
|
|
|
.controls {
|
|
display: grid;
|
|
gap: var(--secondary-gap);
|
|
}
|
|
|
|
.control-group {
|
|
display: grid;
|
|
grid-template-columns: 1fr 1fr;
|
|
gap: var(--secondary-gap);
|
|
place-items: center flex-start;
|
|
}
|
|
|
|
.control-message {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--secondary-gap);
|
|
}
|
|
|
|
.action-controls {
|
|
display: grid;
|
|
padding: var(--secondary-gap);
|
|
padding-left: calc(50% + (var(--secondary-gap) / 2));
|
|
gap: var(--gap);
|
|
place-items: center flex-start;
|
|
background-color: var(--secondary-bg-color);
|
|
border-radius: var(--radius);
|
|
}
|
|
|
|
.control-group label {
|
|
justify-self: flex-end;
|
|
}
|
|
|
|
/*
|
|
* Video thumbnails
|
|
*/
|
|
|
|
div.thumbnail {
|
|
position: relative;
|
|
width: 100%;
|
|
background-color: var(--secondary-bg-color);
|
|
}
|
|
|
|
img.thumbnail {
|
|
width: 100%;
|
|
max-width: 100%;
|
|
max-height: 100%;
|
|
object-fit: cover;
|
|
aspect-ratio: 16 / 9;
|
|
}
|
|
|
|
.thumbnail-placeholder {
|
|
min-height: calc(var(--gap) * 2);
|
|
background-color: var(--secondary-bg-color);
|
|
}
|
|
|
|
div.watched-overlay {
|
|
z-index: 50;
|
|
position: absolute;
|
|
inset: 0;
|
|
background-color: var(--watched-overlay-color);
|
|
}
|
|
|
|
div.watched-indicator {
|
|
position: absolute;
|
|
left: 0;
|
|
bottom: 0;
|
|
height: 0.25rem;
|
|
width: 100%;
|
|
background-color: var(--accent-bg-color);
|
|
}
|
|
|
|
.top-left-overlay {
|
|
top: var(--secondary-gap);
|
|
left: var(--secondary-gap);
|
|
}
|
|
|
|
.length {
|
|
bottom: var(--secondary-gap);
|
|
right: var(--secondary-gap);
|
|
z-index: 100;
|
|
position: absolute;
|
|
padding: 0 var(--secondary-gap);
|
|
border-radius: var(--radius);
|
|
color: white;
|
|
background-color: hsl(175deg 0 0% / 90%);
|
|
line-height: 1;
|
|
}
|
|
|
|
div.thumbnail > .top-left-overlay {
|
|
z-index: 100;
|
|
position: absolute;
|
|
}
|
|
|
|
.length,
|
|
.top-left-overlay button {
|
|
opacity: 0.9;
|
|
}
|
|
|
|
/*
|
|
* Related videos
|
|
*/
|
|
|
|
.related-videos {
|
|
display: grid;
|
|
grid-gap: var(--gap);
|
|
grid-template-columns: 18rem;
|
|
}
|
|
|
|
/*
|
|
* Videos
|
|
*/
|
|
|
|
.videos {
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fill, minmax(20em, 1fr));
|
|
grid-gap: var(--gap);
|
|
}
|
|
|
|
.notifications {
|
|
margin-bottom: var(--gap);
|
|
}
|
|
|
|
/*
|
|
* Video card
|
|
*/
|
|
|
|
.video-card {
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
flex-direction: column;
|
|
}
|
|
|
|
.video-card h3,
|
|
.video-card h4 {
|
|
margin: 0;
|
|
font-weight: normal;
|
|
line-height: 1.1;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.video-card p {
|
|
font-size: 0.9em;
|
|
}
|
|
|
|
.video-meta-sub {
|
|
display: grid;
|
|
grid-template-columns: auto auto;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
opacity: 0.7;
|
|
transition: opacity 96ms ease-in-out;
|
|
}
|
|
|
|
.video-meta-sub h3 {
|
|
margin: 0;
|
|
}
|
|
|
|
.video-meta-sub:hover,
|
|
.video-meta-sub:focus-within {
|
|
opacity: 1;
|
|
}
|
|
|
|
.video-card.hide {
|
|
opacity: 0.3;
|
|
pointer-events: none;
|
|
}
|
|
|
|
/*
|
|
* Navbar
|
|
*/
|
|
|
|
.navbar {
|
|
display: grid;
|
|
grid-template-columns: 1fr 2fr 1fr;
|
|
grid-template-areas: "index-link site-search user-nav";
|
|
align-items: center;
|
|
grid-gap: var(--secondary-gap);
|
|
justify-content: space-between;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.navbar {
|
|
grid-template-columns: 1fr 1fr;
|
|
grid-template-areas:
|
|
"index-link user-nav"
|
|
"site-search site-search";
|
|
}
|
|
}
|
|
|
|
.navbar ul:nth-child(3) {
|
|
justify-self: flex-end;
|
|
}
|
|
|
|
.navbar li {
|
|
padding: 0;
|
|
text-wrap: nowrap;
|
|
}
|
|
|
|
#site-search {
|
|
display: flex;
|
|
justify-content: center;
|
|
grid-area: site-search;
|
|
}
|
|
|
|
#index-link {
|
|
grid-area: index-link;
|
|
}
|
|
|
|
#user-nav {
|
|
grid-area: user-nav;
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
#index-link {
|
|
margin-left: var(--secondary-gap);
|
|
}
|
|
|
|
#user-nav {
|
|
margin-right: var(--secondary-gap);
|
|
}
|
|
}
|
|
|
|
.login,
|
|
.logout {
|
|
all: unset;
|
|
}
|
|
|
|
.login:hover,
|
|
.logout:hover,
|
|
.login:focus,
|
|
.logout:focus {
|
|
color: var(--accent-color);
|
|
}
|
|
|
|
.login:hover,
|
|
.login:active,
|
|
.logout:hover,
|
|
.logout:active {
|
|
text-decoration-color: var(--accent-bg-color);
|
|
}
|
|
|
|
.search-box {
|
|
display: flex;
|
|
align-items: center;
|
|
position: relative;
|
|
}
|
|
|
|
.search-box:focus-within button {
|
|
transform: translateX(3em);
|
|
}
|
|
|
|
.search-box button {
|
|
position: absolute;
|
|
left: 19em;
|
|
transition: transform 96ms ease-in-out;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.search-box button {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
.search {
|
|
width: 20em;
|
|
}
|
|
|
|
input[type="search"]:hover,
|
|
input[type="text"]:hover,
|
|
input[type="password"]:hover,
|
|
textarea:hover {
|
|
outline: var(--border-width) solid var(--secondary-bg-color);
|
|
outline-offset: var(--border-width);
|
|
}
|
|
|
|
input[type="search"]:focus,
|
|
input[type="text"]:focus,
|
|
input[type="password"]:focus,
|
|
textarea:focus {
|
|
outline: var(--border-width) solid var(--accent-color);
|
|
outline-offset: var(--border-width);
|
|
}
|
|
|
|
/* https://stackoverflow.com/a/55170420 */
|
|
input[type="search"]::-webkit-search-cancel-button {
|
|
height: 1em;
|
|
width: 1em;
|
|
background-image: url("");
|
|
background-size: 1em;
|
|
}
|
|
|
|
/* #searchbutton { */
|
|
/* border: none; */
|
|
/* background: none; */
|
|
/* margin-top: 0; */
|
|
/* } */
|
|
/**/
|
|
/* #searchbutton:hover { */
|
|
/* color: var(--accent-color); */
|
|
/* } */
|
|
.search-action {
|
|
background-color: var(--secondary-bg-color);
|
|
padding: var(--secondary-gap);
|
|
}
|
|
|
|
/*
|
|
* Responsive rules
|
|
*/
|
|
|
|
/* @media only screen and (max-aspect-ratio: 16/9) { */
|
|
/* .player-dimensions.vjs-fluid { */
|
|
/* padding-top: 46.86%; */
|
|
/* } */
|
|
/**/
|
|
/* #player-container { */
|
|
/* padding-bottom: 46.86%; */
|
|
/* } */
|
|
/* } */
|
|
/**/
|
|
/*
|
|
* Video "cards" (results/playlist/channel videos)
|
|
*/
|
|
|
|
.video-card-row {
|
|
margin: 0.9375rem 0;
|
|
}
|
|
|
|
.item-block h3 {
|
|
font-weight: normal;
|
|
}
|
|
|
|
.icon-buttons ul {
|
|
gap: 0;
|
|
}
|
|
|
|
.icon-buttons li {
|
|
padding: 0;
|
|
}
|
|
|
|
.icon-buttons li a {
|
|
padding: var(--secondary-gap);
|
|
}
|
|
|
|
/*
|
|
* Comments & community posts
|
|
*/
|
|
|
|
.community {
|
|
margin: var(--gap) auto;
|
|
}
|
|
|
|
.comments-header {
|
|
font-size: 0.9em;
|
|
margin: var(--gap) 0;
|
|
}
|
|
|
|
.comments-header h3 {
|
|
font-weight: normal;
|
|
}
|
|
|
|
.comments-header li {
|
|
display: flex;
|
|
padding: 0;
|
|
align-items: center;
|
|
gap: var(--secondary-gap);
|
|
text-wrap: nowrap;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.comments-header ul {
|
|
flex-direction: column;
|
|
}
|
|
}
|
|
|
|
.comments {
|
|
max-width: 50rem;
|
|
display: grid;
|
|
grid-gap: var(--gap);
|
|
justify-content: stretch;
|
|
}
|
|
|
|
.replies {
|
|
padding-left: var(--secondary-gap);
|
|
border-left: 0.2em solid var(--secondary-bg-color);
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.replies {
|
|
padding-left: var(--secondary-gap);
|
|
}
|
|
}
|
|
|
|
.comment {
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.comment h4 {
|
|
margin: 0;
|
|
font-size: 1em;
|
|
opacity: 0.6;
|
|
transition: opacity 96ms ease-in-out;
|
|
}
|
|
|
|
.comment h4:hover {
|
|
opacity: 1;
|
|
}
|
|
|
|
.comment-header {
|
|
display: grid;
|
|
grid-auto-flow: column;
|
|
align-items: center;
|
|
gap: var(--gap);
|
|
justify-content: space-between;
|
|
font-size: 0.9em;
|
|
}
|
|
|
|
@media (max-width: 30em) {
|
|
.comment-header {
|
|
gap: var(--secondary-gap);
|
|
justify-content: stretch;
|
|
}
|
|
|
|
.comment-header .comment-meta-sub {
|
|
justify-self: flex-end;
|
|
}
|
|
}
|
|
|
|
ul.comment-meta-sub {
|
|
display: flex;
|
|
list-style: none;
|
|
gap: var(--secondary-gap);
|
|
padding: 0;
|
|
margin: 0;
|
|
opacity: 0.7;
|
|
transition: opacity 240ms ease-in-out;
|
|
}
|
|
|
|
ul.comment-meta-sub:hover,
|
|
ul.comment-meta-sub:focus {
|
|
opacity: 1;
|
|
}
|
|
|
|
.comment-meta-sub li {
|
|
text-wrap: nowrap;
|
|
}
|
|
|
|
.replies button {
|
|
font-size: 0.95em;
|
|
}
|
|
|
|
.comment-temporal {
|
|
display: flex;
|
|
gap: var(--secondary-gap);
|
|
align-items: center;
|
|
align-content: center;
|
|
}
|
|
|
|
.comment-temporal time {
|
|
opacity: 0.7;
|
|
transition: opacity 96ms ease-in-out;
|
|
}
|
|
|
|
.comment-temporal time:hover {
|
|
opacity: 1;
|
|
}
|
|
|
|
/*
|
|
* We don't want the top and bottom margin on the post page.
|
|
*/
|
|
.comments.post-comments {
|
|
margin-bottom: 0;
|
|
margin-top: 0;
|
|
}
|
|
|
|
.video-iframe-wrapper {
|
|
position: relative;
|
|
height: 0;
|
|
padding-bottom: 56.25%;
|
|
}
|
|
|
|
.video-iframe {
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
border: none;
|
|
}
|
|
|
|
/*
|
|
* Page navigation
|
|
*/
|
|
|
|
.pagination {
|
|
margin: calc(var(--gap) / 2) 0;
|
|
}
|
|
|
|
.pure-control-group label {
|
|
word-wrap: normal;
|
|
}
|
|
|
|
/*
|
|
* Miscellanous
|
|
*/
|
|
|
|
/* Description Expansion Styling */
|
|
#description-expansion,
|
|
#music-desc-expansion {
|
|
display: none;
|
|
}
|
|
|
|
#description-expansion ~ p,
|
|
#music-desc-expansion ~ p {
|
|
overflow: hidden;
|
|
}
|
|
|
|
#description-expansion:not(:checked) ~ p {
|
|
max-height: 8.3em;
|
|
}
|
|
|
|
#description-expansion:checked ~ p {
|
|
overflow: unset;
|
|
height: 100%;
|
|
}
|
|
|
|
#description-expansion ~ label {
|
|
order: 1;
|
|
margin-top: 1.25rem;
|
|
}
|
|
|
|
label[for="description-expansion"]:hover,
|
|
label[for="music-desc-expansion"]:hover {
|
|
cursor: pointer;
|
|
}
|
|
|
|
/* Bidi (bidirectional text) support */
|
|
.raw-text,
|
|
#description,
|
|
#description-box,
|
|
#music-description-box {
|
|
unicode-bidi: plaintext;
|
|
text-align: start;
|
|
}
|
|
|
|
#music-description-box {
|
|
display: none;
|
|
}
|
|
|
|
#music-desc-expansion:checked ~ #music-description-box {
|
|
display: block;
|
|
}
|
|
|
|
#music-desc-expansion ~ label > h3 > .ion-ios-arrow-up,
|
|
#music-desc-expansion:checked ~ label > h3 > .ion-ios-arrow-down {
|
|
display: none;
|
|
}
|
|
|
|
#music-desc-expansion:checked ~ label > h3 > .ion-ios-arrow-up,
|
|
#music-desc-expansion ~ label > h3 > .ion-ios-arrow-down {
|
|
display: inline;
|
|
}
|
|
|
|
/* Select all the music items except the first one */
|
|
.music-item + .music-item {
|
|
border-top: 1px solid white;
|
|
}
|
|
|
|
/* Center the "invidious" logo on the search page */
|
|
#logo > h1 {
|
|
text-align: center;
|
|
}
|
|
|
|
.channel-emoji {
|
|
margin: 0 0.125rem;
|
|
}
|
|
|
|
#download_widget {
|
|
width: 100%;
|
|
}
|
|
|
|
.watch-action-group {
|
|
margin: var(--gap) 0;
|
|
display: grid;
|
|
grid-gap: var(--secondary-gap);
|
|
}
|
|
|
|
.subscriptions {
|
|
display: grid;
|
|
grid-template-columns: 1fr 1fr 1fr;
|
|
grid-gap: var(--gap);
|
|
}
|
|
|
|
.subscriptions > div {
|
|
border: 0.15em solid var(--secondary-bg-color);
|
|
border-radius: var(--radius);
|
|
padding: 1em;
|
|
}
|
|
|
|
.secondary-button {
|
|
border: none;
|
|
padding: 0.6em 1em;
|
|
background-color: var(--secondary-bg-color);
|
|
color: var(--secondary-color);
|
|
}
|
|
|
|
fieldset.preferences,
|
|
fieldset.form {
|
|
display: grid;
|
|
grid-gap: var(--secondary-gap);
|
|
padding-block: var(--gap);
|
|
margin: var(--gap) 0;
|
|
}
|
|
|
|
#views,
|
|
#likes {
|
|
text-wrap: nowrap;
|
|
}
|