@font-face {
  font-family: "Birthday Display";
  src: url("assets/fonts/BungeeShadeLatin.woff2") format("woff2");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "Birthday Pixel";
  src: url("assets/fonts/SilkscreenRegularLatin.woff2") format("woff2");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "Birthday Pixel";
  src: url("assets/fonts/SilkscreenBoldLatin.woff2") format("woff2");
  font-style: normal;
  font-weight: 700;
  font-display: swap;
}

@font-face {
  font-family: "Birthday Code";
  src: url("assets/fonts/AudiowideLatin.woff2") format("woff2");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

:root {
  --sticky-chrome-offset: 5rem;
  --geo-navy: #111c5c;
  --geo-blue: #0055cc;
  --geo-red: #d51e33;
  --geo-pink: #ff2da3;
  --geo-cyan: #60f6ff;
  --geo-yellow: #ffe35f;
  --geo-paper: #fffef2;
  --geo-paper-cool: #eef6ff;
  --geo-ink: #111438;
  --geo-shadow: rgba(0, 0, 0, 0.76);
  --font-display: "Birthday Display", "Arial Black", "Trebuchet MS", sans-serif;
  --font-pixel: "Birthday Pixel", "Trebuchet MS", Tahoma, Verdana, sans-serif;
  --font-copy: "Comic Sans MS", "Trebuchet MS", cursive;
  --font-code: "Birthday Code", "Arial Black", sans-serif;
  --star-background: url("assets/y2k/star-background.jpg");
  --glitter-tile: url("assets/y2k/glitter-confetti-tile.svg");
  --button-blue: url("assets/y2k/button-88x31-room-entry.svg");
  --button-hot: url("assets/y2k/button-88x31-hot.svg");
  --button-gold: url("assets/y2k/button-88x31-gold.svg");
  --star-bullet: url("assets/y2k/star-bullet.svg");
  --new-sticker: url("assets/y2k/geocities-sticker-new.svg");
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: #020018;
  color: var(--geo-ink);
  overflow-x: clip;
  scroll-behavior: smooth;
}

body {
  min-width: 320px;
  min-height: 100%;
  margin: 0;
  background: #020018;
  font-family: var(--font-copy);
  overflow-x: clip;
}

body,
button,
input,
select,
textarea {
  font: inherit;
}

a {
  color: inherit;
}

.birthday-site {
  min-height: 100vh;
  min-height: 100dvh;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 0;
  background:
    0 0 / auto auto repeat var(--star-background),
    #020018;
  color: var(--geo-ink);
}

.browser-chrome {
  position: sticky;
  top: 0;
  z-index: 1000;
  border: 2px solid #000000;
  border-top-color: #ffffff;
  border-left-color: #ffffff;
  border-right-color: #555555;
  border-bottom-color: #555555;
  background: #d4d0c8;
  box-shadow:
    inset 1px 1px 0 #ffffff,
    inset -1px -1px 0 #808080;
  font-family: "Tahoma", "MS Sans Serif", sans-serif;
  font-size: 0.78rem;
}

[id] {
  scroll-margin-top: var(--sticky-chrome-offset);
}

.browser-title-row {
  min-height: 1.55rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.18rem 0.28rem;
  border-bottom: 1px solid #000000;
  background: linear-gradient(90deg, #0a246a 0%, #3a6ea5 68%, #9db9d5 100%);
  color: #ffffff;
  font-family: var(--font-pixel);
  font-weight: 700;
}

.browser-title {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.window-controls {
  display: inline-flex;
  gap: 0.18rem;
  flex: 0 0 auto;
}

.window-controls span {
  width: 0.86rem;
  height: 0.86rem;
  display: block;
  border: 1px solid #000000;
  border-top-color: #ffffff;
  border-left-color: #ffffff;
  background: #d4d0c8;
  box-shadow:
    inset 1px 1px 0 #ffffff,
    inset -1px -1px 0 #808080;
}

.window-controls .is-close {
  background:
    linear-gradient(135deg, transparent 42%, #c80000 43% 57%, transparent 58%),
    linear-gradient(45deg, transparent 42%, #c80000 43% 57%, transparent 58%),
    #d4d0c8;
}

.browser-menubar,
.browser-toolbar {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  min-height: 1.5rem;
  padding: 0.18rem 0.28rem;
  border-top: 1px solid #ffffff;
  border-bottom: 1px solid #808080;
  background: #d4d0c8;
  color: #000000;
}

.browser-toolbar {
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr) auto;
  gap: 0.42rem;
}

.browser-nav {
  display: inline-flex;
  gap: 0.18rem;
}

.nav-btn,
.go-button {
  min-width: 1.4rem;
  min-height: 1.2rem;
  display: inline-grid;
  place-items: center;
  border: 1px solid #000000;
  border-top-color: #ffffff;
  border-left-color: #ffffff;
  background: #d4d0c8;
  box-shadow:
    inset 1px 1px 0 #ffffff,
    inset -1px -1px 0 #808080;
  color: #000000;
  text-decoration: none;
}

.nav-btn {
  position: relative;
}

.nav-btn::before {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #000000;
  font-family: "Tahoma", "MS Sans Serif", sans-serif;
  font-size: 0.68rem;
  font-weight: 900;
  line-height: 1;
}

.nav-btn-back::before {
  content: "\25C0";
  font-size: 0.58rem;
}

.nav-btn-forward::before {
  content: "\25B6";
  font-size: 0.58rem;
}

.nav-btn-refresh::before {
  content: "\21BB";
  font-family: "Segoe UI Symbol", "Tahoma", "MS Sans Serif", sans-serif;
  font-size: 0.92rem;
  font-weight: 900;
}

.address-box {
  min-width: 0;
  padding: 0.18rem 0.38rem;
  border: 2px inset #ffffff;
  background: #ffffff;
  color: #000000;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.marquee {
  position: relative;
  margin: clamp(0.45rem, 0.9vw, 0.75rem) clamp(0.45rem, 1vw, 0.8rem) 0;
  overflow: hidden;
  border: 2px solid #ffffff;
  background: #050822;
  box-shadow: 4px 4px 0 var(--geo-shadow);
}

.marquee-track {
  display: flex;
  width: max-content;
  min-width: max-content;
  color: var(--geo-yellow);
  font-family: var(--font-pixel);
  font-size: clamp(0.68rem, 1.2vw, 0.88rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  text-shadow: 2px 2px 0 #000000;
  white-space: nowrap;
  animation: marquee-scroll 24s linear infinite;
  will-change: transform;
}

.marquee-track span {
  flex: 0 0 auto;
  padding: 0.46rem 2rem;
}

.homepage-grid {
  min-height: 0;
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(180px, 0.84fr) minmax(360px, 1.46fr) minmax(220px, 0.94fr);
  gap: clamp(0.45rem, 1vw, 0.8rem);
  align-items: start;
  margin: clamp(0.45rem, 1vw, 0.8rem) clamp(0.45rem, 1vw, 0.8rem) 0;
}

.side-rail {
  position: sticky;
  top: calc(var(--sticky-chrome-offset) + clamp(0.45rem, 1vw, 0.8rem));
  z-index: 20;
  min-width: 0;
  display: grid;
  gap: clamp(0.42rem, 0.8vw, 0.68rem);
}

.web-widget,
.main-window,
.site-footer,
.info-window {
  border: 2px solid var(--geo-navy);
  border-radius: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.78)),
    repeating-linear-gradient(0deg, transparent 0 15px, rgba(0, 85, 204, 0.08) 15px 16px),
    var(--geo-paper);
  box-shadow:
    inset 1px 1px 0 rgba(255, 255, 255, 0.96),
    4px 4px 0 var(--geo-shadow);
  color: var(--geo-ink);
}

.web-widget {
  display: grid;
  gap: 0.5rem;
  padding: clamp(0.5rem, 0.9vw, 0.65rem);
}

.left-rail .web-widget:nth-child(odd),
.right-rail .web-widget:nth-child(even) {
  transform: rotate(-0.45deg);
}

.left-rail .web-widget:nth-child(even),
.right-rail .web-widget:nth-child(odd) {
  transform: rotate(0.45deg);
}

.widget-title,
.window-title {
  height: 1.6rem;
  min-height: 1.6rem;
  display: flex;
  align-items: center;
  width: auto;
  max-width: none;
  margin: -0.65rem -0.65rem 0.42rem;
  padding: 0.18rem 0.5rem;
  border: 0;
  border-bottom: 2px solid var(--geo-navy);
  background: linear-gradient(90deg, var(--geo-blue), var(--geo-cyan));
  color: #ffffff;
  font-family: var(--font-pixel);
  font-size: clamp(0.56rem, 0.72vw, 0.72rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.1;
  text-transform: uppercase;
  text-shadow: 1px 1px 0 #000000;
}

.window-title-hot,
.guestbook-widget .widget-title,
.survey-window .widget-title {
  background: linear-gradient(90deg, var(--geo-red), var(--geo-pink));
}

.button-wall,
.status-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
  justify-content: center;
}

.web-button {
  width: 88px;
  min-width: 88px;
  max-width: 88px;
  height: 31px;
  min-height: 31px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.25rem;
  border: 0;
  background: center / 100% 100% no-repeat var(--button-blue);
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.46rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.05;
  text-align: center;
  text-decoration: none;
  text-shadow: none;
  text-transform: uppercase;
  box-shadow: 2px 2px 0 #000000;
  overflow: hidden;
}

.web-button-hot {
  background-image: var(--button-hot);
}

.web-button-gold {
  background-image: var(--button-gold);
}

.geo-list {
  display: grid;
  gap: 0.32rem;
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--geo-ink);
  font-size: clamp(0.78rem, 1vw, 0.9rem);
  font-weight: 700;
  line-height: 1.32;
}

.geo-list li {
  position: relative;
  padding-left: 1.05rem;
}

.geo-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.2rem;
  width: 0.68rem;
  height: 0.68rem;
  background: center / contain no-repeat var(--star-bullet);
}

.counter-widget {
  background:
    linear-gradient(180deg, #061047, #111c5c),
    #111c5c;
  color: var(--geo-yellow);
}

.counter-widget .widget-title {
  color: #ffffff;
}

.counter-digits {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0.18rem;
}

.counter-digits span {
  min-height: 1.75rem;
  display: grid;
  place-items: center;
  border: 2px inset #ffffff;
  background: #000000;
  color: var(--geo-yellow);
  font-family: var(--font-pixel);
  font-weight: 700;
  text-shadow: 0 0 6px rgba(255, 227, 95, 0.82);
}

.new-sticker {
  min-width: 3.1rem;
  display: inline-block;
  margin-right: 0.2rem;
  padding: 0.05rem 0.24rem;
  border: 2px solid var(--geo-navy);
  background: var(--new-sticker) center / 100% 100% no-repeat;
  color: #ffffff;
  font-family: var(--font-pixel);
  font-size: 0.62rem;
  font-weight: 700;
  text-align: center;
  text-shadow: 1px 1px 0 #000000;
  animation: blink 1.1s steps(2, end) infinite;
}

.main-window {
  min-width: 0;
  display: grid;
  gap: clamp(0.48rem, 1vw, 0.78rem);
  padding: clamp(0.52rem, 0.9vw, 0.7rem);
}

.site-header {
  display: grid;
  justify-items: center;
  gap: 0.24rem;
  padding: clamp(0.58rem, 1.2vw, 0.9rem);
  border: 2px solid var(--geo-navy);
  background:
    linear-gradient(90deg, var(--geo-yellow) 0 16%, transparent 16% 100%),
    linear-gradient(180deg, #ffffff, #d8edff);
  box-shadow: 4px 4px 0 var(--geo-shadow);
  text-align: center;
}

.site-kicker,
.site-subtitle {
  margin: 0;
  font-family: var(--font-pixel);
  font-weight: 700;
  letter-spacing: 0.18em;
  line-height: 1.2;
  text-transform: uppercase;
}

.site-kicker {
  color: var(--geo-red);
  font-size: clamp(0.62rem, 1vw, 0.8rem);
  text-transform: none;
}

.site-subtitle {
  color: var(--geo-navy);
  font-size: clamp(0.82rem, 1.4vw, 1.05rem);
}

.site-tagline {
  margin: 0.42rem 0 0;
  color: var(--geo-blue);
  font-family: var(--font-pixel);
  font-size: clamp(1.425rem, 2.475vw, 1.92rem);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.25;
  text-transform: uppercase;
  text-shadow: 1px 1px 0 #ffffff;
}

.tagline-year {
  display: inline-block;
  white-space: nowrap;
}

.tagline-corrected-digit {
  display: inline-block;
  position: relative;
  color: inherit;
}

.tagline-drawn-zero {
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0.74em;
  height: 1.1em;
  max-width: none;
  object-fit: contain;
  overflow: visible;
  transform: translate(-53%, -45%);
  pointer-events: none;
}

.site-header h1 {
  max-width: 100%;
  margin: 0;
  color: var(--geo-yellow);
  font-family: var(--font-display);
  font-size: clamp(3.1rem, 8.2vw, 6.9rem);
  font-weight: 400;
  letter-spacing: 0;
  line-height: 0.92;
  overflow-wrap: anywhere;
  paint-order: stroke fill;
  -webkit-text-stroke-color: var(--geo-navy);
  -webkit-text-stroke-width: 1.5px;
  text-shadow: none;
  text-transform: uppercase;
}

.detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(220px, 0.9fr);
  gap: clamp(0.5rem, 1vw, 0.85rem);
  align-items: stretch;
}

.info-window {
  align-content: start;
  min-width: 0;
}

.big-code {
  margin: 0;
  color: var(--geo-navy);
  font-family: var(--font-code);
  font-size: clamp(2rem, 5.4vw, 4.6rem);
  font-weight: 400;
  line-height: 1;
  text-align: center;
  text-shadow:
    -2px 0 0 var(--geo-pink),
    2px 0 0 var(--geo-cyan),
    5px 5px 0 #000000;
  text-transform: uppercase;
}

.detail-copy,
.detail-lede,
.web-widget p:not(.big-code),
.site-footer p {
  margin: 0;
  color: var(--geo-ink);
  font-size: clamp(0.82rem, 1.1vw, 0.96rem);
  font-weight: 700;
  line-height: 1.35;
}

.web-widget.counter-widget p {
  margin-top: 0.1rem;
  padding: 0.18rem 0.28rem;
  border: 1px solid rgba(255, 255, 255, 0.82);
  background: rgba(0, 0, 0, 0.68);
  color: #ffffff;
  font-family: var(--font-pixel);
  font-size: clamp(0.58rem, 0.8vw, 0.7rem);
  letter-spacing: 0;
  line-height: 1.25;
  text-shadow: none;
}

.detail-lede {
  font-family: var(--font-pixel);
  color: var(--geo-red);
  text-transform: uppercase;
}

.location-link {
  display: block;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.16em;
}

.location-link:hover {
  color: var(--geo-blue);
}

.party-details-window {
  transform: none;
}

.party-detail-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
}

.party-detail-item {
  min-width: 0;
  display: grid;
  gap: 0.28rem;
  padding: 0.58rem 0.62rem;
  border: 2px dashed var(--geo-navy);
  background:
    linear-gradient(180deg, rgba(255, 246, 191, 0.92), rgba(255, 255, 255, 0.86)),
    var(--geo-paper);
  box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.42);
}

