/** * 98.css * Copyright (c) 2020 Jordan Scales * https://github.com/jdan/98.css/blob/master/LICENSE */ :root { /* Color */ --surface: #c0c0c0; --button-highlight: #ffffff; --button-face: #dfdfdf; --button-shadow: #808080; --window-frame: #0a0a0a; --dialog-blue: #000080; --dialog-blue-light: #1084d0; --link-blue: #0000ff; /* Spacing */ --element-spacing: 8px; --grouped-button-spacing: 4px; --grouped-element-spacing: 6px; --radio-width: 12px; --checkbox-width: 13px; --radio-label-spacing: 6px; /* Some detailed computations for radio buttons and checkboxes */ --radio-total-width-precalc: var(--radio-width) + var(--radio-label-spacing); --radio-total-width: calc(var(--radio-total-width-precalc)); --radio-left: calc(-1 * var(--radio-total-width-precalc)); --radio-dot-width: 4px; --radio-dot-top: calc(var(--radio-width) / 2 - var(--radio-dot-width) / 2); --radio-dot-left: calc( -1 * (var(--radio-total-width-precalc)) + var(--radio-width) / 2 - var( --radio-dot-width ) / 2 ); --checkbox-total-width-precalc: var(--checkbox-width) + var(--radio-label-spacing); --checkbox-total-width: calc(var(--checkbox-total-width-precalc)); --checkbox-left: calc(-1 * var(--checkbox-total-width-precalc)); --checkmark-width: 7px; --checkmark-top: 3px; --checkmark-left: 3px; /* Borders */ --border-width: 1px; --border-raised-outer: inset -1px -1px var(--window-frame), inset 1px 1px var(--button-highlight); --border-raised-inner: inset -2px -2px var(--button-shadow), inset 2px 2px var(--button-face); --border-sunken-outer: inset -1px -1px var(--button-highlight), inset 1px 1px var(--window-frame); --border-sunken-inner: inset -2px -2px var(--button-face), inset 2px 2px var(--button-shadow); /* Field borders (checkbox, input, etc) flip window-frame and button-shadow */ --border-field: inset -1px -1px var(--button-highlight), inset 1px 1px var(--button-shadow), inset -2px -2px var(--button-face), inset 2px 2px var(--window-frame); } @font-face { font-family: "Pixelated MS Sans Serif"; src: url("fonts/converted/ms_sans_serif.woff") format("woff"); src: url("fonts/converted/ms_sans_serif.woff2") format("woff2"); font-weight: normal; font-style: normal; } @font-face { font-family: "Pixelated MS Sans Serif"; src: url("fonts/converted/ms_sans_serif_bold.woff") format("woff"); src: url("fonts/converted/ms_sans_serif_bold.woff2") format("woff2"); font-weight: bold; font-style: normal; } body { font-family: Arial; font-size: 12px; color: #222222; } button, label, input, textarea, select, option, ul.tree-view, .window, .title-bar { font-family: "Pixelated MS Sans Serif", Arial; -webkit-font-smoothing: none; font-size: 11px; } h1 { font-size: 5rem; } h2 { font-size: 2.5rem; } h3 { font-size: 2rem; } h4 { font-size: 1.5rem; } u { text-decoration: none; border-bottom: 0.5px solid #222222; } button { box-sizing: border-box; border: none; background: var(--surface); box-shadow: var(--border-raised-outer), var(--border-raised-inner); border-radius: 0; min-width: 75px; min-height: 23px; padding: 0 12px; } button:not(:disabled):active { box-shadow: var(--border-sunken-outer), var(--border-sunken-inner); } button:focus { outline: 1px dotted #000000; outline-offset: -4px; } button::-moz-focus-inner { border: 0; } :disabled, :disabled + label { color: var(--button-shadow); text-shadow: 1px 1px 0 var(--button-highlight); } .window { box-shadow: var(--border-raised-outer), var(--border-raised-inner); background: var(--surface); padding: 3px; } .title-bar { background: linear-gradient( 90deg, var(--dialog-blue), var(--dialog-blue-light) ); padding: 2px; display: flex; justify-content: space-between; align-items: center; } .title-bar-text { font-weight: bold; color: white; letter-spacing: 0; margin-right: 24px; } .title-bar-controls { display: flex; } .title-bar-controls button { padding: 0; display: block; min-width: 14px; min-height: 12px; } .title-bar-controls button:focus { outline: none; } .title-bar-controls button[aria-label="Minimize"] { background-image: svg-load("./icon/minimize.svg"); background-repeat: no-repeat; background-position: bottom 2px left 3px; } .title-bar-controls button[aria-label="Maximize"] { background-image: svg-load("./icon/maximize.svg"); background-repeat: no-repeat; /* Off by 1px because contents can't go above the inner shadow */ /* Should be 9px by 9px, with top 1px */ background-position: top 2px left 2px; } .title-bar-controls button[aria-label="Close"] { margin-left: 2px; background-image: svg-load("./icon/close.svg"); background-repeat: no-repeat; background-position: top 2px center; } .window-body { margin: var(--element-spacing); } fieldset { border: none; box-shadow: var(--border-sunken-outer), var(--border-raised-inner); padding: calc(2 * var(--border-width) + var(--element-spacing)); padding-block-start: var(--element-spacing); margin: 0; } legend { background: var(--surface); } .field-row { display: flex; align-items: center; } [class^="field-row"] + [class^="field-row"] { margin-top: var(--grouped-element-spacing); } .field-row * + * { margin-left: var(--grouped-element-spacing); } .field-row-stacked { display: flex; flex-direction: column; } .field-row-stacked * + * { margin-top: var(--grouped-element-spacing); } label { display: inline-flex; align-items: center; } input[type="radio"], input[type="checkbox"] { appearance: none; -webkit-appearance: none; -moz-appearance: none; margin: 0; border: none; } input[type="radio"] + label, input[type="checkbox"] + label { line-height: 13px; } input[type="radio"] + label { position: relative; margin-left: var(--radio-total-width); } input[type="radio"] + label::before { content: ""; position: absolute; top: 0; left: calc(-1 * (var(--radio-total-width-precalc))); display: inline-block; width: var(--radio-width); height: var(--radio-width); margin-right: var(--radio-label-spacing); background: svg-load("./icon/radio-border.svg"); } input[type="radio"]:checked + label::after { content: ""; display: block; width: var(--radio-dot-width); height: var(--radio-dot-width); top: var(--radio-dot-top); left: var(--radio-dot-left); position: absolute; background: svg-load("./icon/radio-dot.svg"); } input[type="radio"]:focus + label, input[type="checkbox"]:focus + label { outline: 1px dotted #000000; } input[type="radio"][disabled] + label::before { background: svg-load("./icon/radio-border-disabled.svg"); } input[type="radio"][disabled]:checked + label::after { background: svg-load("./icon/radio-dot-disabled.svg"); } input[type="checkbox"] + label { position: relative; margin-left: var(--checkbox-total-width); } input[type="checkbox"] + label::before { content: ""; position: absolute; left: calc(-1 * (var(--checkbox-total-width-precalc))); display: inline-block; width: var(--checkbox-width); height: var(--checkbox-width); background: var(--button-highlight); box-shadow: var(--border-field); margin-right: var(--radio-label-spacing); } input[type="checkbox"]:checked + label::after { content: ""; display: block; width: var(--checkmark-width); height: var(--checkmark-width); position: absolute; top: var(--checkmark-top); left: calc( -1 * (var(--checkbox-total-width-precalc)) + var(--checkmark-left) ); background: svg-load("./icon/checkmark.svg"); } input[type="checkbox"][disabled] + label::before { background: var(--surface); } input[type="checkbox"][disabled]:checked + label::after { background: svg-load("./icon/checkmark-disabled.svg"); } input[type="text"], select, textarea { padding: 3px 4px; border: none; box-shadow: var(--border-field); background-color: var(--button-highlight); box-sizing: border-box; -webkit-appearance: none; -moz-appearance: none; appearance: none; border-radius: 0; } input[type="text"], select { height: 21px; } input[type="text"] { /* For some reason descenders are getting cut off without this */ line-height: 2; } select { appearance: none; -webkit-appearance: none; -moz-appearance: none; position: relative; padding-right: 32px; background-image: svg-load("./icon/button-down.svg"); background-position: top 2px right 2px; background-repeat: no-repeat; border-radius: 0; } select:focus, input[type="text"]:focus, textarea:focus { outline: none; } select:focus { color: var(--button-highlight); background-color: var(--dialog-blue); } select:focus option { color: #000; background-color: #fff; } select:active { background-image: svg-load("./icon/button-down-active.svg"); } a { color: var(--link-blue); } a:focus { outline: 1px dotted var(--link-blue); } ul.tree-view { display: block; background: var(--button-highlight); box-shadow: var(--border-field); padding: 6px; margin: 0; } ul.tree-view li { list-style-type: none; } ul.tree-view a { text-decoration: none; color: #000; } ul.tree-view a:focus { background-color: var(--dialog-blue); color: var(--button-highlight); } ul.tree-view ul, ul.tree-view li { margin-top: 3px; } ul.tree-view ul { margin-left: 16px; padding-left: 16px; /* Goes down too far */ border-left: 1px dotted #808080; } ul.tree-view ul > li { position: relative; } ul.tree-view ul > li::before { content: ""; display: block; position: absolute; left: -16px; top: 6px; width: 12px; border-bottom: 1px dotted #808080; } /* Cover the bottom of the left dotted border */ ul.tree-view ul > li:last-child::after { content: ""; display: block; position: absolute; left: -20px; top: 7px; bottom: 0px; width: 8px; background: var(--button-highlight); } pre { display: block; background: var(--button-highlight); box-shadow: var(--border-field); padding: 12px 8px; margin: 0; } code, code * { font-family: monospace; } summary:focus { outline: 1px dotted #000000; } ::-webkit-scrollbar { width: 16px; } ::-webkit-scrollbar:horizontal { height: 17px; } ::-webkit-scrollbar-corner { background: var(--button-face); } ::-webkit-scrollbar-track { background-image: svg-load("./icon/scrollbar-background.svg"); } ::-webkit-scrollbar-thumb { background-color: var(--button-face); box-shadow: var(--border-raised-outer), var(--border-raised-inner); } ::-webkit-scrollbar-button:vertical:start { height: 17px; background-image: svg-load("./icon/button-up.svg"); } ::-webkit-scrollbar-button:vertical:end { height: 17px; background-image: svg-load("./icon/button-down.svg"); } ::-webkit-scrollbar-button:horizontal:start { width: 16px; background-image: svg-load("./icon/button-left.svg"); } ::-webkit-scrollbar-button:horizontal:end { width: 16px; background-image: svg-load("./icon/button-right.svg"); }