/******************************************************************************

Theme Name: Tortured Tiles
Theme URI: http://petridamsten.com/
Author: Petri Damstén
Author URI: http://petridamsten.com/
Description: Theme for petridamsten.com
Version: 1.3
Tags: tiles
Text Domain: torturedtiles

Copyright (c) 2014-2023 by Petri Damstén <petri.damsten@gmail.com>

******************************************************************************/

@import url('https://petridamsten.com/fonts/fonts.css');

:root {
  --color-bg: 2%;
  --color-bg-l: 13%;
  --color-mid: 50%;
  --color-text: 73%; 
  --color-text-b: 93%;
  --color-text-d: 47%;
  --color-accent: 33 85% 50%;
  --invert: 0;

  --header-font: 'Playfair Display', serif;
  --h1-h5-font-size: 4rem;
  --h2-h6-font-size: 3rem;
  --h3-h7-font-size: 1.1rem;
  --h4-h8-font-size: 1.1rem;
  --header-font-spacing: -0.03em;
  --header-font-color: hsl(0 0% var(--color-text-b));
  --header-font-weight: 800;

  --text-font: 'Josefin Sans', sans-serif;
  --text-font-size: 1.1rem;
  --text-font-weight: 300;
  --text-font-spacing: 0.0em;
  --text-line-height: 1.5;
  --text-color: hsl(0 0% var(--color-text));
  --text-color-highlight: hsl(0 0% var(--color-text-b));
  --text-color-unselected: hsl(0 0% var(--color-text-d));
  --text-color-accent: hsl(var(--color-accent));
  
  --frontpage-font-size: 1rem;
  --frontpage-font-weight: 600;
  --frontpage-font-spacing: 0rem;
  --frontpage-tfont-size: 0.9rem;
  --frontpage-tfont-weight: 300;
  --frontpage-tfont-spacing: 0;

  --text-padding: 1rem;
  --photo-thumbnail-radius: 1rem;
  --admin-bar-height: 0;

  --middle-color: hsl(0 0% var(--color-mid));
  --background-color-a: hsl(0 0% var(--color-bg) / 0.3);
  --background-color: hsl(0 0% var(--color-bg));
  --background-color-light: hsl(0 0% var(--color-bg-l));

  --short-anim: 0.3s;
  --popup-anim: 0.5s;
  --medium-anim: 0.75s;
  --long-anim: 1.2s;

  --topbar-height: 4rem;
  --fade-add: 4rem;
  --topbar-margin: 1.25rem;
  --topbar-font-size: 1.2rem;
  --topbar-font-weight: 400;
  --topbar-logo-width: 16rem;
  --portfolio-pane-width: var(--topbar-height);
  --main-margin: 0.3rem;
  --hero-img-height: 50vh;

  background-color: var(--background-color);
}

@media (prefers-color-scheme: light) {
  :root {
    --color-bg: 98%;
    --color-bg-l: 87%;
    --color-mid: 60%;
    --color-text: 27%; 
    --color-text-b: 7%;
    --color-text-d: 53%;
    --color-accent: 33 85% 30%;
    --invert: 1;
  }
}

@keyframes popup {
  0% {
    scale: 0;
  }
  100% {
    scale: 1;
  }
}

@keyframes fade-from-left {
  0% {
    opacity: 0;
    translate: -70% 0;
  }
  100% {
    opacity: 1;
    translate: 0 0;
  }
}

@keyframes fade-from-top {
  0% {
    opacity: 0;
    translate: 0 -2.5rem;
  }
  100% {
    opacity: 1;
    translate: 0 0;
  }
}

@keyframes fade-from-bottom {
  0% {
    opacity: 0;
    translate: 0 2.5rem;
  }
  100% {
    opacity: 1;
    translate: 0 0;
  }
}

@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

*, *::before, *::after {
  box-sizing: border-box;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
  animation-timing-function: ease-out;
  font: inherit;
  margin: 0;
  padding: 0;
}

html {
  color-scheme: dark light;
}

