.front-page{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.front-page-container{text-align:center;padding:3rem;background:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;max-width:600px}.title{font-size:3rem;margin-bottom:.5rem;color:#333;font-weight:700}.subtitle{font-size:1.1rem;color:#666;margin-bottom:2rem}.create-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2.5rem;font-size:1.2rem;border-radius:.5rem;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600;margin-bottom:3rem}.create-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.create-button:active:not(:disabled){transform:translateY(0)}.create-button:disabled{opacity:.6;cursor:not-allowed}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:2rem;margin-top:2rem}.feature h3{font-size:1rem;color:#667eea;margin-bottom:.5rem}.feature p{font-size:.9rem;color:#888;margin:0}.notification-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background-color:#e74c3c;color:#fff;padding:1rem 1.5rem;border-radius:.5rem;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:slideDown .3s ease-out;font-weight:500}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:1rem;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d}.modal-content h2{margin:0 0 .5rem;color:#333;font-size:1.5rem}.modal-content p{margin:0 0 1.5rem;color:#666;font-size:.9rem}.modal-content form{display:flex;flex-direction:column;gap:1rem}.name-input{padding:.75rem;border:2px solid #ddd;border-radius:.5rem;font-size:1rem;transition:border-color .2s}.name-input:focus{outline:none;border-color:#667eea}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;font-size:1rem;border-radius:.5rem;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.submit-button:disabled{opacity:.5;cursor:not-allowed}.error-message{color:#e74c3c;font-size:.875rem;margin-top:-.5rem;padding:.5rem;background:#ffe5e5;border-radius:.25rem;border-left:3px solid #e74c3c}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:20px}.loading-spinner.inline{display:inline-flex;padding:0;margin-left:8px}.spinner{border:3px solid rgba(255,255,255,.3);border-top:3px solid #667eea;border-radius:50%;animation:spin .8s linear infinite}.loading-spinner.small .spinner{width:16px;height:16px;border-width:2px}.loading-spinner.medium .spinner{width:32px;height:32px}.loading-spinner.large .spinner{width:48px;height:48px;border-width:4px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gm-panel{background:#2c3e50;color:#fff;overflow:hidden;border-right:1px solid #34495e;display:flex;flex-direction:column;height:100vh;width:250px;position:relative}.gm-panel-header{background:#1a252f;padding:0;border-bottom:2px solid #34495e;flex-shrink:0;display:flex;align-items:center;height:43px;box-sizing:border-box}.gm-panel .tab-navigation{display:flex;width:100%;height:100%}.gm-panel .tab-button{flex:1;padding:0;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.85rem;font-weight:500;color:#95a5a6;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:center}.gm-panel .tab-button:hover{background:#4ecdc41a;color:#4ecdc4}.gm-panel .tab-button.active{color:#4ecdc4;border-bottom-color:#4ecdc4;background:#2c3e50;font-weight:600}.gm-panel-content{flex:1;overflow-y:auto;padding:0 0 60px;display:flex;flex-direction:column;gap:0}.gm-panel .tab-content,.gm-panel .tab-pane{flex:1;overflow-y:auto;display:flex;flex-direction:column}.gm-panel .tab-pane.active{animation:fadeIn .2s ease-in}.gm-panel .tab-pane.hidden{display:none}.gm-panel h4{margin:0 0 .5rem;font-size:.8rem;color:#bdc3c7;text-align:center;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.panel-section{margin-bottom:.5rem;padding:.75rem .5rem;border-bottom:1px solid #34495e}.panel-section:last-child{border-bottom:none;margin-bottom:0}.file-input-hidden{display:none}.file-link{display:block;color:#4ecdc4;text-decoration:underline;cursor:pointer;font-size:.85rem;margin-bottom:.4rem;text-align:center;transition:color .2s}.file-link:hover{color:#5dd9d1}.file-selected{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;padding:.25rem .6rem;background:#34495e;border-radius:.25rem}.filename{flex:1;font-size:.85rem;color:#ecf0f1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cancel-file{background:transparent;border:none;color:#e74c3c;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.cancel-file:hover{color:#c0392b}.image-name-input{width:100%;padding:.25rem .5rem;margin-bottom:.4rem;background:#34495e;color:#fff;border:1px solid #4a5f7f;border-radius:.25rem;font-size:.9rem}.image-name-input:focus{outline:none;border-color:#667eea}.image-name-input::placeholder{color:#95a5a6}.upload-link{display:block;background:transparent;color:#4ecdc4;text-decoration:underline;border:none;cursor:pointer;font-weight:500;font-size:.8rem;padding:0;margin:.25rem auto 0;text-align:center;width:fit-content;transition:color .2s}.upload-link:hover:not(:disabled){color:#5dd9d1}.upload-link:disabled{opacity:.5;cursor:not-allowed;color:#7f8c8d;text-decoration:none}.upload-link.uploading{cursor:default;color:#95a5a6;display:flex;align-items:center;gap:.5rem}.share-links-section{position:absolute;bottom:0;left:0;right:0;margin-bottom:0;border-bottom:none;border-top:2px solid #34495e;background:#2c3e50;z-index:10;padding:.5rem!important;transition:padding .2s ease}.share-links-section h4{margin:0;padding:.25rem 0;font-size:.75rem}.collapsible-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s}.collapsible-header:hover{color:#4ecdc4}.share-links-content{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.link-button{width:100%;padding:.3rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.25rem;cursor:pointer;font-weight:600;font-size:.85rem;transition:transform .1s,opacity .2s}.link-button:hover{transform:translateY(-1px)}.image-list-section{padding-top:.5rem;margin-top:0}.no-images{color:#95a5a6;font-size:.85rem;font-style:italic;margin:0;text-align:center}.image-list{display:flex;flex-direction:column;gap:.5rem}.image-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:#34495e;padding:.3rem .5rem;border-radius:.25rem;border:2px solid transparent;transition:border-color .2s,background .2s}.image-item.active{border-color:#27ae60;background:#2c5d3f}.image-name{font-size:.85rem;color:#ecf0f1;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-decoration:underline;cursor:pointer;transition:color .2s}.image-name:hover{color:#4ecdc4}.image-name.previewing{color:#f9ca24;font-weight:600}.activate-button{padding:.2rem .4rem;background:#4a5f7f;color:#fff;border:none;border-radius:.25rem;cursor:pointer;font-size:.7rem;font-weight:500;transition:background .2s;white-space:nowrap}.activate-button:hover:not(:disabled){background:#5a6f8f}.activate-button:disabled{background:#27ae60;cursor:default}.activate-button.exit-preview{background:#4a5f7f;color:#f9ca24;font-weight:600}.activate-button.exit-preview:hover{background:#5a6f8f;color:#fdcb6e}.notification-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:#4ecdc4;color:#1a1a1a;padding:12px 24px;border-radius:6px;font-weight:600;font-size:14px;box-shadow:0 4px 12px #0000004d;z-index:10000;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.image-canvas{width:100%;height:100%;position:relative;overflow:hidden;background:#4a5f7f;cursor:grab;-webkit-user-select:none;user-select:none}.image-canvas.dragging{cursor:grabbing}.image-canvas.placing-token{cursor:crosshair}.image-canvas.preview-mode{border:3px solid #f9ca24}.image-canvas.no-image{display:flex;align-items:center;justify-content:center;cursor:default}.no-image-message{text-align:center;color:#95a5a6}.no-image-message h3{margin:0 0 .5rem;font-size:1.5rem;color:#7f8c8d}.no-image-message p{margin:0;font-size:1rem}.canvas-controls{position:absolute;bottom:.67rem;right:310px;display:flex;gap:.33rem;align-items:center;z-index:10;transition:right .3s ease}.canvas-controls.right-panel-collapsed{right:.67rem}.reset-button{background:#1a252f;color:#fff;border:1px solid #34495e;padding:.33rem .67rem;border-radius:.25rem;cursor:pointer;font-size:.75rem;font-weight:500;transition:background .2s,transform .1s;box-shadow:0 2px 4px #0000001a}.reset-button:hover{background:#2c3e50;transform:translateY(-1px)}.reset-button:active{transform:translateY(0)}.zoom-level{background:#1a252f;color:#fff;border:1px solid #34495e;padding:.33rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:600}.zoom-button{background:#1a252f;color:#fff;border:1px solid #34495e;padding:.2rem .5rem;border-radius:.25rem;cursor:pointer;font-size:.85rem;font-weight:600;line-height:1;transition:background .2s,transform .1s;box-shadow:0 2px 4px #0000001a;min-width:24px;display:flex;align-items:center;justify-content:center}.zoom-button:hover{background:#2c3e50;transform:translateY(-1px)}.zoom-button:active{transform:translateY(0)}.preview-indicator{background:#f9ca24;color:#1a1a1a;padding:.5rem .75rem;border-radius:.25rem;font-size:.85rem;font-weight:600;box-shadow:0 2px 4px #0003;min-width:60px;text-align:center}.image-wrapper{position:absolute;top:0;left:0;transform-origin:center center;transition:transform .1s ease-out;will-change:transform}.image-canvas.dragging .image-wrapper{transition:none}.image-wrapper img{display:block;max-width:none;pointer-events:none;image-rendering:crisp-edges}.token{position:absolute;width:40px;height:40px;border-radius:50%;transform:translate(-50%,-50%);border:3px solid white;box-shadow:0 2px 8px #0000004d;display:flex;align-items:center;justify-content:center;cursor:move;transition:transform .1s;z-index:5}.token:hover{transform:translate(-50%,-50%) scale(1.1);z-index:10}.token-name{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;background:#000c;color:#fff;padding:2px 8px;border-radius:4px;font-size:12px;white-space:nowrap;pointer-events:none;font-weight:600}.context-menu{position:fixed;background:#fff;border:1px solid #ddd;border-radius:.25rem;box-shadow:0 4px 12px #00000026;z-index:1000;padding:.25rem}.context-menu button{width:100%;padding:.5rem 1rem;background:#fff;border:none;text-align:left;cursor:pointer;font-size:.9rem;border-radius:.25rem;transition:background .2s}.context-menu button:hover{background:#f8f9fa;color:#e74c3c}.token-panel{background:#2c3e50;padding:1.5rem;flex:1;overflow-y:auto;color:#ecf0f1}.token-form{display:flex;flex-direction:column;gap:.75rem}.token-name-input{padding:.6rem;background:#34495e;color:#fff;border:1px solid #4a5f7f;border-radius:.25rem;font-size:.9rem;transition:border-color .2s}.token-name-input:focus{outline:none;border-color:#4ecdc4}.token-name-input::placeholder{color:#95a5a6}.color-picker{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.color-option{width:100%;aspect-ratio:1;border:3px solid transparent;border-radius:.25rem;cursor:pointer;transition:all .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#fff;transform:scale(1.15);box-shadow:0 2px 8px #0000004d}.create-token-button{padding:.6rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.25rem;cursor:pointer;font-weight:600;font-size:.9rem;transition:transform .1s,opacity .2s}.create-token-button:hover:not(:disabled){transform:translateY(-1px)}.create-token-button:disabled{opacity:.5;cursor:not-allowed}.token-instructions{margin-top:1rem;padding-top:1rem;border-top:1px solid #34495e}.token-instructions p{margin:0;font-size:.85rem;color:#95a5a6;line-height:1.4}.chat-panel{display:flex;flex-direction:column;height:100%;background-color:#2c3e50;border-radius:0;overflow:hidden}.chat-channels{display:flex;flex-direction:row;gap:4px;padding:8px 12px;background-color:#1a252f;border-bottom:1px solid #34495e;overflow-x:auto;overflow-y:hidden;white-space:nowrap;flex-shrink:0}.chat-channels::-webkit-scrollbar{display:none}.chat-channels{-ms-overflow-style:none;scrollbar-width:none}.channel-pill{padding:4px 10px;background-color:transparent;border:1px solid #4a5f7f;border-radius:12px;color:#95a5a6;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.channel-pill:hover{background-color:#34495e;color:#ecf0f1}.channel-pill.selected{background-color:#4ecdc4;color:#fff;border-color:#4ecdc4}.channel-pill.unread{animation:pulse-background 2s ease-in-out infinite}@keyframes pulse-background{0%,to{background-color:#f39c124d;border-color:#f39c12}50%{background-color:#e67e2280;border-color:#e67e22}}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:#1a252f}.chat-messages::-webkit-scrollbar-thumb{background:#4a5f7f;border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#5a6f8f}.chat-empty{text-align:center;color:#95a5a6;font-style:italic;padding:20px;margin:auto}.chat-message{background-color:#34495e;padding:10px 12px;border-radius:6px;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:8px}.chat-sender{font-weight:600;color:#4ecdc4;font-size:14px}.chat-timestamp{font-size:11px;color:#95a5a6;white-space:nowrap}.chat-message-text{color:#ecf0f1;font-size:14px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap}.chat-message.dice-roll{background-color:#2c3142;border-left:3px solid #f39c12}.chat-message.dice-roll .chat-message-text{font-family:Courier New,monospace;font-size:13px;white-space:pre-line}.chat-error-notification{background:#e74c3c;color:#fff;padding:10px 12px;margin:0 12px 8px;border-radius:6px;font-weight:600;font-size:13px;text-align:center;box-shadow:0 2px 8px #e74c3c4d;animation:slideInError .3s ease-out}@keyframes slideInError{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-input-form{display:flex;gap:8px;padding:12px;background-color:#1a252f;border-top:1px solid #34495e}.chat-input{flex:1;padding:10px 12px;background-color:#34495e;border:1px solid #4a5f7f;border-radius:6px;color:#fff;font-size:14px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#4ecdc4}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-input::placeholder{color:#95a5a6}.chat-send-button{padding:10px 20px;background-color:#4ecdc4;color:#1a252f;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap;display:none}.chat-send-button:hover:not(:disabled){background-color:#5ed9d1;transform:translateY(-1px)}.chat-send-button:active:not(:disabled){transform:translateY(0)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed}.players-panel{padding:1.5rem;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.players-count{font-size:.9rem;color:#bdc3c7;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid #34495e}.players-list{display:flex;flex-direction:column;gap:.75rem}.no-players{text-align:center;color:#95a5a6;font-style:italic;font-size:.9rem;padding:2rem 1rem}.player-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#34495e;border-radius:.5rem;transition:background .2s}.player-item:hover{background:#3d5a7c}.player-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#4ecdc4,#45b7d1);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#1a252f;flex-shrink:0}.player-info{flex:1;min-width:0}.player-name{font-size:.95rem;font-weight:600;color:#ecf0f1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-role{font-size:.8rem;color:#95a5a6;margin-top:.1rem}.right-panel{display:flex;flex-direction:column;background:#2c3e50;border-left:1px solid #34495e;overflow:hidden;height:100vh;width:300px}.tab-navigation{display:flex;background:#1a252f;border-bottom:2px solid #34495e;flex-shrink:0;height:43px}.tab-button{flex:1;padding:0;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.85rem;font-weight:500;color:#95a5a6;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:center}.tab-button:hover{background:#4ecdc41a;color:#4ecdc4}.tab-button.active{color:#4ecdc4;border-bottom-color:#4ecdc4;background:#2c3e50;font-weight:600}.tab-button.has-unread:after{content:"";display:inline-block;width:6px;height:6px;background-color:#f39c12;border-radius:50%;margin-left:6px;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.tab-content,.tab-pane{flex:1;overflow:hidden;display:flex;flex-direction:column}.tab-pane.active{animation:fadeIn .2s ease-in}.tab-pane.hidden{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.tab-pane .token-panel{background:#2c3e50;border-bottom:none;flex:1;overflow-y:auto;padding:1.5rem}.tab-pane .chat-panel{flex:1;display:flex;flex-direction:column;height:100%;border-radius:0;margin:0;background-color:#2c3e50}@media(max-width:768px){.tab-button{font-size:.75rem;padding:.6rem .5rem}}.sandbox-page{width:100vw;height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.sandbox-page.loading,.sandbox-page.error{align-items:center;justify-content:center}.loading-spinner{font-size:1.5rem;color:#667eea}.error h1{color:#e74c3c;margin-bottom:1rem}.error p{color:#666}.sandbox-layout{position:relative;width:100vw;height:100vh;overflow:hidden}.panel-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #34495e}.panel-section:last-child{border-bottom:none}.panel-section p{margin:0;font-size:.9rem;color:#95a5a6}.canvas-area{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;background:#fff;z-index:1}.canvas-header{background:#1a252f;color:#fff;padding:.75rem .1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #34495e;flex-shrink:0;height:43px;box-sizing:border-box}.canvas-header h2{margin:0;font-size:1.3rem}.header-spacer{flex:1}.collapse-arrow{background:none;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;width:0;height:0;border-style:solid;transition:opacity .2s,left .3s ease,right .3s ease;opacity:.7;position:absolute;top:13.5px;z-index:25}.collapse-arrow:hover{opacity:1}.collapse-arrow:active{opacity:.5}.collapse-arrow.left{left:250px}.collapse-arrow.left.collapsed{left:10px}.collapse-arrow.right{right:300px}.collapse-arrow.right.collapsed{right:10px}.collapse-arrow.left:not(.collapsed){border-width:8px 12px 8px 0;border-color:transparent white transparent transparent}.collapse-arrow.left.collapsed{border-width:8px 0 8px 12px;border-color:transparent transparent transparent white}.collapse-arrow.right:not(.collapsed){border-width:8px 0 8px 12px;border-color:transparent transparent transparent white}.collapse-arrow.right.collapsed{border-width:8px 12px 8px 0;border-color:transparent white transparent transparent}.connection-status{display:flex;align-items:center;gap:1rem}.status-indicator{font-size:.9rem;padding:.3rem .8rem;border-radius:1rem;background:#fff3}.status-indicator.connected{background:#4caf504d}.status-indicator.disconnected{background:#f443364d}.role-badge{background:#fff3;color:#fff;padding:.4rem 1rem;border-radius:1rem;font-size:.9rem;font-weight:600}.canvas-container{flex:1;background:#4a5f7f;overflow:hidden;position:relative}.gm-panel-container{position:absolute;left:0;top:0;height:100%;z-index:10;transition:transform .3s ease}.gm-panel-container.collapsed{transform:translate(-240px)}.right-panel-container{position:absolute;right:0;top:0;height:100%;z-index:10;transition:transform .3s ease}.right-panel-container.collapsed{transform:translate(290px)}@media(max-width:768px){.gm-panel{width:200px}.right-panel{width:280px}.gm-panel-container.collapsed{transform:translate(-190px)}.right-panel-container.collapsed{transform:translate(270px)}.canvas-header h2{font-size:1.1rem}.connection-status{flex-direction:column;gap:.5rem;align-items:flex-end}}*{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}.app{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}
