autonomous.contact/public/base.css

609 lines
13 KiB
CSS
Raw Normal View History

/* Dark mode default */
:root {
2026-03-03 20:32:45 -08:00
--base-color: #234;
--bg: hsl(from var(--base-color) h 20% 7.5%);
--bg-darker: hsl(from var(--base-color) h 20% 5%);
--bg-lighter: hsl(from var(--base-color) h 20% 10%);
--blur-radius: 8px;
--text: hsl(from var(--base-color) h 5% 100%);
--accent: hsl(from var(--base-color) h clamp(0, calc(s + 10), 100) clamp(0, calc(l + 20), 100));
--border-subtle: hsl(from var(--base-color) h 50% 25%);
--border-normal: hsl(from var(--base-color) h 50% 50%);
--border-highlight: hsl(from var(--base-color) h 50% 75%);
2025-09-09 15:32:07 -07:00
--icon-scale: 1;
2025-10-25 19:44:07 -07:00
--border-radius: 4px;
}
@media (prefers-color-scheme: light) {
:root {
--bg: hsl(from var(--base-color) h 20% 93%);
--bg-darker: hsl(from var(--base-color) h 20% 88%);
--bg-lighter: hsl(from var(--base-color) h 20% 98%);
--text: hsl(from var(--base-color) h 5% 5%);
--accent: hsl(from var(--base-color) h calc(s + 10) calc(l + 20));
--border-subtle: hsl(from var(--base-color) h 50% 90%);
--border-normal: hsl(from var(--base-color) h 50% 50%);
--border-highlight: hsl(from var var(--base-color) h 50% 25%);
}
}
/* Box sizing rules */
*,
*::before,
*::after {
box-sizing: border-box;
}
/* Remove default margin in favour of better control in authored CSS */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
margin-block-end: 0;
}
body {
min-height: 100vh;
line-height: 1.5;
}
h1,
h2,
h3,
h4,
button,
input,
label {
line-height: 1.1;
}
h1,
h2,
h3,
h4 {
text-wrap: balance;
}
a:not([class]) {
text-decoration-skip-ink: auto;
color: currentColor;
}
img,
picture {
max-width: 100%;
display: block;
}
input,
button,
textarea,
select {
font-family: inherit;
font-size: inherit;
}
details>summary {
display: block;
position: relative;
padding-left: 2rem;
cursor: pointer;
user-select: none;
}
details>summary:before {
content: "";
border-width: 0.6rem;
border-style: solid;
border-color: transparent transparent transparent rgba(from var(--border-subtle) r g b / 0.9);
position: absolute;
top: 0.15rem;
left: 0;
transform: rotate(0);
transform-origin: 0.3rem 50%;
transition: 0.25s transform ease;
}
details[open]>summary:before {
transform: rotate(90deg);
}
details>summary::-webkit-details-marker {
display: none;
}
form input,
form textarea {
width: 100%;
color: inherit;
border-radius: var(--border-radius);
border: 1px solid rgba(128, 128, 128, 0.2);
resize: none;
background: rgba(0, 0, 0, 0.01);
padding: 0.5rem;
font-size: large;
}
/* Make sure textareas without a rows attribute are not tiny */
textarea:not([rows]) {
min-height: 10em;
}
/* Anything that has been anchored to should have extra scroll margin */
:target {
scroll-margin-block: 5ex;
}
* {
margin: 0;
padding: 0;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
body {
font-family: sans-serif;
color: var(--text);
background-color: var(--bg);
display: flex;
flex-direction: column;
height: 100vh;
}
#background-container {
position: fixed;
top: 0;
right: 0;
left: 0;
bottom: 0;
z-index: -1;
}
main {
position: relative;
width: 100%;
height: 100%;
display: grid;
grid-template-columns: auto 1fr;
}
@media screen and (max-width: 1200px) {
main {
grid-template-columns: auto;
}
}
input[type="text"]:focus,
textarea:focus {
border-color: rgb(from var(--border-highlight) r g b / 60%);
outline: 0;
-webkit-box-shadow:
inset 0 1px 1px rgba(0, 0, 0, 0.075),
0 0 2px rgb(from var(--border-highlight) r g b / 60%);
box-shadow:
inset 0 1px 1px rgba(0, 0, 0, 0.075),
0 0 2px rgb(from var(--border-highlight) r g b / 60%);
}
.avatar-container {
display: block;
margin: 0.5rem auto;
width: 3rem;
height: 3rem;
border-radius: var(--border-radius);
overflow: hidden;
}
.avatar-container.inline {
display: inline-block;
margin: 0.5rem;
}
.avatar-container.medium {
width: 4.5rem;
height: 4.5rem;
}
.avatar-container.large {
width: 6rem;
height: 6rem;
}
.avatar-container.x-large {
width: 9rem;
height: 9rem;
}
.avatar-container.xx-large {
width: 12rem;
height: 12rem;
}
.avatar-container img {
height: 100%;
width: 100%;
max-width: none;
object-fit: cover;
}
.clickable {
cursor: pointer;
}
.resizable {
resize: horizontal;
overflow: hidden;
border-right: 4px solid #444;
}
.mockup {
position: relative;
}
.mockup::after {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: repeating-linear-gradient(-55deg,
rgba(0, 0, 0, 0.25) 0px,
rgba(0, 0, 0, 0.25) 20px,
rgba(255, 177, 1, 0.25) 20px,
rgba(255, 177, 1, 0.25) 40px);
}
.collapsed {
height: 0;
}
input[collapse-toggle] {
display: none;
visibility: hidden;
}
label:has(input[collapse-toggle]) {
display: block;
2025-09-21 18:29:37 -07:00
max-width: fit-content;
cursor: pointer;
border: 1px solid var(--text);
border-radius: var(--border-radius);
padding: 0.5rem;
margin-bottom: 2rem;
}
input[collapse-toggle]+.collapsible,
label:has(input[collapse-toggle])+.collapsible {
transition: all 0.33s;
height: 0;
overflow: hidden;
}
input[collapse-toggle]:checked+.collapsible,
label:has(input[collapse-toggle]:checked)+.collapsible {
height: 100%;
}
form div {
position: relative;
display: flex;
margin-bottom: 1.5em;
}
form label.placeholder {
position: absolute;
top: 0;
font-size: large;
margin: 10px;
padding: 0 10px;
-webkit-transition:
top 0.2s ease-in-out,
font-size 0.2s ease-in-out;
transition:
top 0.2s ease-in-out,
font-size 0.2s ease-in-out;
}
form input:focus~label.placeholder,
form input:valid~label.placeholder {
top: -1.6rem;
font-size: small;
border: 1px solid rgba(128, 128, 128, 0.2);
border-bottom: 0;
}
form input:focus {
outline: none;
}
form button {
width: 100%;
padding: 20px;
border: 1px solid var(--text);
font-size: 20px;
background-color: var(--bg);
color: var(--text);
margin-top: 1rem;
}
form button.primary {
background-color: var(--accent);
}
button {
background: inherit;
color: inherit;
padding: 0.5rem;
border: 1px solid var(--text);
border-radius: var(--border-radius);
cursor: pointer;
}
button.primary {
border: 1px solid var(--accent);
}
[data-requires-permission] {
visibility: hidden;
opacity: 0;
height: 0;
}
body[data-perms*="self.read"] [data-requires-permission="self.read"],
body[data-perms*="self.write"] [data-requires-permission="self.write"],
body[data-perms*="channels.create"] [data-requires-permission="channels.create"],
body[data-perms*="channels.read"] [data-requires-permission="channels.read"],
body[data-perms*="channels.write"] [data-requires-permission="channels.write"],
body[data-perms*="events.create.blurb"] [data-requires-permission="events.create.blurb"],
body[data-perms*="events.read.blurb"] [data-requires-permission="events.read.blurb"],
body[data-perms*="events.write.blurb"] [data-requires-permission="events.write.blurb"],
body[data-perms*="events.create.chat"] [data-requires-permission="events.create.chat"],
body[data-perms*="events.read.chat"] [data-requires-permission="events.read.chat"],
body[data-perms*="events.write.chat"] [data-requires-permission="events.write.chat"],
body[data-perms*="events.create.essay"] [data-requires-permission="events.create.essay"],
body[data-perms*="events.read.essay"] [data-requires-permission="events.read.essay"],
body[data-perms*="events.write.essay"] [data-requires-permission="events.write.essay"],
body[data-perms*="events.create.post"] [data-requires-permission="events.create.post"],
body[data-perms*="events.read.post"] [data-requires-permission="events.read.post"],
body[data-perms*="events.write.post"] [data-requires-permission="events.write.post"],
body[data-perms*="users.read"] [data-requires-permission="users.read"],
body[data-perms*="users.write"] [data-requires-permission="users.write"],
body[data-perms*="files.write.own"] [data-requires-permission="files.write.own"] {
visibility: visible;
opacity: 1;
height: unset;
}
2025-08-21 21:30:53 -07:00
.audio-container {
position: relative;
width: 100%;
max-width: 800px;
overflow: hidden;
font-size: small;
padding: 0.25rem;
border: 1px solid color-mix(in srgb, var(--accent) 15%, transparent);
white-space-collapse: discard;
}
.audio-container audio {
width: 100%;
margin-bottom: -5px;
}
.audio-container .audio-player-display-container {
width: 100%;
height: 3rem;
margin-bottom: 0.5rem;
display: flex;
justify-content: center;
align-items: start;
}
.audio-container .audio-player-display-container canvas {
width: 100%;
height: 100%;
color: var(--accent);
background: color-mix(in srgb, var(--accent) 20%, transparent);
}
.audio-container .enhanced-audio-player-container {
opacity: 0;
visibility: hidden;
display: none;
}
.audio-container[data-audio-player] .enhanced-audio-player-container {
opacity: 1;
visibility: visible;
display: block;
}
.audio-container .audio-controls-container .blank {
width: 100%;
max-width: 100px;
}
.audio-container .audio-controls-container .progress-container {
width: 100%;
display: flex;
justify-content: space-between;
align-content: center;
2025-08-21 21:30:53 -07:00
text-align: center;
padding: 0 0.5rem;
}
.audio-container .audio-controls-container .progress-container label[for="progress"] {
display: block;
margin-top: -0.5rem;
margin-bottom: 0.25rem;
}
.audio-container .audio-controls-container .progress-container .time-container {
text-align: center;
}
.audio-container .audio-controls-container .progress-container .slider-container {
width: 80%;
padding: 0 1rem;
max-width: 800px;
}
.audio-container .audio-controls-container .progress-container .slider-container input[name="progress"] {
2025-08-21 21:30:53 -07:00
width: 100%;
}
.audio-container .audio-controls-container .buttons-container {
display: flex;
justify-content: space-between;
align-content: center;
2025-08-21 21:30:53 -07:00
padding: 0 0.5rem;
}
.audio-container .audio-controls-container .blank {
align-content: center;
}
2025-08-21 21:30:53 -07:00
.audio-container .audio-controls-container .volume {
position: relative;
width: 100%;
max-width: 100px;
overflow: hidden;
}
2025-08-21 21:30:53 -07:00
@media screen and (max-width: 480px) {
.audio-container .audio-controls-container .blank {
width: auto;
2025-08-21 21:30:53 -07:00
}
.audio-container .audio-controls-container .volume {
max-width: 50px;
2025-08-21 21:30:53 -07:00
}
}
.audio-container .audio-controls-container input[type="range"] {
--c: var(--accent);
/* active color */
--g: 4px;
/* the gap */
--l: 2px;
/* line thickness*/
--s: 15px;
/* thumb size*/
width: 100%;
height: var(--s);
/* needed for Firefox*/
--_c: color-mix(in srgb, var(--c), #000 var(--p, 0%));
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
background: none;
cursor: pointer;
overflow: hidden;
2025-08-21 21:30:53 -07:00
}
2025-08-21 21:30:53 -07:00
.audio-container .audio-controls-container input[type="range"]:focus-visible,
.audio-container .audio-controls-container input[type="range"]:hover {
--p: 25%;
2025-08-21 21:30:53 -07:00
}
2025-08-21 21:30:53 -07:00
.audio-container .audio-controls-container input[type="range"]:active,
.audio-container .audio-controls-container input[type="range"]:focus-visible {
--_b: var(--s);
2025-08-21 21:30:53 -07:00
}
2025-08-21 21:30:53 -07:00
/* chromium */
.audio-container .audio-controls-container input[type="range"]::-webkit-slider-thumb {
height: var(--s);
aspect-ratio: 1;
border-radius: 50%;
box-shadow: 0 0 0 var(--_b, var(--l)) inset var(--_c);
border-image: linear-gradient(90deg, var(--_c) 50%, #ababab 0) 0 1 / calc(50% - var(--l) / 2) 100vw/0 calc(100vw + var(--g));
-webkit-appearance: none;
appearance: none;
transition: 0.2s;
2025-08-21 21:30:53 -07:00
}
2025-08-21 21:30:53 -07:00
/* Firefox */
.audio-container .audio-controls-container input[type="range"]::-moz-range-thumb {
height: var(--s);
width: var(--s);
background: none;
border-radius: 50%;
box-shadow: 0 0 0 var(--_b, var(--l)) inset var(--_c);
border-image: linear-gradient(90deg, var(--_c) 50%, #ababab 0) 0 1 / calc(50% - var(--l) / 2) 100vw/0 calc(100vw + var(--g));
-moz-appearance: none;
appearance: none;
transition: 0.2s;
}
@supports not (color: color-mix(in srgb, red, red)) {
.audio-container .audio-controls-container input[type="range"] {
--_c: var(--c);
}
2025-08-21 21:30:53 -07:00
}
.audio-container .audio-controls-container .volume label[for="volume"] {
position: absolute;
left: 0;
}
.audio-container .audio-controls-container .audio-control {
cursor: pointer;
}
.audio-container .audio-controls-container .audio-control .icon.play {
opacity: 1;
display: block;
}
2025-08-21 21:30:53 -07:00
.audio-container .audio-controls-container .audio-control .icon.pause {
opacity: 0;
display: none;
}
.audio-container[data-playing] .audio-controls-container .audio-control .icon.play {
opacity: 0;
display: none;
}
2025-08-21 21:30:53 -07:00
.audio-container[data-playing] .audio-controls-container .audio-control .icon.pause {
opacity: 1;
display: block;
}
/* === GLOW EFECTO === from: https://codepen.io/andrewuru/pen/Byjdgrb */
.glow {
position: absolute;
inset: 0;
background: radial-gradient(circle at var(--x, 50%) var(--y, 50%),
hsla(var(--accent), 100%, 60%, 0.4),
transparent 70%);
mix-blend-mode: screen;
pointer-events: none;
filter: blur(calc(2 * var(--blur-radius)));
}
.html-from-markdown {
padding: 2em;
}
.inline {
display: inline-block !important;
}