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,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 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{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-actions{display:flex;align-items:center;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}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{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid #20251f}.room-strip span{min-width:48px;padding:6px 8px;border:1px solid #576755;color:#aee0a1;text-align:center}.chat-log{min-height:0;overflow-y:auto;overscroll-behavior:contain;display:flex;flex-direction:column;gap:10px;padding:16px 14px 18px;scroll-padding-bottom:18px}.message{width:min(88%,430px);padding:11px 12px;border:1px solid #42483f;background:#181c19ed;line-height:1.45}.message-player{align-self:flex-end;border-color:#586d89;background:#1f2b38f0}.message-system{align-self:center;border-color:#76623e}.message-image-stack{display:grid;gap:8px;margin:9px 0}.message-image{width:100%;max-height:68vh;display:block;object-fit:contain;border:1px solid #596055;background:#111412}.message-image-pending{min-height:150px;display:grid;place-items:center;border:1px solid #596055;background:#111412;color:#c6cabf;font-size:.92rem}.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%;display:grid;gap:10px;padding:10px 12px calc(14px + env(safe-area-inset-bottom));border-top:1px solid #4d534b}.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:100vh;overflow-y:auto;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{display:grid;gap:18px;padding:16px 14px 24px}.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,.stat-line{color:#9ed3c2;font-size:.86rem}.known-facts-list li{grid-template-columns:auto 1fr;align-items:start;column-gap:8px}.known-facts-list .fact-status{min-width:70px;padding:3px 6px;border:1px solid #596055;color:#151716;font-size:.72rem;font-weight:800;text-align:center;text-transform:uppercase}.fact-status-canon{background:#e2b45a}.fact-status-rumor{background:#9ed3c2}.fact-status-uncertain{background:#d49bb1}.empty-state{padding:16px 14px;color:#d8d0c1}.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(min-width:760px){.play-shell{border-left:1px solid #30362f;border-right:1px solid #30362f}}
