
:root {
  --yellow: #f5c430;
  --app-bg: linear-gradient(119deg, rgb(0 0 0) 0%, rgb(15 0 0) 0%, rgb(37 35 35) 100%);
  --medium: 1em;
  --error-red: rgb(228 86 86);
  --divider-color: rgb(69 61 61);
  --body-color: rgb(251,251,253);
}

html {
	overscroll-behavior: auto;
  font-family: "Playwrite DE Grund";
}

body
{
  max-width: 100vw;
  max-height: 100vh;
  overflow: hidden;
  min-width: 100vw;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: var(--app-bg);
  font-size: var(--medium);
  letter-spacing: .001em;
  line-height: .9169054441;
  color: var(--body-color);
  overscroll-behavior-y: auto !important;
  font-family: "Playwrite DE Grund";
}

.swal_bottom_button {
  position: relative;
  bottom: -50px;
}
.standard_button {
  background-color: rgb(193 191 219);
  border-radius: 5px;
  border: none;
  padding-top: 5px;
  padding-bottom: 5px;
  width: 100%;
  transition: background-color 300ms;
  box-shadow: -2px 29px 12px -19px black;
}
.standard_button:hover {
  transition: background-color 300ms;
  background-color: rgb(173 181 209);
}
.standard_button a {
  color: black !important;
  text-shadow: none !important;
}
.login--header {
  display: flex;
  flex-direction: column;
}
.login--title {
  text-align: center;
  padding-top: 35px;
  padding-bottom: 50px;
  font-family: "Playwrite DE Grund";
}
.login--title .major {
  font-weight: 600;
  letter-spacing: 2px;
}
.login--title .minor {
  font-size: 13px;
  padding-top: 36px;
}
.login--body {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 50%;
}
.login--body form {
  display: flex;
  flex-direction: column;
  width: 75%;
}
header {
  height: 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.login--body form span {
  text-align: center;
  padding-top: 25px;
  padding-bottom: 25px;
  font-family: 'Playwrite DE Grund';
  font-size: 0.8em;
  color: #d5e8a8;
  letter-spacing: 1px;
  cursor: pointer;
}
.login--body form  input {
  padding: 10px;
  margin-bottom: 12px;
  border: none;
  border-radius: 8px; /* Border radius input */
  transition: outline-color 0.3s ease-in-out;
  outline: 2px solid white;
  color: white;
  background-color: transparent;
  width: 100%;
}

.login--body form input:focus {
  border-color: #ff9900; /* Warna input saat focus */
}

.login--body form button {
  background-color: #ff9900;
  color: black;
  padding: 15px;
  border: none;
  border-radius: 17px; /* Border radius button */
  cursor: pointer;
  transition: background-color 0.3s ease-in-out;
  font-family: 'Playwrite DE Grund';
  font-weight: 600;
}

.login--body form button:hover {
  background-color: #ff6600; /* Warna button saat hover */
}
.logo--header
{
  padding-left: 15px;
  font-family: "Playwrite DE Grund";
  font-size: 1.2em;
}
.close--header
{
  padding-right: 15px;
}
.close--header span {
  font-size: 2em;
}
.logo--header img {
  object-fit: contain;
  max-width: 75px;
}
a, a:hover {
  color: #8f84d1;
  text-decoration: none;
}
break {
  border-bottom: 2px solid var(--divider-color);
  width: 83%;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  margin-bottom: 25px;
  margin-top: 25px;
  border-top: 2px solid var(--divider-color);
  padding-top: 30px;
  padding-bottom: 30px;
}
break p {
  margin: 0;
  color: var(--error-red);
  font-weight: 600;
}
main {
  height: calc(100vh - 120px);
  overflow-y: auto;
}
main .header
{
  border-top: 2px solid var(--divider-color);
  padding-top: 50px;
  font-size: 1.3em;
  line-height: 1.5em;
  padding-left: 10%;
  padding-right: 10%;
}
main .header ul {
  padding-top: 15px;
}
main .header li {
  padding-bottom: 20px;
}
main .header span,
main .body span {
  font-size: 29px;
  color: rgb(154 154 154);
  width: 85%;
  margin: 0 auto;
  margin-bottom: 37px;
  margin-top: 10px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
main .header span svg {
  position: absolute;
  z-index: 999;
}
main .header span::before,
main .body span::before {
  content: '';
  border-bottom: 2px solid var(--divider-color);
  width: 43%;
  position: absolute;
  right: 0;
}
main .header span::after,
main .body span::after {
  content: '';
  border-bottom: 2px solid var(--divider-color);
  width: 43%;
  position: absolute;
  left: 0;
}
main .body
{

}
main .footer
{

}
.main--landing
{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  min-width: 100vw;
  background: linear-gradient(119deg, rgb(0 0 0) 0%, rgb(15 0 0) 0%, rgba(0, 0, 0, 1) 100%);
  background: var(--app-bg);
}
.logo--holder {
  display: flex;
  justify-content: center;
  align-items: center;
}
.logo--holder img {
  object-fit: contain;
  max-width: 65%;
  max-height: 100%;
  padding-top: 30px;
}
.logo--
{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.logo--text
{
  font-family: "Bebas Neue" !important;
  font-size: 4em;
  color: white;
}
.logo--definition
{
  font-family: "Playwrite DE Grund";
  position: relative;
  top: 0px;
  color: #006254;
  text-align: center;
}
.landing footer
{
  font-family: "Playwrite DE Grund";
  position: fixed;
  color: white;
  bottom: 0;
  text-align: center;
  width: 100%;
  background: transparent;
  z-index: 9;
}

.landing footer a {
  top: 0px;
  color: #8f84d1;
}

.logged--out--footer {
  position: relative;
  bottom: 30px;
}
.user--footer {
  height: 70px;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  border-top: 2px solid rgb(69 61 61);
  border-bottom: 2px solid rgb(69 61 61);
}
.user--footer nav {
  font-weight: 600;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 6px;
  position: relative;
  transition: all 500ms;
}
.nav--button
{
  color: rgb(181 181 181);
}
.nav--button p
{
  font-size: 11px;
  top: 11px;
  position: relative;
  color: grey;
  transition: all 500ms;
}
.nav--button img {
  object-fit: contain;
  max-width: 75px;
  filter: grayscale(100%);
  transition: all 500ms;
}
.user--nav--selected {
  color: #8f84d1;
  filter: grayscale(0%);
  transition: all 500ms;
}
footer span
{
  color: #8f84d1;
  font-weight: 600;
  cursor: pointer;
}
.material-symbols-outlined
{
  color: white;
}
.swal--holder {
  position: relative;
  font-size: 2.2em;
  font-family: 'Bebas Neue';
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.swal--text {
  padding: 15px;
  height: 90vh;
  overflow: hidden;
}
.swal--text--header {
  color: yellow;
  text-shadow: 1px 1px 1px black;
  padding-top: 80px;
  padding-bottom: 80px;
  background: rgb(0 0 0 / 48%);
}
.swal--text--body {
  background: rgb(0 0 0 / 17%);
  color: white;
  height: 100%;
  padding-top: 100px;
  font-size: 0.8em;
  padding-left: 50px;
  padding-right: 50px;
}
.swal--text--body a {
  color: #ffe900;
  text-shadow: 1px 1px 2px black;
}
div:where(.swal2-container) button:where(.swal2-close) {
  color: white !important;
  font-size: 3em !important;
}
.unpw_error {
  height: 40px;
  font-size: 0.8em;
  color: var(--error-red);
  padding-top: 5px;
  display: flex;
  justify-content: center;
  text-align: center;
}

.shake {
  animation: shake 0.82s cubic-bezier(.36,.07,.19,.97) both;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  perspective: 1000px;
}

.settings--item {
  font-family: Ubuntu !important;
  font-weight: 100;
  line-height: 1.1em;
  margin-bottom: 32px;
  cursor: pointer;
}
.settings--item-top {
  font-size: 17px;
}
.settings--item-bottom {
  font-size: 15px;
  color: grey;
}


:root {
  --yellow: #f5c430;
  --app-bg: linear-gradient(-174deg, rgb(0 0 0) 0%, rgb(15 0 0) 0%, rgb(37 35 35) 100%);
  --medium: 1em;
  --error-red: rgb(228 86 86);
  --divider-color: rgb(69 61 61);
  --angle: 45deg;
  --card-calm: linear-gradient(var(--angle), #FF5722, #CDDC39);
  --active-access: #8df09f;
  --active: #d6de46;
  --nice-white: #e8e2e2;
  --decembien-blue: #4f7f9f;

}

/* general overrides */
pre {
  color: #d6e0e9;
  text-wrap: auto;
}
button:focus {
  outline: 2px solid rgb(60 44 137 / 68%);
}



/* Page */
section.page {
  padding: 25px;
}

.test {
  font-family: "Bebas Neue";
  font-family: Oswald;
  font-family: "Playwrite DE Grund";
  font-family: Ubuntu;
  font-family: "Fredoka One";
  font-family: "Anek Odia";
  font-family: "Comforter Brush";
  font-family: "Open Sans";
}

html {
  overscroll-behavior: auto;
  font-family: "Playwrite DE Grund";
}

body
{
  /*max-width: 100vw;
  max-height: 100vh;
  overflow: hidden;
  min-width: 100vw;
  min-height: 100vh;*/
  height: 100%;
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: var(--app-bg);
  font-size: var(--medium);
  letter-spacing: .001em;
  line-height: .9169054441;
  color: var(--body-color);
  overscroll-behavior-y: auto !important;
  font-family: "Playwrite DE Grund";
}

html, body {
  height: 100%;
  margin: 0;
  padding: 0;
}

.app-container {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

/* 3. Fixed header and footer */
header {
  height: 50px;
}

.menu-container {
  position: relative;
  display: inline-block;  
}
.menu-photo {
  height: 52px;
  width: 52px;
  background: #341d1d;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
}
.menu-photo img {
  height: 37px;
  width: 37px;
  object-fit: contain;
  border-radius: 50%;
}
.header-dropdown-menu {
  display: none;
  position: absolute;
  right: 0;
  top: 100%;
  background-color: #fff;
  border: 1px solid #ddd;
  box-shadow: 0px 4px 8px rgba(0,0,0,0.1);
  min-width: 160px;
  z-index: 1000;
  border-radius: 4px;
  padding: 5px 0;
}

.dropdown-item {
  padding: 10px 15px;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #333;
}

.dropdown-item i {
  margin-right: 8px;
}

.dropdown-item:hover {
  background-color: #f0f0f0;
}

.dropdown-divider {
  height: 1px;
  background-color: #ccc;
  margin: 5px 0;
}

footer {
  height: 90px;
  display: block;
}

.content--container {
  display: flex;
  flex: 1;
  overflow: hidden; /* Prevent scroll bleeding to body */
}

.side--content {
  width: 260px;
  background: #191818;
  flex-shrink: 0;
  border-radius: 14px;
  margin-top: 12px;
  margin-bottom: 12px;
  margin-left: 7px;
  transition: width 200ms ease;
}
.fa-apple {
  position: relative;
  left: 2px;
}
.fa-youtube {
  position: relative;
  left: -1px;
}
.thin-sidebar {
  width: 56px;
  overflow: hidden;
}
.thin-sidebar .nav-text {
  opacity: 0;
  width: 0;
  margin-left: 0;
  overflow: hidden;
  white-space: nowrap;
}

#content {
  overflow-y: auto;
  border-radius: 14px;
  background: #191818;
  margin-left: 12px;
  margin-bottom: 12px;
  margin-top: 12px;
  flex: 1;
}

/* #content scrollbar */
#content::-webkit-scrollbar {
  width: 12px;
}

#content::-webkit-scrollbar-track {
  background: rgb(15, 0, 0); /* darker base */
  border-radius: 8px;
}

#content::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgb(60, 60, 60), rgb(37, 35, 35));
  border-radius: 8px;
  border: 2px solid rgb(15, 0, 0); /* subtle border for depth */
}

#content::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgb(80, 80, 80), rgb(50, 50, 50));
}


/* main cards */
section.cards {
  display: flex;
  flex-wrap: wrap;
}

.main-card {
  height: 500px;
  display: flex;
  width: 400px;
  flex-direction: column;
  margin: 15px;
  background: var(--card-calm);
  border-radius: 14px;
  transition: all 300ms ease;
}
.main-card:hover {
  padding: 5px;
}
.main-card-top {
  display: flex;
}
.main-card-bottom {
  display: flex;
  flex: 1 1 75%;
  justify-content: flex-end;
  align-items: flex-end;
  padding: 20px 20px 20px 45px;
}
.main-card img {
  max-width: 100%;
  max-height: 100%;
  border-radius: 14px;
  object-fit: contain;
}
.main-card-image {
  flex: 0 0 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  filter: grayscale(60%);
  padding: 15px;
}
.main-card-header {
  flex: 0 0 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Comforter Brush";
  font-size: 2.5em;
  letter-spacing: 5px;
  text-shadow: 1px 1px 3px black;
}
.main-card-text {
  font-size: 0.85em;
  text-align: right;  
}


footer
{
  font-family: "Playwrite DE Grund";
  color: white;
  bottom: 0;
  text-align: center;
  width: 100%;
  background: rgb(27 20 20);
  z-index: 9;
}
footer.logged-out {
  filter: opacity(30%);
  pointer-events: none;;
}
footer a {
  transition: all 500ms;
  font-size: 1em;
  top: 11px;
  position: relative;
  color: grey;
  transition: all 500ms;
}
footer a:hover {
  color: grey;
  text-decoration: none;
}

.swal_bottom_button {
  position: relative;
  bottom: -50px;
}
.standard_button {
  background-color: rgb(193 191 219);
  border-radius: 5px;
  border: none;
  padding-top: 5px;
  padding-bottom: 5px;
  width: 100%;
  transition: background-color 300ms;
  box-shadow: -2px 29px 12px -19px black;
}
.standard_button:hover {
  transition: background-color 300ms;
  background-color: rgb(173 181 209);
}
.standard_button a {
  color: black !important;
  text-shadow: none !important;
}
.login--header {
  display: flex;
  flex-direction: column;
}
.login--title {
  text-align: center;
  padding-top: 35px;
  padding-bottom: 50px;
  font-family: "Playwrite DE Grund";
}
.login--title img {
  object-fit: contain;
  max-width: 100px;
  transition: all 500ms;
}
.login--title .major {
  font-weight: 600;
  letter-spacing: 2px;
  margin-bottom: 25px;;
}
.login--title .minor {
  font-size: 13px;
  padding-top: 36px;
}
.login--body {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 50%;
}
.login--body form {
  display: flex;
  flex-direction: column;
  width: 75%;
}
header {
  height: 70px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-left: 10px;
  padding-right: 10px;
  background-color: rgb(12, 12, 12);
}
.header--left {
  position: relative;
  top: 3px;
  padding-left: 10px;
}
.header--right {  
  display: flex;
  justify-content: center;
  align-items: center;
  padding-right: 15px;
  position: relative;  
}
header img {
  object-fit: contain;
  max-width: 100px;
  transition: all 500ms;
}
header i {
  font-size: 1.4em;
  cursor: pointer;
}
.login--body form span {
  text-align: center;
  padding-top: 25px;
  padding-bottom: 25px;
  font-family: 'Playwrite DE Grund';
  font-size: 0.8em;
  color: #d5e8a8;
  letter-spacing: 1px;
  cursor: pointer;
}
.login--body form  input {
  padding: 10px;
  margin-bottom: 12px;
  border: none;
  border-radius: 8px; /* Border radius input */
  transition: outline-color 0.3s ease-in-out;
  outline: 2px solid white;
  color: white;
  background-color: transparent;
  width: 100%;
}

.login--body form input:focus {
  border-color: #ff9900; /* Warna input saat focus */
}

.login--body form button {
  background-color: #ff9900;
  color: black;
  padding: 15px;
  border: none;
  border-radius: 17px; /* Border radius button */
  cursor: pointer;
  transition: background-color 0.3s ease-in-out;
  font-family: 'Playwrite DE Grund';
  font-weight: 600;
}

.login--body form button:hover {
  background-color: #ff6600; /* Warna button saat hover */
}

.google-btn {
  display: inline-block;
  padding: 10px 16px;
  background-color: #fff;
  color: #444;
  border: 1px solid #ccc;
  border-radius: 4px;
  text-decoration: none;
  font-weight: bold;
  transition: background-color 0.3s;
}
.google-btn span {
  color: #000000 !important;
  font-family: Ubuntu !important;
}

.google-btn:hover {
  background-color: #f3eaea !important;
}

.logo--header
{
  padding-left: 15px;
  font-family: "Playwrite DE Grund";
  font-size: 1.2em;
}
.close--header
{
  padding-right: 15px;
}
.close--header span {
  font-size: 2em;
}
.logo--header img {
  object-fit: contain;
  max-width: 75px;
}
a, a:hover {
  color: #8f84d1;
  text-decoration: none;
}
break {
  border-bottom: 2px solid var(--divider-color);
  width: 83%;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  margin-bottom: 25px;
  margin-top: 25px;
  border-top: 2px solid var(--divider-color);
  padding-top: 30px;
  padding-bottom: 30px;
}
break p {
  margin: 0;
  color: var(--error-red);
  font-weight: 600;
}
main {
  --foo: 0;
}
main .header
{
  border-top: 2px solid var(--divider-color);
  padding-top: 50px;
  font-size: 1.3em;
  line-height: 1.5em;
  padding-left: 10%;
  padding-right: 10%;
}
main .header ul {
  padding-top: 15px;
}
main .header li {
  padding-bottom: 20px;
}
main .header span,
main .body span {
  font-size: 29px;
  color: rgb(154 154 154);
  width: 85%;
  margin: 0 auto;
  margin-bottom: 37px;
  margin-top: 10px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
main .header span svg {
  position: absolute;
  z-index: 999;
}
main .header span::before,
main .body span::before {
  content: '';
  border-bottom: 2px solid var(--divider-color);
  width: 43%;
  position: absolute;
  right: 0;
}
main .header span::after,
main .body span::after {
  content: '';
  border-bottom: 2px solid var(--divider-color);
  width: 43%;
  position: absolute;
  left: 0;
}
main .body {
  --foo: 0;
}
main .footer{
  --foo: 0;
}
.main--landing
{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  min-width: 100vw;
  background: linear-gradient(119deg, rgb(0 0 0) 0%, rgb(15 0 0) 0%, rgba(0, 0, 0, 1) 100%);
  background: var(--app-bg);
}
.logo--holder {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 9vh;
}
.logo--holder img {
  object-fit: contain;
  max-width: 35%;
  max-height: 100%;
  padding-top: 30px;
}
.logo--
{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.logo--text
{
  font-family: "Bebas Neue" !important;
  font-size: 4em;
  color: white;
}
.logo--definition
{
  font-family: "Playwrite DE Grund";
  position: relative;
  top: 0px;
  color: #006254;
  text-align: center;
  line-height: 26px;
}
.logged--out--footer {
  position: relative;
  bottom: 30px;
}
.user--footer {
  height: 90px;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  /*border-top: 2px solid rgb(69 61 61);*/
  border-bottom: 2px solid rgb(69 61 61);
}
.user--footer nav {
  font-weight: 600;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  transition: all 500ms;
  height: 100%;
  top: -11px;
}
.nav--button
{
  color: rgb(181 181 181);
}
.nav--button i {
  font-size: 1.3em;
}
.nav--button p
{
  font-size: 11px;
  top: 11px;
  position: relative;
  color: grey;
  transition: all 500ms;
}
.nav--button img {
  object-fit: contain;
  max-width: 35px;
  transition: all 500ms;
}
.nav-home {
  filter: grayscale(100%);
}
.user--nav--selected {
  color: #8f84d1;
  filter: grayscale(0%);
  transition: all 500ms;
}
footer span
{
  color: #8f84d1;
  font-weight: 600;
  cursor: pointer;
}
.material-symbols-outlined
{
  color: white;
}
section.home {  
  padding-top: 50px;
  font-size: 1.3em;
  line-height: 1.5em;
  padding-left: 10%;
  padding-right: 10%;
}
section.home .decembien-intro {
  max-width: 50vw;
  margin: 0 auto;
}
section.home h2 {
  font-family: "Bebas Neue";
  font-size: 3rem;
  text-align: center;
  margin-bottom: 50px;
  margin: 50px;
}
.sad-red {
  color: #c06969

}
.happy-blue {
  color: #9494dd;
  display: inline;
}
section.home span, section.home .body span {
  font-size: 29px;
  color: rgb(154 154 154);
  width: 85%;
  margin: 0 auto;
  margin-bottom: 37px;
  margin-top: 10px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
section.home span::before, section.home .body span::before {
  content: '';
  border-bottom: 2px solid var(--divider-color);
  width: 43%;
  position: absolute;
  right: 0;
}
section.home span::after, section.home .body span::after {
  content: '';
  border-bottom: 2px solid var(--divider-color);
  width: 43%;
  position: absolute;
  left: 0;
}
section.libraries {
  padding: 25px;
}

















.swal--holder {
  position: relative;
  font-size: 2.2em;
  font-family: 'Bebas Neue';
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.swal--text {
  padding: 15px;
  height: 90vh;
  overflow: hidden;
}
.swal--text--header {
  color: yellow;
  text-shadow: 1px 1px 1px black;
  padding-top: 80px;
  padding-bottom: 80px;
  background: rgb(0 0 0 / 48%);
}
.swal--text--body {
  background: rgb(0 0 0 / 17%);
  color: white;
  height: 100%;
  padding-top: 100px;
  font-size: 0.8em;
  padding-left: 50px;
  padding-right: 50px;
}
.swal--text--body a {
  color: #ffe900;
  text-shadow: 1px 1px 2px black;
}
div:where(.swal2-container) button:where(.swal2-close) {
  color: white !important;
  font-size: 3em !important;
}
.unpw_error {
  height: 40px;
  font-size: 0.8em;
  color: var(--error-red);
  padding-top: 5px;
  display: flex;
  justify-content: center;
  text-align: center;
}

.shake {
  animation: shake 0.82s cubic-bezier(.36,.07,.19,.97) both;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  perspective: 1000px;
}

.settings--item {
  font-family: Ubuntu !important;
  font-weight: 100;
  line-height: 1.1em;
  margin-bottom: 32px;
  cursor: pointer;
}
.settings--item-top {
  font-size: 17px;
}
.settings--item-bottom {
  font-size: 15px;
  color: grey;
}

/*
//
//
// ANIMATIONS
//
//
///////////////// */
@-webkit-keyframes slidein {
from {background-position: top; background-size:490px; }
to {background-position: -100px 0px;background-size:2750px;}
}

@keyframes slidein {
from {background-position: top;background-size:640px; }
to {background-position: -35px 150px;background-size:950px;}

}


@keyframes shake {
  10%, 90% {
    transform: translate3d(-1px, 0, 0);
  }

  20%, 80% {
    transform: translate3d(2px, 0, 0);
  }

  30%, 50%, 70% {
    transform: translate3d(-4px, 0, 0);
  }

  40%, 60% {
    transform: translate3d(4px, 0, 0);
  }
}



/* sidebar nav */
nav {
  --foo: 0;
}

.nav--top {
  padding-top: 20px;
  margin-left: 6px;
}
.nav-items a {
    color: white;
}
.nav-item {
  height: 40px;
  display: flex;
  align-items: center;
  margin-bottom: 9px;
  cursor: pointer;
}
.nav-icon {
  font-size: 1.4em;
  color: #b39e9e;
  width: 30px;
  padding-left: 10px;
}
.nav-icon i.rotate {
  transform: rotate(270deg);
  transition: transform 0.4s ease;
}
.nav-item-selected {
  border-left: 3px solid var(--active) !important;
  font-weight: 700;
}
.nav-text {
  padding-left: 25px;
  font-size: 1em;
  letter-spacing: 0.5px;
  color: #ccc1c1;
  transition: opacity 100ms ease;
}
.active-access a {
  color: var(--active-access) !important;
  font-weight: 700;
}
.active-access-icon i  {
  color: var(--active-access) !important;
}
.active-page {
  color: var(--active) !important;
  font-weight: 700;
}
.active-page-icon {
  color: var(--active) !important;
}

.nav-items {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.nav-items.open {
  max-height: 500px;
}

.nav--mid {
  margin-top: 15px;
  margin-left: 6px;
}

.nav--bot {
  margin-left: 6px;
}


/* Spotify Buttons */
section.spotify {
  padding: 40px;
}
section.spotify-playlist-two {
  padding: 0px;
}
.spotify-header {
  display: flex;
  background: black;
  padding: 20px;
  border-radius: 17px;
  align-items: center;
  justify-content: space-between;
  font-size: 0.9em;
  margin-bottom: 50px;
}
.spotify-synced {
 color: inherit;
}
.spotify-no-profile-picture {
  padding: 11px;
  background: #443f3f;
  border-radius: 50%;
  margin-left: 6px;
  height: 35px;
  width: 33px;
  font-weight: 700;
}
.spotify-account-container {
  height: 70px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Open Sans";
}
.spotify-account-container img {
  max-width: 100%;
  object-fit: contain;
  max-height: 100%;
  border-radius: 50%;
  border: 8px solid rgb(28 209 92);
  margin-left: 12px;
  margin-right: 15px;
}
.spotify-header-dots {
  font-size: 1em;
  cursor: pointer;
  padding:15px
}
.spotify-playlist-header {
  display: flex;
  background: linear-gradient(180deg, rgb(88 151 255) 0%, rgb(28 109 156) 0%, rgb(107 105 105) 100%);
  padding: 20px;
  border-top-left-radius: 17px;
  border-top-right-radius: 17px;
  align-items: center;
  justify-content: space-between;
  font-size: 0.9em;  
}
.spotify-playlist-header .spotify-playlist-top .playlist-image {
  height: 350px;
  width: 350px;
  min-height: 300px;
  min-width: 300px;
  transition: all 300ms;
  position: relative;
}
.spotify-playlist-header .playlist-info h3 {
  font-family: "Rock Salt";
  font-size: 2.25em;
  font-weight: 700;
  margin: 0;
}
.spotify-playlist-header .playlist-info {
    font-family: 'Ubuntu';
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
    padding-left: 15px;
    font-size: 2em;
    flex: 1;
}
.spotify-playlist-header .spotify-playlist-top:hover {
  background: inherit;
  border-radius: inherit;;
}
#songsContainer {  
  min-height: 1000px;
  background: linear-gradient(198deg, rgb(107 105 105) 0%, rgb(28 109 156) 100%, rgb(88 151 255) 100%);
  padding: 35px;  
}

table#spotify-songs-table {
  width: 100%;
}
#spotify-songs-table .trackRow {
  transition: background-color 200ms ease;
}
.list-number {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-right: 7px;
  height: 71px;
  position: relative;
  top: 5px;
  padding-left: 7px;
}
#spotify-songs-table .trackRow:hover {
  background-color: rgb(49 55 82 / 16%);
  transition: background-color 200ms ease;
}
#spotify-songs-table th {
  padding-bottom: 25px;
  font-size: 0.8em;
}
#spotify-songs-table td {    
    font-family: "Anek Odia";
    font-size: 1.1em;
}
#spotify-songs-table .song {
  min-width: 150px;
}
#spotify-songs-table .album {
  max-width: 350px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 3px;
}
#spotify-songs-table .date {
  max-width: 150px;
  white-space: nowrap;
}
.song-info {
  display: flex;
}
.song-info-text {
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  padding-left: 9px;
}
.song-info-text-text {
  font-size: 1.2em;
  font-weight: 600;
  font-family: Ubuntu;
}
.song-info-text a {
  color: #ccc0c0;
  font-size: 0.8em;
  font-family: "Playwrite DE Grund";
}

