/* =============================================
   FONT
   ============================================= */
@font-face {
  font-family: 'PixelifySans';
  src: url('PixelifySans-Regular.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'ZeroPixel';
  src: url('zeropixel-eye-fs.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

.font-zeropixel {
  font-family: 'ZeroPixel', monospace;
}

/* =============================================
   CSS VARIABLES & PIXEL BORDER (original)
   ============================================= */
:root {
  --pixel-bg: #fce1ea;
  --pixel-border: #ff91bd;
  --pixel-border-2: white;
  --pixel-border-3: var(--pixel-border);
  --pixel: .125rem;

  /* Theme tokens - light */
  --bg: #fce1ea;
  --surface: #fce1ea;
  --text: #ff8ab3;
  --text-soft: #b06080;
  --accent: #ff91bd;
  --handle-color: #c4708d;
  --input-bg: #fff0f5;
  --input-border: #ffb8d4;
  --submit-bg: #fce1ea;
}

[data-theme="dark"] {
  --pixel-bg: #2a1020;
  --pixel-border: #cc4477;
  --pixel-border-2: #2b2b2b;
  --pixel-border-3: var(--pixel-border);

  --bg: #2a1020;
  --surface: #2a1020;
  --text: #ffb8d4;
  --text-soft: #cc7799;
  --accent: #cc4477;
  --handle-color: #aa5577;
  --input-bg: #200c18;
  --input-border: #882244;
  --submit-bg: #2a1020;
}

/* =============================================
   PIXEL BORDER CLASS
   ============================================= */
.pixel-border,
.laptop-lid,
.laptop-base,
.ipod {
  background: var(--pixel-bg);
  box-shadow:
    0 calc(var(--pixel) * -3) 0 calc(var(--pixel) * -1) var(--pixel-bg),
    0 calc(var(--pixel) * 3) 0 calc(var(--pixel) * -1) var(--pixel-bg),
    0 calc(var(--pixel) * -6) 0 calc(var(--pixel) * -2) var(--pixel-bg),
    0 calc(var(--pixel) * 6) 0 calc(var(--pixel) * -2) var(--pixel-bg),
    0 calc(var(--pixel) * -9) 0 calc(var(--pixel) * -4) var(--pixel-bg),
    0 calc(var(--pixel) * 9) 0 calc(var(--pixel) * -4) var(--pixel-bg),
    0 calc(var(--pixel) * -12) 0 calc(var(--pixel) * -6) var(--pixel-bg),
    0 calc(var(--pixel) * 12) 0 calc(var(--pixel) * -6) var(--pixel-bg),
    calc(var(--pixel) * -1) 0 0 0 var(--pixel-border),
    var(--pixel) 0 0 0 var(--pixel-border),
    0 calc(var(--pixel) * -2) 0 0 var(--pixel-border),
    0 calc(var(--pixel) * 2) 0 0 var(--pixel-border),
    0 calc(var(--pixel) * -5) 0 calc(var(--pixel) * -1) var(--pixel-border),
    0 calc(var(--pixel) * 5) 0 calc(var(--pixel) * -1) var(--pixel-border),
    0 calc(var(--pixel) * -7) 0 calc(var(--pixel) * -2) var(--pixel-border),
    0 calc(var(--pixel) * 7) 0 calc(var(--pixel) * -2) var(--pixel-border),
    0 calc(var(--pixel) * -10) 0 calc(var(--pixel) * -4) var(--pixel-border),
    0 calc(var(--pixel) * 10) 0 calc(var(--pixel) * -4) var(--pixel-border),
    0 calc(var(--pixel) * -13) 0 calc(var(--pixel) * -6) var(--pixel-border),
    0 calc(var(--pixel) * 13) 0 calc(var(--pixel) * -6) var(--pixel-border),
    calc(var(--pixel) * -2) 0 0 0 var(--pixel-border-2),
    calc(var(--pixel) * 2) 0 0 0 var(--pixel-border-2),
    0 calc(var(--pixel) * -1) 0 var(--pixel) var(--pixel-border-2),
    0 var(--pixel) 0 var(--pixel) var(--pixel-border-2),
    0 calc(var(--pixel) * -4) 0 0 var(--pixel-border-2),
    0 calc(var(--pixel) * 4) 0 0 var(--pixel-border-2),
    0 calc(var(--pixel) * -6) 0 calc(var(--pixel) * -1) var(--pixel-border-2),
    0 calc(var(--pixel) * 6) 0 calc(var(--pixel) * -1) var(--pixel-border-2),
    0 calc(var(--pixel) * -8) 0 calc(var(--pixel) * -2) var(--pixel-border-2),
    0 calc(var(--pixel) * 8) 0 calc(var(--pixel) * -2) var(--pixel-border-2),
    0 calc(var(--pixel) * -11) 0 calc(var(--pixel) * -4) var(--pixel-border-2),
    0 calc(var(--pixel) * 11) 0 calc(var(--pixel) * -4) var(--pixel-border-2),
    0 calc(var(--pixel) * -14) 0 calc(var(--pixel) * -6) var(--pixel-border-2),
    0 calc(var(--pixel) * 14) 0 calc(var(--pixel) * -6) var(--pixel-border-2),
    calc(var(--pixel) * -3) 0 0 0 var(--pixel-border-3),
    calc(var(--pixel) * 3) 0 0 0 var(--pixel-border-3),
    0 0 0 calc(var(--pixel) * 2) var(--pixel-border-3),
    0 calc(var(--pixel) * -3) 0 var(--pixel) var(--pixel-border-3),
    0 calc(var(--pixel) * 3) 0 var(--pixel) var(--pixel-border-3),
    0 calc(var(--pixel) * -5) 0 0 var(--pixel-border-3),
    0 calc(var(--pixel) * 5) 0 0 var(--pixel-border-3),
    0 calc(var(--pixel) * -7) 0 calc(var(--pixel) * -1) var(--pixel-border-3),
    0 calc(var(--pixel) * 7) 0 calc(var(--pixel) * -1) var(--pixel-border-3),
    0 calc(var(--pixel) * -9) 0 calc(var(--pixel) * -2) var(--pixel-border-3),
    0 calc(var(--pixel) * 9) 0 calc(var(--pixel) * -2) var(--pixel-border-3),
    0 calc(var(--pixel) * -12) 0 calc(var(--pixel) * -4) var(--pixel-border-3),
    0 calc(var(--pixel) * 12) 0 calc(var(--pixel) * -4) var(--pixel-border-3),
    0 calc(var(--pixel) * -15) 0 calc(var(--pixel) * -6) var(--pixel-border-3),
    0 calc(var(--pixel) * 15) 0 calc(var(--pixel) * -6) var(--pixel-border-3);
}

/* =============================================
   PAGE LAYOUT
   ============================================= */
.main-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.site-header {
  width: 100%;
  padding: 2rem 1rem 0;
  display: flex;
  justify-content: center;
  box-sizing: border-box;
  margin-bottom: 2rem;
}

.site-header .site-logo {
  width: 100%;
  margin-right: 10px;
  max-width: 1186px;
  padding: 1.2rem 1rem;
  background: var(--pixel-bg);
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  /* Pixel border effect - matching .pixel-border class */
  box-shadow:
    0 calc(var(--pixel) * -3) 0 calc(var(--pixel) * -1) var(--pixel-bg),
    0 calc(var(--pixel) * 3) 0 calc(var(--pixel) * -1) var(--pixel-bg),
    0 calc(var(--pixel) * -6) 0 calc(var(--pixel) * -2) var(--pixel-bg),
    0 calc(var(--pixel) * 6) 0 calc(var(--pixel) * -2) var(--pixel-bg),
    0 calc(var(--pixel) * -9) 0 calc(var(--pixel) * -4) var(--pixel-bg),
    0 calc(var(--pixel) * 9) 0 calc(var(--pixel) * -4) var(--pixel-bg),
    0 calc(var(--pixel) * -12) 0 calc(var(--pixel) * -6) var(--pixel-bg),
    0 calc(var(--pixel) * 12) 0 calc(var(--pixel) * -6) var(--pixel-bg),
    calc(var(--pixel) * -1) 0 0 0 var(--pixel-border),
    var(--pixel) 0 0 0 var(--pixel-border),
    0 calc(var(--pixel) * -2) 0 0 var(--pixel-border),
    0 calc(var(--pixel) * 2) 0 0 var(--pixel-border),
    0 calc(var(--pixel) * -5) 0 calc(var(--pixel) * -1) var(--pixel-border),
    0 calc(var(--pixel) * 5) 0 calc(var(--pixel) * -1) var(--pixel-border),
    0 calc(var(--pixel) * -7) 0 calc(var(--pixel) * -2) var(--pixel-border),
    0 calc(var(--pixel) * 7) 0 calc(var(--pixel) * -2) var(--pixel-border),
    0 calc(var(--pixel) * -10) 0 calc(var(--pixel) * -4) var(--pixel-border),
    0 calc(var(--pixel) * 10) 0 calc(var(--pixel) * -4) var(--pixel-border),
    0 calc(var(--pixel) * -13) 0 calc(var(--pixel) * -6) var(--pixel-border),
    0 calc(var(--pixel) * 13) 0 calc(var(--pixel) * -6) var(--pixel-border),
    calc(var(--pixel) * -2) 0 0 0 var(--pixel-border-2),
    calc(var(--pixel) * 2) 0 0 0 var(--pixel-border-2),
    0 calc(var(--pixel) * -1) 0 var(--pixel) var(--pixel-border-2),
    0 var(--pixel) 0 var(--pixel) var(--pixel-border-2),
    0 calc(var(--pixel) * -4) 0 0 var(--pixel-border-2),
    0 calc(var(--pixel) * 4) 0 0 var(--pixel-border-2),
    0 calc(var(--pixel) * -6) 0 calc(var(--pixel) * -1) var(--pixel-border-2),
    0 calc(var(--pixel) * 6) 0 calc(var(--pixel) * -1) var(--pixel-border-2),
    0 calc(var(--pixel) * -8) 0 calc(var(--pixel) * -2) var(--pixel-border-2),
    0 calc(var(--pixel) * 8) 0 calc(var(--pixel) * -2) var(--pixel-border-2),
    0 calc(var(--pixel) * -11) 0 calc(var(--pixel) * -4) var(--pixel-border-2),
    0 calc(var(--pixel) * 11) 0 calc(var(--pixel) * -4) var(--pixel-border-2),
    0 calc(var(--pixel) * -14) 0 calc(var(--pixel) * -6) var(--pixel-border-2),
    0 calc(var(--pixel) * 14) 0 calc(var(--pixel) * -6) var(--pixel-border-2),
    calc(var(--pixel) * -3) 0 0 0 var(--pixel-border-3),
    calc(var(--pixel) * 3) 0 0 0 var(--pixel-border-3),
    0 0 0 calc(var(--pixel) * 2) var(--pixel-border-3),
    0 calc(var(--pixel) * -3) 0 var(--pixel) var(--pixel-border-3),
    0 calc(var(--pixel) * 3) 0 var(--pixel) var(--pixel-border-3),
    0 calc(var(--pixel) * -5) 0 0 var(--pixel-border-3),
    0 calc(var(--pixel) * 5) 0 0 var(--pixel-border-3),
    0 calc(var(--pixel) * -7) 0 calc(var(--pixel) * -1) var(--pixel-border-3),
    0 calc(var(--pixel) * 7) 0 calc(var(--pixel) * -1) var(--pixel-border-3),
    0 calc(var(--pixel) * -9) 0 calc(var(--pixel) * -2) var(--pixel-border-3),
    0 calc(var(--pixel) * 9) 0 calc(var(--pixel) * -2) var(--pixel-border-3),
    0 calc(var(--pixel) * -12) 0 calc(var(--pixel) * -4) var(--pixel-border-3),
    0 calc(var(--pixel) * 12) 0 calc(var(--pixel) * -4) var(--pixel-border-3),
    0 calc(var(--pixel) * -15) 0 calc(var(--pixel) * -6) var(--pixel-border-3),
    0 calc(var(--pixel) * 15) 0 calc(var(--pixel) * -6) var(--pixel-border-3);
}

.site-header .site-logo img {
  max-width: 200px;
  image-rendering: pixelated;
}

.page-layout {
  display: flex;
  align-items: flex-start;
  gap: 3rem;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 0 1rem 5rem;
  box-sizing: border-box;
}

.arcade-column {
  flex-shrink: 0;
  width: 490px;
  position: sticky;
  top: 2rem;
  margin-left: -1rem;
}

/* =============================================
   SITE WRAPPER (right column)
   ============================================= */
.site-wrapper {
  flex: 1;
  min-width: 0;
  max-width: 720px;
  margin-left: 2rem;
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

/* Logo (now in header above) */

/* =============================================
   LAPTOP COMPUTER
   ============================================= */

:root {
  --arc-border: var(--pixel-border);
  --arc-border-size: 3px;
  --arc-body: var(--pixel-bg);
  --arc-screen-container: var(--pixel-border);
  --arc-screen: #ffffff;
  --arc-screen-line: #ffc7e2;
}

[data-theme="dark"] {
  --arc-screen: #3d001f;
  --arc-screen-line: #9a1050;
}

.arcade-machine {
  width: 496px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 60px auto;
  filter: drop-shadow(0 8px 18px color-mix(in srgb, var(--arc-border) 40%, transparent));
}

/* Hide unused elements */
.arcade-machine .top,
.arcade-machine > .shadow,
.arcade-machine .joystick,
.arcade-machine .board,
.arcade-machine .bottom,
.computer-neck,
.computer-base {
  display: none;
}

/* ---- Monitor bezel ---- */
.laptop-lid {
  width: 100%;
  border: none;
  border-radius: 0;
  padding: 12px 12px 8px;
  position: relative;
  z-index: 2;
}

/* Camera dot */
.laptop-lid::before {
  display: none;
}

.screen-container {
  width: 100%;
  background: var(--arc-body);
  border: none;
  border-radius: 0;
  padding: 0;
  position: relative;
  box-shadow: none;
}

.screen-container::before,
.screen-container::after {
  display: none;
}

.screen-container > .shadow {
  display: none;
}

.screen {
  width: 100%;
  height: 320px;
  background: var(--arc-screen);
  border: var(--arc-border-size) solid var(--arc-border);
  border-radius: 4px;
  overflow: hidden;
  position: relative;
  margin-top: 0;
}

/* Bottom bezel bar with two dots */
.bezel-bar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 6px;
  padding: 6px 4px 0;
}

.bezel-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--arc-screen-container);
  border: var(--arc-border-size) solid var(--arc-border);
  opacity: 0.8;
}

.screen-display {
  position: absolute;
  width: 100%;
  height: 200%;
  top: 0;
  left: 0;
  z-index: 1;
  background-image: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 14px,
    var(--arc-screen-line) 14px,
    var(--arc-screen-line) 15px
  );
  animation: arcadeScroll 2s infinite linear;
  pointer-events: none;
}

