*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--night);color:var(--paper);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;overflow:hidden}#square{position:relative;height:100vh;height:100dvh;display:grid;grid-template-rows:auto 1fr auto;background:radial-gradient(ellipse 120% 60% at 50% 118%,rgba(200,71,46,.34) 0%,transparent 58%),radial-gradient(ellipse 80% 50% at 50% 128%,rgba(255,138,60,.28) 0%,transparent 50%),radial-gradient(circle at 18% 22%,rgba(85,119,170,.1) 0%,transparent 45%),linear-gradient(to bottom,var(--night) 0%,var(--night-2) 62%,var(--night-3) 100%)}#square:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:3;background:linear-gradient(to bottom,rgba(20,12,8,.55) 0%,transparent 14%),radial-gradient(ellipse 60% 14% at 50% 0%,rgba(227,169,60,.16) 0%,transparent 70%)}#sky{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.square-header{position:relative;z-index:4;display:flex;align-items:baseline;justify-content:space-between;padding:var(--space-5) var(--space-7);border-bottom:1px solid rgba(227,169,60,.18)}.square-header .title{font-family:var(--font-serif);font-size:2rem;font-weight:700;letter-spacing:.34em;color:var(--gold-bright);text-shadow:0 0 24px rgba(227,169,60,.4)}.square-header .room-label{font-family:var(--font-num);font-size:.95rem;letter-spacing:.12em;color:var(--paper-dim)}.header-right{display:flex;align-items:center;gap:var(--space-5)}.net-status{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-num);font-size:.9rem;letter-spacing:.08em;color:var(--paper-dim)}.net-dot{width:10px;height:10px;border-radius:50%;background:var(--paper-faint);transition:background var(--dur-med) var(--ease-out),box-shadow var(--dur-med) var(--ease-out)}.net-dot.on{background:#6fcf7f;box-shadow:0 0 10px #6fcf7f}.net-dot.lost{background:var(--vermilion);box-shadow:0 0 10px var(--vermilion);animation:net-pulse 1.4s ease-in-out infinite}@keyframes net-pulse{0%,to{opacity:1}50%{opacity:.4}}.square-stage{position:relative;z-index:1;overflow:hidden;padding:var(--space-6) var(--space-8)}.phase{position:absolute;inset:var(--space-6) var(--space-8);display:flex;flex-direction:column;opacity:1;transform:translateY(0);transition:opacity var(--dur-med) var(--ease-out),transform var(--dur-med) var(--ease-out)}.phase.hidden{opacity:0;transform:translateY(14px);pointer-events:none}.phase h2{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:500;letter-spacing:.2em;color:var(--gold);margin:0 0 var(--space-5)}.phase-lobby{align-items:center;justify-content:center;text-align:center}.phase-lobby .hero h1{font-family:var(--font-serif);font-size:var(--text-2xl);font-weight:700;margin:0;color:var(--incense);letter-spacing:.12em;text-shadow:0 0 40px rgba(255,217,138,.35);animation:rise-in var(--dur-slow) var(--ease-out) both}.phase-lobby .hero p{font-size:var(--text-lg);color:var(--paper-dim);margin:var(--space-3) 0 var(--space-6);animation:rise-in var(--dur-slow) var(--ease-out) .12s both}@keyframes rise-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.qr-box{display:inline-block;padding:var(--space-4) var(--space-6);background:var(--paper);color:var(--ink);border-radius:var(--radius-md);box-shadow:var(--glow-gold);animation:rise-in var(--dur-slow) var(--ease-out) .24s both}.qr-url{font-family:var(--font-num);font-size:1.7rem;font-weight:700;letter-spacing:.02em}.qr-cap{margin-top:var(--space-4);color:var(--paper-dim);font-size:var(--text-base)}.seats{margin-top:var(--space-7);display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;max-width:80%}.seat-bubble{padding:var(--space-3) var(--space-5);background:#e3a93c24;border:1.5px solid rgba(227,169,60,.42);border-radius:var(--radius-full);color:var(--gold-bright);font-size:var(--text-base);animation:pop-in var(--dur-med) var(--ease-bounce) both}@keyframes pop-in{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.lantern-wall{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:var(--space-5);align-content:start}.lantern-tile{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-2)}.lantern-bulb{position:relative;width:96px;height:124px;border-radius:48% 48% 44% 44%/40% 40% 50% 50%;background:radial-gradient(ellipse at 50% 58%,var(--c) 0%,rgba(0,0,0,.55) 100%);filter:brightness(.42) saturate(.45);transition:filter var(--dur-rite) var(--ease-out),box-shadow var(--dur-rite) var(--ease-out)}.lantern-bulb:before{content:"";position:absolute;top:-9px;left:50%;transform:translate(-50%);width:38px;height:10px;background:var(--temple-2);border-radius:4px}.lantern-bulb:after{content:"";position:absolute;bottom:-14px;left:50%;transform:translate(-50%);width:3px;height:14px;background:var(--gold-deep)}.lantern-on .lantern-bulb{filter:brightness(1.22) saturate(1.05);box-shadow:0 0 52px var(--c),0 0 104px #e3a93c47;animation:lantern-breathe 3.2s var(--ease-slow) infinite}@keyframes lantern-breathe{0%,to{transform:scale(1);filter:brightness(1.18) saturate(1.05)}50%{transform:scale(1.03);filter:brightness(1.32) saturate(1.1)}}.lantern-name{color:var(--paper-dim);font-size:var(--text-base)}.lantern-on .lantern-name{color:var(--gold-bright)}.cue{text-align:center;color:var(--paper-dim);font-size:var(--text-lg);margin-top:var(--space-4);letter-spacing:.05em}.divination-stage{flex:0 0 200px;border-radius:var(--radius-lg);background:radial-gradient(circle at 50% 100%,rgba(255,138,60,.22) 0%,transparent 62%),radial-gradient(circle at 50% 80%,rgba(227,169,60,.14) 0%,transparent 50%)}.stories{margin-top:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);overflow-y:auto}.story-line{display:grid;grid-template-columns:160px 1fr;gap:var(--space-4);padding:var(--space-3) var(--space-5);background:#e3a93c12;border-left:3px solid var(--gold);border-radius:var(--radius-sm);font-size:var(--text-base);animation:slide-in var(--dur-med) var(--ease-out) both}@keyframes slide-in{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.story-line .who{color:var(--gold-bright);font-weight:600;font-family:var(--font-serif)}.story-line .said{color:var(--paper)}.empty{color:var(--paper-faint);text-align:center;padding:var(--space-7);font-size:var(--text-lg)}.sky-field{flex:1;position:relative;overflow:hidden}.sky-lantern{position:absolute;bottom:0;width:84px;text-align:center;transition:transform var(--dur-rite) cubic-bezier(.33,0,.25,1),opacity var(--dur-rite) ease-out}.sky-lantern .sky-body{width:84px;height:104px;background:radial-gradient(ellipse at 50% 62%,var(--c) 0%,rgba(40,30,60,.85) 100%);border-radius:14px 14px 10px 10px;box-shadow:0 0 36px var(--c),0 -10px 40px #ff8a3c4d;display:flex;flex-direction:column;align-items:center;justify-content:center}.sky-body .sky-name{font-size:.82rem;color:var(--ink);font-weight:700;font-family:var(--font-sans)}.sky-body .sky-blessing{font-size:.72rem;color:var(--ink);margin-top:3px}.sky-lantern.waiting{bottom:3%;opacity:.55}.sky-lantern.flying{transform:translateY(-86vh);opacity:1;animation:sky-sway 5.5s ease-in-out 1.2s infinite alternate}@keyframes sky-sway{0%{margin-left:-12px}to{margin-left:12px}}.sky-lantern:nth-child(1){left:7%}.sky-lantern:nth-child(2){left:18%}.sky-lantern:nth-child(3){left:30%}.sky-lantern:nth-child(4){left:42%}.sky-lantern:nth-child(5){left:54%}.sky-lantern:nth-child(6){left:66%}.sky-lantern:nth-child(7){left:78%}.sky-lantern:nth-child(8){left:90%}.phase-closing{align-items:center;justify-content:center;text-align:center}.phase-closing h1{font-family:var(--font-serif);font-size:var(--text-2xl);color:var(--incense);margin:0 0 var(--space-5);letter-spacing:.1em}.postcard-card{background:var(--paper);color:var(--ink);padding:var(--space-6) var(--space-8);border-radius:var(--radius-lg);box-shadow:var(--glow-gold);min-width:420px;animation:pop-in var(--dur-slow) var(--ease-bounce) both}.postcard-card h3{font-family:var(--font-serif);margin:0 0 var(--space-4);color:var(--temple-2);letter-spacing:.2em;font-size:var(--text-xl)}.postcard-card ul{list-style:none;padding:0;margin:0 0 var(--space-4);font-size:var(--text-lg);text-align:left}.postcard-card li{padding:var(--space-2) 0}.postcard-tag{color:var(--temple);letter-spacing:.16em;font-size:var(--text-base)}.square-footer{position:relative;z-index:4;display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-7);border-top:1px solid rgba(227,169,60,.18);background:#15101f99;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.caregiver-hint{color:var(--paper-faint);font-size:var(--text-sm);font-family:var(--font-num);letter-spacing:.08em}.advance{font-family:var(--font-sans);background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--ink);border:none;padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-size:var(--text-base);font-weight:700;letter-spacing:.18em;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.advance:hover{transform:translateY(-2px);box-shadow:var(--glow-gold)}.advance:active{transform:translateY(0)}.cheer-flash{position:fixed;bottom:12%;left:50%;font-size:4.5rem;pointer-events:none;z-index:99;animation:cheer-fly 1.8s var(--ease-out) forwards}@keyframes cheer-fly{0%{opacity:0;transform:translate(-50%) scale(.6)}18%{opacity:1;transform:translate(-50%,-48px) scale(1.12)}to{opacity:0;transform:translate(-50%,-180px) scale(1)}}@media (max-width: 1024px){.square-header .title{font-size:1.5rem;letter-spacing:.24em}.square-stage{padding:var(--space-5) var(--space-5)}.phase{inset:var(--space-5)}.lantern-wall{grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:var(--space-4)}.lantern-bulb{width:76px;height:100px}.postcard-card{min-width:0;width:100%;padding:var(--space-5)}}
