Compare commits

..

1 commit

Author SHA1 Message Date
9aa872a9d8
Changed 'oauth2' to 'auth' where relevant. 2025-04-24 19:40:15 +00:00
225 changed files with 3362 additions and 2905 deletions

View file

@ -1 +1 @@
20250617.1 20250423

View file

@ -1,18 +1,17 @@
.oauth2-appinfo {} .auth-appinfo {}
.oauth2-appinfo-name { .auth-appinfo-name {
font-size: 2em; font-size: 2em;
line-height: 1.5em; line-height: 1.5em;
font-weight: 500;
} }
.oauth2-appinfo-links { .auth-appinfo-links {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
gap: 5px; gap: 5px;
} }
.oauth2-appinfo-link { .auth-appinfo-link {
display: flex; display: flex;
color: inherit; color: inherit;
gap: 5px; gap: 5px;
@ -21,24 +20,24 @@
padding: 2px 6px; padding: 2px 6px;
border-radius: 4px; border-radius: 4px;
} }
.oauth2-appinfo-link-icon { .auth-appinfo-link-icon {
flex: 0 0 auto; flex: 0 0 auto;
background-color: #fff; background-color: #fff;
width: 12px; width: 12px;
height: 12px; height: 12px;
} }
.oauth2-appinfo-link-icon-globe { .auth-appinfo-link-icon-globe {
mask: url('/images/globe-solid.svg') no-repeat center; mask: url('/images/globe-solid.svg') no-repeat center;
} }
.oauth2-appinfo-link-text { .auth-appinfo-link-text {
font-size: .75em; font-size: .8em;
line-height: 1.25em; line-height: 1.4em;
} }
.oauth2-appinfo-summary { .auth-appinfo-summary {
font-size: .875em; font-size: .9em;
line-height: 1.375em; line-height: 1.4em;
} }
.oauth2-appinfo-summary p { .auth-appinfo-summary p {
margin: .5em 0; margin: .5em 0;
} }

View file

@ -1,35 +1,35 @@
.oauth2-approval { .auth-approval {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;
} }
.oauth2-approval-icon { .auth-approval-icon {
flex: 0 0 auto; flex: 0 0 auto;
background-color: #fff; background-color: #fff;
width: 40px; width: 40px;
height: 40px; height: 40px;
margin: 10px; margin: 10px;
} }
.oauth2-approval-icon-approved { .auth-approval-icon-approved {
mask: url('/images/circle-check-solid.svg') no-repeat center; mask: url('/images/circle-check-solid.svg') no-repeat center;
} }
.oauth2-approval-icon-denied { .auth-approval-icon-denied {
mask: url('/images/circle-xmark-solid.svg') no-repeat center; mask: url('/images/circle-xmark-solid.svg') no-repeat center;
} }
.oauth2-approval-header { .auth-approval-header {
text-align: center; text-align: center;
font-size: 1.5em; font-size: 1.2em;
line-height: 1.5em; line-height: 1.5em;
} }
.oauth2-approval-text { .auth-approval-text {
width: 100%; width: 100%;
} }
.oauth2-approval-text p { .auth-approval-text p {
margin: .5em 0; margin: .5em 0;
font-size: .875em; font-size: .8em;
line-height: 1.5em; line-height: 1.5em;
} }

View file

@ -1,28 +1,28 @@
.oauth2-authorise-requesting { .auth-authorise-requesting {
font-size: .875em; font-size: .8em;
line-height: 1.5em; line-height: 1.4em;
border-bottom: 1px solid #333; border-bottom: 1px solid #333;
} }
.oauth2-authorise-requesting p { .auth-authorise-requesting p {
margin: .5em 0; margin: .5em 0;
} }
.oauth2-authorise-device { .auth-authorise-device {
font-size: .875em; font-size: .8em;
line-height: 1.375em; line-height: 1.4em;
} }
.oauth2-authorise-device p { .auth-authorise-device p {
margin: .5em 0; margin: .5em 0;
} }
.oauth2-authorise-buttons { .auth-authorise-buttons {
margin-top: 10px; margin-top: 10px;
display: flex; display: flex;
justify-content: center; justify-content: center;
gap: 10px; gap: 10px;
} }
.oauth2-authorise-button { .auth-authorise-button {
background-color: #191919; background-color: #191919;
font-family: var(--font-regular); font-family: var(--font-regular);
font-size: 1.2em; font-size: 1.2em;
@ -41,32 +41,32 @@
color: #8559a5; color: #8559a5;
border-color: #8559a5; border-color: #8559a5;
} }
.oauth2-authorise-button:hover, .auth-authorise-button:hover,
.oauth2-authorise-button:focus { .auth-authorise-button:focus {
color: #191919; color: #191919;
background-color: #8559a5; background-color: #8559a5;
} }
.oauth2-authorise-button[disabled] { .auth-authorise-button[disabled] {
opacity: .5; opacity: .5;
} }
.oauth2-authorise-button-accept { .auth-authorise-button-accept {
color: #080; color: #080;
border-color: #0a0; border-color: #0a0;
} }
.oauth2-authorise-button-accept:hover, .auth-authorise-button-accept:hover,
.oauth2-authorise-button-accept:focus { .auth-authorise-button-accept:focus {
color: #191919; color: #191919;
background-color: #0a0; background-color: #0a0;
} }
.oauth2-authorise-button-deny { .auth-authorise-button-deny {
color: #c00; color: #c00;
border-color: #a00; border-color: #a00;
} }
.oauth2-authorise-button-deny:hover, .auth-authorise-button-deny:hover,
.oauth2-authorise-button-deny:focus { .auth-authorise-button-deny:focus {
color: #191919; color: #191919;
background-color: #a00; background-color: #a00;
} }

View file