.screen-icons {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.5rem;
  padding: 0.7rem;
  z-index: 3;
}

.screen-icon-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  width: 4.2rem;
}

.screen-icon-item img {
  width: 3rem;
  height: 3rem;
  image-rendering: pixelated;
  opacity: 0.95;
}

.screen-icon-item span {
  font-family: 'PixelifySans', monospace;
  font-size: 0.96rem;
  color: var(--arc-screen-container);
  text-align: center;
  line-height: 1.2;
  word-break: break-word;
  text-shadow: none;
}

[data-theme="dark"] .screen-icon-item span {
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,0.6);
}

/* ---- Monitor neck ---- */
.laptop-hinge {
  display: none;
}

.monitor-neck {
  width: 44px;
  height: 38px;
  background: var(--arc-body);
  border-left: var(--arc-border-size) solid var(--arc-border);
  border-right: var(--arc-border-size) solid var(--arc-border);
  border-bottom: var(--arc-border-size) solid var(--arc-border);
  clip-path: polygon(20% 0%, 80% 0%, 100% 100%, 0% 100%);
}

/* ---- Monitor foot ---- */
.monitor-foot {
  width: 170px;
  height: 14px;
  background: var(--arc-body);
  border: var(--arc-border-size) solid var(--arc-border);
  border-radius: 4px;
  margin-bottom: 16px;
}

