:root{--breakpoint-xs:320px;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--font-size-xs:clamp(0.75rem,1.5vw,0.875rem);--font-size-sm:clamp(0.875rem,1.8vw,1rem);--font-size-base:clamp(1rem,2vw,1.125rem);--font-size-lg:clamp(1.125rem,2.5vw,1.25rem);--font-size-xl:clamp(1.25rem,3vw,1.5rem);--font-size-2xl:clamp(1.5rem,3.5vw,2rem);--font-size-3xl:clamp(1.875rem,4vw,2.5rem);--container-padding:clamp(1rem,3vw,2rem);--touch-target-min:44px;--z-index-dropdown:1000;--z-index-sticky:1020;--z-index-fixed:1030;--z-index-modal-backdrop:1040;--z-index-modal:1050;--z-index-popover:1060;--z-index-tooltip:1070;--safe-area-inset-top:env(safe-area-inset-top);--safe-area-inset-right:env(safe-area-inset-right);--safe-area-inset-bottom:env(safe-area-inset-bottom);--safe-area-inset-left:env(safe-area-inset-left)}.responsive-container{box-sizing:border-box;margin:0 auto;max-width:1200px;max-width:var(--container-max-width,1200px);padding:0 clamp(1rem,3vw,2rem);padding:0 var(--container-padding);width:100%}.responsive-grid{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:1fr}@media (min-width:768px){.responsive-grid{gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.responsive-grid{gap:2rem;gap:var(--spacing-xl)}.responsive-grid.game-layout{grid-template-columns:70% 30%}}.mobile-only{display:block}.desktop-only,.tablet-up{display:none}@media (min-width:768px){.mobile-only{display:none}.tablet-up{display:block}}@media (min-width:1024px){.desktop-only{display:block}}.touch-target{align-items:center;display:inline-flex;justify-content:center;min-height:44px;min-height:var(--touch-target-min);min-width:44px;min-width:var(--touch-target-min)}.responsive-text{font-size:clamp(1rem,2vw,1.125rem);font-size:var(--font-size-base);line-height:1.5}.responsive-heading-1{font-size:clamp(1.875rem,4vw,2.5rem);font-size:var(--font-size-3xl);line-height:1.2}.responsive-heading-2{font-size:clamp(1.5rem,3.5vw,2rem);font-size:var(--font-size-2xl);line-height:1.3}.responsive-heading-3{font-size:clamp(1.25rem,3vw,1.5rem);font-size:var(--font-size-xl);line-height:1.4}.safe-area-padding{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);padding:var(--safe-area-inset-top) var(--safe-area-inset-right) var(--safe-area-inset-bottom) var(--safe-area-inset-left)}.safe-area-padding-bottom{padding-bottom:env(safe-area-inset-bottom);padding-bottom:var(--safe-area-inset-bottom)}.responsive-image{display:block;height:auto;max-width:100%}@media (min-width:576px){:root{--container-padding:1.5rem}}@media (min-width:768px){:root{--container-padding:2rem}}@media (min-width:1200px){:root{--container-padding:2.5rem}}body,html{overflow-x:hidden;width:100%}.full-height{height:100vh;height:100dvh;min-height:-webkit-fill-available}.hide-mobile{display:none!important}.hide-desktop,.hide-tablet{display:inline;display:initial}@media (min-width:768px){.hide-mobile{display:inline!important;display:initial!important}.hide-tablet{display:none!important}}@media (min-width:1024px){.hide-desktop{display:none!important}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background-color:#1a1a1a;color:#fff;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;min-height:-webkit-fill-available;overflow:hidden;position:relative;text-align:center}.App-main{align-items:center;display:flex;flex:1 1;justify-content:center;max-width:1200px;overflow-y:auto;padding:var(--container-padding);padding-bottom:calc(var(--container-padding) + var(--safe-area-inset-bottom))}.App-main,.game-initializer{box-sizing:border-box;margin:0 auto;width:100%}.game-initializer{background-color:#2a2a2a;border:1px solid hsla(0,0%,100%,.1);border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.3);max-width:600px;padding:var(--spacing-lg)}@media (min-width:768px){.game-initializer{padding:var(--spacing-xl)}}.game-initializer h2{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#4caf50,#45a049);-webkit-background-clip:text;background-clip:text;font-size:var(--font-size-2xl);margin-bottom:var(--spacing-lg);text-align:center}.game-initializer>p{color:#e2e8f0;font-size:var(--font-size-base);line-height:1.5;margin-bottom:var(--spacing-md);text-align:center}.game-initializer ul{background-color:rgba(74,222,128,.05);border:1px solid rgba(74,222,128,.2);border-radius:12px;list-style:none;margin:0 0 var(--spacing-lg) 0;padding:0;padding:var(--spacing-md)}@media (min-width:768px){.game-initializer ul{padding:var(--spacing-lg)}}.game-initializer ul li{color:#e2e8f0;font-size:var(--font-size-sm);line-height:1.4;margin-bottom:var(--spacing-sm);padding-left:25px;position:relative;transition:transform .2s ease}@media (min-width:768px){.game-initializer ul li{margin-bottom:var(--spacing-md)}}.game-initializer ul li:last-child{margin-bottom:0}.game-initializer ul li:before{content:"";font-size:1.2rem;left:0;line-height:1;position:absolute;top:50%;transform:translateY(-50%)}.game-initializer ul li:hover{color:#4ade80;transform:translateX(5px)}.primer-input{margin:clamp(15px,2vw,20px) 0;text-align:left}.primer-input label{color:#94a3b8;display:block;font-size:clamp(.85rem,1.5vw,.95rem);font-weight:500;letter-spacing:.05em;margin-bottom:clamp(6px,1vw,8px);text-transform:uppercase}.primer-input input{-webkit-appearance:none;appearance:none;background-color:rgba(51,51,51,.8);border:2px solid transparent;border-radius:8px;box-sizing:border-box;color:#fff;font-size:var(--font-size-base);min-height:var(--touch-target-min);outline:none;padding:var(--spacing-md) var(--spacing-md);transition:all .3s ease;width:100%}.primer-input input:focus{background-color:#333;border-color:#4caf50;box-shadow:0 0 0 3px rgba(76,175,80,.2)}.primer-input input:valid{border-color:rgba(76,175,80,.3)}.examples{background-color:rgba(148,163,184,.05);border:1px solid rgba(148,163,184,.1);border-radius:12px;margin-top:clamp(15px,2vw,20px);padding:clamp(12px,2vw,16px)}.examples h3{color:#94a3b8;font-size:clamp(.75rem,1.4vw,.85rem);font-weight:600;letter-spacing:.05em;margin:0 0 clamp(8px,1vw,10px);text-transform:uppercase}.examples ul{list-style:none;margin:0;padding:0}.examples li{background-color:hsla(0,0%,100%,.03);border-radius:6px;color:#64748b;cursor:pointer;font-family:Courier New,monospace;font-size:clamp(.85rem,1.5vw,.95rem);margin:clamp(6px,1vw,8px) 0;padding:clamp(8px,1.5vw,10px) clamp(12px,2vw,15px);transition:all .2s ease}.examples li:hover{background-color:rgba(76,175,80,.1);color:#4ade80;transform:translateX(3px)}.game-interface{margin:0 auto;max-width:1200px}.game-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.primer-display{color:#aaa}.game-content{display:flex;flex-direction:column;gap:var(--spacing-md);height:100%;min-height:calc(100vh - 120px);min-height:calc(100dvh - 120px)}@media (min-width:1024px){.game-content{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:70% 30%}}.scene-image{align-items:center;background-color:#2a2a2a;border-radius:8px;display:flex;height:100%;justify-content:center;min-height:300px;overflow:hidden;position:relative}@media (max-width:1023px){.scene-image{border-radius:8px;cursor:pointer}}.image-container{align-items:center;box-sizing:border-box;display:flex;height:100%;justify-content:center;padding:20px;position:relative;width:100%}@media (max-width:1023px){.image-container{cursor:pointer;padding:10px}}.tap-hint{background:rgba(0,0,0,.7);border-radius:4px;bottom:10px;color:#fff;font-size:.875rem;opacity:.8;padding:5px 10px;pointer-events:none;position:absolute;right:10px}.scene-img{border-radius:8px;display:block;height:auto;max-height:100%;max-width:100%;object-fit:contain;touch-action:pinch-zoom;width:auto}@media (max-width:768px){.scene-img{border-radius:0}}.image-placeholder{align-items:center;background-color:#333;color:#aaa;display:flex;flex-direction:column;height:100%;justify-content:center;padding:var(--spacing-lg);text-align:center;width:100%}@media (max-width:768px){.image-placeholder{padding:var(--spacing-md)}}.image-placeholder p{font-size:18px;margin:0 0 10px}.image-placeholder small{font-size:14px;line-height:1.4}.history-image{border-radius:8px;margin:10px 0;max-width:300px;overflow:hidden}.history-scene-img{border-radius:8px;display:block;height:auto;width:100%}.game-over{border:2px solid;border-radius:8px;margin:20px 0;padding:20px;text-align:center}.game-over h3{font-size:1.5rem;margin:0 0 10px}.game-over p{margin:10px 0}.game-over.quest_complete{background-color:#2d5a2d;border-color:#4caf50}.game-over.quest_complete h3{color:#4caf50}.game-over.player_death{background-color:#5a2d2d;border-color:#f44}.game-over.player_death h3{color:#ff6b6b}.game-over.quest_failed{background-color:#5a4d2d;border-color:#f94}.game-over.quest_failed h3{color:#fa6}.history-scene-img,.scene-img{transition:opacity .3s ease-in-out}.history-scene-img:not([src]),.scene-img:not([src]){opacity:0}.history-scene-img[style*="display: none"]:before,.scene-img[style*="display: none"]+.image-caption:before{background-color:#444;border-radius:8px;color:#aaa;content:"⚠️ Image failed to load";display:block;padding:20px;text-align:center}.game-chat{background-color:#2a2a2a;border-radius:8px;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:0;position:relative}@media (max-width:1023px){.game-chat{border-radius:0}}.chat-messages{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto;padding:var(--spacing-lg);scroll-behavior:smooth}@media (max-width:768px){.chat-messages{padding:var(--spacing-md)}}.chat-message{word-wrap:break-word;border-radius:8px;line-height:1.5;overflow-wrap:break-word;padding:10px 15px;white-space:pre-wrap}.chat-message.action{align-self:flex-end;background-color:#1a3a1a;color:#4caf50;max-width:80%}.chat-message.response{align-self:flex-start;background-color:#333;color:#fff;max-width:95%}.message-prefix{font-weight:700}.inventory-bar{background-color:#333;border-top:1px solid #444;color:#aaa;font-size:14px;padding:10px 20px}.action-form{background-color:#1a1a1a;border-top:1px solid #444;display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + var(--safe-area-inset-bottom))}@media (max-width:1023px){.action-form{bottom:0;box-shadow:0 -2px 10px rgba(0,0,0,.3);position:-webkit-sticky;position:sticky;z-index:var(--z-index-sticky)}}.action-form input{-webkit-appearance:none;appearance:none;background-color:#333;border:1px solid #444;border-radius:4px;flex:1 1;font-size:16px;padding:var(--spacing-md)}.action-form input,button{color:#fff;min-height:var(--touch-target-min)}button{-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:8px;box-shadow:0 4px 15px rgba(76,175,80,.3);cursor:pointer;font-size:var(--font-size-base);font-weight:600;letter-spacing:.5px;padding:var(--spacing-sm) var(--spacing-lg);text-transform:capitalize;touch-action:manipulation;transition:all .3s ease}button:hover{background:linear-gradient(135deg,#5cbf60,#4fa94f);box-shadow:0 6px 20px rgba(76,175,80,.4);transform:translateY(-2px)}button:active{box-shadow:0 2px 10px rgba(76,175,80,.3);transform:translateY(0)}button:disabled{background:#475569;box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.error-message{align-items:center;background-color:hsla(0,91%,71%,.1);border:1px solid hsla(0,91%,71%,.2);border-radius:8px;color:#f87171;display:flex;font-size:.95rem;gap:10px;margin:20px 0;padding:16px 20px}.error-message:before{content:"⚠️";font-size:1.2rem}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#4caf50;height:40px;margin:20px auto;width:40px}@media (max-width:1023px){.scene-image{max-height:40vh;min-height:250px}.game-chat{flex:1 1;min-height:0}.game-interface{display:flex;flex-direction:column;height:100%}.game-header{background-color:#1a1a1a;border-bottom:1px solid #333;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-index-sticky)}.game-header h2{font-size:var(--font-size-xl);margin:0;width:100%}.tab-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.game-chat,.scene-image{height:100%}.chat-message{max-width:100%!important}}@media (max-width:480px){.App-main{padding:10px}.game-initializer{padding:15px}.game-initializer h2{font-size:1.75rem;margin-bottom:20px}.game-initializer>p{font-size:.95rem}.game-initializer ul{padding:15px}.game-initializer ul li{font-size:.9rem;margin-bottom:10px}.primer-input input{font-size:14px;padding:10px 12px}button{font-size:14px;padding:12px 20px}.examples{margin-top:15px;padding:15px}.examples li{font-size:.85rem;padding:8px 12px}}.fullscreen-overlay{animation:fadeIn .3s ease;background:rgba(0,0,0,.95);bottom:0;cursor:pointer;left:0;padding:var(--safe-area-inset-top) var(--safe-area-inset-right) var(--safe-area-inset-bottom) var(--safe-area-inset-left);position:fixed;right:0;top:0;z-index:var(--z-index-modal)}.fullscreen-image-container,.fullscreen-overlay{align-items:center;display:flex;justify-content:center}.fullscreen-image-container{max-height:100%;max-width:100%;position:relative}.fullscreen-img{height:auto;max-height:100%;max-width:100%;object-fit:contain;touch-action:pinch-zoom;width:auto}.close-fullscreen{align-items:center;background:rgba(0,0,0,.7);border:2px solid #fff;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:28px;height:44px;justify-content:center;line-height:1;padding:0;position:absolute;right:10px;top:10px;transition:all .2s ease;width:44px}.close-fullscreen:hover{background:rgba(0,0,0,.9);transform:scale(1.1)}@media (max-height:700px){.game-initializer{padding:15px 20px}.game-initializer h2{font-size:1.5rem;margin-bottom:10px}.game-initializer>p{font-size:.9rem;margin-bottom:10px}.game-initializer ul{margin-bottom:10px;padding:10px}.game-initializer ul li{font-size:.85rem;margin-bottom:6px}.primer-input{margin:8px 0}.primer-input input{padding:8px 12px}.examples{margin-top:10px;padding:10px}.connecting-message{margin-bottom:10px;padding:10px 15px}}.loading-container{background-color:#333;border-radius:8px;margin:clamp(15px,2vw,20px) 0;padding:clamp(15px,2vw,20px);text-align:center}.loading-spinner{animation:spin 2s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#4caf50;height:clamp(40px,6vw,50px);margin:0 auto clamp(15px,2vw,20px);width:clamp(40px,6vw,50px)}.loading-steps{margin:0 auto;max-width:400px;text-align:left}.loading-step{animation:fadeIn .5s ease-in-out forwards;color:#4caf50;font-size:16px;opacity:0;padding:8px 0}.loading-step:first-child{animation-delay:0s}.loading-step:nth-child(2){animation-delay:.5s}.loading-step:nth-child(3){animation-delay:1s}.loading-step:nth-child(4){animation-delay:1.5s}.loading-step:nth-child(5){animation-delay:2s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-message{color:#aaa;font-style:italic;margin:20px 0}.loading{background-color:#333;border-radius:4px;color:#4caf50;font-style:italic;margin:10px 0;padding:10px;text-align:center}.connection-status{align-items:center;color:#888;display:flex;font-size:.9em;gap:8px}.status-indicator{border-radius:50%;display:inline-block;height:8px;width:8px}.status-indicator.connected{background-color:#48bb78;box-shadow:0 0 4px #48bb78}.status-indicator.disconnected{background-color:#e53e3e;box-shadow:0 0 4px #e53e3e}.connecting-message{align-items:center;animation:pulse-glow 2s ease-in-out infinite;background:linear-gradient(135deg,hsla(38,93%,77%,.1),rgba(251,191,36,.1));border:1px solid rgba(251,191,36,.3);border-radius:8px;color:#fbbf24;display:flex;font-size:clamp(.9rem,1.8vw,1rem);font-weight:500;gap:clamp(8px,1.5vw,12px);margin-bottom:clamp(16px,3vw,24px);padding:clamp(12px,2vw,16px) clamp(16px,3vw,20px)}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px rgba(251,191,36,.2)}50%{box-shadow:0 0 20px rgba(251,191,36,.4)}}.connecting-icon{animation:pulse 1.5s ease-in-out infinite;font-size:1.2em}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.progress-message{align-items:center;background-color:#2d3748;border-radius:6px;color:#a0aec0;display:flex;gap:12px;margin:10px 0;padding:12px}.progress-message .spinner{animation:spin .8s linear infinite;border:2px solid #4a5568;border-radius:50%;border-top-color:#4299e1;height:20px;width:20px}.active-games-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:hsla(0,0%,100%,.08);border:1px solid rgba(139,92,246,.3);border-radius:12px;margin-bottom:2rem;padding:1.5rem}.active-games-panel h3{color:#e9d5ff;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.games-list{display:flex;flex-direction:column;gap:.75rem}.game-item{align-items:center;background:hsla(0,0%,100%,.05);border:1px solid rgba(139,92,246,.2);border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:1rem;transition:all .2s ease}.game-item:hover{background:rgba(139,92,246,.1);border-color:rgba(139,92,246,.4);box-shadow:0 4px 12px rgba(139,92,246,.2);transform:translateY(-2px)}.game-info{flex:1 1}.game-primers{color:#f3e8ff;font-size:1.1rem;font-weight:500;margin-bottom:.5rem;text-transform:capitalize}.game-meta{color:hsla(0,0%,100%,.6);display:flex;font-size:.875rem;gap:1rem}.delete-game,.game-created,.game-time{align-items:center;display:flex}.delete-game{background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#fca5a5;cursor:pointer;flex-shrink:0;font-size:1.5rem;height:32px;justify-content:center;line-height:1;transition:all .2s ease;width:32px}.delete-game:hover{background:rgba(239,68,68,.3);border-color:rgba(239,68,68,.5);color:#fff}@media (max-width:768px){.active-games-panel{padding:1rem}.game-meta{flex-direction:column;gap:.25rem}.game-primers{font-size:1rem}}
/*# sourceMappingURL=main.609b22ae.css.map*/