@import url('@szhsin/react-menu/dist/core.css'); @import url('toastify-js/src/toastify.css'); html, body { margin: 0; padding: 0; background-color: var(--bg-color); color: var(--text-color); overflow-x: hidden; } body { touch-action: pan-x pan-y; } #app { min-height: 100vh; min-height: 100dvh; display: flex; align-items: center; justify-content: center; } #app-standalone { background-color: var(--bg-faded-color); } /* MENTIONS */ a.mention { text-decoration-line: none; } a.mention span { text-decoration-line: underline; text-decoration-color: inherit; text-decoration-thickness: 2px; text-underline-offset: 2px; font-variant-numeric: slashed-zero; font-feature-settings: 'ss01'; } /* a.mention:has(span).hashtag { color: var(--link-light-color); } */ a.mention span { color: var(--text-color); } a[href^='http'][rel*='nofollow']:visited:not(:has(div)) { color: var(--link-visited-color); text-decoration-color: var(--link-visited-color); } .deck-container { width: 100%; height: 100vh; height: 100dvh; overflow: auto; overflow-x: hidden; transition: opacity 0.1s ease-in-out; overscroll-behavior: contain; scroll-behavior: smooth; background-color: var(--bg-color); flex-grow: 1; /* This `transform` fixes carousel blocking vertical scrolling for pointer devices on iPad */ transform: translateZ(0); } @media (hover: hover) { .deck-container { overscroll-behavior: auto; } } .deck-container[hidden] { display: block; position: absolute; user-select: none; pointer-events: none; opacity: 0; content-visibility: hidden; } .deck-container, .deck.contained { scroll-padding-top: 3em; } :is(#home-page, #welcome, #columns, #loader-root) ~ .deck-container { z-index: 10; position: fixed; inset: 0; } :is(#home-page, #welcome, #columns, #loader-root):has(~ .deck-container) { /* display: block; */ position: absolute; user-select: none; pointer-events: none; opacity: 0; /* This causes scrollTop to be reset to 0 when the page is hidden */ /* content-visibility: hidden; */ } .deck { min-height: 100vh; min-height: 100dvh; margin: auto; width: var(--main-width); max-width: 100%; background-color: var(--bg-color); overflow-anchor: auto; &.wide { width: 60em; } } .deck.contained { overflow: auto; overflow-x: hidden; height: 100vh; height: 100dvh; overscroll-behavior: contain; } @media (hover: hover) { .deck.contained { overscroll-behavior: auto; } } .deck > header { position: sticky; top: 0; z-index: 1; cursor: default; z-index: 10; user-select: none; transition: transform 0.5s ease-in-out; user-select: none; .header-double-lines { font-size: 90% !important; cursor: pointer; div { font-weight: normal; color: var(--text-insignificant-color); } } } .deck > header[hidden] { display: block; transform: translateY(-100%); pointer-events: none; user-select: none; } .deck > header .header-grid { background-color: var(--bg-color); /* background-color: var(--bg-blur-color); background-image: linear-gradient(to bottom, var(--bg-color), transparent); backdrop-filter: saturate(180%) blur(20px); */ border-bottom: var(--hairline-width) solid var(--divider-color); min-height: 3em; display: grid; grid-template-columns: 1fr minmax(0, max-content) 1fr; align-items: center; white-space: nowrap; } .deck > header .header-grid > .header-side:last-of-type { text-align: right; grid-column: 3; } .deck > header .header-grid :is(button, .button).plain { backdrop-filter: none; } .deck > header .header-grid h1 { margin: 0 8px; padding: 0; font-size: 1.2em; text-align: center; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .deck > header .header-grid.header-grid-2 { grid-template-columns: 1fr max-content; } .deck > header .header-grid-2 h1 { text-align: left; padding-left: 8px; } .deck > header .header-grid h1:has(.ancestors-indicator) { display: flex; gap: 8px; align-items: center; max-width: fit-content; } .deck > header .header-grid h1:has(.ancestors-indicator) .hero-heading { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .deck h2 { font-size: 1.45em; } .deck.padded-bottom .timeline > li:last-child { padding-bottom: 80vh !important; padding-bottom: 80dvh !important; } @keyframes indeterminate-bar { 0% { transform: translateX(-50%); opacity: 0.25; } 50% { opacity: 1; } 100% { transform: translateX(50%); opacity: 0.25; } } .deck > header.loading:after { pointer-events: none; content: ''; display: block; height: 4px; position: absolute; bottom: 0; width: 50%; left: 25%; background-image: radial-gradient( farthest-side at bottom, var(--link-color), transparent ); animation: indeterminate-bar 1s ease-in-out infinite alternate; } @media (min-width: 40em) { .deck > header.loading:after { height: 8px; } } .timeline { margin: 0 auto; padding: 0; &.timeline-media { --grid-gap: 8px; display: grid; grid-template-columns: 1fr; grid-auto-rows: fit-content; gap: var(--grid-gap); padding: var(--grid-gap); &:not(#columns &) { background-color: var(--bg-faded-color); } @media (min-width: 320px) { grid-template-columns: 1fr 1fr; } @media (min-width: 40em) { &:not(#columns &) { --grid-gap: 16px; grid-template-columns: 1fr 1fr 1fr; @media (min-width: 40em) { width: 95vw; max-width: calc(320px * 3.3); transform: translateX(calc(-50% + var(--main-width) / 2)); } } #columns & { padding-inline: 0; } } li { padding: 0 !important; margin: 0 !important; border: 0 !important; overflow: visible !important; background-color: transparent !important; box-shadow: none !important; } @supports (grid-template-rows: masonry) { grid-template-rows: masonry; masonry-auto-flow: pack; .media-post a { aspect-ratio: revert !important; video, img, audio { min-height: var(--min-dimension); /* for extreme dimensions */ } } } } } .deck-container-media-first { .timeline { > li:not(.timeline-item-carousel, .timeline-item-container) { &:has(.status-media-first) { width: fit-content; background-color: transparent !important; border: 0 !important; box-shadow: none !important; max-width: min(480px, 100%); margin-inline: auto !important; margin-block: 32px; &:has(.skeleton) { width: 100%; } } &:has(.media[data-orientation='landscape']) { max-width: 100%; } } .status-link:has(.status-media-first):hover { background-color: transparent; } } } .timeline.grow { /* min-height: 100vh; min-height: 100dvh; */ padding-bottom: calc(env(safe-area-inset-bottom) + 16px); } .timeline > li { list-style: none; margin: 0; padding: 0; border-bottom: var(--hairline-width) solid var(--divider-color); } .timeline.flat > li { border-bottom: none; } .timeline.contextual { --thread-start: 40px; --line-start: 40px; --line-width: 3px; --line-end: calc(var(--line-start) + var(--line-width)); --line-margin-end: 16px; --line-radius: 10px; --line-diameter: calc(var(--line-radius) * 2); --avatar-size: 50px; --avatar-margin-start: 16px; --avatar-margin-end: 12px; } .timeline.contextual > li { background-image: linear-gradient( to right, transparent, transparent var(--line-start), var(--comment-line-color) var(--line-start), var(--comment-line-color) var(--line-end), transparent var(--line-end), transparent ); background-repeat: no-repeat; transition: opacity 0.3s ease-in-out; } .timeline.contextual > li:first-child { background-position: 0 calc(16px + var(--avatar-size)); } .timeline.contextual > li:last-child { background-size: 100% 20px; } .timeline.contextual > li:only-child { background-image: none; } .timeline.contextual > li.descendant { position: relative; } .timeline.contextual > li.descendant { padding-bottom: 1em; } .timeline.contextual > li.descendant:not(.thread) > :is(.status-link, .status-focus) { padding-left: 40px; } .timeline.contextual .replies[data-scroll-left]:not([data-scroll-left='0']) { background-color: var(--bg-color); box-shadow: inset 0 -3px var(--comment-line-color), inset 0 3px var(--comment-line-color); overscroll-behavior-x: contain; /* touch-action: pan-x; */ } .timeline.contextual .replies[data-comments-level='4'] { overflow-x: auto; } .timeline.contextual .replies[data-comments-level='4']:has(.replies) { overflow-x: auto; mask-image: linear-gradient(to left, transparent, black 32px); } .timeline.contextual .replies[data-comments-level='4']:has(.replies) > .replies-summary { border-top: 2px dashed var(--divider-color); } .timeline.contextual .replies[data-comments-level='4'] .replies[data-comments-level-overflow='true'] .status { min-width: min(20em, 80vw); } .timeline.contextual > li.descendant.thread > :is(.status-link, .status-focus) + .replies .replies-summary { margin-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * (var(--comments-level) - 1)) ); } /* .timeline.contextual > li.descendant.thread > .status-link + .replies .replies > .replies-summary { margin-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + var(--line-margin-end) ); } .timeline.contextual > li.descendant.thread > .status-link + .replies .replies .replies > .replies-summary { margin-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * 2) ); } */ .timeline.contextual > li.descendant.thread > :is(.status-link, .status-focus) + .replies :is(.status-link, .status-focus) { padding-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * (var(--comments-level) - 1)) ); } /* .timeline.contextual > li.descendant.thread > .status-link + .replies .replies .status-link { padding-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + var(--line-margin-end) ); } .timeline.contextual > li.descendant.thread > .status-link + .replies .replies .replies .status-link { padding-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * 2) ); } */ .timeline.contextual > li.descendant:not(.thread) > :is(.status-link, .status-focus) + .replies .replies-summary { margin-left: calc( var(--thread-start) + var(--line-margin-end) * var(--comments-level) ); } /* .timeline.contextual > li.descendant:not(.thread) > .status-link + .replies .replies > .replies-summary { margin-left: calc( var(--thread-start) + var(--line-margin-end) + var(--line-margin-end) ); } .timeline.contextual > li.descendant:not(.thread) > .status-link + .replies .replies .replies > .replies-summary { margin-left: calc( var(--thread-start) + var(--line-margin-end) + (var(--line-margin-end) * 2) ); } */ .timeline.contextual > li.descendant:not(.thread) > :is(.status-link, .status-focus) + .replies :is(.status-link, .status-focus) { padding-left: calc( var(--thread-start) + var(--line-margin-end) * var(--comments-level) ); } /* .timeline.contextual > li.descendant:not(.thread) > .status-link + .replies .replies .status-link { padding-left: calc(var(--thread-start) + (var(--line-margin-end) * 2)); } .timeline.contextual > li.descendant:not(.thread) > .status-link + .replies .replies .replies .status-link { padding-left: calc(var(--thread-start) + (var(--line-margin-end) * 3)); } */ .timeline.contextual > li.descendant:not(.thread):before { content: ''; position: absolute; top: 10px; left: var(--line-start); width: var(--line-diameter); height: var(--line-diameter); border-radius: var(--line-radius); border-style: solid; border-width: var(--line-width); border-color: transparent transparent var(--comment-line-color) transparent; transform: rotate(45deg); } .timeline.contextual > li .replies-link { color: var(--text-insignificant-color); margin-left: 16px; margin-top: -12px; padding-bottom: 12px; font-size: 90%; } .timeline.contextual > li.ancestor .replies-link { margin-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) ); } .timeline.contextual > li.thread > :is(.status-link, .status-focus) .replies-link { margin-left: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) ); } .timeline.contextual > li .replies-link * { vertical-align: middle; } .timeline.contextual > li .replies { margin-top: -12px; } .timeline.contextual > li .replies :is(ul, li):not(.content *) { margin: 0; padding: 0; list-style: none; } .timeline.contextual > li .replies > .replies-summary { --summary-padding: 8px; padding: var(--summary-padding); background-color: var(--bg-faded-color); display: inline-flex; border-radius: 8px; cursor: pointer; text-transform: uppercase; font-size: 12px; color: var(--text-insignificant-color); user-select: none; box-shadow: 0 0 0 2px var(--bg-color); position: relative; list-style: none; gap: 8px; align-items: center; margin-right: calc(44px + 8px); b { font-weight: 500; color: var(--text-color); } .avatars { flex-shrink: 0; transition: opacity 0.3s ease; .avatar { transition: transform 0.3s ease; &:not(:first-child) { margin: 0 0 0 -4px; } } } .replies-counts { /* flex-grow: 1; */ > * { display: inline-block; } } .replies-summary-chevron { transition: transform 0.3s ease; } .replies-parent-link { position: absolute; right: 4px; height: 100%; z-index: 2; font-size: 16px; font-weight: bold; align-self: stretch; text-decoration: none; display: flex; align-items: center; padding: var(--summary-padding) calc(var(--summary-padding) * 2); transform: translateX(100%); margin: calc(-1 * var(--summary-padding)) calc(-1 * var(--summary-padding)) calc(-1 * var(--summary-padding)) 0; border-radius: 8px; background-color: var(--link-bg-color); &:is(:hover, :focus) { color: var(--link-text-color); box-shadow: inset 0 0 0 2px var(--link-faded-color); } &:active { background-color: var(--link-faded-color); } } } .timeline.contextual > li .replies > .replies-summary::-webkit-details-marker { display: none; } .timeline.contextual > li .replies > .replies-summary > * { vertical-align: middle; } .timeline.contextual > li .replies > .replies-summary .timeline.contextual > li .replies > .replies-summary:active, .timeline.contextual > li .replies[open] > .replies-summary { color: var(--text-color); background-color: var(--comment-line-color); background-image: linear-gradient( to top right, var(--comment-line-color), var(--bg-faded-color) ); } @keyframes summary-fade { 0% { opacity: 0; transform: translateY(-8px); } 100% { opacity: 1; transform: translateY(0); } } .timeline.contextual > li .replies[open] > .replies-summary { border-bottom-left-radius: 0; .avatars { opacity: 0.5; .avatar { transform: rotate(-15deg); } } .replies-summary-chevron { transform: rotate(180deg); } + * { animation: summary-fade 0.3s ease-out both; } } .timeline.contextual > li .replies .replies-summary[hidden] { display: none; } .timeline.contextual > li .replies li:not(.content li) { position: relative; } .timeline.contextual > li .replies li:not(.content li) { --line-start: calc( var(--thread-start) + var(--line-margin-end) * var(--comments-level) ); --line-end: calc(var(--line-start) + var(--line-width)); background-image: linear-gradient( to right, transparent, transparent var(--line-start), var(--comment-line-color) var(--line-start), var(--comment-line-color) var(--line-end), transparent var(--line-end), transparent ); background-repeat: no-repeat; } /* .timeline.contextual > li .replies .replies li { --line-start: calc(var(--thread-start) + (var(--line-margin-end) * 2)); } .timeline.contextual > li .replies .replies .replies li { --line-start: calc(var(--thread-start) + (var(--line-margin-end) * 3)); } */ .timeline.contextual > li.thread .replies li:not(.content li) { --line-start: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * (var(--comments-level) - 1)) ); } /* .timeline.contextual > li.thread .replies .replies li { --line-start: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + var(--line-margin-end) ); } .timeline.contextual > li.thread .replies .replies .replies li { --line-start: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * 2) ); } */ .timeline.contextual > li .replies li:not(.content li):last-child { background-size: 100% 20px; } .timeline.contextual > li .replies li:not(.content li):before { content: ''; position: absolute; top: 10px; left: var(--line-start); width: var(--line-diameter); height: var(--line-diameter); border-radius: var(--line-radius); border-style: solid; border-width: var(--line-width); border-color: transparent transparent var(--comment-line-color) transparent; transform: rotate(45deg); } /* .timeline.contextual > li .replies .replies li:before { --line-start: calc( var(--thread-start) + var(--line-margin-end) + var(--line-margin-end) ); } .timeline.contextual > li .replies .replies .replies li:before { --line-start: calc( var(--thread-start) + var(--line-margin-end) + (var(--line-margin-end) * 2) ); } */ .timeline.contextual > li.thread .replies li:not(.content li):before { --line-start: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * (var(--comments-level) - 1)) ); } /* .timeline.contextual > li.thread .replies .replies li:before { --line-start: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + var(--line-margin-end) ); } .timeline.contextual > li.thread .replies .replies .replies li:before { --line-start: calc( var(--avatar-size) + var(--avatar-margin-start) + var(--avatar-margin-end) + (var(--line-margin-end) * 2) ); } */ .timeline.contextual.loading > li:not(.hero) { /* opacity: 0.5; */ pointer-events: none; } .timeline.contextual > li .replies { > ul > li:only-child { > .replies { > ul > li:only-child { margin-left: calc(-1 * var(--line-margin-end)); background-position: calc(16px) 0; background-size: 100% calc(20px + 8px); &:before { display: none; } } } } } .timeline-deck.compact .status { max-height: max(25vh, 160px); overflow: hidden; mask-image: linear-gradient( rgba(0, 0, 0, 1), rgba(0, 0, 0, 1) 80%, transparent 95% ); } .timeline-deck.compact .status .meta ~ * { pointer-events: none; } .timeline-header { padding: 0 16px; opacity: 0.75; } .timeline-empty { color: var(--text-insignificant-color); padding: 0 16px; margin-bottom: 3em; } .timeline:not(.flat) > li.timeline-item-container { --avatar-size: 50px; --line-start: 40px; --line-width: 3px; --line-end: calc(var(--line-start) + var(--line-width)); background-image: linear-gradient( to right, transparent, transparent var(--line-start), var(--comment-line-color) var(--line-start), var(--comment-line-color) var(--line-end), transparent var(--line-end), transparent ); background-repeat: no-repeat; } .timeline:not(.flat) > li.timeline-item-container-start { margin-bottom: 0; border-bottom-left-radius: 0; border-bottom-right-radius: 0; border-bottom: 0; background-position: 0 calc(16px + var(--avatar-size)); } .timeline:not(.flat) > li.timeline-item-container-middle { margin-top: 0; margin-bottom: 0; border-radius: 0; border-bottom: 0; border-top: 0; } .timeline:not(.flat) > li.timeline-item-container-end { margin-top: 0; border-top-left-radius: 0; border-top-right-radius: 0; border-top: 0; background-size: 100% 16px; &:has(.status-pre-meta) { /* 20px = icon of the pre-meta */ background-size: 100% calc(16px + 20px); } } .timeline:not(.flat) > li:is(.timeline-item-container-middle, .timeline-item-container-end) .status-reply-to:not(.visibility-direct):not(.status-card) { background-image: none; } .timeline:not(.flat) > li.timeline-item-diff-author > :is(.status-link, .status-focus) > .status > a > .avatar { transform: scale(0.8); filter: drop-shadow(0 0 16px var(--bg-color)) drop-shadow(0 0 8px var(--bg-color)) drop-shadow(0 0 8px var(--bg-color)); } .timeline .show-more { padding-left: calc(var(--line-end) + var(--line-margin-end)) !important; text-align: left; background-color: transparent !important; backdrop-filter: none !important; position: relative; border-radius: 0; padding-block: 16px !important; .avatars-bunch > .avatar:not(:first-child) { margin-left: -4px; } } .timeline .show-more:hover { filter: none !important; color: var(--text-color) !important; background-color: var(--bg-faded-blur-color) !important; } .timeline .show-more:before { content: ''; position: absolute; top: 10px; left: var(--line-start); width: var(--line-diameter); height: var(--line-diameter); border-radius: var(--line-radius); border-style: solid; border-width: var(--line-width); border-color: transparent transparent var(--comment-line-color) transparent; transform: rotate(45deg); } .status-loading { text-align: center; color: var(--text-insignificant-color); max-width: var(--main-width); } .status-error { text-align: center; color: var(--text-insignificant-color); max-width: var(--main-width); } .status-link { display: block; text-decoration-line: none; color: inherit; user-select: none; transition: background-color 0.1s ease-out; -webkit-tap-highlight-color: transparent; animation: appear 0.2s ease-out; -webkit-touch-callout: none; } @media (pointer: coarse) { .status-focus:not(.hero .status-focus) { /* Only the hero doesn't have context menu */ user-select: none; -webkit-tap-highlight-color: transparent; -webkit-touch-callout: none; } } @media not (pointer: coarse) { :is(.status-link, .status-focus):is(:focus, .is-active) { background-color: var(--link-bg-hover-color); outline-offset: -2px; } } @media (hover: hover) { .status-link:hover { background-color: var(--link-bg-hover-color); outline-offset: -2px; } } .status-link:active:not(:has(:is(.media, button):active)) { filter: brightness(0.95); } .status-carousel { --carousel-faded-color: var(--bg-faded-color); background: linear-gradient( to bottom right, var(--carousel-faded-color), transparent ); position: relative; container-type: inline-size; } .status-carousel:after { content: ''; position: absolute; inset: 0; pointer-events: none; background-image: radial-gradient( ellipse 50% 32px at bottom center, var(--carousel-faded-color), transparent ), linear-gradient(to top, var(--bg-color) 8px, transparent 64px); background-repeat: no-repeat; background-position: bottom center; } .status-carousel header { padding: 8px 16px 0; display: flex; justify-content: space-between; align-items: center; } .status-carousel h3 { margin: 0; padding: 0; font-size: 14px; text-transform: uppercase; color: var(--carousel-color); text-shadow: 0 1px var(--bg-color); } .status-carousel > ul { --carousel-gap: 16px; display: flex; overflow-x: auto; overflow-y: clip; scroll-snap-type: x mandatory; scroll-behavior: smooth; margin: 0; padding: 8px 16px; gap: var(--carousel-gap); align-items: flex-start; counter-reset: index; min-height: 160px; max-height: 65vh; max-height: 65dvh; } .status-carousel > ul > li { scroll-snap-align: center; scroll-snap-stop: always; flex-shrink: 0; display: flex; width: 100%; max-width: min(320px, calc(100% - 16px)); list-style: none; margin: 0; padding: 0; /* max-height: 65vh; max-height: 65dvh; */ counter-increment: index; position: relative; } .status-carousel > ul > li:is(:empty, :has(> a:empty)) { display: none; } .status-carousel .status-carousel-beacon { margin-right: calc(-1 * var(--carousel-gap)); pointer-events: none; opacity: 0; ~ .status-carousel-beacon { margin-left: calc(-1 * var(--carousel-gap)); } } /* Assume that browsers that do support inline-size property also support container queries. https://www.smashingmagazine.com/2021/05/css-container-queries-use-cases-migration-strategies/#progressive-enhancement-polyfills */ @supports not (contain: inline-size) { @media (hover: hover) or (pointer: fine) or (min-width: 40em) { .status-carousel > ul { scroll-snap-type: none; } } } @container (min-width: 640px) { .status-carousel > ul { scroll-snap-type: none; } } .status-carousel .content-container .content:only-child { font-size: calc(100% + 25% * max(2 - var(--content-text-weight), 0)); &:has(.status-card) { font-size: unset; } } /* .status-carousel .content-container[data-content-text-weight='1'] .media-container.media-eq1 { /* LOL, this is madness, reading a value from the style attribute * / height: auto; min-height: 160px; max-height: max(160px, 50vh); } */ .status-carousel.boosts-carousel { --carousel-color: var(--reblog-color); --carousel-faded-color: var(--reblog-faded-color); } .status-carousel.boosts-carousel .status-reblog { background-image: none; } .status-carousel.boosts-carousel > ul > li:before { content: counter(index); position: absolute; left: 0; font-size: 10px; color: var(--text-insignificant-color); padding: 6px; } .ui-state { padding: 16px; text-align: center; .icon { vertical-align: middle; } } .status-carousel-link { display: block; width: 100%; text-decoration-line: none; color: inherit; user-select: none; transition: background-color 0.2s ease-out; -webkit-tap-highlight-color: transparent; animation: appear 0.2s ease-out; border: 1px solid var(--outline-color); background-color: var(--bg-blur-color); border-radius: 16px; overflow: clip; box-shadow: 0 1px var(--bg-color); &:has(.status-badge:not(:empty)) { border-top-right-radius: 8px; } .status-carousel.boosts-carousel & { border-top-left-radius: 8px; } } .status-carousel-link::focus { background-color: var(--link-bg-hover-color); } @media (hover: hover) { .status-carousel-link:hover { background-color: var(--link-bg-hover-color); } } .status-carousel-link:active:not(:has(:is(.media, button):active)) { filter: brightness(0.95); } .deck-backdrop { position: fixed; top: 0; right: 0; height: 100%; width: 100%; z-index: 1000; display: flex; background-color: var(--backdrop-color); animation: appear 0.1s ease-out; } .deck-backdrop > a { flex-grow: 1; /* backdrop-filter: saturate(0.75); */ } @keyframes slide-in { 0% { transform: translate3d(100%, 0, 0); } 100% { transform: translate3d(0, 0, 0); } } .deck-backdrop .deck { width: var(--main-width); max-width: 100vw; background-color: var(--bg-color); box-shadow: -1px 0 var(--bg-color); } .deck-backdrop .deck.slide-in:not(.deck-view-full) { animation: slide-in 0.5s var(--timing-function); } .deck-backdrop .deck .status { max-width: var(--main-width); } .deck-backdrop .deck :is(.button-switch-view, .menu-switch-view) { display: none; } @media (min-width: 40em) { .deck-backdrop .deck .button-switch-view { display: inline-block; } .deck-backdrop .deck .menu-switch-view { display: flex; } .deck-backdrop .deck.deck-view-full { /* min-width: 100%; */ width: 100%; background-image: radial-gradient( circle, transparent 30em, var(--bg-faded-color) ); } .deck-backdrop .deck.deck-view-full > * { max-width: calc(var(--main-width) + 32px); margin: 0 auto; } .deck-backdrop .deck.deck-view-full .status { max-width: 100%; } } .deck-close { color: var(--text-insignificant-color) !important; } .deck-close:is(:hover, :focus) { color: var(--text-color) !important; } :is(button, .button).plain.has-badge:after { content: ''; display: inline-block; position: absolute; right: 10px; width: 4px; height: 4px; border-radius: 50%; background-color: var(--link-color); opacity: 0.5; } @keyframes fade-from-top { 0% { transform: translate(-50%, -200%); opacity: 0; } 100% { transform: translate(-50%, 0); opacity: 1; } } .updates-button { position: absolute; z-index: 2; top: 3em; animation: fade-from-top 0.3s var(--timing-function); left: 50%; margin-top: 16px; transform: translate(-50%, 0); font-size: 90%; pointer-events: auto; transition: all 0.3s ease-in-out; header[hidden] & { opacity: 0; transform: translate(-50%, -100%) scale(0.9); pointer-events: none; animation: none !important; } } .updates-button .icon { vertical-align: top; } @media (pointer: coarse) { .updates-button:after { content: ''; position: absolute; inset: -16px; } } /* BOX */ .box { width: var(--main-width); max-width: 100vw; padding: 16px; } /* CAROUSEL */ /* use snap, center children, max width viewport */ .media-modal-container { position: relative; width: 70%; flex-grow: 1; background-color: var(--backdrop-solid-color); animation: appear 0.1s var(--timing-function) both; transition: width 0.3s var(--timing-function); &:only-child { width: 100%; } } .media-modal-container.loading { display: flex; justify-content: center; align-items: center; background-image: radial-gradient( closest-side, var(--bg-blur-color), transparent ); } .carousel { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; /* scroll-behavior: smooth; */ scrollbar-width: none; overscroll-behavior: contain; touch-action: pan-x; user-select: none; width: 100%; gap: 16px; } .carousel::-webkit-scrollbar { display: none; } .carousel .carousel-item { scroll-snap-align: center; scroll-snap-stop: always; flex-shrink: 0; display: flex; justify-content: center; align-items: center; width: 100%; height: 100vh; height: 100dvh; background-color: var(--accent-alpha-color); /* background-image: radial-gradient( closest-side, var(--accent-color) 10%, var(--accent-alpha-color) 40%, transparent 100% ); */ } .carousel .carousel-item :is(img, video) { width: auto; max-width: 100%; height: auto; max-height: 100vh; max-height: 100dvh; vertical-align: middle; } .carousel .carousel-item video { min-height: 80px; max-height: 80vh; /* prevent other UI elements from obscuring video */ } .carousel .carousel-item .media { background-size: contain; background-repeat: no-repeat; background-position: center; width: 100%; height: 100%; overflow: hidden; display: flex; justify-content: center; align-items: center; padding: env(safe-area-inset-top, 0) env(safe-area-inset-right, 0) env(safe-area-inset-bottom, 0) env(safe-area-inset-left, 0); background-origin: content-box; } .carousel-top-controls { top: 0; top: env(safe-area-inset-top, 0); } :is(.carousel-top-controls, .carousel-controls) { /* mix-blend-mode: luminosity; */ position: absolute; left: 0; left: env(safe-area-inset-left, 0); right: 0; right: env(safe-area-inset-right, 0); padding: 16px; display: flex; gap: 8px; justify-content: space-between; text-align: center; pointer-events: none; } :is(.carousel-top-controls, .carousel-controls)[hidden] { opacity: 0; } .carousel-controls { top: 45%; } :is(.button, button).carousel-button, button.carousel-dot { pointer-events: auto; font-weight: bold; color: var(--text-color); background-color: var(--bg-faded-blur-color); border: 1px solid var(--outline-color); box-shadow: 0 4px 32px var(--drop-shadow-color); transition: all 0.2s ease-out; } button.carousel-dot { background-color: transparent; } :is(.button, button).carousel-button { background-color: var(--bg-blur-color); } :is(.button, button).carousel-button:is(:hover, :focus):not(:active) { background-color: var(--bg-color); } .carousel-top-controls .szh-menu-container { pointer-events: auto; } :is(.button, button).carousel-button[hidden] { display: inline-block; opacity: 0; pointer-events: none; } .carousel-dots { border-radius: 999px; background-color: var(--bg-faded-blur-color); border: 1px solid var(--outline-color); box-shadow: 0 4px 32px var(--drop-shadow-color); /* backdrop-filter: blur(12px) invert(0.25); */ transition: background-color 0.2s ease-out; &:hover { background-color: var(--bg-color); } } button.carousel-dot { backdrop-filter: none !important; border: none; box-shadow: none; } /* button.carousel-dot[disabled] { pointer-events: none; } */ button.carousel-dot .icon { transition: all 0.2s; transform: scale(0.5); } button.carousel-dot:not(.active) .icon { opacity: 0.5; } button.carousel-dot:not(.active):is(:hover, :focus) .icon { opacity: 1; } button.carousel-dot:is(.active, [disabled].active) { opacity: 1; } button.carousel-dot:is(.active, [disabled].active) .icon { opacity: 1; transform: scale(1); } @media (hover: hover) { .carousel-top-controls { transform: translateY(-100%); transition: transform 0.2s ease-in-out; } .carousel-controls { transform: scale(0); /* transition: transform 0.2s ease-in-out; */ } .carousel-controls :is(.button, button).carousel-button:is(:hover, :focus):not(:active) { transform: scale(1.2); } .carousel-controls :is(.button, button).carousel-button:active { transition-duration: 0s; } :is(.carousel-top-controls, .carousel-controls)[hidden] { opacity: 1; } .carousel:hover + .carousel-top-controls, .carousel:hover + .carousel-top-controls + .carousel-controls, .carousel-top-controls:hover, .carousel-controls:hover, .carousel-top-controls:focus-within, .carousel-controls:focus-within { transform: translateY(0); } } /* CAROUSEL + STATUS PAGE COMBO */ .media-post-link .button-label { display: none; } body:has(.status-deck) .media-post-link { display: none; } .media-modal-count-1 .button-label { display: inline; } /* ✨ New */ body:has(.media-modal-container + .status-deck) .media-post-link { display: inline-block; } .media-modal-container + .status-deck { /* display: none; */ position: absolute; z-index: -1; pointer-events: none; user-select: none; animation: none; } @media (min-width: calc(40em + 350px)) { .media-post-link .button-label { display: inline; } #modal-container > div, .status-deck { transition: all 0.3s ease-in-out; } /* Don't do this if there's a modal sheet (.sheet) */ :has(#modal-container .carousel):has(.status-deck):not( :has(.sheet, #compose-container) ) .status-deck { width: 350px; min-width: 0; } :has(#modal-container .carousel):has(.status-deck):not( :has(.sheet, #compose-container) ) #modal-container > div { left: 0; right: 350px; width: auto; } /* ✨ New */ /* .deck-backdrop > a { width: 100%; flex-grow: 0; } */ .deck-backdrop .media-modal-container + .status-deck:not(.deck-view-full) { /* display: block; */ width: 30%; /* min-width: 350px; */ position: static; z-index: 1; pointer-events: auto; user-select: auto; } .deck-backdrop .media-modal-container + .status-deck:not(.slide-in) { animation: appear 0.3s ease-in-out; } body:has(.media-modal-container + .status-deck) .media-post-link { display: none; } } /* COMPOSE BUTTON */ #compose-button { position: fixed; bottom: 16px; bottom: max(16px, env(safe-area-inset-bottom)); right: 16px; right: max(16px, env(safe-area-inset-right)); padding: 16px; background-color: var(--button-bg-blur-color); /* backdrop-filter: blur(16px); */ z-index: 10; box-shadow: 0 3px 8px -1px var(--drop-shadow-color), 0 10px 36px -4px var(--button-bg-blur-color); transition: all 0.3s ease-in-out; } .deck-container:has(header[hidden]) ~ #compose-button, #compose-button[hidden] { transform: translateY(200%); pointer-events: none; user-select: none; opacity: 0; } #compose-button .icon { transition: transform 0.3s ease-in-out; } #compose-button[hidden] .icon { transform: rotate3d(0, 0, 1, -25deg); } #compose-button:is(:hover, :focus) { background-color: var(--button-bg-color); filter: none; } #compose-button:active { transform: scale(0.95); transition: none; } #compose-button .icon { filter: drop-shadow(0 1px 2px var(--button-bg-color)); } @media (max-width: calc(40em - 1px)) { #app[data-shortcuts-view-mode='tab-menu-bar'] #compose-button { bottom: calc(16px + 52px); bottom: calc(16px + env(safe-area-inset-bottom) + 52px); } } /* SHEET */ .sheet { align-self: flex-end; display: flex; flex-direction: column; max-height: 90vh; max-height: 90dvh; /* overflow: hidden; */ background-color: var(--bg-color); width: 100%; max-width: calc(var(--main-width) - 50px - 16px); border-radius: 16px 16px 0 0; box-shadow: 0 -1px 32px var(--drop-shadow-color); animation: slide-up 0.3s var(--timing-function); /* border: 1px solid var(--outline-color); */ position: relative; } .sheet-max { max-width: none; height: 90vh; height: 90dvh; } @media (min-width: 40em) { .sheet { width: 90vw; width: 90dvw; } } .sheet .sheet-close { position: absolute; border-radius: 0; padding: 0; right: env(safe-area-inset-right); width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; z-index: 2; background-color: transparent; background-image: radial-gradient( circle, var(--close-button-bg-color) 0px 14px, transparent 14px ); color: var(--close-button-color); } .sheet .sheet-close.outer { margin-top: -44px; background-image: radial-gradient( circle, var(--bg-faded-color) 0px 13px, var(--outline-color) 13px 14px, transparent 14px ); } .sheet .sheet-close:is(:hover, :focus) { color: var(--close-button-hover-color); } .sheet .sheet-close:active { background-image: radial-gradient( circle, var(--close-button-bg-active-color) 0px 14px, transparent 14px ); } .sheet header { padding: 16px 16px 8px; padding-left: max(16px, env(safe-area-inset-left)); padding-right: max(16px, env(safe-area-inset-right)); user-select: none; } .sheet .sheet-close:not(.outer) + header { padding-right: max(44px, env(safe-area-inset-right)); } .sheet header :is(h1, h2, h3) { margin: 0; } .sheet header.header-grid { display: grid; grid-template-columns: 1fr auto; grid-gap: 8px; align-items: center; } .sheet main { overflow: auto; overflow-x: hidden; overscroll-behavior: contain; padding: 16px 16px; padding-left: max(16px, env(safe-area-inset-left)); padding-right: max(16px, env(safe-area-inset-right)); padding-bottom: max(16px, env(safe-area-inset-bottom)); } .sheet header + main { padding-top: 0; mask-image: linear-gradient(to bottom, transparent 0%, black 10px); } /* ICON */ .icon { flex-shrink: 0; display: inline-block; overflow: hidden; line-height: 0; svg { contain: none; width: 100%; height: 100%; } } /* TAG */ .tag { font-size: smaller; color: var(--bg-faded-color); background-color: var(--text-insignificant-color); padding: 2px 4px; border-radius: 4px; display: inline-block; margin: 4px; align-self: center; text-align: center; &.clickable { cursor: pointer; } } .tag .icon { vertical-align: middle; } .tag.collapsed { margin: 0; } .tag.insignificant { border: 1px solid var(--outline-color); color: var(--text-insignificant-color); background-color: var(--bg-faded-color); } .tag.danger { background-color: var(--red-color); } .tag.minimal { margin: 0; color: var(--text-insignificant-color); background-color: var(--bg-faded-color); text-shadow: 0 1px var(--bg-color); line-height: 1; } /* MENU POPUP */ .szh-menu-container { user-select: none; -webkit-touch-callout: none; -webkit-user-drag: none; } body > .szh-menu-container { position: fixed !important; z-index: 10; } .szh-menu-container:not(:empty) { inset: 0; inset: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left); } .szh-menu { padding: 8px 0; margin: 0; font-size: var(--text-size); background-color: var(--bg-color); border: 1px solid var(--outline-color); border-radius: 8px; box-shadow: 0 3px 16px -3px var(--drop-shadow-color); text-align: left; /* animation: appear-smooth 0.15s ease-in-out; */ width: 16em; max-width: 90vw; /* overflow: hidden; */ } .szh-menu[aria-label='Submenu'].menu-blur { background-color: var(--bg-blur-color); backdrop-filter: blur(4px); box-shadow: 0 3px 24px -3px var(--drop-shadow-color); } .szh-menu__header { margin: -8px 0 8px; padding: 8px 16px; color: var(--text-insignificant-color); font-size: 90%; background-color: var(--bg-faded-color); /* background-image: linear-gradient(to top, var(--bg-faded-color), transparent); */ text-shadow: 0 1px 0 var(--bg-color); line-height: 1.2; /* border-bottom: 1px solid var(--outline-color); */ border-radius: 8px 8px 0 0; } .szh-menu__header.plain { margin-bottom: 0; background-color: transparent; } .szh-menu__header * { vertical-align: middle; } .szh-menu.menu-emphasized { border-color: var(--outline-hover-color); box-shadow: 0 3px 16px -3px var(--drop-shadow-color), 0 3px 32px var(--drop-shadow-color), 0 3px 48px var(--drop-shadow-color); background-color: var(--bg-color); animation-duration: 0.3s; animation-timing-function: ease-in-out; width: auto; min-width: min(12em, 90vw); } .szh-menu .footer { margin: 8px 0 -8px; padding: 8px 16px; color: var(--text-insignificant-color); font-size: 90%; background-color: var(--bg-faded-color); text-shadow: 0 1px 0 var(--bg-color); line-height: 1.2; display: flex; gap: 8px; align-items: center; border-radius: 0 0 8px 8px; } .szh-menu .szh-menu__item { display: flex; gap: 8px; align-items: center; line-height: 1.1; padding: 8px 16px !important; /* transition: all 0.1s ease-in-out; */ text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .szh-menu .szh-menu__item--focusable { background-color: transparent; } .szh-menu .szh-menu__item span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } /* .szh-menu .szh-menu__item * { vertical-align: middle; } */ .szh-menu .szh-menu__item a { flex: 1; overflow: hidden; text-overflow: ellipsis; display: flex; gap: 8px; color: inherit; text-decoration: none; padding: 8px 16px !important; margin: -8px -16px !important; align-items: center; user-select: none; -webkit-touch-callout: none; } .szh-menu .szh-menu__item a.is-active { font-weight: bold; } .szh-menu .szh-menu__item .icon { opacity: 0.5; } .szh-menu .szh-menu__item:not(.szh-menu__item--disabled, .szh-menu__item--hover) { color: var(--text-color); } .szh-menu .szh-menu__item--hover:not(.menu-field) { color: var(--button-text-color); background-color: var(--button-bg-color); } .szh-menu__divider { background-color: var(--divider-color); margin-block: 4px; } .szh-menu .szh-menu__item .menu-grow { flex-grow: 1; text-overflow: ellipsis; overflow: hidden; } .szh-menu .menu-double-lines { white-space: normal !important; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden !important; } .szh-menu .menu-double-lines span { white-space: normal; line-height: inherit; font-size: inherit; } .szh-menu .menu-horizontal { display: grid; /* two columns only */ grid-template-columns: repeat(2, 1fr); } .szh-menu .menu-horizontal:has(> .szh-menu__item:only-child) { grid-template-columns: 1fr; } .szh-menu .menu-horizontal > .szh-menu__item:not(:only-child):first-child, .szh-menu .menu-horizontal > *:not(:only-child):first-child .szh-menu__item { padding-right: 4px !important; } .szh-menu .menu-horizontal > .szh-menu__item:not(:only-child):not(:first-child):not(:last-child), .szh-menu .menu-horizontal > *:not(:only-child):not(:first-child):not(:last-child) .szh-menu__item { padding-left: 8px !important; padding-right: 4px !important; } .szh-menu .menu-horizontal > .szh-menu__item:not(:only-child):last-child, .szh-menu .menu-horizontal > *:not(:only-child):last-child .szh-menu__item { padding-left: 8px !important; } .szh-menu .szh-menu__item .menu-shortcut { opacity: 0.5; font-weight: normal; } .szh-menu .szh-menu__item form { display: flex; flex: 1; gap: 8px; align-items: center; } .szh-menu .szh-menu__item form > input[type='text'] { flex-grow: 1; width: 100%; } .szh-menu .szh-menu__item--hover .danger-icon { color: var(--red-color); opacity: 1; } .szh-menu .szh-menu__item:not(.szh-menu__item--disabled):not( .szh-menu__item--hover ).danger { color: var(--red-text-color); } .szh-menu .szh-menu__item.danger:not(.szh-menu__item--disabled).szh-menu__item--hover { background-color: var(--red-text-color); } .szh-menu .szh-menu__item:not(.szh-menu__item--disabled):not( .szh-menu__item--hover ).danger .icon { opacity: 1; } .szh-menu { .menu-control-group-horizontal { display: grid; /* auto columns */ grid-template-columns: repeat(auto-fit, minmax(44px, 1fr)); .szh-menu__item { display: flex; flex-direction: column; padding: 8px !important; gap: 2px; .icon { opacity: 1; + span { font-size: 80%; /* line-height: 1.2; */ width: 100%; text-align: center; opacity: 0.5; text-overflow: clip; mask-image: linear-gradient(to left, transparent, black 16px); } } } } .menu-control-group-horizontal:first-child, li[aria-hidden='true'] + .menu-control-group-horizontal { margin-top: -8px; margin-bottom: -4px; .szh-menu__item { padding-block: 12px !important; } > [class^='szh-menu']:first-child { border-top-left-radius: 8px; } > [class^='szh-menu']:last-child { border-top-right-radius: 8px; } } } .szh-menu .szh-menu__item--type-checkbox:not(.szh-menu__item--disabled):not( .szh-menu__item--hover ) { .icon { opacity: 0.15; } &.szh-menu__item--checked { color: var(--link-color); .icon { opacity: 1; color: inherit; } } } .szh-menu .menu-wrap { display: flex; flex-wrap: wrap; } .szh-menu .menu-wrap > * { flex-grow: 1; flex-basis: 50%; } /* GLASS MENU */ .glass-menu { background-color: var(--bg-blur-color); backdrop-filter: blur(8px) saturate(3); border: var(--hairline-width) solid var(--bg-color); box-shadow: 0 3px 8px -1px var(--drop-shadow-color); text-shadow: 0 var(--hairline-width) var(--bg-color), 0 0 8px var(--bg-color); } .glass-menu .szh-menu__item--hover { background-color: var(--button-bg-blur-color); text-shadow: none; } /* CHAR COUNTER */ .char-counter { --dimension: 24px; min-width: var(--dimension); min-height: var(--dimension); position: relative; display: inline-block; &[hidden] { visibility: hidden; } * { pointer-events: none; } meter { appearance: none; position: relative; --border-width: 2px; --middle-circle-radius: calc(var(--dimension) / 2 - var(--border-width)); width: var(--dimension); height: var(--dimension); border-radius: 50%; --fill: calc(var(--percentage) * 1%); --color: var(--link-color); --middle-circle: radial-gradient( circle at 50% 50%, var(--bg-color) var(--middle-circle-radius), transparent var(--middle-circle-radius) ); background-image: var(--middle-circle), conic-gradient(var(--color) var(--fill), var(--outline-color) 0); transform: scale(0.7); transition: transform 0.2s ease-in-out; &::-webkit-meter-inner-element, &::-webkit-meter-bar, &::-webkit-meter-optimum-value, &::-webkit-meter-suboptimum-value, &::-webkit-meter-even-less-good-value { display: none; } &::-moz-meter-bar { background: transparent; } &.warning { --color: var(--orange-color); transform: scale(1); } &.danger { --color: var(--red-color); transform: scale(1); } &.explode { background-image: none; transform: scale(1); } &:is(.warning, .danger, .explode) + .counter { opacity: 1; color: var(--text-insignificant-color); } &:is(.danger, .explode) + .counter { opacity: 1; color: var(--red-color); } } .counter { line-height: 1; opacity: 0; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 12px; } } /* SHINY PILL */ :is(.shiny-pill, :root .toastify.shiny-pill) { pointer-events: auto; color: var(--link-text-color); font-weight: 500; text-shadow: 0 1px var(--bg-color); background-color: var(--bg-color); border: 2px solid var(--link-faded-color); box-shadow: 0 3px 16px var(--drop-shadow-color), 0 6px 16px -3px var(--drop-shadow-color); } :is(.shiny-pill, :root .toastify.shiny-pill):hover:not(:active) { color: var(--text-color); border-color: var(--link-color); filter: none !important; box-shadow: 0 3px 16px var(--drop-shadow-color), 0 6px 16px -3px var(--drop-shadow-color), 0 6px 16px var(--drop-shadow-color); } /* TOAST */ :root .toastify { user-select: none; padding: 8px 16px; border-radius: 44px; pointer-events: none; color: var(--button-text-color); text-shadow: 0 calc(var(--hairline-width) * -1) var(--drop-shadow-color); background-color: var(--button-bg-color); background-image: none; box-shadow: 0 3px 8px -1px var(--drop-shadow-color), 0 10px 36px -4px var(--button-bg-blur-color); text-align: center; } .toastify-bottom { margin-bottom: env(safe-area-inset-bottom); } /* TOAST - ALERT */ :root .toastify.alert { z-index: 1001; box-shadow: 0 8px 32px var(--text-insignificant-color); background-color: var(--bg-color); color: var(--text-color); cursor: pointer; pointer-events: auto; padding: 16px 32px; font-size: max(calc(16px * 1.1), var(--text-size)); text-align: center; line-height: 1.25; } :root .toastify.alert:is(:hover, :active) { background-color: var(--bg-faded-color); } /* AVATARS STACK */ .avatars-stack { display: flex; flex-wrap: wrap; gap: 4px; } /* I'm just feeling bored, so having fun here */ @media (hover: hover) { .avatars-stack > * img { transition: transform 0.3s ease-in-out; } .avatars-stack:hover > *:nth-of-type(odd) img { transform: rotate(15deg); } .avatars-stack:hover > *:nth-of-type(even) img { transform: rotate(-15deg); } } /* 404 */ #not-found-page { display: flex; align-items: center; justify-content: center; text-align: center; overflow: hidden; cursor: default; color: var(--text-insignificant-color); background-image: radial-gradient( circle at 50% 50%, var(--bg-color) 25%, var(--bg-faded-color) ); text-shadow: 0 1px var(--bg-color); } /* ACCOUNT STATUSES */ @keyframes peekaboo-header { from { opacity: 0; transform: translateY(10%); } to { opacity: 1; transform: translateY(0); } } @supports (animation-timeline: scroll()) { .header-account { animation: peekaboo-header 1s linear both; animation-timeline: scroll(); animation-range: 0 150px; } } /* LINK LISTS? */ ul.link-list { list-style: none; padding: 16px; margin: 0; display: flex; flex-direction: column; gap: 1px; } ul.link-list li { padding: 0; margin: 0; } ul.link-list li a { --radius: 8px; display: block; background-color: var(--bg-faded-color); line-height: 1.25; padding: 12px; text-decoration: none; line-height: 1.4; font-weight: 500; display: flex; align-items: center; gap: 8px; .count { font-size: 80%; display: inline-block; color: var(--text-insignificant-color); min-width: 16px; min-height: 16px; padding: 4px; background-color: var(--bg-color); border-radius: 4px; @media (min-width: 40em) { background-color: var(--bg-faded-color); } } } ul.link-list li:first-child a { border-top-left-radius: var(--radius); border-top-right-radius: var(--radius); } ul.link-list li:last-child a { border-bottom-left-radius: var(--radius); border-bottom-right-radius: var(--radius); } ul.link-list li a:is(:hover, :focus) { color: var(--text-color); } ul.link-list li a:active { filter: brightness(0.9); } ul.link-list li a * { vertical-align: middle; } ul.link-list li a .icon { flex-shrink: 0; } @media (min-width: 40em) { ul.link-list li a { background-color: var(--bg-color); } } /* NAV MENU BUTTON */ .nav-menu-button.with-avatar { position: relative; } .nav-menu-button:is(:hover, :focus):not(:active) { filter: none !important; } .nav-menu-button .avatar { box-shadow: 0 0 0 2px var(--bg-color), 0 0 0 4px var(--link-light-color) !important; } .nav-menu-button:is(:hover, :focus, .active) .avatar { box-shadow: 0 0 0 2px var(--bg-color), 0 0 0 4px var(--link-color) !important; } .nav-menu-button.with-avatar .icon { position: absolute; bottom: 4px; right: 8px; background-color: var(--bg-color); border-radius: 2px; } .nav-menu-button.with-avatar:hover:not(:active, .active) .icon { transform: translateY(-1px); } /* COLUMNS */ #columns { display: flex; width: 100vw; overflow-y: hidden; overflow-x: scroll; scroll-snap-type: x mandatory; scroll-behavior: smooth; /* scrollbar-width: none; */ overscroll-behavior: contain; overscroll-behavior-x: contain; /* This `transform` fixes horizontal scrolling for pointer devices on iPad */ transform: translateZ(0); } /* #columns::-webkit-scrollbar { display: none; } */ #columns > * { overscroll-behavior: auto; scroll-snap-align: left; scroll-snap-stop: always; overscroll-behavior: auto; flex-basis: min(100vw, 360px); flex-shrink: 0; box-shadow: -1px 0 var(--bg-color), -2px 0 var(--drop-shadow-color), -3px 0 var(--bg-color); } #columns:has(> :nth-child(3)) > *:nth-child(even), #columns:has(> :nth-child(3)) > *:nth-child(even) .timeline-deck > header .header-grid { background-color: var(--bg-blur-color); } #columns > .deck-container > .timeline-deck { content-visibility: auto; } #columns .header-grid input { pointer-events: none; } #columns { /* Any buttons except nav menu button on first header-side, on 1st column */ .deck-container:first-of-type .header-grid .header-side:first-of-type > *:not(.nav-menu-button), /* Any buttons on last header-side, on 1st column */ .deck-container:first-of-type .header-grid .header-side:last-of-type > *, /* Any buttons on any header-side, on columns after 1st */ .deck-container:not(:first-of-type) .header-grid .header-side > * { display: none; } } @media (min-width: 40em) { #columns { /* gap: 16px; */ /* padding: 0 16px; */ /* background-color: var(--bg-faded-color); */ height: 100vh; height: 100dvh; justify-content: stretch; align-items: stretch; } #columns > * { padding: 0 16px; border-inline: var(--hairline-width) solid var(--bg-faded-color); /* border-radius: 16px; */ /* box-shadow: -4px 0 16px -8px var(--drop-shadow-color); */ height: unset; /* background-color: var(--bg-faded-blur-color); */ /* backdrop-filter: blur(16px) saturate(3); */ /* background-image: linear-gradient( 160deg, transparent 20%, var(--bg-color), transparent 75% ); */ /* position: sticky; left: 0; */ /* transition: all 0.3s ease-out; */ } /* #columns > *:nth-child(2) { left: 5%; } #columns > *:nth-child(3) { left: 10%; } #columns > *:nth-child(4) { left: 15%; } #columns > *:nth-child(5) { left: 20%; } #columns > *:nth-child(6) { left: 25%; } #columns > *:nth-child(7) { left: 30%; } #columns > *:nth-child(8) { left: 35%; } #columns > *:nth-child(9) { left: 40%; } #columns > *:nth-child(10) { left: 45%; } #columns > *:focus { z-index: 1; box-shadow: 0 0 32px var(--drop-shadow-color), 0 0 32px var(--drop-shadow-color); } */ /* #columns:has(> *:focus) > *:not(:focus) > * { filter: opacity(0.8); } */ #columns > *:focus-visible, #columns > *:has(:focus-visible) { /* box-shadow: 0 4px 16px var(--drop-shadow-color), 0 4px 16px var(--drop-shadow-color); */ /* border-color: var(--outline-hover-color); */ z-index: 1; box-shadow: inset 0 0 0 1px var(--outline-hover-color); } #columns .timeline:not(.flat) > li:has(.status-link.is-active), #columns .timeline:not(.flat) > li:not(:has(.status-carousel)):has(+ li .status-link.is-active), #columns .timeline:not(.flat) > li:not(:has(.status-carousel)):has(.status-link.is-active) + li { transform: none; } #columns .timeline-deck > header { margin: 0; } #columns .timeline-deck > header[hidden] { transform: none; pointer-events: auto; } #columns li.timeline-item-carousel { width: auto; transform: none; } } /* FILTER BAR */ .filter-bar { padding: 8px 16px; background-color: var(--bg-faded-color); display: flex; gap: 8px; overflow-x: auto; mask-image: linear-gradient( to right, transparent, black 16px, black calc(100% - 16px), transparent ); align-items: center; transition: opacity 0.3s ease-out; &.expandable:not(#columns &) { @media (min-width: 40em) { width: 95vw; max-width: calc(320px * 3.3); transform: translateX(calc(-50% + var(--main-width) / 2)); } } &.loading, .loading > & { pointer-events: none; opacity: 0.5; } .filter-field { flex-shrink: 0; padding: 8px 16px; border-radius: 999px; color: var(--text-color); background-color: var(--bg-color); background-image: none; border: 2px solid transparent; margin: 0; /* appearance: none; */ line-height: 1; font-size: 90%; display: flex; gap: 8px; > .icon { color: var(--link-color); } &:placeholder-shown { color: var(--text-insignificant-color); } &:is(:hover, :focus-visible) { border-color: var(--link-light-color); } &:focus { outline-color: var(--link-light-color); } &.is-active { border-color: var(--link-color); box-shadow: inset 0 0 8px var(--link-faded-color); } :is(input, select) { background-color: transparent; background-image: none; border: 0; padding: 0; margin: 0; color: inherit; font-size: inherit; line-height: inherit; appearance: none; border-radius: 0; box-shadow: none; outline: none; } input[type='month'] { min-width: 6em; &::-webkit-calendar-picker-indicator { /* replace icon with triangle */ opacity: 0.5; background-image: url('data:image/svg+xml;utf8,'); } @media (prefers-color-scheme: dark) { &::-webkit-calendar-picker-indicator { filter: invert(1); } } } } } .filter-bar.centered { justify-content: center; } @media (min-width: 40em) { .filter-bar { background-color: transparent; } } .filter-bar > a:not(.filter-clear) { padding: 8px 16px; border-radius: 999px; background-color: var(--bg-color); color: var(--link-color); text-decoration: none; white-space: nowrap; border: 2px solid transparent; transition: border-color 0.3s ease-out; display: inline-flex; align-items: center; gap: 8px; } .filter-bar > a:focus-visible { border-color: var(--link-light-color); } @media (hover: hover) { .filter-bar > a:hover { border-color: var(--link-light-color); } } .filter-bar > a > * { vertical-align: middle; } .filter-bar > a.is-active { border-color: var(--link-color); box-shadow: inset 0 0 8px var(--link-faded-color); } .filter-bar > a > .filter-count { font-size: 80%; display: inline-block; color: var(--text-insignificant-color); min-width: 16px; min-height: 16px; padding: 4px; margin: -4px -8px -4px 0; background-color: var(--bg-faded-color); border-radius: 999px; } /* NOTIFICATION PEEK */ .notification-peek .notification { padding-inline: 0 !important; } /* OTHERS */ @media (min-width: 40em) { html, body { background-color: var(--bg-faded-color); } .deck-container { background-color: var(--bg-faded-color); } #app { display: flex; } .deck-container { transition: transform 0.4s var(--timing-function); } .deck-container:has(~ .deck-backdrop .deck) { transition: transform 0.4s ease-out; transform: translate3d(-5vw, 0, 0); } .deck-backdrop .deck { /* width: 50%; min-width: var(--main-width); */ border-left: 1px solid var(--divider-color); } .timeline-deck { border: 0; background-color: transparent; } .timeline-deck > header { --margin-top: 8px; top: var(--margin-top); margin-inline: 8px; } .timeline-deck > header .header-grid { border-bottom: 0; border-radius: 16px; background-color: var(--bg-faded-blur-color); backdrop-filter: blur(16px); background-image: none; border-radius: 16px; min-height: 4em; } .timeline-deck > header[hidden] { transform: translate3d(0, calc((100% + var(--margin-top)) * -1), 0); } .deck > header { text-shadow: 0 1px var(--bg-color); form { text-shadow: none; } } .deck > header h1 { font-size: 1.5em; } .updates-button { margin-top: 24px; } .timeline:not(.flat) > li { --item-radius: 16px; border: 1px solid var(--divider-color); margin: 16px 0; background-color: var(--bg-color); border-radius: var(--item-radius); overflow: hidden; box-shadow: 0px 1px var(--bg-blur-color); transition: transform 0.4s var(--timing-function); --back-transition: transform 0.4s ease-out; &:is(:empty, :has(> a:empty)) { display: none; } } .timeline:not(.flat) > li > a { border-radius: inherit; } .timeline:not(.flat) > li:not(:has(.status-carousel)) { transform: translate3d(0, 0, 0); } .timeline:not(.flat) > li:not(.timeline-item-container-end, .timeline-item-container-middle):has( .status-badge:not(:empty) ) { border-top-right-radius: 8px; } .timeline:not(.flat) > li:has(.status-link.is-active) { transition: var(--back-transition); transform: translate3d(-2.5vw, 0, 0); } .timeline:not(.flat) > li.timeline-item-container:has(.status-link.is-active) { border-top-left-radius: var(--item-radius); border-bottom-left-radius: var(--item-radius); } .timeline:not(.flat) > li:not(:has(.status-carousel)):has(+ li .status-link.is-active), .timeline:not(.flat) > li:not(:has(.status-carousel)):has(.status-link.is-active) + li { transition: var(--back-transition); transform: translate3d(-1.25vw, 0, 0); } .timeline:not(.flat) > li.timeline-item-container:not(:has(.status-carousel)):has( + li .status-link.is-active ) { border-top-left-radius: var(--item-radius); } .timeline:not(.flat) > li.timeline-item-container:not(:has(.status-carousel)):has( .status-link.is-active ) + li.timeline-item-container { border-bottom-left-radius: var(--item-radius); } .box { padding: 32px; } /* :is(.carousel-top-controls, .carousel-controls) { padding: 32px; } */ li.timeline-item-carousel { width: 95vw; max-width: calc(320px * 3.3); transform: translateX(calc(-50% + var(--main-width) / 2)); } }