: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}@media (max-width: 768px){html,body{height:auto;overflow:visible}}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%}@media (max-width: 768px){.fullscreen-fab{display:none}}.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:flex;flex-direction:column;min-height:0;height:100%;gap:0}.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}.player-inputs{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1.5rem}.player-box{display:flex;flex-direction:column;gap:.5rem;background:#1a1a2e;border:1px solid #333;border-radius:6px;padding:.75rem}.player-box__label{font-size:.75rem;font-weight:600;color:#4a9eff;text-transform:uppercase;letter-spacing:.05em}.player-box__name{width:100%;padding:.45rem .6rem;background:#111;border:1px solid #333;border-radius:4px;color:#e0e0e0;font-size:.9rem;box-sizing:border-box}.player-box__name:focus{outline:none;border-color:#4a9eff}.player-box__name::placeholder{color:#555}.player-box__gender{display:flex;gap:.35rem}.gender-btn{flex:1;padding:.3rem .2rem;background:#111;border:1px solid #333;border-radius:4px;color:#888;font-size:.75rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.gender-btn:hover{border-color:#4a9eff;color:#ccc}.gender-btn--active{background:#1a3a5c;border-color:#4a9eff;color:#4a9eff;font-weight:600}.btn-adventure{font-family:Cinzel,serif;font-weight:600;font-size:.95rem;letter-spacing:.06em;border-radius:8px;cursor:pointer;border-style:solid;border-width:1px;transition:background .2s,box-shadow .2s,border-color .2s,color .2s,transform .12s,filter .2s}.btn-adventure--display{font-family:Cinzel Decorative,serif;font-weight:700}.btn-adventure--primary{background:linear-gradient(135deg,#b8860b,#d4a017);border-color:#c9a227;color:#141208;box-shadow:0 4px 22px #b8860b4d}.btn-adventure--primary:hover:not(:disabled){background:linear-gradient(135deg,#d4a017,#e8c040);box-shadow:0 6px 28px #b8860b66}.btn-adventure--primary:active:not(:disabled){transform:scale(.985)}.btn-adventure--primary:disabled{background:#333;border-color:#333;color:#666;box-shadow:none;cursor:not-allowed;transform:none}.btn-adventure--continue{background:linear-gradient(135deg,#c2410c,#ea580c);border-color:#f97316;color:#fff7ed;box-shadow:0 4px 20px #ea580c61}.btn-adventure--continue:hover:not(:disabled){background:linear-gradient(135deg,#ea580c,#fb923c);box-shadow:0 6px 26px #f973167a}.btn-adventure--continue:active:not(:disabled){transform:scale(.985)}.btn-adventure--continue:disabled{background:#333;border-color:#333;color:#666;box-shadow:none;cursor:not-allowed;transform:none}.btn-adventure--danger{background:#241818;border-color:#5c3838;color:#fca5a5;box-shadow:none}.btn-adventure--danger:hover{background:#301f1f;border-color:#8b4545;color:#fecaca}.btn-adventure--danger:active{transform:scale(.985)}.btn-adventure--compact{padding:.5rem .6rem;font-size:.78rem;letter-spacing:.05em}.btn-adventure--compact.btn-adventure--display{font-size:.82rem}.generate-btn{width:100%;margin-top:.5rem;padding:.75rem 1rem}.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%}@media (min-width: 769px){.output-section .game-layout{grid-template-columns:2fr 1fr;align-items:stretch}}.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}@media (max-width: 768px){.output-section .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}@media (min-width: 769px){.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)}.home-top-section{flex:0 0 15vh;max-height:15vh;min-height:0;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:hidden}.home-top-section .app-header{padding:.15rem 1rem .1rem;gap:.12rem}.home-top-section .app-header__emblem{font-size:1.1rem}.home-top-section .app-header h1{font-size:1.2rem;line-height:1.1}.home-top-section .app-header__version{font-size:.68rem;color:#777;margin:0;line-height:1.2}.home-top-section .app-header__rule{max-width:240px;margin-top:.05rem}.home-start-section{text-align:center;max-width:440px;margin:0 auto;padding:.2rem 1rem .25rem;display:flex;flex-direction:column;align-items:center;gap:.35rem}.home-new-adventure-btn{padding:.75rem 1.85rem;font-size:1rem;letter-spacing:.07em}.home-top-section .home-new-adventure-btn{padding:.45rem 1.35rem;font-size:.88rem;letter-spacing:.06em}.home-new-adventure-btn:active:not(:disabled){transform:scale(.98)}.home-new-adventure-rule{display:flex;align-items:center;gap:.5rem;width:100%;max-width:280px}.home-new-adventure-rule span:first-child,.home-new-adventure-rule span:last-child{flex:1;height:1px;background:linear-gradient(to right,transparent,#b8860b88)}.home-new-adventure-rule span:last-child{background:linear-gradient(to left,transparent,#b8860b88)}.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;background:#111;z-index:2000;color:#999}.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%}.generation-preview{flex:1;min-height:0;display:flex;flex-direction:column;gap:.5rem;width:100%}.generation-preview .output-section{flex:1;min-height:0}.generation-preview__error{flex-shrink:0;margin:0}.story-skeleton{display:flex;flex-direction:column;gap:.5rem}.story-skeleton__line{height:.65rem;border-radius:4px}.story-skeleton__line--full{width:100%}.story-skeleton__line--mid{width:88%}.story-skeleton__line--short{width:55%}.character-card--skeleton{cursor:default}.character-card--skeleton .character-portrait{aspect-ratio:3 / 4;min-height:72px}.character-card--skeleton__name{height:1.35rem;width:70%;border-radius:6px}.character-card--skeleton__pill{height:1.1rem;width:85%;border-radius:999px}.character-card--skeleton__pill--short{width:60%}.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{flex:1;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:stretch;min-height:0;overflow:hidden}.saved-games-section h2{font-size:1.1rem;font-weight:600;color:#e0e0e0;margin-bottom:.75rem;padding:0 1rem;flex-shrink:0}.home-no-games{margin:0;padding:1rem 1.25rem 1.25rem;text-align:center;font-size:.88rem;line-height:1.5;color:#8a7a58;border:1px dashed #b8860b44;border-radius:8px;background:rgba(184,134,11,.06);max-width:22rem;align-self:center;box-sizing:border-box}.saved-games-container{flex:1;display:flex;align-items:center;overflow-x:auto;overflow-y:hidden;min-height:0;padding:.5rem 1rem 1rem;box-sizing:border-box}.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;flex-direction:row;flex-wrap:nowrap;gap:1rem;align-items:flex-start;width:max-content;min-width:100%}.saved-game-card{--saved-card-width: 380px;width:var(--saved-card-width);min-width:var(--saved-card-width);max-width:var(--saved-card-width);box-sizing:border-box;background:#252525;border:1px solid #333;border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .2s,box-shadow .2s;display:flex;flex-direction:column;flex-shrink:0;height:fit-content}.saved-game-card:hover{border-color:#4a9eff;box-shadow:0 0 0 1px #4a9eff22}.saved-game-preview{width:100%;aspect-ratio:16 / 9;flex-shrink:0;background:#1a1a1a;overflow:hidden;line-height:0}.saved-game-preview img{width:100%;height:100%;object-fit:cover;display:block}.saved-game-info{padding:.95rem 1rem;flex-shrink:0}.saved-game-info h3{font-size:1.12rem;font-weight:600;color:#e0e0e0;margin:0 0 .55rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-game-meta{font-size:.92rem;color:#888;margin:0 0 .3rem}.saved-game-date{font-size:.8rem;color:#666;margin:0}.saved-game-characters{display:flex;flex-direction:column;gap:.45rem;padding:0 1rem .75rem;border-top:1px solid #2a2a2a}.saved-game-character{display:flex;flex-direction:row;align-items:center;gap:.6rem;min-width:0}.saved-game-character__portrait{flex-shrink:0;width:2.75rem;height:2.75rem;border-radius:7px;overflow:hidden;background:#1a1a1a;border:1px solid #333;line-height:0}.saved-game-character__portrait img{width:100%;height:100%;object-fit:cover;display:block}.saved-game-character__placeholder{width:100%;height:100%;background:linear-gradient(145deg,#2a2a2a,#1f1f1f)}.saved-game-character__name{font-size:.82rem;font-weight:500;color:#9a9a9a;text-align:left;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.25}.saved-game-actions{display:flex;gap:.55rem;padding:.6rem 1rem;border-top:1px solid #333}.saved-game-actions .btn-adventure{flex:1;min-width:0}.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}.start-adventure-btn{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:500;padding:.85rem 2.5rem;font-size:1.05rem;letter-spacing:.06em}.start-adventure-btn:hover:not(:disabled){transform:translate(-50%) translateY(-2px)}.start-adventure-btn:active:not(:disabled){transform:translate(-50%) translateY(0) scale(.99)}.gameplay-start-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#111;z-index:100}.gameplay-start-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;max-width:560px;text-align:center;padding:2rem}.start-map-preview{width:100%;max-height:220px;object-fit:cover;border-radius:8px;border:1px solid #333}.start-screen-title{font-family:Cinzel Decorative,serif;font-size:1.6rem;color:#e8d5a0;margin:0}.start-screen-subtitle{color:#888;font-size:.9rem;line-height:1.6;margin:0}.start-game-btn{padding:.9rem 2.5rem;font-size:1.05rem;letter-spacing:.06em}.gameplay-screen{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:#111;color:#e0e0e0}.gameplay-screen--mobile{height:100vh;height:100dvh;max-height:100dvh;padding-bottom:calc(3.45rem + env(safe-area-inset-bottom,0px));box-sizing:border-box}.gameplay-screen--mobile .gameplay-tab-bar{position:fixed;left:0;right:0;bottom:0;z-index:200;min-height:3.45rem;align-items:stretch;box-shadow:0 -6px 20px #00000059}.gameplay-topbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;border-bottom:1px solid #2a2a2a;flex-shrink:0;background:#181818}.gameplay-topbar__right{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;flex-wrap:wrap;min-width:0}.gameplay-round-badge{background:#1a3a5c;border:1px solid #4a9eff44;color:#4a9eff;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .6rem;border-radius:20px}.back-to-home-btn--inline{position:static}.gameplay-layout{display:grid;grid-template-columns:30% 1fr;gap:0;flex:1;overflow:hidden;min-height:0}.gameplay-mobile-body,.gameplay-mobile-panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.gameplay-mobile-panel--map{position:relative;container-type:size;container-name:mobile-map;overflow:hidden;-webkit-overflow-scrolling:touch}.gameplay-mobile-panel--map .gameplay-map{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:none}.gameplay-mobile-panel--map .gameplay-map-img{width:100cqh;height:100cqw;max-width:none;max-height:none;object-fit:cover;transform:rotate(90deg);transform-origin:center center}.gameplay-mobile-panel--timeline .gameplay-section--timeline{flex:1;min-height:0}.gameplay-mobile-panel--chars .gameplay-char-bars{flex-direction:column;flex-wrap:nowrap;align-items:stretch;overflow-y:auto;flex:1;min-height:0}.gameplay-mobile-panel--chars .char-bar-row{flex:none}.gameplay-mobile-panel--log{display:flex;flex-direction:column;overflow:hidden;min-height:0}.gameplay-mobile-panel--log .gameplay-section--dm{flex:1;min-height:0;overflow:hidden}.gameplay-mobile-panel--log .gameplay-input-area{flex-shrink:0}.gameplay-tab-bar{display:flex;flex-shrink:0;border-top:1px solid #2a2a2a;background:#141414;padding-bottom:env(safe-area-inset-bottom,0)}.gameplay-tab{flex:1;padding:.65rem .2rem;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#888;background:transparent;border:none;border-top:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.gameplay-tab--active{color:#e8d5a0;border-top-color:#b8860b}.gameplay-tab:active{background:#1a1a1a}.gameplay-left{display:flex;flex-direction:column;border-right:1px solid #2a2a2a;overflow:hidden;min-height:0;background:#161616}.gameplay-map{flex-shrink:0;line-height:0;border-bottom:1px solid #2a2a2a;position:relative;cursor:pointer}.gameplay-map:hover .gameplay-map-hint{opacity:1}.gameplay-map-hint{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.6);border-radius:4px;padding:2px 6px;font-size:.75rem;opacity:0;transition:opacity .2s;pointer-events:none}.gameplay-map-img{width:100%;height:auto;max-height:260px;object-fit:cover;display:block}.gameplay-section--timeline{flex:1;min-height:0}.gameplay-char-bars{flex-shrink:0;padding:.6rem .75rem;display:flex;flex-direction:row;justify-content:space-evenly;border-bottom:1px solid #2a2a2a;background:#161616}.char-bar-row{display:flex;align-items:center;gap:.6rem;padding:.5rem;border-radius:8px;background:#1f1f1f;border:1px solid #2a2a2a;transition:border-color .2s,background .2s;cursor:pointer;flex:1;min-width:0}.char-bar-row:hover{border-color:#555;background:#252525}.char-bar-row--active{border-color:#b8860b88;background:#1f1b10}.char-bar-row--ko{opacity:.5}.char-bar-portrait{width:72px;height:100%;min-height:90px;border-radius:6px;overflow:hidden;flex-shrink:0;background:#2a2a2a;align-self:stretch}.char-bar-portrait img{width:100%;height:100%;object-fit:cover}.char-bar-portrait-placeholder{width:100%;height:100%;background:#2a2a2a}.char-bar-info{flex:1;min-width:0}.char-bar-name-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.2rem;flex-wrap:nowrap;overflow:hidden}.char-bar-name{font-size:.8rem;font-weight:600;color:#e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.char-bar-player{font-size:.65rem;color:#666;white-space:nowrap}.char-bar-ko-badge{font-size:.6rem;font-weight:700;color:#ff6b6b;background:#3a1f1f;border:1px solid #ff6b6b44;border-radius:4px;padding:.1rem .3rem;letter-spacing:.05em}.char-bar-track{height:6px;background:#2a2a2a;border-radius:3px;overflow:hidden}.char-bar-fill{height:100%;background:#4ade80;border-radius:3px;transition:width .5s ease}.char-bar-fill--warning{background:#fbbf24}.char-bar-fill--danger{background:#f87171}.char-bar-hp-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.char-bar-hp-row .char-bar-track{flex:1;margin-bottom:0}.char-bar-hp{font-size:.6rem;color:#666;white-space:nowrap;flex-shrink:0}.char-bar-location{font-size:.6rem;color:#a07830;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;margin-bottom:.2rem}.char-bar-abilities{display:flex;flex-wrap:wrap;gap:3px;margin-top:.3rem}.char-bar-ability-pill{font-size:.55rem;color:#999;background:#2a2a2a;border:1px solid #333;border-radius:3px;padding:1px 5px;white-space:nowrap;line-height:1.4}.gameplay-right{display:flex;flex-direction:column;overflow:hidden;min-height:0}.gameplay-section{display:flex;flex-direction:column;min-height:0;border-bottom:1px solid #2a2a2a}.gameplay-section--dm{flex:1}.gameplay-section-header{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#555;padding:.4rem .75rem;border-bottom:1px solid #2a2a2a;flex-shrink:0;background:#161616}.gameplay-timeline{overflow-y:auto;padding:.75rem;flex:1;min-height:0;display:flex;flex-direction:column;gap:.5rem}.timeline-story{font-size:.8rem;color:#666;line-height:1.6;margin:0;border-left:2px solid #333;padding-left:.6rem}.timeline-summary{font-size:.8rem;color:#aaa;line-height:1.5;border-left:2px solid #4a9eff44;padding-left:.6rem;display:flex;flex-direction:column;gap:.15rem}.timeline-round-image{width:100%;border-radius:6px;margin-top:.4rem;display:block;opacity:.9}.timeline-current-round{font-size:.8rem;color:#ccc;border-left:2px solid #b8860b88;padding-left:.6rem;display:flex;flex-direction:column;gap:.25rem}.timeline-round-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#555;display:block;margin-bottom:.15rem}.timeline-player-move{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:#bbb}.timeline-player-name{font-weight:600;color:#e8d5a0}.timeline-action-type{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:#888;background:#2a2a2a;border-radius:4px;padding:.1rem .35rem}.gameplay-dm-feed{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.6rem}.dm-bubble{border-radius:8px;padding:.6rem .75rem;font-size:.88rem;line-height:1.6;display:flex;flex-direction:column;gap:.3rem}.dm-bubble-label{display:flex;align-items:center;gap:.4rem}.dm-bubble-text{line-height:1.6}.dm-scene-image{width:100%;border-radius:6px;margin-top:.6rem;display:block;opacity:.95}.scene-image-skeleton{width:100%;aspect-ratio:16 / 9;border-radius:6px;margin-top:.5rem;background:linear-gradient(90deg,#2a2a2a 25%,#333 50%,#2a2a2a 75%);background-size:800px 100%;animation:shimmer 1.5s infinite linear}.dm-bubble--narrator{background:#1a1a14;border:1px solid #2e2a1a;border-left:3px solid #b8860b;color:#e8d9b0}.dm-bubble-dm-tag{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#b8860b;background:#2a2410;border:1px solid #b8860b44;border-radius:4px;padding:.1rem .4rem}.dm-bubble--player{background:#131a25;border:1px solid #1e2e44;border-left:3px solid #4a9eff;color:#c8dff8;align-self:flex-end;width:92%}.dm-bubble-player-name{font-size:.7rem;font-weight:700;color:#4a9eff}.dm-bubble-action-tag{font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#888;background:#1e2a3a;border:1px solid #333;border-radius:4px;padding:.1rem .35rem}.dm-bubble--dice{background:#1a1228;border:1px solid #3a2a55;border-left:3px solid #a855f7;color:#d8b8ff;font-weight:600;text-align:center;align-items:center;font-size:.9rem}.dm-bubble--system{background:transparent;border:none;color:#444;font-size:.72rem;text-align:center;font-style:italic;padding:.15rem .5rem}.dm-bubble--loading{display:flex;gap:.35rem;align-items:center;background:transparent;border:none;padding:.25rem .75rem}.dm-dot{width:6px;height:6px;border-radius:50%;background:#555;animation:dm-pulse 1.2s ease-in-out infinite}.dm-dot:nth-child(2){animation-delay:.2s}.dm-dot:nth-child(3){animation-delay:.4s}@keyframes dm-pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.gameplay-input-area{flex-shrink:0;padding:.75rem;border-top:1px solid #2a2a2a;display:flex;flex-direction:column;gap:.6rem;background:#161616}.gameplay-turn-banner{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#e8d5a0}.action-type-pills{display:flex;gap:.5rem}.action-pill{flex:1;padding:.45rem .5rem;background:#1f1f1f;border:1px solid #333;border-radius:6px;color:#aaa;font-size:.8rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.action-pill:hover:not(:disabled){border-color:#4a9eff;color:#e0e0e0}.action-pill--active{background:#1a3a5c;border-color:#4a9eff;color:#4a9eff;font-weight:600}.action-pill:disabled{opacity:.4;cursor:not-allowed}.action-pill--ask-dm:hover:not(:disabled){border-color:#34c77b;color:#e0e0e0}.action-pill--ask-dm.action-pill--active{background:#0e1f16;border-color:#34c77b;color:#34c77b}.gameplay-intent-row{display:flex;gap:.5rem;align-items:flex-end}.gameplay-intent-input{flex:1;padding:.55rem .75rem;background:#1a1a1a;border:1px solid #333;border-radius:6px;color:#e0e0e0;font-size:.88rem;font-family:inherit;resize:none;line-height:1.5}.gameplay-intent-input:focus{outline:none;border-color:#4a9eff}.gameplay-intent-input::placeholder{color:#555}.gameplay-intent-input:disabled{opacity:.4}.gameplay-submit-btn{padding:.55rem 1.15rem;font-size:.82rem;letter-spacing:.05em;flex-shrink:0}.gameplay-submit-btn:active:not(:disabled){transform:scale(.98)}.skill-chips-row{display:flex;flex-wrap:wrap;gap:.35rem}.skill-chip{padding:.25rem .6rem;border-radius:20px;font-size:.75rem;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s;white-space:nowrap;line-height:1.4}.skill-chip--ability{background:rgba(74,158,255,.12);border-color:#4a9eff59;color:#7db8ff}.skill-chip--ability:hover:not(:disabled){background:rgba(74,158,255,.25);border-color:#4a9eff}.skill-chip--strength{background:rgba(80,200,120,.12);border-color:#50c87859;color:#6dcc8a}.skill-chip--strength:hover:not(:disabled){background:rgba(80,200,120,.25);border-color:#50c878}.skill-chip:disabled{opacity:.35;cursor:not-allowed}.mention-dropdown{position:absolute;bottom:100%;left:0;right:3.5rem;background:#1e1e2e;border:1px solid #3a3a4a;border-radius:8px;box-shadow:0 -4px 16px #00000080;z-index:100;overflow:hidden;margin-bottom:4px}.mention-option{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;cursor:pointer;font-size:.84rem;color:#ccc;transition:background .1s}.mention-option:hover,.mention-option--active{background:rgba(74,158,255,.15);color:#e0e0e0}.mention-option-icon{font-size:.9rem;flex-shrink:0}.mention-option-label{flex:1}.mention-option-type{font-size:.7rem;color:#666;text-transform:uppercase;letter-spacing:.03em}.dice-roll-area{display:flex;align-items:center;gap:1rem}.dice-odds-text{font-size:.88rem;color:#aaa;flex:1}.dice-result{color:#e8d5a0;font-weight:700;margin-left:.25rem}.dice-roll-btn{padding:.65rem 1.5rem;font-size:.92rem;font-weight:700;flex-shrink:0}.dice-roll-btn:hover:not(:disabled){transform:translateY(-1px)}.dice-roll-btn:active:not(:disabled){transform:translateY(0) scale(.985)}.dice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:500;pointer-events:none;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.dice-d20{display:flex;flex-direction:column;align-items:center;gap:1rem}.dice-d20-svg{width:160px;height:160px;filter:drop-shadow(0 0 24px #d4a01788)}@keyframes dice-spin{0%{transform:rotate(0) scale(1)}25%{transform:rotate(120deg) scale(1.12)}50%{transform:rotate(240deg) scale(.95)}75%{transform:rotate(330deg) scale(1.08)}to{transform:rotate(360deg) scale(1)}}@keyframes dice-appear{0%{transform:scale(.5) rotate(-20deg);opacity:0}60%{transform:scale(1.15) rotate(5deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.dice-d20--rolling .dice-d20-svg{animation:dice-spin .9s cubic-bezier(.4,0,.2,1) forwards}.dice-d20--result .dice-d20-svg{animation:dice-appear .4s cubic-bezier(.34,1.56,.64,1) forwards}.dice-d20-label{font-size:1.4rem;font-weight:700;color:#e8d5a0;text-shadow:0 0 16px #d4a017aa;letter-spacing:.03em;animation:dice-appear .4s cubic-bezier(.34,1.56,.64,1) forwards}.gameplay-error{background:#3a1f1f;color:#ff6b6b;padding:.6rem .75rem;border-radius:6px;font-size:.82rem;border:1px solid #5a2f2f}.gp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.gp-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}.gp-modal-close:hover{color:#e0e0e0;border-color:#555}.gp-map-modal{position:relative;max-width:90vw;max-height:90vh;border-radius:8px;overflow:hidden;border:1px solid #333;line-height:0}.gp-map-modal-img{max-width:90vw;max-height:90vh;object-fit:contain;display:block}.gp-profile-modal{position:relative;background:#1f1f1f;border:1px solid #333;border-radius:12px;display:grid;grid-template-columns:240px 1fr;width:640px;max-width:90vw;max-height:85vh;overflow:hidden}.gp-profile-portrait{background:#2a2a2a;line-height:0}.gp-profile-portrait img,.gp-profile-portrait-placeholder{width:100%;height:100%;object-fit:cover;display:block}.gp-profile-portrait-placeholder{background:#2a2a2a}.gp-profile-content{padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto}.gp-profile-header{display:flex;flex-direction:column;gap:.25rem}.gp-profile-header h2{font-size:1.25rem;font-weight:600;color:#e0e0e0;margin:0}.gp-profile-hp{display:flex;flex-direction:column;gap:.2rem}@media (max-width: 768px){.app{padding:.75rem;height:auto;min-height:100vh;overflow:visible}.app-header h1{font-size:1.2rem}.app-main{overflow:visible}.character-traits{grid-template-columns:1fr}.input-section{width:100%;margin:0;padding:1.25rem;box-sizing:border-box}.output-section{height:auto;overflow:visible}.output-section .game-layout{display:flex;flex-direction:column;height:auto;overflow:visible;gap:1rem}.output-section .game-layout__left,.output-section .game-layout__right{overflow:visible;min-height:unset;height:auto}.output-section .image-section{padding:0;flex-shrink:0}.output-section .adventure-map{width:100%;height:auto;max-height:70vh;object-fit:contain}.output-section .story-section{overflow:visible;flex:none;height:auto}.output-section .game-layout__right{display:flex;flex-direction:column;gap:.75rem}.output-section .character-card{flex:none}.app-main--home{display:flex;flex-direction:column;flex:1;min-height:0;height:auto;max-height:100%;overflow:hidden}.home-top-section{flex:0 0 15vh;max-height:15vh;min-height:0;overflow:hidden}.saved-games-section{flex:1;min-height:0;overflow:hidden}.saved-games-container{align-items:flex-start;overflow-x:visible;overflow-y:auto;-webkit-overflow-scrolling:touch}.saved-games-grid{flex-direction:column;flex-wrap:nowrap;align-items:center;width:100%;min-width:0;height:auto;box-sizing:border-box}.saved-game-card{--saved-card-width: min(380px, calc(100vw - 2rem));width:var(--saved-card-width);min-width:var(--saved-card-width);max-width:var(--saved-card-width)}.back-to-home-btn{top:50px}.modal.character-modal{display:flex;flex-direction:column;width:min(100vw - 1.5rem,520px);max-width:95vw;max-height:min(90dvh,90vh);overflow:hidden}.modal.character-modal .modal-portrait{flex-shrink:0;width:100%;aspect-ratio:16 / 9;max-height:38vh;overflow:hidden}.modal.character-modal .modal-portrait img,.modal.character-modal .modal-portrait-placeholder{width:100%;height:100%;object-fit:cover;object-position:top center}.modal.character-modal .modal-content{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}}
