Mercurial
view mrjunejune/src/base.css @ 190:a2725419f988 hg-web
Updated so that bun builds will with already existing js files.
| author | MrJuneJune <me@mrjunejune.com> |
|---|---|
| date | Sat, 24 Jan 2026 21:06:42 -0800 |
| parents | 1c0878eb17de |
| children | 3b47e82ac57e |
line wrap: on
line source
/* Reset CSS: https://meyerweb.com/eric/tools/css/reset/ */ html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; } /* --- Colors ---*/ :root { --white: #ffffff; --black: hsl(224, 12%, 4%); --darkgray: #333333; --gray: #5d5d5d; --lightgray: #999999; --gray-light: var(--lightgray); --green: #c2e15f; --orange: #fda333; --purple: #d3a4f9; --red: #fb4485; --blue: #6ce0f1; --darktext: #414141; /* from astro */ --accent: #2337ff; --accent-dark: #000d8a; --gray: 96, 115, 159; --gray-light: 229, 233, 240; --gray-dark: 34, 41, 57; --gray-gradient: rgba(var(--gray-light), 50%), #fff; --box-shadow: 0 2px 6px rgba(var(--gray), 25%), 0 8px 24px rgba(var(--gray), 33%), 0 16px 32px rgba(var(--gray), 33%); --awesome: #dc3522; --main-width: 720px; } .dark { --white: hsl(224, 10%, 10%); --black: hsl(0, 0%, 90%); --darkgray: #cccccc; /* Inverted */ --lightgray: #666666; /* Inverted */ --gray-light: var(--lightgray); --green: #3d1ea0; /* Complementary */ --orange: #025ccc; /* Complementary */ --purple: #2b5b06; /* Complementary */ --red: #04bb7a; /* Complementary */ --blue: #932f0e; /* Complementary */ --darktext: #bebebe; /* Inverted */ --text: var(--lightgray); /* Opposite of --darkgray */ --graytext: var(--lightgray); /* Opposite of --gray */ --lighttext: var(--darkgray); /* Opposite of --lightgray */ --awesome: #23cade; /* Complementary */ /* Opposite of Astro Colors */ --accent: #ffcc00; /* Complementary */ --accent-dark: #ffb275; /* Modified complementary */ --gray: 159, 140, 96; /* Inverted */ --gray-light: 26, 22, 15; /* Inverted */ --gray-dark: 221, 214, 198; /* Inverted */ --gray-gradient: rgba(26, 22, 15, 50%), #000; /* Adjusted */ --box-shadow: 0 -2px -6px rgba(159, 140, 96, 25%), 0 -8px -24px rgba(159, 140, 96, 33%), 0 -16px -32px rgba(159, 140, 96, 33%); } @media (prefers-color-scheme: dark) { :root:not(.light-mode) { --white: hsl(224, 10%, 10%); --black: hsl(0, 0%, 90%); --darkgray: #cccccc; --lightgray: #666666; --gray-light: var(--lightgray); --green: #3d1ea0; --orange: #025ccc; --purple: #2b5b06; --red: #04bb7a; --blue: #932f0e; --darktext: #bebebe; --awesome: #23cade; --accent: #ffcc00; --accent-dark: #ffb275; --gray: 159, 140, 96; --gray-light: 26, 22, 15; --gray-dark: 221, 214, 198; --gray-gradient: rgba(26, 22, 15, 50%), #000; --box-shadow: 0 -2px -6px rgba(159, 140, 96, 25%), 0 -8px -24px rgba(159, 140, 96, 33%), 0 -16px -32px rgba(159, 140, 96, 33%); } } /* --- fonts --- */ /* @font-face { font-family: "Atkinson"; src: url("/public/fonts/atkinson-regular.woff") format("woff"); font-weight: 400; font-style: normal; } @font-face { font-family: "Atkinson"; src: url("/public/fonts/atkinson-bold.woff") format("woff"); font-weight: 700; font-style: normal; } */ @font-face { font-family: "Roboto"; src: url("/public/fonts/Roboto-Regular.ttf"); } @font-face { font-family: "Roboto Light"; src: url("/public/fonts/Roboto-Thin.ttf"); } @font-face { font-family: "More Thin"; src: url("/public/fonts/more-sugar.thin.otf"); } @font-face { font-family: "More"; src: url("/public/fonts/more-sugar.regular.otf"); } /* -- HTML Tags only --*/ html { background: var(--white); } a { color: inherit; /* blue colors for links too */ text-decoration: inherit; /* no underline */ } body { font-family: "More Thin", sans-serif; margin: 0; padding: 0; text-align: left; background: var(--gray-gradient); background-size: 100% 600px; word-wrap: break-word; overflow-wrap: break-word; color: rgb(var(--gray-dark)); font-size: 20px; line-height: 1.7; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } main { background: var(--white); width: var(--main-width); max-width: calc(100% - 2em); margin: auto; } h1, h2, h3, h4, h5, h6 { margin: 0 0 0.5rem 0; color: rgb(var(--black)); line-height: 1.2; } h1 { font-size: 2.5em; } h2 { font-size: 2em; } h3 { font-size: 1.75em; } h4 { font-size: 1.5em; } h5 { font-size: 1.25em; } strong, b { font-weight: 700; } p { margin-bottom: 1em; } .prose p { margin-bottom: 2em; } textarea { width: 100%; font-size: 16px; } input { font-size: 16px; } table { width: 100%; } img { max-width: 100%; height: auto; border-radius: 8px; } code { padding: 2px 5px; background-color: rgb(var(--gray-light)); border-radius: 2px; } pre { padding: 1.5em; border-radius: 8px; } blockquote { border-left: 4px solid var(--accent); padding: 0 0 0 20px; margin-bottom: 1.25em; font-size: 1.333em; } ul { margin-bottom: 1.25em; } hr { border: none; border-top: 1px solid rgb(var(--gray-light)); } .center { display: flex; justify-content: center; } a { text-decoration: underline; } a::before { content: ""; display: inline-block; width: 1em; height: 1em; margin-right: 8px; vertical-align: middle; background-color: #FF69B4; -webkit-mask: url('/public/paw.svg') no-repeat center; mask: url('/public/paw.svg') no-repeat center; animation: pawStep 0.6s ease-out forwards; } @keyframes pawStep { 0% { transform: scale(0); opacity: 0; } 100% { transform: scale(1); opacity: 1; } } a:hover::before { animation: wiggle 0.4s ease-in-out infinite; } @keyframes wiggle { 0%, 100% { transform: rotate(-15deg); } 50% { transform: rotate(15deg); } } /* -- mobile -- */ @media (max-width: 720px) { body { font-size: 18px; line-height: 1.8; } main { padding: 1.5em 1em; } h1 { font-size: 2em; } h2 { font-size: 1.75em; } h3 { font-size: 1.5em; } h4 { font-size: 1.25em; } h5 { font-size: 1.1em; } p { margin-bottom: 1.25em; } /* Better touch targets for mobile */ a { padding: 0.25em 0; display: inline-block; } button, input[type="submit"], input[type="button"] { min-height: 44px; padding: 0.75em 1.5em; font-size: 1em; } input, textarea, select { font-size: 16px; /* Prevents zoom on iOS */ } /* Improve blockquote readability */ blockquote { font-size: 1.1em; padding: 0.5em 0 0.5em 1em; } /* Better code block sizing */ code { font-size: 0.9em; } pre { padding: 1em; overflow-x: auto; } }