:root{font-family:Georgia,serif;line-height:1.6;font-weight:400;color-scheme:dark;color:#dcdcdce6;background-color:#0a0a0a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-image:url(../background.png);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-width:320px;min-height:100vh;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;overflow:hidden;background-image:url(../background.png);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;padding-top:1.5rem;padding-left:1rem;padding-right:1rem;font-family:Georgia,serif;color:#f0f0f0f2;background-color:#050505;text-shadow:0 1px 2px rgba(0,0,0,.5)}#game-screen{width:100%;display:flex;justify-content:center;align-items:center;height:100vh;overflow:hidden}#game-screen[style*="display: block"]{display:flex!important}#game-screen.gameover{animation:gameover-fade 2s ease-in-out}#game-screen.gameover .scene-description{color:#ff4d4d;text-shadow:0 0 10px rgba(255,0,0,.5);animation:gameover-pulse 1.5s infinite}#game-screen.gameover .choice-button{background:linear-gradient(135deg,#64141466,#3c0a0a4d);border-color:#b4282880}#game-screen.gameover .choice-button:hover:not(:disabled){background:linear-gradient(135deg,#8c1e1e80,#5a141466);border-color:#dc3c3cb3}#game-screen.gameclear{animation:gameclear-fade 2s ease-in-out}#game-screen.gameclear .scene-description{color:#4dff4d;text-shadow:0 0 10px rgba(0,255,0,.5);animation:gameclear-pulse 1.5s infinite}#game-screen.gameclear .choice-button{background:linear-gradient(135deg,#14641466,#0a3c0a4d);border-color:#28b42880}#game-screen.gameclear .choice-button:hover:not(:disabled){background:linear-gradient(135deg,#1e8c1e80,#145a1466);border-color:#3cdc3cb3}@keyframes gameover-fade{0%{background-color:#0a050ffa}to{background-color:#28050ffa}}@keyframes gameover-pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}@keyframes gameclear-fade{0%{background-color:#0a050ffa}to{background-color:#052805fa}}@keyframes gameclear-pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}h1{font-size:3.2em;line-height:1.1}#app{max-width:900px;margin:0 auto;padding:1rem;min-height:100vh;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:hidden}.game-container{display:flex;flex-direction:column;height:85vh;max-height:85vh;background:linear-gradient(135deg,#0a050ffa,#140a19f2);border-radius:8px;border:1px solid rgba(80,60,120,.3);overflow:hidden;box-shadow:0 4px 12px #00000040;width:100%;max-width:900px;margin-top:1rem}.game-header{background:linear-gradient(90deg,#503c7826,#281e461a);padding:1rem 1.5rem;border-bottom:2px solid rgba(80,60,120,.4);display:flex;justify-content:space-between;align-items:center}.header-controls{display:flex;gap:1rem;align-items:center}.switch-container{display:flex;align-items:center;gap:.5rem}.switch-label{font-size:.9rem;color:#dcc8f0f2}.switch{position:relative;display:inline-block;width:50px;height:24px;background-color:#783c78b3;border-radius:12px;cursor:pointer;transition:background-color .3s ease;box-shadow:inset 0 1px 2px #0003}.switch.on{background-color:#3cb478b3}.switch-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#dcc8f0f2;border-radius:50%;transition:transform .3s ease;box-shadow:0 1px 2px #0003}.switch.on .switch-slider{transform:translate(26px)}.game-header h1{margin:0;font-size:2rem;background:linear-gradient(90deg,#d11f81,#ac22ce);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.5),0 0 10px rgba(225,29,72,.2),0 0 20px rgba(126,34,206,.15);letter-spacing:1px;font-weight:800;line-height:1.1;font-family:Georgia,serif;position:relative;filter:drop-shadow(0 0 3px rgba(0,0,0,.5))}.log-toggle-btn{background:linear-gradient(135deg,#503c7866,#32285a4d);color:#dcc8f0f2;border:1px solid rgba(80,60,120,.5);border-radius:6px;padding:.5rem 1rem;cursor:pointer;transition:all .3s ease;font-size:.9rem}.log-toggle-btn:hover{background:linear-gradient(135deg,#64509680,#463c7866);border-color:#785aa0b3;box-shadow:0 2px 8px #503c7866}.game-info{display:block;justify-content:space-between;align-items:center;font-size:.9rem;color:#c8b4dccc}.game-stats{display:block;gap:1rem}.game-elements{display:block;gap:1rem;font-size:.8rem}.game-main{flex:1;display:block;flex-direction:column;padding:1.5rem;gap:1.5rem;overflow-y:auto}.scene-description{background:#140a1e66;border:1px solid rgba(80,60,120,.3);border-radius:8px;padding:1.5rem;font-size:1.1rem;line-height:1.8;color:#dcc8f0f2;min-height:150px;box-shadow:inset 0 1px 3px #0003;transition:opacity .5s ease-in-out}.scene-description:before{content:"🕯️ ";font-size:1.2rem}.choices-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:auto;padding:.5rem}.choice-button{background:linear-gradient(135deg,#3c285a4d,#1e143233);border:2px solid rgba(80,60,120,.4);border-radius:8px;padding:1.2rem;cursor:pointer;transition:all .3s ease;text-align:left;color:#dcc8f0e6;opacity:0;transform:translateY(20px)}.choice-button.animate-in{opacity:1;transform:translateY(0)}.choice-button:hover:not(:disabled){background:linear-gradient(135deg,#503c7866,#32285a4d);border-color:#785aa099;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.choice-button:disabled{opacity:.5;cursor:not-allowed;background:#140a1e33}.choice-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;color:#a855f7;text-shadow:0 0 5px rgba(168,85,247,.3)}.choice-description{font-size:.9rem;line-height:1.4;color:#c8b4dccc}.loading-indicator{display:flex;align-items:center;gap:.5rem;padding:1rem;color:#ffffffb3;background-color:#0003}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#646cff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{padding:1rem;background-color:#f003;color:#ff6b6b;border-radius:8px;margin:.5rem 1rem}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vanilla:hover{filter:drop-shadow(0 0 2em #3178c6aa)}.card{padding:2em}.read-the-docs{color:#888}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#3a2c4a;background-color:#1a141e}a:hover{color:#9333ea}button{background-color:#2d1b3d}.game-container{background:linear-gradient(135deg,#1e1428f2,#2d1e3cfa);border:2px solid rgba(120,90,160,.3);box-shadow:0 8px 32px #32145066,inset 0 0 20px #00000080}.game-header{background:linear-gradient(90deg,#6446961a,#3c286e0d);border-bottom:2px solid rgba(120,90,160,.3)}.game-header h1{background:linear-gradient(90deg,#a855f7,#6b21a8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 10px rgba(168,85,247,.3)}.game-info{color:#503c78cc}.scene-description{background:#1e142833;border:1px solid rgba(100,70,150,.3);color:#503c78e6;box-shadow:inset 0 2px 8px #3214504d,0 0 15px #6446961a}.scene-description:before{content:"🕯️ ";font-size:1.2rem}.choice-button{background:linear-gradient(135deg,#503c7826,#32285a1a);border:2px solid rgba(120,90,160,.3);color:#46326ecc}.choice-button:hover:not(:disabled){background:linear-gradient(135deg,#64509633,#463c7826);border-color:#8c6eb466;box-shadow:0 4px 16px #64509633,inset 0 0 10px #785aa04d}.choice-button:disabled{background:#1e14281a}.choice-title{color:#a855f7;text-shadow:0 0 5px rgba(168,85,247,.3)}.choice-description{color:#46326eb3}.loading-indicator{color:#503c78cc;background-color:#1e1428e6}.spinner{border:2px solid rgba(50,30,80,.3);border-top-color:#a855f7}.error-message{background-color:#78143c1a;color:#b91c1c}.switch-label{color:#46326ecc}.switch{background-color:#b478b480}.switch.on{background-color:#3cb47880;box-shadow:0 0 10px #3cb4784d}.switch-slider{background-color:#f0e6faf2}}#title-screen{text-align:center;margin:5rem 0 .5rem;width:100%;margin-left:auto;margin-right:auto;padding:0 1rem;position:relative}#title-screen:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:110%;height:120%;background:radial-gradient(circle,rgba(168,85,247,.2) 0%,transparent 70%);z-index:-1;border-radius:50%;filter:blur(40px);opacity:.8}#title-screen h1{margin:0;font-size:6rem;background:linear-gradient(90deg,#e11d48,#7e22ce);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-align:center;padding:1rem 0;text-shadow:0 4px 8px rgba(0,0,0,.5),0 0 30px rgba(225,29,72,.3),0 0 60px rgba(126,34,206,.2);letter-spacing:3px;font-weight:800;line-height:1.1;white-space:nowrap;overflow:visible;text-overflow:clip;font-family:Georgia,serif;position:relative;transform:translateY(0);transition:transform .3s ease,text-shadow .3s ease;filter:drop-shadow(0 0 10px rgba(0,0,0,.7))}#title-screen h1:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:110%;height:120%;background:radial-gradient(circle,rgba(168,85,247,.15) 0%,transparent 70%);z-index:-1;border-radius:50%;filter:blur(40px);opacity:.7}#title-screen h1:before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(168,85,247,.5),transparent);transform:translateY(-50%);z-index:-1;opacity:.3}@media (max-width: 768px){#title-screen h1{font-size:4rem;letter-spacing:2px;padding:1.5rem 0;text-shadow:0 3px 6px rgba(0,0,0,.4),0 0 20px rgba(168,85,247,.25),0 0 40px rgba(107,33,168,.15)}}@media (max-width: 480px){#title-screen h1{font-size:3rem;letter-spacing:1px;padding:1.2rem 0;text-shadow:0 2px 4px rgba(0,0,0,.3),0 0 15px rgba(168,85,247,.2),0 0 30px rgba(107,33,168,.1)}}@media (max-width: 320px){#title-screen h1{font-size:2.2rem;letter-spacing:.5px;padding:1rem 0;text-shadow:0 1px 3px rgba(0,0,0,.2),0 0 10px rgba(168,85,247,.15),0 0 20px rgba(107,33,168,.1)}}#setup-screen{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;width:100%;max-width:420px;margin:auto;background:linear-gradient(135deg,#0f0a19f2,#190f23e6);border-radius:8px;border:1px solid rgba(80,60,120,.4);box-shadow:0 4px 12px #0003;max-height:90vh;text-align:center;overflow:hidden}.setup-container{padding:.1rem 0;text-align:center;overflow-y:hidden}.setup-container h2{text-align:center;color:#dcc8f0e6;margin-top:0;font-size:1.5rem;text-shadow:0 0 5px rgba(168,85,247,.2)}.form-group{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;gap:.5rem;margin-bottom:.5rem;width:100%}.form-group:last-child{margin-bottom:0}.form-group label{font-weight:700;color:#dcc8f0e6;text-align:right;min-width:100px;font-size:.9rem;padding-right:.5rem}.form-group input{padding:.5rem;border-radius:6px;border:1px solid rgba(80,60,120,.5);background:#140a1e66;color:#dcc8f0f2;box-shadow:inset 0 1px 2px #00000026;transition:all .3s ease;flex:1;font-size:.9rem;min-width:0;text-overflow:ellipsis}.volume-slider-container{display:flex;align-items:center;gap:.5rem;flex:1}#bgm-volume{-webkit-appearance:none;width:100%;height:8px;border-radius:4px;background:#140a1e66;outline:none;border:1px solid rgba(80,60,120,.5);box-shadow:inset 0 1px 2px #00000026}#bgm-volume::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#8e2d9b,#521782);border:2px solid #3c0d52;cursor:pointer;box-shadow:0 2px 4px #0000004d,0 0 8px #8e2d9b66;transition:all .3s ease}#bgm-volume::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#b03261,#7b1fa2);box-shadow:0 2px 4px #0000004d,0 0 12px #b0326199;transform:scale(1.1)}#bgm-volume::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#8e2d9b,#521782);border:2px solid #3c0d52;cursor:pointer;box-shadow:0 2px 4px #0000004d,0 0 8px #8e2d9b66;transition:all .3s ease}#bgm-volume::-moz-range-thumb:hover{background:linear-gradient(135deg,#b03261,#7b1fa2);box-shadow:0 2px 4px #0000004d,0 0 12px #b0326199;transform:scale(1.1)}#bgm-volume-value{min-width:30px;text-align:center;font-weight:700;color:#dcc8f0f2;text-shadow:0 0 5px rgba(168,85,247,.3)}.form-group input:focus,.form-group select:focus{outline:none;border-color:#a855f7b3;box-shadow:0 0 0 2px #a855f74d,inset 0 1px 2px #00000026}#start-game-btn{padding:.8rem;font-size:1.2rem;background:linear-gradient(135deg,#8e2d9b,#521782);color:#c7c7c7;border:2px solid #3c0d52;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin:.25rem auto 0;display:block;width:100%;text-shadow:0 1px 3px rgba(0,0,0,.5)}#start-game-btn:hover{background:linear-gradient(135deg,#b03261,#7b1fa2);border-color:#4a0f68;box-shadow:0 4px 8px #0006,0 0 15px #9b2d544d;transform:translateY(-2px)}#load-game-btn{padding:.8rem;font-size:1.2rem;background:linear-gradient(135deg,#483d8b,#465a8c);color:#c7c7c7;border:2px solid #2a2450;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin:.25rem auto 0;display:block;width:100%;text-shadow:0 1px 3px rgba(0,0,0,.5)}#load-game-btn:hover{background:linear-gradient(135deg,#5a4daa,#596f9f);border-color:#39316f;box-shadow:0 4px 8px #0006,0 0 15px #483d8b4d;transform:translateY(-2px)}#confirm-settings-btn{padding:.7rem;font-size:1rem;background:linear-gradient(135deg,#503c7866,#32285a4d);color:#dcc8f0f2;border:2px solid rgba(80,60,120,.5);border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;font-weight:600;margin:.25rem auto 0;display:block;width:100%;max-width:250px}#confirm-settings-btn:hover{background:linear-gradient(135deg,#64509680,#463c7866);border-color:#785aa0b3;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.log-panel{position:absolute;top:5%;left:5%;width:90%;height:90%;background:linear-gradient(135deg,#0f0a19fa,#190f23f2);border:1px solid rgba(80,60,120,.4);border-radius:8px;z-index:10;display:flex;flex-direction:column;box-shadow:0 4px 12px #00000040}.log-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:2px solid rgba(80,60,120,.4);background:linear-gradient(90deg,#503c7826,#281e461a)}.log-header h2{margin:0;font-size:1.5rem;background:linear-gradient(90deg,#a855f7,#6b21a8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 10px rgba(168,85,247,.3)}.log-close-btn{background:#140a1e66;color:#dcc8f0f2;border:1px solid rgba(80,60,120,.5);border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.log-close-btn:hover{background:#64509680;border-color:#785aa0b3}.log-content{flex:1;padding:1.5rem;overflow-y:auto;color:#dcc8f0f2;line-height:1.6;font-size:1rem}.log-entry{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(80,60,120,.3)}.log-entry:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.log-entry.scene{color:#a855f7;padding:.5rem;background:#140a1e4d;border-radius:4px;margin-bottom:.5rem;font-weight:700}.log-entry.choice{color:#dcc8f0f2;padding:.5rem;margin-bottom:.5rem}.modal{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#00000080;display:flex;justify-content:center;align-items:center}.modal-content{background-color:#1e1e1e;color:#e0e0e0;margin:auto;padding:20px;border:1px solid #888;width:80%;max-width:500px;border-radius:10px;box-shadow:0 4px 12px #0003;text-align:center}.close-button{color:#aaa;float:right;font-size:28px;font-weight:700}.close-button:hover,.close-button:focus{color:#fff;text-decoration:none;cursor:pointer}.modal-button{background:linear-gradient(135deg,#503c7866,#32285a4d);color:#dcc8f0f2;border:1px solid rgba(80,60,120,.5);border-radius:6px;padding:.8rem 1.5rem;cursor:pointer;transition:all .3s ease;font-size:1rem;margin-top:1rem}.modal-button:hover{background:linear-gradient(135deg,#64509680,#463c7866);border-color:#785aa0b3;box-shadow:0 2px 4px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(80,60,120,.4);padding-bottom:1rem;margin-bottom:1.5rem}.modal-header h2{margin:0}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(80,60,120,.4)}.modal-button.secondary{background:#140a1e66;border-color:#503c784d}.modal-button.secondary:hover{background:#1e143299;border-color:#64508c80}.secondary-btn{background:transparent;border:1px solid rgba(80,60,120,.5);color:#dcc8f0cc;padding:.4rem .8rem;border-radius:6px;cursor:pointer;transition:all .3s ease;display:block;width:100%;max-width:250px;margin:.5rem auto;text-align:center;font-size:.9rem}.secondary-btn:hover{background:#503c7833;border-color:#785aa0b3;box-shadow:0 2px 4px #0000001a}.button-group{display:flex;gap:1rem;justify-content:center;margin:1rem 0}.button-group .secondary-btn{margin:0;width:auto;max-width:none}#api-setup-info-modal .modal-body,#audio-setup-info-modal .modal-body{text-align:left;padding:0 1rem}#audio-setup-info-modal .modal-body p,#audio-setup-info-modal .modal-body ul,#audio-setup-info-modal .modal-body ol{margin-bottom:1rem}#audio-setup-info-modal .modal-body code{background:#0000004d;padding:.2rem .4rem;border-radius:4px;font-family:Courier New,Courier,monospace}.settings-section{background:#140a1e33;border:1px solid rgba(80,60,120,.3);border-radius:8px;padding:.75rem;margin-bottom:.5rem;text-align:center;overflow:hidden}.main-actions{display:flex;flex-direction:column;gap:.75rem;align-items:center;margin-top:.75rem;margin-bottom:.25rem}.main-actions button{flex:1}.form-group-horizontal{flex-direction:row;justify-content:flex-start;align-items:center;gap:1rem}#settings-modal .form-group-horizontal{justify-content:flex-start;width:100%}#settings-modal .form-group-horizontal label{text-align:left;min-width:120px;flex-shrink:0}#settings-modal .form-group-horizontal input,#settings-modal .form-group-horizontal select{flex:1;min-width:0}#settings-gemini-api-key-container,#settings-openai-api-key-container,#settings-api-url-container,#settings-model-container{width:100%}.settings-group{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}fieldset.settings-section{border:none;border-radius:0;padding:0;margin:0;background:none}fieldset.settings-section legend{padding:0 .5rem;font-size:1.1rem;font-weight:700;color:#dcc8f0e6;text-shadow:0 0 5px rgba(168,85,247,.2);margin-left:.5rem;text-align:left;margin-bottom:.5rem}.settings-section{background:none;border:none;padding:0;margin-bottom:0}.settings-section .button-group{margin:1rem 0 0}.settings-section .button-group .secondary-btn{max-width:none}#api-setup-info-btn{flex-grow:1}#audio-setup-info-btn{flex-grow:0}.setting-actions{margin-top:1.5rem}.select-wrapper{display:flex;flex:1;min-width:0;position:relative}.form-group select{padding:.5rem 2rem .5rem .5rem;border-radius:6px;border:1px solid rgba(80,60,120,.5);background:#140a1e66;color:#dcc8f0f2;box-shadow:inset 0 1px 2px #00000026;transition:all .3s ease;font-size:.9rem;text-overflow:ellipsis;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.select-wrapper:after{content:"▼";position:absolute;top:50%;right:.75rem;transform:translateY(-50%);pointer-events:none;color:#dcc8f0f2}