body {
  min-height: 100vh;;
  font-family: var(--text-font);
  font-size: var(--text-font-size);
  color: var(--text-color);
  font-weight: var(--text-font-weight);
  letter-spacing: var(--text-font-spacing);
  line-height: var(--text-line-height);
  padding-bottom: 2.8125rem;
  position: relative;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-color: var(--background-color);
}

img, picture, svg, video { 
  display: block;
  max-width: 100%;
}

h1, h2, h3, h4, h5, h6, h7, h8 {
  color: var(--header-font-color);
  font-family: var(--header-font);
  letter-spacing: var(--header-font-spacing);
  font-weight: var(--header-font-weight);
  padding-bottom: 0.3125rem;
  text-wrap: balance;
}

h1, h2, h3, h4 {
  text-transform: lowercase;
}
h5, h6, h7, h8 {
  text-transform: none;
}
h1, h5 {
  font-size: var(--h1-h5-font-size);
}
h2, h6 {
  font-size: var(--h2-h6-font-size);
}
h3, h7 {
  font-size: var(--h3-h7-font-size);
}
h4, h8 {
  font-size: var(--h4-h8-font-size);
}

.paused {
  animation-play-state: paused;
}

p, .tags {
  margin-top: 0.7rem;
  margin-bottom: 1rem;
  margin-inline: auto;
}

.aligncenter {
  margin-left: auto;
  margin-right: auto;
  display: block;
}

a {
  color: var(--text-color-highlight);
}

a:hover, a:focus {
  color: var(--text-color-accent);
}

/* Jetpack tiled gallery */

.tiled-gallery__item img {
  border-radius: var(--photo-thumbnail-radius) !important;
  border: 0.375rem solid var(--background-color);
  position: relative;
  left: -0.375rem;
  width: calc(100% - 0.75rem) !important;
  height: calc(100% - 0.75rem) !important;
  aspect-ratio: 1/1;
}

.tiled-gallery__item {
  padding-left: 0.3125rem !important;
  padding-right: 0.3125rem !important;
}

.gallery-size-thumbnail {
  margin-right: -1.25rem;
}

.image-panel {
  display: grid;
  grid-gap: 2rem;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr;
  max-width: 100rem;
  margin: auto;
}

.image-panel img {
  grid-column-start: 1;
  grid-row-start: 1;
}

.multiple .site-content {
  width:100%;
  height:2000px;
}

.tiles-padding {
  margin-top: 2.25rem;
}

#content {
  --gutter: 0.2%;
  --columns: 4;
}
.gutter-sizer { 
  width: var(--gutter); 
}
.grid-sizer, .tile {
  width: calc((100% - ((var(--columns) - 1) * var(--gutter))) / var(--columns));
}
@media (max-width: 1800px) { 
  #content { --columns: 3; }
}
@media (max-width: 1300px) { 
  #content { --columns: 2; }
}
@media (max-width: 800px) {
  #content { --columns: 1; }
}

