* {
  box-sizing: border-box;
  transition: var(--hover-transition);
  max-width: var(--safe-width);
}

:root {
  --navbar-height: 44px;
  --searchbar-height: 44px;
  --tabbar-height: 44px;
  --toolbar-height: 44px;
  --display-corner-radius: 40px;
  --bar-backdrop-filter: blur(8px);
  --spacing: 10px;
  --spacing-25: calc(var(--spacing) * 0.25);
  --spacing-50: calc(var(--spacing) * 0.5);
  --spacing-150: calc(var(--spacing) * 1.5);
  --spacing-200: calc(var(--spacing) * 2);
  --scrollbar-width: calc(var(--spacing) * 0.5);
  --button-size: 44px;
  --input-size: 32px;
  --font-size: 16px;
  --icon-font-size: calc(var(--font-size) * 1.5);
  --hover-transition: 0.05s ease-out;
  --panel-bg: #eee;
  --panel-border: 1px solid #0002;
  --background: #fff;
  --background-inset: #eee;
  --input-bg: #eee;
  --background-translucent: #fffb;
  --text-color: #333;
  --transparent: #8880;
  --input-text-color: #222;
  --gray: #e5e5e6;
  --button-color: rgb(162 162 162);
  --accent-color: #00c9f3;
  --accent-text-color: #eee;
  --subtle-accent-bg: #00c9f37d;
  --button-shadow: inset 0 0 0 0 var(--transparent);
  --button-hover-shadow: inset 0 0 0 1px var(--transparent);
  --button-active-shadow: inset 0 0 0 4px var(--accent-color);
  --button-corner-radius: 8px;
  --input-corner-radius: 4px;
  --content-padding: calc(var(--spacing) * 2);
  --safe-width: calc(100vw - env(safe-area-inset-right) - env(safe-area-inset-left));
  --safe-height: calc(100vh - env(safe-area-inset-top) - env(safe-area-inset-bottom));
}

@media (prefers-color-scheme: dark) {
  :root {
    --panel-bg: #333f;
    --panel-border: 1px solid #fff2;
    --background: #000;
    --background-inset: #111;
    --background-translucent: #000b;
    --input-bg: #333;
    --text-color: #eee;
    --input-text-color: #e8e8e8;
    --gray: #747474;
    --button-color: rgb(131 131 131);
  }
}

html {
  overflow: hidden;
  background: var(--background);
}

body {
  overflow: hidden;
  min-height: 100vh;
  font-family:
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    Helvetica,
    Arial,
    sans-serif,
    "Apple Color Emoji",
    "Segoe UI Emoji",
    "Segoe UI Symbol";
  font-size: var(--font-size);
  background: var(--background);
  font-weight: 400;
  display: flex;
  flex-direction: column;
  color: var(--text-color);
  height: var(--safe-height);
  width: var(--safe-width);

  /*
  padding:
    env(safe-area-inset-top)
    env(safe-area-inset-right)
    env(safe-area-inset-bottom)
    env(safe-area-inset-left);
*/
}

.content,
header,
footer {
  left: env(safe-area-inset-left);
  right: env(safe-area-inset-right);
  position: fixed;
}

.content {
  overflow-x: hidden;
  overflow-y: scroll;
  overflow-y: overlay;
  width: 100%;
  flex: 1 1 100px;
  position: fixed;
  top: calc(var(--navbar-height) + env(safe-area-inset-top));
  bottom: calc(var(--navbar-height) + env(safe-area-inset-bottom));
  padding: 0;
}

.content.logged-out {
  top: env(safe-area-inset-top);
  bottom: env(safe-area-inset-bottom);
}

.content > * {
  padding: calc(var(--content-padding) * 0.25) var(--content-padding);
}

.row {
  display: flex;
  flex-direction: row;
  align-items: center;
  background: var(--background);
}

.panel.panel {
  padding: 0;
  background: var(--panel-bg);
  border: var(--panel-border);
  border-width: 1px 0;
  display: flex;
  flex-direction: column;
}

.panel > * {
  flex-shrink: 0;
}

.panel h3 {
  padding: 0 var(--content-padding);
  font-weight: normal;
  text-transform: uppercase;
  font-size: 80%;
  opacity: 0.75;
  line-height: 34px;
  margin: 10px 0 0;
}

.elastic {
  flex: 1 1 auto;
}

.spacer {
  flex: 0 0 var(--spacing);
}

header,
footer {
  /* backdrop-filter: var(--bar-backdrop-filter); */
  background: var(--background);
  display: flex;
  padding: 0 4px;
}

header,
footer,
header *,
footer * {
  font-size: var(--font-size);
}

.content > blockquote {
  margin: 0;
  padding: calc(var(--content-padding) * 0.5) calc(2 * var(--content-padding));
}

header h1 {
  font-weight: 600;
}

header {
  top: 0;
  height: calc(var(--navbar-height) + env(safe-area-inset-top));

  /* background: linear-gradient(180deg, var(--background) 0%, var(--background-translucent) 100%); */
}

footer {
  bottom: 0;
  height: calc(var(--navbar-height) + env(safe-area-inset-bottom));

  /* background: linear-gradient(0deg, var(--background) 0%, var(--background-translucent) 100%); */
}

header button,
footer button {
  background: transparent;
  border: none;
  min-width: var(--button-size);
  height: var(--button-size);
  color: var(--button-color);
}

header button,
footer button.current {
  color: var(--accent-color);
}

footer button {
  flex: 1 1 var(--button-size);
}

hr {
  border: none;
  flex: 1 1 1px;
}

label {
  display: flex;
  flex-direction: column;
}

