/* global */
:root {
  --p-1: 0.2em;
  --p-2: 0.4em;
  --p-3: 0.6em;
  --p-4: 0.8em;
  --p-5: 1em;
  --p-6: 2em;

  --font: 10pt/1.6 calibri;

  --solid: 1px solid var(--faded);
  --dotted: 1px dotted var(--faded);
  --dashed: 1px dashed;

  --accent: #d8cfc4;
  --darkgreen: #81946f;
  --green: #b9ca82;
  --lightgreen: #f0f7d9;
  --light: #f5f1ea;
  --dark: #7a6963;
  --faded: #afa69d;
  --white: #fcfcfc;

  --column: column nowrap;
  --row: row nowrap;
}

::-webkit-scrollbar {
  width: 0;
}

@font-face {
  font-family: dotted;
  src: url(https://file.garden/ZdkezegxzVCR-6D7/neocities/fonts/Minecart%20LCD.ttf);
}

body {
  font: var(--font);
  text-transform: lowercase;
  color: var(--dark);
  background: var(--light) url("/assets/img/stripe.png") repeat center / auto;
  background-blend-mode: lighten;
}

/* layout */

#main-container {
  max-width: 480px;
  margin: 8% auto;
}

.wrapper {
  border-width: 7px;
  border-style: solid;
  border-image: url("/assets/img/lace.gif") 7 fill round;
}

footer {
  text-align: center;
  color: var(--faded);
}

/* images */
img {
  max-width: 100%;
  object-fit: cover;
  user-select: none;
}

.img {
  border: var(--solid) var(--faded);
  padding: var(--p-1);
}

#header-img {
  display: flex;
  align-items: end;
  justify-content: start;
  height: 8em;
  background: var(--faded) url("/assets/img/clovers.png") repeat center / cover;
  border-bottom: var(--solid);
  background-blend-mode: overlay;

  marquee {
    color: var(--darkgreen);
    text-shadow: 1px 0 var(--white), -1px 0 var(--white), 0 2px var(--white),
      0 -1px var(--white), 1px 1px var(--white), -1px -1px var(--white),
      1px -1px var(--white), -1px 1px var(--white);
    background: linear-gradient(transparent, var(--white));

    img {
      width: 14px;
      margin-top: -4px;
    }
  }
}

#bg {
  background: var(--faded) url("/assets/img/clovers.png") repeat center / cover;
}

.emote {
  width: 20px;
  display: inline;
}

/* text */
h1,
h2,
h3,
h4,
h5 {
  align-self: self-start;
}

h5 {
  background: linear-gradient(transparent 60%, var(--lightgreen) 60%);
  display: inline;
  font-size: inherit;
  font-weight: bold;
}

h4 {
  font-size: 13pt;
  font-variant: small-caps;
  color: var(--faded);

  &::before {
    content: "✱";
    padding-right: var(--p-1);
    color: var(--accent);
    font-size: 9pt;
  }
}

h3 {
  color: var(--white);
  font-size: 12pt;
  display: inline;
  padding: 0 var(--p-1);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-family: cursive;
  text-shadow: -1px -1px 0 var(--dark),
    /* Top-left shadow */ 1px -1px 0 var(--dark),
    /* Top-right shadow */ -1px 1px 0 var(--dark),
    /* Bottom-left shadow */ 1px 1px 0 var(--dark);
  /* Bottom-right shadow */
}

h2 {
  border-left: 4px solid var(--green);
  background: linear-gradient(to right, var(--lightgreen) 60%, transparent);
  color: var(--darkgreen);
  padding: var(--p-2);
  text-align: left;
}

h1 {
  font-size: 13pt;
  letter-spacing: 0.04em;
  font-variant: small-caps;
  font-weight: thin;
  color: var(--darkgreen);
}

p {
  overflow-wrap: break-word;
  text-align: justify;
}

.warning {
  border: var(--dashed) var(--green);
  background: var(--lightgreen);
  padding: var(--p-1) var(--p-2);
  border-radius: var(--p-2);
  text-align: left;
  color: var(--darkgreen);
}

.divider {
  width: 100%;
  margin-inline: auto;
  object-fit: contain;
  margin-block: var(--p-2);
}

/* headers */
#navbar {
  display: flex;
  justify-content: space-between;
  font-variant: small-caps;
  padding: var(--p-1) var(--p-2);
  position: sticky;
  top: 0;
  z-index: 20;
  background: var(--white);
  border-bottom: var(--solid);

  h1::before {
    content: "";
    background: url("/assets/img/clover.png") no-repeat center / contain;
    display: inline-block;
    aspect-ratio: 1/1;
    width: 16px;
    margin-right: var(--p-1);
    position: relative;
    top: 3px;
    rotate: 45deg;
  }

  span {
    color: var(--green);
  }

  nav {
    display: flex;
    align-items: center;
    gap: var(--p-1);
    color: var(--accent);

    a:not(:last-child)::after {
      content: "|";
      padding-left: var(--p-2);
      color: var(--faded);
    }

    a:hover {
      color: var(--green);
    }

    .btn {
      line-height: 1.2;
    }
  }
}

/* links */
.outlink:link,
.outlink:visited {
  color: var(--green);
  text-decoration: 1px underline dotted;
}

.outlink:hover,
.outlink:active {
  color: var(--white);
  background: var(--green);
  text-decoration: none;
}

a:link,
a:visited {
  color: var(--dark);
  text-decoration: none;
}

a:hover,
a:active {
  color: var(--green);
}

hr {
  border-style: dotted;
  margin-block: var(--p-2);
}

/* buttons */
.btn {
  font: var(--font);
  font-variant: small-caps;
  outline: var(--solid);
  border: var(--white);
  background: linear-gradient(var(--white) 30%, var(--light) 70%);
  border-radius: var(--p-1);
  text-shadow: 1px 1px 1px var(--white);
  padding: 0 var(--p-2);
}

.btn > a:link,
a:visited {
  color: var(--dark);
}

.btn:hover {
  background: var(--white);
  color: var(--faded);
}

/* list */

/* flexbox */
.flex-column {
  display: flex;
  flex-flow: var(--column);
}

.overflow {
  flex: 1 1 0;
  overflow-y: auto;
}

.card {
  border-radius: 0;
  border: var(--solid);
  color: inherit;
  padding: revert;
}

.card__body {
  display: flex;
  flex-flow: var(--column);
  padding: var(--p-2);
  background: inherit;
}

.card__img {
  flex: 1;
}

.card-block {
  display: flex;
  flex-flow: column wrap;
  flex: 1;
  border-radius: 0;
  color: inherit;
  padding: var(--p-2);
  gap: var(--p-2);
}

.row {
  --bs-gutter-x: var(--p-2);
}

.g-0 {
  --bs-gutter-x: 0;
}

marquee {
  padding: 0;
}
