/* ===================================================================
   mwthediva ~ LINKS (linktree, pure y2k) ~ pairs with styles.css
   =================================================================== */
.lt-wrap { width: 440px; max-width: 94%; margin: 14px auto; }

/* header card */
.lt-head { text-align: center; }
.lt-logo { width: 290px; max-width: 90%; height: auto; display: block; margin: 2px auto 6px; filter: drop-shadow(2px 3px 0 rgba(180,20,140,.3)); }
.lt-hero { width: 100%; max-width: 100%; height: auto; display: block; margin: 0 auto 8px; border: 4px ridge var(--cyan); box-shadow: 3px 3px 0 var(--hotpink); background: #2a0a40; }
.lt-handle { font-family: "Comic Sans MS", cursive; font-weight: bold; }
.lt-bio { font-size: 13px; color: #5a0040; margin-top: 4px; }
.lt-bio b { color: var(--hotpink); }
.lt-status { margin-top: 6px; }

/* the big link buttons */
.lt-links { margin-top: 10px; display: flex; flex-direction: column; gap: 9px; }
.lt-link {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: #2a0033; font-weight: bold; font-size: 15px;
  background: linear-gradient(#fff, #ffd6f5);
  border: 3px outset var(--pink);
  padding: 12px 14px; position: relative;
  box-shadow: 2px 2px 0 rgba(255,0,153,.35);
  transition: transform .08s;
}
.lt-link:hover { background: var(--yellow); color: var(--hotpink); border-style: inset; }
.lt-link:active { transform: translate(2px,2px); box-shadow: none; }
.lt-link .ic {
  width: 34px; height: 34px; flex-shrink: 0; display: grid; place-items: center;
  font-size: 19px; border: 2px solid #fff; background: var(--hotpink); color: #fff;
  box-shadow: inset 1px 1px 0 rgba(255,255,255,.5);
}
.lt-link .ic.cyan { background: var(--cyandk); color: #001a1a; }
.lt-link .ic.pur { background: var(--purple); }
.lt-link .ic.blk { background: #1a0033; }
.lt-link .ic.lime { background: #2a7a00; }
.lt-link .lbl { flex: 1; text-align: left; line-height: 1.1; }
.lt-link .lbl small { display: block; font-size: 11px; font-weight: normal; color: #7a5a7a; }
.lt-link:hover .lbl small { color: #99004d; }
.lt-link .go { font-family: "VT323", monospace; font-size: 18px; color: var(--hotpink); }
.lt-link.soon { opacity: .8; }
.lt-link.soon .ic { background: #999; }
.lt-link .new {
  position: absolute; top: -8px; right: -6px; transform: rotate(8deg);
  font-family: "Press Start 2P", monospace; font-size: 8px; color: #fff;
  background: var(--hotpink); border: 1px solid #fff; padding: 2px 4px;
}
/* hero link (the spotify pre-save) ~ a lil bigger + pulsing green glow */
.lt-link--hero {
  border-color: #1db000; font-size: 16px;
  background:
    linear-gradient(105deg, transparent 42%, rgba(255,255,255,.65) 48%, transparent 54%) -200% 0 / 220% 100% no-repeat,
    linear-gradient(#fff, #d9ffd6);
  animation: heroPulse 1.7s ease-in-out infinite, heroSheen 3s linear infinite;
}
.lt-link--hero .ic.lime { background: #1db000; }
.lt-link--hero .go { color: #0a8a00; }
@keyframes heroPulse { 0%,100% { box-shadow: 2px 2px 0 rgba(0,140,0,.4); } 50% { box-shadow: 0 0 0 3px rgba(40,200,40,.45), 2px 2px 0 rgba(0,140,0,.4); } }
@keyframes heroSheen { to { background-position: 300% 0, 0 0; } }
body.reduce-motion .lt-link--hero { animation: none; background: linear-gradient(#fff, #d9ffd6); }

/* section label */
.lt-sec {
  text-align: center; font-family: "Comic Sans MS", cursive; font-weight: bold;
  color: var(--purple); margin: 14px 0 2px; font-size: 13px;
}

/* footer bits */
.lt-foot { text-align: center; margin-top: 14px; font-size: 12px; color: #5a0040; }
.lt-share {
  font-family: "Comic Sans MS", cursive; font-weight: bold; cursor: pointer;
  background: linear-gradient(#fff,#d6ffff); border: 3px outset var(--cyan); padding: 6px 16px; font-size: 13px;
}
.lt-share:active { border-style: inset; }

/* MWAMP ~ now playing (real audio, pink-purple diva skin) */
.mini-amp {
  background: linear-gradient(#f3c4e8, #db95cf);
  border: 2px solid; border-color: #fff7fc #6a1f52 #6a1f52 #fff7fc;
  padding: 8px; text-align: left;
}
.mini-amp__top { display: flex; gap: 8px; align-items: stretch; }
.mini-amp__art {
  width: 90px; height: 90px; flex-shrink: 0; object-fit: cover;
  border: 2px solid; border-color: #fff7fc #6a1f52 #6a1f52 #fff7fc;
  box-shadow: 2px 2px 0 rgba(90,0,70,.4);
}
.mini-amp__screen {
  flex: 1; min-width: 0;
  background: radial-gradient(130% 150% at 50% 0, #2c0a40, #14041f);
  border: 2px inset #6a1f52; padding: 5px 7px;
  display: flex; flex-direction: column;
}
.mini-amp__lcd {
  font-family: "VT323", monospace; color: #ff6fe0; font-size: 16px;
  text-shadow: 0 0 4px #ff33cc; white-space: nowrap; overflow: hidden;
  display: flex; justify-content: space-between; gap: 6px;
}
.mini-amp__lcd .t { overflow: hidden; text-overflow: ellipsis; }
.mini-amp__lcd .time { color: #cba6ff; flex-shrink: 0; }
.mini-amp__eq { width: 100%; height: 38px; display: block; image-rendering: pixelated; margin-top: 3px; flex: 1; }
.mini-amp__sin { font-family: "VT323", monospace; font-size: 13px; color: #cba6ff; margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mini-amp__sin em { color: #ff8fe0; font-style: normal; }
/* seek bar */
.mini-amp__bar { position: relative; height: 12px; margin: 8px 0 2px; background: #14041f; border: 2px inset #6a1f52; cursor: pointer; touch-action: none; }
.mini-amp__bar i { position: absolute; inset: 0 auto 0 0; width: 0; background: linear-gradient(90deg,#7b2cff,#ff33cc); }
.mini-amp__bar span { position: absolute; top: -2px; left: 0; width: 8px; height: 12px; background: #f3c4e8; border: 1px solid; border-color:#fff #6a1f52 #6a1f52 #fff; transform: translateX(-50%); }
.mini-amp__ctrls { display: flex; align-items: center; gap: 7px; margin-top: 6px; }
.ma-btn {
  font-family: "Courier New", monospace; font-weight: bold; font-size: 12px;
  width: 32px; height: 28px; cursor: pointer; color: #4a0040;
  background: linear-gradient(#fff0fa, #e3a8d6);
  border: 2px solid; border-color: #fff7fc #6a1f52 #6a1f52 #fff7fc;
  display: grid; place-items: center;
}
.ma-btn--big { width: 48px; height: 36px; font-size: 17px; }
.ma-btn:active, .ma-btn.on { border-color: #6a1f52 #fff7fc #fff7fc #6a1f52; background: #d68dc4; }
.ma-label { flex: 1; font-family: "VT323", monospace; font-size: 16px; color: #7a005f; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ma-vol { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.ma-vol input { width: 70px; accent-color: var(--hotpink); }

@media (max-width: 480px) {
  .lt-link { font-size: 14px; }
  .lt-logo { width: 240px; }
  .mini-amp__art { width: 78px; height: 78px; }
  .ma-vol input { width: 54px; }
  .ma-label { font-size: 14px; }
}

/* photo album carousel (auto-rotate + swipe) */
.album__viewport {
  position: relative; overflow: hidden; aspect-ratio: 3 / 4;
  border: 4px ridge var(--cyan); box-shadow: 3px 3px 0 var(--hotpink);
  background: #2a0a40; touch-action: pan-y; cursor: grab; user-select: none;
}
.album__viewport:active { cursor: grabbing; }
.album__track { display: flex; height: 100%; transition: transform .42s cubic-bezier(.4,0,.2,1); will-change: transform; }
.album__slide { min-width: 100%; height: 100%; }
.album__slide img { width: 100%; height: 100%; object-fit: cover; display: block; pointer-events: none; -webkit-user-drag: none; }
.album__arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 34px; height: 46px; border: 2px outset var(--pink); border-radius: 0;
  background: rgba(255,214,245,.82); color: var(--hotpink);
  font-family: "Comic Sans MS", cursive; font-weight: bold; font-size: 24px;
  cursor: pointer; display: grid; place-items: center; z-index: 2;
}
.album__arrow:active { border-style: inset; }
.album__arrow--prev { left: 6px; }
.album__arrow--next { right: 6px; }
.album__dots { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; margin-top: 8px; }
.album__dot { width: 11px; height: 11px; padding: 0; border: 2px solid var(--hotpink); background: #fff; cursor: pointer; }
.album__dot.on { background: var(--hotpink); }
body.reduce-motion .album__track { transition: none; }

/* ===================================================================
   phase-1 glow-up ~ out-now shimmer, spinning CD, counter blip
   =================================================================== */

/* "OUT NOW" rainbow-chrome shimmer in the bio */
.out-now {
  color: var(--hotpink);
  background: linear-gradient(90deg, #ff0099, #ffd6f5, #00ffff, #ffd6f5, #ff0099);
  background-size: 300% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: outNowShimmer 2.4s linear infinite;
}
@keyframes outNowShimmer { to { background-position: 300% 0; } }
body.reduce-motion .out-now { animation: none; -webkit-text-fill-color: var(--hotpink); }

/* cover art as a spinning CD ~ rotates only while playing */
.cd-wrap { position: relative; width: 90px; height: 90px; flex-shrink: 0; }
.mini-amp__art.cd {
  width: 100%; height: 100%; border-radius: 50%; object-fit: cover;
  border: 2px solid #2a0a40; box-shadow: 0 0 0 2px #f3c4e8, 2px 2px 0 rgba(90,0,70,.4);
  animation: cdSpin 3.6s linear infinite; animation-play-state: paused;
}
.mini-amp.playing .mini-amp__art.cd { animation-play-state: running; }
/* spindle hole + ring + a static sheen, painted over the rotating label */
.cd-wrap::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%; pointer-events: none;
  background:
    radial-gradient(circle at 50% 50%, #14041f 0 8px, rgba(216,166,238,.9) 8px 11px, transparent 11px),
    linear-gradient(125deg, transparent 44%, rgba(255,255,255,.5) 50%, transparent 56%);
}
@keyframes cdSpin { to { transform: rotate(360deg); } }
body.reduce-motion .mini-amp__art.cd { animation: none; }

/* online dot flashes green when the visitor counter finishes rolling */
.online.blip .dot { animation: onlineBlip .55s ease 2; }
@keyframes onlineBlip { 0%, 100% { filter: none; } 35% { filter: drop-shadow(0 0 6px #66ff00) drop-shadow(0 0 3px #66ff00); } }

@media (max-width: 480px) { .cd-wrap { width: 78px; height: 78px; } }
