/* =========================
   GLOBAL RESET / STABILITY
========================= */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
}

/* =========================
   KEYFRAMES
========================= */

@keyframes sway {
  0% {
    transform: rotate(0deg);
  }

  20% {
    transform: rotate(2deg);
  }

  40% {
    transform: rotate(-2deg);
  }

  60% {
    transform: rotate(1.5deg);
  }

  80% {
    transform: rotate(-1.5deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

/* =========================
   BASE LAYOUT
========================= */

html {
  /* background-color: black; */
}

body {
  position: relative;
  counter-reset: section;
  margin: 0;
  padding: 12pt 0 64pt;
  overflow-x: hidden;
}

/* =========================
   MAIN GRID
========================= */

main {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 0 12pt 20vh 12pt;
  gap: 12pt;
  align-items: start;
}

/* =========================
   LINKS / TEXT RESET
========================= */

a {
  text-decoration: none;
  color: inherit;
}

p {
  margin: 0;
}

/* =========================
   TITLE
========================= */

.title {
  position: sticky;
  top: 0;
  z-index: 20;
  background: transparent;
}

.title p {
  font-size: 24pt;
  color: silver;
  text-shadow: 2px 2px 10px black;
  padding-left: 4pt;
  padding-bottom: 2pt;
  font-family: "Audiowide", sans-serif;
  text-align: center;
}

/* =========================
   PILLARS
========================= */

.pillar {
  position: fixed;
  top: 0;
  width: 8pt;
  height: 100%;
  transform: translateX(-50%);
  background: linear-gradient(90deg,
      #999 5%,
      #fff 10%,
      #999 20%,
      #ddd 50%,
      #ccc 70%,
      #fff 80%,
      #999 95%);
  box-shadow: 2px 2px 10px black;
  will-change: transform;
}

.pillar:nth-of-type(1) {
  left: 12.5%;
}

.pillar:nth-of-type(2) {
  left: 37.5%;
}

.pillar:nth-of-type(3) {
  left: 62.5%;
}

.pillar:nth-of-type(4) {
  left: 87.5%;
}

.pillar:nth-of-type(5),
.pillar:nth-of-type(6) {
  transform: translateX(0);
  z-index: 20;
}

.pillar:nth-of-type(5) {
  left: 0;
}

.pillar:nth-of-type(6) {
  right: 0;
}

/* =========================
   IMAGE CARD
========================= */

.image-container {
  background-color: white;
  position: relative;
  top: 32pt;
  display: block;
  height: fit-content;

  transform-origin: center 16px;
  animation: grow 1s ease-in-out;
  will-change: transform;

  contain: layout paint;
}

.image-container:hover {
  animation: sway 1.2s ease-in-out both;
  cursor: pointer;
}

.image-container::after {
  content: "";
  position: absolute;
  inset: -15px;
  mix-blend-mode: multiply;
  opacity: 0.4;
}

/* =========================
   IMAGE WRAPPER
========================= */

.image-wrapper {
  margin: 4pt;
  padding: 4pt 4pt 6pt;
  font-size: 9pt;
  border-left: 1pt inset silver;
  border-right: 1pt inset silver;
  display: flex;
  justify-content: center;
}

/* =========================
   IMAGE
========================= */

.image {
  position: relative;
  overflow: hidden;
}

.image figure {
  margin: 0;
  padding: 0;
  position: relative;
}

.image img {
  width: 100%;
  height: auto;

  -webkit-mask-image: url(/assets/images/graphics/shop-mask.svg);
  mask-image: url(/assets/images/graphics/shop-mask.svg);

  -webkit-mask-size: 100%;
  mask-size: 100%;
}

/* overlay mask */
.image::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.5;
  mix-blend-mode: multiply;

  -webkit-mask-image:
    linear-gradient(180deg, transparent 0%, black 10%, black 90%, transparent 100%),
    linear-gradient(90deg, transparent 0%, black 10%, black 90%, transparent 100%);

  mask-image:
    linear-gradient(180deg, transparent 0%, black 10%, black 90%, transparent 100%),
    linear-gradient(90deg, transparent 0%, black 10%, black 90%, transparent 100%);

  -webkit-mask-composite: destination-in;
  mask-composite: intersect;
}

/* =========================
   IMAGE NUMBER
========================= */

.image-number {
  position: absolute;
  top: 0;
  left: 0;
  margin: 10pt 0 0 12pt;
}

.image-number::before {
  counter-increment: section;
  content: "nr: " counter(section);
  font-size: 6pt;
}

/* =========================
   CAPTION
========================= */

.image figcaption {
  text-align: center;
  font-size: 6pt;
  font-family: 'Courier New', monospace;
  border-bottom: 1pt solid silver;
}

/* =========================
   INFO BLOCKS
========================= */

.image-info {
  margin: 0 4pt 6pt;
  padding: 4pt 4pt 6pt;
  font-size: 9pt;
  border-radius: 6pt;
}

.image-info-line {
  display: flex;
}

.image-info-line .left {
  width: 25%;
  text-align: right;
  text-transform: uppercase;
  color: gray;
  border-top: 1pt inset silver;
}

.image-info-line .right {
  width: 75%;
  margin-left: 6pt;
  padding-left: 6pt;
  text-transform: capitalize;
  color: gray;
  border-top: 1pt inset silver;
  border-bottom: 0.5pt solid silver;
}

/* =========================
   DECORATIVE ELEMENTS
========================= */

.screw {
  width: 16pt;
  position: absolute;
  top: 16px;
  transform: translateX(-50%);
  filter: drop-shadow(1px 1px 2px black);
  z-index: 10;
}

.screw:nth-of-type(1) {
  left: 50%;
}

/* =========================
   HIDDEN / AUX ELEMENTS
========================= */

.image-clip img {
  width: 30px;
  position: absolute;
  top: 4px;
  left: 80px;
  display: none;
}

#nr {
  position: absolute;
  left: 12pt;
  font-family: "Sedgwick Ave Display", cursive;
  font-size: 24pt;
  color: red;
  text-shadow: 2px 2px 3px crimson;
  display: none;
}

#nr::before {
  counter-increment: section;
  content: counter(section);
}

/* =========================
   HOME GRID
========================= */

.home-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
  list-style: none;
  line-height: 0;
}

.home-grid li {
  position: relative;
  overflow: hidden;
  background: #000;
}

/* =========================
   MEDIA OBJECTS
========================= */

.home-grid img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.3s;
}

.home-grid figcaption {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.5);
  color: white;
}

/* =========================
   RESPONSIVE
========================= */

@media screen and (min-width: 375px) and (max-width: 768px) {

  main {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
    margin: 0 4pt 20vh 4pt;
  }

  .screw {
    display: none;
  }

  .foreground {
    width: 150%;
    max-width: 150%;
  }

  .image-info {
    font-size: 9pt;
    text-align: center;
  }

  .image-info .left {
    display: none;
  }

  .image-info .right {
    width: 100%;
    margin-left: 0;
  }

  .image-info-line:nth-of-type(even) {
    display: none;
  }
}

/* =========================
   FOREGROUND
========================= */

.foreground {
  pointer-events: none;
  position: fixed;
  bottom: -25pt;
  left: 0;
  width: 100%;
  z-index: 20;
  will-change: transform;
}
/* =========================================
   BLUR LOAD
========================================= */

.blur-load {
  filter: blur(16px);
  transition: filter 0.35s ease-out, opacity 0.35s ease-out;
  opacity: 0.85;
  will-change: opacity;
  backface-visibility: hidden;
  transform: translateZ(0);
}

.blur-load.loaded {
  filter: blur(0);
  opacity: 1;
}

