@import "variables.css";

html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

html,
body {
  overflow: hidden;
  height: 100dvh;
  width: 100dvw;
  margin: 0;

  display: flex;
  flex-direction: column;
}

body {
  background-color: var(--desktop-bg);
  font-family: "Microsoft Sans Serif";
  font-size: 16px;
}

button {
  display: inline-flex;
  align-items: center;
  font-family: "Microsoft Sans Serif Bold";
  font-size: 16px;
  text-align: center;
}

/* Keep visited links colour the same */
a:visited {
  color: var(--link-colour);
}

.white-text {
  color: white;
}

.icon span {
  color: white;
}

p img.emoticon {
  display: inline;
  vertical-align: text-bottom;
  height: 1em;
  width: auto;
}

.border-style-default {
  border-top: 2px solid black;
  border-left: 2px solid black;
  border-bottom: 2px solid white;
  border-right: 2px solid white;
}

.border-style-simple-button {
  border-top: 2px solid white;
  border-left: 2px solid white;
  border-bottom: 2px solid black;
  border-right: 2px solid black;
}

/* Desktop */

.desktop {
  display: flex;
  flex-direction: row;
  flex: 1;
  padding: 10px;
  gap: 10px;
}

.icon {
  cursor: grab;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 100px;
  text-align: center;
  gap: 5px;
}

.icon:active {
  cursor: grabbing;
}

.icon img {
  width: 32px;
  height: 32px;
}

/* Footer */

.footer {
  display: flex;
  flex-direction: row;

  font-family: "Microsoft Sans Serif Bold";
  background-color: var(--grey-bg);
  border-top: 2px solid white;
  justify-content: space-between;
  padding: 5px;

  z-index: 100;
  max-width: 100%;
}

.footer button {
  display: flex;
  gap: 7px;
  background-color: #c3c3c3;
  padding: 0;
  margin: 0;
  appearance: none;
  justify-content: center;
  padding: 0 10px;

  border-top: 2px solid white;
  border-left: 2px solid white;
  border-bottom: 2px solid var(--dark-grey-border);
  border-right: 2px solid var(--dark-grey-border);

  box-shadow: 2px 2px 0 0px black;
}

.footer button:active {
  background: repeating-conic-gradient(white 0% 25%, transparent 0% 50%) 50% /
    5px 5px; /* Fancy way to make a checkerboard pattern*/
  border-top: 2px solid black;
  border-left: 2px solid black;
  border-bottom: 2px solid white;
  border-right: 2px solid white;
  box-shadow: none;
}

.time {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: "Microsoft Sans Serif";
  align-items: center;
  gap: 10px;
  padding: 3px 10px;
}

.time img {
  width: 20px;
  height: 20px;
}

/**
  Windows 95 style scrollbar
  Changed from this: https://gist.github.com/Dakedres/0ccda599648833a1c2f65d3967aa131b
 */

body *::-webkit-scrollbar {
  width: 20px;
  height: 20px;
  background: none;
}

body *::-webkit-scrollbar-thumb,
body *::-webkit-scrollbar-button {
  width: 20px;
  height: 20px;
  background: silver;
  box-shadow: inset 2px 2px #dfdfdf, inset -2px -2px gray;
  border: 2px solid;
  border-color: silver #000 #000 silver;
}

body *::-webkit-scrollbar-track {
  image-rendering: optimizeSpeed;
  image-rendering: pixelated;
  image-rendering: optimize-contrast;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTAuNSAyIDIiIHNoYXBlLXJlbmRlcmluZz0iY3Jpc3BFZGdlcyI+CjxtZXRhZGF0YT5NYWRlIHdpdGggUGl4ZWxzIHRvIFN2ZyBodHRwczovL2NvZGVwZW4uaW8vc2hzaGF3L3Blbi9YYnh2Tmo8L21ldGFkYXRhPgo8cGF0aCBzdHJva2U9IiNjMGMwYzAiIGQ9Ik0wIDBoMU0xIDFoMSIgLz4KPC9zdmc+");
  background-position: 0 0;
  background-repeat: repeat;
  background-size: 2px;
}