section.spotify h4 {
  font-size: 1em;
}
section.spotify button,
section.local button {
  padding: 10px 25px;
  font-size: 16px;
  background-color: #564d80;
  color: #fff;
  border: 2px solid #2b254b;
  border-radius: 11px;
  vertical-align: middle;
  text-align: center;
  white-space: nowrap;
  line-height: normal;
  transition: background-color 300ms ease;
}

section.spotify button .icon,
section.local button .icon {
  color: #ffffff;
  font-size: 1.3em;
  display: inline-flex;
  align-items: center;
  position: relative;
  top: 1px;
}

section.spotify button .text,
section.local button .text {
  color: #ffffff;
  margin-left: 10px;
  font-weight: 600;
  font-size: 0.9em;
  letter-spacing: 1px;
}

section.spotify button:hover,
section.local button:hover {
  background-color: #37305a;
}


/* Spotify Playlists */
.playlist-info {
  font-family: 'Ubuntu';
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  padding-left: 15px;
}
.playlist-info h3 {
  font-family: "Playwrite DE Grund";
  font-size: 1.25em;
  font-weight: 700;
  margin: 0;
}
.playlist-info-header-bottom {
  font-family: "Anek Odia";
  display: flex;
  flex-direction: column;
  font-size: 0.7em;
  color: #e4d8d8;
}
.playlist-info-header-bottom a {
  margin-bottom: 15px;
}
.playlist-info-header-bottom p {
  margin: 0;
  padding: 0;
}
#playlistsContainer {
  display: flex;
  flex-wrap: wrap;
}
.spotify-playlist {
  display: flex;
  margin: 25px;
  padding: 25px;
  background: transparent;
  transition: background 200ms ease;
  cursor: pointer;
  width: 500px;
}
.spotify-playlist-top {
  display: flex;
  margin: 25px;
  padding: 25px;
  background: transparent;
  transition: background 200ms ease;
  cursor: default;
  width: 100%;
}
.spotify-playlist:hover {
  background: #2a2626;
  border-radius: 23px;
}
.spotify-playlist .playlist-image {
  height: 150px;
  width: 150px;
  transition: all 300ms;
  position: relative;
}
.playlist-image img {
  max-width: 100%;
  max-height: 100%;
  border-radius: 14px;
  object-fit: contain;
}
.playlist-image:hover {
  filter: brightness(0.5);
}
.playlist-mouseover {  
  font-family: "Font Awesome 5 Free";
  font-weight: 900; 
  color: #ff5454;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 3.5em;
  filter: contrast(1.5) brightness(1.5);
  text-shadow: 0px 0px 2px black;
  mix-blend-mode: normal;
}



