/* Can't use this yet because custom-media doesn't propagate to other CSS files yet, in Vite */ @custom-media --viewport-medium (min-width: 40em); :root { --sai-top: env(safe-area-inset-top); --sai-right: env(safe-area-inset-right); --sai-bottom: env(safe-area-inset-bottom); --sai-left: env(safe-area-inset-left); --text-size: 16px; --main-width: 40em; text-size-adjust: none; --hairline-width: 1px; --monospace-font: ui-monospace, 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, Courier, monospace; --blue-color: royalblue; --purple-color: blueviolet; --purple-fg-color: color-mix( in srgb-linear, var(--purple-color) 60%, var(--text-color) 40% ); --purple-bg-color: color-mix(in srgb, var(--purple-color) 10%, transparent); --green-color: darkgreen; --orange-color: darkorange; --orange-light-bg-color: color-mix( in srgb, var(--orange-color) 20%, transparent ); --orange-fg-color: color-mix( in srgb-linear, var(--orange-color) 60%, var(--text-color) 40% ); --orange-bg-color: color-mix(in srgb, var(--orange-color) 10%, transparent); --red-color: orangered; --red-text-color: color-mix( in srgb-linear, var(--red-color) 60%, var(--text-color) 40% ); --red-bg-color: color-mix(in lch, var(--red-color) 40%, transparent); --bg-color: #fff; --bg-faded-color: #f0f2f5; --bg-blur-color: #fff9; --bg-faded-blur-color: #f0f2f599; --text-color: #1c1e21; --text-insignificant-color: #1c1e2199; --link-color: var(--blue-color); --link-bg-color: #4169e122; --link-light-color: #4169e199; --link-faded-color: #4169e155; --link-bg-hover-color: #f0f2f599; --link-visited-color: mediumslateblue; --link-text-color: color-mix( in lch, var(--link-color) 60%, var(--text-color) 40% ); --focus-ring-color: var(--link-color); --button-bg-color: var(--blue-color); --button-bg-blur-color: #4169e1aa; --button-text-color: white; --button-plain-bg-hover-color: rgba(128, 128, 128, 0.1); --reblog-color: var(--purple-color); --reblog-faded-color: #892be220; --group-color: var(--green-color); --group-faded-color: #00640020; --reply-to-color: var(--orange-color); --reply-to-text-color: #b36200; --favourite-color: var(--red-color); --reply-to-faded-color: #ffa60020; --hashtag-color: LightSeaGreen; --hashtag-faded-color: color-mix( in srgb, var(--hashtag-color) 15%, transparent ); --hashtag-text-color: color-mix( in lch, var(--hashtag-color) 40%, var(--text-color) 60% ); --outline-color: rgba(128, 128, 128, 0.2); --outline-hover-color: rgba(128, 128, 128, 0.7); --divider-color: rgba(0, 0, 0, 0.1); --backdrop-color: rgba(0, 0, 0, 0.1); --backdrop-darker-color: rgba(0, 0, 0, 0.25); --backdrop-solid-color: #eee; --img-bg-color: rgba(128, 128, 128, 0.2); --loader-color: #1c1e2199; --comment-line-color: #e5e5e5; --drop-shadow-color: rgba(0, 0, 0, 0.15); --close-button-bg-color: rgba(0, 0, 0, 0.1); --close-button-bg-active-color: rgba(0, 0, 0, 0.2); --close-button-color: rgba(0, 0, 0, 0.5); --close-button-hover-color: rgba(0, 0, 0, 1); --private-note-text-color: var(--text-color); --private-note-bg-color: color-mix(in srgb, yellow 20%, var(--bg-color)); --private-note-border-color: rgba(0, 0, 0, 0.2); /* Media colors won't change based on color scheme */ --media-fg-color: #f0f2f5; --media-bg-color: #242526; --media-outline-color: color-mix(in lch, var(--media-fg-color), transparent); --timing-function: cubic-bezier(0.3, 0.5, 0, 1); --spring-timing-funtion: cubic-bezier(0.175, 0.885, 0.32, 1.275); --min-dimension: 88px; } @media (min-resolution: 2dppx) { :root { --hairline-width: 0.5px; } } @media (prefers-color-scheme: dark) { :root { --blue-color: CornflowerBlue; --purple-color: #b190f1; --green-color: lightgreen; --orange-color: orange; --bg-color: #242526; --bg-faded-color: #18191a; --bg-blur-color: #0009; --bg-faded-blur-color: #18191a99; --text-color: #f0f2f5; --text-insignificant-color: #f0f2f599; --link-light-color: #6494ed99; --link-faded-color: #6494ed88; --link-bg-hover-color: #34353799; --link-visited-color: color-mix( in lch, mediumslateblue 70%, var(--text-color) 30% ); --reblog-faded-color: #b190f141; --reply-to-text-color: var(--reply-to-color); --reply-to-faded-color: #ffa60017; --divider-color: rgba(255, 255, 255, 0.1); --bg-blur-color: #24252699; --backdrop-color: rgba(0, 0, 0, 0.5); --backdrop-solid-color: #111; --loader-color: #f0f2f599; --comment-line-color: #565656; --drop-shadow-color: rgba(0, 0, 0, 0.5); --close-button-bg-color: rgba(255, 255, 255, 0.2); --close-button-bg-active-color: rgba(255, 255, 255, 0.15); --close-button-color: rgba(255, 255, 255, 0.5); --close-button-hover-color: rgba(255, 255, 255, 1); --private-note-border-color: rgba(255, 255, 255, 0.2); } } *, *::before, *::after { box-sizing: border-box; } [dir] { text-align: start; } html { text-size-adjust: 100%; } body { font-family: ui-rounded, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif; font-size: var(--text-size); word-wrap: break-word; overflow-wrap: break-word; } /* Prevent pull-to-refresh on Chrome PWA */ @media (display-mode: standalone) { html, body { overscroll-behavior-y: none; } } a { color: var(--link-color); text-decoration-color: var(--link-faded-color); text-decoration-thickness: 2px; text-underline-offset: 2px; overflow-wrap: anywhere; } a:is(:hover, :focus) { text-decoration-color: var(--link-color); } img { max-width: 100%; } hr { height: 2px; border: 0; padding: 0; margin: 16px 0; background-image: linear-gradient( to right, transparent, var(--divider-color), transparent ); } button, input, select, textarea { font-family: inherit; font-size: inherit; line-height: inherit; max-width: 100%; } button, .button { display: inline-block; padding: 8px 12px; border-radius: 2.5em; border: 0; background-color: var(--button-bg-color); color: var(--button-text-color); line-height: 1; vertical-align: middle; text-decoration: none; user-select: none; } button[hidden] { display: none; } :is(button, .button) > * { vertical-align: middle; pointer-events: none; } :is(button, .button):not(:disabled, .disabled):is(:hover, :focus) { cursor: pointer; filter: brightness(1.05); } :is(button, .button):not(:disabled, .disabled):active { filter: brightness(0.8); } :is(button:disabled, .button.disabled) { opacity: 0.5; } :is(button, .button).plain { background-color: transparent; color: var(--link-color); backdrop-filter: blur(12px); } :is(button, .button).plain2 { background-color: transparent; color: var(--link-color); backdrop-filter: blur(12px) invert(0.1); } :is(button, .button).plain3 { background-color: transparent; color: var(--button-text-color); backdrop-filter: blur(12px) invert(0.25); } :is(button, .button).plain4 { background-color: transparent; color: var(--text-insignificant-color); } :is(button, .button).plain4:not(:disabled, .disabled):is(:hover, :focus) { color: var(--text-color); } :is(button, .button).plain5 { background-color: transparent; color: var(--link-color); text-decoration: underline; text-decoration-color: var(--link-faded-color); } :is(button, .button).plain5:not(:disabled, .disabled):is(:hover, :focus) { text-decoration: underline; } :is(button, .button).plain6 { background-color: var(--bg-blur-color); color: var(--link-color); border: 1px solid var(--link-color); } :is(button, .button).plain6:not(:disabled, .disabled):is(:hover, :focus) { background-color: var(--link-bg-color); } :is(button, .button).light { background-color: var(--bg-faded-color); color: var(--text-color); border: 1px solid var(--outline-color); } :is(button, .button).light:not(:disabled, .disabled):is(:hover, :focus) { border-color: var(--outline-hover-color); } :is(button, .button).light.danger:not(:disabled, .disabled) { color: var(--red-color); } :is(button, .button).block { display: block; width: 100%; padding: 12px; } :is(button, .button).textual { padding: 0; margin: 0; vertical-align: baseline; color: var(--link-color); background-color: transparent; border-radius: 0; } :is(button, .button).swap { display: grid; /* 1 column, 1 row */ grid-template-columns: 1fr; grid-template-rows: 1fr; } :is(button, .button).swap > * { grid-column: 1; grid-row: 1; transition: opacity 0.3s; } :is(button, .button).swap > *:nth-child(2) { opacity: 0; } :is(button, .button).swap:is(:hover, :focus) > *:nth-child(2) { opacity: 1; } :is(button, .button).swap[data-swap-state='danger']:is(:hover, :focus) { color: var(--red-color); border-color: var(--red-color); } :is(button, .button).swap:is(:hover, :focus) > *:nth-child(1) { opacity: 0; } input[type='text'], input[type='search'], textarea, select { color: var(--text-color); background-color: var(--bg-color); border: 2px solid var(--divider-color); padding: 8px; border-radius: 4px; } input[type='text']:focus, input[type='search']:focus, textarea:focus, select:focus { border-color: var(--outline-color); } input[type='text'].large, textarea.large, select.large, button.large { font-size: 125%; padding: 12px; } textarea:disabled { background-color: var(--bg-faded-color); } :is(input[type='text'], input[type='search'], textarea, select).block { display: block; width: 100%; } button.small { font-size: 90%; padding: 4px 8px; } select.plain { border: 0; background-color: transparent; } pre { tab-size: 2; } pre code, code, kbd { font-size: 90%; font-family: var(--monospace-font); } @media (prefers-color-scheme: dark) { :is(button, .button).plain2 { backdrop-filter: blur(12px) brightness(0.5); } } [tabindex='-1'] { outline: 0; } :not([tabindex='-1']):focus-visible { outline: 2px solid var(--focus-ring-color); } /* UTILS */ .ib { display: inline-block; } .spacer { flex-grow: 1; } .insignificant { color: var(--text-insignificant-color); } .more-insignificant { opacity: 0.5; } .hide-until-focus-visible { display: none; } :has(:focus-visible) .hide-until-focus-visible { display: initial; } /* KEYFRAMES */ @keyframes appear { from { opacity: 0; } to { opacity: 1; } } @keyframes appear-smooth { from { opacity: 0; transform: scale(0.98); } to { opacity: 1; transform: scale(1); } } @keyframes fade-in { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } } @keyframes slide-up { 0% { transform: translateY(100%); } 100% { transform: translateY(0); } } @keyframes slide-up-smooth { 0% { opacity: 0; transform: translateY(100%); } 100% { opacity: 1; transform: translateY(0); } } @keyframes position-object { 0% { object-position: 50% 50%; } 25% { object-position: 0% 0%; } 75% { object-position: 100% 100%; } 100% { object-position: 50% 50%; } } @keyframes shazam { 0% { grid-template-rows: 0fr; } 100% { grid-template-rows: 1fr; } } .shazam-container { display: grid; grid-template-rows: 1fr; transition: grid-template-rows 0.5s ease-in-out; } .shazam-container:not(.no-animation) { animation: shazam 0.5s ease-in-out both !important; } .shazam-container[hidden] { grid-template-rows: 0fr; } .shazam-container-inner { overflow: hidden; } @keyframes shazam-horizontal { 0% { grid-template-columns: 0fr; } 100% { grid-template-columns: 1fr; } } .shazam-container-horizontal { display: grid; grid-template-columns: 1fr; transition: grid-template-columns 0.5s ease-in-out; white-space: nowrap; } .shazam-container-horizontal:not(.no-animation) { animation: shazam-horizontal 0.5s ease-in-out both !important; } .shazam-container-horizontal[hidden] { grid-template-columns: 0fr; }