:root{--bg: #0d0d0f;--surface: #16161a;--surface-2: #1e1e24;--border: #2e2e38;--text: #d4cfc8;--text-muted: #7a7570;--accent: #c8a96e;--exit-color: #6ea8c8;--item-color: #7ec88a;--danger: #c86e6e}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-text-size-adjust:100%;text-size-adjust:100%}body,#root{height:100%}body{background:#0d0d0f;color:#d4cfc8;font-family:Georgia,Times New Roman,serif;font-size:16px;line-height:1.6;overscroll-behavior:none}.game-layout{display:flex;flex-direction:column;min-height:100dvh;min-height:100vh}.game-header{display:flex;align-items:center;padding:.75rem 1.5rem;background:#16161a;border-bottom:1px solid #2e2e38}.game-title{font-size:1.1rem;font-variant:small-caps;letter-spacing:.1em;color:#c8a96e}.game-main{display:flex;flex:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.room-view{flex:3;padding:2rem 2.5rem;border-right:1px solid #2e2e38;animation:fadeIn .3s ease}.room-name{font-size:1.6rem;font-weight:400;color:#c8a96e;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #2e2e38}.room-description{font-size:1rem;line-height:1.75;margin-bottom:2rem;max-width:65ch;white-space:pre-line}.options-list{display:flex;flex-direction:column;gap:.6rem;max-width:480px}.option-btn{min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer;display:block;width:100%;padding:.65rem 1rem;border-radius:4px;border:1px solid transparent;font-family:inherit;font-size:.95rem;text-align:left;transition:background .15s,border-color .15s}.option-btn--exit{background:#1e1e24;border-color:#6ea8c8;color:#6ea8c8}.option-btn--exit:hover{background:#2a4a5e}.option-btn--photo{background:#1e1e24;border-color:#7ec88a;color:#7ec88a}.option-btn--photo:hover:not(:disabled){background:#2a4e33}.option-btn--collected{background:#3a3a3a;border-color:#2e2e38;color:#7a7570;cursor:not-allowed}.option-btn--collected:disabled{background:#3a3a3a;border-color:#2e2e38;color:#7a7570}.sidebar{flex:1;min-width:220px;max-width:300px;display:flex;flex-direction:column;background:#16161a}.inventory-panel{padding:1.5rem 1.25rem 1.25rem;border-bottom:1px solid #2e2e38}.inventory-title{font-size:1rem;font-variant:small-caps;letter-spacing:.08em;color:#c8a96e;margin-bottom:1rem;padding-bottom:.4rem;border-bottom:1px solid #2e2e38}.inventory-empty{color:#7a7570;font-size:.9rem;font-style:italic}.inventory-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.item-badge{padding:.5rem .75rem;background:#1e1e24;border:1px solid #2e2e38;border-radius:4px;display:flex;flex-direction:column;gap:.2rem}.item-badge__name{font-size:.9rem;color:#7ec88a}.item-badge__desc{font-size:.78rem;color:#7a7570;font-style:italic;line-height:1.4}.machine-interface{margin-top:1.5rem;padding:1rem 1.25rem 1.25rem;background:#1a1612;border:1px solid #c89e6e;border-radius:4px;max-width:480px}.machine-title{font-size:1rem;font-variant:small-caps;letter-spacing:.08em;color:#c89e6e;margin-bottom:.75rem}.machine-empty,.machine-instructions{font-size:.9rem;color:#7a7570;margin-bottom:.75rem}.machine-polaroids{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.machine-polaroid{display:flex;align-items:flex-start;gap:.6rem;min-height:44px;padding:.4rem .5rem;border-radius:4px;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.machine-polaroid:hover{background:#c89e6e14}.machine-polaroid input[type=checkbox]{width:1.1rem;height:1.1rem;margin-top:.25rem;accent-color:#c89e6e;cursor:pointer}.machine-polaroid__name{font-size:.92rem;color:#d4cfc8;line-height:1.4}.machine-go{min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer;width:100%;padding:.7rem 1rem;background:#c89e6e;border:1px solid #c89e6e;color:#15110c;border-radius:4px;font-family:inherit;font-size:.95rem;font-weight:700;text-align:center;transition:background .15s,opacity .15s}.machine-go:disabled{opacity:.4;cursor:not-allowed}.machine-go:hover:not(:disabled){background:#d3b28c}.machine-failure{margin-top:1rem;padding:.75rem .9rem;background:#c89e6e0f;border-left:2px solid #c89e6e;font-size:.9rem;font-style:italic;color:#7a7570;line-height:1.5}.map-panel{padding:1.25rem 1.25rem 1.5rem}.map-title{font-size:1rem;font-variant:small-caps;letter-spacing:.08em;color:#c8a96e;margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid #2e2e38}.map-grid{display:grid;grid-template-columns:repeat(3,36px);grid-auto-rows:36px;gap:22px;width:max-content;margin:0 auto;padding:11px}.map-room{position:relative;width:36px;height:36px;border-radius:2px}.map-room--visited{background:#1e1e24;border:1px solid #2e2e38}.map-room--current{background:#c8a96e;border:1px solid #c8a96e}.map-room--unknown{background:transparent;border:1px dashed #2e2e38}.map-edge{position:absolute;background:#2e2e38}.map-edge--down{top:100%;left:50%;width:2px;height:22px;transform:translate(-50%)}.map-edge--right{left:100%;top:50%;height:2px;width:22px;transform:translateY(-50%)}.game-footer{display:flex;justify-content:center;padding:1rem 1.5rem 1.25rem;background:#16161a;border-top:1px solid #2e2e38}.reset-btn{min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer;padding:.6rem 1.5rem;background:#c86e6e;border:1px solid #c86e6e;color:#15110c;border-radius:4px;font-family:inherit;font-size:.95rem;font-weight:700;letter-spacing:.05em;transition:background .15s,transform .05s}.reset-btn:hover{background:#d08484}.reset-btn:active{transform:translateY(1px)}@media (max-width: 640px){.game-main{flex-direction:column}.room-view{border-right:none;border-bottom:1px solid #2e2e38;padding:1.25rem 1rem}.room-name{font-size:1.3rem}.room-description{max-width:100%;font-size:.95rem}.options-list{max-width:100%}.option-btn{font-size:1rem}.sidebar{max-width:100%}.inventory-panel,.map-panel{padding:1rem}.machine-interface{max-width:100%}}
