/* Scroller-only CSS: collage + spinner + button + DailyVault + ScrollerPhotos */

/* Base */
body {
  background-color: #000;
  color: #fff;
  font-family: 'Montserrat', Arial, sans-serif;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  min-height: 100vh;
  word-spacing: normal;
}

main {
  padding-top: 30px;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
}

/* Shuffle buttons (top + bottom) */
#refresh-button,
#refresh-button-bottom {
  display: block;
  margin: 20px auto 0 auto;
  padding: calc(5px + 8px) calc(20px + 8px);
  font-size: calc(16px + 8px);
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  background-color: #fff;
  color: #000;
  border: 2px solid transparent;
  border-radius: 5px;
  cursor: pointer;
  text-align: center;
  transition: background-color 0.3s ease, color 0.3s ease, border 0.3s ease;
}

#refresh-button:hover,
#refresh-button-bottom:hover {
  background-color: #000;
  color: #fff;
  border: 2px solid #fff;
}

#refresh-button.toggled,
#refresh-button-bottom.toggled {
  border: 2px solid #fff;
}

#refresh-button.toggled:hover,
#refresh-button-bottom.toggled:hover {
  background-color: #000;
  color: #fff;
  border: 2px solid #fff;
}

.button-container {
  margin-bottom: 20px;
  margin-top: 10px;
  text-align: center;
}

/* Bottom shuffle button: mobile only */
.button-container--mobile-only {
  display: none;
}

@media (max-width: 768px) {
  .button-container--mobile-only {
    display: block;
  }
}

/* Masonry container */
.collage-container {
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 20px;
  min-height: 600px;
  opacity: 0;
  transition: opacity 0.5s ease;
  box-sizing: border-box;
}

.collage-container.visible {
  opacity: 1;
}

/* Masonry tiles */
.collage-item {
  position: absolute;
  background-color: #000;
  color: #fff;
  border: 3px double #fff;
  border-radius: 15px;
  padding: 10px;
  box-sizing: border-box;
  overflow: hidden;
  text-align: center;
  transition: transform 0.3s ease, z-index 0.3s ease;
  width: 200px; /* scroller.js overrides to computed width */
  height: auto;
}

.collage-item img {
  border-radius: 15px;
  width: 100%;
  margin-bottom: 8px;
  display: block;
}

/* Title */
.collage-item .preview-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  font-size: 24px;
  text-align: center;
  line-height: 1.2;
  margin: -15px 0;
  width: 100%;
  display: block;
  white-space: normal;
  overflow: hidden;
}

/* Icons row */
.preview-icons {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  margin-top: -5px;
  margin-bottom: 5px;
}

.custom-number {
  font-size: 16px;
  font-weight: bold;
  margin-right: -9px;
  color: #aaa;
  line-height: 1;
}

.preview-icons i {
  color: #aaa;
  font-size: 16px;
  line-height: 1;
  vertical-align: middle;
}

/* Gold "Extra" label */
.extra-label {
  color: #d4af37;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
}

/* Hover zoom (archive + extras) */
.collage-item.article-preview:hover,
.collage-item.substack-preview:hover {
  transform: scale(1.05);
  z-index: 10;
}

/* Hover zoom (photos) */
.collage-item.scrollerphoto-preview:hover {
  transform: scale(1.05);
  z-index: 10;
}

/* Share button */
.share-button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  font-size: 1.2rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  transition: transform 0.3s ease;
  color: #aaa;
}

.share-button:focus {
  outline: none;
}

.share-button:hover {
  transform: scale(1.2);
  color: #fff;
}

/* ===================================================================== */
/* Scroller Photos tile text                                              */
/* ===================================================================== */
.scrollerphoto-caption {
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 16px;
  line-height: 1.25;
  color: #fff;
  margin: 6px 0 8px 0;
  text-align: center;
}

.scrollerphoto-credit {
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 14px;
  line-height: 1.2;
  color: #aaa;
  margin: 0 0 6px 0;
  text-align: center;
}

.scrollerphoto-credit a {
  color: #aaa;
  text-decoration: underline;
}

.scrollerphoto-credit a:hover {
  color: #fff;
}

/* Spinner */
.spinner-container {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 100;
}

.spinner-container.visible {
  display: flex;
  opacity: 1;
  visibility: visible;
}

.spinner-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fastSpin 0.3s linear 1;
}

.spinner-logo .logo-line {
  width: 40px;
  border: 1px solid #fff;
}

.spinner-logo .logo-text {
  font-family: 'Troyale', Arial, sans-serif;
  font-size: 48px;
  font-weight: bold;
  color: #fff;
}

