html,:root{height:100%;color:#f7f0df;background:#151716;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;height:100%;min-height:100%;margin:0;overflow:hidden}#root{height:100%;overflow:hidden}button,input,select,textarea{font:inherit}button{min-height:44px;border:1px solid #5c6258;color:#f7f0df;background:#242925;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.start-shell{width:min(100%,520px);height:var(--app-viewport-height, 100dvh);margin:0 auto;display:grid;align-items:start;padding:max(18px,env(safe-area-inset-top)) 14px max(28px,env(safe-area-inset-bottom));overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:linear-gradient(#0a0c0bb8,#0a0c0be6),url(/cellar-backdrop.svg);background-size:cover;background-position:center}.start-panel{display:grid;gap:18px;padding:18px;border:1px solid #4d534b;background:#151716f2;min-width:0}.start-heading{display:grid;gap:4px}.character-form{display:grid;gap:9px}.character-form label{color:#d8d0c1;font-weight:800}.character-form input{min-height:48px;width:100%;border:1px solid #596055;border-radius:6px;padding:10px;color:#f7f0df;background:#111412}.character-form button,.restore-button{border-radius:6px;color:#101210;background:#e2b45a;font-weight:800}.reset-button{border-radius:6px;color:#f7f0df;background:#5b2d35;font-weight:800}.delete-button{border-radius:6px;color:#fff6ea;border-color:#b64d3d;background:#7a241d;font-weight:800}.save-list{display:grid;gap:10px}.save-list-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.save-list-header button{min-height:38px;border-radius:6px;padding:0 12px}.save-buttons{display:grid;gap:8px}.save-button{min-height:58px;display:grid;gap:3px;justify-items:start;border-radius:6px;padding:9px 10px;text-align:left}.save-button-selected{border-color:#e2b45a;background:#2c2f26}.save-button span{font-weight:800}.save-button small,.start-status{color:#9ed3c2}.play-shell{width:min(100%,520px);height:var(--app-viewport-height, 100dvh);max-height:var(--app-viewport-height, 100dvh);margin:0 auto;display:grid;grid-template-rows:auto auto auto minmax(0,1fr) auto auto;overflow:hidden;background:linear-gradient(#0a0c0bd6,#0a0c0beb),url(/cellar-backdrop.svg);background-size:cover;background-position:center}.top-bar,.room-strip,.composer{min-width:0;background:#151716f0;border-bottom:1px solid #3a3f38}.top-bar{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px}.top-bar>div:first-child{min-width:0}.top-actions{min-width:0;display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:8px}.micro-label{margin:0 0 3px;color:#d9b35f;font-size:.72rem;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin:0}h1{font-size:1.24rem;line-height:1.15;letter-spacing:0;overflow-wrap:anywhere}h2{font-size:1rem;line-height:1.2;letter-spacing:0}h3{font-size:.92rem;line-height:1.2;letter-spacing:0}.icon-button{width:44px;height:44px;display:grid;place-items:center;border-radius:999px;font-size:.78rem;font-weight:800}.room-strip{min-width:0;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid #20251f}.state-rail{min-width:0;display:flex;flex-wrap:wrap;justify-content:flex-end;gap:5px}.state-rail span{min-width:0;padding:6px 8px;border:1px solid #576755;color:#aee0a1;font-size:.78rem;font-weight:800;text-align:center}.safe-room-actions{min-width:0;display:grid;gap:10px;padding:10px 14px;border-top:1px solid #20251f;border-bottom:1px solid #3a3f38;background:#121613f5}.safe-room-actions-compact{display:flex;align-items:center;justify-content:space-between;min-height:34px;padding:6px 14px;color:#d8d0c1;font-size:.84rem}.safe-room-actions-compact strong{color:#9ed3c2}.safe-room-heading{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px}.safe-room-heading span{min-width:76px;padding:5px 8px;border:1px solid #596055;color:#9ed3c2;font-size:.86rem;font-weight:800;text-align:center}.safe-room-result{display:grid;gap:3px;padding:8px 10px;border-left:3px solid #9ed3c2;background:#151b18;color:#d8d0c1;line-height:1.35}.safe-room-result strong{color:#f7f0df}.safe-room-result span,.safe-room-note{color:#d8d0c1;font-size:.88rem}.safe-room-command-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.safe-room-command-grid button,.safe-room-travel-row button{border-radius:6px;font-weight:800}.safe-room-command-grid button:not(:disabled),.safe-room-travel-row button:not(:disabled){color:#101210;background:#9ed3c2}.safe-room-travel-row{display:grid;grid-template-columns:minmax(0,1fr) 92px;align-items:end;gap:8px}.safe-room-travel-row label{min-width:0;display:grid;gap:5px}.safe-room-travel-row label span{color:#d8d0c1;font-size:.82rem;font-weight:800}.safe-room-travel-row select{min-height:44px;width:100%;border:1px solid #596055;border-radius:6px;padding:0 9px;color:#f7f0df;background:#111412}.chat-log{width:100%;max-width:100vw;min-width:0;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;display:flex;flex-direction:column;gap:10px;padding:16px 14px 18px;scroll-padding-bottom:18px}.message{width:100%;max-width:100%;padding:11px 12px;border:1px solid #42483f;background:#181c19ed;line-height:1.45}.message-player{width:min(88%,430px);align-self:flex-end;border-color:#586d89;background:#1f2b38f0}.message-system{align-self:center;border-color:#76623e}.message-image-stack{display:flex;flex-wrap:wrap;gap:8px;margin:9px 0}.message-image-button{width:min(168px,46vw);min-height:0;display:grid;gap:5px;padding:6px;border-radius:6px;text-align:left;background:#111412}.message-image{width:100%;aspect-ratio:4 / 3;display:block;object-fit:cover;border:1px solid #596055;background:#111412}.message-image-button span{min-width:0;overflow:hidden;color:#d8d0c1;font-size:.76rem;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.message-image-pending{min-height:150px;display:grid;place-items:center;border:1px solid #596055;background:#111412;color:#c6cabf;font-size:.92rem}.image-lightbox{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:max(18px,env(safe-area-inset-top)) 14px max(18px,env(safe-area-inset-bottom));background:#050706e6}.image-lightbox figure{width:min(100%,980px);max-height:100%;display:grid;gap:10px;margin:0}.image-lightbox img{width:100%;max-height:calc(var(--app-viewport-height, 100dvh) - 110px);object-fit:contain;border:1px solid #697063;background:#080a09}.image-lightbox figcaption{color:#f7f0df;font-weight:800;text-align:center}.lightbox-close{position:fixed;top:max(12px,env(safe-area-inset-top));right:12px;z-index:31;min-height:40px;border-radius:999px;padding:0 14px;font-size:.82rem;font-weight:800}.pending-message{border-color:#76623e;background:#23211cf5}.pending-row{display:flex;align-items:center;gap:10px}.pending-dots{width:34px;display:inline-flex;align-items:center;gap:4px}.pending-dots span{width:7px;height:7px;border-radius:999px;background:#e2b45a;animation:pending-pulse 1.1s ease-in-out infinite}.pending-dots span:nth-child(2){animation-delay:.16s}.pending-dots span:nth-child(3){animation-delay:.32s}@keyframes pending-pulse{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}.check-card{display:grid;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid #4d534b}.check-card span{color:#9ed3c2;font-size:.82rem;font-weight:800;text-transform:uppercase}.check-card small{color:#d8d0c1;font-size:.82rem;line-height:1.35}.consequence-banner{width:100%;display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;border:1px solid #b96b62;background:#361916f5;line-height:1.4}.consequence-banner button{min-width:92px;border-radius:6px;color:#151716;background:#e2b45a;font-weight:800}.suggestion-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.suggestion-chip{min-height:40px;max-width:100%;display:inline-flex;align-items:center;gap:7px;border-radius:6px;padding:8px 10px;color:#f6f0df;background:#1c2835;border-color:#64748a;font-size:.9rem;line-height:1.2;text-align:left}.suggestion-chip span{flex:0 0 auto;color:#101210;background:#e2b45a;border-radius:4px;padding:3px 5px;font-size:.72rem;font-weight:900}.suggestion-assess span{background:#9ed3c2}.suggestion-inspect span{background:#d49bb1}.suggestion-chip:disabled{cursor:not-allowed;color:#8f928b;background:#171a18;border-color:#3b403a}.suggestion-chip:disabled span{color:#444840;background:#777d72}.error-line{padding:8px 14px;color:#ffb1a8;background:#3a1513f2}.composer{position:relative;width:100%;min-width:0;display:grid;gap:10px;padding:10px 12px calc(14px + env(safe-area-inset-bottom));border-top:1px solid #4d534b}.latest-action-tray{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin}.latest-action-tray .suggestion-chip{flex:0 0 auto;max-width:min(290px,82vw)}.mode-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.mode-pill{border-radius:6px;color:#ddd7c8}.mode-action,.mode-assess,.mode-inspect{color:#101210;font-weight:800}.mode-action{background:#e2b45a}.mode-assess{background:#9ed3c2}.mode-inspect{background:#d49bb1}textarea{width:100%;min-height:76px;max-height:118px;resize:vertical;border:1px solid #596055;border-radius:6px;padding:10px;color:#f7f0df;background:#111412;line-height:1.35}.composer-actions{display:grid;grid-template-columns:minmax(0,1fr);gap:8px}.composer-actions button{border-radius:6px;font-weight:800}.state-drawer{position:fixed;top:0;right:max(0px,calc((100vw - 520px)/2));z-index:10;width:min(88vw,390px);height:var(--app-viewport-height, 100dvh);max-height:var(--app-viewport-height, 100dvh);display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;border-left:1px solid #596055;background:#181c19;box-shadow:-18px 0 40px #00000059}.image-drawer{z-index:11}.drawer-header{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;border-bottom:1px solid #3a3f38}.drawer-content{min-height:0;display:grid;gap:18px;align-content:start;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:16px 14px calc(24px + env(safe-area-inset-bottom))}.drawer-content section{display:grid;gap:7px}.drawer-content p,.drawer-content li{color:#d8d0c1;line-height:1.42}.drawer-content ul{display:grid;gap:8px;margin:0;padding:0;list-style:none}.drawer-content li{display:grid;gap:3px;padding-bottom:8px;border-bottom:1px solid #30362f}.drawer-content li span{color:#9ed3c2;font-size:.86rem}.gear-list{gap:12px}.gear-card{gap:10px;padding:10px;border:1px solid #3d473c;background:#131713}.gear-card-title{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.gear-card,.gear-card-title strong,.gear-card-title span,.gear-card dd,.gear-card p,.gear-meta,.gear-subsection li,.gear-subsection span{min-width:0;overflow-wrap:anywhere}.gear-card dl{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:6px;margin:0}.gear-card dl div{display:grid;gap:2px;min-width:0}.gear-card dt,.gear-subsection h4{margin:0;color:#9ed3c2;font-size:.72rem;font-weight:800;text-transform:uppercase}.gear-card dd{margin:0;color:#f7f0df;font-size:.86rem}.gear-meta{color:#9ed3c2;font-size:.86rem}.gear-subsection{display:grid;gap:5px}.gear-subsection ul{gap:5px}.gear-subsection li{display:grid;gap:3px;padding-bottom:5px}.empty-state{padding:16px 14px;color:#d8d0c1}.map-drawer{z-index:12}.map-content{gap:16px}.map-mode-row,.map-filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.map-filter{min-height:44px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px 9px;border:1px solid #30362f;background:#121612;color:#f4efe6;font-size:.84rem;font-weight:800}.map-filter input{width:17px;height:17px;accent-color:#9ed3c2}.map-filter:has(input:disabled){color:#898982;background:#161815}.map-filter-count{min-width:26px;padding:2px 6px;border:1px solid #596055;color:#9ed3c2;text-align:center}.map-section{padding-top:2px}.map-section h3{padding-bottom:6px;border-bottom:1px solid #596055;color:#e2b45a}.map-list{gap:9px}.map-list-item{gap:5px;padding:10px;border:1px solid #30362f;background:#141914}.map-list-item strong{color:#f7f0df;font-size:.95rem}.map-list-item span{color:#9ed3c2;font-size:.84rem}.surface-image-grid{display:grid;gap:10px}.surface-image-card{display:grid;gap:7px;padding:10px;border:1px solid #30362f;background:#141914}.surface-image-card img{width:100%;max-height:48vh;display:block;border:1px solid #596055;background:#111412;object-fit:contain}.surface-image-card strong,.surface-image-card span{min-width:0;overflow-wrap:anywhere}.surface-image-card span{color:#d8d0c1;font-size:.86rem}.map-overview-grid{display:grid;gap:9px}.map-overview-node{display:grid;grid-template-columns:34px minmax(0,1fr);gap:4px 9px;padding:9px;border:1px solid #3f4a3f;background:#121714}.map-overview-node span{grid-row:span 2;width:30px;height:30px;display:grid;place-items:center;border-radius:999px;color:#101210;background:#e2b45a;font-weight:900}.map-overview-safe span{background:#9ed3c2}.map-overview-node strong,.map-overview-node small,.map-overview-edge{min-width:0}.map-overview-edge{padding-left:12px;border-left:2px solid #596055;color:#d8d0c1;font-size:.86rem}.image-gallery{gap:14px}.image-category{display:grid;gap:12px}.image-category h3{padding-bottom:6px;border-bottom:1px solid #596055;color:#e2b45a}.subject-card{display:grid;gap:10px;padding:12px;border:1px solid #30362f;background:#141914}.subject-card-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start}.subject-card h4,.image-card h4{font-size:1rem}.subject-card p{color:#d8d0c1;font-size:.92rem}.subject-card button{min-height:42px;padding:0 12px;border:1px solid #596055;background:#1c241e;color:#f4efe6;font-weight:800}.subject-card button:disabled{color:#898982}.image-card{display:grid;gap:8px;padding-bottom:14px;border-bottom:1px solid #30362f}.image-card img,.image-placeholder{width:100%;max-height:68vh;border:1px solid #596055;background:#111412;object-fit:contain}.image-card img{display:block}.image-placeholder{aspect-ratio:4 / 3}.image-placeholder{display:grid;place-items:center;color:#d9b35f;font-weight:800;text-transform:uppercase}.image-card p{color:#d8d0c1}.image-card span{color:#9ed3c2;font-size:.82rem}@media(max-width:390px){.composer-actions{gap:6px}.composer-actions button{font-size:.86rem}}@media(max-width:430px){.top-bar{align-items:flex-start;gap:10px;padding:10px 12px}.top-actions{flex-wrap:nowrap;gap:6px}.icon-button{width:40px;height:40px;min-height:40px;font-size:.72rem}.micro-label{font-size:.66rem}h1{font-size:1.05rem}}@media(max-width:390px){.icon-button{width:36px;height:36px;min-height:36px;font-size:.68rem}}@media(min-width:760px){.start-shell{width:min(100%,760px)}.play-shell{width:min(100%,960px);grid-template-columns:minmax(0,1fr) minmax(280px,34%);grid-template-rows:auto auto minmax(0,1fr) auto;border-left:1px solid #30362f;border-right:1px solid #30362f}.top-bar{grid-column:1 / -1}.room-strip{grid-column:2;grid-row:2;align-items:flex-start;flex-direction:column}.state-rail{justify-content:flex-start}.safe-room-actions{grid-column:2;grid-row:3;align-content:start;border-left:1px solid #30362f}.safe-room-actions-compact{align-items:flex-start;flex-direction:column;justify-content:flex-start;gap:4px}.chat-log{grid-column:1;grid-row:2 / 4;border-right:1px solid #30362f}.composer{grid-column:1 / -1;grid-row:4}}
