    html {
      height: 100%;
      overflow: hidden !important;
    }
    body {
      height: 100%;
      overflow: hidden !important;
    }

    .arrow {
      position: absolute;
      border: solid var(--gray-color-1);
      box-shadow: 3px 3px 3px var(--gray-color-5);
      border-width: 0 15px 15px 0;
      display: inline-block;
      padding: 15px;
      opacity: 0.3;
      transition: opacity 2s ease-in-out, transform 2s ease-in-out;
      top: calc(50% - 7.5px);
    }

    .arrow.right {
      right: 15px;
      --angle: -45deg;
    }

    .arrow.left {
      left: 15px;
      --angle: 135deg;
    }

    .arrow{
      transform: rotate(var(--angle)) translateX(0px) translateY(0px);
    }

    .arrow.hidden {
        opacity: 0;
      transform: rotate(var(--angle)) translateX(15px) translateY(15px);
    }


    #card {
        --dimensioning: clamp(300px, 70vw, 600px);
        height: 100%;
        text-align: center;
        display: block;
        position: relative;
    }

    .taskCard {
        position: relative;
        font-family: Tahoma, serif;
        margin: 1rem auto;
        border: solid 0.5rem white;
        border-radius: 8px;
        box-shadow: 6px 6px 4px hsla(0,0%,0%,0.5);
        width: 90%;
        height: calc(80% - 45px);
        top: 2%;
    }

    @media (orientation: landscape) {
      .taskCard {
            height: 90vmin;
            width: calc(1.9 * vmin);
        height: calc(var(--dimensioning) / 1.92);
        width: var(--dimensioning);
      }
    }

    .innerCard {
        height: 100%;
        display: block;
      }

    .innerCard > .topic {
        font-size: calc(var(--dimensioning)/12);
        font-weight: 800;
        border-radius: 8px 8px 0 0;
        padding: 12px;
        text-align: center;
        vertical-align: middle;
    }

    .innerCard > .category {
        padding: 4px 8px 6px 8px;
        font-size: max(2vmax, 12px);
        text-align: center;
        padding: 10px 30px;
        color: var(--contrast-color-0a);
        background: var(--base-color-9);
    }
    .innerCard > .action {
        padding: 1rem;
        font-size: calc(var(--dimensioning)/15);
        text-align: center;
        font-weight: 400;
        bottom: 0;
    }
    .innerCard > .footer {
        font-size: calc(var(--dimensioning)/25);
        position: absolute;
        text-align: center;
        bottom: 10px;
        flex: 1 1 1rem;
    }

    .taskCard > .legal {
        position: relative;
        font-size: 0.7rem;
        bottom: 1rem;
        opacity: 0.25;
    }

    .taskCard > .id {
        position: absolute;
        text-align: right;
        font-size: 0.7rem;
        color: black;
        opacity: 0.25;
        bottom: 0.3rem;
        right: 0.5rem;
        filter: drop-shadow(0px 0px 2px white);
    }


    #menu {
        width: 100%;
        height: 10vh;
        position: absolute;
        bottom: 2vh;
        left: -15px;
        display: flex;
        align-items:center;
        justify-content:center;
        flex-wrap: wrap;
        gap: 1rem;
    }

    #menu > div {
        width: 90%;
        display: flex;
        align-items:center;
        justify-content: space-between;
    }

    #menu .btn {
      --btn-size: max(48px, 5vw, 5vh);
      margin: auto;
      box-shadow: 1px 2px 3px hsla(0, 0%, 0%, 0.5);
      transition: background 1s ease-in-out;
      line-height: calc(var(--btn-size) * 0.67);
      width: var(--btn-size);
      height: var(--btn-size);
      text-align: center;
      vertical-align: center;
      padding: 0;
      font-size: calc(var(--btn-size) / 2);
      border: solid 3px rgba(0,0,0,0);
      border-radius: 50%;
    }

    .btn > * {
      user-select: none;
    }

    .a-rotate {
      margin: 0;
      padding: 0;
      filter: drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.5));
    }

    .btn:has(*.hidden) {
        display: none !important;
    }

    .btn:focus, .btn:hover {
      outline: none;
      border: solid 3px white !important;
      background: var(--contrast-color-5);
      transition: border 1s ease-in-out, background 1s ease-in;
    }

    #menu .btn:hover .a-rotate, menu .btn:focus .a-rotate {
      transition: transform 0.2s ease-in-out, background 0.2s ease-out;
    }

    #menu .btn.activated {
      transition: all 1s ease-in;
      background: var(--contrast-color-8);
    }

    #menu .btn.activated .a-rotate {
      transition: transform 0.8s ease-in-out, background 0.1s ease-in;
      transform: rotate(-1080deg);
    }

    @media (orientation: landscape) {

        .innerCard > .topic {
            padding: calc(var(--dimensioning)/60);
            font-size: calc(var(--dimensioning)/20);
        }
        .innerCard > .category {
            font-size: 0.75rem;
            padding: 0.25rem;
        }

        .innerCard > .action {
            padding: min(0.5rem, 5%);
            font-size: min(calc(var(--dimensioning)/13.5), 10vh);
        }

        #menu {
            padding: 4px;
            bottom: 5%;
        }

        #menu > div {
            width: clamp(300px, 50%, 50vw);
        }

    }


    @media (height < 450px) {

        top-navigation {display: none !important}

        .taskCard {
            position: absolute;
            top: max(0px, calc(50% - var(--dimensioning)/2.5));
            margin: 5px auto;
            border: 3px solid white;
            max-height: 90vmin;
          }

        .innerCard > .topic {
            padding: calc(var(--dimensioning)/80);
            font-size: calc(var(--dimensioning)/25);
        }

        .innerCard > .action {
            padding: calc(var(--dimensioning)/80);
            font-size: min(calc(var(--dimensioning)/15), 14vmin);
        }

        #menu {
            --menu-size: min(50px, 25vw, 25vh);
            position: absolute;
            bottom: 5%;
            left: calc(100% - 20px - min(2 * var(--menu-size), 80px));
            width: var(--menu-size);
            height: -webkit-fill-available;
            justify-content: center;
            display: flex;
            vertical-align: middle;
            align-items: center;
        }
        #menu > div {
            width: 100%;
            height: 100%;
            display: flex;
            flex-wrap: wrap;
            gap: 0 100%;
            vertical-align: middle;
            align-items: center;
        }
        #menu .btn {
              --btn-size: min(36px, 25vw, 25vh);
              margin: auto;
              box-shadow: 1px 2px 3px hsla(0, 0%, 0%, 0.5);
              transition: background 1s ease-in-out;
              line-height: calc(var(--btn-size) * 0.67);
              width: var(--btn-size);
              height: var(--btn-size);
        }
    }


.options-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.fullscreen-options {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  z-index: 9999;
}

.show-options {
  display: block;
  margin-bottom: 20px;
}

.close-options {
  position: absolute;
  top: 20px;
  right: 20px;
  border-radius: 50%;
  margin: 0;
  padding: 1px;
  line-height: 2.2rem;
}

.options-container > ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.options-container > li {
  margin-bottom: 10px;
}

.options-container > a {
  display: block;
  padding: 10px;
  color: #000;
  text-decoration: none;
}