.party-detail-item h3 {
  margin: 0;
  color: var(--geo-red);
  font-family: var(--font-pixel);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.15;
  text-transform: uppercase;
}

.party-detail-item p {
  margin: 0;
  color: var(--geo-ink);
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.32;
}

.survey-window {
  transform: none;
}

.survey-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.62rem;
}

.survey-form label {
  display: grid;
  gap: 0.28rem;
  min-width: 0;
}

.survey-form label span {
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.wide-field,
.submit-button,
.form-status {
  grid-column: 1 / -1;
}

input,
select,
textarea {
  width: 100%;
  min-width: 0;
  border: 2px inset #ffffff;
  border-radius: 0;
  background: #ffffff;
  color: #000000;
  padding: 0.54rem 0.62rem;
  font-size: 1rem;
}

textarea {
  resize: vertical;
}

input:focus,
select:focus,
textarea:focus,
.go-button:focus,
.web-button:focus,
.location-link:focus,
.site-footer a:focus,
.submit-button:focus,
.song-search-button:focus,
.requested-song:focus-within,
.requested-song-vote:focus,
.song-result:focus-within,
.song-add-button:focus,
.song-preview-button:focus,
.selected-song button:focus {
  outline: 3px solid var(--geo-cyan);
  outline-offset: 2px;
}

.song-picker {
  display: grid;
  gap: 0.6rem;
  padding: 0.62rem;
  border: 2px dashed var(--geo-navy);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(238, 246, 255, 0.78)),
    var(--geo-paper-cool);
}