.header-image {
  grid-column: 1 / -1;
  animation-name: fade-in;
  animation-duration: var(--medium-anim);
  position: relative;
  height: 35vh;
  padding-bottom: 0.5rem;
}
.header-image > img {
  border-radius: 1rem;
  object-fit: cover;
  height: 100%;
  width: 100%;
  mask-image: url(/media/ink_mask.gif); 
  mask-mode: luminance;
  mask-size: cover;
  mask-position: center;
}
.header-image .overlay {
  --border: 0.25vh solid white;
  --delay: 1.5s;
  --duration: 2s;
  position: absolute;
  bottom: 10%;
  left: calc((100vw - (20vw + 250px)) / 2);
  width: calc(20vw + 250px);
  padding: 2vh;
}
.header-image .overlay img {
  width: 100%;
  animation-name: fade-in;
  animation-duration: var(--medium-anim);
  animation-delay: var(--delay);
  opacity: 0;
}
.header-image .overlay:before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  opacity: 0;
  border-top: var(--border);
  border-right: var(--border);
  animation-name: overlay-tr;
  animation-duration: var(--duration);
  animation-delay: var(--delay);
  animation-timing-function: linear;
}
.header-image .overlay:after {
  content: '';
  position: absolute;
  right: 0;
  bottom: 0;
  width: 0;
  height: 0;
  opacity: 0;
  border-bottom: var(--border);
  border-left: var(--border);
  animation-name: overlay-bl;
  animation-duration: var(--duration);
  animation-delay: var(--delay);
  animation-timing-function: linear;
}
/* 391 x 114 */
@keyframes overlay-tr {
  0%   {width: 0; height: 0; opacity: 0;}
  0.1% {width: 0; height: 0; opacity: 1;}
  35%  {width: 100%; height: 0; opacity: 1;}
  50%  {width: 100%; height: 100%; opacity: 1;}
  100% {width: 100%; height: 100%; opacity: 1;}
}
@keyframes overlay-bl {
  0%   {width: 0; height: 0; opacity: 0;}
  50%  {width: 0; height: 0; opacity: 0;}
  50.1%  {width: 0; height: 0; opacity: 1;}
  85%  {width: 100%; height: 0; opacity: 1;}
  100% {width: 100%; height: 100%; opacity: 1;}
}

.portfolio-pics img {
  opacity: 0;
  animation-name: fade-from-left;
  animation-duration: var(--medium-anim);
}

.fulllink { 
  position: absolute; 
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  cursor: pointer;
} 

#main-img-fg, #main-img-bg {
  width: 100%;
  height: 100%;
  position: absolute;
}

#main-img {
  width: 100%;
  opacity: 0;
  animation-duration: var(--medium-anim);
  position: relative;
}

#main-img-fg {
  margin: auto;
  left: 0;
  right: 0;
}

#main-img-bg {
  filter: blur(5px);
  overflow: hidden;
}

.post #main-img, .error #main-img {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  width: 100vw;
  height: var(--hero-img-height);
  text-align: center;
  margin-left: calc(-1 * var(--main-margin));
}

.post .site-content, .error .site-content {
  padding-top: var(--hero-img-height);
  position: relative;
}


.post #main-img-fg, .error #main-img-fg, .post #main-img-bg, .error #main-img-bg {
  background: #000 url("") no-repeat center 50%;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

.page #main-img {
  animation-name: fade-from-left;
}

.post #main-img {
  animation-name: fade-in;
}

.page article {
  max-width: 65ch;
  margin-inline: auto;
}

.entry-header {
  text-wrap: balance;
  text-align: center;
}

.single .entry-header, .page .entry-header {
  text-transform: uppercase;
}

.single .entry-header {
  padding-top: 2.1875rem;
  padding-bottom: 1.5625rem;
}

.page .entry-header {
  padding-top: 0.3125rem;
  padding-bottom: 1rem;
}

.main-content.multiple {
  padding-top: var(--topbar-height);
}

.multiple .entry-content {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  word-wrap: break-word;
  text-overflow: ellipsis;
  overflow: hidden;
  padding: 0;
  pointer-events: none;
}
article:hover > * .entry-header, article:hover > * .entry-blur {
  opacity: 1.0;
  transition-delay: 0s;
  transition-duration: var(--medium-anim);
}
.article-animation {
  animation-name: fade-from-bottom;
  animation-duration: var(--medium-anim);
}
.multiple article {
  opacity: 0;
  margin-bottom: 0.2%;
  display: block;
}

.multiple .entry-image-container {
  left: 0.0rem;
  top: 0.0rem;
  width: 100%;
  overflow: hidden;
  transition: all var(--short-anim) ease-in-out;
}

.multiple .entry-image {
  width: 100%;
  pointer-events: none;
}

.multiple .entry-header, .entry-blur {
  position: absolute;
  bottom: 0;
  padding: 0.5rem;
  width: 100%;
  opacity: 0;
  transition-property: opacity;
  transition-duration: var(--long-anim);
  transition-timing-function: ease-in-out;
  transition-delay: 0.5s;

  @media (hover: none) {
    opacity: 0.85;
  }
}

