mirror of
https://github.com/cheeaun/phanpy.git
synced 2025-02-25 17:28:54 +01:00
88 lines
2 KiB
CSS
88 lines
2 KiB
CSS
|
.media-post {
|
||
|
--item-radius: 16px;
|
||
|
position: relative;
|
||
|
animation: appear-smooth 1s ease-out;
|
||
|
|
||
|
&:is(.filtered, .has-spoiler) :is(img, video) {
|
||
|
filter: blur(32px);
|
||
|
image-rendering: crisp-edges;
|
||
|
image-rendering: pixelated;
|
||
|
animation: none !important;
|
||
|
}
|
||
|
|
||
|
&.filtered[data-filtered-text]:before,
|
||
|
&.has-spoiler[data-spoiler-text]:before {
|
||
|
pointer-events: none;
|
||
|
content: attr(data-spoiler-text);
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
z-index: 1;
|
||
|
background-color: var(--bg-blur-color);
|
||
|
margin: 8px;
|
||
|
padding: 4px 6px;
|
||
|
border-radius: calc(var(--item-radius) / 2);
|
||
|
font-size: 90%;
|
||
|
border: var(--hairline-width) dashed var(--bg-color);
|
||
|
|
||
|
> * {
|
||
|
pointer-events: none;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.media {
|
||
|
border-radius: var(--item-radius);
|
||
|
overflow: hidden;
|
||
|
position: relative;
|
||
|
display: block;
|
||
|
aspect-ratio: 1 !important;
|
||
|
|
||
|
&:before {
|
||
|
position: absolute;
|
||
|
inset: 0;
|
||
|
content: '';
|
||
|
border: 1px solid var(--outline-color);
|
||
|
border-radius: inherit;
|
||
|
}
|
||
|
|
||
|
&:not(.media-audio) {
|
||
|
background-color: var(--average-color, var(--media-bg-color));
|
||
|
}
|
||
|
|
||
|
@media (hover: hover) {
|
||
|
&:hover {
|
||
|
--drop-shadow: var(--drop-shadow-color);
|
||
|
box-shadow: 0 8px 16px -4px var(--drop-shadow),
|
||
|
0 4px 8px var(--drop-shadow);
|
||
|
|
||
|
@media (prefers-color-scheme: dark) {
|
||
|
--drop-shadow: var(--link-color);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
&:active:not(:has(button:active)) {
|
||
|
box-shadow: none;
|
||
|
filter: brightness(0.8);
|
||
|
transform: scale(0.99);
|
||
|
}
|
||
|
|
||
|
video,
|
||
|
img,
|
||
|
audio {
|
||
|
border-radius: 16px;
|
||
|
/* object-fit: scale-down; */
|
||
|
object-fit: cover;
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
vertical-align: top;
|
||
|
}
|
||
|
|
||
|
&:is(:hover, :focus) img {
|
||
|
/* Less delay here to make it feel more responsive */
|
||
|
animation: position-object 5s ease-in-out 0.3s 5;
|
||
|
animation-duration: var(--anim-duration, 5s);
|
||
|
}
|
||
|
}
|
||
|
}
|