.song-picker-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.6rem;
  align-items: start;
}

.song-picker h3,
.song-picker p {
  margin: 0;
}

.song-picker h3 {
  color: var(--geo-red);
  font-family: var(--font-pixel);
  font-size: clamp(0.9rem, 1.4vw, 1.1rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.15;
  text-transform: uppercase;
}

.song-picker p,
.song-search-status,
.song-empty {
  color: var(--geo-ink);
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.35;
}

.song-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.8rem;
  min-width: 4.5rem;
  padding: 0.2rem 0.42rem;
  border: 2px inset #ffffff;
  background: #000000;
  color: var(--geo-yellow);
  font-family: var(--font-pixel);
  font-size: 0.72rem;
  font-weight: 700;
  text-shadow: 0 0 6px rgba(255, 227, 95, 0.82);
}

.song-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.42rem;
  align-items: end;
}

.song-search-row label {
  min-width: 0;
}

.song-search-button {
  min-height: 2.35rem;
  padding: 0.28rem 0.72rem;
  border: 2px outset #ffffff;
  border-radius: 0;
  background: var(--geo-yellow);
  color: var(--geo-navy);
  cursor: pointer;
  font-family: var(--font-pixel);
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 2px 2px 0 var(--geo-shadow);
}

.song-search-button:active {
  border-style: inset;
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 var(--geo-shadow);
}