.multiple .entry-header {
  text-transform: lowercase;
  font-family: var(--header-font);
  font-size: var(--frontpage-font-size);
  font-weight: var(--frontpage-font-weight);
  letter-spacing: var(--frontpage-font-spacing);
}

.entry-blur {
  height: 4rem;
  background-color: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(10px);
  mask-image: linear-gradient(to top, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 50%, rgba(0,0,0,0) 100%);
}

/* Fonts */

/* TODO better name */
.biglink {
  font-size: 1.125rem;
}

.img-story, .wp-caption {
  padding-top: 0.625rem;
  max-width: 100%;
}

.img-story, .wp-caption-text, .wp-block-image, .wp-block-jetpack-image-compare {
  text-align: center;
}

figcaption {
  font-style: italic;
}
figcaption::before {
  content: '\201C';
  font-size: 1.4rem;
  font-family: 'Playfair Display', serif;
  margin-right: 0.3rem;
}
figcaption::after {
  content: '\201D';
  font-family: 'Playfair Display', serif;
  font-size: 1.4rem;
  margin-left: 0.3rem;
}

figure.size-full, .wp-block-jetpack-tiled-gallery, .vvideo {
  width: 120%;
  max-width: 100vw;
  margin-left: -10% !important;
}

.vvideo {
  height: auto;
  aspect-ratio: 16 / 10.5;
}

.hvideo {
  width: auto;
  max-width: 100vw;
  height: 550px;
  aspect-ratio: 8.35 / 16;
  margin: 0 auto;
  display: block;
}

.entry-content img {
  max-width: 100%;
  height: auto;
}

figcaption {
  font-size: 100% !important;
  margin-top: 0.625rem;
  margin-bottom: 1.25rem;
}

#respond textarea, #respond input[type="text"] {
  font-size: 0.875rem;
}
#respond h3 {
  text-transform: uppercase;
}

.comment-author {
  font-weight: 500;
}

.post h1, .post h2, .post .post-info, .multiple .entry-content {
  color: var(--text-color-highlight);
}

.small {
  font-size: 0.875rem;
}

.post-info {
  text-align: center;
}

.bookinfo {
  font-size: 0.6875rem;
}

.comments-link, .comment-meta {
  font-size: 0.6875rem;
}

.format-link p a:last-of-type {
  font-size: 1.5625rem;
  font-style: italic;
  line-height: 125%;
}

.format-quote p:first-of-type {
  font-size: 1.25rem;
  font-style: italic;
  line-height: 125%;
}
.format-quote p:last-of-type {
  font-size: 1rem;
  font-style: italic;
}
.format-quote strong {
  font-weight: 600;
  font-style: italic;
}

.category-lyrics p {
  font-size: 1.0rem;
  font-style: italic;
  text-align: center;
  line-height: 120%;
}
.category-lyrics h6 {
  font-size: 0.8125rem;
  text-align: center;
  font-weight: normal;
  font-style: italic;
}

/* Padding & Margins */

.tags {
  margin-top: 1.875rem;
  margin-bottom: 1.875rem;
}

.entry-content, .entry-summary, .entry-footer, .comments-title, .comments-list, .comment-respond
{
  padding-left: var(--text-padding);
  padding-right: var(--text-padding);
  padding-top: var(--text-padding);
}

.entry-content p {
  margin-bottom: 1.25rem;
}

.bookinfo
{
  padding-top: 1rem;
}

.comment-respond {
  padding-bottom: 0.625rem;
}

.comment-meta {
  padding-top: 0.3125rem;
}

.entry-footer {
  margin-top: 1rem;
  padding-top: 0.3125rem;
  padding-bottom: 0.3125rem;
}

ol {
  padding-left: 1.875rem;
}

ul {
  padding-left: 2.1875rem;
  margin-bottom: 1em;;
}

footer{
  font-size: 1.25rem;
  display: block;
  color: var(--text-color-highlight);
  padding-top: 1rem;
  padding-inline: 2rem;
}

footer > nav > :last-child {
  margin-left: auto;
}