/* ---- Keyboard (separate, sits below stand) ---- */
.laptop-base {
  width: 108%;
  border: none;
  border-radius: 0;
  padding: 10px 14px 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin-top: 1.2rem;
}

.laptop-base::before {
  display: none;
}

/* ---- Keyboard ---- */
.laptop-keyboard {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.keyboard-row {
  display: flex;
  gap: 3px;
  justify-content: center;
}

.key {
  height: 12px;
  width: 18px;
  background: var(--arc-screen-container);
  border-radius: 2px;
  opacity: 0.6;
  flex-shrink: 0;
}

.key.wide {
  width: 28px;
}

.key.spacebar {
  width: 140px;
  height: 12px;
}

/* ---- Touchpad ---- */
.laptop-touchpad {
  width: 80px;
  background: color-mix(in srgb, var(--arc-body) 60%, var(--arc-border));
  border: var(--arc-border-size) solid var(--arc-border);
  border-radius: 4px;
  padding: 6px 4px 4px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
}

.touchpad-btns {
  display: flex;
  gap: 4px;
}

.touchpad-btn {
  width: 30px;
  height: 8px;
  background: var(--arc-screen-container);
  border-radius: 2px;
  opacity: 0.7;
}

@keyframes arcadeScroll {
  from { top: 0; }
  to   { top: 10%; }
}

/* =============================================
   ============================================= */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  min-height: 100%;
}

