*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#111;color:#e5e5e5;overflow:hidden;height:100vh}#root{height:100vh}.app{display:flex;height:100vh}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.field-container{flex:1;position:relative;background:#1e2128;overflow:hidden}.field-container svg{display:block;width:100%;height:100%}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;opacity:.6}.empty-state h1{font-size:2rem}.room-share-icon{display:flex;align-items:center;gap:10px;margin-top:4px;padding:8px 16px;border-radius:8px;border:1px solid #333;background:#1a1a1a;color:#888;cursor:pointer;transition:all .2s}.room-share-icon:hover{border-color:#555;color:#ccc;background:#222}.room-share-icon:active{transform:scale(.97)}.room-share-room{font-size:.85rem}.room-share-room code{background:#333;padding:2px 8px;border-radius:4px;font-size:.85rem;color:#aaa}.copy-toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:10px 20px;background:#1a2a1a;border:1px solid #2a4a2a;border-radius:10px;color:#4ade80;font-size:.85rem;font-weight:500;box-shadow:0 8px 30px #0006;animation:toast-in .3s cubic-bezier(.16,1,.3,1);z-index:9999}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.sidebar{width:72px;background:#0d0d0d;border-right:1px solid #222;display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px;flex-shrink:0}.sidebar-header{display:flex;flex-direction:column;align-items:center;gap:6px;padding-bottom:12px;border-bottom:1px solid #222;margin-bottom:8px;width:100%}.sidebar-title{font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:#666}.sidebar-tab{display:flex;flex-direction:column;align-items:center;gap:4px;width:56px;padding:10px 4px;background:none;border:1px solid transparent;border-radius:8px;color:#888;cursor:pointer;font-size:.65rem;transition:all .15s}.sidebar-tab:hover{background:#1a1a1a;color:#ccc}.sidebar-tab.active{background:#1a2a1a;border-color:#4ade80;color:#4ade80}.tab-icon{font-size:1.2rem;font-weight:800;line-height:1}.tab-count{font-size:.6rem;color:#555}.sidebar-tab.active .tab-count{color:#4ade80}.sidebar-spacer{flex:1}.sidebar-export-btn{margin:8px 8px 0;padding:8px;border-radius:6px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#aaa;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .15s}.sidebar-export-btn:hover{background:#4ade8014;border-color:#4ade8033;color:#4ade80}.sidebar-room{font-size:.55rem;color:#444;text-align:center;padding:8px 4px;word-break:break-all}.sidebar-room code{color:#666;display:block;margin-top:2px}.play-overlay{position:fixed;top:0;left:72px;right:0;bottom:0;background:#000000f2;z-index:100;display:flex;flex-direction:column;overflow:hidden}.play-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;border-bottom:1px solid #222;flex-shrink:0}.play-overlay-header h2{font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.play-overlay-actions{display:flex;gap:8px}.formation-tabs{display:flex;gap:4px;padding:10px 32px;border-bottom:1px solid #1a1a1a;flex-shrink:0;overflow-x:auto}.formation-tab{padding:6px 16px;border-radius:6px;border:1px solid rgba(255,255,255,.06);background:transparent;color:#777;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all .15s;white-space:nowrap}.formation-tab:hover{background:#ffffff0a;color:#aaa}.formation-tab.active{background:#4ade801a;border-color:#4ade8040;color:#4ade80}.play-overlay-body{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 32px;overflow:hidden}.play-overlay-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 0;color:#666;font-size:1rem}.play-cylinder-viewport{width:100%;max-width:1100px;display:flex;flex-direction:column;align-items:center;gap:24px;perspective:800px}.play-cylinder-row{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:1fr;gap:20px;width:100%;min-height:230px;transform-style:preserve-3d;align-items:start}.play-cylinder-row.exit-down{animation:exitDown .2s cubic-bezier(.4,0,1,1) forwards}.play-cylinder-row.exit-up{animation:exitUp .2s cubic-bezier(.4,0,1,1) forwards}.play-cylinder-row.enter-down{animation:enterDown .2s cubic-bezier(0,0,.2,1) forwards}.play-cylinder-row.enter-up{animation:enterUp .2s cubic-bezier(0,0,.2,1) forwards}@keyframes exitDown{0%{transform:rotateX(0) translateY(0);opacity:1}to{transform:rotateX(50deg) translateY(30px);opacity:0}}@keyframes exitUp{0%{transform:rotateX(0) translateY(0);opacity:1}to{transform:rotateX(-50deg) translateY(-30px);opacity:0}}@keyframes enterDown{0%{transform:rotateX(-50deg) translateY(-30px);opacity:0}to{transform:rotateX(0) translateY(0);opacity:1}}@keyframes enterUp{0%{transform:rotateX(50deg) translateY(30px);opacity:0}to{transform:rotateX(0) translateY(0);opacity:1}}.play-card-lg{position:relative;background:#141416;border:2px solid #2a2a2e;border-radius:12px;padding:0;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;overflow:hidden;text-align:left}.play-card-lg:hover{border-color:#555;background:#1a1a1e;transform:scale(1.02)}.play-card-lg.active{border-color:#4ade80;box-shadow:0 0 20px #4ade8026}.play-card-lg-thumb{width:100%;overflow:hidden}.play-card-lg-thumb svg{display:block;width:100%;height:auto}.play-card-lg-footer{padding:10px 14px;display:flex;flex-direction:column;gap:2px}.play-card-lg-name{font-size:.9rem;font-weight:600;color:#e4e4e4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-card-lg-formation{font-size:.65rem;color:#555;text-transform:uppercase;letter-spacing:.05em}.play-card-lg .play-card-delete{top:8px;right:8px;width:24px;height:24px;font-size:.85rem}.play-card-lg:hover .play-card-delete{opacity:1}.play-overlay.export-mode{background:#1e1400f5}.export-mode-banner{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:10px 32px;background:#f59e0b;color:#000}.export-mode-banner-text{font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:8px}.export-mode-banner-icon{font-size:1.1rem}.export-mode-banner-actions{display:flex;gap:8px}.export-mode-print-btn{padding:6px 18px;border-radius:6px;border:none;background:#000;color:#f59e0b;font-size:.8rem;font-weight:700;cursor:pointer;transition:opacity .15s}.export-mode-print-btn:disabled{opacity:.3;cursor:not-allowed}.export-mode-print-btn:hover:not(:disabled){opacity:.85}.export-mode-cancel-btn{padding:6px 18px;border-radius:6px;border:1.5px solid rgba(0,0,0,.3);background:transparent;color:#000;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.export-mode-cancel-btn:hover{background:#0000001a}.play-overlay.export-mode .play-card-lg{border-color:#333}.play-card-lg.export-selected{border-color:#f59e0b!important;box-shadow:0 0 24px #f59e0b33}.play-card-lg.export-disabled{opacity:.25;pointer-events:none}.export-checkbox{position:absolute;top:10px;left:10px;z-index:2;width:26px;height:26px;border-radius:6px;border:2px solid rgba(255,255,255,.2);background:#0006;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:transparent;transition:all .15s}.export-checkbox.checked{border-color:#f59e0b;background:#f59e0b;color:#000}.play-card-delete{position:absolute;top:4px;right:4px;background:none;border:none;color:#555;font-size:.75rem;cursor:pointer;width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .1s}.play-card-delete:hover{background:#3a2020;color:#f87171}.play-pager{display:flex;align-items:center;gap:14px}.play-pager-arrow{background:none;border:1px solid #333;color:#666;font-size:.7rem;width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.play-pager-arrow:hover:not(:disabled){border-color:#555;color:#ccc}.play-pager-arrow:disabled{opacity:.25;cursor:not-allowed}.play-pager-dots{display:flex;gap:6px}.play-pager-dot{width:8px;height:8px;border-radius:50%;background:#333;transition:background .2s}.play-pager-dot.active{background:#4ade80}.confirm-delete-modal{background:#1e1e1e;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;width:320px;text-align:center;box-shadow:0 20px 60px #00000080}.confirm-delete-text{margin:0 0 6px;font-size:1rem;color:#e4e4e4}.confirm-delete-sub{margin:0 0 20px;font-size:.75rem;color:#666}.confirm-delete-actions{display:flex;gap:10px;justify-content:center}.confirm-delete-btn{padding:8px 20px;border-radius:8px;border:none;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.confirm-delete-btn.cancel{background:#ffffff14;color:#ccc}.confirm-delete-btn.cancel:hover{background:#ffffff24}.confirm-delete-btn.delete{background:#dc2626;color:#fff}.confirm-delete-btn.delete:hover{background:#ef4444}.presence-chips{display:flex;gap:3px;flex-wrap:wrap}.presence-chip{width:10px;height:10px;border-radius:3px;flex-shrink:0}.tab-presence{display:flex;gap:2px;flex-wrap:wrap;margin-top:2px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:200;display:flex;align-items:center;justify-content:center}.modal{background:#1a1a1a;border:1px solid #333;border-radius:12px;width:520px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #333}.modal-header h2{font-size:1.1rem}.modal-close{background:none;border:none;color:#666;font-size:1rem;cursor:pointer;padding:4px 8px;border-radius:4px}.modal-close:hover{background:#333;color:#fff}.modal-body{padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.modal-label{display:flex;flex-direction:column;gap:6px;font-size:.8rem;color:#aaa;text-transform:uppercase;letter-spacing:.05em}.modal-input{background:#222;border:1px solid #444;color:#e5e5e5;padding:10px 12px;border-radius:6px;font-size:.95rem;text-transform:none;letter-spacing:normal}.modal-input:focus{outline:none;border-color:#4ade80}.modal-error{color:#f87171;font-size:.85rem;padding:8px 12px;background:#2a1515;border-radius:6px;border:1px solid #3a2020}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid #333}.modal-btn{padding:8px 16px;border-radius:6px;font-size:.85rem;cursor:pointer;border:1px solid transparent;transition:all .15s}.modal-btn.primary{background:#2d5a27;border-color:#4ade80;color:#fff}.modal-btn.primary:hover{background:#3a7a30}.modal-btn.secondary{background:#333;color:#ccc}.modal-btn.secondary:hover{background:#444}.formation-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.formation-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:#222;border:2px solid #333;border-radius:8px;cursor:pointer;transition:all .15s;color:#aaa}.formation-card:hover{border-color:#555;background:#2a2a2a}.formation-card.selected{border-color:#4ade80;background:#1a2a1a;color:#4ade80}.formation-name{font-size:.7rem;text-transform:none;letter-spacing:normal}.player-count-row{display:flex;gap:6px}.count-btn{padding:8px 14px;border-radius:6px;background:#222;border:2px solid #333;color:#aaa;cursor:pointer;font-size:.85rem;transition:all .15s}.count-btn:hover{border-color:#555}.count-btn.selected{border-color:#4ade80;background:#1a2a1a;color:#4ade80}.floating-toolbar-wrapper{position:absolute;bottom:24px;left:50%;z-index:50;touch-action:none;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;align-items:stretch}.floating-toolbar{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#1e2028f2;border:1px solid rgba(255,255,255,.1);border-radius:14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006;min-width:600px}.toolbar-handle{cursor:grab;padding:4px 6px;display:flex;align-items:center}.toolbar-handle:active{cursor:grabbing}.toolbar-divider{width:1px;height:24px;background:#ffffff1a;flex-shrink:0}.tb-btn{width:40px;height:40px;border-radius:10px;border:1px solid transparent;background:transparent;color:#aaa;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.tb-btn:hover{background:#ffffff14;color:#ddd}.tb-btn.active{background:#4ade8026;border-color:#4ade8066;color:#4ade80}.tb-btn.danger:hover{background:#f8717126;color:#f87171}.tb-field-group{display:flex;align-items:center;gap:6px}.tb-label{display:flex;align-items:center;gap:6px;font-size:.7rem;color:#666;text-transform:uppercase;letter-spacing:.05em}.tb-range{width:60px;accent-color:#4ade80}.toolbar-spacer{flex:1;min-width:16px}.tb-btn.confirm{border-color:#4ade804d}.tb-btn.confirm:hover{background:#4ade8026}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.connected{background:#4ade80}.status-dot.connecting{background:#fbbf24;animation:pulse 1s ease-in-out infinite}.status-dot.disconnected{background:#f87171}.status-label{font-size:.75rem;color:#888}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#ef4444e6;color:#fff;padding:10px 20px;border-radius:8px;font-size:.85rem;font-weight:600;z-index:300;pointer-events:none;animation:toast-in .25s ease-out;box-shadow:0 4px 16px #0000004d}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.join-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:#111}.join-card{background:#1a1a1a;border:1px solid #333;border-radius:16px;padding:40px;width:400px;display:flex;flex-direction:column;gap:20px;box-shadow:0 20px 60px #0006}.join-title{font-size:1.8rem;text-align:center;font-weight:800;background:linear-gradient(90deg,#4ade80,#06b6d4,#8b5cf6,#ec4899,#f97316,#4ade80);background-size:300% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradient-shift 8s linear infinite}@keyframes gradient-shift{0%{background-position:0% 50%}to{background-position:300% 50%}}.join-room{text-align:center;font-size:.8rem;color:#666}.join-room code{background:#222;padding:2px 8px;border-radius:4px;color:#888}.join-label{display:flex;flex-direction:column;gap:8px;font-size:.8rem;color:#aaa;text-transform:uppercase;letter-spacing:.05em}.join-input{background:#222;border:1px solid #444;color:#e5e5e5;padding:12px 14px;border-radius:8px;font-size:1rem;text-transform:none;letter-spacing:normal}.join-input:focus{outline:none;border-color:#4ade80}.color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.color-swatch{width:100%;aspect-ratio:1;border-radius:8px;border:3px solid transparent;cursor:pointer;transition:all .15s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:#fff;box-shadow:0 0 12px #ffffff4d}.join-preview{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:#222;border:1px solid #333;border-radius:8px;font-weight:600;font-size:.9rem;transition:border-color .2s}.join-error{color:#f87171;font-size:.85rem;padding:8px 12px;background:#2a1515;border-radius:6px;border:1px solid #3a2020;text-align:center}.join-btn{padding:14px;border-radius:8px;background:linear-gradient(135deg,#2d5a27,#1a6a3a);border:1px solid #4ade80;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s}.join-btn:hover{background:linear-gradient(135deg,#3a7a30,#22884a);box-shadow:0 4px 20px #4ade8033}.right-sidebar{width:48px;background:#0d0d0d;border-left:1px solid #222;display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:8px;flex-shrink:0}.rsb-tool-wrapper{position:relative}.rsb-btn{width:36px;height:36px;border-radius:8px;border:1px solid transparent;background:transparent;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.rsb-btn:hover{background:#ffffff0f;color:#ccc}.rsb-btn.active{background:#4ade801f;border-color:#4ade804d;color:#4ade80}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;line-height:16px;text-align:center;pointer-events:none}.rsb-popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.rsb-popover{position:absolute;right:48px;top:0;z-index:100;background:#1a1a1a;border:1px solid #333;border-radius:10px;padding:8px;min-width:180px;box-shadow:0 8px 24px #00000080;display:flex;flex-direction:column;gap:4px}.rsb-popover-title{font-size:.7rem;color:#666;text-transform:uppercase;letter-spacing:.08em;padding:4px 8px 6px}.rsb-popover-item{padding:8px 12px;background:none;border:1px solid transparent;border-radius:6px;color:#ccc;font-size:.82rem;cursor:pointer;text-align:left;transition:all .1s}.rsb-popover-item:hover{background:#ffffff0f}.rsb-popover-item.active{background:#4ade801a;border-color:#4ade8040;color:#4ade80}.rsb-slider-group{padding:8px 12px 4px;border-top:1px solid rgba(255,255,255,.06);margin-top:4px}.rsb-slider-label{display:block;font-size:.7rem;color:#aaa;text-align:center;margin-bottom:6px}.rsb-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:#ffffff1f;outline:none}.rsb-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#4ade80;cursor:pointer}.rsb-slider::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:#4ade80;cursor:pointer}.rsb-slider-ticks{display:flex;justify-content:space-between;font-size:.6rem;color:#666;margin-top:2px}.highlight-modal{background:#1e1e1e;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;width:340px;text-align:center;box-shadow:0 20px 60px #00000080}.highlight-modal-title{font-size:1rem;font-weight:600;color:#e4e4e4;margin-bottom:4px}.highlight-modal-sub{font-size:.75rem;color:#666;margin:0 0 16px}.highlight-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.highlight-chip{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#ccc;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.highlight-chip:hover{background:#ffffff1a;border-color:#fff3}.highlight-chip.active{background:#4ade801a;border-color:#4ade804d;color:#4ade80}.highlight-chip-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.highlight-clear{margin-top:14px;padding:6px 16px;border-radius:6px;border:none;background:#ffffff0f;color:#999;font-size:.75rem;cursor:pointer;transition:background .15s}.highlight-clear:hover{background:#ffffff1f;color:#ccc}.export-modal{background:#1e1e1e;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;width:560px;max-width:90vw;box-shadow:0 20px 60px #00000080}.export-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.export-modal-header h2{font-size:1.1rem;font-weight:600;color:#e4e4e4;margin:0}.export-preview-card{border-radius:8px;overflow:hidden;background:#fff;border:1px solid rgba(255,255,255,.08);margin-bottom:16px;padding:16px;display:flex;flex-direction:column;align-items:center}.export-preview-card.compact{padding:0;border-radius:6px}.export-preview-title{font-size:18px;font-weight:700;color:#1a1a1a;text-align:center;margin-bottom:10px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.export-preview-field{width:100%}.export-preview-field img{display:block;width:100%;height:auto}.export-preview-loading{padding:60px;text-align:center;color:#666;font-size:.8rem}.export-name-row{display:flex;align-items:center;gap:12px}.export-name-row .export-name-input{flex:1;margin-top:0}.export-name-input{padding:8px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#e4e4e4;font-size:.85rem;outline:none;transition:border-color .15s}.export-name-input:focus{border-color:#4ade8066}.export-options{margin-bottom:16px}.export-compact-toggle{display:flex;align-items:center;gap:8px;margin-top:10px;cursor:pointer}.export-compact-toggle input[type=checkbox]{accent-color:#4ade80;width:16px;height:16px;cursor:pointer}.export-compact-label{font-size:.8rem;color:#aaa}.export-highlight{margin-top:10px;display:flex;align-items:center;gap:8px}.export-highlight-label{font-size:.8rem;color:#aaa;white-space:nowrap}.export-highlight-chips{display:flex;flex-wrap:wrap;gap:4px}.export-highlight-chip{display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;border:1px solid #444;background:transparent;color:#ccc;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.export-highlight-chip:hover{border-color:#888;color:#fff}.export-highlight-chip.active{background:#4ade8026;border-color:#4ade80;color:#4ade80}.export-highlight-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.export-density{margin-top:10px;display:flex;align-items:center;gap:8px}.export-density-label{font-size:.8rem;color:#aaa;white-space:nowrap}.export-density-btns{display:flex;gap:4px}.export-density-btn{padding:3px 10px;border-radius:6px;border:1px solid #444;background:transparent;color:#ccc;font-size:.75rem;cursor:pointer;transition:all .15s}.export-density-btn:hover{border-color:#888;color:#fff}.export-density-btn.active{background:#4ade8026;border-color:#4ade80;color:#4ade80}.compact-card{display:flex;flex-direction:column}.compact-half{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.compact-half-name{padding:1px 4px;font-size:.55rem;font-weight:700;color:#aaa;border-bottom:1px solid #333;flex-shrink:0;line-height:1.3;text-align:center}.compact-half-field{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.compact-half-field svg{width:100%;height:100%}.compact-half-empty{flex:1;background:#ffffff05}.compact-divider{height:0;border-top:1px solid #333;flex-shrink:0}.export-actions{display:flex;gap:10px;justify-content:flex-end}.export-btn{padding:8px 20px;border-radius:8px;border:none;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.export-btn.secondary{background:#ffffff14;color:#ccc}.export-btn.secondary:hover{background:#ffffff24}.export-btn.primary{background:#4ade80;color:#0d0d0d}.export-btn.primary:hover{background:#6ee7a0}.playbook-export{width:620px;max-width:95vw}.pb-export-sub{font-size:.75rem;color:#888;margin:0 0 12px}.pb-export-picker{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;max-height:120px;overflow-y:auto}.pb-export-play{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#ccc;font-size:.75rem;cursor:pointer;transition:all .15s}.pb-export-play:hover{background:#ffffff14}.pb-export-play.selected{background:#4ade801a;border-color:#4ade804d;color:#4ade80}.pb-export-play.disabled{opacity:.35;cursor:not-allowed}.pb-export-num{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#4ade80;color:#0d0d0d;font-size:.65rem;font-weight:700;flex-shrink:0}.pb-export-play-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pb-export-preview{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;margin-bottom:16px;aspect-ratio:2.1 / 1}.pb-export-card{border-radius:6px;overflow:hidden;display:flex;flex-direction:column}.pb-export-card.filled{border:1px solid rgba(255,255,255,.1);background:#fff}.pb-export-card.empty{border:1.5px dashed rgba(255,255,255,.08);background:#ffffff05;display:flex;align-items:center;justify-content:center}.pb-export-card-empty-label{font-size:1.2rem;font-weight:700;color:#ffffff0f}.pb-export-card-name{padding:3px 8px;font-size:.6rem;font-weight:700;color:#444;border-bottom:1px solid #e0e0e0;background:#fafafa;flex-shrink:0}.pb-export-card.filled svg{display:block;width:100%;height:auto}.player-settings{margin-top:4px;background:#1e2028f2;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;gap:14px}.ps-section{display:flex;flex-direction:column;gap:8px}.ps-row{display:flex;align-items:center;gap:12px}.ps-section-title{font-size:.65rem;color:#666;text-transform:uppercase;letter-spacing:.08em}.ps-label-input-wrap{flex-shrink:0}.ps-label-input{width:48px;padding:6px 4px;background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#e5e5e5;font-size:1rem;font-weight:700;text-align:center;text-transform:uppercase}.ps-label-input:focus{outline:none;border-color:#4ade80}.ps-color-grid{display:flex;flex-wrap:wrap;gap:5px}.ps-swatch{width:28px;height:28px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .1s;display:flex;align-items:center;justify-content:center;padding:0}.ps-swatch:hover{transform:scale(1.1);border-color:#ffffff4d}.ps-swatch.selected{border-color:#fff;box-shadow:0 0 8px #ffffff40}.ps-swatch.route{background:#ffffff0a}.comment-detail-modal{background:#1a1a1a;border:1px solid #333;border-radius:12px;width:340px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column}.comment-detail-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #333}.comment-detail-author{font-size:.9rem;font-weight:600}.comment-detail-body{padding:16px}.comment-detail-footer{display:flex;justify-content:space-between;padding:12px 16px;border-top:1px solid #333}.chat-panel{position:fixed;bottom:80px;right:64px;width:300px;height:400px;background:#1e2028eb;border:1px solid rgba(255,255,255,.1);border-radius:14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;z-index:60;overflow:hidden}.chat-titlebar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.chat-titlebar:active{cursor:grabbing}.chat-title{flex:1;font-size:.8rem;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.08em}.chat-close-btn{background:none;border:none;color:#666;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.chat-close-btn:hover{background:#ffffff14;color:#ccc}.chat-messages{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:8px}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:#555;font-size:.8rem}.chat-msg{display:flex;flex-direction:column;gap:2px}.chat-msg-header{display:flex;align-items:baseline;gap:8px}.chat-msg-author{font-size:.75rem;font-weight:600}.chat-msg-time{font-size:.6rem;color:#555}.chat-msg-text{font-size:.82rem;color:#ddd;word-break:break-word;line-height:1.4}.chat-input-row{display:flex;align-items:center;gap:6px;padding:8px 10px;border-top:1px solid rgba(255,255,255,.08)}.chat-input{flex:1;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:8px 10px;color:#e5e5e5;font-size:.82rem;font-family:inherit}.chat-input:focus{outline:none;border-color:#4ade8066}.chat-send-btn{width:32px;height:32px;border-radius:8px;border:none;background:#4ade8026;color:#4ade80;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.chat-send-btn:hover{background:#4ade8040}