.gallery {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  position: relative;
  width: 120%;
  max-width: 95vw;
  left: -10%;
  gap: 1rem;
}

.gallery-item {
  aspect-ratio: 1 / 1;
  grid-column: span 2;
}

.gallery-item:last-child:nth-child(3n + 1){
  grid-column-end: 5;
}

.gallery-item:nth-last-child(2):nth-child(3n + 1){
  grid-column: 2 / span 2;
}

.gallery-item img {
	padding: 0;
  margin: 0;
  border: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  -webkit-border-radius: var(--photo-thumbnail-radius);
  -moz-border-radius: var(--photo-thumbnail-radius);
  border-radius: var(--photo-thumbnail-radius);
  background-clip: content-box;
  padding: 0.3rem;
  margin-left: -0.3rem;
}

.comment-list {
  padding-left: 1rem;
  padding-right: 1rem;
}

.comment-list li {
  padding-top: 1rem;
}

iframe {
  padding-top: 1rem;
  padding-bottom: 1.25rem;
  position: relative;
}

/* Rest */
#infinite-footer {
  opacity: 0 !important;
}

.infinite-scroll .bottom-nav {
  display: none;
}

.full-div-link {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
  background-image: url('images/empty.gif?v=DFZIOY');
}

.entry-date {
  padding: 0.3rem;
  padding-left: 0;
  padding-right: 0;
  margin: 0;
  height: 2rem;
  font-size: 0.7rem;
}

.gsc-control-cse {
  background-color: var(--background-color) !important;
  border-color: var(--background-color) !important;
}

.post .entry-title, .post .post-info {
  position: relative;
  z-index: 120;
}

.error h1 {
  font-size: 12.5rem;
}

.post .entry-content {
  max-width: 65ch;
  margin: 0 auto;
}

.portfolio-div {
  --scrollbar: 0.4rem;
  position: fixed;
  display: flex;
  flex-direction: row;
  border-collapse: separate;
  border-spacing: 0;
  top: 3;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--background-color);
  z-index: 10000;
}
.portfolio-pics {
  flex: 1;
  overflow-y: scroll;
  overflow-x: visible;
  scrollbar-color: var(--background-color) var(--background-color);
  scrollbar-width: thin;
  padding-top: var(--main-margin);
}
.portfolio-pics:hover {
  scrollbar-color: var(--background-color-light) var(--background-color);
}
.portfolio-pics::-webkit-scrollbar {
  width: var(--scrollbar);
}
.portfolio-pics::-webkit-scrollbar-track {
  background: var(--background-color);
}
.portfolio-pics::-webkit-scrollbar-thumb {
  background: var(--background-color);
}
.portfolio-pics:hover::-webkit-scrollbar-thumb {
  background: var(--background-color-light); 
}
.portfolio-left-pane, .portfolio-right-pane {
  writing-mode: vertical-rl;
  text-orientation: upright;
  color: var(--text-color-highlight);
  font-family: var(--header-font);
  font-size: 2.5rem;
  padding-top: var(--topbar-height);
  text-transform: uppercase;
  letter-spacing: 1.25rem;
  animation-name: fade-from-top;
  animation-duration: var(--long-anim);
  width: var(--portfolio-pane-width);
}
.portfolio-right-pane {
  width: calc(var(--portfolio-pane-width) - var(--scrollbar));
}
.portfolio-separator {
  height: 80vh;
  margin: 0.625rem;
  margin-right: calc(0.625rem + var(--scrollbar));
  margin-top: 10vh;
  border: 0.03125rem solid;
  border-top: 0;
  border-bottom: 0;
  border-image: linear-gradient(to bottom, hsla(0 0% var(--color-text-b) / 0) 0%,
                hsla(0 0% var(--color-text-b) / 0.5) 50%, hsla(0 0% var(--color-text-b) / 0) 100%);
  border-image-slice: 1;
}

main {
  padding-top: var(--main-margin);
  padding-inline: var(--main-margin);
}

.page main {
  padding-top: calc(var(--fade-add) *0.75 + var(--topbar-height));
  padding-inline: var(--topbar-height);
}