/* Local */
.local_top {
  padding: 25px;
}
.local_table {
  margin-bottom: 25px;
  background: var(--nice-white);
  height: 250px;
  overflow: auto;
}
.local_table .empty_table_td {
  height: 150px;
  background: var(--nice-white);
}
.local_table table {
    width: 100%;
    border-collapse: collapse;    
}

.local_table th, 
.local_table td {
    border: 1px solid var(--nice-white);
    padding: 12px;
    text-align: left;
    background: var(--nice-white);
    color: black;
}

.local_table th {
    background-color: #fffafa;
    font-weight: bold;
    color: black;
}
.local_table td {
  font-family: 'Open Sans';
}

.local_table tr:nth-child(even) {
    background-color: var(--nice-white);
}

.local_table tr:hover {
    /* background-color: #e9f5ff; */
    cursor: pointer;
}

.status_icon {
  height: 20px;
  width: 20px;
  background: #6d6d6d;
  border-radius: 50%;
  box-shadow: 0px 2px 6px -3px black;
}
.status_icon.active {    
  background: #34be34;    
}
.status_icon.inactive {    
  background: #be346b;    
}
#localPathsTable tr {
  background: transparent;
  transition: background 400ms;
}
#localPathsTable tr:hover {
  background: #d3cbcb;
  transition: background 400ms;
}
#localPathsTable td {
  background: transparent;
}