label.row {
  padding: 0 var(--content-padding);
  height: 44px;
}

label.row + label.row {
  border-top: var(--panel-border);
}

.switch {
  border-radius: 14px;
  height: 28px;
  width: 48px;
  margin: 8px 0;
  position: relative;
  overflow: hidden;
  display: inline-block;
}

.switch > input + span {
  width: 48px;
  height: 28px;
  display: block;
  position: relative;
  transition: 0.1s ease-out;
  background: var(--panel-bg);
}

.switch > input:checked + span {
  background: var(--accent-color);
}

:not(.switch) > input[type="checkbox"] + span,
:not(.switch) > input[type="radio"] + span {
  content: " ";
  display: inline-block;
  width: 24px;
  height: 24px;
  margin: 10px 10px 10px 0;
  background: var(--background);
  box-shadow: inset 0 0 0 2px var(--subtle-accent-bg);
}

:not(.switch) > input[type="checkbox"] + span {
  transition: 0.1s ease-out;
  border-radius: 3px;
  padding: 4px;
}

:not(.switch) > input[type="checkbox"]:checked + span {
  box-shadow: inset 0 0 0 2px var(--accent-color);
}

input[type="checkbox"] + span::before {
  transition: 0.1s ease-out;
  color: var(--accent-color);
  opacity: 0;
}

input[type="checkbox"]:checked + span::before {
  opacity: 1;
}

:not(.switch) > input[type="radio"] + span {
  border-radius: 12px;
}

:not(.switch) > input[type="radio"]:checked + span {
  box-shadow: inset 0 0 0 7px var(--accent-color);
}

.switch > input + span::after {
  content: " ";
  position: absolute;
  display: block;
  width: 28px;
  height: 28px;
  border-radius: 14px;
  left: 0;
  top: 0;
  transition: 0.1s ease-out;
  background: var(--panel-bg);
  box-shadow: inset 0 0 0 2px var(--subtle-accent-bg);
}

.switch > input:checked + span::after {
  left: 20px;
}

.switch > input,
input[type="checkbox"],
input[type="radio"] {
  position: absolute;
  top: -1000px;
  left: -1000px;
}

.row > span {
  text-align: left;
}

label > span {
  text-align: center;
}

nav {
  display: flex;
  height: var(--button-size);
  margin: calc(var(--button-size) * 0.25) 0;
}

.stack {
  display: flex;
  height: auto;
  flex-direction: column;
}

nav:not(.stack) > * + * {
  margin-left: calc(var(--button-size) * 0.25);
}

nav.stack > * + * {
  margin-top: calc(var(--button-size) * 0.25);
}

button {
  color: var(--text-color);
  background: var(--background);
  height: var(--button-size);
  line-height: var(--button-size);
  border: none;
  border-radius: var(--button-corner-radius);
  padding: 0 calc(var(--button-size) * 0.4);
  transform: scale(1);
  transition: 0.1s ease-out;
  display: inline-flex;
  justify-content: center;
  box-shadow: var(--button-shadow);
}

button:not(.current):enabled:hover {
  box-shadow: var(--button-hover-shadow);
}

button:not(.current):enabled:active {
  color: var(--accent-color);
  box-shadow: var(--button-active-shadow);
}

.medium {
  --button-size: 32px;
  --font-size: 14px;
  --icon-font-size: calc(var(--font-size) * 1.5);
}

.small {
  --button-size: 24px;
  --input-size: 24px;
  --font-size: 12px;
  --icon-font-size: calc(var(--font-size) * 1.5);
}

.gray {
  background: var(--gray);
}

.tinted {
  background: var(--accent-color);
  color: var(--accent-text-color);
}

.filled {
  color: var(--text-color);
  background: var(--accent-color);
}

.transparent {
  background: none;
}

.round {
  text-align: center;
  width: var(--button-size);
  border: none;
  padding: 0;
  border-radius: var(--button-size);
  flex: 0 0 auto;
}

:disabled {
  opacity: 0.25;
}

select,
input {
  color: var(--input-text-color);
  background: var(--input-bg);
  height: var(--input-size);
  line-height: var(--input-size);
  margin: calc(var(--button-size) * 0.5 - var(--input-size) * 0.5) 0;
  padding: 0 calc(var(--input-size) * 0.4);
  border: 0;
  box-shadow: 0 0 0 1px #0004, inset 0 1px 1px #0004;
  border-radius: var(--input-corner-radius);
}

input[type="search"] {
  border-radius: calc(var(--input-size) * 0.5);
  flex: 1 1 auto;
}

:focus {
  outline: none;
}

.page-controls {
  justify-content: center;
}

.page-controls input {
  appearance: none;
  border: none;
  box-shadow: none;
  background: var(--accent-color);
  margin: 0 calc(var(--button-size) * 0.1);
  width: calc(var(--button-size) * 0.2);
  height: calc(var(--button-size) * 0.2);
  border-radius: 99px;
  opacity: 0.25;
}

.page-controls input:not(:checked):enabled:hover {
  opacity: 0.5;
}

.page-controls input:checked {
  opacity: 1;
}

.page-controls input:disabled {
  background: transparent;
  box-shadow: inset 0 0 0 1px var(--accent-color);
}

input::-webkit-calendar-picker-indicator {
  transform: translate(14px, -8px);
}

::-webkit-scrollbar {
  height: var(--scrollbar-width);
  width: var(--scrollbar-width);
}

::-webkit-scrollbar-track {
  background: none;
}

::-webkit-scrollbar-thumb {
  background: var(--accent-color);
  border-radius: calc(var(--scrollbar-width) * 0.5);
}