body *::-webkit-scrollbar-button {
  background-repeat: no-repeat;
  background-size: 20px;
}

body *::-webkit-scrollbar-button:single-button:vertical:decrement {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTAuNSAxNiAxNiIgc2hhcGUtcmVuZGVyaW5nPSJjcmlzcEVkZ2VzIj4KPG1ldGFkYXRhPk1hZGUgd2l0aCBQaXhlbHMgdG8gU3ZnIGh0dHBzOi8vY29kZXBlbi5pby9zaHNoYXcvcGVuL1hieHZOajwvbWV0YWRhdGE+CjxwYXRoIHN0cm9rZT0iIzAwMDAwMCIgZD0iTTcgNWgxTTYgNmgzTTUgN2g1TTQgOGg3IiAvPgo8L3N2Zz4=");
}

body *::-webkit-scrollbar-button:single-button:vertical:increment {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTAuNSAxNiAxNiIgc2hhcGUtcmVuZGVyaW5nPSJjcmlzcEVkZ2VzIj4KPG1ldGFkYXRhPk1hZGUgd2l0aCBQaXhlbHMgdG8gU3ZnIGh0dHBzOi8vY29kZXBlbi5pby9zaHNoYXcvcGVuL1hieHZOajwvbWV0YWRhdGE+CjxwYXRoIHN0cm9rZT0iIzAwMDAwMCIgZD0iTTQgNWg3TTUgNmg1TTYgN2gzTTcgOGgxIiAvPgo8L3N2Zz4=");
}

body *::-webkit-scrollbar-button:single-button:horizontal:decrement {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTAuNSAxNiAxNiIgc2hhcGUtcmVuZGVyaW5nPSJjcmlzcEVkZ2VzIj4KPG1ldGFkYXRhPk1hZGUgd2l0aCBQaXhlbHMgdG8gU3ZnIGh0dHBzOi8vY29kZXBlbi5pby9zaHNoYXcvcGVuL1hieHZOajwvbWV0YWRhdGE+CjxwYXRoIHN0cm9rZT0iIzAwMDAwMCIgZD0iTTggM2gxTTcgNGgyTTYgNWgzTTUgNmg0TTYgN2gzTTcgOGgyTTggOWgxIiAvPgo8L3N2Zz4=");
}

body *::-webkit-scrollbar-button:single-button:horizontal:increment {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTAuNSAxNiAxNiIgc2hhcGUtcmVuZGVyaW5nPSJjcmlzcEVkZ2VzIj4KPG1ldGFkYXRhPk1hZGUgd2l0aCBQaXhlbHMgdG8gU3ZnIGh0dHBzOi8vY29kZXBlbi5pby9zaHNoYXcvcGVuL1hieHZOajwvbWV0YWRhdGE+CjxwYXRoIHN0cm9rZT0iIzAwMDAwMCIgZD0iTTYgM2gxTTYgNGgyTTYgNWgzTTYgNmg0TTYgN2gzTTYgOGgyTTYgOWgxIiAvPgo8L3N2Zz4=");
}

body *::-webkit-scrollbar-corner {
  background: silver;
}

/* Booting up animation */

#boot-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: linear-gradient(to bottom right, #1a001a, #0d000d); /* Dark purple gradient */
  color: #c9c9ff; /* Light, slightly purplish text color */
  font-family: 'Courier New', 'Lucida Console', monospace;
  padding: 20px;
  z-index: 9999;
  opacity: 1;
  font-size: 0.75rem;
  overflow-y: auto;
}

#boot-log {
  white-space: pre-wrap; /* Respects spaces and line breaks */
  word-break: break-all;
}

#boot-log > div {
  margin-bottom: 5px; /* Space between lines */
}

/* Blinking cursor effect */
#boot-cursor {
  display: inline-block;
  vertical-align: middle;
  animation: blink 1s step-end infinite;
}

@keyframes blink {
  from, to {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}

/* Hide the boot screen after the animation */
#boot-screen.hidden {
  opacity: 0;
  pointer-events: none;
}
