@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,700;1,500&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=Inter:wght@400;500;600&display=swap";:root{--ink-blue: #0f1420;--ink-blue-deep: #090c14;--wine: #3d0f1a;--wine-deep: #260a12;--brass: #c9a227;--brass-soft: #e6c766;--candle: #ffb347;--parchment: #ece2c9;--parchment-dim: #d8cba8;--ok: #6fae7c;--bad: #b5495b;--shadow-deep: rgba(0, 0, 0, .55)}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%;background:radial-gradient(ellipse at 50% 0%,var(--wine-deep) 0%,var(--ink-blue-deep) 62%,#05060a 100%);color:var(--parchment);font-family:Cormorant Garamond,serif;font-size:19px;overflow-x:hidden}#app{position:relative;z-index:2;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 16px}h1,h2,h3{font-family:Playfair Display,serif;color:var(--brass-soft);letter-spacing:.02em}.atmosphere-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.vignette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 45%,rgba(5,3,8,.75) 100%)}.paper-grain-overlay{position:fixed;top:0;right:0;bottom:0;left:0;filter:url(#paper-grain);mix-blend-mode:overlay;opacity:.5}.lightning-flash{position:fixed;top:0;right:0;bottom:0;left:0;background:#dfe6ff;opacity:0;mix-blend-mode:overlay}.lightning-flash.flash-active{opacity:.55;transition:opacity 60ms ease-out}.candle-wrap{position:fixed;bottom:18px;right:18px;width:44px;height:100px;z-index:3;opacity:.9;filter:drop-shadow(0 0 6px rgba(255,179,71,.5))}.candle-svg{width:100%;height:100%}.candle-flame{animation:flicker 2.6s infinite ease-in-out;transform-origin:20px 22px}.candle-flame-inner{animation:flicker 2.1s infinite ease-in-out reverse;transform-origin:20px 20px}@keyframes flicker{0%,to{transform:scale(1) rotate(0);opacity:1}30%{transform:scale(.94,1.05) rotate(-2deg);opacity:.92}60%{transform:scale(1.05,.96) rotate(2deg);opacity:1}}@media (max-width: 640px){.candle-wrap{width:32px;height:74px}}.scene{position:relative;width:100%;max-width:720px;background:linear-gradient(160deg,#1e1014eb,#0c0e18f0);border:1px solid rgba(201,162,39,.28);border-radius:6px;padding:44px 40px;box-shadow:0 30px 80px var(--shadow-deep),inset 0 0 60px #00000059;animation:scene-in .6s ease both}@keyframes scene-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.paper-texture{position:relative}.paper-texture:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;filter:url(#paper-grain);mix-blend-mode:overlay;opacity:.35;pointer-events:none;border-radius:inherit}@media (max-width: 640px){.scene{padding:30px 22px}}.eyebrow{text-transform:uppercase;letter-spacing:.28em;font-family:Inter,sans-serif;font-size:12px;color:var(--brass);margin:0 0 6px}.title{margin:0 0 18px;font-size:2.4rem}.lede{line-height:1.6;color:var(--parchment-dim);margin-bottom:28px}.error-text{color:var(--bad);font-family:Inter,sans-serif;font-size:14px;margin-bottom:16px}.btn{font-family:Inter,sans-serif;font-size:15px;font-weight:600;border:none;border-radius:4px;padding:13px 22px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:not(:disabled):hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(160deg,var(--brass-soft),var(--brass));color:#241205;box-shadow:0 6px 18px #c9a22740}.btn-secondary{background:transparent;color:var(--brass-soft);border:1px solid rgba(201,162,39,.5)}.btn-small{font-size:13px;padding:8px 14px;background:#c9a22726;color:var(--brass-soft);border:1px solid rgba(201,162,39,.4)}.btn-hint{font-size:13px;padding:9px 16px;background:#6fae7a26;color:var(--ok);border:1px solid rgba(111,174,122,.4)}.landing-actions{display:flex;flex-direction:column;align-items:stretch;gap:18px}.divider{display:flex;align-items:center;text-align:center;color:var(--parchment-dim);font-family:Inter,sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:.15em}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#c9a22740}.divider span{padding:0 14px}.join-form{display:flex;gap:10px}.join-form input,.share-link-input,.code-entry input{font-family:Inter,sans-serif;background:#00000059;border:1px solid rgba(201,162,39,.35);color:var(--parchment);border-radius:4px;padding:12px 14px;font-size:15px;letter-spacing:.08em;flex:1;min-width:0}.join-form input:focus,.code-entry input:focus{outline:none;border-color:var(--brass)}.room-code-label{font-family:Inter,sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:.2em;color:var(--parchment-dim);margin-bottom:4px}.room-code{font-family:Playfair Display,serif;font-size:2.2rem;letter-spacing:.12em;color:var(--brass-soft);margin-bottom:22px}.share-box{background:#00000040;border:1px solid rgba(201,162,39,.2);border-radius:4px;padding:16px;margin-bottom:22px}.share-box p{margin:0 0 10px;font-family:Inter,sans-serif;font-size:13px;color:var(--parchment-dim)}.share-link-row{display:flex;gap:8px}.player-status-list{list-style:none;padding:0;margin:0 0 26px;font-family:Inter,sans-serif;font-size:14px}.player-status-list li{padding:10px 0;border-bottom:1px solid rgba(201,162,39,.15);color:var(--parchment-dim)}.player-status-list li.connected{color:var(--ok)}.intro-scene{text-align:center}.intro-paragraph{font-size:1.35rem;line-height:1.7;color:var(--parchment);min-height:140px;margin-bottom:26px}.intro-dots{display:flex;gap:8px;justify-content:center;margin-top:22px}.dot{width:7px;height:7px;border-radius:50%;background:#c9a2274d}.dot.active{background:var(--brass)}.puzzle-header{display:flex;flex-direction:column;gap:4px;margin-bottom:22px;border-bottom:1px solid rgba(201,162,39,.2);padding-bottom:18px}.puzzle-progress{font-family:Inter,sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--parchment-dim)}.puzzle-title{margin:2px 0 8px;font-size:1.7rem}.role-badge{align-self:flex-start;font-family:Inter,sans-serif;font-size:12px;font-weight:600;padding:5px 12px;border-radius:999px;text-transform:uppercase;letter-spacing:.1em}.role-badge.role-navigator{background:#c9a2272e;color:var(--brass-soft);border:1px solid rgba(201,162,39,.4)}.role-badge.role-solver{background:#6fae7a26;color:var(--ok);border:1px solid rgba(111,174,122,.4)}.navigator-intro,.solver-intro{line-height:1.6;margin-bottom:12px}.solver-task{font-family:Inter,sans-serif;font-size:14px;color:var(--parchment-dim);margin-bottom:22px}.navigator-clue{font-style:italic;font-size:1.25rem;color:var(--brass-soft);border-left:3px solid var(--brass);padding:4px 0 4px 18px;margin:18px 0}.navigator-note{font-family:Inter,sans-serif;font-size:13px;color:var(--parchment-dim);margin-top:24px}.family-tree{width:100%;border-collapse:collapse;font-family:Inter,sans-serif;font-size:13px;margin:18px 0}.family-tree th,.family-tree td{text-align:left;padding:8px 10px;border-bottom:1px solid rgba(201,162,39,.15)}.family-tree th{color:var(--brass-soft);font-weight:600}.hint-panel{margin-top:22px;padding-top:16px;border-top:1px dashed rgba(201,162,39,.25)}.hint-text{font-family:Inter,sans-serif;font-size:14px;color:var(--parchment-dim);background:#6fae7a14;border-radius:4px;padding:10px 12px;margin:0 0 8px}.hint-exhausted{font-family:Inter,sans-serif;font-size:13px;color:var(--parchment-dim);font-style:italic}.solved-transition{text-align:center;padding:70px 40px}.solved-banner{font-family:Playfair Display,serif;font-size:1.8rem;color:var(--brass-soft);margin-bottom:10px}.solved-sub{color:var(--parchment-dim);font-family:Inter,sans-serif;font-size:14px}.puzzle-widget{background:#00000038;border:1px solid rgba(201,162,39,.18);border-radius:6px;padding:22px}.shake{animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.ciphertext{font-family:Inter,monospace;font-size:1.1rem;letter-spacing:.15em;color:var(--brass-soft);word-spacing:.4em;margin-bottom:18px}.shift-label{display:block;font-family:Inter,sans-serif;font-size:13px;color:var(--parchment-dim);margin-bottom:8px}#shift-range{width:100%;margin-bottom:18px;accent-color:var(--brass)}.decoded-text{font-family:Inter,monospace;font-size:1rem;letter-spacing:.1em;color:var(--ok);min-height:26px;margin-bottom:18px}.crest-instructions{font-family:Inter,sans-serif;font-size:13px;color:var(--parchment-dim);margin-bottom:16px}.crest-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}.crest-slot{display:flex;flex-direction:column;align-items:center;gap:6px;background:#0000004d;border:1px solid rgba(201,162,39,.3);border-radius:6px;padding:16px 8px;cursor:pointer;font-family:Inter,sans-serif;color:var(--parchment);transition:border-color .15s ease,transform .15s ease}.crest-slot:hover{transform:translateY(-2px)}.crest-slot.selected{border-color:var(--brass);box-shadow:0 0 0 2px #c9a22759}.crest-icon{font-size:1.8rem}.crest-label{font-size:11px;color:var(--parchment-dim)}.portrait-frame{position:relative;width:100%;max-width:320px;aspect-ratio:1 / 1;margin:0 auto 16px;border-radius:4px;overflow:hidden;border:1px solid rgba(201,162,39,.35)}.portrait-svg{width:100%;height:100%;display:block}.portrait-hotspot{position:absolute;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;border:1px dashed rgba(230,199,102,.5);background:#00000026;color:var(--brass-soft);font-family:Inter,sans-serif;font-weight:700;cursor:pointer}.portrait-hotspot.found{background:#c9a227d9;color:#241205;border-style:solid}.portrait-hint-text{font-family:Inter,sans-serif;font-size:13px;color:var(--parchment-dim);text-align:center;margin-bottom:16px}.code-entry{display:flex;gap:10px;justify-content:center}.code-entry input{max-width:140px;text-align:center}.lock-display{font-family:Inter,monospace;font-size:2rem;letter-spacing:.3em;text-align:center;color:var(--brass-soft);background:#00000059;border-radius:6px;padding:14px;margin-bottom:18px}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.keypad-btn{font-family:Inter,sans-serif;font-size:1.1rem;padding:16px;background:#0000004d;border:1px solid rgba(201,162,39,.3);border-radius:6px;color:var(--parchment);cursor:pointer}.keypad-btn:hover{border-color:var(--brass)}.signal-widget{text-align:center}.signal-lamp{position:relative;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,#2a1c0a,#150d05);border:2px solid rgba(201,162,39,.4);display:inline-flex;align-items:center;justify-content:center;font-size:2rem;cursor:pointer;margin-bottom:18px;user-select:none;-webkit-user-select:none;touch-action:none}.signal-lamp .lamp-glow{position:absolute;top:-14px;right:-14px;bottom:-14px;left:-14px;border-radius:50%;background:radial-gradient(circle,rgba(255,179,71,.55),transparent 70%);opacity:0;transition:opacity .1s ease}.signal-lamp.lamp-active .lamp-glow{opacity:1}.signal-lamp.lamp-active{border-color:var(--candle)}.signal-instructions{font-family:Inter,sans-serif;font-size:13px;color:var(--parchment-dim);margin-bottom:18px}.signal-progress{display:flex;gap:10px;justify-content:center}.signal-dot{width:12px;height:12px;border-radius:50%;background:#c9a22740;border:1px solid rgba(201,162,39,.4)}.signal-dot.dot-ok{background:var(--ok);border-color:var(--ok)}.signal-dot.dot-bad{background:var(--bad);border-color:var(--bad)}.finale-scene{text-align:center}.finale-title{font-size:2rem;margin-bottom:24px}.finale-paragraph{line-height:1.75;font-size:1.15rem;color:var(--parchment);margin-bottom:16px}.finale-signature{margin-top:26px;font-style:italic;color:var(--brass-soft);font-family:Inter,sans-serif;font-size:13px}@media (max-width: 480px){.crest-slots{grid-template-columns:repeat(2,1fr)}.title{font-size:1.9rem}.room-code{font-size:1.7rem}}