.requested-song-panel {
  display: grid;
  gap: 0.38rem;
  border-top: 2px dotted var(--geo-navy);
  padding-top: 0.48rem;
}

.requested-song-header {
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
  align-items: center;
  justify-content: space-between;
}

.requested-song-header h4 {
  margin: 0;
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.15;
  text-transform: uppercase;
}

.requested-song-count {
  display: inline-flex;
  align-items: center;
  min-height: 1.35rem;
  padding: 0.12rem 0.35rem;
  border: 2px outset #ffffff;
  background: var(--geo-yellow);
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
}

.requested-songs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.38rem;
}

.requested-song {
  min-width: 0;
  display: grid;
  grid-template-columns: 2.9rem minmax(0, 1fr);
  gap: 0.28rem 0.42rem;
  align-items: center;
  padding: 0.42rem 0.5rem;
  border: 2px solid var(--geo-navy);
  border-radius: 0;
  background:
    linear-gradient(180deg, #ffffff, #eef6ff);
  color: var(--geo-ink);
  box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.52);
  text-align: left;
}

.requested-song-artwork,
.song-result-artwork,
.selected-song-artwork {
  width: 2.75rem;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border: 2px inset #ffffff;
  background: #000000;
  color: var(--geo-yellow);
  font-family: var(--font-pixel);
  font-size: 0.58rem;
  font-weight: 700;
  overflow: hidden;
  text-shadow: 0 0 6px rgba(255, 227, 95, 0.82);
}

