html body { color: var(--text-color); background: var(--background-color); font-family: var(--font-mono); letter-spacing: -.025rem; word-spacing: -.075rem; scrollbar-width: thin; scrollbar-color: var(--accent-color) var(--gray-light); } html { font-size: 100%; -webkit-text-size-adjust: none; } body { font-size: var(--font-size-base); line-height: var(--line-height-base); } ::-moz-selection { color: var(--color-lightest); background: var(--accent-color); } ::selection { color: var(--color-lightest); background: var(--accent-color); } ::-webkit-scrollbar-track { background-color: var(--gray-light); } ::-webkit-scrollbar-thumb { background: var(--accent-color); border-radius: var(--border-radius-full); } ::-webkit-scrollbar-button { background-color: var(--accent-color); } ::-webkit-scrollbar, body::-webkit-scrollbar { width: var(--sizing-md); height: var(--sizing-md); } p { margin: var(--margin-vertical-base-horizontal-zero); &.books, &.concerts, &.country, &.favorite, &.movies, &.tv, &.music, &.posts, &.tattoo { &.books { --section-color: var(--books); } &.concerts { --section-color: var(--concerts); } &.country { --section-color: var(--country); } &.favorite { --section-color: var(--favorite); } &.movies, &.tv { --section-color: var(--tv); } &.music { --section-color: var(--music); } &.posts { --section-color: var(--posts); } &.tattoo { --section-color: var(--tattoo); } color: var(--section-color); & svg { stroke: var(--section-color); } } & a { text-decoration: underline; text-decoration-style: dashed; text-underline-offset: var(--spacing-xs); } } blockquote { font-size: var(--font-size-lg); color: var(--gray-dark); padding-left: var(--spacing-lg); border-left: var(--sizing-xs) solid var(--gray-dark); margin: var(--margin-vertical-base-horizontal-zero); } code { padding: var(--spacing-xs); color: var(--text-color-inverted); background-color: var(--background-color-inverted); border-radius: var(--border-radius-slight); } p:not(.flex-centered):not(.banner p) > svg { margin-bottom: var(--inline-margin-bottom); } :is(h1, h2, h3, h4, h5, h6) svg { stroke-width: var(--stroke-width-bold); } :is(h1, h2, h3, h4, h5, h6):has(svg) { gap: var(--spacing-xs) } strong, blockquote { font-weight: var(--font-weight-bold); } em, blockquote { font-style: italic; } svg { width: var(--sizing-svg-base); height: var(--sizing-svg-base); stroke-width: var(--stroke-width-default); } /* links */ a { color: var(--accent-color); text-decoration: none; &.mail > svg { stroke: var(--brand-gmail); } &.brand-github > svg { stroke: var(--brand-github); } &.brand-npm > svg { stroke: var(--brand-npm); } &.brand-mastodon > svg { stroke: var(--brand-mastodon); } &.article > svg { stroke: var(--posts); } &.books > svg { stroke: var(--books); } &.device-watch > svg { stroke: var(--now); } &.coffee > svg { stroke: var(--brand-buy-me-a-coffee); } &.device-tv-old > svg { stroke: var(--tv); } &.favorite > svg { stroke: var(--favorite); } &.headphones > svg { stroke: var(--music); } &.heart-handshake > svg { stroke: var(--webrings); } &.info-circle > svg { stroke: var(--about); } &.link > svg { stroke: var(--links); } &.mail-plus > svg { stroke: var(--newsletter); } &.rss > svg { stroke: var(--brand-rss); } &.search > svg { stroke: var(--search); } & svg { stroke: var(--accent-color); &[data-tablericon-name^="arrow-"]:hover, &[data-tablericon-name^="arrow-"]:active, &[data-tablericon-name^="arrow-"]:focus { stroke: var(--accent-color-hover); } } } :is(a:hover, a:active, a:focus) svg[data-tablericon-name^="arrow-"] { stroke: var(--accent-color-hover); } a:focus, a:focus-within a:focus > svg, a:focus-within > svg { outline: var(--outline-default); border-radius: var(--border-radius-slight); text-decoration: none; } a:has(svg):focus, a:has(svg):focus-within { outline: none; } a.icon-link:focus, a.icon-link:focus-within { outline: var(--outline-default); border-radius: var(--border-radius-slight); text-decoration: none; & svg { outline: none; } } a:hover, a:focus, a:active, :is(.main-title, footer nav.sub-pages) a:hover, :is(.main-title, footer nav.sub-pages) a:focus, :is(.main-title, footer nav.sub-pages) a:active { color: var(--accent-color-hover); transition-property: color; transition-timing-function: var(--transition-ease-in-out); transition-duration: var(--transition-duration-default); } :is( a:has(svg):hover, a:has(svg):active, a:has(svg):focus ) svg { stroke: var(--accent-color-hover); } :is(a):has(svg) { display: inline-flex; align-items: center; gap: var(--spacing-xs); & svg { stroke: var(--accent-color); } &:hover svg, &:active svg, &:focus svg { stroke: var(--accent-color-hover); } } /* headers */ h1, h2, h3, h4, h5, h6 { font-weight: var(--font-weight-bold); line-height: var(--line-height-md); margin: var(--margin-vertical-base-horizontal-zero); } h1 { font-size: var(--font-size-2xl); @media screen and (min-width: 768px) { font-size: var(--font-size-3xl); } } h2 { font-size: var(--font-size-xl); @media screen and (min-width: 768px) { font-size: var(--font-size-2xl); } } h3 { font-size: var(--font-size-lg); @media screen and (min-width: 768px) { font-size: var(--font-size-xl); } } h4 { font-size: var(--font-size-base); @media screen and (min-width: 768px) { font-size: var(--font-size-lg); } } h5 { font-size: var(--font-size-md); @media screen and (min-width: 768px) { font-size: var(--font-size-base); } } h6 { font-size: var(--font-size-sm); @media screen and (min-width: 768px) { font-size: var(--font-size-md); } } .section-header-wrapper { justify-content: space-between; margin: var(--spacing-xl) 0 var(--spacing-lg); & .section-header { margin: 0; } } .section-header { margin: var(--spacing-xl) 0 var(--spacing-lg); line-height: var(--line-height-sm); &.posts { margin: 0 0 var(--spacing-lg); } } /* dividers */ hr { height: 1px; background-color: var(--gray-light); border: 0; margin: var(--margin-vertical-base-horizontal-zero); & + .section-header { margin-top: 0; } } /* tables */ table { display: block; overflow-x: auto; width: 100%; border: var(--border-gray); border-radius: var(--border-radius-slight); white-space: nowrap; caption-side: bottom; overscroll-behavior: none; } table, th, td { border-collapse: collapse; width: 100%; } :is(th, td):not(:first-child, :last-child) { border-right: var(--border-gray); } th, tr:not(:last-child) { border-bottom: var(--border-gray); } th, td { padding: var(--spacing-sm); min-width: max-content; word-break: break-word; width: 100%; &:first-child { position: sticky; left: 0; border-inline-end: none; max-width: 200px; text-overflow: ellipsis; overflow: hidden; &::after { content: ''; position: absolute; inset-block-start: 0; inset-inline-end: 0; width: 1px; height: 100%; background: var(--gray-light); } } } td { min-width: calc(var(--spacing-3xl) * 2); &:first-child { background-color: var(--background-color); } } td:first-of-type, :where(thead, tfoot) th:nth-child(2) { border-inline-start: none; } th { font-weight: var(--font-weight-bold); background-color: var(--gray-lighter); text-align: left; } /* header */ .main-title { width: 100%; padding-top: var(--spacing-3xl); display: flex; flex-direction: row; align-items: center; justify-content: space-between; & h1 { font-weight: var(--font-weight-extrabold); margin: 0; padding: 0; } } /* nav */ .active, .active svg { cursor: not-allowed; color: var(--accent-color); stroke: var(--accent-color-hover); } /* layout */ .default-wrapper { padding-top: var(--spacing-2xl); & .posts-wrapper article:last-of-type, & .article-widget-wrapper:last-of-type { border-bottom: none; } & > h2 { margin-top: 0; } & > a + h2 { margin-top: var(--spacing-base); } } .main-wrapper { min-height: 100vh; display: flex; flex-direction: column; } main { flex: 1 1 0%; width: 80%; margin-left: auto; margin-right: auto; @media screen and (min-width: 768px) { max-width: 768px; } } .status, article { margin-bottom: var(--spacing-base); } .status, .posts-wrapper article { border-bottom: var(--border-gray); } .status p:first-child { margin-top: 0; } .article-widget-wrapper { border-bottom: var(--border-gray); margin-bottom: var(--spacing-base); & article { border-bottom: none; } } footer { & p:first-of-type { margin: var(--spacing-3xl) 0 var(--spacing-lg); font-size: var(--font-size-sm); } & nav { &.social { gap: var(--spacing-md); margin-bottom: var(--spacing-lg); width: 100%; & svg { margin-top: 0; } & a { display: flex; } } &.sub-pages { font-size: var(--font-size-sm); padding-bottom: var(--spacing-3xl); & span:not(.active) { margin-left: var(--spacing-sm); margin-right: var(--spacing-sm); } } } } :is(.main-title, footer nav.sub-pages) a { color: var(--text-color); } /* articles */ article { & h3 { margin: 0; display: inline-block; } & time { display: block; color: var(--gray-dark); font-size: var(--font-size-sm); } } /* lists */ ul, ol { list-style-position: inside; margin: var(--margin-vertical-base-horizontal-zero); padding-left: var(--spacing-base); & li { margin-top: var(--spacing-lg); margin-bottom: var(--spacing-lg); } } /* images */ .image-banner { border: var(--border-default); border-radius: var(--border-radius-slight); height: auto; width: 100%; display: block; } /* utilities */ .highlight-text { color: var(--color-lightest); background-color: var(--accent-color); padding: var(--spacing-xs); border-radius: var(--border-radius-slight); } .hidden { display: none !important; } .text-centered { text-align: center !important; } .flex-centered { display: flex; flex-direction: row; align-items: center; } .justify-centered { justify-content: center; }