:root{
  --bg0:#0b0720;
  --bg1:#130a3a;
  --ink:#f7f3ff;
  --muted:#d5cdf0;
  --outline:#ff2bd6;
  --outline2:#3dffea;
  --panel:#120a2e;
  --panel2:#0f0826;
  --shadow: rgba(0,0,0,.55);
  --yellow:#ffd800;
  --green:#3dff7a;
  --red:#ff2955;
  --pink:#ff4be3;
  --cyan:#39f2ff;
  --pad: 22px;
  --radius: 18px;
  --radius2: 14px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  color:var(--ink);
  background:
    radial-gradient(1200px 800px at 15% 10%, rgba(255,75,227,.18), transparent 55%),
    radial-gradient(900px 700px at 85% 20%, rgba(57,242,255,.14), transparent 55%),
    radial-gradient(900px 900px at 50% 110%, rgba(61,255,122,.10), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  font-family: "VT323", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  letter-spacing: 0.2px;
  overflow-x:hidden;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior:auto !important; }
}

.wrap{
  position:relative;
  z-index: 2;
  width:min(960px, 100%);
  margin: 0 auto;
  padding: 28px 16px 42px;
}

.panel{
  background: linear-gradient(180deg, rgba(18,10,46,.92), rgba(12,7,28,.92));
  border: 3px solid rgba(255,43,214,.65);
  border-radius: var(--radius);
  box-shadow:
    0 18px 45px var(--shadow),
    0 0 0 2px rgba(57,242,255,.22) inset;
  padding: var(--pad);
  margin: 16px 0;
  position:relative;
}

.panel::after{
  content:"";
  position:absolute;
  inset: 10px;
  border-radius: calc(var(--radius) - 10px);
  border: 2px dashed rgba(61,255,122,.25);
  pointer-events:none;
}

.hero{
  padding: calc(var(--pad) + 2px);
}

.hero-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.badge{
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, rgba(255,216,0,.95), rgba(255,75,227,.55));
  box-shadow: 0 10px 20px rgba(0,0,0,.35);
  border: 2px solid rgba(12,7,28,.55);
  font-size: 22px;
}

.title{
  font-family: "Press Start 2P", system-ui, sans-serif;
  font-size: clamp(22px, 3vw, 34px);
  line-height: 1.25;
  margin: 6px 0 14px;
  padding: 8px 10px; /* ensures no overlap with outline */
  border-radius: 14px;
  background: rgba(0,0,0,.18);
  border: 2px solid rgba(57,242,255,.35);
  box-shadow: 0 0 0 2px rgba(255,43,214,.18) inset;
  text-shadow: 0 2px 0 rgba(0,0,0,.5);
}

.title .matze{
  color: var(--yellow);
  text-shadow:
    0 0 10px rgba(255,216,0,.35),
    0 2px 0 rgba(0,0,0,.55);
}

.lead{
  margin: 0;
  color: var(--muted);
  font-size: 24px;
  line-height: 1.35;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.16);
  border: 2px solid rgba(255,216,0,.22);
}

.section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 12px;
}

h2{
  font-family:"Press Start 2P", system-ui, sans-serif;
  font-size: 16px;
  margin: 0;
  padding: 6px 10px;
  border-radius: 12px;
  border: 2px solid rgba(61,255,122,.32);
  background: rgba(0,0,0,.14);
}

.chip{
  font-size: 18px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 2px solid rgba(57,242,255,.35);
  background: rgba(0,0,0,.14);
}

.btn{
  font-family:"Press Start 2P", system-ui, sans-serif;
  font-size: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 2px solid rgba(255,216,0,.45);
  background: rgba(0,0,0,.25);
  color: var(--ink);
  cursor:pointer;
  box-shadow: 0 10px 18px rgba(0,0,0,.35);
  position:relative;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  user-select:none;
}

.btn:focus-visible{
  outline: 3px solid rgba(61,255,122,.75);
  outline-offset: 2px;
}

.btn:active{ transform: translateY(1px); }

.btn-party{
  border-color: rgba(57,242,255,.75);
  background: linear-gradient(135deg, rgba(57,242,255,.18), rgba(255,43,214,.18));
  color: #ffffff;
  text-shadow: 0 2px 0 rgba(0,0,0,.65);
}

.btn-party .btn-dot{
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #0b0720;
  box-shadow: 0 0 0 3px rgba(255,216,0,.7);
}