.single main {
  padding-top: 0;
}

header, footer {
  text-transform: lowercase;
  font-weight: var(--topbar-font-weight);
  font-size: var(--topbar-font-size);
  z-index: 99998;
}

header {
    left: 0;
  right: 0;
  padding-inline: 2rem;
  height: calc(var(--fade-add) + var(--topbar-height));
  padding-bottom: var(--fade-add);
  position: fixed;
  background-color: var(--background-color-a);
  background: linear-gradient(180deg, hsla(0 0% var(--color-bg) / 0.95) 0%, 
      hsla(0 0% var(--color-bg) / 0.75) 40%, hsla(0 0% var(--color-bg) / 0) 100%);
  display: flex;
  gap: 1rem;
  align-items: center;
  animation-name: fade-from-top;
  animation-duration: var(--medium-anim);
  pointer-events: none;
}

header * {
  pointer-events: all;
}

.topbar-spacer {
  flex-basis: 100%;
}

.topbar-logo {
  flex-basis: min-content;
  opacity: 1;
  filter: invert(var(--invert));
}

.topbar-name {
  flex-basis: min-content;
  font-family: var(--header-font);
  color: var(--text-color-highlight);
  text-transform: lowercase;
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: 0;
  white-space: nowrap;
  margin-bottom: 0.2rem;
}

.topbar-name a:hover, .topbar-name a:focus {
  color: var(--text-color-highlight);
}

.topbar-logo img {
  flex-basis: min-content;
  height: calc(var(--topbar-height) * 0.5);
  max-width: var(--topbar-height);
  margin-top: -7px;
}

footer nav {
  flex-basis: min-content;
  display: grid;
  grid-gap: 2rem;
  grid-auto-flow: column;
  grid-template-columns: 1fr, 1fr;
  letter-spacing: 0.4rem;
}

header nav {
  flex-basis: min-content;
  display: grid;
  grid-gap: 2rem;
  align-items: center;
  grid-auto-flow: column;
  grid-template-columns: repeat(3, min-content);
  letter-spacing: 0.4rem;
}
header img {
  opacity: 0.95;
}
header .icon18search {
  translate: 0 0.4375rem;
}
header nav div {
  --menu-item-height: 1.75rem;
  height: var(--menu-item-height);
}
header nav .active {
  position: relative;
  border-bottom: 1px solid var(--text-color-highlight);
}

.video-group {
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: center;
}

.entry-footer {
  height: 1.5625rem;
  text-align: center;
}

.entry-footer .left {
  float: left;
}

.entry-footer .right {
  float: right;
}

body.admin-bar {
  --admin-bar-height: 32px;
}

@media screen and (max-width: 782px) {
  body.admin-bar {
    --admin-bar-height: 46px;
  }
}

@media screen and (max-width: 600px) {
  #wpadminbar {
    position: fixed !important;
  }
}

header, .portfolio-div {
  top: var(--admin-bar-height);
}

a, a:hover, a:focus {
  text-decoration: none;
  transition: var(--medium-anim) linear 0s;
  outline: 0 none;
}

.singular .site-content, .singular .site-content-page {
  margin: 0 auto;
}

/* link block */

.linkblock {
  display: grid;
  grid-gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
}

.linkblock .block {
  display: grid;
  align-items: end;
  column-gap: 1.3rem;
  row-gap: 0.2rem;
  background-color: var(--background-color-light);
  grid-template-columns: min-content 1fr;
  position: relative;
}

.linkblock .link {
  cursor: pointer;
  text-align: left;
  translate: 0 -1.4rem;
  font-size: 1rem;
}

.linkblock .number {
  font-size: 4rem;
  padding-left: 1rem;
  font-weight: 900;
  font-family: var(--header-font);
  color: var(--text-color-highlight);
  translate: 0 -1.5rem;
  height: 5rem;
}

.linkblock .img {
  grid-column: 1 / span 2;
}

.linkblock img {
  width: 100%;
}