.requested-song-artwork img,
.song-result-artwork img,
.selected-song-artwork img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.requested-song-copy,
.song-result-copy,
.selected-song-copy {
  min-width: 0;
  display: grid;
  gap: 0.12rem;
}

.requested-song strong {
  min-width: 0;
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.78rem;
  line-height: 1.15;
  overflow-wrap: anywhere;
  text-transform: uppercase;
}

.requested-song-meta {
  min-width: 0;
  color: var(--geo-red);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.requested-song-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  gap: 0.32rem;
}

.requested-song-votes {
  display: grid;
  grid-template-columns: repeat(2, 1.78rem);
  gap: 0.32rem;
}

.requested-song-votes:only-child {
  grid-column: 1 / -1;
  justify-self: start;
}

.requested-song-preview-button {
  min-height: 1.78rem;
  width: 100%;
}

.requested-song-vote {
  width: 1.78rem;
  min-height: 1.78rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.52rem;
  border: 2px outset #ffffff;
  border-radius: 0;
  background: #ffffff;
  color: var(--geo-navy);
  cursor: pointer;
  font-family: var(--font-pixel);
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 2px 2px 0 var(--geo-shadow);
}

.requested-song-vote-icon {
  --arrow-fill: #19b86a;
  --arrow-outline: var(--geo-navy);
  width: 0.98rem;
  height: 0.98rem;
  display: inline-block;
  position: relative;
  flex: 0 0 auto;
  image-rendering: pixelated;
}

