.token-tooltip-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9998;background:transparent}.token-tooltip{position:fixed;z-index:9999;background:#121717f2;border:2px solid hsl(172,85%,53%);border-radius:8px;padding:12px;min-width:200px;max-width:300px;box-shadow:0 4px 12px #00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto}.tooltip-header{margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid hsl(156,14%,17%)}.token-name-display{display:flex;align-items:center;gap:8px}.token-name{font-size:1rem;font-weight:600;color:#21edd2;flex:1}.edit-name-button{background:none;border:none;cursor:pointer;font-size:1rem;padding:2px 4px;border-radius:4px;transition:background .15s}.edit-name-button:hover{background:#25312d}.token-name-input{width:100%;padding:4px 8px;background:#25312d;border:1px solid hsl(172,85%,53%);border-radius:4px;color:#fafafa;font-size:.9rem;font-weight:600;outline:none}.token-name-input:focus{background:#2c3a34}.tooltip-stats{display:flex;flex-direction:column;gap:6px}.stat-item{display:flex;justify-content:space-between;font-size:.85rem}.stat-label{color:#b3b3b3;font-weight:500}.stat-value{color:#fafafa;font-weight:600}.tooltip-hint{margin-top:8px;padding-top:8px;border-top:1px solid hsl(156,14%,17%);text-align:center;font-size:.75rem;color:#999;font-style:italic}.gm-controls{display:flex;flex-direction:column;gap:12px}.gm-panel{background:#282c34;border:1px solid hsl(220,13%,28%);border-radius:8px;padding:12px}.gm-panel h2{margin:0 0 12px;font-size:14px;font-weight:600;color:#21edd2;text-transform:uppercase;letter-spacing:.5px}.gm-panel h3{margin:0 0 8px;font-size:12px;font-weight:600;color:#ccc}.vision-mode-selector{display:flex;flex-direction:column;gap:8px}.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 8px;border-radius:4px;transition:background .15s}.radio-label:hover{background:#31363f}.radio-label input[type=radio]{cursor:pointer}.radio-label span{font-size:13px;color:#e6e6e6}.barrier-visibility{margin-top:8px;padding-top:8px;border-top:1px solid hsl(220,13%,24%)}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 8px;border-radius:4px;transition:background .15s}.checkbox-label:hover{background:#31363f}.checkbox-label input[type=checkbox]{cursor:pointer}.checkbox-label span{font-size:13px;color:#e6e6e6}.tool-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}.tool-button{padding:8px 12px;background:#353b45;border:2px solid hsl(220,13%,32%);border-radius:6px;color:#e6e6e6;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:4px}.tool-button:hover:not(:disabled){background:#3e4451;border-color:#21edd2}.tool-button.active{background:#21edd2;border-color:#21edd2;color:#0f0f0f;font-weight:600}.tool-button:disabled{opacity:.4;cursor:not-allowed}.current-mode{font-size:12px;color:#b3b3b3;text-align:center}.current-mode strong{color:#21edd2}.barrier-instructions{background:#23272e;border-color:#f2a60d}.instructions-list{margin:0;padding-left:20px;font-size:12px;color:#ccc;line-height:1.6}.instructions-list li{margin-bottom:4px}.barrier-hint{margin-top:8px;padding:6px 8px;background:#2c313a;border-radius:4px;font-size:11px;color:#b3b3b3;text-align:center}.barrier-hint kbd{padding:2px 6px;background:#3e4451;border:1px solid hsl(220,13%,36%);border-radius:3px;font-family:monospace;font-size:11px;color:#21edd2}.barrier-blocking-options{display:flex;flex-direction:column;gap:6px;margin-top:8px;padding:8px;background:#23272e;border-radius:4px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#101913;color:#fafafa}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background-color:#121717cc;padding:1rem 2rem;border-bottom:1px solid hsl(156,14%,17%);display:flex;align-items:center;justify-content:space-between}.app-header h1{color:#21edd2;font-size:1.5rem;font-weight:600;font-family:Cinzel,serif}.phase-badge{background-color:#21edd2;color:#0f0f0f;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600}.app-main{flex:1;display:flex;gap:1rem;padding:1rem}.sidebar{width:300px;background-color:#121717cc;border:1px solid hsl(156,14%,17%);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;overflow-y:auto;max-height:calc(100vh - 150px)}.sidebar h2{font-size:1rem;color:#fafafa;margin-bottom:.75rem;border-bottom:1px solid hsl(156,14%,17%);padding-bottom:.5rem;font-weight:600}.info-panel,.tokens-panel,.help-panel{background-color:#25312d;padding:1rem;border-radius:8px;border:1px solid hsl(156,14%,17%)}.info-item{padding:.5rem 0;font-size:.875rem;color:#b3b3b3}.info-item strong{color:#fafafa;margin-right:.5rem}.selected-token-panel{background:#21edd233!important;border:2px solid hsl(172,85%,53%)!important}.selected-token-info{display:flex;gap:1rem;align-items:center}.selected-token-color{width:60px;height:60px;border-radius:50%;border:3px solid hsl(172,85%,53%);box-shadow:0 2px 8px #0000004d}.selected-token-details{flex:1}.token-name-large{font-size:1.1rem;font-weight:700;color:#fafafa;margin-bottom:.5rem}.token-stats{font-size:.875rem;color:#fafafa;display:flex;flex-direction:column;gap:.25rem}.tokens-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.token-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background-color:#12171780;border-radius:6px;font-size:.875rem;transition:all .2s ease-in-out;border:1px solid transparent}.token-item:hover{background-color:#121717b3;transform:translate(2px)}.token-item.selected{background-color:#21edd233;border-left:3px solid hsl(172,85%,53%);padding-left:calc(.5rem - 3px)}.token-item.selected .token-name{font-weight:700;color:#21edd2}.token-color{width:16px;height:16px;border-radius:50%;border:1px solid hsl(0,0%,98%);flex-shrink:0}.token-name{flex:1;color:#fafafa}.token-pos{color:#b3b3b3;font-size:.75rem;font-family:monospace}.help-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.help-list li{padding:.5rem;font-size:.875rem;color:#b3b3b3;background-color:#12171780;border-radius:6px;line-height:1.4}.help-list li strong{color:#fafafa}.feature-list li{display:flex;align-items:center;gap:.5rem}.feature-complete{color:#21edd2!important}.feature-pending{color:#b3b3b3!important}.canvas-container{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:1rem;background-color:#25312d;border-radius:12px;border:1px solid hsl(156,14%,17%);overflow:auto;touch-action:none}.canvas-container canvas{touch-action:none}.app-footer{background-color:#121717cc;padding:1rem 2rem;border-top:1px solid hsl(156,14%,17%);text-align:center;color:#b3b3b3;font-size:.875rem}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#101913;border-radius:3px}.sidebar::-webkit-scrollbar-thumb{background:#25312d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#374942}.sidebar{scrollbar-width:thin;scrollbar-color:hsl(156,14%,17%) hsl(137,21%,8%)}.sidebar-toggle{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:1000;background-color:#21edd2;color:#0f0f0f;border:none;border-radius:0 8px 8px 0;padding:1rem .5rem;cursor:pointer;font-size:1.2rem;line-height:1;transition:all .2s ease-in-out;box-shadow:2px 0 8px #0000004d;display:none}.sidebar-toggle:hover{background-color:#42f0d9;padding-right:.75rem}.sidebar-toggle:active{background-color:#11d4ba}.sidebar-toggle .arrow{display:block;transition:transform .2s ease-in-out}@media (max-width: 768px){.sidebar-toggle{display:block}.app-header{padding:.75rem 1rem;flex-direction:column;gap:.5rem;align-items:flex-start}.app-header h1{font-size:1.25rem}.app-main{flex-direction:column;padding:.5rem;gap:.5rem}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;max-height:100vh;z-index:999;transition:transform .3s ease-in-out;border-radius:0;margin:0;padding:1rem;box-shadow:4px 0 12px #00000080}.sidebar.closed{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.app.sidebar-open .sidebar-toggle{left:280px}.canvas-container{padding:.5rem;overflow:auto;width:100%;min-height:400px;align-items:center;justify-content:center}.canvas-container>div{transform-origin:center;max-width:100%;max-height:100%}.canvas-container canvas{max-width:100%;height:auto!important;width:auto!important}.app-footer{padding:.75rem 1rem;font-size:.75rem}.participants-list{top:auto;bottom:1rem;right:1rem;max-width:calc(100vw - 2rem)}.info-panel,.tokens-panel,.help-panel{padding:.75rem}.sidebar h2{font-size:.9rem;margin-bottom:.5rem}.info-item,.help-list li{font-size:.8rem;padding:.4rem}.token-item{padding:.4rem;font-size:.8rem}.token-item{min-height:44px}}@media (max-width: 480px){.sidebar{width:100%;max-width:280px}.app.sidebar-open .sidebar-toggle{left:280px}.app-header h1{font-size:1.1rem}.canvas-container{min-height:300px}.help-panel{display:none}}@media (max-width: 896px) and (orientation: landscape){.sidebar{width:250px}.app.sidebar-open .sidebar-toggle{left:250px}.app-main{padding:.5rem}.canvas-container{min-height:250px}}.right-sidebar{width:350px;background-color:#121717cc;border:1px solid hsl(156,14%,17%);border-radius:12px;display:flex;flex-direction:column;max-height:calc(100vh - 150px)}.tab-panel{display:flex;flex-direction:column;height:100%}.tab-buttons{display:flex;border-bottom:1px solid hsl(156,14%,17%);background-color:#12171780;border-radius:12px 12px 0 0}.tab-button{flex:1;padding:.75rem 1rem;background:none;border:none;color:#b3b3b3;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease-in-out;position:relative}.tab-button:first-child{border-radius:12px 0 0}.tab-button:last-child{border-radius:0 12px 0 0}.tab-button:hover{background-color:#25312d;color:#fafafa}.tab-button.active{background-color:#21edd233;color:#21edd2;font-weight:600}.tab-button.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background-color:#21edd2}.tab-content{flex:1;overflow-y:auto;padding:1rem}.tab-content::-webkit-scrollbar{width:6px}.tab-content::-webkit-scrollbar-track{background:#101913;border-radius:3px}.tab-content::-webkit-scrollbar-thumb{background:#25312d;border-radius:3px}.tab-content::-webkit-scrollbar-thumb:hover{background:#374942}.tokens-tab-content,.map-tab-content,.gm-tab-content{display:flex;flex-direction:column;gap:1rem}.chat-panel{display:flex;flex-direction:column;height:100%;min-height:400px}.chat-header{padding-bottom:.75rem;border-bottom:1px solid hsl(156,14%,17%);margin-bottom:.75rem}.chat-header h3{font-size:1rem;color:#fafafa;margin-bottom:.5rem}.chat-help{font-size:.75rem;color:#b3b3b3;font-style:italic}.message-feed{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding:.5rem;background-color:#12171780;border-radius:8px;margin-bottom:.75rem;min-height:200px}.message-feed::-webkit-scrollbar{width:6px}.message-feed::-webkit-scrollbar-track{background:#101913;border-radius:3px}.message-feed::-webkit-scrollbar-thumb{background:#25312d;border-radius:3px}.empty-feed-message{text-align:center;color:gray;font-size:.875rem;font-style:italic;padding:2rem 1rem}.chat-message{background-color:#25312d;padding:.75rem;border-radius:8px;border-left:3px solid hsl(172,85%,53%)}.chat-message.own-message{background-color:#21edd21a;border-left-color:#42f0d9}.chat-message.whisper{background-color:#261339;border-left-color:#7f26d9}.message-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.message-author{font-weight:600;font-size:.875rem;color:#21edd2}.message-time{font-size:.75rem;color:#999}.whisper-badge{background-color:#7f26d9;color:#fff;padding:.125rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.message-content{font-size:.875rem;color:#e6e6e6;line-height:1.4;word-wrap:break-word}.dice-roll-message{background-color:#25312d;padding:.75rem;border-radius:8px;border-left:3px solid hsl(45,100%,60%)}.dice-roll-message.own-roll{background-color:#ffcc331a;border-left-color:#ffd966}.dice-roll-message.whisper{background-color:#261339;border-left-color:#7f26d9}.roll-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.roll-author{font-weight:600;font-size:.875rem;color:#fc3}.roll-time{font-size:.75rem;color:#999}.roll-content{display:flex;flex-direction:column;gap:.5rem}.roll-notation{font-family:monospace;font-size:.875rem;color:#e6e6e6}.roll-result{display:flex;align-items:center;gap:.5rem}.roll-total{font-size:1.5rem;font-weight:700;color:#fc3}.roll-details{font-size:.75rem;color:#b3b3b3;font-family:monospace}.message-input-form{display:flex;gap:.5rem;align-items:center}.message-input{flex:1;padding:.75rem;background-color:#25312d;border:1px solid hsl(156,14%,25%);border-radius:8px;color:#fafafa;font-size:.875rem;font-family:inherit;outline:none;transition:all .2s ease-in-out}.message-input:focus{border-color:#21edd2;background-color:#2c3a34}.message-input::placeholder{color:gray}.send-button{padding:.75rem 1.25rem;background-color:#21edd2;color:#0f0f0f;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease-in-out}.send-button:hover{background-color:#42f0d9;transform:translateY(-1px)}.send-button:active{background-color:#11d4ba;transform:translateY(0)}.send-button:disabled{background-color:#374942;color:gray;cursor:not-allowed;transform:none}