.linkblock .icons {
  white-space: nowrap;
  translate: 1rem -1.4rem;
}

.linkblock .block::after {
  content: "";
  background-image: url("images/corner.svg?v=wPbv0Y");
  background-position-x: right;
  background-position-y: bottom;
  background-size: 1.875rem 1.875rem;
  width: 1.875rem;
  height: 1.875rem;
  position: absolute;
  right: 0;
  bottom: -0.0625rem;
  z-index: 1;
  display: inline-block;
  filter: invert(var(--invert));
}

/* quote */

figure.quote {
  padding: 1.25rem;
  width: fit-content;
  margin: 0 auto;
}

blockquote {
  font-size: 1.2rem;
  font-style: italic;
}
blockquote:before {
  content: open-quote;
}
blockquote:after {
  content: close-quote;
}
figure.quote > figcaption:before {
  content: "\2014\00a0";
}
figure.quote > figcaption {
  display: block;
  text-align: right;
  width: 100%;
}

.format-quote p:first-of-type {
  margin-bottom: 0;
}
.format-quote p:first-of-type:before {
  content: open-quote;
}
.format-quote p:first-of-type:after {
  content: close-quote;;
}
.format-quote p:last-of-type {
  text-align: right;
  display: block;
  width: 95%;
  margin-top: 0;
}
.format-quote p:last-of-type:before {
  content: "- ";
}
.format-quote .entry-header {
  display: none;
}

/* link */

.format-link p a:last-of-type {
  margin-top: 0.125rem;
  margin-bottom: 0.125rem;
  display: block;
}

/* lyrics */

.category-lyrics h6 {
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
  display: block;
}

/* searchbox */

.popupbox {
  background-color: var(--background-color-a);
  color: var(--text-color);
  display: flex;
  flex-direction: column;
  position: fixed;
  z-index: 100000;
  top: var(--topbar-height);
  right: 2rem;
  height: calc(90% - var(--topbar-height));
  width: 25ch;
  padding: 1rem;
  overflow: auto;
  overflow-y: hidden;
  border-radius: 1rem;
  transition-property: opacity;
  transition-duration: var(--short-anim);
  transition-timing-function: ease-in-out;
  backdrop-filter: blur(0.5rem);
  -webkit-backdrop-filter: blur(0.5rem);
}
.popupbox li {
  list-style-type: none;
}
.popupbox ul {
  padding-left: 0;
}
.popupbox .contact-links {
  padding-top: 1rem;
  padding-bottom: 0.5rem;
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  justify-items: center;
}
.popupbox-fill {
  display: inline-block;
  overflow-y: scroll;
  width: 100%;
  margin-bottom: var(--popupbox-padding);
  flex: 0 1 auto;
}
.popupbox-fixed {
  flex: 0 0 auto;
  width: 100%;
  margin-bottom: var(--popupbox-padding);
}
::-webkit-scrollbar {
  background: var(--background-color);
  border-radius: 0.25rem;
  height: 0.5rem;
  width: 0.5rem;
}

::-webkit-scrollbar-thumb {
  background: var(--middle-color);
  border-radius: 0.1875rem;
  border: 0.0625rem solid transparent;
  background-clip: content-box;
}

.popupbox-fill::-webkit-scrollbar, .popupbox-fill::-webkit-scrollbar-thumb {
  visibility: hidden;
}

.popupbox-fill:hover::-webkit-scrollbar, .popupbox-fill:hover::-webkit-scrollbar-thumb {
  visibility: visible;
}

#searchedit {
  width: 100%;
  display: block;
  border: 0.0625rem solid var(--text-color);
  color: var(--text-color-unselected);
  background-color: var(--background-color-light);
  font-family: var(--text-font);
  font-size: var(--text-font-size);
  height: 1.8rem;
  border-radius: 1rem;
  line-height: 2rem;
  padding: 0.1875rem 0.0rem 0.1875rem 2.125rem;
  background-image: url("images/search.svg?v=9PQ97Y");
  background-repeat: no-repeat;
  background-position: 0.6rem 0.3rem;
  z-index: 3000;
}