body.party-on .btn-party{
  background: linear-gradient(135deg, rgba(255,216,0,.35), rgba(255,43,214,.25));
  border-color: rgba(255,216,0,.80);
}
body.party-on .btn-party .btn-dot{ background: #0b0720; }

.masonry{
  column-count: 3;
  column-gap: 14px;
}

@media (max-width: 860px){
  .masonry{ column-count: 2; }
}
@media (max-width: 520px){
  .masonry{ column-count: 1; }
  :root{ --pad: 18px; }
}

.tile{
  break-inside: avoid;
  margin: 0 0 14px;
  border-radius: var(--radius2);
  overflow:hidden;
  position:relative;
  border: 2px solid rgba(255,43,214,.35);
  box-shadow: 0 14px 26px rgba(0,0,0,.35);
  background: rgba(0,0,0,.12);
}

.tile img{
  display:block;
  width:100%;
  height:auto;
  cursor: zoom-in;
  transform: scale(1.001);
  transition: transform .18s ease, filter .18s ease;
}

.tile:hover img{
  transform: scale(1.03);
  filter: saturate(1.15) contrast(1.05);
}

/* Guestbook */
.toast{
  margin: 10px 0 14px;
  padding: 12px 14px;
  border-radius: 14px;
  font-size: 22px;
  border: 2px solid rgba(255,216,0,.35);
  background: rgba(0,0,0,.18);
}
.toast.ok{ border-color: rgba(61,255,122,.45); }
.toast.fail{ border-color: rgba(255,41,85,.55); }

.gb{ margin-top: 10px; }
.gb-row{ margin: 10px 0 12px; }
.lbl{
  display:block;
  margin: 0 0 6px;
  font-family:"Press Start 2P", system-ui, sans-serif;
  font-size: 12px;
  color: var(--muted);
}
.inp{
  width:100%;
  border-radius: 14px;
  border: 2px solid rgba(57,242,255,.35);
  background: rgba(0,0,0,.20);
  color: var(--ink);
  padding: 12px 12px;
  font-size: 22px;
  line-height: 1.25;
}
.inp:focus{
  outline:none;
  border-color: rgba(61,255,122,.65);
  box-shadow: 0 0 0 3px rgba(61,255,122,.18);
}
.ta{ min-height: 110px; resize: vertical; }

.emoji-bar{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  margin: 10px 0 6px;
}
.emoji{
  border: 2px solid rgba(255,216,0,.25);
  background: rgba(0,0,0,.18);
  border-radius: 14px;
  padding: 8px 10px;
  font-size: 18px;
  cursor:pointer;
  color: var(--ink);
}
.emoji:hover{ transform: translateY(-1px); border-color: rgba(255,216,0,.55); }

.gb-actions{ margin-top: 12px; }

.entries{
  margin-top: 16px;
  display:grid;
  gap: 12px;
}
.entry{
  border-radius: var(--radius2);
  border: 2px solid rgba(61,255,122,.22);
  background: rgba(0,0,0,.14);
  padding: 14px 14px;
}
.entry-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.entry-name{
  font-family:"Press Start 2P", system-ui, sans-serif;
  font-size: 12px;
  color: var(--yellow);
  padding: 4px 8px;
  border-radius: 10px;
  border: 2px solid rgba(255,216,0,.25);
  background: rgba(0,0,0,.12);
}
.entry-ts{ font-size: 18px; color: rgba(213,205,240,.85); }
.entry-msg{ font-size: 22px; line-height: 1.25; color: var(--ink); }

/* Footer */
.foot{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 12px;
  padding-top: 6px;
  opacity: .85;
}
.footline{
  height: 2px;
  width: min(240px, 40vw);
  background: linear-gradient(90deg, transparent, rgba(57,242,255,.8), transparent);
  border-radius: 999px;
}

/* Lightbox */
.lightbox{
  position:fixed;
  inset:0;
  display:none;
  z-index: 20;
}
.lightbox.open{ display:block; }
.lb-backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(4px);
}
.lb-frame{
  position:relative;
  width:min(980px, 96vw);
  height:min(82vh, 720px);
  margin: 7vh auto 0;
  border-radius: 18px;
  border: 3px solid rgba(255,216,0,.35);
  background: linear-gradient(180deg, rgba(18,10,46,.92), rgba(12,7,28,.92));
  box-shadow: 0 22px 60px rgba(0,0,0,.65);
  display:grid;
  grid-template-columns: 56px 1fr 56px;
  grid-template-rows: 56px 1fr 40px;
  overflow:hidden;
}
#lbImg{
  grid-column: 1 / 4;
  grid-row: 1 / 4;
  width:100%;
  height:100%;
  object-fit: contain;
  background: rgba(0,0,0,.25);
}
.lb-btn{
  position:absolute;
  top: 12px;
  border-radius: 14px;
  border: 2px solid rgba(57,242,255,.35);
  background: rgba(0,0,0,.35);
  color: var(--ink);
  padding: 10px 12px;
  cursor:pointer;
  font-family:"Press Start 2P", system-ui, sans-serif;
  font-size: 12px;
}
.lb-close{ right: 12px; }
.lb-prev, .lb-next{
  top: 50%;
  transform: translateY(-50%);
  font-size: 20px;
  padding: 10px 14px;
}
.lb-prev{ left: 12px; }
.lb-next{ right: 12px; }
.lb-count{
  position:absolute;
  left: 12px;
  bottom: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 2px solid rgba(255,43,214,.25);
  background: rgba(0,0,0,.28);
  font-family:"Press Start 2P", system-ui, sans-serif;
  font-size: 11px;
}