body {
  font-family: 'PixelifySans', 'Courier New', Courier, monospace;
  font-size: 1.1rem;
  background: var(--bg);
  color: var(--text);
  transition: background 0.3s, color 0.3s;
}

* {
  font-size: inherit;
}

/* =============================================
   TOP ROW (bar + dark mode button)
   ============================================= */
.top-row {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 1rem;
}

/* ---- Top Bar ---- */
.top-bar {
  flex: 1;
  min-width: 0;
  max-width: calc(100% - 6rem);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.6rem 1rem;
  color: var(--text);
}

/* Search wrapper */
.search-wrap {
  position: relative;
  flex: 1;
  min-width: 0;
  max-width: 400px;
  display: flex;
  align-items: center;
}

.search-input {
  width: 96%;
  background: var(--input-bg);
  border: 2px solid var(--input-border);
  color: var(--text);
  font-family: inherit;
  padding: 0.45rem 2.4rem 0.45rem 0.75rem;
  outline: none;
  transition: border-color 0.2s;
  image-rendering: pixelated;
}

.search-input::placeholder {
  color: var(--text-soft);
}

.search-input:focus {
  border-color: var(--accent);
}

.search-icon {
  margin-right: 1.1rem;
  position: absolute;
  right: 0.55rem;
  width: 1.1rem;
  height: 1.1rem;
  cursor: pointer;
  opacity: 0.75;
  image-rendering: pixelated;
}