@keyframes fastSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.hidden {
  display: none !important;
}

/* ===================================================================== */
/* DailyVault (merged from css/dailyvault-masonry.css)                    */
/* ===================================================================== */

/* DailyVault interactive card inside the existing masonry tile */
.collage-item.dailyvault-preview {
  border-color: #fff; /* default: white border */
}

/* After answering: color the whole card border red/green */
.collage-item.dailyvault-preview.is-correct {
  border-color: #0b3 !important;
}

.collage-item.dailyvault-preview.is-wrong {
  border-color: #d22 !important;
}

/* Hide old meta row (category/tag); we will use a simple "Vault" header instead */
.dailyvault-meta {
  display: none !important;
}

/* --- Vault header (injected via ::before so no JS changes needed) --- */
.collage-item.dailyvault-preview::before {
  content: "Vault";
  display: block;
  text-align: center;
  margin: 0 0 12px 0;

  font-family: 'Montserrat', 'League Spartan', Arial, sans-serif;
  font-weight: 800;
  font-size: 26px;
  letter-spacing: 1px;
  color: #fff;
}

/* On the answer key slide, hide the "Vault" header */
.collage-item.dailyvault-preview:has(.dailyvault-result-slide:not(.is-hidden))::before {
  content: "";
  display: none;
}

/* slides */
.dailyvault-slide {
  opacity: 1;
  transition: opacity 0.25s ease;
  width: 100%;
}

/* Hidden state */
.dailyvault-slide.is-hidden {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}

/* --- Prevent the tile from resizing when switching slides --- */
.collage-item.dailyvault-preview .dailyvault-question-slide {
  visibility: hidden; /* still takes space, but isn't visible unless active */
}

.collage-item.dailyvault-preview .dailyvault-question-slide:not(.is-hidden) {
  visibility: visible;
}

.collage-item.dailyvault-preview .dailyvault-result-slide {
  position: absolute;
  inset: 0;
}

.collage-item.dailyvault-preview .dailyvault-result-slide.is-hidden {
  position: absolute;
  inset: 0;
}

/* question text */
.dailyvault-question {
  font-family: 'Montserrat', Arial, sans-serif;
  font-size: 18px;
  line-height: 1.25;
  color: #fff;
  margin: 0 0 12px 0;
}

/* answers list */
.dailyvault-choices {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
  width: 100%;
}

.dailyvault-choices li {
  width: 100%;
}

/* Answer buttons: full width, NOT bold, same size as question text */
.dailyvault-choice-btn {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;

  background: #000;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 10px;
  padding: 10px 12px;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;

  font-family: 'Montserrat', Arial, sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.25;
  text-align: center;
}

.dailyvault-choice-btn:hover {
  background: #fff;
  color: #000;
}

/* after answering */
.dailyvault-choice-btn.is-disabled {
  opacity: 0.7;
  cursor: default;
}

.dailyvault-choice-btn.is-correct {
  border-color: #0b3;
  color: #0b3;
}

.dailyvault-choice-btn.is-wrong {
  border-color: #d22;
  color: #d22;
}

/* result slide content */
.dailyvault-result-title {
  display: none !important;
}

/* Base for keyTitle + correctText + spice */
.dailyvault-correct-answer,
.dailyvault-correct-text,
.dailyvault-spice {
  text-align: center;
  color: #fff;
}

/* KeyTitle */
.dailyvault-correct-answer {
  font-weight: 700;
  font-size: 26px;
  line-height: 1.15;
  margin: 0 0 18px 0;
  padding-top: 6px;
}

/* Correct answer text */
.dailyvault-correct-text {
  font-weight: 700;
  font-size: 18px;
  line-height: 1.3;
  margin: 0 0 18px 0;
}

/* Spice */
.dailyvault-spice {
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.3;
  margin: 0;
}

/* Colorize key slide text to match border */
.collage-item.dailyvault-preview.is-correct .dailyvault-correct-answer,
.collage-item.dailyvault-preview.is-correct .dailyvault-correct-text,
.collage-item.dailyvault-preview.is-correct .dailyvault-spice {
  color: #0b3;
}

.collage-item.dailyvault-preview.is-wrong .dailyvault-correct-answer,
.collage-item.dailyvault-preview.is-wrong .dailyvault-correct-text,
.collage-item.dailyvault-preview.is-wrong .dailyvault-spice {
  color: #d22;
}

/* Remove the Back button area */
.dailyvault-actions,
.dailyvault-action-btn {
  display: none !important;
}
