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