:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#e0e0e0;background:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#4a9eff;text-decoration:inherit}a:hover{color:#6bb0ff}html,body{margin:0;min-width:320px;height:100%;overflow:hidden;background:#1a1a1a}h1{font-size:2em;line-height:1.2}*{box-sizing:border-box}button:focus,button:focus-visible{outline:2px solid #4a9eff;outline-offset:2px}.fullscreen-fab{position:fixed;top:12px;left:12px;z-index:1000;width:32px;height:32px;padding:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffff59;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.fullscreen-fab:hover{background:rgba(255,255,255,.12);color:#ffffffb3}.fullscreen-fab svg{width:100%;height:100%}.app{margin:0 auto;padding:1rem 1.25rem;height:100vh;overflow:hidden;color:#e0e0e0;display:flex;flex-direction:column}.app-header{text-align:center;padding:1rem 2rem .25rem;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.35rem}.app-header__emblem{font-size:1.5rem;color:#b8860b;filter:drop-shadow(0 0 8px #b8860b88);line-height:1}.app-header h1{font-family:Cinzel Decorative,serif;font-size:1.6rem;font-weight:700;color:#e8d5a0;margin:0;letter-spacing:.05em;text-shadow:0 0 20px #b8860b55,0 2px 4px #00000088}.app-header__rule{display:flex;align-items:center;gap:.5rem;width:100%;max-width:320px}.app-header__rule span:first-child,.app-header__rule span:last-child{flex:1;height:1px;background:linear-gradient(to right,transparent,#b8860b88)}.app-header__rule span:last-child{background:linear-gradient(to left,transparent,#b8860b88)}.app-header__rule-gem{font-size:.5rem;color:#b8860b;flex:none!important;height:auto!important;background:none!important}.app-main{display:flex;flex-direction:column;gap:0;flex:1;overflow:hidden;min-height:0}.app-main--home{display:grid;grid-template-rows:1fr 1fr;gap:0;height:100%}.input-section{background:#252525;padding:2rem;border:1px solid #333;border-radius:4px;width:40vw;margin:0 auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:#e0e0e0;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #444;border-radius:4px;font-size:1rem;transition:border-color .2s;font-family:inherit;background:#1a1a1a;color:#e0e0e0;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4a9eff}.form-group input::placeholder{color:#666}.generate-btn{width:100%;padding:.75rem;background:#4a9eff;color:#fff;border:1px solid #4a9eff;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.generate-btn:hover:not(:disabled){background:#3a8eef}.generate-btn:disabled{background:#333;color:#666;cursor:not-allowed;border-color:#333}.error{background:#3a1f1f;color:#ff6b6b;padding:1rem;border-radius:4px;margin-top:1rem;border:1px solid #5a2f2f}.output-section{padding:0;height:100%;overflow:hidden}.game-layout{display:grid;grid-template-columns:1fr;gap:1rem;height:100%}.output-section--desktop .game-layout{grid-template-columns:2fr 1fr;align-items:stretch}.output-section--desktop{height:100%}.game-layout__left{display:flex;flex-direction:column;gap:1rem;overflow:hidden;min-height:0}.game-layout__right{display:flex;flex-direction:column;gap:.5rem;overflow:hidden;min-height:0}.output-section--mobile .game-layout__right{overflow-y:auto}.story-section{padding:.5rem 0;overflow-y:auto;flex:1;min-height:0}.story-content{font-size:.9rem;line-height:1.7;color:#aaa;margin:0}.character-card{background:#1f1f1f;border:1px solid #333;border-radius:12px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;overflow:hidden;flex:0 0 calc(25% - .375rem);transition:border-color .2s,box-shadow .2s;position:relative}.character-card{cursor:pointer}.output-section--desktop .character-card:hover{border-color:#4a9eff;box-shadow:0 0 0 1px #4a9eff22}.character-card__label{font-size:.65rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.08em}.character-card__body{display:grid;grid-template-columns:3fr 2fr;gap:.6rem;flex:1;min-height:0}.character-portrait{min-height:0;border-radius:8px;overflow:hidden;background:#2a2a2a;line-height:0}.character-portrait-img{width:100%;height:100%;object-fit:cover;display:block}.character-portrait-placeholder{width:100%;height:100%;background:#2a2a2a}.character-name-box{background:#252525;border:1px solid #333;border-radius:6px;padding:.3rem .5rem;flex-shrink:0}.character-name-box h3{color:#e0e0e0;font-size:.85rem;margin:0 0 .15rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.character-class{color:#888;font-size:.65rem;font-weight:500;letter-spacing:.03em}.character-card__right{display:flex;flex-direction:column;gap:.35rem;min-height:0}.ability-pill{background:#2a2a2a;border:1px solid #383838;border-radius:6px;padding:.25rem .4rem;font-size:.65rem;color:#ccc;text-align:center;flex:1;display:flex;align-items:center;justify-content:center;min-height:0;transition:background .15s,border-color .15s}.character-personality{color:#aaa;font-size:.75rem;line-height:1.5;margin:0}.character-traits{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.strengths h4,.weaknesses h4{color:#888;margin:0 0 .3rem;font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.trait-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.25rem}.trait-list li{font-size:.72rem;padding:.2rem .4rem;border-radius:4px;line-height:1.3}.trait-list--strengths li{color:#6ee7b7;background:rgba(110,231,183,.07);border-left:2px solid rgba(110,231,183,.4)}.trait-list--weaknesses li{color:#fca5a5;background:rgba(252,165,165,.07);border-left:2px solid rgba(252,165,165,.4)}.platform-select{text-align:center;max-width:600px;margin:0 auto;padding:0 2rem 1rem;display:flex;flex-direction:column;justify-content:center;height:100%}.home-top-section{display:flex;flex-direction:column;height:100%;overflow:hidden}.platform-select h2{font-size:1.1rem;font-weight:600;color:#e0e0e0;margin-bottom:.25rem}.platform-select>p{color:#999;font-size:.8rem;margin-bottom:1rem}.platform-options{display:flex;gap:1.5rem;justify-content:center}.platform-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 2rem;background:#252525;border:1px solid #333;border-radius:8px;cursor:pointer;transition:border-color .2s,background .2s;color:#e0e0e0;min-width:160px}.platform-card:hover{border-color:#4a9eff;background:#2a2a2a}.platform-icon{display:flex;flex-direction:column;align-items:center}.desktop-icon .screen{width:64px;height:40px;border:2px solid #666;border-radius:4px;display:flex;align-items:center;justify-content:center;background:#1a1a1a}.desktop-icon .screen-content{width:52px;height:28px;background:#333;border-radius:2px}.desktop-icon .stand{width:4px;height:12px;background:#666;margin:0 auto}.desktop-icon .base{width:28px;height:4px;background:#666;border-radius:2px}.phone{width:36px;height:62px;border:2px solid #666;border-radius:8px;background:#1a1a1a;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:4px}.phone-screen{width:100%;flex:1;background:#333;border-radius:4px;margin-bottom:4px}.phone-button{width:12px;height:12px;border-radius:50%;background:#555;flex-shrink:0}.platform-label{font-size:1rem;font-weight:600}.platform-ratio{font-size:.8rem;color:#999}.mode-chip{margin-top:1rem;padding:.35rem .9rem;background:transparent;border:1px solid #444;border-radius:20px;color:#999;font-size:.8rem;cursor:pointer;transition:border-color .2s,color .2s}.mode-chip:hover{border-color:#4a9eff;color:#4a9eff}.slider-wrapper{display:flex;flex-direction:column;gap:.4rem}.character-slider{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:#444;border-radius:2px;outline:none;cursor:pointer}.character-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#4a9eff;cursor:pointer;border:2px solid #1a1a1a}.character-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#4a9eff;cursor:pointer;border:2px solid #1a1a1a}.slider-ticks{display:flex;justify-content:space-between;padding:0 2px}.tick{font-size:.8rem;color:#666;min-width:18px;text-align:center}.tick.active,.slider-value{color:#4a9eff;font-weight:600}.story-loading{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;background:#111;z-index:100;color:#999}.story-loading p{margin:0;font-size:1rem}.loader{position:relative;width:108px;display:flex;justify-content:space-between}.loader:after,.loader:before{content:"";display:inline-block;width:48px;height:48px;background-color:#fff;background-image:radial-gradient(circle 14px,#0d161b 100%,transparent 0);background-repeat:no-repeat;border-radius:50%;animation:eyeMove 10s infinite,blink 10s infinite}@keyframes eyeMove{0%,10%{background-position:0px 0px}13%,40%{background-position:-15px 0px}43%,70%{background-position:15px 0px}73%,90%{background-position:0px 15px}93%,to{background-position:0px 0px}}@keyframes blink{0%,10%,12%,20%,22%,40%,42%,60%,62%,70%,72%,90%,92%,98%,to{height:48px}11%,21%,41%,61%,71%,91%,99%{height:18px}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#2a2a2a 25%,#333 50%,#2a2a2a 75%);background-size:800px 100%;animation:shimmer 1.5s infinite linear;border-radius:4px}.map-loader-container{width:100%;background:#1a1a2e;display:flex;align-items:center;justify-content:center;border-radius:4px}.skeleton-landscape{aspect-ratio:16 / 9}.skeleton-portrait{aspect-ratio:9 / 16}.map-loader{position:relative;width:120px;height:140px;background-image:radial-gradient(circle 30px,#fff 100%,transparent 0),radial-gradient(circle 5px,#fff 100%,transparent 0),radial-gradient(circle 5px,#fff 100%,transparent 0),linear-gradient(#FFF 20px,transparent 0);background-position:center 127px,94px 102px,16px 18px,center 114px;background-size:60px 60px,10px 10px,10px 10px,4px 14px;background-repeat:no-repeat;z-index:10;perspective:500px}.map-loader:before{content:"";position:absolute;width:100px;height:100px;border-radius:50%;border:3px solid #fff;left:50%;top:50%;transform:translate(-50%,-55%) rotate(-45deg);border-right-color:transparent;box-sizing:border-box}.map-loader:after{content:"";position:absolute;height:80px;width:80px;transform:translate(-50%,-55%) rotate(-45deg) rotateY(0);left:50%;top:50%;box-sizing:border-box;border:7px solid #FF3D00;border-radius:50%;animation:map-rotate .5s linear infinite}@keyframes map-rotate{to{transform:translate(-50%,-55%) rotate(-45deg) rotateY(360deg)}}.skeleton-portrait-card{width:100%;height:100%}.image-section{line-height:0;flex-shrink:0}.generated-image{margin:0;padding:0}.adventure-map{max-width:100%;height:auto;border-radius:4px;border:1px solid #333}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#1f1f1f;border:1px solid #333;border-radius:12px;display:grid;grid-template-columns:280px 1fr;gap:0;width:680px;max-width:90vw;max-height:85vh;overflow:hidden;position:relative}.modal-close{position:absolute;top:.75rem;right:.75rem;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:50%;color:#999;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:.7rem;cursor:pointer;z-index:1;transition:color .15s,border-color .15s}.modal-close:hover{color:#e0e0e0;border-color:#555}.modal-portrait{background:#2a2a2a;line-height:0}.modal-portrait img,.modal-portrait-placeholder{width:100%;height:100%;object-fit:cover;display:block}.modal-portrait-placeholder{background:#2a2a2a}.modal-content{padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto}.modal-header{display:flex;flex-direction:column;gap:.35rem}.modal-header h2{font-size:1.25rem;font-weight:600;color:#e0e0e0;margin:0}.modal-abilities{display:flex;flex-wrap:wrap;gap:.35rem}.saved-games-section{width:100%;display:flex;flex-direction:column;min-height:0;overflow:hidden;height:100%}.saved-games-section h2{font-size:1.1rem;font-weight:600;color:#e0e0e0;margin-bottom:.75rem;padding:0 1rem;flex-shrink:0}.saved-games-container{flex:1;overflow-x:auto;overflow-y:hidden;min-height:0;padding:0 1rem 1rem}.saved-games-container::-webkit-scrollbar{height:8px}.saved-games-container::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.saved-games-container::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.saved-games-container::-webkit-scrollbar-thumb:hover{background:#555}.saved-games-grid{display:flex;gap:1rem;height:100%;align-items:flex-start}.saved-game-card{background:#252525;border:1px solid #333;border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .2s,box-shadow .2s;display:flex;flex-direction:column;flex-shrink:0}.saved-game-card:hover{border-color:#4a9eff;box-shadow:0 0 0 1px #4a9eff22}.saved-game-preview{width:100%;height:20vh;flex-shrink:0;background:#1a1a1a;overflow:hidden;line-height:0}.saved-game-preview img{width:100%;height:100%;object-fit:cover}.saved-game-info{padding:.75rem;flex-shrink:0}.saved-game-info h3{font-size:1rem;font-weight:600;color:#e0e0e0;margin:0 0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-game-meta{font-size:.85rem;color:#888;margin:0 0 .25rem}.saved-game-date{font-size:.75rem;color:#666;margin:0}.saved-game-actions{display:flex;gap:.5rem;padding:.5rem .75rem;border-top:1px solid #333}.saved-game-btn{flex:1;padding:.5rem;border:1px solid #444;border-radius:4px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background-color .2s,border-color .2s;background:#1a1a1a;color:#e0e0e0}.saved-game-btn--open{color:#4a9eff;border-color:#4a9eff}.saved-game-btn--open:hover{background:#4a9eff22}.saved-game-btn--delete{color:#ff6b6b;border-color:#ff6b6b}.saved-game-btn--delete:hover{background:#ff6b6b22}.back-to-home-btn{position:fixed;top:12px;right:12px;z-index:1000;padding:.5rem 1rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffffb3;cursor:pointer;font-size:.9rem;transition:background .2s,color .2s}.back-to-home-btn:hover{background:rgba(255,255,255,.12);color:#ffffffe6}@media (max-width: 768px){.app{padding:1rem}.app-header h1{font-size:1.2rem}.character-traits{grid-template-columns:1fr}.input-section{margin:0 1rem}.image-section{padding:1rem}.image-loading{padding:2rem 1rem}.generated-image{padding:.5rem}.saved-games-grid{grid-template-columns:1fr}.back-to-home-btn{top:50px}}
