.loot-explorer-page{min-height:100vh;background:linear-gradient(180deg,#0a0a0f,#12121a);color:#e0e0e0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;gap:1.5rem}.loading-spinner{width:64px;height:64px;border:4px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{font-size:1.25rem;color:#a78bfa;animation:pulse 2s ease-in-out infinite}.loot-explorer-header{position:relative;padding:3rem 2rem;overflow:hidden}.header-background{position:absolute;inset:0;background:url(/images/zones/WorldZonesConcept.webp) 50%/cover;opacity:.15}.header-gradient{position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(10,10,15,.8) 70%,#0a0a0f)}.header-content{position:relative;text-align:center;max-width:800px;margin:0 auto}.page-title{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#f59e0b,#8b5cf6 50%,#22c55e);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 40px rgba(139,92,246,.3);margin-bottom:.5rem}.title-icon{display:inline-block;margin-right:.5rem;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.page-subtitle{font-size:1.25rem;color:#9ca3af}.loot-explorer-content{display:grid;grid-template-columns:280px 1fr 280px;gap:1.5rem;padding:0 2rem 3rem;max-width:1600px;margin:0 auto}@media (max-width:1200px){.loot-explorer-content{grid-template-columns:1fr}.history-panel{order:-1}}.config-panel{display:flex;flex-direction:column;gap:1.5rem}.config-section{background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.25rem;backdrop-filter:blur(10px)}.config-title{font-size:.875rem;font-weight:600;color:#a78bfa;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.05em}.config-icon{font-size:1rem}.zone-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.zone-button{position:relative;aspect-ratio:1.5;border:2px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;background:transparent;padding:0}.zone-button:hover{border-color:var(--zone-color,#8b5cf6);transform:scale(1.02)}.zone-button.active{border-color:var(--zone-color,#8b5cf6);box-shadow:0 0 20px rgba(var(--zone-color),.3),inset 0 0 30px rgba(0,0,0,.5)}.zone-button-bg{position:absolute;inset:0}.zone-button-image{object-fit:cover;opacity:.6;transition:opacity .3s ease}.zone-button.active .zone-button-image,.zone-button:hover .zone-button-image{opacity:.8}.zone-button-content{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:linear-gradient(180deg,transparent,rgba(0,0,0,.7));color:white;text-shadow:0 2px 4px rgba(0,0,0,.8)}.zone-number{font-size:1.5rem;font-weight:800;opacity:.9}.zone-name{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.tier-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.tier-button{display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;background:rgba(20,20,30,.6);border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#9ca3af;cursor:pointer;transition:all .3s ease}.tier-button:hover{border-color:var(--zone-color,#8b5cf6);transform:translateY(-2px)}.tier-button.active{background:rgba(139,92,246,.2);border-color:var(--zone-color,#8b5cf6);color:white;box-shadow:0 4px 15px rgba(139,92,246,.3)}.tier-stars{font-size:.75rem;color:#fbbf24;margin-bottom:.25rem}.tier-label{font-size:.625rem;font-weight:600;text-transform:uppercase}.faction-buttons{display:flex;flex-direction:column;gap:.5rem}.faction-button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:rgba(20,20,30,.6);border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#9ca3af;cursor:pointer;transition:all .3s ease;text-align:left}.faction-button:hover{border-color:#8b5cf6;background:rgba(139,92,246,.1)}.faction-button.active{background:rgba(139,92,246,.2);border-color:#8b5cf6;color:white}.faction-icon{font-size:1.25rem}.faction-name{font-size:.875rem;font-weight:500}.no-factions{padding:1rem;color:#6b7280;font-size:.875rem;text-align:center}.session-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1rem}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-value{font-size:1.75rem;font-weight:800;color:#a78bfa}.stat-item.rare .stat-value{color:#fbbf24}.stat-label{font-size:.625rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.chest-container,.simulator-panel{display:flex;flex-direction:column;gap:1.5rem}.chest-container{align-items:center;padding:3rem 2rem;background:linear-gradient(180deg,rgba(30,30,40,.4),rgba(20,20,30,.8));border:1px solid rgba(255,255,255,.1);border-radius:24px;backdrop-filter:blur(10px)}.table-info{flex-direction:column}.table-info,.table-name-parts{display:flex;align-items:center;gap:.5rem}.table-name-parts{font-size:1.125rem;font-weight:600}.table-zone{font-weight:700}.table-separator{color:#4b5563;font-size:.75rem}.table-faction{color:#e0e0e0}.table-tier{color:#fbbf24}.table-stats{font-size:.75rem;color:#6b7280}.chest-visual{position:relative;width:160px;height:160px;cursor:pointer;transition:transform .3s ease}.chest-visual:hover:not(.disabled){transform:scale(1.1)}.chest-visual.disabled{opacity:.5;cursor:not-allowed}.chest-visual.opening{animation:chestShake .5s ease-in-out}@keyframes chestShake{0%,to{transform:translateX(0) rotate(0deg)}20%{transform:translateX(-8px) rotate(-3deg)}40%{transform:translateX(8px) rotate(3deg)}60%{transform:translateX(-6px) rotate(-2deg)}80%{transform:translateX(6px) rotate(2deg)}}.chest-glow{position:absolute;inset:-20px;background:radial-gradient(circle,var(--zone-color,rgba(139,92,246,.3)) 0,transparent 70%);opacity:.6;animation:glowPulse 2s ease-in-out infinite}@keyframes glowPulse{0%,to{transform:scale(1);opacity:.4}50%{transform:scale(1.1);opacity:.7}}.chest-image{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 8px 16px rgba(0,0,0,.5))}.chest-particles{position:absolute;inset:0;pointer-events:none}.open-button{padding:1rem 3rem;font-size:1.25rem;font-weight:700;color:white;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px rgba(139,92,246,.4);text-transform:uppercase;letter-spacing:.1em}.open-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 30px rgba(139,92,246,.5)}.open-button:disabled{opacity:.5;cursor:not-allowed}.open-button.opening{background:linear-gradient(135deg,#f59e0b,#ef4444);animation:buttonPulse .5s ease-in-out infinite}@keyframes buttonPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.quick-actions{display:flex;gap:.75rem}.quick-action{padding:.5rem 1rem;font-size:.75rem;font-weight:600;color:#9ca3af;background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.1);border-radius:20px;cursor:pointer;transition:all .3s ease}.quick-action:hover{background:rgba(139,92,246,.2);border-color:#8b5cf6;color:white}.loot-display{background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;min-height:200px}.loot-display-title{font-size:1rem;font-weight:600;color:#a78bfa;text-align:center;margin-bottom:1rem}.loot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.loot-item{position:relative;display:flex;align-items:center;gap:.75rem;padding:.75rem;background:rgba(20,20,30,.8);border:2px solid var(--rarity-color,rgba(255,255,255,.1));border-radius:12px;text-decoration:none;color:white;transition:all .3s ease;overflow:hidden}.loot-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.3)}.loot-item-glow{position:absolute;inset:0;background:linear-gradient(135deg,var(--rarity-color,transparent) 0,transparent 100%);opacity:.1}.loot-item-icon{position:relative;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);border-radius:8px}.loot-quantity{position:absolute;bottom:2px;right:2px;font-size:.625rem;font-weight:700;color:white;background:rgba(0,0,0,.7);padding:.125rem .25rem;border-radius:4px}.loot-item-info{flex:1;min-width:0}.loot-item-name{display:block;font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loot-item-chance{display:block;font-size:.625rem;color:#6b7280;margin-top:.125rem}.loot-rarity-badge{position:absolute;top:.5rem;right:.5rem;font-size:.5rem;font-weight:700;text-transform:uppercase;padding:.125rem .375rem;border-radius:4px;color:white}.loot-empty{display:flex;align-items:center;justify-content:center;height:150px;color:#6b7280}.drop-rates-section{background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem}.drop-rates-header{margin-bottom:1rem}.section-title{font-size:1rem;font-weight:600;color:#a78bfa}.sort-toggle{font-size:.75rem;padding:.375rem .75rem;border-radius:6px}.drop-rates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.drop-rates-grid::-webkit-scrollbar{width:6px}.drop-rates-grid::-webkit-scrollbar-track{background:rgba(255,255,255,.05);border-radius:3px}.drop-rates-grid::-webkit-scrollbar-thumb{background:rgba(139,92,246,.4);border-radius:3px}.drop-rates-grid::-webkit-scrollbar-thumb:hover{background:rgba(139,92,246,.6)}.drop-rate-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:rgba(20,20,30,.6);border:1px solid rgba(255,255,255,.05);border-radius:10px;transition:all .2s ease;text-decoration:none;color:inherit;cursor:pointer}.drop-rate-card:hover{background:rgba(30,30,45,.8);border-color:rgba(139,92,246,.2)}.drop-rate-info{flex:1;min-width:0}.drop-rate-name{display:block;font-size:.8rem;margin-bottom:.375rem}.drop-rate-bar{height:6px}.drop-rate-bar,.drop-rate-fill{border-radius:3px}.drop-rate-percent{font-size:.875rem;min-width:50px}.history-panel{display:flex;flex-direction:column;gap:1rem;background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.25rem;backdrop-filter:blur(10px);max-height:calc(100vh - 200px);overflow-y:auto}.panel-title{font-size:.875rem;font-weight:600;color:#a78bfa;text-transform:uppercase;letter-spacing:.05em}.history-list{gap:.5rem}.history-entry,.history-list{display:flex;flex-direction:column}.history-entry{gap:.25rem;padding:.75rem;background:rgba(20,20,30,.6);border-radius:8px}.history-number{font-size:.625rem;font-weight:700;color:#6b7280;margin-bottom:.25rem}.history-items{display:flex;flex-direction:column;gap:.375rem}.history-item-row{display:flex;align-items:center;gap:.5rem}.history-item-icon{width:28px;height:28px;background:rgba(0,0,0,.3);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.history-item-name{font-size:.75rem;color:#e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-qty{font-size:.625rem;font-weight:700;color:#fbbf24}.history-empty{font-size:.625rem;color:#6b7280;font-style:italic}.history-placeholder{padding:2rem 1rem;color:#6b7280;font-size:.75rem;text-align:center}.table-preview{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.drop-rates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.sort-toggle{font-size:.625rem;font-weight:600;color:#a78bfa;background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.3);padding:.25rem .5rem;border-radius:4px;cursor:pointer;transition:all .2s ease}.sort-toggle:hover{background:rgba(139,92,246,.25);border-color:rgba(139,92,246,.5)}.drop-rates-list{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto;padding-right:.25rem}.drop-rates-list::-webkit-scrollbar{width:4px}.drop-rates-list::-webkit-scrollbar-track{background:rgba(255,255,255,.05);border-radius:2px}.drop-rates-list::-webkit-scrollbar-thumb{background:rgba(139,92,246,.4);border-radius:2px}.drop-rates-list::-webkit-scrollbar-thumb:hover{background:rgba(139,92,246,.6)}.drop-rate-item{display:grid;grid-template-columns:28px 1fr 60px 50px;align-items:center;gap:.5rem;font-size:.75rem;padding:.375rem;background:rgba(20,20,30,.4);border-radius:6px}.drop-rate-name{color:#e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.drop-rate-bar{width:100%;height:8px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden}.drop-rate-fill{height:100%;border-radius:4px;transition:width .3s ease;box-shadow:0 0 8px currentColor}.drop-rate-percent{font-size:.75rem;font-weight:700;text-align:right}@media (max-width:768px){.loot-explorer-content{padding:0 1rem 2rem}.page-title{font-size:2rem}.zone-grid{grid-template-columns:repeat(2,1fr)}.loot-grid,.structure-explorer-grid{grid-template-columns:1fr}.structure-explorer-grid{gap:1rem}.category-list{flex-direction:row;overflow-x:auto;padding-bottom:.5rem;gap:.5rem}.category-btn{min-width:140px;flex-shrink:0}.structure-list{max-height:400px}.selected-item-header{flex-direction:column;text-align:center;gap:1rem}.view-item-btn{width:100%;text-align:center}}@media (max-width:480px){.zone-grid{grid-template-columns:1fr}.category-btn{flex-direction:column;align-items:center;text-align:center;padding:.5rem}.category-name{font-size:.75rem}}.structure-explorer-grid{display:grid;grid-template-columns:280px 1fr 320px;gap:1.5rem;max-width:1600px;margin:0 auto}.category-list{display:flex;flex-direction:column;gap:.5rem}.category-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.05);border-radius:10px;color:#e0e0e0;cursor:pointer;transition:all .2s ease;text-align:left}.category-btn:hover{background:rgba(40,40,55,.8);border-color:rgba(139,92,246,.3)}.category-btn.active{background:rgba(139,92,246,.2);border-color:rgba(139,92,246,.5)}.category-icon{font-size:1.25rem}.category-name{flex:1;font-weight:500}.category-count{font-size:.75rem;font-weight:600;color:#a78bfa;background:rgba(139,92,246,.2);padding:.125rem .5rem;border-radius:99px}.chest-count{font-size:.625rem;color:#6b7280}.search-box{margin-bottom:1rem}.search-input{width:100%;padding:.75rem 1rem;background:rgba(20,20,30,.8);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#e0e0e0;font-size:.875rem;outline:none;transition:all .2s ease}.search-input:focus{border-color:rgba(139,92,246,.5);box-shadow:0 0 0 3px rgba(139,92,246,.1)}.search-input::placeholder{color:#6b7280}.structure-list{display:flex;flex-direction:column;gap:.5rem;max-height:calc(100vh - 300px);overflow-y:auto;padding-right:.5rem}.structure-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.05);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;color:inherit}.structure-card:hover{background:rgba(40,40,55,.8);border-color:rgba(139,92,246,.3);transform:translateX(4px)}.structure-card.selected{background:rgba(139,92,246,.15);border-color:rgba(139,92,246,.5)}.structure-info{display:flex;flex-direction:column;gap:.25rem}.structure-name{font-weight:600;font-size:.875rem;color:#e0e0e0}.structure-type{font-size:.75rem;color:#6b7280}.structure-stats{display:flex;align-items:center}.chest-badge{font-size:.75rem;font-weight:600;color:#f59e0b;background:rgba(245,158,11,.15);padding:.25rem .75rem;border-radius:99px}.structure-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:rgba(20,20,30,.4);border-radius:6px}.detail-label{font-size:.75rem;color:#6b7280}.detail-value{font-size:.875rem;font-weight:600;color:#e0e0e0}.tier-breakdown{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.tier-breakdown h4{font-size:.75rem;font-weight:600;color:#a78bfa;text-transform:uppercase;margin-bottom:.75rem}.tier-row{display:flex;justify-content:space-between;padding:.375rem 0;font-size:.75rem}.tier-label{color:#9ca3af;word-break:break-all}.tier-value{color:#f59e0b;font-weight:600}.structure-loot{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.structure-loot .section-title{font-size:.875rem;margin-bottom:1rem}.structure-loot .drop-rates-grid{max-height:300px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:#6b7280;font-size:.875rem;text-align:center;gap:.5rem}.empty-state.large{min-height:400px}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{color:#e0e0e0;font-size:1.25rem;margin:0}.empty-state .hint{font-size:.75rem;color:#6b7280}.drop-calculator-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:900px;margin:0 auto}.search-container,.search-panel{position:relative}.search-input.large{width:100%;padding:1rem 1.5rem;background:rgba(30,30,40,.8);border:2px solid rgba(139,92,246,.3);border-radius:16px;color:#e0e0e0;font-size:1.125rem;outline:none;transition:all .2s ease}.search-input.large:focus{border-color:rgba(139,92,246,.6);box-shadow:0 0 20px rgba(139,92,246,.2)}.search-results{position:absolute;top:100%;left:0;right:0;margin-top:.5rem;background:rgba(30,30,40,.98);border:1px solid rgba(255,255,255,.1);border-radius:12px;max-height:400px;overflow-y:auto;z-index:100}.search-result-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.05);color:#e0e0e0;cursor:pointer;transition:all .2s ease;text-align:left}.search-result-item:hover{background:rgba(139,92,246,.15)}.search-result-item:last-child{border-bottom:none}.result-name{flex:1;font-weight:500}.result-rarity{font-size:.75rem;text-transform:capitalize;font-weight:600}.results-panel{background:rgba(30,30,40,.6);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem}.selected-item-header{display:flex;align-items:center;gap:1rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:1.5rem}.selected-item-info{flex:1}.selected-item-info h2{font-size:1.5rem;font-weight:700;color:#e0e0e0;margin:0 0 .5rem}.rarity-tag{display:inline-block;padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-weight:600;text-transform:capitalize}.view-item-btn{padding:.75rem 1.5rem;background:rgba(139,92,246,.2);border:1px solid rgba(139,92,246,.4);border-radius:10px;color:#a78bfa;font-weight:600;text-decoration:none;transition:all .2s ease}.view-item-btn:hover{background:rgba(139,92,246,.3);border-color:rgba(139,92,246,.6)}.drop-sources{margin-top:1rem}.drop-sources .section-title{font-size:1rem;margin-bottom:1rem}.sources-list{display:flex;flex-direction:column;gap:.75rem}.source-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:rgba(20,20,30,.6);border:1px solid rgba(255,255,255,.05);border-radius:12px;transition:all .2s ease}.source-card:hover{background:rgba(30,30,45,.8);border-color:rgba(139,92,246,.2)}.source-info{display:flex;align-items:center;gap:.75rem}.zone-badge{padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;color:white}.source-name{font-weight:500;color:#e0e0e0}.tier-badge{font-size:.75rem;color:#f59e0b;background:rgba(245,158,11,.15);padding:.25rem .5rem;border-radius:4px}.source-stats{display:flex;align-items:center;gap:1rem}.quantity{font-size:.875rem;color:#9ca3af;font-weight:500}.prob-bar{width:80px;height:8px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden}.prob-fill{height:100%;border-radius:4px;transition:width .3s ease}.probability{font-size:1rem;font-weight:700;min-width:60px;text-align:right}