:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-deep:#050403;--bg-panel:#11100d;--bg-panel-2:#15120d;--bg-elevated:#1d160e;--gold:#d4a94e;--gold-bright:#f4e0a9;--gold-soft:#f2dfaf;--gold-dim:#a88d55;--gold-deep:#7a541d;--gold-line:#d4a94e59;--gold-line-soft:#d4a94e38;--parchment-from:#efe0ba;--parchment-to:#cdbb91;--parchment-shadow:#53321040;--ink:#1c160e;--ink-faded:#5b4122;--ink-quill:#43311c;--text-warm:#f4e8ca;--text-soft:#d8c27a;--text-dim:#a88d55;--accent:var(--gold);--dark:#241910;--mid:#6b4a25;--hint-purple:#4a2f5a;--hint-purple-bright:#7a4f8c;--danger:#8b3a2a;--success:#5a6b3a;--font-display:"Cinzel", "IM Fell English", Georgia, serif;--font-body:"Crimson Text", Georgia, serif;--font-hand:"IM Fell English", "Crimson Text", Georgia, serif;--font-mono:"Courier Prime", "Courier New", monospace;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{overscroll-behavior:none;height:100%;margin:0;padding:0}body{font-family:var(--font-body);color:var(--text-warm);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;-webkit-user-select:none;user-select:none;background:radial-gradient(circle at top,#21170e,#050403 65%);font-size:16px;line-height:1.4}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}img,svg{max-width:100%;display:block}.t-display{font-family:var(--font-display);letter-spacing:.04em;font-weight:700}.t-eyebrow{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-size:11px;font-weight:400}.t-mono{font-family:var(--font-mono);letter-spacing:.04em}.t-hand{font-family:var(--font-hand);color:var(--ink)}.app-root{place-items:center;padding:18px;display:grid;position:fixed;inset:0;overflow:hidden}.viewport{border:1px solid var(--gold-line);background:linear-gradient(#120f0b,#070604);border-radius:34px;flex-direction:column;width:min(430px,100%);height:min(920px,100%);min-height:640px;display:flex;position:relative;overflow:hidden;box-shadow:0 30px 80px #000000b8,inset 0 0 0 1px #ffffff0a}@media (width<=460px){.app-root{padding:0}.viewport{border:none;border-radius:0;width:100%;height:100%}}.room-stage{flex-direction:column;flex:1;min-height:0;display:flex}.room-stage .zone-scene{flex:0 0 clamp(220px,38vh,380px);min-height:0}.room-stage .zone-puzzle{flex:auto;min-height:0}.room-stage .zone-narrator{flex:none}@media (height<=720px){.room-stage .zone-scene{flex:0 0 clamp(180px,32vh,280px)}}.topbar{padding:calc(14px + var(--safe-top)) 18px 10px;z-index:5;background:linear-gradient(#000000b8,#0000002e);justify-content:space-between;align-items:center;display:flex;position:relative}.topbar-mid{pointer-events:none;flex-direction:column;align-items:center;display:flex}.topbar-mid .eyebrow{color:var(--accent)}.topbar-mid h1{font-family:var(--font-display);letter-spacing:.04em;color:var(--gold-bright);margin:0;font-size:20px}.icon-button{width:38px;height:38px;color:var(--text-warm);background:#0000005c;border:1px solid #d4a94e66;border-radius:12px;place-items:center;transition:transform .1s,border-color .12s,background .12s;display:grid}.icon-button:hover{border-color:var(--gold);background:#0000008c}.icon-button:active{transform:scale(.94)}.top-actions{gap:8px;display:flex}.zone-scene{border:1px solid var(--gold-line);background:linear-gradient(180deg, #0000000d, #000000bf), radial-gradient(circle at 50% 25%, color-mix(in srgb, var(--mid) 68%, transparent), transparent 32%), linear-gradient(135deg, var(--dark), #080604 70%);border-radius:22px;margin:0 14px 10px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff05}.zone-scene:before{content:"";opacity:.9;filter:blur(.2px);pointer-events:none;background:linear-gradient(90deg,#0000 0 9%,#ffdc8c21 10% 11%,#0000 12% 21%,#ffdc8c14 22% 23%,#0000 24%),radial-gradient(#ffdc8c33,#0000 36%);position:absolute;inset:8% 10% 0}.zone-scene:after{content:"";pointer-events:none;background:radial-gradient(circle at 50% 35%,#ffe6aa26,#0000 21%),linear-gradient(#0000,#0000008c);border:2px solid #d4a94e47;border-bottom:0;border-radius:180px 180px 0 0;height:52%;position:absolute;bottom:0;left:18%;right:18%}.zone-scene[data-room="1"]:after{border-radius:18px 18px 0 0;height:62%;left:26%;right:26%}.zone-scene[data-room="2"]:before{background:radial-gradient(circle at 52% 57%,#ffbe694d,#0000 19%),linear-gradient(90deg,#0000 0 42%,#ffdc8c17 43% 47%,#0000 48%)}.zone-scene[data-room="4"]{filter:saturate(.85)}.zone-scene[data-room="5"]:after{border-radius:14px 14px 0 0;height:70%;left:14%;right:14%}.scene-noise{opacity:.04;mix-blend-mode:screen;pointer-events:none;background-image:radial-gradient(#ffdc8c99 1px,#0000 1px);background-size:4px 4px;position:absolute;inset:0}.candle{pointer-events:none;background:#7c552d;border-radius:8px;width:9px;height:33px;animation:1.4s infinite alternate flicker;position:absolute;bottom:18%;box-shadow:0 0 22px 8px #ffac4347}.candle:before{content:"";filter:drop-shadow(0 0 6px #ffc464d9);background:#ffd36d;border-radius:50% 50% 45% 45%;width:8px;height:15px;position:absolute;top:-13px;left:.5px}.candle.c1{left:18%}.candle.c2{animation-delay:.35s;right:16%}@keyframes flicker{0%{opacity:.7;transform:scaleY(.96)}to{opacity:1;transform:scaleY(1.03)}}.ghost-card{z-index:3;border:1px solid var(--gold-line);-webkit-backdrop-filter:blur(7px);background:#03030394;border-radius:14px;padding:10px 12px;position:absolute;bottom:14px;left:18px;right:18px}.ghost-card span{color:var(--accent);font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;font-size:11px;display:block}.ghost-card strong{font-family:var(--font-display);letter-spacing:.04em;color:var(--gold-bright);margin-top:3px;font-size:15px;font-weight:700;display:block}.scene-silhouette{z-index:2;pointer-events:none;position:absolute;inset:0}.zone-puzzle{border:1px solid var(--gold-line);background:linear-gradient(180deg, var(--parchment-from), var(--parchment-to));color:var(--ink);box-shadow:inset 0 0 22px var(--parchment-shadow), 0 6px 20px #00000059;border-radius:20px;flex-direction:column;margin:0 14px 10px;padding:12px;display:flex;position:relative;overflow-y:auto}.zone-puzzle::-webkit-scrollbar{width:4px}.zone-puzzle::-webkit-scrollbar-thumb{background:var(--ink-faded);border-radius:2px}.puzzle-meta{color:var(--ink-faded);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;justify-content:space-between;gap:8px;margin-bottom:8px;font-size:11px;display:flex}.puzzle-question{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;text-align:center;color:var(--ink-faded);margin:0 0 8px;font-size:11px}.zone-narrator{padding:12px 18px calc(14px + var(--safe-bottom));border-top:1px solid var(--gold-line-soft);background:linear-gradient(#0000002e,#000000a8);position:relative}.narrator-text{min-height:44px;font-size:16px;line-height:1.3;font-family:var(--font-body);color:var(--text-warm);margin:0 0 10px}.narrator-text strong{font-style:normal;font-family:var(--font-mono);letter-spacing:.16em;color:var(--accent);text-transform:uppercase;margin-bottom:4px;font-size:.7rem;font-weight:400;display:block}.action-row{flex-wrap:wrap;align-items:stretch;gap:10px;display:flex}.action-row .btn{flex:auto}.btn{border:1px solid var(--gold-deep);min-height:48px;color:var(--gold-bright);font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;background:linear-gradient(#342312,#15100a);border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:.85rem;font-weight:600;transition:transform .1s,border-color .12s,box-shadow .12s;display:inline-flex;box-shadow:0 8px 18px #00000059}.btn:hover:not(:disabled){border-color:var(--gold);box-shadow:0 8px 22px #00000073,0 0 24px #d4a94e2e}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{border-color:var(--gold);color:var(--gold-bright);background:linear-gradient(#4a3618,#1f1609)}.btn-primary:hover:not(:disabled){background:linear-gradient(#5a4220,#281c0d)}.btn-hint{border-color:var(--hint-purple-bright);color:#e2c8ec;background:linear-gradient(#3a2050,#2a1638)}.btn-ghost{border-color:var(--gold-line);color:var(--text-soft);box-shadow:none;background:#0000005c}.btn-sm{letter-spacing:.12em;border-radius:10px;min-height:38px;padding:6px 14px;font-size:.7rem}.note-tile{color:#24190c;min-height:44px;font-family:var(--font-display);cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;background:linear-gradient(#f5e7c2,#e2d09b);border:1px solid #7b5b2b;border-radius:12px;place-items:center;padding:6px 8px;font-size:1.1rem;font-weight:700;transition:transform .12s,box-shadow .12s;display:grid;box-shadow:inset 0 1px #ffffff73,0 2px 4px #00000059}.note-tile:active{cursor:grabbing}.note-tile.dragging{z-index:100;transform:scale(1.1);box-shadow:inset 0 1px #ffffff8c,0 10px 22px #0000008c,0 0 18px #d4a94e73}.note-tile.placed{cursor:default;color:var(--gold-bright);background:#25190f;border-color:#25190f}.title-screen{padding:60px 24px calc(40px + var(--safe-bottom));text-align:center;z-index:5;background:linear-gradient(#0000 0%,#0009 70%,#000000f2 100%),radial-gradient(at 50% 40%,#2a1a0a 0%,#0a0705 70%);flex-direction:column;flex:1;justify-content:space-between;align-items:center;display:flex;position:relative}.title-screen .logo-mark{font-family:var(--font-display);letter-spacing:.04em;background:linear-gradient(#f4d98c 0%,#c9a35c 50%,#8a6d3b 100%);color:#0000;text-shadow:0 2px 12px #e8c88733;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2.4rem,11vw,4.2rem);font-weight:700;line-height:.95}.title-screen .logo-sub{font-family:var(--font-display);letter-spacing:.4em;color:var(--gold);margin-top:14px;font-size:.7rem}.title-screen .ornament{color:var(--gold-dim);letter-spacing:.5em;margin:16px 0;font-size:.9rem}.title-screen .silhouette{flex:1;place-items:center;width:100%;display:grid}.stars{gap:4px;display:inline-flex}.star{color:#d4a94e40;font-size:1.1rem;line-height:1}.star.filled{color:var(--gold-bright);text-shadow:0 0 8px #e8c88799}.modal-backdrop{-webkit-backdrop-filter:blur(2px);z-index:100;background:#000000b8;place-items:center;padding:18px;display:grid;position:absolute;inset:0}.modal{background:#11100d;border:1px solid #d4a94e73;border-radius:24px;flex-direction:column;width:min(430px,100%);max-height:78vh;display:flex;overflow:hidden;box-shadow:0 30px 80px #000000b3}.modal-header{border-bottom:1px solid var(--gold-line-soft);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.modal-header h2{font-family:var(--font-display);color:var(--gold-bright);letter-spacing:.04em;margin:0;font-size:18px;font-weight:700}.modal-body{flex:1;padding:16px;overflow-y:auto}.notebook{background:linear-gradient(180deg, var(--parchment-from), var(--parchment-to));color:var(--ink);box-shadow:inset 0 0 22px var(--parchment-shadow);border-radius:18px;padding:16px}.notebook article{border-bottom:1px solid #3c230c40;margin-bottom:12px;padding-bottom:12px}.notebook article:last-child{border-bottom:0;margin-bottom:0}.notebook .head{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.notebook h3{font-family:var(--font-display);color:var(--ink);letter-spacing:.04em;margin:0;font-size:.95rem;font-weight:700}.notebook p{font-family:var(--font-hand);color:var(--ink);margin:0;line-height:1.45}.house-map{grid-template-columns:1fr 1fr;gap:10px;display:grid}.house-map button{text-align:left;border:1px solid var(--gold-line);min-height:130px;color:var(--gold-soft);background:linear-gradient(#d4a94e24,#00000059);border-radius:16px;flex-direction:column;padding:0;display:flex;position:relative;overflow:hidden}.house-map button:disabled{opacity:.48;filter:grayscale(.6);cursor:not-allowed}.house-map .card-art{flex:1;position:relative;overflow:hidden}.house-map .card-meta{border-top:1px solid var(--gold-line-soft);background:#000000a6;justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.house-map .card-name{font-family:var(--font-display);letter-spacing:.16em;text-transform:uppercase;color:var(--gold-bright);font-size:.78rem;font-weight:600}.house-map .card-num{font-family:var(--font-mono);color:var(--text-dim);font-size:.65rem}.house-map .lock-overlay{color:var(--gold-dim);background:#0009;place-items:center;display:grid;position:absolute;inset:0}.flourish{text-align:center;color:var(--gold-dim);letter-spacing:.5em;margin:6px 0;font-size:.8rem}.fade-in{animation:.6s ease-out both fadein}@keyframes fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.shake{animation:.38s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-thumb{background:var(--gold-deep);border-radius:3px}.secret-hotspot{cursor:pointer;z-index:4;background:radial-gradient(circle,#e8c887d9 0%,#e8c88759 50%,#0000 75%);border:1px solid #e8c88799;border-radius:50%;place-items:center;width:36px;height:36px;padding:0;transition:transform .12s;animation:2.2s ease-in-out infinite secret-pulse;display:grid;position:absolute}.secret-hotspot:hover{transform:scale(1.12)}.secret-hotspot:active{transform:scale(.92)}.secret-hotspot:before{content:"";pointer-events:none;background:radial-gradient(circle,#e8c88766,#0000 70%);border-radius:50%;position:absolute;inset:-8px}.secret-glyph{font-family:var(--font-display);color:var(--ink);text-shadow:0 0 6px #ffdc8ccc;z-index:1;font-size:.95rem;font-weight:700;position:relative}@keyframes secret-pulse{0%,to{box-shadow:0 0 12px #e8c88766}50%{box-shadow:0 0 28px #e8c887d9}}.fragment-toast{z-index:90;border:1px solid var(--gold);color:var(--gold-bright);text-align:center;pointer-events:none;background:linear-gradient(#2a1c08,#15100a);border-radius:14px;padding:14px 22px;position:absolute;top:32%;left:50%;transform:translate(-50%);box-shadow:0 12px 30px #0009,0 0 30px #e8c88766}.fragment-toast .eyebrow{font-family:var(--font-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:4px;font-size:10px}.fragment-toast .title{font-family:var(--font-display);letter-spacing:.04em;font-size:1.1rem;font-weight:700}.fragment-toast .sub{font-family:var(--font-body);color:var(--text-soft);margin-top:2px;font-size:.85rem;font-style:italic}.fragment-piece{background:linear-gradient(180deg, var(--parchment-from), var(--parchment-to));color:var(--ink);border:1px solid var(--parchment-shadow);cursor:pointer;-webkit-user-select:none;user-select:none;clip-path:polygon(2% 5%,12% 0%,28% 4%,45% 0%,60% 5%,78% 1%,92% 4%,100% 12%,96% 28%,100% 48%,97% 68%,100% 88%,90% 100%,70% 96%,50% 100%,30% 97%,10% 100%,0% 88%,4% 70%,0% 48%,3% 30%,0% 12%);padding:14px 12px 10px;transition:transform .12s,box-shadow .12s;position:relative;box-shadow:inset 0 0 12px #5332102e,0 4px 10px #00000080}.fragment-piece:hover{transform:translateY(-2px)}.fragment-piece.placed{color:var(--gold-bright);border-color:var(--gold);cursor:default;background:linear-gradient(#4a3618,#251808)}.fragment-piece .piece-num{font-family:var(--font-mono);letter-spacing:.16em;color:var(--ink-faded);font-size:.7rem;position:absolute;top:6px;right:8px}.fragment-piece.placed .piece-num{color:var(--gold-soft)}.house-map button.secret-room{border-color:var(--gold);background:linear-gradient(#d4a94e47,#0006);box-shadow:0 0 20px #e8c8874d}
