html, body { margin: 0; padding: 0; min-height: 100%; }
:root { --bg1:#1a1028; --bg2:#2a1639; --bg3:#171b2d; --pink:#ff4fcf; --blue:#4dc8ff; --cyan:#7cf5ff; --cream:#fff2df; --gold:#ffcc57; --text:#f8ecff; --panel:rgba(31,18,45,.78); --panel-border:rgba(255,255,255,.14); }
body {
  font-family: Arial, sans-serif; color: var(--text);
  background-color: var(--bg1);
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255,79,207,.16), transparent 26%),
    radial-gradient(circle at 78% 18%, rgba(77,200,255,.15), transparent 24%),
    radial-gradient(circle at 50% 70%, rgba(255,204,87,.10), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,.03) 0, rgba(255,255,255,0) 100%),
    repeating-linear-gradient(180deg, rgba(255,255,255,.02) 0px, rgba(255,255,255,.02) 2px, rgba(0,0,0,0) 2px, rgba(0,0,0,0) 74px),
    linear-gradient(135deg, var(--bg1), var(--bg2) 55%, var(--bg3));
  background-attachment: fixed;
}
.page-shell { max-width: 1180px; margin: 0 auto; padding: 28px 16px 42px; }
.hero { margin-bottom: 24px; }
.neon-frame {
  position: relative; text-align: center; padding: 24px 20px; border-radius: 28px;
  background: rgba(19,10,30,.72); border: 3px solid rgba(255,255,255,.10);
  box-shadow: 0 0 0 2px rgba(255,79,207,.18), 0 0 22px rgba(255,79,207,.35), 0 0 38px rgba(77,200,255,.18), inset 0 0 22px rgba(255,255,255,.03);
}
.neon-frame::before {
  content:""; position:absolute; inset:12px; border-radius:22px; border:3px solid rgba(77,200,255,.8);
  box-shadow:0 0 14px rgba(77,200,255,.75), 0 0 24px rgba(255,79,207,.45); pointer-events:none;
}
.main-logo {
  width: min(100%, 620px); display:block; margin:0 auto 10px;
  filter: drop-shadow(0 0 8px rgba(255,255,255,.30)) drop-shadow(0 0 14px rgba(255,79,207,.34)) drop-shadow(0 0 20px rgba(77,200,255,.22));
}
.tagline { margin:4px 0 0; font-size:1.1rem; color:#bfefff; text-shadow:0 0 10px rgba(77,200,255,.45); }
.panel {
  background: var(--panel); border: 1px solid var(--panel-border); border-radius: 22px; padding: 22px 18px; margin-bottom: 18px;
  box-shadow: 0 0 18px rgba(255,79,207,.10), 0 10px 28px rgba(0,0,0,.28);
}
h2 {
  display:inline-block; margin:0 0 16px; color:var(--cyan); border-bottom:3px solid var(--pink); padding-bottom:6px;
  text-shadow:0 0 8px rgba(77,200,255,.42), 0 0 10px rgba(255,79,207,.24);
}
h3.subhead, .filter-title { margin:24px 0 14px; color:#ffd9e9; letter-spacing:.03em; text-shadow:0 0 10px rgba(255,79,207,.28); }
.info-box { background: rgba(255,255,255,.05); border-left: 4px solid var(--blue); border-radius: 16px; padding: 16px; box-shadow: inset 0 0 10px rgba(255,255,255,.02); }
.hours-layout { display:grid; grid-template-columns:1.05fr .95fr; gap:18px; align-items:center; }
.open-sign-wrap { text-align:center; }
.open-sign {
  width:min(100%,360px); display:block; margin:0 auto;
  filter: drop-shadow(0 0 8px rgba(255,255,255,.22)) drop-shadow(0 0 16px rgba(255,79,207,.32)) drop-shadow(0 0 20px rgba(77,200,255,.22));
}
.shaws-intro { display:grid; grid-template-columns:.9fr 1.1fr; gap:18px; align-items:center; }
.shaws-copy p, p { margin:8px 0; line-height:1.55; }
.shaws-badge {
  display:inline-flex; flex-direction:column; gap:2px; background:linear-gradient(180deg, rgba(90,27,37,.95), rgba(64,20,28,.95));
  padding:14px 18px 12px; border-radius:18px; border:2px solid rgba(255,255,255,.15); box-shadow: inset 0 0 0 2px rgba(255,255,255,.08), 0 0 14px rgba(255,79,207,.10); margin-bottom:10px;
}
.shaws-script { font-size:2rem; line-height:1; color:#fff0f0; font-style:italic; font-weight:700; }
.shaws-sub { font-size:1.05rem; text-transform:uppercase; letter-spacing:.18em; color:#fff2df; }
.shaws-since { font-size:.9rem; color:#ffced7; letter-spacing:.08em; text-transform:uppercase; }
.shaws-board-photo { width:100%; max-width:520px; display:block; margin:0 auto; border-radius:18px; box-shadow:0 0 16px rgba(77,200,255,.16), 0 10px 28px rgba(0,0,0,.35); }

.freezer {
  position: relative;
  background: linear-gradient(180deg, rgba(13,30,52,.92), rgba(9,18,33,.95));
  border: 2px solid rgba(111, 222, 255, .34);
  border-radius: 18px;
  box-shadow: inset 0 0 18px rgba(255,255,255,.03), 0 0 18px rgba(77,200,255,.10), 0 0 26px rgba(255,79,207,.06);
  padding: 22px 16px 18px;
  margin: 16px 0;
}
.freezer-top {
  height: 12px;
  border-radius: 8px;
  margin: 0 8px 16px;
  background: linear-gradient(90deg, rgba(255,255,255,.25), rgba(255,255,255,.08), rgba(255,255,255,.22));
}
.freezer-label {
  display: inline-block;
  margin: 0 0 14px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: #bfefff;
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.freezer-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}
.tub-card {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 12px 10px 14px;
  min-height: 100%;
  box-shadow: inset 0 0 10px rgba(255,255,255,.02), 0 0 14px rgba(255,255,255,.03);
}
.tub-photo {
  width: 100%;
  max-width: 150px;
  display: block;
  margin: 0 auto 10px;
}
.tub-name {
  font-size: .98rem;
  font-weight: 700;
  color: #fff4fa;
  margin-bottom: 6px;
  text-align: center;
}
.tub-desc {
  font-size: .88rem;
  color: #d5d0db;
  line-height: 1.4;
  text-align: center;
}
.ribbon {
  position: absolute; top: 12px; right: -36px; transform: rotate(35deg);
  background: linear-gradient(180deg, #37d55d, #1ea545); color: #081508;
  font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  padding: 6px 40px; box-shadow: 0 0 10px rgba(55,213,93,.25);
}
.ribbon.sold { background: linear-gradient(180deg, #9b9b9b, #676767); color: #fff; box-shadow: 0 0 10px rgba(255,255,255,.12); }
.sold-out { opacity: .66; }

.warning-box {
  background: rgba(255,204,87,.08); border-left:4px solid #ffcc57; border-radius:14px; padding:14px 16px; margin:22px 0 18px; color:#ffe8b3; box-shadow:0 0 10px rgba(255,204,87,.15);
}
.warning-box p { margin:6px 0; }

.dietary-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.dietary-chip {
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: #fff4fa;
  border: 1px solid rgba(255,255,255,.10);
}

.muted { color:#d0c5da; }
.marquee-board {
  position:relative; background:radial-gradient(circle at center, rgba(255,255,255,.04), rgba(0,0,0,.12)), linear-gradient(180deg, #4b2d12, #2d1b0b);
  border:8px solid #9b6a2d; border-radius:18px; padding:26px 18px 16px; margin:16px 0;
  box-shadow: inset 0 0 0 2px #d8a452, inset 0 0 18px rgba(0,0,0,.40), 0 0 16px rgba(255,204,87,.14);
}
.marquee-board::before { content:""; position:absolute; inset:8px; border-radius:10px; border:2px dashed rgba(255,213,120,.32); pointer-events:none; }
.bulb {
  position:absolute; top:8px; width:10px; height:10px; border-radius:50%; background:#ffd776;
  box-shadow:0 0 6px rgba(255,215,118,.85), 0 0 12px rgba(255,215,118,.55); animation:bulbPulse 2.8s infinite ease-in-out;
}
.bulb-1 { left:24px; animation-delay:0s; } .bulb-2 { left:62px; animation-delay:.25s; } .bulb-3 { left:100px; animation-delay:.55s; } .bulb-4 { left:138px; animation-delay:.85s; }
.bulb-5 { right:138px; animation-delay:1.15s; } .bulb-6 { right:100px; animation-delay:1.45s; } .bulb-7 { right:62px; animation-delay:1.75s; } .bulb-8 { right:24px; animation-delay:2.05s; }
.board-title { font-size:1.3rem; color:var(--cream); text-transform:uppercase; letter-spacing:.08em; margin-bottom:14px; text-shadow:0 0 8px rgba(255,204,87,.35), 0 0 12px rgba(255,204,87,.18); }
.price-row {
  display:flex; justify-content:space-between; gap:18px; padding:12px 0; border-top:1px solid rgba(255,224,165,.18); color:var(--cream); font-family:"Courier New", monospace; text-transform:uppercase; letter-spacing:.04em;
}
.price-row:first-of-type { border-top:none; }
.price-row span:last-child { color:#fff1b4; text-shadow:0 0 8px rgba(255,204,87,.28); }
.board-note { margin-top:6px; font-size:.95rem; }
.footer { text-align:center; color:#d9c7eb; padding:8px 0 0; }
.flicker { animation:neonFlicker 4.8s infinite; } .flicker-soft { animation:softFlicker 5.2s infinite; }
@keyframes neonFlicker {
  0%,18%,22%,53%,57%,100% { opacity:1; filter:drop-shadow(0 0 8px rgba(255,255,255,.30)) drop-shadow(0 0 14px rgba(255,79,207,.34)) drop-shadow(0 0 20px rgba(77,200,255,.22)); }
  19% { opacity:.96; filter:drop-shadow(0 0 6px rgba(255,255,255,.22)) drop-shadow(0 0 10px rgba(255,79,207,.24)) drop-shadow(0 0 14px rgba(77,200,255,.16)); }
  20% { opacity:.84; filter:drop-shadow(0 0 4px rgba(255,255,255,.16)) drop-shadow(0 0 7px rgba(255,79,207,.18)) drop-shadow(0 0 10px rgba(77,200,255,.12)); }
  21%,54%,56% { opacity:1; }
  55% { opacity:.80; filter:drop-shadow(0 0 5px rgba(255,255,255,.18)) drop-shadow(0 0 8px rgba(255,79,207,.20)) drop-shadow(0 0 12px rgba(77,200,255,.13)); }
}
@keyframes softFlicker {
  0%,40%,44%,78%,100% { opacity:1; filter:drop-shadow(0 0 8px rgba(255,255,255,.22)) drop-shadow(0 0 16px rgba(255,79,207,.32)) drop-shadow(0 0 20px rgba(77,200,255,.22)); }
  41% { opacity:.95; }
  42% { opacity:.88; filter:drop-shadow(0 0 5px rgba(255,255,255,.16)) drop-shadow(0 0 11px rgba(255,79,207,.22)) drop-shadow(0 0 14px rgba(77,200,255,.15)); }
  43%,79%,81% { opacity:1; }
  80% { opacity:.90; }
}
@keyframes bulbPulse { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:.66; transform:scale(.92); } }

@media (max-width: 1100px) {
  .freezer-row { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 880px) {
  .shaws-intro { grid-template-columns:1fr; }
  .freezer-row { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width:760px) {
  .hours-layout { grid-template-columns:1fr; }
}
@media (max-width:640px) {
  .page-shell { padding:20px 12px 30px; }
  .neon-frame, .panel, .freezer { border-radius:18px; }
  .freezer-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .price-row { font-size:.95rem; }
}