.search {
  margin-right: 0.625rem;
}

.button {
	box-shadow:inset 0.0rem -0.1875rem 0.4375rem 0.0rem var(--text-color-accent);
	background-color: var(--text-color-accent);
	border-radius:0.1875rem;
	border:0.0625rem solid #0b0e07;
	display:inline-block;
	cursor:pointer;
	color: var(--text-color);
	font-size:0.8125rem;
	padding:0.3125rem 1.4375rem;
	text-decoration:none;
  font-family: var(--text-font);
  font-size: var(--text-font-size);
}
.button:hover {
	color: var(--text-color-highlight);
}
.button:active {
	position:relative;
	top:0.0625rem;
}

/* cv */

.cv ul {
  list-style-type: none;
  text-indent: -3.25rem;
  margin-left: 1rem;
}

.cv .sd-content ul {
  text-indent: 0 !important;
}

.cv h5 {
  margin-bottom: 0.625rem;
}

.cv ul {
  margin-bottom: 1.25rem;
}
.cv ul ul, .cv ul ul ul {
  margin-bottom: 0;
  padding-left: 2ch;
}

/* icons */

.icon18left, .icon18right, .icon18close, .icon18search, .icon18searchmenu, .icon18categories,
.icon18fb, .icon18twitter, .icon18youtube, .icon18email, .icon18instagram, .icon18behance {
  background-image: url('images/icons.svg?v=exRRpY');
  background-repeat: no-repeat;
  background-size: 18.0rem 1.5rem;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  margin: 0;
  display: inline-block;
  cursor: pointer;
  filter: invert(var(--invert));
}
.icon18left {
  background-position: 0.0rem 0.0rem;
}
.icon18right {
  background-position: -1.5rem 0.0rem;
}
.icon18close {
  background-position: -3.0rem 0.0rem;
}
.icon18search {
  background-position: -4.5rem 0.0rem;
}
.icon18categories {
  background-position: -6.0rem 0.0rem;
}
.icon18fb {
  background-position: -7.5rem 0.0rem;
}
.icon18twitter {
  background-position: -9.0rem 0.0rem;
}
.icon18email {
  background-position: -10.5rem 0.0rem;
}
.icon18instagram {
  background-position: -12.0rem 0.0rem;
}
.icon18youtube {
  background-position: -13.5rem 0.0rem;
}
.icon18behance {
  background-position: -15.0rem 0.0rem;
}
.icon18searchmenu {
  background-position: -16.5rem 0.0rem;
}

.hidden {
  opacity: 0;
  pointer-events: none;
}

.bottomimg {
  display: none;
}

.centered {
  text-align: center;
}

/* special pages */

.page-projects h2 {
  text-align: center;
}

.page-cv h3 {
  font-size: 1.3rem;
}

/* smaller screens */

@media (max-width: 800px) { 
  .topbar-name {
    display: none;
  }
  .video-group {
    flex-direction: column;
  }
  .portfolio-left-pane, .portfolio-right-pane {
    font-size: 1.5rem;
    --portfolio-pane-width: calc(--topbar-height / 2)
  }
  figure.size-full, .wp-block-jetpack-tiled-gallery, .vvideo {
    width: calc(100vw - 2 * var(--main-margin));
    margin-left: calc(-1 * var(--text-padding))  !important;
  }
  .page main {
    padding-inline: var(--main-margin);
  }
}

@media (max-width: 704px) { 
  :root {
    --main-margin: 1rem;
  }
  .multiple {
    padding-inline: 0;
  }
  .topBar {
    padding-inline: 1rem;
  }
  .image-panel {
    grid-template-columns: 1fr;
  }
  .image-panel img {
    grid-row-start: 2;
  }
}

@media (max-width: 608px) { 
  header nav {
    grid-gap: 0.5rem;
    letter-spacing: .1rem;
    font-size: 90%;
  }
}

@media (max-width: 512px) { 
  header nav {
    font-size: 75%;
  }
  h1 {
    font-size: 2rem;
  }
}