/* Submit button */
.submit-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.45rem 0.85rem;
  background: var(--submit-bg);
  border: none;
  cursor: pointer;
  font-family: inherit;
  color: var(--text);
  white-space: nowrap;
  transition: opacity 0.15s;
  margin-left: auto;
}

.submit-btn:hover {
  opacity: 0.8;
}

.submit-btn img {
  width: 1rem;
  height: 1rem;
  image-rendering: pixelated;
}

/* ---- Dark Mode Toggle ---- */
.darkmode-btn {
  flex-shrink: 0;
  width: 5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  border: none;
  cursor: pointer;
  background: var(--pixel-bg);
  transition: opacity 0.15s;
  order: -1;
}

.darkmode-btn:hover {
  opacity: 0.8;
}

.darkmode-btn img {
  width: 1.9rem;
  height: 1.9rem;
  image-rendering: pixelated;
}

[data-theme="light"] .icon-dark  { display: none; }
[data-theme="dark"]  .icon-light { display: none; }

/* =============================================
   FEED
   ============================================= */
.feed {
  display: flex;
  flex-direction: column;
  gap: 3rem;
}

/* =============================================
   POST BOX
   ============================================= */
.post-box {
  width: 100%;
  padding: 1.2rem 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  color: var(--text);
}

/* Post header */
.post-header {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.pfp {
  width: 2.8rem;
  height: 2.8rem;
  flex-shrink: 0;
  image-rendering: smooth;
  background: var(--pixel-bg);
  border-radius: 4px;
}

.post-meta {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.meta-top {
  display: flex;
  align-items: baseline;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.user-name {
  font-weight: bold;
  color: var(--text);
}

.post-date {
  color: var(--text-soft);
}

.user-handle {
  color: var(--handle-color);
}

/* Post body */
.post-body {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.post-body p {
  line-height: 1.35;
  color: var(--text);
}

.post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.2rem;
}

.post-tag {
  font-family: 'PixelifySans', monospace;
  font-size: 0.88rem;
  color: var(--handle-color);
  background: var(--input-bg);
  border: 2px solid var(--input-border);
  padding: 0.15rem 0.5rem;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  user-select: none;
}

.post-tag:hover {
  background: var(--accent);
  color: var(--pixel-bg);
  border-color: var(--accent);
}

[data-theme="dark"] .post-tag {
  color: var(--text);
}

/* Active tag bar */
#active-tag-bar {
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.active-tag-label {
  font-family: 'PixelifySans', monospace;
  font-size: 0.9rem;
  color: var(--text-soft);
}

.active-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: var(--accent);
  color: var(--pixel-bg);
  font-family: 'PixelifySans', monospace;
  font-size: 0.9rem;
  padding: 0.2rem 0.55rem;
  border: 2px solid var(--accent);
}

.active-tag-remove {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--pixel-bg);
  font-family: inherit;
  font-size: 0.9rem;
  padding: 0;
  line-height: 1;
  transition: opacity 0.15s;
}

.active-tag-remove:hover {
  opacity: 0.7;
}

/* Source link on cross-page posts */
.post-source-link {
  display: inline-block;
  margin-top: 0.3rem;
  font-family: 'PixelifySans', monospace;
  font-size: 0.85rem;
  color: var(--handle-color);
  text-decoration: underline;
}

/* Lazy loading fade-in animation */
@keyframes fadeInImage {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.post-image {
  width: auto;
  max-height: auto;
  object-fit: cover;
  display: block;
  image-rendering: auto;
  animation: fadeInImage 0.5s ease-in-out forwards;
  background-color: var(--input-bg);
  border-radius: 10px;
}

/* State-based styling for lazy loading */
.post-image[loading="lazy"] {
  opacity: 0;
}

.post-image.loaded {
  opacity: 1;
}

.post-image.in-view {
  animation: fadeInImage 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.post-video {
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  display: block;
  border-radius: 10px;
}

/* =============================================
   LIGHTBOX
   ============================================= */
.lightbox {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  box-sizing: border-box;
}

.lightbox.active {
  display: flex;
}

.lightbox-content {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lightbox-image {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border: none;
}

.lightbox-close {
  position: absolute;
  top: -2.5rem;
  right: 0;
  width: 2.5rem;
  height: 2.5rem;
  background-color: var(--accent);
  border: 2px solid var(--text);
  color: var(--pixel-bg);
  font-size: 1.8rem;
  font-weight: bold;
  border-radius: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 1;
  transition: all 0.2s ease;
}

.lightbox-close:hover {
  background-color: var(--text);
  color: var(--accent);
}

[data-theme="dark"] .lightbox-close {
  background-color: var(--accent);
  border: 2px solid var(--text);
  color: var(--pixel-bg);
}

[data-theme="dark"] .lightbox-close:hover {
  background-color: var(--text);
  color: var(--accent);
}

.lightbox-prev,
.lightbox-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 3rem;
  height: 3rem;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: opacity 0.2s ease;
  z-index: 10;
}

.lightbox-prev {
  left: -4rem;
}

.lightbox-next {
  right: -4rem;
}

.lightbox-prev img,
.lightbox-next img,
.lightbox-prev svg,
.lightbox-next svg {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.5));
}

.lightbox-prev:hover,
.lightbox-next:hover {
  opacity: 0.8;
  transform: translateY(-50%) scale(1.1);
}

.lightbox-prev:disabled,
.lightbox-next:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.post-image.lightbox-trigger {
  cursor: pointer;
  transition: transform 0.2s ease;
}

.post-image.lightbox-trigger:hover {
  transform: scale(1.02);
}

/* =============================================
   MOBILE STYLES
   ============================================= */
@media (max-width: 768px) {

  /* Logo header */
  .site-header {
    padding: 1.5rem 1rem 1rem;
  }

  .site-header .site-logo {
    padding: 0.6rem 0.8rem;
  }

  .site-header .site-logo img {
    max-width: 160px;
  }

  /* Stack layout vertically */
  .page-layout {
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    padding: 1.5rem 1rem 4rem;
    max-width: 100%;
  }

  .arcade-column {
    position: static;
    margin-left: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }

  .ipod {
    width: 350px !important;
    padding: 10px 12px;
  }

  /* Shrink computer to fit mobile */
  .arcade-machine {
    width: 360px;
  }

  /* Shrink keyboard base proportionally */
  .laptop-base {
    width: 100%;
  }

  .key {
    width: 12px;
  }

  .key.wide {
    width: 18px;
  }

  .key.spacebar {
    width: 90px;
  }

  /* Right column full width, no extra margin */
  .site-wrapper {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    grid-column: 1;
    grid-row: auto;
  }

  /* Top bar wraps nicely */
  .top-bar {
    max-width: 100%;
  }

  .search-wrap {
    max-width: 100%;
  }

  /* Shrink dark mode button */
  .darkmode-btn {
    width: 3.5rem;
    padding: 0.4rem;
  }

  .darkmode-btn img {
    width: 1.5rem;
    height: 1.5rem;
  }

  /* Shrink submit button */
  .submit-btn {
    padding: 0.4rem 0.6rem;
    font-size: 0.85rem;
  }

  /* Post boxes full width */
  .post-box {
    padding: 1rem 1rem;
  }

  /* Lightbox on mobile */
  .lightbox {
    padding: 1rem;
  }

  .lightbox-content {
    max-width: 100vw;
    max-height: 100vh;
  }

  .lightbox-image {
    max-width: 100%;
    max-height: 85vh;
    border: none;
  }

  .lightbox-close {
    top: -2rem;
    right: 1px;
    width: 2rem;
    height: 2rem;
    font-size: 1.5rem;
    border: 2px solid var(--text);
  }

  .lightbox-prev,
  .lightbox-next {
    position: absolute;
    width: 2.5rem;
    height: 2.5rem;
    top: 50%;
    transform: translateY(-50%);
  }

  .lightbox-prev {
    left: 0.5rem;
  }

  .lightbox-next {
    right: 0.5rem;
  }

}

/* ---- Hover heart sizing fixes ---- */
.screen-icon-item img[src*="hover%20heart"],
.screen-icon-item img[src*="hover heart"] {
  width: auto;
  height: 2.4rem;
  object-fit: contain;
}

.darkmode-btn img[src*="hover%20heart"],
.darkmode-btn img[src*="hover heart"] {
  width: auto;
  height: 1.9rem;
  object-fit: contain;
}

.submit-btn img[src*="hover%20heart"],
.submit-btn img[src*="hover heart"] {
  width: auto;
  height: 1rem;
  object-fit: contain;
}
    .computer-links {
      display: flex;
      flex-wrap: wrap;
      gap: 0.4rem 0.7rem;
      justify-content: center;
      margin-top: 0.75rem;
      padding: 0 0.5rem;
    }
    .computer-links a {
      color: #c2185b;
      text-decoration: underline;
    }
    .computer-links a:visited {
      color: #ad1457;
    }
    [data-theme="dark"] .computer-links a {
      color: #f48fb1;
    }
    [data-theme="dark"] .computer-links a:visited {
      color: #f06292;
    }

/* =============================================
   MINI IPOD (horizontal)
   ============================================= */
.ipod {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
  width: 496px;
  padding: 14px 16px;
  margin: 1.5rem auto 0;
  border-radius: 0;
}

/* Left: screen area */
.ipod-screen-wrap {
  flex: 0 0 auto;
  width: 180px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ipod-screen {
  width: 180px;
  height: 110px;
  background: var(--arc-screen);
  border: var(--arc-border-size) solid var(--arc-border);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ipod-screen-inner {
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 14px,
    var(--arc-screen-line) 14px,
    var(--arc-screen-line) 15px
  );
  animation: arcadeScroll 2s infinite linear;
  pointer-events: none;
  z-index: 1;
}

.ipod-screen-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 6px;
}

.ipod-song-info {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  text-align: center;
}

.ipod-song-info #ipod-title {
  font-family: 'PixelifySans', monospace;
  font-size: 0.82rem;
  color: var(--arc-screen-container);
  line-height: 1.3;
}