.requested-song-vote-icon::before,
.requested-song-vote-icon::after {
  content: "";
  position: absolute;
  clip-path: polygon(
    50% 0,
    94% 42%,
    70% 42%,
    70% 100%,
    30% 100%,
    30% 42%,
    6% 42%
  );
}

.requested-song-vote-icon::before {
  inset: 0;
  background: var(--arrow-outline);
}

.requested-song-vote-icon::after {
  inset: 0.11rem;
  background: var(--arrow-fill);
}

.requested-song-vote.is-down .requested-song-vote-icon {
  --arrow-fill: #ed173d;
}

.requested-song-vote-icon.is-down {
  transform: rotate(180deg);
}

.requested-song-vote.is-active .requested-song-vote-icon {
  --arrow-fill: #ffffff;
}

.requested-song-vote.is-up.is-active {
  background: #19b86a;
}

.requested-song-vote.is-down.is-active {
  background: #ed173d;
}

.requested-song-vote:active {
  border-style: inset;
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 var(--geo-shadow);
}

.song-results,
.selected-songs {
  display: grid;
  gap: 0.38rem;
}

.song-results {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.song-result,
.selected-song {
  min-width: 0;
  border: 2px solid var(--geo-navy);
  border-radius: 0;
  background:
    linear-gradient(180deg, #ffffff, #eef6ff);
  color: var(--geo-ink);
  box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.52);
}

.song-result {
  display: grid;
  grid-template-columns: 2.9rem minmax(0, 1fr);
  gap: 0.28rem 0.42rem;
  align-items: center;
  padding: 0.42rem 0.5rem;
  text-align: left;
}

.song-result:hover {
  background:
    linear-gradient(180deg, #fff6bf, #ffffff);
}

.song-result.is-selected,
.song-result.is-requested {
  background:
    linear-gradient(180deg, #f0f0f0, #ffffff);
}

.song-result strong {
  min-width: 0;
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.78rem;
  line-height: 1.15;
  overflow-wrap: anywhere;
  text-transform: uppercase;
}

.song-result-meta,
.song-album {
  min-width: 0;
  color: var(--geo-red);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.song-album {
  color: var(--geo-blue);
  font-size: 0.74rem;
}

.song-result em {
  width: fit-content;
  padding: 0.06rem 0.28rem;
  border: 1px solid var(--geo-navy);
  background: var(--geo-yellow);
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.56rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1.15;
  text-transform: uppercase;
}

.song-result-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.32rem;
}

.song-result-actions.is-single {
  grid-template-columns: 1fr;
}

.song-add-button,
.song-preview-button {
  min-height: 1.78rem;
  border: 2px outset #ffffff;
  border-radius: 0;
  color: var(--geo-navy);
  cursor: pointer;
  font-family: var(--font-pixel);
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 2px 2px 0 var(--geo-shadow);
}

.song-add-button {
  background: var(--geo-yellow);
}

.song-preview-button {
  background: #ffffff;
}

.song-preview-button.is-playing {
  background: var(--geo-cyan);
}

.song-add-button:active,
.song-preview-button:active {
  border-style: inset;
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 var(--geo-shadow);
}

.song-add-button:disabled,
.song-preview-button:disabled {
  cursor: default;
  opacity: 0.58;
  transform: none;
}

.song-preview-player {
  grid-column: 1 / -1;
  width: 100%;
  min-width: 0;
  height: 2.1rem;
}

.song-preview-player[hidden] {
  display: none;
}

.song-results {
  border-top: 2px dotted var(--geo-navy);
  padding-top: 0.48rem;
}

.selected-songs {
  border-top: 2px dotted var(--geo-navy);
  padding-top: 0.48rem;
}

.selected-song {
  display: grid;
  grid-template-columns: 2.9rem minmax(0, 1fr) auto;
  gap: 0.42rem;
  align-items: center;
  padding: 0.38rem 0.45rem;
}

.selected-song-copy strong {
  min-width: 0;
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.78rem;
  line-height: 1.15;
  overflow-wrap: anywhere;
  text-transform: uppercase;
}

.selected-song-copy span {
  min-width: 0;
  font-size: 0.85rem;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.selected-song button {
  min-height: 1.7rem;
  border: 2px outset #ffffff;
  background: var(--geo-yellow);
  color: var(--geo-navy);
  cursor: pointer;
  font-family: var(--font-pixel);
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
}

.song-empty {
  margin: 0;
  padding: 0.42rem 0.5rem;
  border: 2px dotted var(--geo-navy);
  background: #ffffff;
}

.submit-button {
  min-height: 2.8rem;
  border: 2px solid var(--geo-navy);
  background:
    linear-gradient(180deg, #ffef83, #ffb62f 52%, #ff4cad);
  color: var(--geo-navy);
  cursor: pointer;
  font-family: var(--font-pixel);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 3px 3px 0 #000000;
}

.submit-button:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 #000000;
}

.form-status {
  min-height: 1.3rem;
  margin: 0;
  color: var(--geo-red);
  font-family: var(--font-pixel);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.35;
}

.guestbook-entry {
  display: grid;
  gap: 0.24rem;
  padding: 0.48rem 0.55rem;
  border: 2px dashed var(--geo-navy);
  background: #ffffff;
  text-align: center;
}

.guestbook-entry strong {
  color: var(--geo-blue);
  font-family: var(--font-pixel);
  font-size: 0.76rem;
  text-transform: uppercase;
}

.guestbook-entry span,
.guestbook-names {
  color: var(--geo-ink);
  font-weight: 700;
}

.guestbook-names ul {
  display: grid;
  gap: 0.18rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.guestbook-names li {
  color: var(--geo-red);
  font-weight: 700;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.site-footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.6rem;
  margin: clamp(0.45rem, 1vw, 0.8rem);
  padding: 0.72rem 0.82rem;
}

.footer-status {
  font-family: var(--font-pixel);
  font-weight: 700;
}

.site-footer a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.28rem 0.65rem;
  border: 2px outset #ffffff;
  background: var(--geo-yellow);
  color: var(--geo-navy);
  font-family: var(--font-pixel);
  font-size: 0.72rem;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;
  box-shadow: 2px 2px 0 var(--geo-shadow);
}

@media (max-width: 1180px) {
  .side-rail {
    position: static;
    top: auto;
    z-index: auto;
  }

  .homepage-grid {
    grid-template-columns: minmax(0, 1fr) minmax(240px, 0.62fr);
    grid-template-areas:
      "main main"
      "left right";
  }

  .main-window {
    grid-area: main;
  }

  .left-rail {
    grid-area: left;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .right-rail {
    grid-area: right;
  }
}

@media (max-width: 760px) {
  :root {
    --sticky-chrome-offset: 3.7rem;
  }

  body {
    min-width: 0;
  }

  .birthday-site {
    width: 100%;
  }

  .browser-chrome {
    width: 100%;
    min-width: 0;
    font-size: 0.7rem;
  }

  .browser-menubar {
    display: none;
  }

  .homepage-grid,
  .detail-grid,
  .survey-form,
  .site-footer {
    grid-template-columns: 1fr;
  }

  .browser-toolbar {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.32rem;
  }

  .browser-nav {
    display: none;
  }

  .address-label {
    display: none;
  }

  .address-box {
    font-size: 0.7rem;
  }

  .homepage-grid {
    grid-template-areas:
      "main"
      "right"
      "left";
    width: auto;
    margin: 0.52rem 0.44rem 0;
  }

  .left-rail,
  .right-rail {
    grid-template-columns: 1fr;
  }

  .main-window,
  .web-widget,
  .info-window,
  .site-footer {
    box-shadow: 3px 3px 0 var(--geo-shadow);
  }

  .main-window {
    padding: 0.54rem;
  }

  .site-header {
    padding: 0.7rem 0.5rem;
  }

  .requested-songs,
  .party-detail-list,
  .song-results {
    grid-template-columns: 1fr;
  }

  .selected-song {
    grid-template-columns: 2.9rem minmax(0, 1fr);
  }

  .selected-song button {
    grid-column: 2;
    justify-self: start;
  }

  .left-rail .web-widget,
  .right-rail .web-widget {
    transform: none !important;
  }

  .site-header h1 {
    font-size: clamp(1.9rem, 12vw, 3.1rem);
    line-height: 0.96;
    overflow-wrap: normal;
    word-break: keep-all;
  }

  .big-code {
    font-size: clamp(1.8rem, 13vw, 3.1rem);
  }

  .site-footer a {
    justify-self: stretch;
  }
}

@media (max-width: 480px) {
  .browser-title-row,
  .browser-toolbar {
    padding-inline: 0.22rem;
  }

  .window-controls span {
    width: 0.76rem;
    height: 0.76rem;
  }

  .go-button {
    min-width: 2.2rem;
  }

  .marquee {
    margin: 0.44rem 0.44rem 0;
  }

  .marquee-track {
    font-size: 0.62rem;
  }

  .marquee-track span {
    padding-inline: 1.2rem;
  }

  .site-kicker,
  .site-subtitle {
    letter-spacing: 0.12em;
  }

  .site-header h1 {
    font-size: clamp(1.75rem, 10.8vw, 2.65rem);
  }

  .song-picker {
    padding: 0.5rem;
  }

  .song-picker-header {
    grid-template-columns: 1fr;
    gap: 0.42rem;
  }

  .song-count {
    justify-self: start;
  }

  .song-search-row {
    grid-template-columns: 1fr;
  }

  .song-search-button {
    width: 100%;
  }

  .requested-song,
  .song-result {
    grid-template-columns: 2.55rem minmax(0, 1fr);
    padding: 0.36rem 0.4rem;
  }

  .requested-song-artwork,
  .song-result-artwork,
  .selected-song-artwork {
    width: 2.35rem;
  }

  .selected-song {
    grid-template-columns: 2.55rem minmax(0, 1fr);
    gap: 0.34rem;
  }

  .selected-song button {
    width: 100%;
  }

  .site-footer {
    align-items: stretch;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .marquee-track,
  .new-sticker {
    animation: none;
  }
}

@keyframes marquee-scroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translate3d(-25%, 0, 0);
  }
}

@keyframes blink {
  0%,
  49% {
    opacity: 1;
  }

  50%,
  100% {
    opacity: 0.45;
  }
}
