view mrjunejune/src/base.css @ 116:7bd795bac997

[Postdog] Added scrollable area to inputs and history files, buttons to delete and view.
author June Park <parkjune1995@gmail.com>
date Wed, 07 Jan 2026 04:52:17 -0800
parents 65e5a5b89a4e
children 902e29c38d66
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;
  --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 */
  --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;
    --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;
  padding: 1em 1em;
}

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: 0px;
  font-size: 1.333em;
}

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;
  }
}