:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{background-color:#0c0c14}:root{--bg-primary: #0c0c14;--bg-secondary: #14141f;--bg-tertiary: #1c1c2a;--bg-hover: #252535;--border-color: #2a2a3a;--border-subtle: #1f1f2d;--text-primary: #e8e8f0;--text-secondary: #9898a8;--text-muted: #6a6a7a;--accent-gold: #1eff00;--accent-gold-dim: rgba(30, 255, 0, .2);--accent-blue: #4a9eff;--accent-green: #3fb950;--accent-red: #f85149;--shadow-color: rgba(0, 0, 0, .5)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;transition:background-color .2s,color .2s}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.app-header-left{display:flex;align-items:center}.app-header-mode-switcher{display:flex;align-items:center;gap:4px}.mode-switcher-btn-nav{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:.95rem;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-muted);cursor:pointer;transition:color .15s,background .15s,border-color .15s}.mode-switcher-btn-nav:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.mode-switcher-btn-nav.active{color:var(--accent-gold);background:#1eff001f;border-color:var(--accent-gold-dim)}.header-titles{display:flex;flex-direction:column;gap:2px}.app-header h1{font-family:Montserrat,sans-serif;font-size:2.6rem;font-weight:800;color:var(--accent-gold);text-shadow:0 0 40px var(--accent-gold-dim);letter-spacing:1.5px;text-transform:uppercase;display:flex;align-items:center;gap:12px}.header-alpha-tag{display:inline-block;font-family:Montserrat,sans-serif;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;border-radius:4px;background:var(--accent-gold-dim);color:var(--accent-gold);border:1px solid rgba(30,255,0,.35)}.app-header .subtitle{font-size:.85rem;font-weight:500;color:var(--text-secondary);letter-spacing:1px;text-transform:uppercase}.app-header-tagline{margin:0;font-size:.75rem;font-weight:400;color:var(--text-muted);letter-spacing:.3px;text-transform:none;font-family:var(--font-sans)}.toolbar{display:flex;flex-wrap:wrap;gap:16px;padding:12px 20px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);align-items:center}.toolbar-section{display:flex;align-items:center;gap:8px}.toolbar-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.toolbar-buttons{display:flex;gap:4px}.tool-button{width:36px;height:36px;border:1px solid var(--border-subtle);border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-primary);font-size:1.1rem;cursor:pointer;transition:all .15s ease-out;display:flex;align-items:center;justify-content:center}.tool-button:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-color)}.tool-button:disabled{opacity:.4;cursor:not-allowed}.tool-button.active{background-color:var(--accent-blue);border-color:var(--accent-blue)}.color-picker{display:flex;gap:4px}.color-button{width:24px;height:24px;border:2px solid #333;border-radius:4px;cursor:pointer;transition:all .15s ease}.color-button:hover{transform:scale(1.1)}.color-button.active{border-color:#fff;box-shadow:0 0 6px #ffffff80}.stroke-slider{width:80px;cursor:pointer}.stroke-value{font-size:.75rem;color:var(--text-muted);min-width:35px}.patrol-speed{display:flex;flex-direction:column;gap:4px;margin-top:4px}.patrol-speed label{font-size:.7rem;color:var(--text-muted)}.main-content{display:flex;flex:1 1 0;min-height:0;overflow:hidden}.sidebar{width:330px;min-width:330px;background-color:var(--bg-secondary);border-right:1px solid var(--border-subtle);overflow-y:auto;overflow-x:hidden;transition:background-color .15s ease-out,border-color .15s ease-out}.sidebar-branding{padding:16px 16px 12px;border-bottom:1px solid var(--border-subtle)}.sidebar-title{font-family:Montserrat,sans-serif;font-size:2.4rem;font-weight:800;color:#1eff00;text-shadow:0 0 20px rgba(30,255,0,.3);letter-spacing:2px;text-transform:uppercase;margin:0;display:flex;align-items:center;gap:10px}.sidebar-alpha-tag{font-size:.55rem;font-weight:700;color:#1eff00;background:#1eff001a;border:1px solid rgba(30,255,0,.3);border-radius:4px;padding:2px 6px;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}.sidebar-tagline{margin:-2px 0 0;font-size:.7rem;font-weight:400;color:var(--text-muted);letter-spacing:.2px}.sidebar-section{padding:16px;border-bottom:1px solid var(--border-subtle)}.sidebar-section:last-child{border-bottom:none}.sidebar-section:first-child{padding-top:20px}.sidebar-legend-section{padding-top:12px;padding-bottom:12px}.sidebar-legend-footer{margin-top:auto;padding-top:10px;border-top:1px solid var(--border-subtle)}.sidebar-legend-footer .sidebar-legend-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:2px 0;background:none;border:none;font-size:.65rem;font-weight:400;color:var(--text-muted);text-transform:none;letter-spacing:0;cursor:pointer;text-align:left;opacity:.85}.sidebar-legend-footer .sidebar-legend-toggle:hover{color:var(--text-secondary);opacity:1}.sidebar-legend-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:0;background:none;border:none;font-size:.75rem;font-weight:600;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;text-align:left}.sidebar-legend-toggle:hover{color:var(--text-primary)}.sidebar-legend-chevron{font-size:.6rem;color:var(--text-muted)}.sidebar-legend-content{margin-top:12px;padding-top:8px;border-top:1px solid var(--border-subtle)}.sidebar-legend-content .role-legend{margin-bottom:12px}.sidebar-credit{margin:0;padding:10px 16px 4px;font-size:.65rem;font-weight:400;color:var(--text-muted);opacity:.8;letter-spacing:.2px;text-align:center}.sidebar-mqg-counter{margin:0;padding:0 16px 16px;font-size:.55rem;font-weight:400;color:var(--text-muted);opacity:.4;letter-spacing:.1px;text-align:center;font-style:italic}.sidebar-header{font-size:.7rem;font-weight:600;color:var(--text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.5px}.sidebar-header-hint{font-size:.65rem;font-weight:400;color:var(--text-secondary);text-transform:none;letter-spacing:0;opacity:.7;margin-left:auto}.sidebar-header .npc-count{font-weight:400;color:var(--text-secondary);font-size:.75rem}.sidebar-hint{font-size:.75rem;color:var(--text-muted);margin-bottom:12px}.map-selector-container{position:relative;display:block}.map-selector-trigger{width:100%;padding:12px 14px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.03) 100%);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:10px;text-align:left}.map-selector-trigger:hover{border-color:#1eff0066;background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.08) 100%)}.map-selector-trigger.open{border-color:var(--accent-gold);box-shadow:0 0 0 2px #1eff0026,0 0 20px #1eff001a;border-bottom-left-radius:0;border-bottom-right-radius:0}.map-selector-icon{font-size:1.1rem}.map-selector-text{flex:1}.map-selector-arrow{font-size:.6rem;color:var(--accent-gold);transition:transform .2s}.map-selector-arrow.open{transform:rotate(180deg)}.map-selector-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-tertiary);border:1px solid var(--accent-gold);border-top:none;border-radius:0 0 8px 8px;max-height:320px;overflow-y:auto;z-index:100;box-shadow:0 8px 24px #0006,0 0 20px #1eff0014}.map-selector-option{width:100%;padding:10px 14px;background:transparent;border:none;color:var(--text-primary);font-family:inherit;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:10px;text-align:left;transition:all .15s;border-left:2px solid transparent}.map-selector-option:hover{background:#1eff0014;border-left-color:var(--accent-gold)}.map-selector-option.selected{background:#1eff001f;border-left-color:var(--accent-gold)}.map-selector-option.wip{opacity:.7}.map-selector-option.wip:hover{opacity:1}.map-selector-option-icon{font-size:1rem;width:24px;text-align:center}.map-selector-option-text{flex:1;display:flex;align-items:center;gap:8px}.map-selector-wip-tag{font-size:.6rem;font-weight:600;color:var(--text-muted);background:#ffffff1a;padding:2px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.map-selector-check{color:var(--accent-gold);font-size:.9rem;font-weight:700}.map-selector-hint{font-size:.7rem;color:var(--text-muted);margin-top:6px;font-style:italic}.route-section{margin-top:16px;padding-top:12px;border-top:1px solid var(--border-subtle)}.route-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.route-header-right{display:flex;align-items:center;gap:8px}.route-saved-indicator{font-size:.65rem;color:#27ae60;opacity:.9;animation:route-saved-fade .3s ease-out}@keyframes route-saved-fade{0%{opacity:0}to{opacity:.9}}.route-label{font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.route-add-btn{width:22px;height:22px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-secondary);font-size:1rem;cursor:pointer;transition:all .15s}.route-add-btn:hover{background:var(--accent-gold-dim);border-color:var(--accent-gold);color:var(--accent-gold)}.route-create-form{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.route-name-input,.route-rename-input{width:100%;padding:8px 10px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-primary);font-size:.8rem}.route-name-input:focus,.route-rename-input:focus{outline:none;border-color:var(--accent-gold)}.route-create-actions{display:flex;gap:6px}.route-create-save,.route-create-cancel{flex:1;padding:6px 10px;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s}.route-create-save{background:var(--accent-gold);border:none;color:#000}.route-create-save:hover{background:#19cc00}.route-create-cancel{background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary)}.route-create-cancel:hover{border-color:var(--text-muted);color:var(--text-primary)}.route-list{display:flex;flex-direction:column;gap:4px}.route-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.02) 100%);border:1px solid var(--border-subtle);border-radius:8px;cursor:pointer;transition:all .15s}.route-item:hover{background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.06) 100%);border-color:#1eff004d}.route-item-active{background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.1) 100%);border-color:var(--accent-gold);box-shadow:0 0 0 2px #1eff001a,0 0 12px #1eff0014}.route-item-active:hover{background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.12) 100%)}.route-item-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.route-item-active .route-item-name{color:var(--accent-gold)}.route-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.route-item:hover .route-item-actions{opacity:1}.route-action-btn{width:22px;height:22px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:all .15s}.route-action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.route-action-delete:hover{color:#e74c3c}.route-rename-input{flex:1;margin:0;padding:4px 8px}.route-delete-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;animation:route-modal-fade-in .15s ease-out}@keyframes route-modal-fade-in{0%{opacity:0}to{opacity:1}}.route-delete-modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:12px;padding:24px;max-width:320px;width:90%;box-shadow:0 8px 32px #00000080;animation:route-modal-slide-up .2s ease-out}@keyframes route-modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.route-delete-modal-content{text-align:center;margin-bottom:20px}.route-delete-modal-text{font-size:1rem;color:var(--text-primary);margin:0 0 8px}.route-delete-modal-subtext{font-size:.8rem;color:var(--text-muted);margin:0}.route-delete-modal-actions{display:flex;gap:12px}.route-delete-modal-cancel,.route-delete-modal-confirm{flex:1;padding:10px 16px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.route-delete-modal-cancel{background:var(--bg-tertiary);border:1px solid var(--border-subtle);color:var(--text-secondary)}.route-delete-modal-cancel:hover{background:var(--bg-primary);border-color:var(--text-muted);color:var(--text-primary)}.route-delete-modal-confirm{background:#c0392b;border:none;color:#fff}.route-delete-modal-confirm:hover{background:#e74c3c}.sidebar-npc-search{width:100%;box-sizing:border-box;padding:8px 10px;margin-bottom:8px;font-size:.8rem;font-family:inherit;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:6px;outline:none}.sidebar-npc-search::placeholder{color:var(--text-secondary)}.sidebar-npc-search:focus{border-color:var(--accent)}.npc-list{display:flex;flex-direction:column;gap:4px}.npc-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background-color:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:8px;cursor:grab;transition:all .15s ease-out;-webkit-user-select:none;user-select:none}.npc-item-boss{background-color:#f8514914;border-color:#f8514966}.npc-item:hover{background-color:var(--bg-hover);border-color:var(--border-color)}.npc-item-boss:hover{background-color:#f851491f;border-color:#f8514980}.npc-item-placement-selected{border-color:var(--accent);box-shadow:0 0 0 2px #1eff0066}.npc-item:active{cursor:grabbing;opacity:.8}.npc-icon-container{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center;min-width:32px;min-height:32px}.npc-dot{display:block;width:24px;height:24px;border-radius:50%;flex-shrink:0;border:2px solid rgba(0,0,0,.3)}.npc-dot-boss{width:32px;height:32px;border:3px solid #FFFFFF;box-shadow:0 0 8px #f449}.ability-icon{position:absolute;width:16px;height:16px;border-radius:3px;border:2px solid;background-color:var(--bg-tertiary)}.ability-icon-top-left{top:-4px;left:-4px}.ability-icon-top-right{top:-4px;right:-4px}.ability-icon-bottom-left{bottom:-4px;left:-4px}.ability-icon-bottom-right{bottom:-4px;right:-4px}.ability-icon-interruptible{border-color:#0f0!important;border-style:dashed;animation:pulse-green 1.5s infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 2px #0f0}50%{box-shadow:0 0 8px #0f0}}.npc-info{flex:1;display:flex;flex-direction:column;min-width:0}.npc-name{font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.npc-role{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.npc-item-count{font-size:.7rem;color:var(--text-secondary);background-color:var(--bg-hover);padding:2px 8px;border-radius:10px;min-width:24px;text-align:center}.npc-item-count-zero{color:var(--text-muted);background-color:var(--bg-tertiary)}.npc-item-empty{opacity:.6}.npc-item-empty:hover{opacity:.9}.add-npc-button{width:100%;padding:12px 14px;margin-bottom:12px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.02) 100%);border:1px dashed var(--border-color);border-radius:8px;color:var(--text-muted);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease-out}.add-npc-button:hover{background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(30,255,0,.06) 100%);border-color:#1eff0066;color:var(--text-primary)}.add-npc-button.create-pull-highlight{border-color:var(--accent-gold);color:var(--accent-gold);animation:create-pull-glow 1.8s ease-in-out infinite}@keyframes create-pull-glow{0%,to{box-shadow:0 0 12px var(--accent-gold-dim),0 0 0 1px var(--accent-gold)}50%{box-shadow:0 0 24px var(--accent-gold),0 0 0 2px var(--accent-gold)}}.add-npc-form{display:flex;flex-direction:column;gap:8px}.add-npc-form input,.add-npc-form select{padding:10px 12px;background-color:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-size:.85rem}.add-npc-form input:focus,.add-npc-form select:focus{outline:none;border-color:var(--accent-blue)}.add-npc-buttons{display:flex;gap:8px}.add-npc-buttons button{flex:1;padding:10px;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .15s ease-out}.add-npc-buttons button[type=submit]{background-color:var(--accent-blue);border:none;color:#fff}.add-npc-buttons button[type=submit]:hover{background-color:#5eb0ff}.add-npc-buttons button[type=button]{background-color:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.add-npc-buttons button[type=button]:hover{background-color:var(--bg-hover);color:var(--text-primary)}.role-legend{display:flex;flex-direction:column;gap:8px}.role-legend-item{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--text-secondary)}.role-dot{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.3)}.role-dot-boss{border:2px solid #FFFFFF;box-shadow:0 0 6px #ff444480}.role-legend-icon{width:20px;height:20px;border-radius:50%;object-fit:cover}.ability-legend{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.ability-legend-item{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--text-secondary)}.ability-legend-icon{width:18px;height:18px;border-radius:3px;border:2px solid}.ability-legend-icon-red{border-color:#f44}.ability-legend-icon-purple{border-color:#9b59b6}.ability-legend-icon-orange{border-color:#f39c12}.interruptible-indicator{width:18px;height:18px;border-radius:3px;border:2px dashed #00FF00;background-color:var(--bg-tertiary)}.map-container{flex:1 1 0;min-height:0;min-width:0;overflow:hidden;background-color:#08080f;position:relative}.map-top-center{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:100;display:flex;flex-direction:column;align-items:center;gap:8px}.map-switcher{display:flex;gap:4px;padding:4px;background-color:#14141fe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 20px var(--shadow-color)}.map-switcher-btn{padding:6px 14px;font-size:.85rem;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s ease-out;white-space:nowrap}.map-switcher-btn:hover{color:var(--text-primary);background-color:var(--bg-hover)}.map-switcher-btn.active{color:var(--text-primary);background-color:var(--accent-gold-dim);border-color:var(--accent-gold)}.neutral-summon-warning{max-width:420px;background-color:#14141fe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 20px var(--shadow-color);overflow:hidden}.neutral-summon-warning-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:.85rem;color:var(--text-primary);background:transparent;border:none;cursor:pointer;text-align:left;transition:background-color .15s ease-out}.neutral-summon-warning-trigger:hover{background-color:var(--bg-hover)}.neutral-summon-warning-icon{flex-shrink:0;font-size:1.1rem;color:#f0ad4e}.neutral-summon-warning-label{flex:1;font-weight:500}.neutral-summon-warning-chevron{flex-shrink:0;font-size:.7rem;color:var(--text-secondary)}.neutral-summon-warning-body{padding:0 12px 12px;border-top:1px solid var(--border-color);max-height:50vh;overflow-y:auto}.neutral-summon-warning-body p{margin:0 0 8px;font-size:.8rem;color:var(--text-secondary);line-height:1.4}.neutral-summon-warning-body p:last-child{margin-bottom:0}.neutral-summon-warning-mobs{font-size:.75rem;color:var(--text-tertiary)}.neutral-summon-warning-mobs strong{color:var(--text-secondary)}.neutral-summon-warning-mob-cards{display:flex;flex-direction:column;gap:10px;margin-top:10px}.neutral-summon-mob-card{padding:10px 12px;background:#0006;border:1px solid var(--border-color);border-radius:6px;font-size:12px}.neutral-summon-mob-card-name{font-weight:700;font-size:13px;color:var(--accent-gold);margin-bottom:2px}.neutral-summon-mob-card-meta{font-size:11px;color:var(--text-secondary);margin-bottom:4px}.neutral-summon-mob-card-hp{font-size:11px;color:var(--text-secondary);margin-bottom:6px}.neutral-summon-mob-card-abilities{border-top:1px solid var(--border-color);padding-top:6px;margin-top:4px}.neutral-summon-mob-card-ability{display:flex;align-items:flex-start;gap:8px;margin-bottom:6px;font-size:11px}.neutral-summon-mob-card-ability:last-child{margin-bottom:0}.neutral-summon-mob-card-ability-icon{width:18px;height:18px;border-radius:2px;flex-shrink:0}.neutral-summon-mob-card-ability-text{display:flex;flex-direction:column;gap:2px;min-width:0}.neutral-summon-mob-card-ability-name{font-weight:600;color:var(--text-primary)}.neutral-summon-mob-card-ability-desc{color:var(--text-secondary);font-size:10px;line-height:1.35}.dungeon-map-stage-container{position:absolute;inset:0;width:100%;height:100%}.floating-button{width:48px;height:48px;border-radius:50%;border:1px solid var(--border-color);background-color:#14141fd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-primary);font-size:1.4rem;cursor:pointer;transition:all .15s ease-out;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px var(--shadow-color)}.floating-button:hover{background-color:#252535e6;border-color:var(--border-color);transform:scale(1.05)}.floating-button.active{background-color:var(--accent-blue);border-color:var(--accent-blue)}.floating-patrol-button{position:absolute;top:20px;right:20px;display:flex;gap:8px;z-index:100}.patrol-button{background-color:#2d4a2d;border-color:#4a8a4a}.patrol-button:hover{background-color:#3d5a3d;border-color:#5a9a5a}.patrol-clear-button{width:32px;height:32px;font-size:.9rem;background-color:#4a2d2d;border-color:#8a4a4a}.patrol-clear-button:hover{background-color:#5a3d3d;border-color:#9a5a5a}.floating-patrol-creation{position:absolute;top:20px;right:20px;background-color:#14141fe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:12px;padding:16px;z-index:100;box-shadow:0 4px 20px var(--shadow-color);min-width:200px}.patrol-creation-header{font-size:.9rem;font-weight:600;color:var(--accent-gold);margin-bottom:12px;display:flex;align-items:center;gap:8px}.patrol-creation-header:before{content:"🚶"}.patrol-creation-controls{display:flex;gap:8px;margin-bottom:12px}.patrol-type-button{flex:1;padding:8px 12px;border:1px solid var(--border-subtle);border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s ease-out}.patrol-type-button:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-color);color:var(--text-primary)}.patrol-type-button.active{background-color:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.patrol-type-button:disabled{opacity:.5;cursor:not-allowed}.patrol-creation-hint{font-size:.75rem;color:var(--text-muted);text-align:center}.floating-top-left-stack{position:absolute;top:20px;left:20px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;z-index:100}.floating-top-left-stack .stack-item{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:6px}.floating-top-left-stack .stack-item-play{flex-direction:column}.floating-top-left-stack .floating-button.play-button,.floating-top-left-stack .floating-button.drawing-button,.floating-top-left-stack .floating-button.file-button{width:44px;height:44px;font-size:1.25rem;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.floating-top-left-stack .speed-controls-inline{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:20px;background-color:#14141fd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:0 4px 20px var(--shadow-color)}.floating-top-left-stack .speed-controls-inline .speed-slider{width:64px}.floating-top-left-stack .speed-controls-inline .speed-label{font-size:.75rem;min-width:24px}.floating-top-left-stack .stack-item-relative .file-menu-stack,.floating-top-left-stack .stack-item-relative .drawing-options-menu-stack{position:absolute;left:100%;top:0;margin-left:8px}.floating-top-left-stack .stack-item-relative .file-menu-stack{bottom:auto}.play-button{width:44px;height:44px;font-size:1.25rem}.play-button .play-button-icon{display:inline-block}.play-button:not(.playing) .play-button-icon{transform:translate(1px)}.play-button.playing .play-button-icon{transform:none}.play-button.playing{background-color:#4a90d9;border-color:#5aa0e9;animation:pulse-play 2s infinite}@keyframes pulse-play{0%,to{box-shadow:0 4px 12px #4a90d966}50%{box-shadow:0 4px 20px #4a90d9b3}}.speed-controls{display:flex;align-items:center;gap:8px;background-color:#14141fd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:24px;padding:8px 16px;box-shadow:0 4px 20px var(--shadow-color)}.speed-slider{width:80px;cursor:pointer;accent-color:var(--accent-blue)}.speed-label{font-size:.8rem;color:var(--text-secondary);min-width:30px}.file-button{width:44px;height:44px}.file-menu{position:absolute;background-color:#14141fe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:4px;box-shadow:0 4px 20px var(--shadow-color);min-width:140px}.file-menu button{display:flex;align-items:center;gap:8px;padding:10px 14px;border:none;border-radius:8px;background-color:transparent;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .15s ease-out;text-align:left}.file-menu button:hover{background-color:#ffffff0f}.app-footer{display:flex;justify-content:center;align-items:center;padding:12px 24px;background-color:var(--bg-secondary);border-top:1px solid var(--border-subtle);font-size:.8rem;transition:background-color .2s,border-color .2s}.instructions{color:var(--text-muted);letter-spacing:.3px}.loading{color:#888;font-size:1.2rem}.mode-toggle-section{padding-bottom:8px!important}.mode-toggle{display:flex;background:var(--bg-primary);border-radius:8px;padding:4px;gap:4px}.mode-toggle-btn{flex:1;min-width:0;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.mode-toggle-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.mode-toggle-btn.active{background:var(--accent-gold);color:var(--bg-primary)}.create-pull-row{display:flex;align-items:center;gap:8px}.create-pull-row .cooldown-picker-trigger-btn{flex:0 0 auto;min-width:0}.pull-list{display:flex;flex-direction:column;gap:8px}.pull-empty-state{padding:16px;text-align:center;color:var(--text-muted);font-size:12px;line-height:1.5}.pull-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:10px;cursor:pointer;transition:all .15s ease;position:relative}.pull-item:hover{border-color:var(--accent-gold-dim)}.pull-item-just-created{border-color:var(--accent-gold);background:#1eff0014;animation:pull-just-created-fade 2.2s ease-out forwards}@keyframes pull-just-created-fade{0%{border-color:var(--accent-gold);background:#1eff001f}to{border-color:var(--border-color);background:var(--bg-tertiary)}}.pull-item-dragging{opacity:.5;border-color:var(--accent-gold);border-style:dashed}.pull-item-dragover{border-color:var(--accent-gold);background:#1eff0026;transform:scale(1.02)}.pull-header{display:flex;align-items:center;gap:8px}.pull-header .pull-name{flex:1;font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pull-header .pull-delete-btn{flex-shrink:0}.pull-number-badge{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s ease;padding:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.pull-number-badge:hover{transform:scale(1.1);border-color:#ffffff80;box-shadow:0 0 8px #fff3}.pull-color-picker-container{position:relative}.pull-color-picker-portal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:12px;box-shadow:0 8px 32px #0006;animation:colorPickerFadeIn .15s ease-out}@keyframes colorPickerFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.pull-color-picker-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:200px}.pull-color-option{width:24px;height:24px;border-radius:4px;border:2px solid transparent;cursor:pointer;padding:0;transition:all .15s ease}.pull-color-option:hover{transform:scale(1.1)}.pull-color-option.active{border-color:#fff;box-shadow:0 0 6px #fff6}.pull-meta-row{display:flex;align-items:center;gap:6px;margin-top:4px;margin-left:30px;flex-wrap:wrap}.pull-mob-count{font-size:.7rem;color:var(--text-muted)}.pull-meta-separator{color:var(--text-muted);font-size:.6rem}.pull-has-notes{font-size:.7rem}.pull-map-badge{font-size:.6rem;padding:1px 5px;border-radius:3px;background-color:transparent;color:var(--text-muted);border:1px solid var(--border-color);white-space:nowrap;max-width:100px;overflow:hidden;text-overflow:ellipsis}.pull-map-badge.current{color:var(--text-secondary);border-color:var(--text-muted)}.pull-cooldowns-inline{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;margin-left:0}.pull-cooldowns-inline-icon-wrap{width:20px;height:20px;border-radius:3px;overflow:hidden}.pull-cooldowns-inline-icon{width:20px;height:20px;border-radius:3px;object-fit:cover;display:block}.pull-name{font-weight:500;font-size:13px;color:var(--text-secondary);font-style:italic}.pull-mob-count{font-size:11px;color:var(--text-muted)}.pull-delete-btn{width:26px;height:26px;border:1px solid var(--border-color);border-radius:6px;background:#50282866;color:var(--accent-red);font-size:18px;font-weight:600;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.pull-delete-btn:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.pull-details{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color)}.pull-cooldowns-list-section{margin-top:10px}.pull-cooldowns-list-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.pull-cooldowns-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.pull-cooldowns-list-item{display:flex;align-items:center;gap:8px;font-size:12px}.pull-cooldowns-list-class{font-weight:600;min-width:56px}.pull-cooldowns-list-name{color:var(--text-secondary)}.pull-cooldowns-list-empty{font-size:11px;color:var(--text-muted);font-style:italic}.selected-mob-pulls{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;padding:8px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.selected-mob-pull-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-secondary);border-radius:6px}.selected-mob-pull-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.selected-mob-pull-info{flex:1;font-size:12px;color:var(--text-primary)}.selected-mob-actions{margin-bottom:10px}.selected-mob-cc-btn{padding:4px 8px;border:none;border-radius:4px;background:#9b59b633;color:#9b59b6;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease}.selected-mob-cc-btn:hover{background:#9b59b666}.selected-mob-cc-btn.active{background:#9b59b6;color:#fff}.selected-mob-cc-btn.global-cc-btn{width:100%;padding:8px 12px;font-size:12px;display:flex;align-items:center;justify-content:center}.selected-mob-pull-remove{padding:4px 10px;border:none;border-radius:4px;background:#e74c3c33;color:var(--accent-red);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease}.selected-mob-pull-remove:hover{background:var(--accent-red);color:#fff}.pull-add-selected-btn{width:100%;padding:8px;margin-bottom:10px;border:1px dashed var(--accent-gold);border-radius:6px;background:transparent;color:var(--accent-gold);font-size:12px;cursor:pointer;transition:all .15s ease}.pull-add-selected-btn:hover{background:var(--accent-gold-dim)}.pull-empty-hint{padding:12px;margin-bottom:10px;border:1px dashed var(--border-color);border-radius:6px;background:var(--bg-tertiary);color:var(--text-muted);font-size:12px;text-align:center;line-height:1.4}.pull-stat{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px}.pull-stat-label{color:var(--text-muted)}.pull-stat-value{font-weight:500}.pull-mob-types{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.pull-mob-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}.pull-mob-list{display:flex;flex-direction:column;gap:4px}.pull-mob-item{display:flex;align-items:center;gap:6px;padding:4px 6px;background:var(--bg-secondary);border-radius:4px;font-size:11px}.pull-mob-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.pull-mob-name{flex:1;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pull-mob-remove{width:16px;height:16px;border:none;border-radius:3px;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .15s ease}.pull-mob-item:hover .pull-mob-remove{opacity:1}.pull-mob-remove:hover{background:var(--accent-red);color:#fff}.pull-mob-type-group{margin-bottom:4px}.pull-mob-type{display:flex;align-items:flex-start;gap:6px;font-size:12px;color:var(--text-secondary);padding:8px;border-radius:4px;cursor:pointer;transition:all .15s ease}.pull-mob-type:hover{background:var(--bg-hover)}.pull-mob-type-expanded{background:var(--bg-tertiary)}.pull-mob-type-expand{font-size:8px;color:var(--text-muted);width:12px;flex-shrink:0;margin-top:4px}.pull-mob-type-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.pull-mob-type-header{display:flex;align-items:center;gap:6px}.pull-mob-type-name{flex:1;font-weight:500;color:var(--text-primary)}.pull-mob-type-count{color:var(--text-muted);font-size:11px}.pull-mob-type-stats{display:flex;flex-wrap:wrap;gap:8px;font-size:10px}.pull-mob-hp{color:var(--accent-green);font-weight:500}.pull-mob-abilities{color:var(--text-muted);font-style:italic}.pull-total-hp{background:#2ecc711a;padding:6px 10px;border-radius:6px;margin-bottom:8px}.pull-total-hp .pull-stat-value{color:var(--accent-green);font-weight:600}.pull-mob-type-individuals{margin-left:20px;margin-top:4px;padding-left:8px;border-left:1px solid var(--border-color)}.pull-mob-individual{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:4px;font-size:11px;transition:all .15s ease;cursor:default}.pull-mob-individual:hover{background:var(--bg-hover)}.pull-mob-individual-hovered{background:#00ff0026;border:1px solid rgba(0,255,0,.3)}.pull-mob-individual .pull-mob-remove{opacity:0}.pull-mob-individual:hover .pull-mob-remove{opacity:1}.pull-has-notes{font-size:12px;opacity:.7;flex-shrink:0}.pull-notes-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.pull-notes-label{display:block;font-size:11px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.pull-notes-input{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:12px;font-family:inherit;line-height:1.4;resize:vertical;min-height:60px;transition:border-color .15s ease}.pull-notes-input:focus{outline:none;border-color:var(--accent-gold)}.pull-notes-input::placeholder{color:var(--text-muted)}.pull-sticky-note{background:linear-gradient(135deg,#fff9c4,#fff59d);border:1px solid #1eff00;border-radius:4px;padding:0;min-width:200px;max-width:280px;box-shadow:0 4px 12px #0000004d,2px 2px #1eff004d;transform:rotate(-1deg);font-family:Comic Sans MS,Segoe UI,sans-serif}.pull-sticky-header{display:flex;align-items:center;gap:6px;padding:8px 10px;background:#1eff0026;border-bottom:1px dashed #1eff00;border-radius:4px 4px 0 0;cursor:grab}.pull-sticky-header:active{cursor:grabbing}.pull-sticky-drag-handle{font-size:10px;color:#8d6e63;letter-spacing:-2px;opacity:.6;-webkit-user-select:none;user-select:none}.pull-sticky-icon{font-size:14px}.pull-sticky-title{font-size:12px;font-weight:600;color:#5d4037;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pull-sticky-textarea{width:100%;padding:10px;border:none;background:transparent;color:#3e2723;font-size:12px;font-family:inherit;line-height:1.5;resize:none;min-height:80px}.pull-sticky-textarea:focus{outline:none}.pull-sticky-textarea::placeholder{color:#8d6e63;font-style:italic}.drawing-button.active{background:var(--accent-gold)!important;color:var(--bg-primary)!important}.drawing-options-menu{background:#14141ff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:10px;padding:12px;margin-top:4px;box-shadow:0 4px 20px var(--shadow-color);min-width:180px}.drawing-option-group{margin-bottom:12px}.drawing-option-group:last-child{margin-bottom:0}.drawing-option-label{display:block;font-size:11px;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.stroke-width-options{display:flex;gap:8px}.stroke-width-btn{width:40px;height:32px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.stroke-width-btn:hover{border-color:var(--accent-gold-dim);background:var(--bg-hover)}.stroke-width-btn.active{border-color:var(--accent-gold);background:var(--accent-gold-dim)}.stroke-preview{width:24px;border-radius:2px}.color-options{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.color-btn{width:28px;height:28px;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s ease}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:#fff;box-shadow:0 0 8px #ffffff4d}.color-btn[style*="background-color: rgb(0, 0, 0)"],.color-btn[style*="background-color: #000000"]{border-color:var(--border-color)}.color-btn[style*="background-color: rgb(0, 0, 0)"].active,.color-btn[style*="background-color: #000000"].active{border-color:#fff}.clear-drawings-btn{width:100%;padding:8px 12px;background:#ff505033;border:1px solid rgba(255,80,80,.4);border-radius:6px;color:#ff6b6b;font-size:12px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:6px}.clear-drawings-btn:hover{background:#ff50504d;border-color:#ff505099}.share-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.share-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:90%;max-width:600px;box-shadow:0 20px 60px #00000080}.share-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.share-modal-header h3{margin:0;color:var(--accent-gold);font-size:18px}.share-modal-close{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s ease}.share-modal-close:hover{background:#ffffff1a;color:var(--text-primary)}.share-modal-content{padding:20px}.share-modal-content p{margin:0 0 12px;color:var(--text-secondary)}.share-url-container{display:flex;gap:8px;margin-bottom:16px}.share-url-input{flex:1;padding:12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:13px;font-family:monospace}.share-url-input:focus{outline:none;border-color:var(--accent-gold)}.share-copy-btn{padding:12px 20px;background:var(--accent-gold);border:none;border-radius:6px;color:#000;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}.share-copy-btn:hover{background:#e6c200;transform:translateY(-1px)}.share-note{font-size:12px;color:var(--text-muted);margin-top:8px}.settings-modal{max-width:420px}.settings-modal-content{padding:20px}.settings-section-title{font-weight:600;color:var(--text-primary);margin-bottom:4px!important}.settings-note{font-size:12px;color:var(--text-muted);margin-bottom:16px!important}.settings-keybindings-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.settings-keybinding-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-keybinding-label{font-size:13px;color:var(--text-secondary);flex:1}.settings-keybinding-btn{padding:6px 12px;font-size:12px;font-family:inherit;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;min-width:80px}.settings-keybinding-btn:hover{border-color:var(--accent-gold-dim);background:var(--bg-hover)}.settings-keybinding-recording{font-size:12px;color:var(--accent-gold);font-style:italic}.settings-reset-btn{padding:8px 16px;font-size:12px;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer}.settings-reset-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.party-members-list{display:flex;flex-direction:column;gap:8px}.party-member-row{display:flex;flex-direction:column;gap:6px;padding:10px;background:var(--bg-tertiary);border-radius:6px;border:1px solid var(--border-color)}.party-member-role{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.party-class-icons{display:flex;flex-wrap:wrap;gap:4px}.party-class-icon-btn{width:32px;height:32px;padding:0;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .15s ease;overflow:hidden}.party-class-icon-btn img{width:100%;height:100%;display:block;border-radius:2px}.party-class-icon-btn:hover{border-color:var(--text-muted);transform:scale(1.05)}.party-class-icon-btn.selected{border-width:2px}.party-member-cooldowns{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.party-cooldown-btn{width:28px;height:28px;padding:2px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .15s;opacity:.5}.party-cooldown-btn:hover{border-color:var(--text-muted);opacity:.8}.party-cooldown-btn.selected{border-color:var(--accent-gold);opacity:1;box-shadow:0 0 6px var(--accent-gold-dim)}.party-cooldown-icon{width:100%;height:100%;border-radius:2px;object-fit:cover}.pull-cooldown-pull-name{font-weight:400;color:var(--text-secondary);font-size:11px;margin-left:8px}.pull-cooldowns-grid{display:flex;flex-direction:column;gap:10px}.pull-cooldown-member{display:flex;flex-direction:column;gap:6px}.pull-cooldown-member-label{font-size:11px;font-weight:600}.pull-cooldown-member-cds{display:flex;flex-wrap:wrap;gap:4px}.pull-cooldown-assign-btn{position:relative;width:32px;height:32px;padding:2px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .15s}.pull-cooldown-assign-btn:hover{border-color:var(--text-muted);transform:scale(1.05)}.pull-cooldown-assign-btn.assigned{border-color:var(--accent-green);box-shadow:0 0 8px #3fb95066}.pull-cooldown-icon{width:100%;height:100%;border-radius:2px;object-fit:cover}.pull-cooldown-check{position:absolute;bottom:-4px;right:-4px;width:14px;height:14px;background:var(--accent-green);border-radius:50%;font-size:10px;line-height:14px;text-align:center;color:#fff;font-weight:700}.pull-cooldown-empty{padding:12px;text-align:center;color:var(--text-muted);font-size:12px;background:var(--bg-tertiary);border-radius:6px;border:1px dashed var(--border-color)}.annotate-actions{display:flex;gap:8px;padding:12px 16px!important}.annotate-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:12px;cursor:pointer;transition:all .15s}.annotate-action-btn:hover{background:var(--bg-hover);border-color:var(--accent-gold-dim)}.party-setup-highlight{animation:party-setup-pulse 1.5s ease-in-out infinite;border-color:var(--accent-gold)!important;box-shadow:0 0 12px #ffd70080,inset 0 0 4px #ffd70033}@keyframes party-setup-pulse{0%,to{box-shadow:0 0 8px #ffd70066,inset 0 0 4px #ffd7001a}50%{box-shadow:0 0 20px #ffd700b3,inset 0 0 6px #ffd7004d}}.annotate-action-icon{font-size:14px}.annotate-action-badge{background:var(--accent-gold);color:var(--bg-primary);font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;margin-left:4px}.pull-cooldowns-section{margin-top:10px;border-top:1px solid var(--border-subtle);padding-top:10px}.pull-cooldowns-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:all .15s}.pull-cooldowns-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.pull-cooldowns-toggle-icon{font-size:8px;color:var(--text-muted)}.pull-cooldowns-badge{background:var(--accent-green);color:#fff;font-size:10px;font-weight:600;padding:1px 5px;border-radius:8px;margin-left:auto}.pull-cooldowns-content{margin-top:8px;display:flex;flex-direction:column;gap:4px}.pull-cooldown-class{margin-bottom:2px}.pull-cooldown-class-header{display:flex;align-items:center;gap:6px;width:100%;padding:4px 6px;background:var(--bg-tertiary);border:none;border-radius:4px;cursor:pointer;text-align:left;transition:background .15s}.pull-cooldown-class-header:hover{background:var(--bg-hover)}.pull-cooldown-class-header.collapsed{background:transparent}.pull-cooldown-class-header.collapsed:hover{background:var(--bg-tertiary)}.pull-cooldown-class-arrow{font-size:8px;color:var(--text-muted);width:10px}.pull-cooldown-class-indicator{width:4px;height:14px;border-radius:2px;flex-shrink:0}.pull-cooldown-class-name{font-size:11px;font-weight:600;flex:1}.pull-cooldown-class-badge{background:var(--accent-green);color:#fff;font-size:9px;font-weight:600;padding:1px 5px;border-radius:8px}.pull-cooldown-class-cds{display:flex;gap:4px;flex-wrap:wrap;padding:6px 6px 8px 20px}.pull-cooldown-assign-btn{width:26px;height:26px;padding:2px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);cursor:pointer;position:relative;transition:all .15s}.pull-cooldown-assign-btn:hover{border-color:var(--border-hover);transform:scale(1.05)}.pull-cooldown-assign-btn.assigned{border:2px solid var(--accent-green);background:#4caf5026}.pull-cooldown-icon{width:100%;height:100%;border-radius:2px;opacity:.6}.pull-cooldown-assign-btn.assigned .pull-cooldown-icon{opacity:1}.pull-cooldown-check{position:absolute;bottom:-2px;right:-2px;font-size:10px;color:var(--accent-green);font-weight:700}.inline-cooldown-picker-box{min-width:260px;max-width:320px;max-height:min(70vh,420px);overflow-y:auto;overflow-x:hidden;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #0006;padding:14px}.inline-cooldown-picker-portal .pull-cooldown-assign-btn{width:30px;height:30px;padding:2px}.inline-cooldown-picker-portal .pull-cooldown-class-cds{gap:6px;padding:8px 0 0}.inline-cooldown-picker-portal .pull-cooldown-check{font-size:10px;bottom:-2px;right:-2px}.inline-cooldown-class-strip{display:flex;flex-wrap:nowrap;gap:4px;padding-bottom:10px;margin-bottom:0;border-bottom:1px solid var(--border-color);overflow-x:auto;overflow-y:hidden;min-height:28px;align-items:center}.inline-cooldown-class-strip::-webkit-scrollbar{height:4px}.inline-cooldown-class-strip::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.inline-cooldown-class-icon-btn{position:relative;width:24px;height:24px;padding:0;border:2px solid var(--border-color);border-radius:4px;background:var(--bg-tertiary);cursor:pointer;transition:border-color .15s,box-shadow .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.inline-cooldown-class-icon-btn img{width:100%;height:100%;border-radius:2px;object-fit:cover}.inline-cooldown-class-icon-btn:hover{border-color:var(--text-muted)}.inline-cooldown-class-icon-btn.selected{border-color:var(--accent-gold);box-shadow:0 0 0 2px #ffd7004d}.inline-cooldown-class-badge{position:absolute;bottom:-3px;right:-3px;min-width:10px;height:10px;padding:0 2px;background:var(--accent-green);color:#fff;font-size:8px;font-weight:600;border-radius:5px;display:flex;align-items:center;justify-content:center}.inline-cooldown-picker-portal .inline-cooldown-grid .pull-cooldown-class-cds{padding:8px 0 0}.inline-cooldown-picker-portal .pull-cooldowns-content.inline-cooldown-grid{margin-top:0}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:500px;width:90%;max-height:80vh;overflow:hidden;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 var(--border-color)}.modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--accent-gold)}.modal-close{width:28px;height:28px;border:none;background:var(--bg-tertiary);border-radius:6px;color:var(--text-secondary);font-size:18px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-hint{color:var(--text-muted);font-size:12px;margin-bottom:16px}.modal-footer{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:8px}.modal-btn-primary{padding:8px 20px;background:var(--accent-gold);border:none;border-radius:6px;color:var(--bg-primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.modal-btn-primary:hover{filter:brightness(1.1)}.party-modal .party-members-list{gap:12px}.party-modal .party-member-row{padding:12px}.party-modal .party-class-icon-btn{width:36px;height:36px}.party-modal .party-cooldown-btn{width:32px;height:32px}@media(max-width:768px){.toolbar{gap:10px;padding:8px 12px}.toolbar-label{display:none}.tool-button{width:32px;height:32px;font-size:1rem}.sidebar-title{font-size:1.3rem}.sidebar-tagline{font-size:.65rem}.legend{flex-wrap:wrap;gap:8px}.sidebar{width:220px;min-width:220px}}.map-role-legend-top-right{position:absolute;top:12px;right:12px;z-index:100}.map-role-legend-inner{padding:10px 14px;background-color:#14141fe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 20px var(--shadow-color)}.map-role-legend-inner .role-legend{margin-bottom:0}.map-role-legend-hint{font-size:11px;color:var(--text-secondary);margin:8px 0 0;padding:0}.map-controls-overlay{position:absolute;inset:auto auto 10px 10px;display:flex;align-items:stretch;gap:8px;z-index:1000}.map-control-box{height:36px;min-height:36px;max-height:36px;padding:0 12px;box-sizing:border-box;background-color:#000c;color:gold;font-size:12px;font-family:monospace;border-radius:4px;border:1px solid #333;display:flex;align-items:center;justify-content:center;gap:4px}.map-control-box .zoom-buttons{display:flex;align-items:center;gap:4px}.map-control-box button.zoom-btn{width:24px;height:24px;padding:0;border:1px solid #555;border-radius:4px;background:#2a2a2a;color:gold;cursor:pointer;font-size:12px;line-height:1;flex-shrink:0}.map-control-box .zoom-value{min-width:44px;text-align:center;font-size:12px}.map-key-wrapper{display:flex;flex-direction:column;align-items:flex-start;position:relative}.map-key-tooltip-floating{position:absolute;bottom:100%;left:0;margin-bottom:8px;z-index:10}.map-key-btn{min-width:36px;height:36px;padding:0 10px;border-radius:4px;border:1px solid #333;background:#000c;color:gold;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.map-key-btn:hover{background:#282828f2;border-color:#1eff0066}.map-key-icon{font-size:1rem;line-height:1;margin-right:6px}.map-key-label{font-size:.85rem;font-weight:500;line-height:1}.map-key-tooltip{margin-bottom:0}.map-key-tooltip-inner{padding:12px 14px;background:#141414f5;border:1px solid var(--border-subtle);border-radius:6px;box-shadow:0 4px 20px #00000080;min-width:180px;font-size:.75rem;color:var(--text-primary)}.map-key-tooltip-inner .role-legend{margin-bottom:10px}.map-key-tooltip-inner .role-legend:last-child,.map-key-tooltip-inner .ability-legend{margin-bottom:0}.xp-settings-section{margin-top:8px}.xp-settings-toggle{display:flex;align-items:center;width:100%;padding:10px 12px;background:#0000004d;border:1px solid var(--border-subtle);border-radius:6px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s,border-color .15s;gap:8px}.xp-settings-toggle:hover{background:#0006;border-color:var(--border-hover, rgba(255, 255, 255, .2))}.xp-settings-toggle-icon{font-size:10px;color:var(--text-secondary);transition:transform .2s}.xp-settings-toggle-label{flex:1;font-size:.8rem;font-weight:600;color:var(--text-primary);text-align:left}.xp-settings-panel{padding:10px;background:#0003;border:1px solid var(--border-subtle);border-top:none;border-radius:0 0 6px 6px;margin-top:-1px}.xp-panel-hint{font-size:.7rem;color:var(--text-secondary);margin:0 0 10px;padding:8px 10px;background:#ffffff08;border-radius:4px;line-height:1.4}.xp-party-section{display:flex;flex-direction:column;gap:4px}.xp-player-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#00000040;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .15s}.xp-player-row:hover{background:#00000059;border-color:var(--border-subtle)}.xp-player-row-active{background:#8b5cf614;border-color:#8b5cf666}.xp-player-row-active:hover{border-color:#8b5cf680}.xp-player-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.xp-player-top{display:flex;align-items:center;gap:10px}.xp-player-name{font-size:.8rem;color:var(--text-primary);font-weight:500}.xp-player-level-wrap{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary)}.xp-player-level{width:42px;padding:5px 6px;border-radius:5px;border:1.5px solid rgba(30,255,0,.5);background:#0000004d;color:var(--accent-gold);font-size:.9rem;text-align:center;font-family:monospace;font-weight:600}.xp-player-level:hover{border-color:#1eff00b3}.xp-player-level:focus{outline:none;border-color:var(--accent-gold)}.xp-viewing-tag{font-size:.6rem;color:#a78bfa;background:#8b5cf626;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;white-space:nowrap}.xp-player-bottom{display:flex;align-items:center}.xp-player-total{font-size:.75rem;color:#a78bfa;font-weight:500;font-family:monospace}.xp-player-total-zero{color:var(--text-disabled)}.xp-player-remove{flex-shrink:0;padding:4px 8px;border-radius:4px;background:transparent;border:none;color:var(--text-disabled);font-size:16px;line-height:1;cursor:pointer;transition:all .15s;opacity:0}.xp-player-row:hover .xp-player-remove{opacity:1}.xp-player-remove:hover{color:#ef4444;background:#ef44441a}.xp-add-player{width:100%;padding:8px;margin-top:4px;border-radius:6px;background:transparent;border:1px dashed var(--border-subtle);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s}.xp-add-player:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#ffd7000d}.xp-panel-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-subtle)}.xp-rested-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.7rem;color:var(--text-secondary)}.xp-rested-toggle input{width:14px;height:14px;accent-color:#4ade80}.xp-rested-toggle:hover{color:var(--text-primary)}.xp-no-data{font-size:.65rem;color:#eab308;opacity:.8}.route-total-xp-tag{display:flex;flex-direction:column;gap:4px;margin:12px 0 4px;padding:8px 10px;background:#8b5cf614;border-radius:6px;border:1px solid rgba(139,92,246,.15)}.route-total-xp-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.route-total-xp-value{font-size:.75rem;color:#a78bfa;font-family:monospace;font-weight:600}.route-xp-player-select{font-size:.65rem;padding:2px 6px;border-radius:4px;border:1px solid rgba(139,92,246,.3);background:#8b5cf61a;color:var(--text-secondary);cursor:pointer;outline:none}.route-xp-player-select:hover{border-color:#8b5cf680;background:#8b5cf626}.route-xp-player-select:focus{border-color:#a78bfa}.route-total-xp-player{font-size:.6rem;color:var(--text-secondary)}.pull-xp-value{font-size:.7rem;color:#a78bfa;font-family:monospace}.pull-xp-gray{margin-left:4px;font-size:.65rem;color:#9ca3af}.pull-meta-separator{color:var(--text-disabled);margin:0 4px}.xp-player-max-level{color:var(--accent-gold);font-style:italic;font-family:inherit}.xp-player-no-pulls{color:var(--text-disabled);font-style:italic;font-family:inherit;font-size:.7rem}.route-total-xp-max-level{color:var(--accent-gold);font-style:italic}.route-total-xp-no-pulls{color:var(--text-secondary);font-style:italic;font-size:.7rem}.route-total-xp-instance{font-size:.65rem;color:var(--text-disabled);font-family:monospace}.xp-widget{margin:12px 0 4px;background:#8b5cf614;border-radius:8px;border:1px solid rgba(139,92,246,.15)}.xp-widget-title{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.xp-widget-header{display:flex;flex-direction:column;gap:6px;padding:10px 12px;cursor:pointer;transition:background .15s}.xp-widget-header-row{display:flex;align-items:center;justify-content:space-between}.xp-widget-header:hover{background:#8b5cf61f}.xp-widget-summary{display:flex;align-items:center;gap:8px}.xp-widget-value{font-size:.85rem;color:#a78bfa;font-family:monospace;font-weight:600}.xp-widget-route-xp,.xp-widget-instance-xp{position:relative;cursor:help;border-bottom:1px dotted rgba(167,139,250,.4)}.xp-widget-route-xp:after,.xp-widget-instance-xp:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:0;padding:5px 8px;background:#1a1a24;border:1px solid var(--border-color);border-radius:4px;font-size:.65rem;font-family:inherit;font-weight:500;color:var(--text-primary);white-space:nowrap;box-shadow:0 4px 12px #00000080;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;z-index:9999;pointer-events:none}.xp-widget-route-xp:hover:after,.xp-widget-instance-xp:hover:after{opacity:1;visibility:visible}.xp-widget-route-xp:hover,.xp-widget-instance-xp:hover{border-bottom-color:#a78bfa}.xp-widget-value.xp-widget-max-level{color:var(--accent-gold);font-style:italic;font-family:inherit}.xp-widget-value.xp-widget-no-pulls{color:var(--text-muted);font-style:italic;font-family:inherit;font-size:.8rem}.xp-widget-rested-badge{font-size:.75rem;opacity:.8}.xp-widget-controls{display:flex;align-items:center;gap:6px}.xp-widget-player-select{font-size:.7rem;padding:4px 8px;border-radius:4px;border:1px solid rgba(139,92,246,.3);background:#8b5cf61a;color:var(--text-secondary);cursor:pointer;outline:none}.xp-widget-player-select:hover{border-color:#8b5cf680;background:#8b5cf626}.xp-widget-player-select:focus{border-color:#a78bfa}.xp-widget-expand-btn{width:24px;height:24px;padding:0;border:none;border-radius:4px;background:#8b5cf626;color:#a78bfa;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.xp-widget-expand-btn:hover{background:#8b5cf640}.xp-widget-panel{border-top:1px solid rgba(139,92,246,.15);padding:10px 12px;background:#00000026}.xp-widget-players{display:flex;flex-direction:column;gap:6px}.xp-widget-player{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#0003;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .15s}.xp-widget-player:hover{background:#0000004d;border-color:#8b5cf633}.xp-widget-player-selected{background:#8b5cf61f;border-color:#8b5cf666}.xp-widget-player-selected:hover{border-color:#8b5cf680}.xp-widget-player-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.xp-widget-player-name{font-size:.8rem;color:var(--text-primary);font-weight:500;display:flex;align-items:center;gap:6px}.xp-widget-viewing{font-size:.6rem;color:#a78bfa;background:#8b5cf626;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px;font-weight:600}.xp-widget-player-xp{font-size:.7rem;color:#a78bfa;font-family:monospace}.xp-widget-player-xp .xp-widget-max-level{color:var(--accent-gold);font-style:italic;font-family:inherit}.xp-widget-player-xp .xp-widget-no-pulls{color:var(--text-muted)}.xp-widget-player-level{display:flex;align-items:center;gap:4px;flex-shrink:0}.xp-widget-level-label{font-size:.7rem;color:var(--text-secondary)}.xp-widget-level-input{width:42px;padding:5px 6px;border-radius:5px;border:1.5px solid rgba(30,255,0,.5);background:#0000004d;color:var(--accent-gold);font-size:.9rem;text-align:center;font-family:monospace;font-weight:600}.xp-widget-level-input:hover{border-color:#1eff00b3}.xp-widget-level-input:focus{outline:none;border-color:var(--accent-gold)}.xp-widget-player-remove{flex-shrink:0;width:20px;height:20px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-size:14px;cursor:pointer;opacity:0;transition:all .15s;display:flex;align-items:center;justify-content:center}.xp-widget-player:hover .xp-widget-player-remove{opacity:1}.xp-widget-player-remove:hover{color:#ef4444;background:#ef44441a}.xp-widget-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid rgba(139,92,246,.15)}.xp-widget-add-player{padding:6px 12px;border-radius:5px;background:transparent;border:1px dashed rgba(139,92,246,.3);color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:all .15s}.xp-widget-add-player:hover{border-color:#a78bfa;color:#a78bfa;background:#8b5cf61a}.xp-widget-formula-label{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--text-secondary)}.xp-widget-formula-select{font-size:.7rem;padding:2px 6px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary)}.xp-widget-formula-select:focus{outline:none;border-color:var(--accent-gold)}.xp-widget-rested-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.7rem;color:var(--text-secondary);margin-left:auto}.xp-widget-rested-toggle input{width:14px;height:14px;accent-color:#a78bfa}.xp-widget-rested-toggle:hover{color:var(--text-primary)}