.ipod-song-info #ipod-artist {
  font-family: 'PixelifySans', monospace;
  font-size: 0.72rem;
  color: var(--text-soft);
  line-height: 1.3;
}

[data-theme="dark"] .ipod-song-info #ipod-title,
[data-theme="dark"] .ipod-song-info #ipod-artist {
  color: #fff;
}

/* Equalizer bars */
.ipod-eq {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 24px;
}

.eq-bar {
  width: 5px;
  background: var(--pixel-border);
  border-radius: 1px;
  height: 4px;
  transition: height 0.1s;
}

.ipod-eq.playing .eq-bar:nth-child(1) { animation: eq1 0.6s ease-in-out infinite alternate; }
.ipod-eq.playing .eq-bar:nth-child(2) { animation: eq2 0.4s ease-in-out infinite alternate; }
.ipod-eq.playing .eq-bar:nth-child(3) { animation: eq3 0.5s ease-in-out infinite alternate; }
.ipod-eq.playing .eq-bar:nth-child(4) { animation: eq4 0.35s ease-in-out infinite alternate; }
.ipod-eq.playing .eq-bar:nth-child(5) { animation: eq5 0.55s ease-in-out infinite alternate; }

@keyframes eq1 { from { height: 4px; } to { height: 20px; } }
@keyframes eq2 { from { height: 8px; } to { height: 16px; } }
@keyframes eq3 { from { height: 4px; } to { height: 24px; } }
@keyframes eq4 { from { height: 10px; } to { height: 18px; } }
@keyframes eq5 { from { height: 4px; } to { height: 14px; } }

