You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

425 lines
7.2 KiB

.default{
--c: var(--c-default);
}
.contributed{
--c: var(--c-contributed);
}
.jave{
--c: var(--c-jave);
}
body{
background-color: var(--c-back);
}
img{
display: block;
max-width: 100%;
}
/* BAR
================================================= */
body{
margin-top: calc(var(--bar-h) * 1);
}
body > .tabs{
position: fixed;
top: 0;
width: 100%;
z-index: 99999;
}
nav ul,
.controls{
box-sizing: border-box;
width: 100%;
display: flex;
align-items: center;
}
nav ul li{
flex-grow: 1;
}
nav ul li:not(:last-child){
border-right: 1px solid var(--c-back);
}
nav ul a{
color: white;
padding: 0 2rem;
display: flex;
align-items: center;
justify-content: center;
text-decoration: none;
height: var(--bar-h);
background-color: black;
box-sizing: border-box;
}
nav ul a.active{
background-color: var(--c-link);
}
/* CONTROLS
================================================= */
.controls{
position: fixed;
gap: 0.5rem;
top: var(--bar-h);
background-color: var(--c-back);
padding: 0rem 1rem;
height: var(--bar-h);
z-index: 99;
}
#text-input{
width: 26em;
}
.controls hr{
display: block !important;
border: none;
margin: none;
margin-left: auto;
}
.reload::after{
content: 'reload';
position: fixed;
inset: 0;
background-color: rgba(0,0,205,0.2);
z-index: 998;
pointer-events: all;
color: white;
right: 0.5rem;
display: flex;
justify-content: center;
align-items: center;
}
/* BOXES
================================================= */
.box{
box-sizing: border-box;
padding: 0 2rem 1rem;
}
.two-columns{
display: flex;
flex-wrap: wrap;
gap: var(--bar-h);
}
.two-columns > *{
flex: 1 1 0%;
}
/* one font block */
.split-screen{
display: grid;
grid-template-columns: repeat(2, calc(50% - 0.5rem));
gap: 1rem;
padding: 0 1rem 1rem;
position: relative;
}
.split-screen aside{
position: absolute;
bottom: 0.5rem;
display: flex;
gap: 0.5rem;
}
body.write .split-screen,
body.catalogue .split-screen,
body.image .split-screen,
body.draw .split-screen{
height: calc(100vh - var(--bar-h) * 2);
grid-template-rows: 1fr;
box-sizing: border-box;
}
body.write,
body.catalogue,
body.image,
body.draw{
margin-top: calc(var(--bar-h) * 2);
}
body.image .f-image,
body.image .f-ascii{
grid-row: auto;
grid-column: 1;
}
body.image .f-svg{
grid-row: -1 / 1;
grid-column: 2;
}
body.image .f-image img{
width: 100%;
height: 100%;
object-fit: contain;
filter: grayscale(1);
}
aside.right{
right: 2.5rem;
}
aside.left{
right: calc(50vw + 1.5rem);
}
.split-screen h2{
font-size: 0.875rem;
grid-column: 1 / -1;
font-weight: normal;
}
.f-image,
.f-ascii,
.f-svg{
background-color: white;
overflow: auto;
height: 100%;
width: 100%;
box-sizing: border-box;
grid-row: 1 / span 1;
border: 1px solid black;
font-family: monospace;
font-size: 1rem;
line-height: 1;
}
.f-svg iframe{
border: none !important;
width: 100%;
height: 100%;
display: block;
}
body.image .split-screen{
grid-template-columns: 1fr 2fr;
}
.f-double{
width: 100%;
height: 100%;
}
.split-screen:first-of-type{
margin-top: 1rem;
}
/* TITLE
================================================= */
.title.split-screen{
padding: 2rem 2rem 4rem;
gap: 0 var(--bar-h);
grid-template-columns: repeat(2, calc(50% - calc(var(--bar-h) / 2)));
}
.title .f-ascii{
margin-left: auto;
grid-row: auto;
}
.title .f-svg{
grid-row: auto;
margin-right: auto;
padding: 0;
}
.title .f-ascii,
.title .f-svg{
padding: 0;
background: initial;
border: none;
width: auto;
}
.title svg {
overflow: visible;
max-width: 100%;
grid-column: span 2;
max-height: 21rem;
margin: 0 auto;
}
.title svg a{
fill: var(--c-link);
}
.title svg a.software{
font-weight: bold;
}
.title .intro{
margin: 1rem auto;
grid-column: span 2;
max-width: 48rem;
}
/* gallery
================================================= */
.gallery{
padding: 2rem 2rem 4rem;
margin: 2rem 0;
grid-column: span 2;
display: grid;
grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
gap: 1rem;
}
.gallery h3{
font-size: 0.875rem;
font-weight: bold;
grid-column: 1 / -1;
}
.gallery h2{
display: block;
font-size: 0.875rem;
font-weight: bold;
grid-column: 1 / -1;
width: fit-content;
padding: 1rem;
margin: 1rem auto;
border: 1px solid black;
}
/* font
================================================= */
.write .split-screen{
grid-template-columns: 32rem 1fr;
}
/* catalogue
================================================= */
.catalogue .split-screen{
grid-template-columns: 1fr;
}
details{
position: relative;
z-index: 999;
}
details[open] > summary{
background-color: var(--c-link);
color: white;
}
#current-figfont,
.category{
width: 15em;
}
.collection-menu{
position: relative;
}
.collection-menu[open] .collection-menu-back{
position: fixed;
inset: 0;
top: var(--bar-h);
padding: 0 1rem 1rem;
background-color: rgba(240, 240, 240, 0.85);
background-color: var(--c-back);
}
.collection-menu-back{
display: flex;
justify-content: flex-end;
flex-direction: column;
}
summary{
padding: calc(1rem - 1px) 1rem;
height: var(--bar-h);
border-top: 1px solid var(--c-back);
box-sizing: border-box;
background: lightgray;
color: black;
cursor: pointer;
white-space: nowrap;
padding-right: 3rem;
z-index: 999;
position: relative;
}
summary span{
display: inline-block;
position: absolute;
right: 0.5rem;
}
summary + div{
position: absolute;
left: calc(100% + 1px);
top: 0;
}
.collection{
top: calc(-1 * var(--bar-h) * calc(var(--index) - 1) + 1px);
max-height: calc(100vh - 1px - var(--bar-h));
overflow: auto;
width: calc(100vw - 30rem);
display: grid;
grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
gap: 1px;
padding-bottom: var(--bar-h);
box-sizing: border-box;
}
.collection > .figfont{
padding: 0rem 0.5rem;
background: lightgray;
cursor: pointer;
white-space: nowrap;
box-sizing: border-box;
display: flex;
justify-content: space-between;
align-items: center;
gap: 0.25rem;
position: relative;
}
.specimen-link {
display: flex;
align-items: center;
padding: 1em;
}
.figfont:hover{
color: var(--c-link);
}
/* catalogue colors */
.figfont::after{
content: '';
width: 0.75rem;
height: 0.75rem;
border-radius: 50%;
background-color: var(--c);
display: inline-block;
position: absolute;
top: 0.5rem;
right: 0.5rem;
}
.thumbnail{
mix-blend-mode: darken;
display: block;
}
.legend{
width: 24rem;
font-size: 0.825rem;
margin-top: 1em;
}
.legend::before{
content: '';
width: 0.75rem;
height: 0.75rem;
border-radius: 50%;
background-color: var(--c);
margin-right: 0.5rem;
display: inline-block;
vertical-align: middle;
}