@ -1,14 +1,16 @@
.oauth2-banner { .auth-banner {
display: flex; display: flex;
align-items: center; align-items: center;
gap: 10px; gap: 10px;
margin-bottom: 10px; margin-bottom: 10px;
} }
.oauth2-banner-text { .auth-banner-text {
font-size: .9em;
line-height: 1.4em;
flex: 1 1 auto; flex: 1 1 auto;
} }
.oauth2-banner-logo { .auth-banner-logo {
flex: 0 0 auto; flex: 0 0 auto;
background-color: #fff; background-color: #fff;
mask: url('/images/flashii.svg') no-repeat center; mask: url('/images/flashii.svg') no-repeat center;

View file

@ -1,11 +1,11 @@
.oauth2-device-form { .auth-device-form {
display: flex; display: flex;
justify-content: center; justify-content: center;
margin: 10px; margin: 10px;
} }
.oauth2-device-code { .auth-device-code {
font-size: 1.25em; font-size: 1.4em;
border: 1px solid #222; border: 1px solid #222;
padding: 5px 10px; padding: 5px 10px;
background: #222; background: #222;
@ -15,11 +15,10 @@
transition: border-color .2s; transition: border-color .2s;
text-align: center; text-align: center;
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
min-width: 0; min-width: 0;
max-width: 200px; max-width: 200px;
width: 100%; width: 100%;
} }
.oauth2-device-code:focus { .auth-device-code:focus {
border-color: #8559a5; border-color: #8559a5;
} }

View file

@ -1,3 +1,3 @@
.oauth2-errorbody p { .auth-errorbody p {
margin: .5em 1em; margin: .5em 1em;
} }

View file

@ -12,7 +12,6 @@ body {
pre, code { pre, code {
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
} }
a { a {
@ -27,14 +26,14 @@ a:focus {
text-decoration: underline; text-decoration: underline;
} }
.oauth2-wrapper { .auth-wrapper {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
flex: 1 0 auto; flex: 1 0 auto;
margin-bottom: 10px; margin-bottom: 10px;
} }
.oauth2-dialog { .auth-dialog {
display: flex; display: flex;
flex: 1 0 auto; flex: 1 0 auto;
padding: 10px; padding: 10px;
@ -43,7 +42,7 @@ a:focus {
justify-content: center; justify-content: center;
} }
.oauth2-dialog-body { .auth-dialog-body {
max-width: 500px; max-width: 500px;
width: 100%; width: 100%;
background: #191919; background: #191919;
@ -52,7 +51,7 @@ a:focus {
flex-direction: column; flex-direction: column;
} }
.oauth2-header { .auth-header {
background-image: url('/images/clouds.png'); background-image: url('/images/clouds.png');
background-blend-mode: multiply; background-blend-mode: multiply;
background-color: #8559a5; background-color: #8559a5;
@ -60,7 +59,7 @@ a:focus {
min-height: 4px; min-height: 4px;
} }
.oauth2-body { .auth-body {
margin: 10px; margin: 10px;
} }

View file

@ -1,26 +1,26 @@
.oauth2-scope { .auth-scope {
background: #292929; background: #292929;
border-radius: 4px; border-radius: 4px;
padding: 4px 8px; padding: 4px 8px;
} }
.oauth2-scope-header { .auth-scope-header {
border-bottom: 1px solid #494949; border-bottom: 1px solid #494949;
} }
.oauth2-scope-perms { .auth-scope-perms {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 4px; gap: 4px;
margin: 4px 0; margin: 4px 0;
} }
.oauth2-scope-perm { .auth-scope-perm {
display: flex; display: flex;
align-items: center; align-items: center;
gap: 4px; gap: 4px;
} }
.oauth2-scope-perm-icon { .auth-scope-perm-icon {
width: 16px; width: 16px;
height: 16px; height: 16px;
mask: url('/images/circle-check-regular.svg') no-repeat center; mask: url('/images/circle-check-regular.svg') no-repeat center;
@ -28,11 +28,11 @@
background-color: #0a0; background-color: #0a0;
margin: 2px; margin: 2px;
} }
.oauth2-scope-perm-icon-warn { .auth-scope-perm-icon-warn {
mask: url('/images/circle-regular.svg') no-repeat center, url('/images/exclamation-solid.svg') no-repeat center center / 10px 10px; mask: url('/images/circle-regular.svg') no-repeat center, url('/images/exclamation-solid.svg') no-repeat center center / 10px 10px;
background-color: #c80; background-color: #c80;
} }
.oauth2-scope-perm-text { .auth-scope-perm-text {
font-size: .875em; font-size: .8em;
line-height: 1.375em; line-height: 1.4em;
} }

View file

@ -1,9 +1,9 @@
.oauth2-simplehead { .auth-simplehead {
display: flex; display: flex;
align-items: center; align-items: center;
} }
.oauth2-simplehead-icon { .auth-simplehead-icon {
flex: 0 0 auto; flex: 0 0 auto;
background-color: #fff; background-color: #fff;
mask: url('/images/circle-question-solid.svg') no-repeat center; mask: url('/images/circle-question-solid.svg') no-repeat center;
@ -11,20 +11,20 @@
height: 40px; height: 40px;
margin: 10px; margin: 10px;
} }
.oauth2-simplehead-icon--code { .auth-simplehead-icon--code {
mask-image: url('/images/mobile-screen-solid.svg'); mask-image: url('/images/mobile-screen-solid.svg');
} }
.oauth2-simplehead-icon--error { .auth-simplehead-icon--error {
mask-image: url('/images/circle-exclamation-solid.svg'); mask-image: url('/images/circle-exclamation-solid.svg');
} }
.oauth2-simplehead-icon--login { .auth-simplehead-icon--login {
mask-image: url('/images/user-lock-solid.svg'); mask-image: url('/images/user-lock-solid.svg');
} }
.oauth2-simplehead-icon--wait { .auth-simplehead-icon--wait {
mask-image: url('/images/ellipsis-solid.svg'); mask-image: url('/images/ellipsis-solid.svg');
} }
.oauth2-simplehead-text { .auth-simplehead-text {
font-size: 1.75em; font-size: 1.8em;
line-height: 1.375em; line-height: 1.4em;
} }

View file

@ -1,64 +1,64 @@
.oauth2-userhead { .auth-userhead {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
background-color: #0005; background-color: #0005;
} }
.oauth2-userhead-main { .auth-userhead-main {
display: flex; display: flex;
align-items: center; align-items: center;
} }
.oauth2-userhead-main-avatar { .auth-userhead-main-avatar {
flex: 0 0 auto; flex: 0 0 auto;
margin: 10px; margin: 10px;
} }
.oauth2-userhead-main-avatar-image { .auth-userhead-main-avatar-image {
width: 60px; width: 60px;
height: 60px; height: 60px;
overflow: hidden; overflow: hidden;
border-radius: 4px; border-radius: 4px;
} }
.oauth2-userhead-main-avatar-image img { .auth-userhead-main-avatar-image img {
width: 100%; width: 100%;
height: 100%; height: 100%;
object-fit: cover; object-fit: cover;
border: 0; border: 0;
} }
.oauth2-userhead-main-name { .auth-userhead-main-name {
font-size: 1.75em; font-size: 1.8em;
line-height: 1.375em; line-height: 1.4em;
} }
.oauth2-userhead-main-name a { .auth-userhead-main-name a {
color: inherit; color: inherit;
} }
.oauth2-userhead-guise { .auth-userhead-guise {
display: flex; display: flex;
align-items: center; align-items: center;
background-image: repeating-linear-gradient(-45deg, #8559a57f, #8559a57f 10px, #1111117f 10px, #1111117f 20px); background-image: repeating-linear-gradient(-45deg, #8559a57f, #8559a57f 10px, #1111117f 10px, #1111117f 20px);
} }
.oauth2-userhead-guise-avatar { .auth-userhead-guise-avatar {
flex: 0 0 auto; flex: 0 0 auto;
margin: 10px; margin: 10px;
} }
.oauth2-userhead-guise-avatar-image { .auth-userhead-guise-avatar-image {
width: 30px; width: 30px;
height: 30px; height: 30px;
overflow: hidden; overflow: hidden;
border-radius: 4px; border-radius: 4px;
} }
.oauth2-userhead-guise-avatar-image img { .auth-userhead-guise-avatar-image img {
width: 100%; width: 100%;
height: 100%; height: 100%;
object-fit: cover; object-fit: cover;
border: 0; border: 0;
} }
.oauth2-userhead-guise-text { .auth-userhead-guise-text {
font-size: .75em; font-size: .8em;
line-height: 1.375em; line-height: 1.5em;
overflow: hidden; overflow: hidden;
padding: 2px 0; padding: 2px 0;
} }
.oauth2-userhead-guise-text p { .auth-userhead-guise-text p {
margin: 1px 0; margin: 1px 0;
} }

View file

@ -0,0 +1,30 @@
const MszAuthAppInfoLink = function(info) {
const element = <a href={info.uri} target="_blank" rel="noopener noreferrer" class="auth-appinfo-link" title={info.title}>
<div class="auth-appinfo-link-icon auth-appinfo-link-icon-globe"></div>
<div class="auth-appinfo-link-text">{info.display}</div>
</a>;
return {
get element() { return element; },
};
};
const MszAuthAppInfo = function(info) {
const linksElem = <div class="auth-appinfo-links"/>;
if(Array.isArray(info.links))
for(const link of info.links)
linksElem.appendChild((new MszAuthAppInfoLink(link)).element);
// TODO: author should be listed
const element = <div class="auth-appinfo">
<div class="auth-appinfo-name">{info.name}</div>
{linksElem}
<div class="auth-appinfo-summary">
<p>{info.summary}</p>
</div>
</div>;
return {
get element() { return element; },
};
};

View file

@ -0,0 +1,33 @@
const MszAuthAppScopeEntry = function(text, warn) {
const icon = <div class="auth-scope-perm-icon"/>;
if(warn)
icon.classList.add('auth-scope-perm-icon-warn');
const element = <div class="auth-scope-perm">
{icon}
<div class="auth-scope-perm-text">{text}</div>
</div>;
return {
get element() { return element; },
};
};
const MszAuthAppScopeList = function(scopes) {
const permsElem = <div class="auth-scope-perms"/>;
if(Array.isArray(scopes) && scopes.length > 0) {
for(const scope of scopes)
if(typeof scope === 'string')
permsElem.appendChild(new MszAuthAppScopeEntry(scope).element);
} else
permsElem.appendChild(new MszAuthAppScopeEntry('A limited amount of things. No scope was specified by the developer.', true).element);
const element = <div class="auth-scope">
<div class="auth-scope-header">This application will be able to:</div>
{permsElem}
</div>;
return {
get element() { return element; },
};
};

View file

@ -30,7 +30,7 @@ const MszOAuth2AuthoriseErrors = Object.freeze({
const MszOAuth2Authorise = async () => { const MszOAuth2Authorise = async () => {
const queryParams = new URLSearchParams(window.location.search); const queryParams = new URLSearchParams(window.location.search);
const loading = new MszLoading({ element: '.js-loading', size: 2 }); const loading = new MszLoading({ element: '.js-loading', size: 2 });
const header = new MszOAuth2Header; const header = new MszAuthHeader;
const fAuths = document.querySelector('.js-authorise-form'); const fAuths = document.querySelector('.js-authorise-form');
const eAuthsInfo = document.querySelector('.js-authorise-form-info'); const eAuthsInfo = document.querySelector('.js-authorise-form-info');
@ -172,7 +172,7 @@ const MszOAuth2Authorise = async () => {
return translateError(body.error, body); return translateError(body.error, body);
} }
const userHeader = new MszOAuth2UserHeader(body.user); const userHeader = new MszAuthUserHeader(body.user);
header.setElement(userHeader); header.setElement(userHeader);
const verifyAuthsRequest = async () => { const verifyAuthsRequest = async () => {
@ -216,8 +216,8 @@ const MszOAuth2Authorise = async () => {
return; return;
} }
eAuthsInfo.replaceWith(new MszOAuth2AppInfo(body.app).element); eAuthsInfo.replaceWith(new MszAuthAppInfo(body.app).element);
eAuthsScope.replaceWith(new MszOAuth2AppScopeList(body.scope).element); eAuthsScope.replaceWith(new MszAuthAppScopeList(body.scope).element);
fAuths.onsubmit = ev => { fAuths.onsubmit = ev => {
ev.preventDefault(); ev.preventDefault();

View file

@ -1,4 +1,4 @@
const MszOAuth2Header = function(element = '.js-oauth2-header', simpleElement = '.js-oauth2-header-simple') { const MszAuthHeader = function(element = '.js-auth-header', simpleElement = '.js-auth-header-simple') {
if(typeof element === 'string') if(typeof element === 'string')
element = document.querySelector(element); element = document.querySelector(element);
if(!(element instanceof HTMLElement)) if(!(element instanceof HTMLElement))
@ -7,8 +7,8 @@ const MszOAuth2Header = function(element = '.js-oauth2-header', simpleElement =
if(typeof simpleElement === 'string') if(typeof simpleElement === 'string')
simpleElement = element.querySelector(simpleElement); simpleElement = element.querySelector(simpleElement);
const simpleElementIcon = simpleElement?.querySelector('.js-oauth2-header-simple-icon'); const simpleElementIcon = simpleElement?.querySelector('.js-auth-header-simple-icon');
const simpleElementText = simpleElement?.querySelector('.js-oauth2-header-simple-text'); const simpleElementText = simpleElement?.querySelector('.js-auth-header-simple-text');
const hasSimpleElement = simpleElement instanceof HTMLElement; const hasSimpleElement = simpleElement instanceof HTMLElement;
const setSimpleVisible = state => { const setSimpleVisible = state => {
@ -18,10 +18,10 @@ const MszOAuth2Header = function(element = '.js-oauth2-header', simpleElement =
const setSimpleData = (icon, text) => { const setSimpleData = (icon, text) => {
if(hasSimpleElement) { if(hasSimpleElement) {
for(const className of simpleElementIcon.classList) for(const className of simpleElementIcon.classList)
if(className.startsWith('oauth2-simplehead-icon--')) if(className.startsWith('auth-simplehead-icon--'))
simpleElementIcon.classList.remove(className); simpleElementIcon.classList.remove(className);
simpleElementIcon.classList.add(`oauth2-simplehead-icon--${icon}`); simpleElementIcon.classList.add(`auth-simplehead-icon--${icon}`);
simpleElementText.textContent = text; simpleElementText.textContent = text;
} }
}; };

View file

@ -1,11 +1,11 @@
const MszOAuth2UserGuiseHeader = function(guise) { const MszAuthUserGuiseHeader = function(guise) {
const element = <div class="oauth2-userhead-guise"> const element = <div class="auth-userhead-guise">
<div class="oauth2-userhead-guise-avatar"> <div class="auth-userhead-guise-avatar">
<div class="oauth2-userhead-guise-avatar-image"> <div class="auth-userhead-guise-avatar-image">
<img src={guise.avatar_uri} alt=""/> <img src={guise.avatar_uri} alt=""/>
</div> </div>
</div> </div>
<div class="oauth2-userhead-guise-text"> <div class="auth-userhead-guise-text">
<p>Are you <a href={guise.profile_uri} target="_blank" style={`color: ${guise.colour}`}>{guise.name}</a> and did you mean to use your own account?</p> <p>Are you <a href={guise.profile_uri} target="_blank" style={`color: ${guise.colour}`}>{guise.name}</a> and did you mean to use your own account?</p>
<p><a href={guise.revert_uri} target="_blank">Click here</a> and reload this page.</p> <p><a href={guise.revert_uri} target="_blank">Click here</a> and reload this page.</p>
</div> </div>
@ -21,15 +21,15 @@ const MszOAuth2UserGuiseHeader = function(guise) {
}; };
}; };
const MszOAuth2UserHeader = function(user) { const MszAuthUserHeader = function(user) {
const element = <div class="oauth2-userhead"> const element = <div class="auth-userhead">
<div class="oauth2-userhead-main"> <div class="auth-userhead-main">
<div class="oauth2-userhead-main-avatar"> <div class="auth-userhead-main-avatar">
<div class="oauth2-userhead-main-avatar-image"> <div class="auth-userhead-main-avatar-image">
<img src={user.avatar_uri} alt=""/> <img src={user.avatar_uri} alt=""/>
</div> </div>
</div> </div>
<div class="oauth2-userhead-main-name"> <div class="auth-userhead-main-name">
<a href={user.profile_uri} target="_blank">{user.name}</a> <a href={user.profile_uri} target="_blank">{user.name}</a>
</div> </div>
</div> </div>
@ -37,7 +37,7 @@ const MszOAuth2UserHeader = function(user) {
let guiseInfo; let guiseInfo;
if(user.guise) { if(user.guise) {
guiseInfo = new MszOAuth2UserGuiseHeader(user.guise); guiseInfo = new MszAuthUserGuiseHeader(user.guise);
element.appendChild(guiseInfo.element); element.appendChild(guiseInfo.element);
} }

View file

@ -6,7 +6,7 @@
const MszOAuth2Verify = () => { const MszOAuth2Verify = () => {
const queryParams = new URLSearchParams(window.location.search); const queryParams = new URLSearchParams(window.location.search);
const loading = new MszLoading({ element: '.js-loading', size: 2 }); const loading = new MszLoading({ element: '.js-loading', size: 2 });
const header = new MszOAuth2Header; const header = new MszAuthHeader;
const fAuths = document.querySelector('.js-verify-authorise'); const fAuths = document.querySelector('.js-verify-authorise');
const eAuthsInfo = document.querySelector('.js-verify-authorise-info'); const eAuthsInfo = document.querySelector('.js-verify-authorise-info');
@ -128,7 +128,7 @@ const MszOAuth2Verify = () => {
userCode = body.req.code; userCode = body.req.code;
userHeader = new MszOAuth2UserHeader(body.user); userHeader = new MszAuthUserHeader(body.user);
header.setElement(userHeader); header.setElement(userHeader);
if(body.app.trusted && body.user.guise === undefined) { if(body.app.trusted && body.user.guise === undefined) {
@ -139,8 +139,8 @@ const MszOAuth2Verify = () => {
return; return;
} }
eAuthsInfo.replaceWith(new MszOAuth2AppInfo(body.app).element); eAuthsInfo.replaceWith(new MszAuthAppInfo(body.app).element);
eAuthsScope.replaceWith(new MszOAuth2AppScopeList(body.scope).element); eAuthsScope.replaceWith(new MszAuthAppScopeList(body.scope).element);
loading.visible = false; loading.visible = false;
fAuths.classList.remove('hidden'); fAuths.classList.remove('hidden');

View file

@ -17,16 +17,8 @@ html, body {
} }
:root { :root {
--font-regular: Inter, 'Zen Kaku Gothic New', sans-serif; --font-regular: Verdana, Geneva, 'Dejavu Sans', Arial, Helvetica, sans-serif;
--font-monospace: 'Victor Mono', monospace; --font-monospace: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
font-feature-settings: 'calt' 1, 'dlig' 1, 'ss01' 1;
font-optical-sizing: auto;
}
@supports (font-variation-settings: normal) {
:root {
--font-regular: InterVariable, 'Zen Kaku Gothic New', sans-serif;
}
} }
@include loading.css; @include loading.css;

View file

@ -19,8 +19,7 @@
.msz-perf { .msz-perf {
background-color: #111d; background-color: #111d;
color: #fff; color: #fff;
font-family: var(--font-monospace); font-family: monospace;
font-feature-settings: 'ss07' 1;
font-size: 12px; font-size: 12px;
line-height: 20px; line-height: 20px;
padding: 4px 8px; padding: 4px 8px;

View file

@ -20,9 +20,7 @@ body {
color: #fff; color: #fff;
font-size: 16px; font-size: 16px;
line-height: 25px; line-height: 25px;
font-family: Inter, 'Zen Kaku Gothic New', sans-serif; font-family: Verdana, Geneva, 'Dejavu Sans', Arial, Helvetica, sans-serif;
font-feature-settings: 'calt' 1, 'dlig' 1, 'ss01' 1;
font-optical-sizing: auto;
background-color: #8559a5; background-color: #8559a5;
background-color: var(--error-colour, #8559a5); background-color: var(--error-colour, #8559a5);
background-image: url('/images/clouds.png'); background-image: url('/images/clouds.png');
@ -32,12 +30,6 @@ body {
flex-direction: column; flex-direction: column;
} }
@supports (font-variation-settings: normal) {
body {
--font-regular: InterVariable, 'Zen Kaku Gothic New', sans-serif;
}
}
.error { .error {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@ -101,8 +93,8 @@ body {
} }
.error-home { .error-home {
font-size: 1.5rem; font-size: 1.5em;
line-height: 1.375rem; line-height: 1.4em;
} }
.error-nav { .error-nav {
@ -120,24 +112,21 @@ body {
justify-content: center; justify-content: center;
} }
.error-title {
line-height: 3rem;
}
.error-icon { .error-icon {
font-size: 4rem; font-size: 4em;
line-height: 1.5rem; line-height: 1.4em;
} }
.error-blerb { .error-blerb {
font-size: .875rem; margin: 10px auto;
line-height: 1rem; font-size: .9em;
line-height: 1.4em;
} }
.error-footer { .error-footer {
text-align: center; text-align: center;
font-size: .75rem; font-size: 12px;
line-height: 1.375em; line-height: 1.4em;
color: #888; color: #888;
border-top: 1px solid #444; border-top: 1px solid #444;
padding-top: 4px; padding-top: 4px;

View file

@ -1,7 +1,9 @@
.input__button { .input__button {
background-color: var(--background-colour); background-color: var(--background-colour);
font-family: var(--font-regular); font-family: var(--font-regular);
padding: 4px 12px; font-size: 1.2em;
line-height: 1.4em;
padding: 5px 10px;
min-width: 80px; min-width: 80px;
text-align: center; text-align: center;
cursor: pointer; cursor: pointer;
@ -13,8 +15,6 @@
align-items: center; align-items: center;
justify-content: center; justify-content: center;
text-decoration: none; text-decoration: none;
font-size: inherit;
line-height: inherit;
} }
.input__button:hover, .input__button:active, .input__button:hover, .input__button:active,
.input__button:focus, .input__button:checked, .input__button:focus, .input__button:checked,

View file

@ -49,8 +49,6 @@
.input__checkbox__text { .input__checkbox__text {
display: inline-block; display: inline-block;
margin-left: 4px; margin-left: 4px;
font-size: .875em;
line-height: 1.375em;
} }
.input__checkbox--disabled { .input__checkbox--disabled {
opacity: .5; opacity: .5;

View file

@ -4,12 +4,10 @@
background: #222; background: #222;
color: #fff; color: #fff;
min-width: 150px; min-width: 150px;
font-size: 1.2em;
border-radius: 2px; border-radius: 2px;
box-shadow: inset 0 0 4px #111; box-shadow: inset 0 0 4px #111;
transition: border-color .2s; transition: border-color .2s;
font-family: inherit;
font-size: 1em;
line-height: 1.25em;
} }
.input__select:focus { .input__select:focus {
border-color: var(--accent-colour); border-color: var(--accent-colour);

View file

@ -1,4 +1,5 @@
.input__text { .input__text {
font-size: 1.2em;
border: 1px solid #222; border: 1px solid #222;
padding: 5px 10px; padding: 5px 10px;
background: #222; background: #222;
@ -6,11 +7,8 @@
border-radius: 2px; border-radius: 2px;
box-shadow: inset 0 0 4px #111; box-shadow: inset 0 0 4px #111;
transition: border-color .2s; transition: border-color .2s;
font-family: inherit;
font-size: 1em;
line-height: 1.25em;
} }
.input__text:focus { border-color: var(--accent-colour); } .input__text:focus { border-color: var(--accent-colour); }
.input__text--readonly { color: #888; } .input__text--readonly { color: #888; }
.input__text--monospace { font-family: var(--font-monospace); font-feature-settings: 'ss07' 1; } .input__text--monospace { font-family: var(--font-monospace); }
.input__text--centre { text-align: center; } .input__text--centre { text-align: center; }

View file

@ -1,11 +1,11 @@
.input__textarea { .input__textarea {
font-size: 1.2em;
border: 1px solid #222; border: 1px solid #222;
padding: 4px 12px; padding: 5px 10px;
vertical-align: bottom; vertical-align: bottom;
background: #222; background: #222;
color: #fff; color: #fff;
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
border-radius: 2px; border-radius: 2px;
box-shadow: inset 0 0 4px #111; box-shadow: inset 0 0 4px #111;
transition: border-color .2s; transition: border-color .2s;

View file

@ -10,8 +10,9 @@
} }
.input__upload__selection { .input__upload__selection {
text-align: center; text-align: center;
font-size: 1.2em;
border: 1px solid #222; border: 1px solid #222;
padding: 4px 12px; padding: 5px 10px;
background: #222; background: #222;
color: #fff; color: #fff;
border-radius: 2px; border-radius: 2px;

View file

@ -43,7 +43,7 @@
.changelog__change__username { .changelog__change__username {
color: inherit; color: inherit;
font-size: 1.375em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
text-decoration: none; text-decoration: none;
} }
@ -52,7 +52,7 @@
} }
.changelog__change__userrole { .changelog__change__userrole {
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
@ -64,13 +64,15 @@
.changelog__change__date { .changelog__change__date {
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
font-size: 1.1em;
line-height: 1.5em;
} }
.changelog__change__date:hover { .changelog__change__date:hover {
text-decoration: underline; text-decoration: underline;
} }
.changelog__change__text { .changelog__change__text {
line-height: 1.25em; line-height: 1.2em;
flex: 1 1 auto; flex: 1 1 auto;
word-wrap: break-word; word-wrap: break-word;
overflow: hidden; overflow: hidden;

View file

@ -1,8 +1,6 @@
.changelog__entry { .changelog__entry {
display: flex; display: flex;
margin: 5px; margin: 5px;
font-size: .875em;
line-height: 1.5em;
} }
.changelog__entry__info { display: flex; } .changelog__entry__info { display: flex; }
@ -70,7 +68,7 @@
.changelog__entry__tags { .changelog__entry__tags {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
font-size: .75em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
} }

View file

@ -6,6 +6,8 @@
text-decoration: none; text-decoration: none;
padding: 1px 3px; padding: 1px 3px;
color: var(--accent-colour); color: var(--accent-colour);
font-size: 1.2em;
line-height: 1.5em;
} }
.changelog__listing__date:hover { .changelog__listing__date:hover {
text-decoration: underline; text-decoration: underline;

View file

@ -21,8 +21,8 @@
} }
.changelog__log__text { .changelog__log__text {
padding: 8px 12px; padding: 8px 12px;
font-size: 1.375em; font-size: 1.5em;
line-height: 1.25em; line-height: 1.3em;
align-self: center; align-self: center;
flex: 1 1 auto; flex: 1 1 auto;
overflow: hidden; overflow: hidden;

View file

@ -19,7 +19,7 @@
} }
.comments-form-wrap { .comments-form-wrap {
display: grid; display: grid;
grid-template-rows: 1fr 35px; grid-template-rows: 1fr 32px;
gap: 2px; gap: 2px;
margin: 3px; margin: 3px;
margin-left: 0; margin-left: 0;
@ -49,6 +49,8 @@
.comments-form-status { .comments-form-status {
flex: 1 1 auto; flex: 1 1 auto;
font-size: 1.2em;
line-height: 1.4em;
padding: 0 6px; padding: 0 6px;
overflow: hidden; overflow: hidden;
transition: color .2s; transition: color .2s;
@ -64,8 +66,8 @@
.comments-form-pin { .comments-form-pin {
flex: 0 0 auto; flex: 0 0 auto;
font-size: 1.25em; font-size: 1.2em;
line-height: 1.375em; line-height: 1.4em;
} }
.comments-form-post { .comments-form-post {

View file

@ -3,8 +3,8 @@
justify-content: center; justify-content: center;
align-items: center; align-items: center;
flex-wrap: wrap; flex-wrap: wrap;
font-size: 1.25em; font-size: 1.4em;
line-height: 1.375em; line-height: 1.5em;
gap: 6px; gap: 6px;
padding: 12px; padding: 12px;
margin: 2px; margin: 2px;

View file

@ -13,12 +13,10 @@
overflow: hidden; overflow: hidden;
} }
.container__title__text { .container__title__text {
font-size: 1.125rem; font-size: 1.5em;
line-height: 1.5em; line-height: 1.5em;
padding: 8px 10px; padding: 8px 10px;
word-wrap: break-word; word-wrap: break-word;
font-weight: 500;
min-height: 44px;
} }
.container__title__link { .container__title__link {
color: inherit; color: inherit;

View file

@ -21,7 +21,7 @@
visibility: hidden; visibility: hidden;
} }
.eeprom-widget-form-text { .eeprom-widget-form-text {
font-size: 1.325em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
} }
.eeprom-widget-form:focus, .eeprom-widget-form:focus,
@ -70,8 +70,8 @@
text-decoration: underline; text-decoration: underline;
} }
.eeprom-widget-file-progress { .eeprom-widget-file-progress {
font-size: .875em; font-size: .9em;
line-height: 1.325em; line-height: 1.4em;
text-align: right; text-align: right;
padding: 0 2px; padding: 0 2px;
white-space: nowrap; white-space: nowrap;

View file

@ -88,26 +88,30 @@
margin-left: 5px; margin-left: 5px;
} }
.embedph-info-title { .embedph-info-title {
font-size: 1.5rem !important; font-size: 2em !important;
font-weight: 500 !important; font-weight: 400 !important;
line-height: 1.5rem !important; line-height: 1.2em !important;
margin: 5px 0; margin-bottom: 5px;
word-break: break-word; word-break: break-word;
margin: 0 !important; margin: 0 !important;
padding: 0 !important; padding: 0 !important;
border-width: 0 !important; border-width: 0 !important;
} }
.embedph-info-desc { .embedph-info-desc {
font-size: .875rem; line-height: 1.4em;
line-height: 1.5rem; margin: .5em 0;
margin: .25rem 0;
word-break: break-word; word-break: break-word;
} }
.embedph-info-site { .embedph-info-site {
font-size: .75rem; font-size: .9em;
line-height: 1.2em;
} }
@media (max-width: 640px) { @media (max-width: 640px) {
.embedph-info-title {
font-size: 1.5em;
line-height: 1.2em;
}
.embedph-info-desc { .embedph-info-desc {
display: none; display: none;
} }
@ -131,7 +135,9 @@
margin-bottom: 20px; margin-bottom: 20px;
} }
.embedph-play-external { .embedph-play-external {
padding: 4px 8px; padding: 5px 10px;
font-size: 1.2em;
line-height: 1.5em;
text-decoration: none !important; text-decoration: none !important;
color: var(--text-colour) !important; color: var(--text-colour) !important;
background-color: var(--background-colour-translucent-6); background-color: var(--background-colour-translucent-6);
@ -219,7 +225,6 @@
height: 70px; height: 70px;
border-radius: 5px; border-radius: 5px;
margin: 5px; margin: 5px;
font-size: .75rem;
} }
.aembedph:hover .aembedph-play, .aembedph:hover .aembedph-play,
.aembedph:active .aembedph-play, .aembedph:active .aembedph-play,
@ -288,9 +293,9 @@
padding: 0 5px; padding: 0 5px;
} }
.aembedph-info-title { .aembedph-info-title {
font-size: 1.25em !important; font-size: 1.4em !important;
font-weight: 500 !important; font-weight: 400 !important;
line-height: 1.25em !important; line-height: 1.2em !important;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
@ -304,10 +309,10 @@
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
font-weight: 600; font-weight: 700;
} }
.aembedph-info-album { .aembedph-info-album {
line-height: 1.5em; line-height: 1.4em;
word-break: break-word; word-break: break-word;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
@ -316,7 +321,7 @@
} }
.aembedph-info-site { .aembedph-info-site {
font-size: .9em; font-size: .9em;
line-height: 1.25em; line-height: 1.2em;
} }
.aembedph-play { .aembedph-play {

View file

@ -13,8 +13,8 @@
max-width: var(--site-max-width); max-width: var(--site-max-width);
margin: 0 auto; margin: 0 auto;
text-align: center; text-align: center;
font-size: .875rem; font-size: .9em;
line-height: 1.5rem; line-height: 1.5em;
padding: 1em 0; padding: 1em 0;
} }
.footer__background { .footer__background {

View file

@ -4,6 +4,8 @@
overflow: auto; overflow: auto;
} }
.forum__categories__empty { .forum__categories__empty {
font-size: 1.2em;
line-height: 1.5em;
text-align: center; text-align: center;
padding: 10px; padding: 10px;
} }
@ -61,8 +63,8 @@
background-size: 80px 80px; background-size: 80px 80px;
background-image: radial-gradient(ellipse at center, rgba(255, 255, 255, .2) 0%, rgba(0, 0, 0, .4) 100%); background-image: radial-gradient(ellipse at center, rgba(255, 255, 255, .2) 0%, rgba(0, 0, 0, .4) 100%);
box-shadow: 0 1px 4px #111; box-shadow: 0 1px 4px #111;
font-size: 1.5em; font-size: 2em;
line-height: 1.25em; line-height: 1.5em;
color: #fff; color: #fff;
display: flex; display: flex;
justify-content: center; justify-content: center;
@ -80,25 +82,22 @@
justify-content: center; justify-content: center;
flex-direction: column; flex-direction: column;
line-height: 1.5em; line-height: 1.5em;
gap: 2px;
} }
.forum__category__title { .forum__category__title {
font-size: 1.125em; font-size: 1.3em;
line-height: 1.25em;
} }
.forum__category__description, .forum__category__description,
.forum__category__subforums { .forum__category__subforums {
font-size: .875em; font-size: .9em;
line-height: 1.25em;
} }
.forum__category__subforums { .forum__category__subforums {
display: flex; display: flex;
gap: 6px;
} }
.forum__category__subforum { .forum__category__subforum {
padding: 2px;
pointer-events: initial; pointer-events: initial;
color: var(--accent-colour); color: var(--accent-colour);
text-decoration: none; text-decoration: none;
@ -126,23 +125,21 @@
} }
.forum__category__stat { .forum__category__stat {
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.3em;
opacity: .7; opacity: .7;
pointer-events: auto; pointer-events: auto;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.forum__category__stat:first-child { .forum__category__stat:first-child {
font-size: 1.25em; font-size: 1.5em;
opacity: 1; opacity: 1;
} }
.forum__category__activity { .forum__category__activity {
text-align: right; text-align: right;
min-width: 300px; min-width: 270px;
font-size: .875em; line-height: 1.4em;
line-height: 1.375em;
} }
.forum__category__activity__none, .forum__category__activity__none,
.forum__category__activity__details { .forum__category__activity__details {
@ -163,7 +160,7 @@
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
max-width: 230px; max-width: 200px;
} }
.forum__category__activity__post:hover, .forum__category__activity__post:hover,
.forum__category__activity__post:focus { .forum__category__activity__post:focus {
@ -197,7 +194,7 @@
flex-wrap: wrap; flex-wrap: wrap;
} }
.forum__category__details { .forum__category__details {
flex-basis: calc(100% - 8em); /* god knows what this does */ flex-basis: calc(100% - 100px);
} }
.forum__category__stats { .forum__category__stats {
min-width: initial; min-width: initial;

View file

@ -7,8 +7,8 @@
} }
.forum__header__title { .forum__header__title {
font-size: 1.5em; font-size: 2em;
line-height: 1.25em; line-height: 1.5em;
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
padding: 0 5px; padding: 0 5px;
@ -28,18 +28,19 @@
margin: 0; margin: 0;
box-shadow: initial; box-shadow: initial;
font-size: 1em; font-size: 1em;
font-family: var(--font-regular); font-family: inherit;
} }
.forum__header__breadcrumbs { .forum__header__breadcrumbs {
display: flex; display: flex;
font-size: 1.1em;
line-height: 1.5em; line-height: 1.5em;
align-items: center; align-items: center;
} }
.forum__header__breadcrumb { .forum__header__breadcrumb {
color: var(--accent-colour); color: var(--accent-colour);
text-decoration: none; text-decoration: none;
padding: 2px 6px; padding: 2px 5px;
} }
.forum__header__breadcrumb:hover { .forum__header__breadcrumb:hover {
text-decoration: underline; text-decoration: underline;
@ -47,7 +48,7 @@
.forum__header__breadcrumb__separator { .forum__header__breadcrumb__separator {
color: var(--accent-colour); color: var(--accent-colour);
margin: 0 4px; margin: 0 4px;
font-size: .875em; font-size: .9em;
} }
.forum__header__actions { .forum__header__actions {

View file

@ -36,13 +36,14 @@
.forum__leaderboard__user { .forum__leaderboard__user {
margin: 2px 0; margin: 2px 0;
font-size: 1.2em;
} }
.forum__leaderboard__user--rank-1 { .forum__leaderboard__user--rank-1 {
font-size: 1.5em; font-size: 1.6em;
} }
.forum__leaderboard__user--rank-2, .forum__leaderboard__user--rank-2,
.forum__leaderboard__user--rank-3 { .forum__leaderboard__user--rank-3 {
font-size: 1.25em; font-size: 1.4em;
} }
.forum__leaderboard__user__background { .forum__leaderboard__user__background {
@ -68,7 +69,6 @@
justify-content: center; justify-content: center;
font-weight: 700; font-weight: 700;
flex: 0 0 auto; flex: 0 0 auto;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.forum__leaderboard__user__rank:before { .forum__leaderboard__user__rank:before {
content: "#"; content: "#";

View file

@ -22,8 +22,8 @@
} }
.forum__post__details { .forum__post__details {
font-size: .875em; font-size: .9em;
line-height: 1.75em; line-height: 1.7em;
padding: 0 2px; padding: 0 2px;
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@ -36,9 +36,6 @@
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
} }
.forum__post__id {
font-feature-settings: 'ss01' 1, 'tnum' 1;
}
.forum__post__datetime:hover, .forum__post__datetime:hover,
.forum__post__datetime:focus, .forum__post__datetime:focus,
.forum__post__id:hover, .forum__post__id:hover,
@ -50,7 +47,7 @@
.forum__post__text { .forum__post__text {
padding: 2px; padding: 2px;
line-height: 1.5em; line-height: 1.4em;
flex: 1 1 auto; flex: 1 1 auto;
} }
.forum__post__text--edit { .forum__post__text--edit {
@ -100,14 +97,14 @@
} }
.forum__post__posts-count { .forum__post__posts-count {
font-size: .75em; font-size: .9em;
margin-left: 8px; margin-left: 4px;
} }
.forum__post__joined { .forum__post__joined {
flex: 1 1 auto; flex: 1 1 auto;
max-width: 170px; max-width: 170px;
font-size: .75em; font-size: .9em;
justify-self: flex-end; justify-self: flex-end;
} }
@ -120,7 +117,7 @@
.forum__post__username { .forum__post__username {
color: inherit; color: inherit;
font-size: 1.25em; font-size: 1.4em;
line-height: 2em; line-height: 2em;
text-decoration: none; text-decoration: none;
} }
@ -130,8 +127,8 @@
} }
.forum__post__usertitle { .forum__post__usertitle {
font-size: .75em; font-size: .9em;
line-height: 1.25em; line-height: 1.5em;
margin-bottom: 4px; margin-bottom: 4px;
} }
@ -190,13 +187,12 @@
.forum__post__badge { .forum__post__badge {
background-color: var(--accent-colour); background-color: var(--accent-colour);
border-radius: 24px; border-radius: 12px;
width: 100%; width: 100%;
padding: 2px; padding: 2px;
box-shadow: 0 2px 3px #000A; box-shadow: 0 2px 3px #000A;
margin: 4px; margin: 4px;
overflow: hidden; overflow: hidden;
font-size: .875em;
} }
.forum__post__badge__desktop { .forum__post__badge__desktop {
display: block; display: block;
@ -211,11 +207,13 @@
} }
.forum__post__text { .forum__post__text {
margin: 4px; margin: 4px;
font-size: 1.2em;
line-height: 1.3em;
} }
.forum__post__info { .forum__post__info {
flex-direction: row; flex-direction: row;
margin: 0; margin: 0;
padding: 4px; padding: 5px;
} }
.forum__post__info__content { .forum__post__info__content {
width: 100%; width: 100%;
@ -254,8 +252,8 @@
padding: 2px 10px; padding: 2px 10px;
margin: 0; margin: 0;
align-self: flex-start; align-self: flex-start;
margin-left: 10px; margin-left: 5px;
font-size: .875em; font-size: .9em;
} }
.forum__post__badge__desktop { .forum__post__badge__desktop {
display: none; display: none;

View file

@ -12,7 +12,7 @@
display: flex; display: flex;
justify-content: center; justify-content: center;
align-items: center; align-items: center;
font-size: 1.5em; font-size: 2em;
padding-bottom: 1px; padding-bottom: 1px;
} }
.forum__status__icon__background { .forum__status__icon__background {

View file

@ -4,6 +4,8 @@
overflow: auto; overflow: auto;
} }
.forum__topics__empty { .forum__topics__empty {
font-size: 1.2em;
line-height: 1.5em;
text-align: center; text-align: center;
padding: 10px; padding: 10px;
} }
@ -74,7 +76,7 @@
background-size: 60px 60px; background-size: 60px 60px;
background-image: radial-gradient(ellipse at center, rgba(255, 255, 255, .2) 0%, rgba(0, 0, 0, .4) 100%); background-image: radial-gradient(ellipse at center, rgba(255, 255, 255, .2) 0%, rgba(0, 0, 0, .4) 100%);
box-shadow: 0 1px 4px #111; box-shadow: 0 1px 4px #111;
font-size: 1.125em; font-size: 1.5em;
line-height: 1.5em; line-height: 1.5em;
color: #fff; color: #fff;
display: flex; display: flex;
@ -112,15 +114,14 @@
} }
.forum__topic__title { .forum__topic__title {
font-size: 1.125em; font-size: 1.3em;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
} }
.forum__topic__info { .forum__topic__info {
font-size: .875em; font-size: .9em;
line-height: 1.25em;
} }
.forum__topic__stats, .forum__topic__stats,
@ -136,15 +137,14 @@
} }
.forum__topic__stat { .forum__topic__stat {
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.3em;
opacity: .7; opacity: .7;
pointer-events: auto; pointer-events: auto;
cursor: default; cursor: default;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.forum__topic__stat:first-child { .forum__topic__stat:first-child {
font-size: 1.25em; font-size: 1.4em;
opacity: 1; opacity: 1;
} }
@ -153,7 +153,7 @@
align-items: center; align-items: center;
text-align: right; text-align: right;
min-width: 200px; min-width: 200px;
line-height: 1.25em; line-height: 1.5em;
} }
.forum__topic__activity__details { .forum__topic__activity__details {
display: flex; display: flex;
@ -198,9 +198,8 @@
.forum__topic__pagination { .forum__topic__pagination {
display: flex; display: flex;
align-items: center; align-items: center;
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.2em;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.forum__topic__pagination__separator { .forum__topic__pagination__separator {
margin: 0 8px; margin: 0 8px;
@ -210,7 +209,7 @@
text-decoration: none; text-decoration: none;
pointer-events: initial; pointer-events: initial;
margin: 0 1px; margin: 0 1px;
padding: 3px; padding: 2px 4px;
border-radius: 2px; border-radius: 2px;
min-width: 25px; min-width: 25px;
height: 25px; height: 25px;
@ -263,8 +262,8 @@
.forum__topic__pagination__item { .forum__topic__pagination__item {
min-width: 30px; min-width: 30px;
height: 30px; height: 30px;
line-height: 1.375em; line-height: 26px;
font-size: 1.25em; font-size: 1.2em;
} }
} }

View file

@ -69,7 +69,8 @@
} }
.header__desktop__menu__link { .header__desktop__menu__link {
margin: var(--header-link-margin) 0; margin: var(--header-link-margin) 0;
padding: 4px 10px; font-size: 1.2em;
padding: 6px 10px;
text-align: center; text-align: center;
} }
@ -85,8 +86,6 @@
} }
.header__desktop__submenu__link { .header__desktop__submenu__link {
margin: 5px; margin: 5px;
font-size: .875em;
line-height: 1.5em;
} }
.header__desktop__submenu__background { .header__desktop__submenu__background {
background: var(--header-accent-colour); background: var(--header-accent-colour);
@ -129,8 +128,8 @@
margin: 2px; margin: 2px;
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
font-size: 1.125rem; font-size: 1.5em;
line-height: 2rem; line-height: 32px;
width: 32px; width: 32px;
height: 32px; height: 32px;
transition: background-color .2s; transition: background-color .2s;
@ -150,8 +149,8 @@
top: -5px; top: -5px;
right: -3px; right: -3px;
z-index: 1; z-index: 1;
font-size: .625rem; font-size: .5em;
line-height: 1.375rem; line-height: 1.4em;
text-align: right; text-align: right;
padding: 2px 2px 0; padding: 2px 2px 0;
border-radius: 4px; border-radius: 4px;
@ -159,8 +158,7 @@
opacity: .9; opacity: .9;
border-radius: 4px; border-radius: 4px;
line-height: 12px; line-height: 12px;
padding: 2px 3px; padding: 2px 4px;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
/** MOBILE HEADER **/ /** MOBILE HEADER **/
@ -188,12 +186,18 @@
.header__mobile__icon { .header__mobile__icon {
flex: 0 0 auto; flex: 0 0 auto;
cursor: pointer; cursor: pointer;
font-size: 1.5rem; font-size: 32px;
width: var(--header-icon-px); width: var(--header-icon-px);
height: var(--header-icon-px); height: var(--header-icon-px);
display: flex; display: flex;
justify-content: center; justify-content: center;
align-items: center; align-items: center;
-webkit-touch-callout: none !important;
-webkit-user-select: none !important;
-khtml-user-select: none !important;
-moz-user-select: none !important;
-ms-user-select: none !important;
user-select: none !important; user-select: none !important;
} }
@ -223,7 +227,7 @@
background: var(--background-pattern); background: var(--background-pattern);
background-color: var(--header-accent-colour); background-color: var(--header-accent-colour);
background-blend-mode: multiply; background-blend-mode: multiply;
transition: max-height .3s; transition: max-height .2s;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.6); box-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
max-height: 0; max-height: 0;
overflow: hidden; overflow: hidden;
@ -233,7 +237,7 @@
} }
.header__mobile__toggle:checked ~ .header__mobile__menu { .header__mobile__toggle:checked ~ .header__mobile__menu {
max-height: 100vh; max-height: 600px;
} }
.header__mobile__user { .header__mobile__user {
@ -251,23 +255,24 @@
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
display: block; display: block;
padding: 6px; padding: 8px;
padding-left: 24px; padding-left: 20px;
cursor: pointer; cursor: pointer;
border-radius: 2px; border-radius: 2px;
transition: background-color .2s, margin .1s, opacity .1s; transition: background-color .2s, margin .1s, opacity .1s;
font-size: 1.2em;
} }
.header__mobile__link:not(:last-child) { .header__mobile__link:not(:last-child) {
margin-bottom: 2px; margin-bottom: 2px;
} }
.header__mobile__link--primary { .header__mobile__link--primary {
font-size: 1.25rem; font-size: 1.5em;
padding: 8px; padding: 10px;
} }
.header__mobile__link--user { .header__mobile__link--user {
margin: 2px; margin: 2px;
font-size: 1.25rem; font-size: 1.5em;
padding: 8px; padding: 10px;
} }
.header__mobile__link:hover, .header__mobile__link:hover,
.header__mobile__link:focus { .header__mobile__link:focus {

View file

@ -2,8 +2,8 @@ pre code.hljs {
display: block; display: block;
overflow-x: auto; overflow-x: auto;
padding: 1em; padding: 1em;
font-size: 1.2em;
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
} }
code.hljs { code.hljs {

View file

@ -46,8 +46,8 @@
.landingv2-footer-copyright { .landingv2-footer-copyright {
text-align: right; text-align: right;
line-height: 1.5em; line-height: 1.8em;
font-size: .875em; font-size: .9em;
align-self: flex-end; align-self: flex-end;
} }

View file

@ -52,8 +52,8 @@
display: flex; display: flex;
align-items: center; align-items: center;
min-height: 70px; min-height: 70px;
font-size: 1.5em; font-size: 1.4em;
padding: 8px 16px; padding: 10px 16px;
grid-column: 1; grid-column: 1;
} }
.landingv2-header-menu-link:hover, .landingv2-header-menu-link:hover,

View file

@ -13,6 +13,7 @@
display: flex; display: flex;
align-items: center; align-items: center;
margin: 10px; margin: 10px;
text-shadow: 0 1px 4px #000;
} }
.landingv2-stat-icon { .landingv2-stat-icon {
font-size: 4em; font-size: 4em;
@ -24,7 +25,6 @@
} }
.landingv2-stat-value-num { .landingv2-stat-value-num {
font-weight: 700; font-weight: 700;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.landingv2-forum { .landingv2-forum {
@ -37,6 +37,7 @@
.landingv2-forum-topics { .landingv2-forum-topics {
background-color: var(--container-colour); background-color: var(--container-colour);
box-shadow: 0 1px 2px #0009; box-shadow: 0 1px 2px #0009;
text-shadow: 0 1px 4px #000;
overflow: hidden; overflow: hidden;
word-wrap: break-word; word-wrap: break-word;
} }
@ -94,7 +95,7 @@
background-size: 60px 60px; background-size: 60px 60px;
background-image: radial-gradient(ellipse at center, rgba(255, 255, 255, .2) 0%, rgba(0, 0, 0, .4) 100%); background-image: radial-gradient(ellipse at center, rgba(255, 255, 255, .2) 0%, rgba(0, 0, 0, .4) 100%);
box-shadow: 0 1px 4px #111; box-shadow: 0 1px 4px #111;
font-size: 1.25em; font-size: 1.5em;
line-height: 1.5em; line-height: 1.5em;
color: #fff; color: #fff;
display: flex; display: flex;
@ -109,35 +110,34 @@
display: flex; display: flex;
justify-content: center; justify-content: center;
flex-direction: column; flex-direction: column;
line-height: 1.625em; line-height: 1.6em;
overflow: hidden; overflow: hidden;
} }
.landingv2-forum-topic-info-details-title { .landingv2-forum-topic-info-details-title {
font-size: 1.25em; font-size: 1.3em;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
} }
.landingv2-forum-topic-info-stats { .landingv2-forum-topic-info-stats {
font-size: .875em; font-size: .9em;
display: flex; display: flex;
flex: 0 0 auto; flex: 0 0 auto;
text-align: center; text-align: center;
min-width: 60px; min-width: 60px;
flex-direction: column; flex-direction: column;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.landingv2-forum-topic-info-stats-posts, .landingv2-forum-topic-info-stats-posts,
.landingv2-forum-topic-info-stats-views { .landingv2-forum-topic-info-stats-views {
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.3em;
opacity: .7; opacity: .7;
pointer-events: auto; pointer-events: auto;
cursor: default; cursor: default;
} }
.landingv2-forum-topic-info-stats-posts { .landingv2-forum-topic-info-stats-posts {
font-size: 1.25em; font-size: 1.4em;
opacity: 1; opacity: 1;
} }
@ -150,6 +150,7 @@
.landingv2-news-post { .landingv2-news-post {
background-color: var(--container-colour); background-color: var(--container-colour);
box-shadow: 0 1px 2px #0009; box-shadow: 0 1px 2px #0009;
text-shadow: 0 1px 4px #000;
overflow: hidden; overflow: hidden;
word-wrap: break-word; word-wrap: break-word;
padding: 0 10px 10px 10px; padding: 0 10px 10px 10px;
@ -166,6 +167,7 @@
.landingv2-online { .landingv2-online {
background-color: var(--container-colour); background-color: var(--container-colour);
box-shadow: 0 1px 2px #0009; box-shadow: 0 1px 2px #0009;
text-shadow: 0 1px 4px #000;
margin: 4px 0; margin: 4px 0;
} }
.landingv2-online-users { .landingv2-online-users {

View file

@ -37,6 +37,7 @@
height: 30px; height: 30px;
line-height: 29px; line-height: 29px;
text-align: center; text-align: center;
font-size: 1.5em;
background-color: #222d; background-color: #222d;
display: block; display: block;
color: var(--text-colour); color: var(--text-colour);

View file

@ -57,10 +57,13 @@
width: 45%; width: 45%;
padding: 4px 0; padding: 4px 0;
} }
.landing__statistic__name {
font-size: 1.3em;
line-height: 2em;
}
.landing__statistic__value { .landing__statistic__value {
font-size: 1.25em; font-size: 1.5em;
line-height: 1.625em; line-height: 1.5em;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.landing__latest { .landing__latest {
@ -88,13 +91,13 @@
padding-left: 8px; padding-left: 8px;
} }
.landing__latest__username { .landing__latest__username {
font-size: 1.25em; font-size: 1.5em;
line-height: 1.375em; line-height: 1.4em;
color: var(--user-colour); color: var(--user-colour);
} }
.landing__latest__joined { .landing__latest__joined {
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.2em;
} }
@media (max-width: 800px) { @media (max-width: 800px) {

View file

@ -1,6 +1,6 @@
:root { :root {
--font-size: 16px; --font-size: 12px;
--line-height: 25px; --line-height: 20px;
--site-max-width: 1200px; --site-max-width: 1200px;
--site-mobile-width: 800px; --site-mobile-width: 800px;

View file

@ -9,10 +9,10 @@
flex: 1 1 auto; flex: 1 1 auto;
} }
.manage__description { .manage__description {
font-size: .875em; font-size: .9em;
margin: 1px 2px; margin: 1px 2px;
border-bottom: 1px solid var(--accent-colour); border-bottom: 1px solid var(--accent-colour);
padding: 2px 4px; padding: 2px 5px;
} }
@media (max-width: 800px) { @media (max-width: 800px) {

View file

@ -4,13 +4,13 @@
} }
.manage__ban__title { .manage__ban__title {
font-size: 1.25em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
padding: 0 4px; padding: 0 4px;
} }
.manage__ban__desc { .manage__ban__desc {
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
font-style: italic; font-style: italic;
border-bottom: 1px solid var(--accent-colour); border-bottom: 1px solid var(--accent-colour);

View file

@ -107,7 +107,7 @@
border-top: 1px solid var(--accent-colour); border-top: 1px solid var(--accent-colour);
} }
.manage__bans__item__reason__title { .manage__bans__item__reason__title {
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
font-style: italic; font-style: italic;
} }
@ -117,6 +117,6 @@
} }
.manage__bans__item__noreason { .manage__bans__item__noreason {
font-size: .875em; font-size: .9em;
font-style: italic; font-style: italic;
} }

View file

@ -13,8 +13,7 @@
.manage__blacklist__textarea { .manage__blacklist__textarea {
margin: 0; margin: 0;
padding: 5px 10px; padding: 5px 10px;
font-family: var(--font-monospace); font-family: monospace;
font-feature-settings: 'ss07' 1;
width: 100%; width: 100%;
min-width: 100%; min-width: 100%;
max-width: 100%; max-width: 100%;

View file

@ -4,11 +4,13 @@
.manage__navigation__links { .manage__navigation__links {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
font-size: 1.2em;
} }
.manage__navigation__link { .manage__navigation__link {
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
padding: 2px 8px; padding: 2px 5px;
margin-bottom: 2px;
} }
.manage__navigation__link:hover { .manage__navigation__link:hover {
text-decoration: underline; text-decoration: underline;

View file

@ -17,11 +17,11 @@
.manage__note__title { .manage__note__title {
flex-grow: 1; flex-grow: 1;
flex-shrink: 1; flex-shrink: 1;
font-size: 1.375em; font-size: 1.4em;
line-height: 1.25em; line-height: 1.3em;
} }
.manage__note__title__text { .manage__note__title__text {
padding: 2px 6px; padding: 2px 5px;
} }
.manage__note__title input { .manage__note__title input {
width: 100%; width: 100%;
@ -73,7 +73,7 @@
.manage__note__nobody { .manage__note__nobody {
text-align: center; text-align: center;
font-size: .875em; font-size: .9em;
font-style: italic; font-style: italic;
} }

View file

@ -24,9 +24,9 @@
.manage__notes__item__title { .manage__notes__item__title {
flex-grow: 1; flex-grow: 1;
flex-shrink: 1; flex-shrink: 1;
font-size: 1.25em; font-size: 1.4em;
line-height: 1.25em; line-height: 1.3em;
padding: 2px 6px; padding: 2px 5px;
} }
.manage__notes__item__title a { .manage__notes__item__title a {
color: inherit; color: inherit;
@ -96,7 +96,7 @@
.manage__notes__item__nobody { .manage__notes__item__nobody {
text-align: center; text-align: center;
font-size: .875em; font-size: .9em;
font-style: italic; font-style: italic;
} }

View file

@ -49,7 +49,7 @@
justify-content: center; justify-content: center;
width: 100%; width: 100%;
height: 100%; height: 100%;
font-size: 1.25em; font-size: 1.5em;
transition: background-color .2s; transition: background-color .2s;
} }
.manage__role-item__icon__background { .manage__role-item__icon__background {
@ -73,9 +73,14 @@
flex: 1 1 auto; flex: 1 1 auto;
} }
.manage__role-item__name {
font-size: 1.4em;
line-height: 1.4em;
}
.manage__role-item__details { .manage__role-item__details {
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.3em;
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
padding: 1px 0; padding: 1px 0;
@ -85,11 +90,11 @@
border-radius: 10px; border-radius: 10px;
background-color: var(--accent-colour); background-color: var(--accent-colour);
box-shadow: 0 1px 4px #111; box-shadow: 0 1px 4px #111;
padding: 2px 6px; padding: 2px 5px;
} }
.manage__role-item__title { .manage__role-item__title {
padding: 2px 6px; padding: 2px 5px;
} }
.manage__role-item__actions { .manage__role-item__actions {

View file

@ -27,7 +27,6 @@
} }
.manage-list-setting-key-text { .manage-list-setting-key-text {
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
} }
.manage-list-setting-type { .manage-list-setting-type {
@ -54,7 +53,7 @@
border-radius: 5px; border-radius: 5px;
font-weight: 700; font-weight: 700;
padding: 0 5px; padding: 0 5px;
font-size: .75em; font-size: .9em;
display: inline-block; display: inline-block;
} }
@ -64,7 +63,6 @@
} }
.manage-list-setting-value-text { .manage-list-setting-value-text {
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;

View file

@ -1,21 +1,20 @@
.manage__statistic { .manage__statistic {
border: 1px solid var(--accent-colour); border: 1px solid var(--accent-colour);
border-radius: 2px; border-radius: 2px;
padding: 2px 6px; padding: 2px 5px;
} }
.manage__statistic__name { .manage__statistic__name {
font-size: 1.125em; font-size: 1.1em;
line-height: 1.5em; line-height: 1.5em;
} }
.manage__statistic__value { .manage__statistic__value {
text-align: right; text-align: right;
font-size: 1.375em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.manage__statistic__updated { .manage__statistic__updated {
text-align: right; text-align: right;
font-size: .75em; font-size: .9em;
font-style: italic; font-style: italic;
line-height: 1.5em; line-height: 1.5em;
} }

View file

@ -57,26 +57,25 @@
} }
.manage__user-item__name { .manage__user-item__name {
font-size: 1.125em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.4em;
max-width: 600px; /* whatever */ max-width: 600px; /* whatever */
} }
.manage__user-item__details { .manage__user-item__details {
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.3em;
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
} }
.manage__user-item__detail { .manage__user-item__detail {
border-radius: 16px; border-radius: 10px;
background-color: var(--accent-colour); background-color: var(--accent-colour);
box-shadow: 0 1px 4px #111; box-shadow: 0 1px 4px #111;
padding: 2px 8px; padding: 3px 8px;
pointer-events: initial; pointer-events: initial;
margin: 2px; margin: 2px;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.manage__user-item__actions { .manage__user-item__actions {
@ -89,7 +88,7 @@
width: 32px; width: 32px;
height: 32px; height: 32px;
line-height: 32px; line-height: 32px;
font-size: 1.25em; font-size: 1.5em;
border-radius: 2px; border-radius: 2px;
margin: 5px; margin: 5px;
margin-right: 0; margin-right: 0;

View file

@ -4,13 +4,13 @@
} }
.manage__warning__title { .manage__warning__title {
font-size: 1.25em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
padding: 0 4px; padding: 0 4px;
} }
.manage__warning__desc { .manage__warning__desc {
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
font-style: italic; font-style: italic;
border-bottom: 1px solid var(--accent-colour); border-bottom: 1px solid var(--accent-colour);

View file

@ -1,5 +1,5 @@
.markdown { .markdown {
line-height: 1.5em; line-height: 1.7em;
} }
.markdown a { .markdown a {
@ -78,7 +78,8 @@
.markdown h1, .markdown h2, .markdown h1, .markdown h2,
.markdown h3, .markdown h4, .markdown h3, .markdown h4,
.markdown h5, .markdown h6 { .markdown h5, .markdown h6 {
margin: calc(var(--font-size) * 0.875) 0; margin-top: calc(var(--font-size) * 1.2);
margin-bottom: var(--font-size);
font-weight: 700; font-weight: 700;
line-height: 1em; line-height: 1em;
} }

View file

@ -3,6 +3,8 @@
align-items: center; align-items: center;
height: 30px; height: 30px;
margin: 1px; margin: 1px;
font-size: 1.3em;
line-height: 1.4em;
color: #fff; color: #fff;
text-decoration: none; text-decoration: none;
transition: background-color .1s; transition: background-color .1s;
@ -10,7 +12,6 @@
border: 0; border: 0;
background-color: inherit; background-color: inherit;
text-align: left; text-align: left;
font-size: 1rem;
} }
.messages-actions-item:hover, .messages-actions-item:hover,
.messages-actions-item:focus { .messages-actions-item:focus {

View file

@ -10,6 +10,8 @@
} }
.messages-entry-header { .messages-entry-header {
display: flex; display: flex;
font-size: 1.1em;
line-height: 1.6em;
border-bottom: 2px solid #9999; border-bottom: 2px solid #9999;
gap: 2px; gap: 2px;
} }
@ -58,12 +60,12 @@
align-self: flex-end; align-self: flex-end;
} }
.messages-entry-subject { .messages-entry-subject {
line-height: 1.5em; line-height: 1.4em;
color: #fff; color: #fff;
overflow: hidden; overflow: hidden;
} }
.messages-entry-preview { .messages-entry-preview {
line-height: 1.5em; line-height: 1.4em;
color: #888; color: #888;
overflow: hidden; overflow: hidden;
} }

View file

@ -25,7 +25,7 @@
margin: 10px; margin: 10px;
} }
.messages-folder-notice-text { .messages-folder-notice-text {
font-size: 1.375em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
} }
.messages-folder .pagination { .messages-folder .pagination {

View file

@ -6,7 +6,7 @@
} }
.messages-message-snippet { .messages-message-snippet {
cursor: pointer; cursor: pointer;
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
color: #888; color: #888;
gap: 5px; gap: 5px;
@ -117,7 +117,7 @@
} }
.messages-message-body { .messages-message-body {
line-height: 1.5em; line-height: 1.4em;
} }
.messages-message-body p:first-child { .messages-message-body p:first-child {
margin-top: 0 !important; margin-top: 0 !important;
@ -131,5 +131,5 @@
-webkit-line-clamp: 2; -webkit-line-clamp: 2;
-webkit-box-orient: vertical; -webkit-box-orient: vertical;
overflow: hidden; overflow: hidden;
line-height: 1.5em; line-height: 1.4em;
} }

View file

@ -9,7 +9,7 @@
display: flex; display: flex;
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
font-size: 1.25em; font-size: 1.5em;
line-height: 32px; line-height: 32px;
height: 32px; height: 32px;
transition: background-color .2s; transition: background-color .2s;

View file

@ -44,7 +44,7 @@
.news__post__username { .news__post__username {
color: inherit; color: inherit;
font-size: 1.25em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
text-decoration: none; text-decoration: none;
} }
@ -53,14 +53,14 @@
} }
.news__post__date { .news__post__date {
font-size: .875em; font-size: 1.1em;
line-height: 1.5em; line-height: 1.5em;
} }
.news__post__category { .news__post__category {
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
font-size: 1.125em; font-size: 1.1em;
line-height: 1.5em; line-height: 1.5em;
margin: 6px 0; margin: 6px 0;
} }
@ -69,6 +69,7 @@
} }
.news__post__text { .news__post__text {
line-height: 1.2em;
flex: 1 1 auto; flex: 1 1 auto;
word-wrap: break-word; word-wrap: break-word;
overflow: hidden; overflow: hidden;
@ -100,4 +101,4 @@
width: 50px; width: 50px;
height: 50px; height: 50px;
} }
} }

View file

@ -23,8 +23,8 @@
} }
.news__preview__title h1 { .news__preview__title h1 {
font-weight: 700; font-size: 2em;
line-height: 1.375em; line-height: 1.5em;
} }
.news__preview__attrs { .news__preview__attrs {
@ -32,7 +32,7 @@
flex-shrink: 0; flex-shrink: 0;
display: flex; display: flex;
gap: 4px; gap: 4px;
font-size: .875em; font-size: .9em;
} }
.news__preview__attr { .news__preview__attr {
@ -62,7 +62,7 @@
} }
.news__preview__content { .news__preview__content {
line-height: 1.5em; line-height: 1.4em;
word-wrap: break-word; word-wrap: break-word;
overflow: hidden; overflow: hidden;
} }
@ -73,5 +73,5 @@
} }
.news__preview__link { .news__preview__link {
font-size: .875em; font-size: .9em;
} }

View file

@ -23,7 +23,9 @@
.pagination__link { .pagination__link {
display: flex; display: flex;
min-width: 40px; min-width: 40px;
min-height: 36px; font-size: 1.2em;
line-height: 1.5em;
padding: 3px 10px 4px;
text-align: center; text-align: center;
text-decoration: none; text-decoration: none;
background-color: var(--background-colour); background-color: var(--background-colour);
@ -35,17 +37,13 @@
align-items: center; align-items: center;
justify-content: center; justify-content: center;
flex: 1 0 auto; flex: 1 0 auto;
font-feature-settings: 'ss01' 1, 'tnum' 1;
} }
.pagination__link:not(:last-child) { margin-right: 1px; }
.pagination__link:not(:last-child) { .pagination__link--disabled { --accent-colour: #555; }
margin-right: 1px; .pagination__link--first, .pagination__link--last,
.pagination__link--next, .pagination__link--prev {
padding-top: 5px;
} }
.pagination__link--disabled {
--accent-colour: #555;
}
.pagination__link--current, .pagination__link--current,
.pagination__link:not(.pagination__link--disabled):hover, .pagination__link:not(.pagination__link--disabled):hover,
.pagination__link:not(.pagination__link--disabled):active, .pagination__link:not(.pagination__link--disabled):active,
@ -55,7 +53,5 @@
} }
@media (max-width: 800px) { @media (max-width: 800px) {
.pagination__section--pages { .pagination__section--pages { display: none; }
display: none;
}
} }

View file

@ -6,12 +6,12 @@
.permissions__line { .permissions__line {
display: flex; display: flex;
font-size: .8rem; font-size: .9em;
line-height: 1.5rem; line-height: 1.7em;
} }
.permissions__line--header { .permissions__line--header {
font-size: 1rem; font-size: 1.2em;
line-height: 1.25rem; line-height: 1.4em;
border-bottom: 1px solid rgba(255, 255, 255, .1); border-bottom: 1px solid rgba(255, 255, 255, .1);
padding-bottom: 1px; padding-bottom: 1px;
font-weight: 700; font-weight: 700;

View file

@ -1,26 +1,30 @@
.profile__accounts__content { .profile__accounts__content {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
padding: 2px 6px; padding: 2px 5px;
} }
.profile__accounts__item { .profile__accounts__item {
padding-bottom: 4px; padding-bottom: 5px;
} }
.profile__accounts__item:not(:last-child) { .profile__accounts__item:not(:last-child) {
border-bottom: 1px solid #222; border-bottom: 1px solid #222;
} }
.profile__accounts__notice { .profile__accounts__notice {
font-size: 1.2em;
line-height: 1.5em;
text-align: center; text-align: center;
padding: 10px; padding: 10px;
} }
.profile__accounts__title { .profile__accounts__title {
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.8em;
} }
.profile__accounts__value { .profile__accounts__value {
font-size: 1.2em;
line-height: 1.2em;
color: inherit; color: inherit;
text-decoration: none; text-decoration: none;
} }

View file

@ -1,5 +1,5 @@
.profile__birthdate__content { .profile__birthdate__content {
padding: 2px 6px; padding: 2px 5px;
} }
.profile__birthdate__select { .profile__birthdate__select {
min-width: auto; min-width: auto;
@ -8,6 +8,6 @@
display: inline-block; display: inline-block;
} }
.profile__birthdate__title { .profile__birthdate__title {
font-size: .875em; font-size: .9em;
line-height: 1.75em; line-height: 1.8em;
} }

View file

@ -7,14 +7,14 @@
} }
.profile__forum-activity__leader { .profile__forum-activity__leader {
font-size: .875em; font-size: .9em;
margin: 0 4px; margin: 0 5px;
} }
.profile__forum-activity .forum__category__icon { .profile__forum-activity .forum__category__icon {
width: 30px; width: 30px;
height: 30px; height: 30px;
font-size: 1.25em; font-size: 1.5em;
line-height: 1.5em; line-height: 1.5em;
flex: 0 0 30px; flex: 0 0 30px;
} }

View file

@ -14,18 +14,20 @@
padding: 1px; padding: 1px;
} }
.profile__guidelines__line--header { .profile__guidelines__line--header {
font-weight: 600; font-size: 1.2em;
line-height: 1.5em;
font-weight: 700;
margin-bottom: 2px; margin-bottom: 2px;
border-bottom: 1px solid var(--accent-colour); border-bottom: 1px solid var(--accent-colour);
padding-bottom: 2px; padding-bottom: 2px;
} }
.profile__guidelines__line:not(.profile__guidelines__line--header) { .profile__guidelines__line:not(.profile__guidelines__line--header) {
margin-left: 1.25em; margin-left: 1.3em;
list-style: square; list-style: square;
} }
.profile__guidelines__emphasis { .profile__guidelines__emphasis {
font-weight: 600; font-weight: 700;
} }
.profile__guidelines__link { .profile__guidelines__link {

View file

@ -101,11 +101,12 @@
min-width: 130px; min-width: 130px;
} }
.profile__header__stat__name { .profile__header__stat__name {
font-size: .875em; font-size: .9em;
font-variant: small-caps;
cursor: inherit; cursor: inherit;
} }
.profile__header__stat__value { .profile__header__stat__value {
font-size: 1.125em; font-size: 1.3em;
text-align: right; text-align: right;
cursor: inherit; cursor: inherit;
display: block; display: block;
@ -113,9 +114,6 @@
.profile__header__stat--date .profile__header__stat__value { .profile__header__stat--date .profile__header__stat__value {
text-align: left; text-align: left;
} }
.profile__header__stat:not(.profile__header__stat--date) .profile__header__stat__value {
font-feature-settings: 'ss01' 1, 'tnum' 1;
}
.profile__header__stat--link { .profile__header__stat--link {
cursor: pointer; cursor: pointer;
} }
@ -124,18 +122,17 @@
.profile__header__stat--link:focus, .profile__header__stat--link:focus,
.profile__header__stat--link:active, .profile__header__stat--link:active,
.profile__header__stat--active { .profile__header__stat--active {
padding-bottom: 8px;
border-bottom: 2px solid var(--accent-colour); border-bottom: 2px solid var(--accent-colour);
} }
.profile__header__username { .profile__header__username {
font-size: 1.75em; font-size: 2em;
line-height: 1.125em; line-height: 1.5em;
} }
.profile__header__title { .profile__header__title {
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.2em;
} }
.profile__header__country { .profile__header__country {
@ -143,9 +140,9 @@
align-items: center; align-items: center;
} }
.profile__header__country__name { .profile__header__country__name {
font-size: .875em; font-size: .9em;
margin-left: 4px; margin-left: 4px;
line-height: 1.25em; line-height: 1.2em;
} }
@media (max-width: 800px) { @media (max-width: 800px) {

View file

@ -12,15 +12,15 @@
} }
.profile__warnings__datetime { .profile__warnings__datetime {
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
font-style: italic; font-style: italic;
padding-top: 2px; padding-top: 2px;
} }
.profile__warnings__body { .profile__warnings__body {
padding: 0 6px; padding: 0 5px;
} }
.profile__warnings__body p { .profile__warnings__body p {
line-height: 1.375em; line-height: 1.4em;
} }

View file

@ -11,6 +11,7 @@
overflow: hidden; overflow: hidden;
border: 1px solid transparent; border: 1px solid transparent;
border-radius: 5px; border-radius: 5px;
font-size: 1.1em;
margin: 1px 1px 1px 0; margin: 1px 1px 1px 0;
} }
@ -32,5 +33,5 @@
} }
.search__category__content { .search__category__content {
padding: 2px 6px; padding: 2px 5px;
} }

View file

@ -4,8 +4,7 @@
overflow: hidden; overflow: hidden;
border: 1px solid transparent; border: 1px solid transparent;
border-radius: 5px; border-radius: 5px;
font-family: var(--font-regular); font-size: 1.5em;
font-size: 1.125em;
} }
.search__input__background { .search__input__background {
background-color: var(--background-colour-translucent-9); background-color: var(--background-colour-translucent-9);
@ -25,7 +24,7 @@
border: 0; border: 0;
background-color: transparent; background-color: transparent;
color: #fff; color: #fff;
padding: 4px 12px; padding: 5px 10px;
font-size: inherit; font-size: inherit;
} }

View file

@ -6,7 +6,7 @@
height: 60px; height: 60px;
line-height: 60px; line-height: 60px;
text-align: center; text-align: center;
font-size: 2.5em; font-size: 3em;
flex: 0 0 auto; flex: 0 0 auto;
} }
.search__none__content { .search__none__content {
@ -16,6 +16,6 @@
flex: 1 1 auto; flex: 1 1 auto;
} }
.search__none__title { .search__none__title {
font-size: 1.25em; font-size: 1.5em;
line-height: 1.25em; line-height: 1.5em;
} }

View file

@ -22,7 +22,7 @@
.settings__account-log__important { .settings__account-log__important {
display: flex; display: flex;
align-items: center; align-items: center;
font-size: 1.25em; font-size: 1.4em;
z-index: 2; z-index: 2;
} }

View file

@ -18,8 +18,8 @@
} }
.settings__account__title { .settings__account__title {
font-size: .875em; font-size: .9em;
line-height: 1.75em; line-height: 1.8em;
} }
.settings__account__input { .settings__account__input {
@ -43,4 +43,4 @@
.settings__account__section { .settings__account__section {
grid-column: 1 / 1; grid-column: 1 / 1;
} }
} }

View file

@ -2,7 +2,7 @@
margin: 4px; margin: 4px;
} }
.settings__login-attempts__none { .settings__login-attempts__none {
padding: 2px 6px; padding: 2px 5px;
text-align: center; text-align: center;
} }
@ -31,7 +31,7 @@
.settings__login-attempt__important { .settings__login-attempt__important {
display: flex; display: flex;
align-items: center; align-items: center;
font-size: 1.25em; font-size: 1.4em;
z-index: 2; z-index: 2;
} }

View file

@ -22,7 +22,8 @@
} }
.settings__role__name { .settings__role__name {
line-height: 1.5em; font-size: 1.2em;
line-height: 1.7em;
padding: 0 5px; padding: 0 5px;
margin: 2px 0; margin: 2px 0;
min-width: 160px; min-width: 160px;
@ -39,8 +40,8 @@
} }
.settings__role__description { .settings__role__description {
font-size: .875em; font-size: .9em;
line-height: 1.75em; line-height: 1.8em;
padding: 0 2px; padding: 0 2px;
margin: 0 2px; margin: 0 2px;
flex: 1 1 auto; flex: 1 1 auto;
@ -49,7 +50,7 @@
.settings__role__options { .settings__role__options {
flex: 0 0 auto; flex: 0 0 auto;
display: flex; display: flex;
font-size: 1.25em; font-size: 1.5em;
justify-content: space-evenly; justify-content: space-evenly;
} }

View file

@ -29,7 +29,7 @@
.settings__session__important { .settings__session__important {
display: flex; display: flex;
align-items: center; align-items: center;
font-size: 1.25em; font-size: 1.4em;
z-index: 2; z-index: 2;
} }

View file

@ -6,13 +6,10 @@
} }
.settings__description { .settings__description {
font-size: .875rem; font-size: .9em;
line-height: 1.25rem; padding: 2px 5px;
border-bottom: 1px solid var(--accent-colour); border-bottom: 1px solid var(--accent-colour);
padding: 2px 6px; margin: 1px 1px 2px;
}
.settings__description p {
margin: .25rem 0;
} }
.settings__pagination { .settings__pagination {
@ -42,7 +39,7 @@
display: block; display: block;
padding: 4px; padding: 4px;
margin: 2px; margin: 2px;
font-size: 1.25em; font-size: 1.5em;
line-height: 1.5em; line-height: 1.5em;
border-radius: 2px; border-radius: 2px;
transition: background-color .2s; transition: background-color .2s;
@ -65,4 +62,4 @@
display: inline-block; display: inline-block;
padding: 4px 10px; padding: 4px 10px;
} }
} }

View file

@ -17,9 +17,9 @@
.settings__two-factor__code__text { .settings__two-factor__code__text {
color: #000; color: #000;
flex: 0 0 auto; flex: 0 0 auto;
padding: 2px 6px; font-size: 1.2em;
line-height: 1.5em;
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
} }
.settings__two-factor__settings { .settings__two-factor__settings {
@ -30,7 +30,7 @@
flex: 1 1 auto; flex: 1 1 auto;
} }
.settings__two-factor__settings__status { .settings__two-factor__settings__status {
font-size: 1.25em; font-size: 1.5em;
line-height: 2em; line-height: 2em;
} }

View file

@ -51,16 +51,16 @@
} }
.usercard__details__username { .usercard__details__username {
font-size: 1.125em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.4em;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
} }
.usercard__details__title { .usercard__details__title {
font-size: .75em; font-size: .9em;
line-height: 1em; line-height: 1.2em;
} }
.usercard__details__country { .usercard__details__country {
@ -68,9 +68,9 @@
align-items: center; align-items: center;
} }
.usercard__details__country__name { .usercard__details__country__name {
font-size: .75em; font-size: .9em;
margin-left: 4px; margin-left: 4px;
line-height: 1em; line-height: 1.2em;
} }
.usercard__stats { .usercard__stats {
@ -111,19 +111,17 @@
} }
.usercard__stat__name { .usercard__stat__name {
display: block; display: block;
font-size: .875em; font-size: .9em;
line-height: 1.5em; line-height: 1.5em;
font-variant: small-caps;
cursor: inherit; cursor: inherit;
} }
.usercard__stat__value { .usercard__stat__value {
display: block; display: block;
font-size: 1.125em; font-size: 1.2em;
line-height: 1.25em; line-height: 1.5em;
cursor: inherit; cursor: inherit;
} }
.usercard__stat:not(.usercard__stat--wide) .usercard__stat__value {
font-feature-settings: 'ss01' 1, 'tnum' 1;
}
@media (max-width: 800px) { @media (max-width: 800px) {
.usercard { .usercard {
@ -155,8 +153,8 @@
.usercard__stat__name, .usercard__stat__name,
.usercard__stat__value { .usercard__stat__value {
display: inline-block; display: inline-block;
font-size: .875em; font-size: .9em;
line-height: 1.25em; line-height: 1.2em;
font-variant: initial; font-variant: initial;
} }
} }

View file

@ -8,8 +8,8 @@
} }
.userlist__empty { .userlist__empty {
text-align: center; text-align: center;
font-size: 1.5em; font-size: 2em;
line-height: 1.25em; line-height: 1.5em;
margin: 1em; margin: 1em;
} }
.userlist__container { .userlist__container {

View file

@ -14,7 +14,7 @@
--end-colour: #f00; --end-colour: #f00;
} }
.warning--bigger { .warning--bigger {
font-size: 1.375em; font-size: 1.4em;
line-height: 1.5em; line-height: 1.5em;
} }
.warning__content { .warning__content {

View file

@ -102,8 +102,7 @@ const MsgMessagesEntry = function(entry) {
entry.dataset.msgRead = state ? 'sent' : 'draft'; entry.dataset.msgRead = state ? 'sent' : 'draft';
}; };
const checkboxWrapper = entry.querySelector('.js-entry-checkbox-wrapper'); const checkbox = entry.querySelector('.js-entry-checkbox');
const checkbox = checkboxWrapper.querySelector('.js-entry-checkbox');
const getSelected = () => checkbox.checked; const getSelected = () => checkbox.checked;
const setSelected = state => checkbox.checked = state; const setSelected = state => checkbox.checked = state;
const toggleSelected = () => checkbox.checked = !checkbox.checked; const toggleSelected = () => checkbox.checked = !checkbox.checked;
@ -114,7 +113,6 @@ const MsgMessagesEntry = function(entry) {
watchers.define(['select']); watchers.define(['select']);
checkbox.addEventListener('click', ev => ev.stopPropagation()); checkbox.addEventListener('click', ev => ev.stopPropagation());
checkboxWrapper.addEventListener('click', ev => ev.stopPropagation());
checkbox.addEventListener('keydown', ev => ev.stopPropagation()); checkbox.addEventListener('keydown', ev => ev.stopPropagation());
checkbox.addEventListener('change', () => { checkbox.addEventListener('change', () => {

View file

@ -1,30 +0,0 @@
const MszOAuth2AppInfoLink = function(info) {
const element = <a href={info.uri} target="_blank" rel="noopener noreferrer" class="oauth2-appinfo-link" title={info.title}>
<div class="oauth2-appinfo-link-icon oauth2-appinfo-link-icon-globe"></div>
<div class="oauth2-appinfo-link-text">{info.display}</div>
</a>;
return {
get element() { return element; },
};
};
const MszOAuth2AppInfo = function(info) {
const linksElem = <div class="oauth2-appinfo-links"/>;
if(Array.isArray(info.links))
for(const link of info.links)
linksElem.appendChild((new MszOAuth2AppInfoLink(link)).element);
// TODO: author should be listed
const element = <div class="oauth2-appinfo">
<div class="oauth2-appinfo-name">{info.name}</div>
{linksElem}
<div class="oauth2-appinfo-summary">
<p>{info.summary}</p>
</div>
</div>;
return {
get element() { return element; },
};
};

View file

@ -1,33 +0,0 @@
const MszOAuth2AppScopeEntry = function(text, warn) {
const icon = <div class="oauth2-scope-perm-icon"/>;
if(warn)
icon.classList.add('oauth2-scope-perm-icon-warn');
const element = <div class="oauth2-scope-perm">
{icon}
<div class="oauth2-scope-perm-text">{text}</div>
</div>;
return {
get element() { return element; },
};
};
const MszOAuth2AppScopeList = function(scopes) {
const permsElem = <div class="oauth2-scope-perms"/>;
if(Array.isArray(scopes) && scopes.length > 0) {
for(const scope of scopes)
if(typeof scope === 'string')
permsElem.appendChild(new MszOAuth2AppScopeEntry(scope).element);
} else
permsElem.appendChild(new MszOAuth2AppScopeEntry('A limited amount of things. No scope was specified by the developer.', true).element);
const element = <div class="oauth2-scope">
<div class="oauth2-scope-header">This application will be able to:</div>
{permsElem}
</div>;
return {
get element() { return element; },
};
};

View file

@ -24,8 +24,8 @@
} }
.redir-landing-footer { .redir-landing-footer {
font-size: .75em; font-size: .8em;
line-height: 1.375em; line-height: 1.4em;
text-align: center; text-align: center;
margin: 10px; margin: 10px;
} }

View file

@ -17,7 +17,6 @@ body {
pre, code { pre, code {
font-family: var(--font-monospace); font-family: var(--font-monospace);
font-feature-settings: 'ss07' 1;
} }
a { a {

View file

@ -22,5 +22,5 @@
} }
.redir-social-body p { .redir-social-body p {
margin: .5em; margin: .5em;
line-height: 1.5em; line-height: 1.4em;
} }

View file

@ -16,14 +16,14 @@ const fs = require('fs');
js: [ js: [
{ source: 'common.js', target: '/assets', name: 'common.{hash}.js', }, { source: 'common.js', target: '/assets', name: 'common.{hash}.js', },
{ source: 'misuzu.js', target: '/assets', name: 'misuzu.{hash}.js', }, { source: 'misuzu.js', target: '/assets', name: 'misuzu.{hash}.js', },
{ source: 'oauth2.js', target: '/assets', name: 'oauth2.{hash}.js', }, { source: 'auth.js', target: '/assets', name: 'auth.{hash}.js', },
{ source: 'redirects.js', target: '/assets', name: 'redirects.{hash}.js', }, { source: 'redirects.js', target: '/assets', name: 'redirects.{hash}.js', },
], ],
css: [ css: [
{ source: 'errors.css', target: '/', name: 'errors.css', }, { source: 'errors.css', target: '/', name: 'errors.css', },
{ source: 'common.css', target: '/assets', name: 'common.{hash}.css', }, { source: 'common.css', target: '/assets', name: 'common.{hash}.css', },
{ source: 'misuzu.css', target: '/assets', name: 'misuzu.{hash}.css', }, { source: 'misuzu.css', target: '/assets', name: 'misuzu.{hash}.css', },
{ source: 'oauth2.css', target: '/assets', name: 'oauth2.{hash}.css', }, { source: 'auth.css', target: '/assets', name: 'auth.{hash}.css', },
{ source: 'redirects.css', target: '/assets', name: 'redirects.{hash}.css', }, { source: 'redirects.css', target: '/assets', name: 'redirects.{hash}.css', },
], ],
twig: [ twig: [

View file

@ -3,7 +3,6 @@
"php": ">=8.4", "php": ">=8.4",
"ext-mbstring": "*", "ext-mbstring": "*",
"flashwave/index": "^0.2504", "flashwave/index": "^0.2504",
"railgun/jwt": "^0.3",
"erusev/parsedown": "~1.7", "erusev/parsedown": "~1.7",
"chillerlan/php-qrcode": "~5.0", "chillerlan/php-qrcode": "~5.0",
"symfony/mailer": "~7.2", "symfony/mailer": "~7.2",

Some files were not shown because too many files have changed in this diff Show more