/* Divider between screen and controls */
.ipod-divider {
  width: 2px;
  align-self: stretch;
  background: var(--pixel-border);
  margin: 0 14px;
  opacity: 0.5;
  flex-shrink: 0;
}

/* Right: controls */
.ipod-controls {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

/* Clickwheel ring */
.ipod-wheel {
  position: relative;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--pixel-border) 20%, var(--pixel-bg));
  border: 2px solid var(--pixel-border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Center play button */
.ipod-btn-play {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--pixel-bg);
  border: 2px solid var(--pixel-border);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--text);
  transition: opacity 0.15s;
  z-index: 2;
  position: relative;
}

.ipod-btn-play:hover { opacity: 0.75; }

/* Surrounding wheel buttons (prev, next, vol-, vol+) */
.ipod-wheel-btn {
  position: absolute;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.75rem;
  color: var(--text);
  background: transparent;
  border: 2px solid var(--text);
  transition: opacity 0.15s;
  font-family: 'PixelifySans', monospace;
  user-select: none;
}

.ipod-wheel-btn:hover { opacity: 0.6; }

.ipod-btn-prev  { top: 50%; left: 6px;  transform: translateY(-50%); }
.ipod-btn-next  { top: 50%; right: 6px; transform: translateY(-50%); }
.ipod-btn-volup { top: 6px; left: 50%;  transform: translateX(-50%); }
.ipod-btn-voldn { bottom: 6px; left: 50%; transform: translateX(-50%); }

a {
  color:#ff2e82;
  text-decoration: underline;
}