/* SWAL */
.swal2-html-container,
.swal2-popup {
  background: var(--nice-white);
}

.filechooser_container {

}
.filechooser_header {
  display: flex;
  justify-content: space-between;
  border-bottom: 2px solid black;
  padding-bottom: 18px;
  font-family: 'Anek Odia';
  font-weight: 700;
}
.filechooser_notice {
  background: var(--yellow);
  padding: 15px;
  margin-top: 15px;
  border-radius: 8px;
  font-weight: 400;
  font-size: 0.9rem;
  text-align: left;
  border: 2px solid #b7ae1f;
  margin-bottom: 12px;
  color: #362b2b;
}
.filechooser_body {
    max-height: 300px;
    overflow: auto;
    height: 300px;
    border-bottom: 2px solid #c7b0b0;
}
.filechooser_path {
  display: flex;
  width: 100%;  
}
input#filechooser_path::placeholder {
  color: #948080;
}
input#filechooser_path {
  width: 100%;
  margin-bottom: 25px;
  border-radius: 6px;
  border: none;
  outline: 1px solid #8a7b7b;
  font-family: Ubuntu;
  padding: 9px 6px 8px 13px;
  font-size: 1rem;
}
#filechooser_table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Anek Odia';
  font-size: 1rem;
}
#filechooser_table tr {
  background: transparent;
  transition: background 400ms;
  border-bottom: 1px solid;
  cursor: pointer;
}
#filechooser_table tr:hover {
  background: #d3cbcb;
  transition: background 400ms;
}
#filechooser_table th,
#filechooser_table td {
  text-align: left;
  padding: 3px;
}
#filechooser_table colgroup col:nth-child(1) {
  width: 70px;
}
#filechooser_table colgroup col:nth-child(2) {
  width: auto;
}
.filechooser_td {
  display: flex;
  align-items: center;
  font-family: 'Ubuntu';
  padding: 4px;
}
.valid-ext {
  color: #127a4c;
}
.swal2-actions {
  width: 100%;
  justify-content: flex-start;
  flex-direction: row-reverse;
  padding-right: 20px;
  font-family: 'Open Sans';
}
.swal2-confirm {
  background: var(--decembien-blue);
}






/* desktop */
@media screen and (min-width: 768px) {

  .landing footer {
    display: block;
  }
  footer {
    display: none;
  }


}

/*
//
//
// ANIMATIONS
//
//
///////////////// */
@-webkit-keyframes slidein {
from {background-position: top; background-size:490px; }
to {background-position: -100px 0px;background-size:2750px;}
}

@keyframes slidein {
from {background-position: top;background-size:640px; }
to {background-position: -35px 150px;background-size:950px;}

}


@keyframes shake {
  10%, 90% {
    transform: translate3d(-1px, 0, 0);
  }

  20%, 80% {
    transform: translate3d(2px, 0, 0);
  }

  30%, 50%, 70% {
    transform: translate3d(-4px, 0, 0);
  }

  40%, 60% {
    transform: translate3d(4px, 0, 0);
  }
}