/* Party background wash */
#party-bg{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 250ms ease;
  background:
    radial-gradient(700px 520px at 15% 20%, rgba(255,41,85,.20), transparent 60%),
    radial-gradient(700px 520px at 85% 30%, rgba(57,242,255,.18), transparent 62%),
    radial-gradient(760px 620px at 55% 85%, rgba(255,216,0,.16), transparent 65%),
    linear-gradient(90deg, rgba(255,75,227,.10), rgba(61,255,122,.10));
  background-size: 220% 220%;
  mix-blend-mode: screen;
  filter: saturate(1.35);
}
#party-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background: repeating-linear-gradient(
    0deg,
    rgba(0,0,0,0) 0px,
    rgba(0,0,0,0) 6px,
    rgba(0,0,0,.10) 7px
  );
  opacity: .28;
}
body.party-on #party-bg{
  opacity: .95;
  animation: partyGradient 10s ease-in-out infinite;
}
@keyframes partyGradient{
  0%{ background-position: 0% 20%; filter: saturate(1.25) hue-rotate(0deg); }
  50%{ background-position: 100% 80%; filter: saturate(1.5) hue-rotate(18deg); }
  100%{ background-position: 0% 20%; filter: saturate(1.25) hue-rotate(0deg); }
}

/* Overlays */
#ghost-overlay, #confetti-overlay{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index: 12;
}
#confetti-overlay{ z-index: 13; }

.ghost{
  position:absolute;
  width: 52px;
  height: 52px;
  filter: drop-shadow(0 10px 14px rgba(0,0,0,.35));
  opacity: .96;
  animation: ghostFloat 2.2s ease-in-out infinite;
  will-change: transform, opacity;
}
.ghost svg{
  width:100%;
  height:100%;
  display:block;
  overflow: visible;
}
.ghost .shape{
  fill: var(--c);
  stroke: rgba(255,255,255,.22);
  stroke-width: 3.2;
  vector-effect: non-scaling-stroke;
}
.ghost .eye{
  fill: #ffffff;
}
.ghost .pupil{
  fill: #0b2a6a;
  transform-box: fill-box;
  transform-origin: center;
}
.ghost .pupil.l{ transform: translate(var(--plx, 0px), var(--ply, 0px)); }
.ghost .pupil.r{ transform: translate(var(--prx, 0px), var(--pry, 0px)); }

@keyframes ghostFloat{
  0%,100%{ transform: translateY(0) rotate(-2deg); }
  50%{ transform: translateY(-7px) rotate(2deg); }
}


.confetti{
  position:absolute;
  width: 6px;
  height: 10px;
  border-radius: 2px;
  background: var(--cc);
  opacity: .95;
  animation: confettiFall 900ms ease-out forwards;
  transform: translate(-50%, -50%) rotate(var(--r));
}
@keyframes confettiFall{
  0%{ transform: translate(-50%, -50%) rotate(var(--r)) scale(1); opacity: .95; }
  100%{ transform: translate(calc(-50% + var(--dx)), calc(-50% + var(--dy))) rotate(calc(var(--r) + 240deg)) scale(.9); opacity: 0; }
}

/* Pacman runner (background) */
#pacman-runner{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index: 1;
  opacity: .28;
  mix-blend-mode: screen;
}

.pacman{
  position:absolute;
  left: -80px;
  top: 40%;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: var(--yellow);
  box-shadow: 0 0 22px rgba(255,216,0,.25);
  animation: pacMove 6.5s linear infinite;
}

/* Mouth cutout */
.pacman::before{
  content:"";
  position:absolute;
  inset: -6px;
  background: radial-gradient(circle at center, transparent 0 0);
  border-radius: 50%;
  clip-path: polygon(50% 50%, 120% 20%, 120% 80%); /* wedge */
  background: rgba(11,7,32,.95);
  animation: pacChomp 320ms ease-in-out infinite;
}

.pacman::after{
  content:"";
  position:absolute;
  top: 16px;
  left: 30px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(0,0,0,.65);
}

@keyframes pacMove{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(calc(100vw + 180px)); }
}
@keyframes pacChomp{
  0%,100%{ clip-path: polygon(50% 50%, 120% 25%, 120% 75%); }
  50%{ clip-path: polygon(50% 50%, 120% 45%, 120% 55%); }
}
