2021-06-08 14:14:47 -05:00
: root {
2021-07-19 23:07:49 -05:00
--font-fallback : - apple-system , BlinkMacSystemFont , Segoe UI , Helvetica , Arial , sans-serif , Apple Color Emoji , Segoe UI Emoji ;
--font-body : ' IBM Plex Sans ' , var ( -- font-fallback ) ;
--font-mono : ' IBM Plex Mono ' , Consolas , ' Andale Mono WT ' , ' Andale Mono ' , ' Lucida Console ' , ' Lucida Sans Typewriter ' , ' DejaVu Sans Mono ' , ' Bitstream Vera Sans Mono ' ,
' Liberation Mono ' , ' Nimbus Mono L ' , Monaco , ' Courier New ' , Courier , monospace ;
--color-white : #fff ;
2021-06-08 14:14:47 -05:00
--color-black : #000014 ;
2021-07-19 23:07:49 -05:00
--color-gray-50 : #f9fafb ;
--color-gray-100 : #f3f4f6 ;
--color-gray-200 : #e5e7eb ;
--color-gray-300 : #d1d5db ;
--color-gray-400 : #9ca3af ;
--color-gray-500 : #6b7280 ;
--color-gray-600 : #4b5563 ;
2021-06-08 14:14:47 -05:00
--color-gray-700 : #374151 ;
2021-07-19 23:07:49 -05:00
--color-gray-800 : #1f2937 ;
2021-06-08 14:14:47 -05:00
--color-gray-900 : #111827 ;
2021-07-19 23:07:49 -05:00
--color-blue : #3894ff ;
--color-blue-rgb : 56 , 148 , 255 ;
--color-green : #17c083 ;
--color-green-rgb : 23 , 192 , 131 ;
--color-orange : #ff5d01 ;
--color-orange-rgb : 255 , 93 , 1 ;
--color-purple : #882de7 ;
--color-purple-rgb : 136 , 45 , 231 ;
--color-red : #ff1639 ;
--color-red-rgb : 255 , 22 , 57 ;
--color-yellow : #ffbe2d ;
--color-yellow-rgb : 255 , 190 , 45 ;
2021-06-08 14:14:47 -05:00
}
: root {
color-scheme : light ;
--theme-accent : var ( -- color - orange ) ;
--theme-accent-rgb : var ( -- color - orange - rgb ) ;
--theme-accent-opacity : 0 .1 ;
--theme-divider : var ( -- color - gray - 100 ) ;
--theme-text : var ( -- color - gray - 800 ) ;
--theme-text-light : var ( -- color - gray - 600 ) ;
--theme-text-lighter : var ( -- color - gray - 400 ) ;
--theme-bg : var ( -- color - white ) ;
--theme-bg-offset : var ( -- color - gray - 100 ) ;
--theme-bg-accent : rgba ( var ( -- theme-accent-rgb ) , var ( -- theme-accent-opacity )) ;
--theme-code-inline-bg : var ( -- color - gray - 100 ) ;
--theme-code-text : var ( -- color - gray - 100 ) ;
--theme-code-bg : var ( -- color - gray - 700 ) ;
}
body {
background : var ( -- theme-bg ) ;
color : var ( -- theme-text ) ;
}
: root . theme-dark {
color-scheme : dark ;
--theme-accent-opacity : 0 .3 ;
--theme-divider : var ( -- color - gray - 900 ) ;
--theme-text : var ( -- color - gray - 200 ) ;
--theme-text-light : var ( -- color - gray - 400 ) ;
--theme-text-lighter : var ( -- color - gray - 600 ) ;
--theme-bg : var ( -- color - black ) ;
--theme-bg-offset : var ( -- color - gray - 900 ) ;
--theme-code-inline-bg : var ( -- color - gray - 800 ) ;
--theme-code-text : var ( -- color - gray - 200 ) ;
--theme-code-bg : var ( -- color - gray - 900 ) ;
}
: : selection {
color : var ( -- theme-accent ) ;
background-color : rgba ( var ( -- theme-accent-rgb ) , var ( -- theme-accent-opacity )) ;
}
2021-06-08 14:01:46 -05:00
* {
box-sizing : border-box ;
margin : 0 ;
}
: root {
--user-font-scale : 1 rem - 16 px ;
--max-width : calc ( 100 % - 2 rem ) ;
}
@media ( min-width : 50 em ) {
: root {
--max-width : 40 em ;
}
}
body {
display : flex ;
flex-direction : column ;
min-height : 100 vh ;
font-family : var ( -- font-body ) ;
font-size : 1 rem ;
font-size : clamp ( 0 .875 rem , 0 .4626 rem + 1 .0309 vw + var ( -- user-font-scale ) , 1 .125 rem ) ;
line-height : 1 .625 ;
}
body {
width : 100 % ;
display : grid ;
--gutter : 0 .5 rem ;
--doc-padding : 2 rem ;
}
. layout {
display : grid ;
grid-auto-flow : column ;
grid-template-columns : minmax ( var ( -- gutter ) , 1 fr ) minmax ( 0 , var ( -- max-width )) minmax ( var ( -- gutter ) , 1 fr ) ;
gap : 1 em ;
}
. layout > article {
grid-column : 2 ;
}
nav ul {
list-style : none ;
padding : 0 ;
}
/* Typography */
: is ( h1 , h2 , h3 , h4 , h5 , h6 ) {
margin-bottom : 1 .38 rem ;
font-weight : 400 ;
line-height : 1 .3 ;
}
: is ( h1 , h2 ) {
max-width : 40 ch ;
}
: is ( h2 , h3 ) : not ( : first-child ) {
margin-top : 3 rem ;
}
h1 {
2021-07-19 23:07:49 -05:00
font-size : clamp ( 2 .488 rem , 1 .924 rem + 1 .41 vw , 3 .052 rem ) ;
2021-06-08 14:01:46 -05:00
}
h2 {
2021-07-19 23:07:49 -05:00
font-size : clamp ( 2 .074 rem , 1 .707 rem + 0 .9175 vw , 2 .441 rem ) ;
2021-06-08 14:01:46 -05:00
}
h3 {
2021-07-19 23:07:49 -05:00
font-size : clamp ( 1 .728 rem , 1 .503 rem + 0 .5625 vw , 1 .953 rem ) ;
2021-06-08 14:01:46 -05:00
}
h4 {
2021-07-19 23:07:49 -05:00
font-size : clamp ( 1 .44 rem , 1 .317 rem + 0 .3075 vw , 1 .563 rem ) ;
2021-06-08 14:01:46 -05:00
}
h5 {
2021-07-19 23:07:49 -05:00
font-size : clamp ( 1 .2 rem , 1 .15 rem + 0 .125 vw , 1 .25 rem ) ;
2021-06-08 14:01:46 -05:00
}
p {
color : var ( -- theme-text-light ) ;
}
2021-07-19 23:07:49 -05:00
small ,
. text_small {
2021-06-08 14:01:46 -05:00
font-size : 0 .833 rem ;
}
a {
color : var ( -- theme-accent ) ;
font-weight : 400 ;
text-underline-offset : 0 .08 em ;
text-decoration : none ;
align-items : center ;
gap : 0 .5 rem ;
}
2021-07-19 23:07:49 -05:00
a > code : not ( [ class * = ' language ' ] ) {
2021-06-08 14:01:46 -05:00
position : relative ;
color : var ( -- theme-accent ) ;
background : transparent ;
text-underline-offset : var ( -- padding-block ) ;
}
2021-07-19 23:07:49 -05:00
a > code : not ( [ class * = ' language ' ] ) : : before {
2021-06-08 14:01:46 -05:00
content : ' ' ;
position : absolute ;
top : 0 ;
right : 0 ;
bottom : 0 ;
left : 0 ;
display : block ;
background : var ( -- theme-accent ) ;
opacity : var ( -- theme-accent-opacity ) ;
border-radius : var ( -- border-radius ) ;
}
a : hover ,
a : focus {
text-decoration : underline ;
}
a : focus {
outline : 2 px solid currentColor ;
outline-offset : 0 .25 em ;
}
strong {
font-weight : 600 ;
color : inherit ;
}
/* Supporting Content */
2021-07-19 23:07:49 -05:00
code : not ( [ class * = ' language ' ] ) {
2021-06-08 14:01:46 -05:00
--border-radius : 3 px ;
--padding-block : 0 .2 rem ;
--padding-inline : 0 .33 rem ;
font-family : var ( -- font-mono ) ;
2021-07-19 23:07:49 -05:00
font-size : 0 .85 em ;
2021-06-08 14:01:46 -05:00
color : inherit ;
background-color : var ( -- theme-code-inline-bg ) ;
padding : var ( -- padding-block ) var ( -- padding-inline ) ;
margin : calc ( var ( -- padding-block ) * - 1 ) - 0 .125 em ;
border-radius : var ( -- border-radius ) ;
}
2021-07-19 23:07:49 -05:00
pre > code : not ( [ class * = ' language ' ] ) {
2021-06-08 14:01:46 -05:00
background-color : transparent ;
padding : 0 ;
margin : 0 ;
border-radius : 0 ;
color : inherit ;
}
pre {
position : relative ;
background-color : var ( -- theme-code-bg ) ;
color : var ( -- theme-code-text ) ;
--padding-block : 1 rem ;
--padding-inline : 2 rem ;
padding : var ( -- padding-block ) var ( -- padding-inline ) ;
padding-right : calc ( var ( -- padding-inline ) * 2 ) ;
margin-left : calc ( 50 vw - var ( -- padding-inline )) ;
transform : translateX ( - 50 vw ) ;
2021-07-19 23:07:49 -05:00
2021-06-08 14:01:46 -05:00
line-height : 1 .414 ;
width : calc ( 100 vw + ( var ( -- padding-inline ) * 2 )) ;
max-width : calc ( 100 % + ( var ( -- padding-inline ) * 2 )) ;
overflow-y : hidden ;
overflow-x : auto ;
}
@media ( min-width : 37 .75 em ) {
pre {
--padding-inline : 1 .25 rem ;
border-radius : 8 px ;
}
}
. flex {
display : flex ;
align-items : center ;
}
img . cover {
width : 100 % ;
max-height : 50 vh ;
object-fit : cover ;
2021-06-08 14:14:47 -05:00
}