:root {
  --publisher-color-safe: red;
}
* {
  -webkit-tap-highlight-color: transparent;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
body {
  background: #141612;
  padding: 0;
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Noto,
    Arial, Ubuntu, sans-serif, "Apple Color Emoji", "Segoe UI Emoji",
    "Segoe UI Symbol"-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Noto,
    Arial, Ubuntu, sans-serif, "Apple Color Emoji", "Segoe UI Emoji",
    "Segoe UI Symbol";
  color: #fff;
}
body {
  /* backdrop-filter: blur(1rem); */
  /* background-repeat: no-repeat; */
  /* background-size: cover; */
  /* background-blend-mode: darken; */
}
.thumbnail-wrapper {
  width: 100%;
  text-align: center;
  position: relative;
  margin: auto;
  z-index: 5;
  margin-top: 4rem;
}

img.thumbnail_image {
  width: 100%;
  height: 100%;
  border-radius: 10px;
  position: relative;
  z-index: 5;
}

.article-title {
  font-family: "Rubik", sans-serif;
  font-weight: bolder;
  font-size: 27pt;
  padding: 14px 0px;
}
img.thumbnail-backdrop {
  position: absolute;
  height: 36rem;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  filter: blur(6rem);
  opacity: 0.45;
  width: 100%;
  background-position-x: center;
  opacity: 0;
  transition: opacity 0.5s ease-in-out, filter 0.5s ease-in-out;
}

.article-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0px 0px;
  position: relative;
  z-index: -1;
  flex-wrap: wrap;
  margin: 6px 0;
}

.meta-item {
  display: flex;
  gap: 6px;
  align-items: center;
  opacity: 0.8;
  font-family: "Rubik", sans-serif;
  height: 26px;
}

.meta-divider {
  height: 4px;
  width: 4px;
  background: #fff;
  border-radius: 50%;
}

article.article-container {
  padding: 8px 0px;
  line-height: 26px;
  font-size: 13pt;
  font-family: "Nunito", sans-serif;
}
header.art-header {
  display: flex;
  width: 100%;
  justify-content: space-between;
  position: fixed;
  top: 0px;
  height: 3rem;
  align-items: center;
  left: 0;
  /* background: #0000001a; */
  z-index: 6;
  backdrop-filter: blur(10px);
  padding: 0px 9px;
  box-sizing: border-box;
  background-blend-mode: color-burn;
  max-width: 45rem;
  left: 50%;
  transform: translateX(-50%);
}

button.btn-ic {
  background: transparent;
  border: none;
  height: 30px;
  cursor: pointer;
  width: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  transition: 0.15s;
}

.h-central-title {
  font-family: "Rubik", sans-serif;
  font-weight: bolder;
  background: #00000054;
  padding: 3px 10px;
  border-radius: 23px;
}

button.btn-ic:active,
button.btn-ic:hover {
  background: #ffffff1a;
}

img.ic-btn {
  height: 22px;
}

img.meta-ic {
  height: 21px;
}
.hljs {
  background: transparent !important;
  text-align: left;
}

.code-container {
  background: #ffffff17;
  border-radius: 12px;
  overflow: hidden;
  /* text-align: right; */
}

.code-label {
  padding: 7px 19px;
  border-bottom: 1px dashed #ffffff6b;
  font-family: "Rubik", sans-serif;
}
.social-media-share-sheet {
  position: fixed;
  background: #00000073;
  bottom: -30rem;
  width: 100%;
  text-align: center;
  padding: 3rem 0px;
  border-radius: 45px 45px 0px 0px;
  z-index: 10;
  left: 0;
  backdrop-filter: blur(10px);
  /* height: 0; */
  display: none;
  transition: 0.15s all ease;
}

.sheet-show {
  display: block;
}
/* .sheet-remove */
.sheet-open {
  bottom: 0;
}

.overlay {
  position: fixed;
  background: transparent;
  height: 100vh;
  width: 100vw;
  top: 0;
  left: 0;
  z-index: 9;
  display: none;
}

div#shareButtons a {
  text-decoration: none;
}

div#shareButtons a img {
  height: 39px;
}

div#shareButtons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 7px;
}
.sheet-thumb {
  position: absolute;
  height: 4px;
  width: 4rem;
  background: #ffffff3b;
  border-radius: 14px;
  top: 7px;
  left: 50%;
  transform: translateX(-50%);
}
section.root {
  width: 90%;
  margin: auto;
  max-width: 45rem;
}
ul.dropdown-menu.dropdown-menu--refresh {
  background: black !important;
}
h2.social-share-title {
  font-family: "Rubik", sans-serif;
  margin-bottom: 2rem;
}
img.thumbnail_image {
  opacity: 0;
  transition: opacity 0.5s ease-in-out, filter 0.5s ease-in-out;
  filter: blur(20px);
}

.thumbnail-wrapper {
  width: 100%;
  height: calc(100vw / 1.75);
  background: #ffffff1c;
  border-radius: 10px;
}
.thumb-loader {
  width: 25px;
  height: 25px;
  border-radius: 50%;
  position: relative;
  animation: rotate 1s linear infinite;
  display: block;
}
.thumb-loader::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  inset: 0px;
  border-radius: 50%;

  animation: prixClipFix 2s linear infinite;
}

@keyframes rotate {
  100% {
    transform: rotate(360deg);
  }
}

@keyframes prixClipFix {
  0% {
    clip-path: polygon(50% 50%, 0 0, 0 0, 0 0, 0 0, 0 0);
  }
  25% {
    clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 0, 100% 0, 100% 0);
  }
  50% {
    clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 100%, 100% 100%, 100% 100%);
  }
  75% {
    clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 100%, 0 100%, 0 100%);
  }
  100% {
    clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 100%, 0 100%, 0 0);
  }
}
.thumb-loader-wrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#page-loader {
  position: fixed;
  top: 0px;
  left: 0;
  width: 100%;
  height: 4px;
  z-index: 100;
  /* background-color: #28b456; */
  animation: pageLoading 1s;
  /* box-shadow: 0px 0px 35px #00ff54; */
  border-radius: 11px;
  z-index: 10;
}
@keyframes pageLoading {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}
.loader-hidden {
  display: none;
}
.thumb-loaded {
  opacity: 1 !important;
  filter: blur(0) !important;
}
.back-drop-loaded {
  opacity: 0.45 !important;
}
article.article-container img {
  max-width: 90%;
  margin: auto;
  border-radius: 10px;
  border: 2px solid #ffffff3d;
  padding: 7px;
  display: block;
}
article blockquote {
  background: #ffffff1f;
  margin: 0;
  border-left: 4px solid #fff;
  padding: 2px 10px;
  border-radius: 0 7px 7px 0;
  padding-left: 14px;
}

.height-auto {
  height: auto !important;
}
::selection {
  background: #ffffff47;
  color: #fff;
}
code {
  background: #ffffff17 !important;
  padding: 2px 4px;
  border-radius: 3px;
  margin: 0px 2px;
}
article#article_block table, tr, th, td {
    border: 1px solid #ffffff4f;
}

article#article_block table {
    border-collapse: collapse;
}

article#article_block td, th {
    padding: 8px 10px;
}

article#article_block th {
    background: #ffffff14;
}

article#article_block hr {
    border: none;
    border-top: 1px solid #ffffff30;
}