@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;900&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body,html{margin:0;padding:0;background:linear-gradient(to top,#333,#222,#111,#222,#333);background-attachment:fixed;color:#d1c6ff;height:100%;width:100%;font-family:Inter,sans-serif}.app.coming-soon{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background:transparent;overflow:hidden}.overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%;max-width:500px;margin:0 auto;padding:20px;animation:fadeIn 2s ease-in-out}.container{width:100%;max-width:600px;animation:fadeIn .5s ease-in-out}.header{text-align:center;margin-bottom:40px}.mastema-img{width:360px;height:480px;filter:drop-shadow(0 0 18px #8a64ff);animation:float 4s ease-in-out infinite}.mastema-icon{width:120px;height:160px;filter:drop-shadow(0 0 12px #8a64ff);animation:float 4s ease-in-out infinite;margin-bottom:10px}.title{font-size:2.5rem;font-weight:900;margin:10px 0;color:#c7b5ff;text-shadow:0 0 20px rgba(139,104,255,.4)}.subtitle{font-size:1rem;font-weight:400;color:#b1a0e5;margin:5px 0}.search-section{display:flex;gap:10px;margin-bottom:30px}.search-input{flex:1;padding:15px 20px;font-size:1rem;background:#ffffff0d;border:2px solid rgba(138,100,255,.3);border-radius:12px;color:#d1c6ff;font-family:inherit;transition:all .3s ease}.search-input:focus{outline:none;border-color:#8a64ff;background:#ffffff14;box-shadow:0 0 20px #8a64ff4d}.search-input::placeholder{color:#6b5b8a}.search-button{padding:15px 30px;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#8a64ff,#6b4fd4);border:none;border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;font-family:inherit}.search-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #8a64ff66}.search-button:disabled{opacity:.6;cursor:not-allowed}.error-box{padding:15px 20px;background:#ff52521a;border:2px solid rgba(255,82,82,.3);border-radius:12px;color:#ffb3b3;margin-bottom:20px;text-align:center}.divider{width:60%;height:1px;background:linear-gradient(90deg,transparent,#5f45b7,transparent);margin:30px auto}.footer{font-size:.9rem;color:#8374c7;letter-spacing:.05em;text-align:center;margin-top:20px}.footer p{font-size:.85rem;color:#8374c7;letter-spacing:.05em}@media(max-width:600px){.stats-grid{grid-template-columns:1fr}.search-section{flex-direction:column}.character-header{flex-direction:column;text-align:center}.title{font-size:2rem}}.navbar{position:fixed;top:0;left:0;right:0;height:70px;background:linear-gradient(135deg,#1e1432f2,#140f23f2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(139,92,246,.3);z-index:1000;box-shadow:0 4px 20px #8b5cf626,0 2px 10px #0006}.navbar-container{max-width:1400px;height:100%;margin:0 auto;padding:0 30px;display:flex;align-items:center;justify-content:space-between}.navbar-left{display:flex;align-items:center;gap:40px}.navbar-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;font-size:20px;font-weight:700;transition:all .3s ease}.navbar-cat{width:35px;height:47px;filter:drop-shadow(0 0 8px rgba(138,100,255,.6));transition:all .3s ease;animation:floatSmall 3s ease-in-out infinite}.navbar-logo:hover .navbar-cat{filter:drop-shadow(0 0 12px rgba(138,100,255,.9));transform:scale(1.05)}@keyframes floatSmall{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.navbar-logo:hover{color:#8b5cf6}.navbar-links{display:flex;align-items:center;gap:8px}.navbar-link{display:flex;align-items:center;gap:8px;padding:10px 16px;color:#ffffffb3;text-decoration:none;font-size:15px;font-weight:500;border-radius:8px;transition:all .3s ease;background:none;border:none;cursor:pointer;white-space:nowrap}.navbar-link:hover{color:#fff;background:#8b5cf626}.navbar-link.active{color:#8b5cf6;background:#8b5cf633}.navbar-icon{font-size:18px;flex-shrink:0}.navbar-dropdown{position:relative}.dropdown-trigger{font-family:inherit}.dropdown-arrow{margin-left:4px;transition:transform .3s ease}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 5px);left:0;min-width:200px;background:#1e1e32fa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:8px;box-shadow:0 8px 32px #0006;opacity:0;transform:translateY(-10px);animation:dropdownFadeIn .2s ease forwards}.dropdown-menu.closing{animation:dropdownFadeOut .2s ease forwards}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes dropdownFadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#fffc;text-decoration:none;font-size:14px;font-weight:500;border-radius:8px;transition:all .2s ease;position:relative}.dropdown-item:hover{color:#fff;background:#8b5cf633;transform:translate(4px)}.dropdown-item.disabled{color:#fff6;cursor:not-allowed;pointer-events:none}.soon-badge{margin-left:auto;padding:2px 8px;background:#8b5cf64d;color:#8b5cf6;font-size:10px;font-weight:700;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.navbar-right{display:flex;align-items:center;gap:12px}.discord-invite-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#5865f2;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;box-shadow:0 4px 15px #5865f24d}.discord-invite-btn:hover{background:#4752c4;transform:translateY(-2px);box-shadow:0 6px 20px #5865f266}.discord-invite-btn .navbar-icon{font-size:18px}.dev-mode-badge{display:flex;align-items:center;padding:6px 12px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.5px;box-shadow:0 2px 8px #f59e0b66;animation:devPulse 2s ease-in-out infinite}@keyframes devPulse{0%,to{box-shadow:0 2px 8px #f59e0b66}50%{box-shadow:0 2px 12px #f59e0b99}}.login-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #8b5cf64d}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.login-button.disabled{background:#8b5cf64d;cursor:not-allowed;box-shadow:none}.login-button.disabled:hover{transform:none}.user-menu{position:relative}.user-button{display:flex;align-items:center;gap:8px;padding:6px 14px 6px 6px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.user-button:hover{background:#8b5cf640;border-color:#8b5cf680}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.user-dropdown{right:0;left:auto;min-width:150px}.logout-item{color:#f87171!important;background:none;border:none;width:100%;cursor:pointer;font-family:inherit}.logout-item:hover{background:#f871711a!important}@media(max-width:768px){.navbar-container{padding:0 20px}.navbar-left{gap:20px}.navbar-links{gap:4px}.navbar-link span,.login-button span,.discord-invite-btn span,.navbar-logo span{display:none}.navbar-icon{font-size:20px}.dropdown-arrow{display:none}}.footer{width:100%;max-width:100%;box-sizing:border-box;background:linear-gradient(135deg,#140f23fa,#0f0a19fa);border-top:1px solid rgba(139,92,246,.2);padding:40px 20px 24px;margin-top:auto;overflow-x:hidden}.footer-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:24px}.footer-content{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:32px;width:100%}.footer-credits{display:flex;align-items:center;gap:6px;color:#ffffffb3;font-size:14px}.footer-heart{color:#ef4444;font-size:12px;animation:heartbeat 1.5s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.footer-link{color:#a78bfa;text-decoration:none;transition:color .2s ease}.footer-link:hover{color:#c4b5fd;text-decoration:underline}.footer-links{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.footer-link-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease}.footer-link-btn.discord{background:#5865f226;color:#7289da;border:1px solid rgba(88,101,242,.3)}.footer-link-btn.discord:hover{background:#5865f240;border-color:#5865f280;transform:translateY(-2px)}.footer-disclaimer{text-align:center;padding:16px 24px;background:#0003;border-radius:8px;border:1px solid rgba(255,255,255,.05);max-width:700px}.footer-disclaimer p{margin:0;color:#ffffff73;font-size:11px;line-height:1.6}.footer-disclaimer p+p{margin-top:6px}.footer-copyright{color:#ffffff59;font-size:12px}@media(max-width:600px){.footer{padding:30px 16px 20px}.footer-content{flex-direction:column;gap:20px}.footer-links{flex-direction:column;width:100%}.footer-link-btn{justify-content:center;width:100%}.footer-disclaimer{padding:12px 16px}.footer-disclaimer p{font-size:10px}}.layout{display:flex;flex-direction:column;min-height:100vh;width:100%;max-width:100%;background:transparent;overflow-x:hidden}.main-content{flex:1;margin-top:70px;width:100%;max-width:100%;display:flex;justify-content:center;align-items:flex-start;padding:0;margin-left:0;margin-right:0}.home-page{width:100%;min-height:calc(100vh - 70px);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;display:flex;align-items:flex-start;justify-content:center;padding:60px 24px 40px}.home-content{display:flex;flex-direction:column;align-items:center;gap:48px;width:100%;max-width:560px}.home-hero{display:flex;flex-direction:column;align-items:center;gap:40px;width:100%}.hero-brand{display:flex;flex-direction:column;align-items:center;gap:20px}.hero-mascot{width:100px;height:auto;filter:drop-shadow(0 8px 24px rgba(0,0,0,.3))}.hero-text{text-align:center}.hero-title{font-size:2.5rem;font-weight:700;margin:0;letter-spacing:.02em;background:linear-gradient(135deg,#fff,#6322ca,#a5b4fc,#c4b5fd,#6322ca,#fff);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 40px rgba(139,92,246,.2);animation:titleShimmer 6s ease-in-out infinite}.hero-divider{width:60px;height:2px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.5),transparent);margin:12px auto;border-radius:1px}.hero-subtitle{font-size:1rem;font-weight:500;color:#9ca3af;margin:0}.search-form{display:flex;width:100%;gap:12px}.search-input{flex:1;background:#18181b;border:1px solid #27272a;border-radius:6px;outline:none;font-size:.95rem;font-family:inherit;color:#fff;padding:12px 16px;min-width:0;transition:border-color .2s ease}.search-input:focus{border-color:#3f3f46}.search-input::placeholder{color:#52525b}.search-btn{padding:12px 28px;background:#8b5cf6;border:none;border-radius:6px;color:#fff;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s ease;white-space:nowrap}.search-btn:hover:not(:disabled){background:#7c3aed}.search-btn:disabled{opacity:.4;cursor:not-allowed}.home-links{display:flex;align-items:center;gap:16px;flex-wrap:nowrap;justify-content:center}.quick-link{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;color:#9ca3af;text-decoration:none;font-size:.9rem;font-weight:500;border-radius:6px;transition:color .2s ease,background .2s ease;white-space:nowrap}.quick-link:hover{color:#fff;background:#ffffff0d}.link-icon{font-size:16px}.link-divider{color:#4b5563;font-size:.8rem}@media(max-width:640px){.home-page{padding:60px 20px 32px}.home-content{gap:40px}.hero-mascot{width:80px}.hero-title{font-size:2rem}.search-form{flex-direction:column;gap:10px}.search-input,.search-btn{padding:12px}.home-links{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding:8px 0;width:100%}.quick-link{white-space:nowrap;font-size:.85rem;padding:8px 10px}}.character-lookup{width:100%;max-width:700px;padding:60px 20px 40px;transition:all .3s ease}.character-lookup.has-character{max-width:100%;display:grid;grid-template-columns:280px 1fr;gap:0;align-items:start;padding:0;margin:0}.character-search-section{width:100%;animation:fadeIn .86s ease-in-out}.character-lookup.has-character .character-search-section{position:fixed;left:0;top:70px;width:250px;height:calc(100vh - 70px);background:#1e192df2;border-right:1px solid rgba(139,92,246,.2);padding:30px 20px;overflow-y:auto;z-index:10;box-sizing:border-box;transition:width .3s ease,padding .3s ease}.sidebar-toggle{position:absolute;top:50%;right:-16px;transform:translateY(-50%);width:32px;height:64px;border-radius:0 12px 12px 0;background:linear-gradient(135deg,#28233cfa,#191626fc);border:1px solid rgba(139,92,246,.3);border-left:none;color:#b4aac8cc;font-size:1.1rem;font-weight:300;display:none;align-items:center;justify-content:center;cursor:pointer;z-index:20;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 16px #0000004d,inset 1px 0 #ffffff08;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden}.character-lookup.sidebar-minimized .sidebar-toggle{display:flex;left:0;right:auto;border-radius:0 12px 12px 0}.sidebar-toggle:before{content:"";position:absolute;left:0;top:10%;height:80%;width:2px;background:linear-gradient(180deg,transparent 0%,rgba(139,92,246,.5) 50%,transparent 100%);opacity:.6;transition:opacity .3s ease}.sidebar-toggle:after{content:"";position:absolute;width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);transition:transform .3s ease}.sidebar-toggle:hover{background:linear-gradient(135deg,#8b5cf633,#50328c40);border-color:#8b5cf699;color:#fff;box-shadow:4px 0 20px #8b5cf633,0 0 30px #8b5cf61a,inset 1px 0 #ffffff0d}.sidebar-toggle:hover:before{opacity:1;background:linear-gradient(180deg,transparent 0%,rgba(139,92,246,.8) 50%,transparent 100%)}.sidebar-toggle:active{transform:translateY(-50%) scale(.95)}.character-lookup.sidebar-minimized.has-character .character-search-section{width:0;padding:0;border-right:none;overflow:visible}.character-lookup.sidebar-minimized .search-title,.character-lookup.sidebar-minimized .search-icon,.character-lookup.sidebar-minimized .search-header,.character-lookup.sidebar-minimized .search-form,.character-lookup.sidebar-minimized .character-info,.character-lookup.sidebar-minimized .character-card-mini,.character-lookup.sidebar-minimized .character-preview,.character-lookup.sidebar-minimized .info-boxes,.character-lookup.sidebar-minimized .sidebar-saved-characters{display:none}.character-lookup.sidebar-minimized.has-character .content-section{margin-left:-30px;overflow-x:visible}.character-lookup.sidebar-minimized .main-grid{transform:scale(1);transform-origin:top center}.character-lookup.has-character .content-section{transition:margin-left .3s ease,width .3s ease}.content-section{width:100%;min-height:400px}.character-lookup.has-character .content-section{margin-left:250px;width:calc(100vw - 250px);min-height:calc(100vh - 70px);display:flex;flex-direction:column;align-items:center;padding:36px 20px;box-sizing:border-box;overflow-x:hidden}.main-grid{display:grid;grid-template-columns:280px 1fr 620px;grid-template-rows:minmax(350px,auto) auto;gap:20px;width:100%;max-width:1400px;padding:0 20px;box-sizing:border-box;align-items:stretch;transform:scale(.92) translate(-165px);transform-origin:top center;transition:transform .3s ease}.badges-card{grid-column:1;grid-row:2;background:linear-gradient(180deg,#1f2124 20%,#111 80%);border:3px solid rgba(100,100,120,.6);border-radius:14px;padding:20px;height:fit-content;align-self:start;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,inset 0 -1px #00000080,0 0 20px #6478c814}.habits-container{padding:5px}.habits-item{text-align:center}.habits-title{font-size:1.1rem;font-weight:700;color:#e8e8f0;margin:0 0 15px;letter-spacing:.02em;text-shadow:0 2px 8px rgba(120,140,200,.3),0 1px 3px rgba(0,0,0,.8)}.habits-stats{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%}.habits-stat-item{display:flex;align-items:center;justify-content:center;padding:10px 20px;background:linear-gradient(135deg,#282d3799,#191e26cc);border-radius:8px;border:2px solid rgba(100,100,120,.35);transition:all .3s ease;position:relative;overflow:hidden;box-shadow:0 2px 8px #0006,inset 0 1px #ffffff08,inset 0 -1px #0000004d;min-height:40px;width:70%;max-width:200px;cursor:pointer}.habits-stat-item:before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(120,140,200,.3) 50%,transparent 100%);opacity:.6}.habits-stat-item:hover{background:linear-gradient(135deg,#323746b3,#232832e6);border-color:#788cb480;transform:translateY(-2px);box-shadow:0 4px 16px #6478c826,inset 0 1px #ffffff0f,inset 0 -1px #0000004d,0 0 20px #6478c814}.habits-stat-item .stat-label{font-size:.88rem;color:#eaeaec;font-weight:600;letter-spacing:.03em;text-shadow:0 1px 4px rgba(0,0,0,.6),0 0 10px rgba(120,140,200,.3),0 0 20px rgba(120,140,200,.15);text-transform:capitalize;line-height:1;display:flex;align-items:center;margin-bottom:1px;filter:drop-shadow(0 2px 8px rgba(120,140,200,.5))}.trend-badge{display:flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:8px;border:2px solid;transition:all .3s ease;position:relative;overflow:hidden;min-height:36px;width:85%;max-width:180px;cursor:default}.trend-badge:before{content:"";position:absolute;left:0;right:0;top:0;height:1px;opacity:.6}.trend-badge .badge-label{font-size:.82rem;font-weight:600;letter-spacing:.03em;text-shadow:0 1px 3px rgba(0,0,0,.5);line-height:1}.trend-badge .badge-category{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7;margin-top:2px}.trend-badge.color-green{background:linear-gradient(135deg,#22c55e40,#16a34a26);border-color:#22c55e80}.trend-badge.color-green .badge-label{color:#86efac}.trend-badge.color-green:before{background:linear-gradient(90deg,transparent 0%,rgba(34,197,94,.5) 50%,transparent 100%)}.trend-badge.color-yellow{background:linear-gradient(135deg,#eab30840,#ca8a0426);border-color:#eab30880}.trend-badge.color-yellow .badge-label{color:#fde047}.trend-badge.color-yellow:before{background:linear-gradient(90deg,transparent 0%,rgba(234,179,8,.5) 50%,transparent 100%)}.trend-badge.color-orange{background:linear-gradient(135deg,#f9731640,#ea580c26);border-color:#f9731680}.trend-badge.color-orange .badge-label{color:#fdba74}.trend-badge.color-orange:before{background:linear-gradient(90deg,transparent 0%,rgba(249,115,22,.5) 50%,transparent 100%)}.trend-badge.color-red{background:linear-gradient(135deg,#ef444440,#dc262626);border-color:#ef444480}.trend-badge.color-red .badge-label{color:#fca5a5}.trend-badge.color-red:before{background:linear-gradient(90deg,transparent 0%,rgba(239,68,68,.5) 50%,transparent 100%)}.trend-badge.color-blue{background:linear-gradient(135deg,#3b82f640,#2563eb26);border-color:#3b82f680}.trend-badge.color-blue .badge-label{color:#93c5fd}.trend-badge.color-blue:before{background:linear-gradient(90deg,transparent 0%,rgba(59,130,246,.5) 50%,transparent 100%)}.trend-badge.color-purple{background:linear-gradient(135deg,#8b5cf640,#7c3aed26);border-color:#8b5cf680}.trend-badge.color-purple .badge-label{color:#c4b5fd}.trend-badge.color-purple:before{background:linear-gradient(90deg,transparent 0%,rgba(139,92,246,.5) 50%,transparent 100%)}.trend-badge.color-gray{background:linear-gradient(135deg,#6b728040,#4b556326);border-color:#6b728080}.trend-badge.color-gray .badge-label{color:#d1d5db}.trend-badge.color-gray:before{background:linear-gradient(90deg,transparent 0%,rgba(107,114,128,.5) 50%,transparent 100%)}.trend-badge.color-gold{background:linear-gradient(135deg,#fbbf2459,#f59e0b40);border-color:#fbbf24b3;box-shadow:0 0 12px #fbbf244d}.trend-badge.color-gold .badge-label{color:#fcd34d;text-shadow:0 0 8px rgba(251,191,36,.5)}.trend-badge.color-gold:before{background:linear-gradient(90deg,transparent 0%,rgba(251,191,36,.6) 50%,transparent 100%)}.trend-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.badges-grid{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.badge-row{display:flex;gap:8px;justify-content:center;width:100%}.no-badges{font-size:.8rem;color:#889;font-style:italic;text-align:center;padding:20px;opacity:.7}.character-info-card{grid-column:1;grid-row:1;background:linear-gradient(180deg,#1f2124 20%,#111 80%);border:3px solid rgba(100,100,120,.6);border-radius:14px;padding:20px;min-height:350px;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,inset 0 -1px #00000080,0 0 20px #6478c814;position:relative;transition:all .3s ease}.character-info-card:before{content:"";position:absolute;inset:0;border-radius:14px;padding:3px;background:linear-gradient(135deg,rgba(120,140,200,.2) 0%,transparent 40%,transparent 60%,rgba(120,140,200,.1) 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.6}.char-image-container{position:relative;width:100%;aspect-ratio:1;background:linear-gradient(135deg,#1e2026cc,#14161ae6);border:2px solid rgba(100,100,120,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:15px;overflow:hidden;box-shadow:inset 0 2px 8px #00000080}.char-image{width:100%;height:100%;object-fit:contain;scale:.99}.char-details{text-align:center;padding:0 4px}.char-name{font-size:1.57rem;font-weight:800;color:#e8e8f0;margin:0 0 5px;letter-spacing:.02em;-webkit-text-stroke:1px rgba(0,0,0,0);position:relative;filter:drop-shadow(0 2px 8px rgba(120,140,200,.5))}.character-info-card{position:relative}.save-char-btn{position:absolute;top:12px;left:12px;background:#0f0c19cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1.5px solid rgba(100,100,120,.4);color:#b4b4c8b3;width:38px;height:38px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;font-size:20px;font-weight:400;line-height:1;z-index:10;box-shadow:0 2px 8px #00000080}.save-char-btn:hover{background:#eab3081a;border-color:#eab30880;transform:scale(1.08);color:#fbbf24;box-shadow:0 4px 12px #0009,0 0 16px #eab30840}.save-char-btn.saved{background:#eab30833;border-color:#eab308b3;color:#fbbf24;box-shadow:0 2px 8px #00000080,0 0 16px #eab30866}.save-char-btn.saved:hover{background:#eab30826!important;border-color:#eab308cc!important;transform:scale(1.1);color:#fcd34d!important;box-shadow:0 4px 12px #0009,0 0 20px #eab30866!important}.save-char-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.sidebar-saved-characters{margin-top:50px;padding:20px 0 0;border-top:1px solid rgba(139,92,246,.2)}.sidebar-login-prompt{margin-top:50px;padding:20px 16px;border-top:1px solid rgba(139,92,246,.2);display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.login-prompt-icon{font-size:24px;color:#8b5cf699}.login-prompt-text{font-size:13px;color:#e4e4f0b3;line-height:1.5;margin:0;font-weight:500}.sidebar-login-prompt:hover .login-prompt-icon{color:#8b5cf6cc;transition:color .2s ease}.sidebar-login-prompt:hover .login-prompt-text{color:#e4e4f0e6;transition:color .2s ease}.saved-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:0;justify-content:center}.saved-header .saved-icon{font-size:16px;color:#8b5cf6}.saved-title{font-size:13px;font-weight:700;color:#e8e8f0;text-transform:uppercase;letter-spacing:.5px;margin:0;flex:1}.saved-count{font-size:11px;font-weight:600;color:#8b5cf6;background:#8b5cf633;padding:2px 8px;border-radius:10px}.saved-list{display:flex;flex-direction:column;gap:8px;margin:0;width:100%}.saved-item-wrapper{position:relative;touch-action:none;transition:transform .2s ease,margin .2s ease}.saved-drag-area{position:absolute;left:0;top:0;bottom:0;width:24px;cursor:grab;z-index:5;background-image:repeating-linear-gradient(to bottom,rgba(113,113,122,.15) 0px,rgba(113,113,122,.15) 3px,transparent 3px,transparent 6px);background-position:center center;background-size:8px 100%;background-repeat:repeat-y;border-radius:8px 0 0 8px;transition:all .2s ease;pointer-events:auto}.saved-drag-area:active{cursor:grabbing}.saved-drag-area:hover{background-color:#8b5cf614;background-image:repeating-linear-gradient(to bottom,rgba(139,92,246,.5) 0px,rgba(139,92,246,.5) 3px,transparent 3px,transparent 6px);box-shadow:inset 2px 0 6px #8b5cf633}.saved-drag-area:active{cursor:grabbing;background-color:#8b5cf626;background-image:repeating-linear-gradient(to bottom,rgba(139,92,246,.6) 0px,rgba(139,92,246,.6) 3px,transparent 3px,transparent 6px)}.saved-item-wrapper .saved-item{padding-left:30px}.saved-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#ffffff05;border:1px solid rgba(100,100,120,.2);border-radius:10px;cursor:pointer;transition:all .2s ease;text-decoration:none;width:100%;min-height:80px;text-align:left;box-sizing:border-box}.saved-item:hover{background:#8b5cf61a;border-color:#8b5cf666;transform:translate(3px)}.saved-item.active{background:#8b5cf626;border-color:#8b5cf699}.saved-thumb{width:64px;height:64px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1.5px solid rgba(100,100,120,.4);box-shadow:0 2px 8px #0000004d}.saved-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.saved-name{font-size:15px;font-weight:700;color:#e8e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.saved-stats{display:flex;align-items:center;gap:4px;line-height:1}.saved-level{font-size:13px;font-weight:600;color:#8b5cf6}.saved-exp{font-size:13px;font-weight:500;color:#a0a0b0}.exp-percent{font-size:11px;color:#808090}.saved-class{font-size:13px;font-weight:500;color:#a0a0b0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-exp-gain{font-size:11px;font-weight:600;color:#10b981;line-height:1;margin-top:1px}.saved-view-all{padding:8px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:#8b5cf6;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:center;margin-top:4px}.saved-view-all:hover{background:#8b5cf633;border-color:#8b5cf680}.char-job{font-size:.85rem;color:#a8a8c0;text-shadow:0 0 .3px #fff,0 0 5px;margin:0 0 15px;font-weight:500}.char-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(100,100,120,.15)}.char-stat-centered{grid-column:1 / -1;max-width:50%;margin:0 auto}.char-stat-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0px;padding:8px 16px;background:linear-gradient(135deg,#3c415026,#282d3c14);border-radius:6px;border:1.5px solid rgba(100,100,120,.2);transition:all .3s ease;position:relative;overflow:hidden;box-shadow:0 1px 3px #0003,inset 0 1px #ffffff05}.char-stat-item:before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,#6478c866,#6478c81a);opacity:.5;transition:opacity .3s ease}.char-stat-item:hover{background:linear-gradient(135deg,#50556433,#3c41501f);border-color:#78788c4d;transform:translateY(-1px);box-shadow:0 2px 6px #6478c826,inset 0 1px #ffffff0a}.char-stat-item:hover:before{opacity:1}.char-stat-item .stat-label{font-size:.55rem;color:#a0a0b8;text-transform:uppercase;letter-spacing:.1em;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.4);position:relative;z-index:1;opacity:.85;line-height:1;margin-bottom:-2px}.char-stat-item .stat-value{font-size:1.05rem;font-weight:800;background:linear-gradient(135deg,#f0f0f8,#d8d8e8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.02em;text-shadow:0 2px 4px rgba(100,120,200,.15);position:relative;z-index:1;line-height:1;margin-top:5px}.char-stat-item .stat-subtext{font-size:.6rem;color:#889;font-weight:500;letter-spacing:.02em;margin-top:0;opacity:.75;text-shadow:0 1px 2px rgba(0,0,0,.3)}.exp-graph-card{background:linear-gradient(180deg,#1f2124 20%,#111 80%);border:3px solid rgba(100,100,120,.6);border-radius:14px;padding:34px 34px 34px 17px;min-height:350px;grid-column:2;grid-row:1;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,inset 0 -1px #00000080,0 0 20px #6478c814;position:relative;transition:all .3s ease;margin-top:-0px}.exp-graph-card:before{content:"";position:absolute;inset:0;border-radius:14px;padding:3px;background:linear-gradient(135deg,rgba(120,140,200,.2) 0%,transparent 40%,transparent 60%,rgba(120,140,200,.1) 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.6}.chart-wrapper-outer{display:flex;gap:8px}.y-axis-labels{display:flex;flex-direction:column;justify-content:space-between;min-width:43px;padding:0;height:290px}.y-axis-label{font-size:.72rem;color:#bbb;font-weight:600;text-align:right;text-shadow:1px 1px 2px rgba(0,0,0,.8);line-height:1}.chart-area{flex:1;display:flex;flex-direction:column;gap:0;min-width:0;max-width:100%}.chart-bars-container{display:flex;align-items:flex-end;justify-content:space-between;gap:4px;height:290px;min-width:600px;max-width:600px;padding:0 17px 2px;background:linear-gradient(180deg,#1b1d2299,#16171acc);border-radius:10px 10px 0 0;position:relative;box-shadow:inset 0 2px 10px #00000080}.chart-bars-container:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(180deg,transparent 0,transparent calc(20% - 1px),rgba(55,58,65,.5) calc(20% - 1px),rgba(55,58,65,.5) 20%);background-position:bottom;pointer-events:none;z-index:0}.chart-bars-container:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:#969696cc;z-index:0}.bar-column{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative;z-index:1;padding-bottom:3px}.bar-spacer{width:100%}.chart-bar{width:70%;background:linear-gradient(180deg,#8b5cf6,#5d3fd3 70%,#4a32a8);border-radius:8px 8px 0 0;cursor:pointer;transition:all .3s ease;box-shadow:0 -2px 8px #8b5cf666,0 0 0 3px #000c,inset 0 -20px 30px #0000004d;filter:brightness(.95);position:relative}.bar-value-top{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:5px;font-size:clamp(.65rem,.7vw,.81rem);color:#f0f0f0;font-weight:700;text-shadow:1px 1px 0 #030303,-1px -1px 0 #030303,1px -1px 0 #030303,-1px 1px 0 #030303,0 0 8px rgba(0,0,0,.6);white-space:nowrap;pointer-events:none}.chart-bar:hover{background:linear-gradient(180deg,#a78bfa,#6d4fd4 70%,#5a3fb8);box-shadow:0 -4px 16px #8b5cf699,0 0 0 3px #000000e6,inset 0 -20px 30px #0003;filter:brightness(1.1)}.x-axis-labels{display:flex;justify-content:space-between;gap:4px;min-width:600px;max-width:600px;padding:10px 17px 0;background:transparent}.x-label-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px}.x-label-date{font-size:.72rem;color:#e8e8e8;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.8);white-space:nowrap}.x-label-day{font-size:.6rem;color:#bbb;font-weight:500;text-shadow:1px 1px 2px rgba(0,0,0,.8);white-space:nowrap}.graph-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.eta-calculator-card{background:linear-gradient(180deg,#1f2124 20%,#111 80%);border:3px solid rgba(100,100,120,.6);border-radius:12px;padding:20px;height:fit-content;grid-column:2;grid-row:2;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,inset 0 -1px #00000080,0 0 20px #6478c814;position:relative;overflow:hidden;transition:all .3s ease}.calendar-card{background:linear-gradient(180deg,#1f2124 20%,#111 80%);border:3px solid rgba(100,100,120,.6);border-radius:12px;padding:20px;height:fit-content;grid-column:3;grid-row:1 / 3;overflow:hidden;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,inset 0 -1px #00000080,0 0 20px #6478c814}.calendar-card .card-title{font-size:1.2rem;font-weight:700;color:#f0f0f0;margin:0 0 16px;text-align:center}.heatmap-calendar{margin-bottom:20px;padding:16px;background:#14161c99;border-radius:12px;border:1px solid rgba(100,100,120,.2)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 4px}.calendar-nav-btn{background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:6px;color:#c4b5fd;font-size:1.2rem;font-weight:600;width:32px;height:32px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.calendar-nav-btn:hover:not(:disabled){background:#8b5cf640;border-color:#8b5cf680;color:#e9e3ff}.calendar-nav-btn:disabled{opacity:.3;cursor:not-allowed}.calendar-month{font-size:1rem;font-weight:700;color:#e8e8f0;text-shadow:0 0 10px rgba(139,92,246,.3)}.calendar-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(100,100,120,.2)}.calendar-summary-item{display:flex;flex-direction:column;align-items:center;gap:2px}.calendar-summary-item .summary-label{font-size:.65rem;color:#8b8b9e;text-transform:uppercase;letter-spacing:.5px}.calendar-summary-item .summary-value{font-size:.95rem;font-weight:700;color:#c4b5fd}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}.weekday-label{text-align:center;font-size:.65rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.calendar-grid{display:flex;flex-direction:column;gap:4px}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{aspect-ratio:1;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative;min-height:48px}.calendar-day:hover:not(.empty){transform:scale(1.08);z-index:10}.calendar-day.empty{background:transparent;cursor:default}.calendar-day .day-number{font-size:1rem;font-weight:700;color:#fff;text-shadow:0 0 3px rgba(0,0,0,.9),1px 1px 0 rgba(0,0,0,.8),-1px -1px 0 rgba(0,0,0,.8),1px -1px 0 rgba(0,0,0,.8),-1px 1px 0 rgba(0,0,0,.8),0 0 8px rgba(0,0,0,.5)}.calendar-day .day-exp{font-size:.75rem;font-weight:600;color:#fff;margin-top:2px;text-shadow:0 0 3px rgba(0,0,0,.9),1px 1px 0 rgba(0,0,0,.8),-1px -1px 0 rgba(0,0,0,.8),1px -1px 0 rgba(0,0,0,.8),-1px 1px 0 rgba(0,0,0,.8)}.calendar-day.heat-0{background:#14161ccc;border:1px solid rgba(40,42,50,.5)}.calendar-day.heat-0 .day-number{color:#fff}.calendar-day.heat-0 .day-exp{display:none}.calendar-day.heat-1{background:#4b2d8266;border:1px solid rgba(100,60,160,.5);box-shadow:0 0 6px #8a2be233}.calendar-day.heat-1 .day-number{color:#fff}.calendar-day.heat-2{background:#6e3cb499;border:1px solid rgba(138,80,220,.6);box-shadow:0 0 12px #8a2be266}.calendar-day.heat-2 .day-number{color:#fff}.calendar-day.heat-3{background:linear-gradient(135deg,#8a2be2cc,#a050ffcc);border:1px solid rgba(180,100,255,.7);box-shadow:0 0 16px #8a2be299,0 0 30px #8a2be24d}.calendar-day.heat-3 .day-number{color:#fff}.calendar-day.heat-4{background:linear-gradient(135deg,#a050ff,#c878ff);border:2px solid rgba(220,180,255,.9);box-shadow:0 0 20px #a050ffe6,0 0 40px #8a2be299,0 0 60px #8a2be24d,inset 0 0 20px #fff3;animation:peakGlow 1.5s ease-in-out infinite}.calendar-day.heat-4 .day-number{color:#fff;text-shadow:0 0 12px rgba(255,255,255,1),0 0 20px rgba(200,150,255,.8);font-weight:700}.calendar-day.heat-4 .day-exp{color:#fff;text-shadow:0 0 8px rgba(255,255,255,.8)}@keyframes peakGlow{0%,to{box-shadow:0 0 20px #a050ffe6,0 0 40px #8a2be299,0 0 60px #8a2be24d,inset 0 0 20px #fff3;transform:scale(1)}50%{box-shadow:0 0 30px #b464ff,0 0 55px #a050ffcc,0 0 80px #8a2be266,inset 0 0 25px #ffffff4d;transform:scale(1.02)}}.calendar-day.today{outline:2px solid rgba(250,204,21,.8);outline-offset:1px}.calendar-day.today:after{content:"";position:absolute;top:3px;right:3px;width:6px;height:6px;background:#facc15;border-radius:50%;box-shadow:0 0 6px #facc15cc}.calendar-legend{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:14px;padding-top:12px;border-top:1px solid rgba(100,100,120,.2)}.calendar-legend .legend-label{font-size:.65rem;color:#6b7280;font-style:italic}.legend-cell{width:16px;height:16px;border-radius:4px}.legend-cell.heat-0{background:#14161ccc;border:1px solid rgba(40,42,50,.5)}.legend-cell.heat-1{background:#4b2d8266;border:1px solid rgba(100,60,160,.5)}.legend-cell.heat-2{background:#6e3cb499;border:1px solid rgba(138,80,220,.6)}.legend-cell.heat-3{background:linear-gradient(135deg,#8a2be2cc,#a050ffcc);border:1px solid rgba(180,100,255,.7);box-shadow:0 0 8px #8a2be266}.legend-cell.heat-4{background:linear-gradient(135deg,#a050ff,#c878ff);border:1px solid rgba(220,180,255,.9);box-shadow:0 0 12px #a050ffb3}.no-activity-data{color:#6b7280;font-size:.8rem;padding:20px;text-align:center}.stats-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.3),transparent);margin:20px 0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-box{background:linear-gradient(145deg,#232630e6,#191b23f2);border:1px solid rgba(100,100,140,.25);border-radius:10px;padding:14px 8px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;position:relative;overflow:hidden;transition:all .25s ease;box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff08;min-height:80px}.stat-box:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.5),transparent);opacity:0;transition:opacity .25s ease}.stat-box:hover{transform:translateY(-2px);border-color:#8b5cf666;box-shadow:0 4px 16px #0006,0 0 20px #8b5cf61a,inset 0 1px #ffffff0d}.stat-box:hover:before{opacity:1}.stat-box-label{font-size:.6rem;color:#8b8b9e;font-weight:600;text-transform:uppercase;letter-spacing:.5px;min-height:28px;display:flex;align-items:center;justify-content:center;line-height:1.3}.stat-box-value{font-size:1.1rem;font-weight:700;color:#f0f0f8;text-shadow:0 0 10px rgba(139,92,246,.2);margin-top:auto}.stat-box:nth-child(1){border-left:3px solid rgba(139,92,246,.6)}.stat-box:nth-child(2){border-left:3px solid rgba(99,102,241,.6)}.stat-box:nth-child(3){border-left:3px solid rgba(79,172,254,.6)}.stat-box:nth-child(4){border-left:3px solid rgba(52,211,153,.6)}.stat-box:nth-child(5){border-left:3px solid rgba(251,191,36,.6)}.stat-box:nth-child(6){border-left:3px solid rgba(244,114,182,.6)}.eta-title{font-size:1.2rem;font-weight:700;color:#e8e8f0;margin:0;text-align:center;filter:drop-shadow(0 2px 8px rgba(120,140,200,.4))}.eta-content{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;width:100%;max-width:100%;overflow:hidden}.eta-section{display:flex;flex-direction:column;gap:8px}.eta-section-title{font-size:.75rem;font-weight:500;color:#b8b8d0;text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;text-align:center;opacity:.9}.eta-result{text-align:center;padding:8px 0}.eta-value{font-size:1.8rem;font-weight:700;color:#e8e8f0;display:block;margin-bottom:4px;filter:drop-shadow(0 2px 8px rgba(120,140,200,.5))}.eta-label{font-size:.75rem;color:#a8a8c0;text-transform:uppercase;letter-spacing:.5px;display:block}.eta-subtext{font-size:.8rem;color:#d6d6db;font-style:italic;opacity:.85;margin-top:6px;display:block;font-weight:400}.eta-level-range{margin-top:8px;font-size:.75rem;color:#a8a8c0;text-align:center;line-height:1.6;opacity:.9;letter-spacing:.3px;font-weight:500;grid-column:1 / -1}.eta-range-placeholder{font-style:italic;color:#707080;opacity:.6}.eta-input-group{display:flex;flex-direction:column;gap:8px;width:100%;max-width:100%;overflow:hidden}.eta-input{background:#1e2026cc;border:1.5px solid rgba(100,100,120,.35);border-radius:8px;padding:10px 12px;color:#e8e8f0;font-size:.95rem;font-weight:500;width:100%;max-width:100%;box-sizing:border-box;transition:all .3s ease}.eta-input:focus{outline:none;border-color:#788cb499;background:#282a30e6;box-shadow:0 0 0 3px #6478c81a}.eta-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;grid-column:1 / -1;padding-top:12px;border-top:1px solid rgba(100,100,120,.2);margin-top:8px}.eta-stat-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#1e202699;border-radius:6px;border:1px solid rgba(100,100,120,.2)}.eta-stat-label{font-size:.8rem;color:#b8b8d0;font-weight:500}.eta-stat-value{font-size:.85rem;color:#e8e8f0;font-weight:600}.eta-divider{display:none}.card-title{font-size:1.53rem;font-weight:700;color:#f0f0f0;text-shadow:0 0 10px rgba(139,92,246,.3),1px 1px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000;text-align:center;margin:0 0 0 40px}.time-range-toggle{display:flex;gap:8px;background:#0000004d;padding:4px;border-radius:8px;border:1px solid rgba(139,92,246,.2)}.range-btn{padding:6px 16px;font-size:.75rem;font-weight:700;color:#a89ac7;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;letter-spacing:.05em;text-transform:uppercase}.range-btn:hover{color:#d4c5ff;background:#8a64ff26}.range-btn.active{color:#f0f0f0;background:linear-gradient(135deg,#8a64ff66,#6450c84d);box-shadow:0 2px 8px #8b5cf64d,inset 0 1px #ffffff1a}.search-header{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:20px;transition:all .3s ease;position:relative}.search-header.minimized{justify-content:flex-start;margin-bottom:20px;gap:10px}.sidebar-toggle-inline{position:absolute;right:0;width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#8b5cf633,#6d28d940);border:1.5px solid rgba(139,92,246,.4);color:#a78bfa;font-size:18px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;box-shadow:0 2px 8px #8b5cf626;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.character-lookup.sidebar-minimized .sidebar-toggle-inline{display:none}.sidebar-toggle-inline:hover{background:linear-gradient(135deg,#8b5cf659,#6d28d966);border-color:#8b5cf6b3;color:#c4b5fd;transform:scale(1.08);box-shadow:0 4px 16px #8b5cf64d,0 0 24px #8b5cf633,inset 0 1px #ffffff1a}.sidebar-toggle-inline:active{transform:scale(.95);box-shadow:0 2px 8px #8b5cf633}.search-icon{font-size:2.5rem;color:#dbd8e2;filter:drop-shadow(0 0 10px rgba(139,92,246,.5));transition:all .3s ease}.search-header.minimized .search-icon{font-size:1.3rem}.search-title{font-size:2.5rem;font-weight:900;color:#dbd8e2;text-shadow:0 0 20px rgba(139,104,255,.4);margin:0;transition:all .3s ease}.search-header.minimized .search-title{font-size:1.1rem;text-align:left;padding-right:40px}.search-form{display:flex;gap:12px;margin-bottom:50px;transition:all .3s ease}.search-form.minimized{flex-direction:column;margin-bottom:0}.search-input{flex:1;padding:18px 24px;font-size:1.1rem;background:#ffffff0d;border:2px solid rgba(139,92,246,.3);border-radius:12px;color:#fff;font-family:inherit;transition:all .3s ease}.search-form.minimized .search-input{padding:12px 14px;font-size:.9rem}.search-input:focus{outline:none;border-color:#8b5cf6;background:#ffffff14;box-shadow:0 0 20px #8b5cf64d}.search-input::placeholder{color:#b1a0e580}.search-button{padding:18px 32px;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;font-family:inherit;white-space:nowrap}.search-form.minimized .search-button{padding:12px 20px;font-size:.9rem;width:100%}.search-button:hover{transform:translateY(-2px);box-shadow:0 6px 25px #8b5cf666}.info-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}.character-lookup.has-character .info-boxes{display:none}.info-box{background:#8b5cf61a;border:2px solid rgba(139,92,246,.3);border-radius:16px;padding:30px 20px;text-align:center;transition:all .3s ease}.character-lookup.has-character .info-box{padding:20px 15px}.info-box:hover{background:#8b5cf626;border-color:#8b5cf680;transform:translateY(-4px);box-shadow:0 8px 25px #8b5cf633}.info-icon{font-size:3rem;margin-bottom:15px;color:#dbd8e2;filter:drop-shadow(0 0 10px rgba(139,92,246,.5))}.character-lookup.has-character .info-icon{font-size:2rem;margin-bottom:10px}.info-title{font-size:1.2rem;font-weight:700;color:#dbd8e2;margin:0 0 12px}.character-lookup.has-character .info-title{font-size:1rem;margin-bottom:8px}.info-text{font-size:.95rem;color:#dbd8e2;line-height:1.5;margin:0}.character-lookup.has-character .info-text{font-size:.85rem}@media(max-width:768px){.info-boxes{grid-template-columns:1fr;gap:15px}}.loading-box{padding:40px 20px;background:#ffffff0d;border:2px solid rgba(138,100,255,.3);border-radius:16px;text-align:center;margin-bottom:20px}.spinner{width:50px;height:50px;border:4px solid rgba(138,100,255,.2);border-top-color:#8a64ff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.loading-box p{color:#b1a0e5;font-size:1rem}.error-box{padding:20px;background:#ff52521a;border:2px solid rgba(255,82,82,.3);border-radius:12px;color:#ffb3b3;margin-bottom:20px;text-align:center}.error-box p{margin:5px 0}.error-hint{font-size:.9rem;opacity:.8}.character-card{background:#ffffff0d;border:2px solid rgba(138,100,255,.3);border-radius:16px;padding:30px;animation:slideUp .5s ease-out}.character-header{display:flex;align-items:center;gap:20px;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid rgba(138,100,255,.2)}.character-image{width:80px;height:80px;border-radius:12px;border:2px solid #8a64ff;box-shadow:0 0 20px #8a64ff4d}.character-info{flex:1}.character-name{font-size:1.8rem;font-weight:900;color:#c7b5ff;margin:0 0 5px}.character-job{font-size:1rem;color:#b1a0e5;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:30px}@media(min-width:1200px){.stats-grid{grid-template-columns:repeat(6,1fr)}}.stat-box{background:#8a64ff1a;border:1px solid rgba(138,100,255,.3);border-radius:12px;padding:20px 15px;text-align:center;transition:all .3s ease}.stat-box:hover{background:#8a64ff26;transform:translateY(-2px)}.stat-label{font-size:.85rem;color:#b1a0e5;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.5rem;font-weight:700;color:#c7b5ff}.trend-indicator{font-size:1.2rem}.trend-increasing{border-color:#22c55e80!important}.trend-decreasing{border-color:#ef444480!important}.trend-stable{border-color:#8b5cf64d!important}.section-title{font-size:1.3rem;font-weight:700;color:#c7b5ff;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid rgba(138,100,255,.2)}.exp-chart-section{margin-top:30px;padding:25px;background:#8a64ff0d;border-radius:12px;border:1px solid rgba(138,100,255,.2)}.exp-chart{display:flex;align-items:flex-end;justify-content:space-evenly;gap:15px;height:300px;padding:0;background:linear-gradient(180deg,#1b1d2299,#16171acc);border-radius:12px;position:relative;box-shadow:inset 0 2px 10px #00000080}.exp-chart:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,rgba(55,58,65,.6) 0px,rgba(55,58,65,.6) 1px,transparent 1px,transparent 20%);pointer-events:none;z-index:0}.chart-column{flex:1;display:flex;flex-direction:column;align-items:center;min-width:70px;position:relative;z-index:1}.chart-bar-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:300px;width:100%}.bar-value-label{font-size:.95rem;color:#f0f0f0;font-weight:700;text-shadow:1px 1px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,0 0 10px rgba(0,0,0,.8);white-space:nowrap;margin-bottom:8px;min-height:20px}.chart-labels{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 0;background:transparent}.chart-label-date{font-size:.85rem;color:#e8e8e8;text-align:center;white-space:nowrap;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.chart-label-day{font-size:.7rem;color:#bbb;text-align:center;white-space:nowrap;font-weight:500;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.eta-section{margin-top:30px}.eta-card{background:linear-gradient(135deg,#8b5cf626,#6366f11a);border:2px solid rgba(139,92,246,.3);border-radius:16px;padding:30px;display:flex;gap:30px;align-items:center}.eta-main{text-align:center;padding-right:30px;border-right:1px solid rgba(139,92,246,.3);min-width:200px}.eta-number{font-size:4rem;font-weight:900;color:#8b5cf6;text-shadow:0 0 30px rgba(139,92,246,.5);line-height:1;margin-bottom:10px}.eta-label{font-size:1.1rem;color:#c7b5ff;font-weight:600}.eta-details{flex:1;display:flex;flex-direction:column;gap:15px}.eta-detail-item{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#8a64ff1a;border-radius:8px;transition:all .2s ease}.eta-detail-item:hover{background:#8a64ff26;transform:translate(5px)}.eta-detail-label{font-size:.95rem;color:#b1a0e5;font-weight:500}.eta-detail-value{font-size:1.1rem;color:#dbd8e2;font-weight:700}.eta-detail-value.trend-increasing{color:#22c55e}.eta-detail-value.trend-decreasing{color:#ef4444}.eta-detail-value.trend-stable{color:#a78bfa}.exp-history{margin-top:30px;padding-top:20px;border-top:1px solid rgba(138,100,255,.2)}.history-title{font-size:1.2rem;font-weight:700;color:#c7b5ff;margin-bottom:15px}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#8a64ff0d;border-radius:8px;transition:all .2s ease}.history-item:hover{background:#8a64ff1a}.history-date{font-size:.9rem;color:#b1a0e5}.history-exp{font-size:.95rem;font-weight:600;color:#8fff8f}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1200px){.main-grid{grid-template-columns:1fr;gap:20px;padding-left:0}.character-info-card,.badges-card,.exp-graph-card,.eta-calculator-card,.calendar-card{grid-column:1;grid-row:auto;max-width:100%}.character-info-card{max-width:400px;margin:0 auto;min-height:auto}.badges-card{max-width:400px;margin:0 auto}.calendar-card{max-width:100%}}@media(max-width:1024px){.character-lookup.has-character{grid-template-columns:1fr;max-width:100%}.character-lookup.has-character .character-search-section{position:relative;width:100%;height:auto;border-right:none;border-bottom:1px solid rgba(139,92,246,.2);padding:20px}.character-lookup.has-character .content-section{margin-left:0;width:100%;padding:20px;transform:none}.search-header.minimized{justify-content:center}.search-form.minimized{flex-direction:row}.search-form.minimized .search-button{width:auto}}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-box{padding:10px 6px;min-height:70px}.stat-box-label{font-size:.55rem;min-height:24px}.stat-box-value{font-size:.95rem}.heatmap-calendar{padding:12px}.calendar-day{min-height:36px}.calendar-day .day-number{font-size:.8rem}.calendar-day .day-exp,.weekday-label{font-size:.55rem}.calendar-month{font-size:.9rem}.eta-content{grid-template-columns:1fr;gap:12px}.eta-section{padding:12px}.eta-input{font-size:.85rem}}@media(max-width:600px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:6px}.character-header{flex-direction:column;text-align:center}.title{font-size:2rem}.search-form{flex-direction:column}.search-button{width:100%}.calendar-day{min-height:32px}.calendar-day .day-number{font-size:.7rem}.calendar-day .day-exp{display:none}.calendar-legend{flex-wrap:wrap;justify-content:center}}@media(max-width:480px){.character-lookup.has-character .content-section{padding:10px}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-box{padding:8px 4px;min-height:60px}.stat-box-label{font-size:.5rem}.stat-box-value{font-size:.85rem}.calendar-day{min-height:28px;border-radius:4px}.calendar-day .day-number{font-size:.65rem}.weekday-label{font-size:.5rem}.character-info-card{padding:15px;width:100%;max-width:100%;box-sizing:border-box}.char-stats{flex-direction:column;gap:8px}.char-stat-item{width:100%;text-align:center}.badges-card{width:100%;max-width:100%;box-sizing:border-box}.badges-grid{flex-direction:column;gap:8px}.trend-badge{width:100%}.character-lookup.has-character .character-search-section{padding:15px 10px}.search-header h2{font-size:1.1rem}.exp-graph-card{padding:15px}.card-title{font-size:1.1rem}.eta-calculator-card{padding:15px}.eta-title{font-size:1rem}.calendar-card{padding:15px}.calendar-card .card-title{font-size:1rem}.heatmap-calendar{padding:10px}}.outfit-history-card{grid-column:1 / -1;background:linear-gradient(180deg,#1f2124 20%,#111 80%);border:3px solid rgba(100,100,120,.6);border-radius:14px;padding:24px;position:relative}.outfit-history-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.6) 50%,transparent)}.outfit-history-title{font-size:1.3rem;font-weight:700;color:#e8e8f0;text-align:center;margin-bottom:20px}.fashion-timeline{display:flex;flex-direction:column;align-items:center;padding:40px 20px 30px;min-height:500px;position:relative;box-sizing:border-box}.timeline-bar{position:relative;width:85%;max-width:800px;height:70px;margin-bottom:50px}.timeline-line{position:absolute;top:50%;left:0;right:0;height:3px;background:#3c4150cc;transform:translateY(-50%);border-radius:3px;box-shadow:inset 0 1px 2px #0006}.timeline-line:before{content:"";position:absolute;top:0;right:0;height:100%;width:var(--timeline-progress, 0%);background:linear-gradient(90deg,#a855f7,#8b5cf6e6);border-radius:3px;box-shadow:0 0 12px #8b5cf699;transition:width .4s ease}.timeline-node{position:absolute;top:50%;transform:translate(-50%,-50%) rotate(45deg);width:10px;height:10px;border-radius:2px;background:#464b5ae6;border:2px solid rgba(90,95,110,.8);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:2}.timeline-node:hover{background:#8b5cf699;border-color:#8b5cf6e6;transform:translate(-50%,-50%) rotate(45deg) scale(1.4);box-shadow:0 0 15px #8b5cf680}.timeline-node.active{width:16px;height:16px;background:linear-gradient(135deg,#8b5cf6,#a855f7);border:2px solid rgba(255,255,255,.7);box-shadow:0 0 20px #8b5cf6e6,0 0 40px #8b5cf666,inset 0 0 8px #ffffff4d;animation:nodeGlow 2s ease-in-out infinite alternate}@keyframes nodeGlow{0%{box-shadow:0 0 20px #8b5cf6e6,0 0 40px #8b5cf666}to{box-shadow:0 0 25px #8b5cf6,0 0 50px #8b5cf699}}.timeline-label{position:absolute;top:-70px;left:50%;transform:translate(-50%) rotate(-45deg) rotate(-8deg);text-align:center;white-space:nowrap;padding:8px 16px;background:#14161cf2;border-radius:8px;border:1px solid rgba(139,92,246,.4);box-shadow:0 4px 16px #0006}.timeline-date-main{display:block;font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:.02em}.timeline-date-sub{display:block;font-size:.75rem;color:#a855f7e6;margin-top:2px;font-weight:500}.fashion-display{display:flex;align-items:center;justify-content:center;width:100%;max-width:1200px;min-height:480px;position:relative}.fashion-nav-btn{position:absolute;width:52px;height:52px;border-radius:14px;background:linear-gradient(145deg,#2d3241f2,#1e212afa);border:1px solid rgba(80,85,100,.5);color:#b4b4c3e6;font-size:1.6rem;font-weight:300;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10;box-shadow:0 4px 16px #0000004d,inset 0 1px #ffffff0f,inset 0 -1px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.fashion-nav-btn:before{content:"";position:absolute;inset:3px;border-radius:11px;border:1px solid transparent;transition:border-color .3s ease}.fashion-nav-btn.left{left:10px}.fashion-nav-btn.right{right:10px}.fashion-nav-btn:hover{background:linear-gradient(145deg,#8b5cf640,#643cb433);border-color:#8b5cf699;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px #8b5cf640,0 4px 12px #0000004d,inset 0 1px #ffffff1a}.fashion-nav-btn:hover:before{border-color:#8b5cf64d}.fashion-nav-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0006,inset 0 2px 4px #0003}.fashion-side-preview{position:absolute;width:160px;height:210px;opacity:.4;transition:opacity .3s ease,transform .3s ease;cursor:pointer}.fashion-side-preview.left{left:100px;animation:slideFromLeft .4s cubic-bezier(.4,0,.2,1)}.fashion-side-preview.right{right:100px;animation:slideFromRight .4s cubic-bezier(.4,0,.2,1)}@keyframes slideFromLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:.4;transform:translate(0)}}@keyframes slideFromRight{0%{opacity:0;transform:translate(30px)}to{opacity:.4;transform:translate(0)}}.fashion-side-preview img{width:100%;height:100%;object-fit:contain;filter:grayscale(30%);transition:all .3s ease}.fashion-side-preview:hover{opacity:.75}.fashion-side-preview:hover img{filter:grayscale(0%);transform:scale(1.08)}.fashion-main{position:relative;width:380px;height:450px;display:flex;align-items:center;justify-content:center;z-index:5;animation:slideIn .4s cubic-bezier(.4,0,.2,1)}@keyframes slideIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.fashion-main-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:550px;height:550px;background:radial-gradient(ellipse at center,rgba(139,92,246,.55) 0%,rgba(120,70,200,.3) 25%,rgba(80,40,150,.15) 45%,transparent 65%);pointer-events:none;animation:glowPulse 3s ease-in-out infinite alternate}@keyframes glowPulse{0%{opacity:.85;transform:translate(-50%,-50%) scale(1)}to{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}.fashion-main img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 40px rgba(139,92,246,.7));transform:scale(1.3)}.fashion-date-label{margin-top:35px;padding:12px 32px;background:linear-gradient(145deg,#232630f2,#191c23fa);border-radius:12px;font-size:1rem;font-weight:600;color:#e8e8f0;letter-spacing:.03em;border:1px solid rgba(80,85,100,.4);box-shadow:0 4px 20px #00000059,inset 0 1px #ffffff0f,inset 0 -1px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5;animation:fadeUp .35s cubic-bezier(.4,0,.2,1)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1200px){.fashion-timeline,.outfit-history-title{padding-right:120px}}@media(max-width:900px){.fashion-timeline{padding-right:20px}.outfit-history-title{padding-right:0}.fashion-side-preview{width:100px;height:130px}.fashion-side-preview.left{left:60px}.fashion-side-preview.right{right:60px}.fashion-main{width:240px;height:300px}.fashion-main-glow{width:350px;height:350px}.fashion-nav-btn{width:44px;height:44px;font-size:1.4rem;border-radius:12px}.timeline-bar{width:95%}}@media(max-width:600px){.fashion-side-preview{display:none}.fashion-main{width:200px;height:260px}.fashion-main img{transform:scale(1.1)}.fashion-nav-btn.left{left:5px}.fashion-nav-btn.right{right:5px}}:root{--bg-deepest: #0f1012;--bg-dark: #161719;--bg-panel: #1c1d21;--bg-elevated: #232428;--bg-hover: #2a2b30;--bg-active: #323338;--accent-primary: #8b5cf6;--accent-secondary: #a78bfa;--accent-light: #c4b5fd;--accent-dark: #7c3aed;--accent-muted: rgba(139, 92, 246, .15);--accent-border: rgba(139, 92, 246, .4);--accent-gradient: linear-gradient(135deg, #8b5cf6 0%, #6366f1 100%);--accent-gradient-hover: linear-gradient(135deg, #9d7afa 0%, #7577f5 100%);--text-primary: #f4f4f5;--text-secondary: #e4e4e7;--text-muted: #a1a1aa;--text-faint: #71717a;--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .16);--border-accent: rgba(139, 92, 246, .4);--success: #22c55e;--success-light: #4ade80;--success-muted: rgba(34, 197, 94, .15);--success-border: rgba(34, 197, 94, .4);--info: #3b82f6;--info-light: #60a5fa;--info-muted: rgba(59, 130, 246, .15);--info-border: rgba(59, 130, 246, .4);--warning: #f59e0b;--warning-light: #fbbf24;--warning-muted: rgba(245, 158, 11, .15);--warning-border: rgba(245, 158, 11, .4);--danger: #ef4444;--danger-light: #f87171;--danger-muted: rgba(239, 68, 68, .15);--danger-border: rgba(239, 68, 68, .4);--rarity-common: #71717a;--rarity-rare: #3b82f6;--rarity-epic: #a855f7;--rarity-unique: #f97316;--rarity-legendary: #22c55e;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-accent: 0 4px 16px rgba(139, 92, 246, .25);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}.familiar-dice-page{min-height:calc(100vh - 70px);padding:35px 24px;background:transparent;width:100%;box-sizing:border-box}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.familiars-list,.decks-content-v2,.solver-content{animation:fadeIn 1.25s ease-out}.familiar-dice-container{max-width:1700px;width:100%;margin:0 auto;overflow:visible;box-sizing:border-box}.page-title{display:flex;align-items:center;justify-content:center;gap:16px;font-size:2.2rem;font-weight:700;color:var(--text-primary);margin-bottom:8px;filter:drop-shadow(0 2px 8px rgba(139,92,246,.4))}.title-icon{font-size:2.2rem;color:var(--accent-secondary);animation:diceFloat 2s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(139,92,246,.4))}@keyframes diceFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-7px) rotate(10deg)}}.page-subtitle{color:#ffffff80;font-size:1.05rem;margin-bottom:0;text-align:center}.page-credit{color:#ffffff80;font-size:.85rem;margin-bottom:28px;text-align:center}.three-column-layout{display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:18px;align-items:start;transition:grid-template-columns .4s cubic-bezier(.4,0,.2,1),gap .4s cubic-bezier(.4,0,.2,1)}.three-column-layout.solver-mode,.three-column-layout.expanded-mode{grid-template-columns:0fr 1fr 0fr;gap:0}.column{display:flex;flex-direction:column;gap:16px;min-width:0;overflow:visible;transition:opacity .35s ease,transform .35s ease}.column.hidden{opacity:0;transform:scale(.96);pointer-events:none;overflow:hidden;visibility:hidden}@keyframes solverExpand{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.column.solver-expanded .solver-panels{animation:solverExpand .35s cubic-bezier(.4,0,.2,1) .4s both}.column.solver-expanded{max-width:100%;width:100%;display:block}.column.solver-expanded .familiar-sets-section{max-width:100%;width:100%}.column.solver-expanded .solver-content{width:100%}.column.solver-expanded .solver-content>*{width:100%}.section-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin-bottom:14px;display:flex;align-items:center;gap:9px;filter:drop-shadow(0 2px 8px rgba(139,92,246,.3))}.section-title:before{content:"";width:4px;height:18px;background:linear-gradient(180deg,var(--accent-primary),#6366f1);border-radius:2px}.dice-section{background:linear-gradient(180deg,var(--bg-panel) 20%,var(--bg-deepest) 80%);border:2px solid rgba(80,81,88,.5);border-radius:14px;padding:18px;min-width:0;overflow:visible;box-sizing:border-box;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614}.dice-inputs{display:flex;flex-direction:column;gap:11px}.dice-input-wrapper{display:flex;align-items:center;gap:11px}.dice-label{font-size:.95rem;color:#ffffffb3;font-weight:500;width:60px;flex-shrink:0}.dice-input-container{position:relative;display:flex;align-items:center;flex:1}.dice-icon{position:absolute;left:14px;font-size:1.2rem;color:var(--accent-secondary);pointer-events:none}.dice-input{width:100%;height:46px;padding:0 16px 0 44px;font-size:1.2rem;font-weight:600;color:var(--text-primary);background:#1c1d21cc;border:1.5px solid rgba(80,81,88,.35);border-radius:9px;transition:all .3s ease}.dice-input:focus{outline:none;border-color:#8b5cf699;background:#232428e6;box-shadow:0 0 0 3px #8b5cf61a}.dice-input::placeholder{color:#ffffff4d}.reset-dice-btn{width:100%;padding:9px 16px;margin-top:11px;background:#50515833;border:1px solid rgba(80,81,88,.4);border-radius:9px;color:#ffffffb3;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.reset-dice-btn:hover{background:#50515859;border-color:#8b5cf680;color:#fff}.familiar-sets-section{background:linear-gradient(180deg,var(--bg-panel) 20%,var(--bg-deepest) 80%);border:2px solid rgba(80,81,88,.5);border-radius:14px;padding:18px;min-width:0;overflow:visible;box-sizing:border-box;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614}.solver-expanded .familiar-sets-section{width:100%;max-width:none}.familiars-list{display:flex;flex-direction:column;gap:10px;margin-bottom:12px;overflow:visible}.familiar-card{background:#1c1d2199;border:2px solid rgba(80,81,88,.4);border-radius:10px;padding:12px;transition:border-color .2s ease;overflow:visible}.familiar-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.lineup-monster-wrapper{position:relative}.lineup-monster-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;height:34px;background:linear-gradient(135deg,var(--bg-hover),var(--bg-elevated));border:1px solid var(--bg-active);border-radius:6px;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .15s ease;white-space:nowrap;box-sizing:border-box}.lineup-monster-btn:hover{background:linear-gradient(135deg,var(--bg-active),var(--bg-hover));color:var(--text-primary);border-color:var(--accent-primary)}.lineup-monster-dropdown.open-up{transform-origin:bottom center}.lineup-monster-dropdown{position:fixed;width:300px;max-height:450px;background:var(--bg-elevated);border:1px solid var(--bg-active);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:9999;overflow:hidden;display:flex;flex-direction:column}.lineup-monster-dropdown .monster-search-results{max-height:380px}.familiar-number{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:#8b5cf633;border-radius:50%;color:var(--accent-secondary);font-size:.75rem;font-weight:600;flex-shrink:0}.familiar-name-input{flex:1;padding:0 10px;height:34px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:6px;color:var(--text-primary);font-size:.9rem;font-weight:500;transition:all .2s ease;box-sizing:border-box}.familiar-name-input:focus{outline:none;border-color:#8b5cf699}.familiar-name-input::placeholder{color:#fff6}.familiar-attributes{display:flex;gap:8px;margin-bottom:10px}.familiar-attr{flex:1;display:flex;flex-direction:column;gap:4px;position:relative}.familiar-attr label{font-size:.7rem;color:#ffffff80;font-weight:500}.familiar-select{padding:6px 8px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:5px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;width:100%}.familiar-select:focus{outline:none;border-color:#8b5cf699}.familiar-select option{background:var(--bg-panel);color:var(--text-primary)}.familiar-select.rarity-select{border-width:2px}.attr-dropdown{position:relative;width:100%}.attr-dropdown-trigger{display:flex;align-items:center;gap:6px;width:100%;height:34px;padding:0 8px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:5px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;text-align:left;box-sizing:border-box}.attr-dropdown-trigger:hover{border-color:#8b5cf680}.attr-trigger-icon{width:22px;height:22px;object-fit:contain;flex-shrink:0}.attr-placeholder{color:#ffffff80}.attr-dropdown-trigger .dropdown-arrow{margin-left:auto;font-size:.6rem}.attr-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:3px;background:var(--bg-panel);border:1px solid rgba(80,81,88,.5);border-radius:6px;max-height:180px;overflow-y:auto;z-index:1000;box-shadow:0 6px 20px #00000080;animation:dropdownSlide .15s ease}.attr-dropdown-option{display:flex;align-items:center;gap:8px;padding:7px 10px;cursor:pointer;transition:background .15s ease;font-size:.8rem}.attr-dropdown-option:hover{background:#5051584d}.attr-dropdown-option.selected{background:#8b5cf633}.attr-option-icon{width:20px;height:20px;object-fit:contain;flex-shrink:0}.familiar-line-section{display:flex;flex-direction:column;gap:6px;overflow:visible}.familiar-line-section>label{font-size:.7rem;color:#ffffff80;font-weight:500}.familiar-line-dropdown{position:relative}.familiar-line-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:6px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;text-align:left}.familiar-line-trigger:hover{border-color:#8b5cf680}.familiar-line-trigger span:first-child{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-line{color:#ffffff80}.familiar-line-menu{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--bg-panel);border:1px solid rgba(80,81,88,.5);border-radius:8px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 8px 30px #00000080;animation:dropdownSlide .15s ease}.familiar-line-menu .dropdown-option{font-size:.8rem;padding:8px 10px}.familiar-line-config{display:flex;flex-direction:column;gap:6px;margin-top:6px;padding:8px;background:#16171980;border-radius:6px}.familiar-line-inputs{display:flex;gap:6px}.familiar-line-field{flex:1;display:flex;flex-direction:column;gap:2px;position:relative}.familiar-line-field label{font-size:.65rem;color:#ffffff80;font-weight:500}.familiar-line-field input{width:100%;padding:5px 8px;background:#1c1d21cc;border:1px solid rgba(80,81,88,.35);border-radius:4px;color:var(--text-primary);font-size:.8rem;font-weight:500;box-sizing:border-box}.familiar-line-field input:focus{outline:none;border-color:#8b5cf699}.familiar-line-field input::placeholder{color:#ffffff4d}.line-suffix{position:absolute;right:6px;bottom:5px;color:#8b5cf6b3;font-weight:600;font-size:.7rem}.apply-familiars-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:9px 14px;background:linear-gradient(135deg,var(--accent-primary) 0%,#6366f1 100%);border:none;border-radius:8px;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-bottom:12px}.apply-familiars-btn:hover:not(:disabled){background:linear-gradient(135deg,#9d7afa,#7577f5);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.apply-familiars-btn:disabled{opacity:.4;cursor:not-allowed}.save-to-decks-section{margin-top:16px;padding-top:16px;border-top:1px solid rgba(80,81,88,.2)}.save-to-decks-section.save-top{margin-top:0;margin-bottom:16px;padding-top:0;padding-bottom:12px;border-top:none;border-bottom:1px solid rgba(80,81,88,.2)}.save-to-decks-label{font-size:.8rem;color:#fff9;margin-bottom:8px}.save-set-row{display:flex;gap:8px}.set-name-input{flex:1;padding:8px 10px;background:#1c1d21cc;border:1px solid rgba(80,81,88,.35);border-radius:7px;color:var(--text-primary);font-size:.85rem;transition:all .2s ease}.set-name-input:focus{outline:none;border-color:#8b5cf699}.set-name-input::placeholder{color:#fff6}.save-set-btn{display:flex;align-items:center;gap:5px;padding:8px 12px;background:#4ade8026;border:1px solid rgba(74,222,128,.4);border-radius:7px;color:var(--success-light);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.save-set-btn:hover:not(:disabled){background:#4ade8040;border-color:var(--success-light)}.save-set-btn:disabled{opacity:.4;cursor:not-allowed}.saved-sets{display:flex;flex-direction:column;gap:6px}.saved-sets-label{font-size:.8rem;color:#ffffff80;margin-bottom:4px}.saved-set-item{display:flex;gap:6px}.load-set-btn{flex:1;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#1c1d2199;border:1px solid rgba(80,81,88,.3);border-radius:7px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .2s ease;text-align:left}.load-set-btn:hover{background:#32333880;border-color:#8b5cf666}.load-set-btn svg{color:var(--accent-secondary);font-size:.9rem}.delete-set-btn{display:flex;align-items:center;justify-content:center;width:32px;padding:0;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:7px;color:var(--danger);cursor:pointer;transition:all .2s ease}.delete-set-btn:hover{background:#ef444440;border-color:var(--danger)}.delete-set-btn svg{font-size:.8rem}.add-line-section{background:linear-gradient(180deg,var(--bg-panel) 20%,var(--bg-deepest) 80%);border:2px solid rgba(80,81,88,.5);border-radius:14px;padding:18px;min-width:0;overflow:hidden;box-sizing:border-box;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614}.dice-set-selector{margin-bottom:16px}.dice-set-label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#ffffffb3;margin-bottom:9px;font-weight:500}.dice-label-icons{display:flex;gap:4px;margin-left:8px}.dice-label-icons img{width:22px;height:22px;object-fit:contain;opacity:.7}.dice-set-dropdown-row{display:flex;gap:9px}.custom-dropdown{flex:1;position:relative;z-index:100}.custom-dropdown-trigger{width:100%;display:flex;align-items:center;gap:11px;padding:9px 14px;background:#1c1d21cc;border:1px solid rgba(80,81,88,.35);border-radius:9px;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:all .2s ease;text-align:left}.custom-dropdown-trigger:hover{border-color:#8b5cf680}.dropdown-selected-image{width:26px;height:26px;object-fit:contain;border-radius:4px}.dropdown-placeholder{color:#ffffff80}.dropdown-arrow{margin-left:auto;font-size:.75rem;color:#ffffff80;transition:transform .2s ease}.custom-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--bg-panel);border:1px solid rgba(80,81,88,.5);border-radius:9px;max-height:300px;overflow-y:auto;z-index:9999;box-shadow:0 8px 32px #0009;animation:dropdownSlide .15s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dropdown-group-label{padding:9px 14px 6px;font-size:.8rem;font-weight:600;color:var(--accent-secondary);background:var(--bg-panel);border-bottom:1px solid rgba(80,81,88,.2)}.dropdown-option{display:flex;align-items:center;gap:11px;padding:9px 14px;cursor:pointer;transition:background .15s ease;background:var(--bg-panel)}.dropdown-option:hover{background:#50515866}.dropdown-option.selected{background:#8b5cf633}.dropdown-option-image{width:26px;height:26px;object-fit:contain;border-radius:4px;flex-shrink:0}.dropdown-option-text{display:flex;flex-direction:column;gap:2px}.dropdown-option-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.dropdown-option-desc{color:#ffffff80;font-size:.75rem}.add-dice-set-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;background:linear-gradient(135deg,var(--accent-primary) 0%,#6366f1 100%);border:none;border-radius:9px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.add-dice-set-btn:hover:not(.disabled){background:linear-gradient(135deg,#9d7afa,#7577f5);transform:translateY(-1px);box-shadow:0 4px 14px #8b5cf64d}.add-dice-set-btn.disabled{opacity:.4;cursor:not-allowed}.dice-set-preview{display:flex;align-items:center;gap:11px;margin-top:9px;padding:9px 14px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:9px;animation:slideDown .2s ease}.dice-set-description{color:var(--accent-light);font-size:.9rem;font-weight:500}.section-divider{display:flex;align-items:center;gap:14px;margin:16px 0;color:#fff6;font-size:.8rem}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(80,81,88,.4),transparent)}.template-selector{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;width:100%}.template-btn{padding:11px 14px;background:#1c1d2199;border:1px solid rgba(80,81,88,.25);border-radius:7px;color:#ffffffb3;font-size:.9rem;cursor:pointer;transition:all .2s ease;text-align:left}.template-btn:hover{background:#32333880;border-color:#8b5cf666;color:#fff}.template-btn.selected{background:#8b5cf626;border-color:#8b5cf680;color:#fff;box-shadow:0 0 14px #8b5cf633}.line-builder{background:#1c1d2180;border-radius:11px;padding:14px;animation:slideDown .2s ease;display:flex;flex-direction:column;gap:11px;min-height:110px;width:100%;box-sizing:border-box}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.builder-inputs{display:flex;flex-wrap:wrap;gap:9px;min-height:55px;width:100%}.builder-field{display:flex;flex-direction:column;gap:4px;position:relative;flex:1 1 110px}.builder-field label{font-size:.75rem;color:#fff9;font-weight:500}.builder-field input{width:100%;padding:9px 11px;background:#1c1d21cc;border:1px solid rgba(80,81,88,.35);border-radius:7px;color:var(--text-primary);font-size:.95rem;font-weight:500;transition:all .2s ease;box-sizing:border-box}.builder-field input:focus{outline:none;border-color:#8b5cf699;box-shadow:0 0 0 2px #8b5cf61a}.builder-field input::placeholder{color:#ffffff4d}.input-suffix{position:absolute;right:11px;bottom:9px;color:#8b5cf6b3;font-weight:600;font-size:.85rem}.add-line-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:11px 18px;background:linear-gradient(135deg,var(--accent-primary) 0%,#6366f1 100%);border:none;border-radius:9px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:0;box-shadow:0 4px 14px #8b5cf640}.add-line-btn:hover:not(.disabled){background:linear-gradient(135deg,#9d7afa,#7577f5);transform:translateY(-1px);box-shadow:0 6px 22px #8b5cf666}.add-line-btn.disabled{opacity:.4;cursor:not-allowed}.active-lines-section{background:linear-gradient(180deg,var(--bg-panel) 20%,var(--bg-deepest) 80%);border:2px solid rgba(80,81,88,.5);border-radius:14px;padding:18px;min-width:0;overflow:hidden;box-sizing:border-box;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614}.active-lines-section.expedition-bonuses{border-color:#50515880}.active-lines-section.expedition-bonuses .section-title:before{background:linear-gradient(180deg,var(--accent-secondary),var(--accent-primary))}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:11px}.section-header .section-title{margin-bottom:0}.clear-all-btn{display:flex;align-items:center;gap:6px;padding:7px 11px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:7px;color:var(--danger);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-all-btn:hover{background:#ef444440;border-color:var(--danger)}.clear-all-btn.confirming{background:var(--danger);border-color:var(--danger);color:#fff;animation:pulse-warning .5s ease-in-out infinite alternate}@keyframes pulse-warning{0%{opacity:1}to{opacity:.7}}.no-lines{text-align:center;color:#fff6;padding:18px;font-size:.9rem}.lines-list{display:flex;flex-direction:column;gap:7px}.line-item{display:flex;align-items:center;gap:11px;padding:11px 14px;background:#1c1d2199;border:1px solid rgba(80,81,88,.2);border-radius:9px;animation:lineAppear .2s ease;position:relative}@keyframes lineAppear{0%{opacity:0;transform:translate(-15px)}to{opacity:1;transform:translate(0)}}.line-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#8b5cf633;border-radius:50%;color:var(--accent-secondary);font-size:.75rem;font-weight:600;flex-shrink:0}.line-dice-image{width:30px;height:30px;object-fit:contain;border-radius:4px;flex-shrink:0}.line-item.is-dice-set{border-color:#8b5cf64d}.line-text{flex:1;color:#ffffffe6;font-size:.9rem;line-height:1.4}.line-content{flex:1;display:flex;flex-direction:column;gap:4px}.line-condition{color:var(--text-muted);font-size:.8rem;font-style:italic}.line-divider{display:flex;align-items:center;justify-content:center;color:var(--accent-primary);font-size:1rem;margin:4px 0}.line-divider svg{width:18px;height:18px}.line-effect{color:var(--text-primary);font-size:.9rem;font-weight:500}@media(min-width:1200px){.line-content{flex-direction:row;align-items:center;gap:10px}.line-condition{font-size:.85rem}.line-divider{margin:0}.line-divider svg{width:16px;height:16px}.line-effect{font-size:.9rem}}.line-item.has-warning{border-color:#fbbf2466}.line-item.has-info{border-color:#60a5fa4d}.line-warning{display:flex;align-items:center;justify-content:center;color:var(--warning-light);font-size:.95rem;cursor:help;flex-shrink:0;animation:warningPulse 2s ease-in-out infinite}.line-info{display:flex;align-items:center;justify-content:center;color:var(--info-light);font-size:.9rem;cursor:help;flex-shrink:0}.line-info:hover{color:var(--info-light)}.line-warning:hover:after{content:"Not working as intended in-game - results may be inaccurate";position:absolute;bottom:100%;right:0;background:#1c1d21f2;border:1px solid rgba(251,191,36,.5);color:var(--warning-light);padding:7px 11px;border-radius:7px;font-size:.8rem;white-space:nowrap;z-index:10;margin-bottom:7px}@keyframes warningPulse{0%,to{opacity:.7}50%{opacity:1}}.line-remove-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:var(--danger);cursor:pointer;transition:all .2s ease;flex-shrink:0;padding:0}.line-remove-btn svg{width:13px;height:13px;fill:currentColor}.line-remove-btn:hover{background:#ef444440;border-color:var(--danger);transform:scale(1.05)}.line-remove-btn.confirming{width:auto;padding:0 9px;background:#ef44444d;border-color:var(--danger);font-size:.75rem;font-weight:600;animation:pulse .5s ease-in-out infinite alternate}@keyframes pulse{0%{opacity:.8}to{opacity:1}}.results-section{background:linear-gradient(180deg,var(--bg-panel) 20%,var(--bg-deepest) 80%);border:2px solid rgba(80,81,88,.5);border-radius:14px;padding:18px;min-width:0;overflow:hidden;box-sizing:border-box;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614}.results-box{background:#1c1d2199;border-radius:11px;padding:14px}.result-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0}.result-row:not(:last-child){border-bottom:1px solid rgba(80,81,88,.15)}.result-label{color:#ffffffb3;font-size:.95rem}.result-value{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.result-value.multiplier{color:var(--accent-secondary)}.result-value.bonus{color:var(--success-light)}.result-divider{height:2px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.4),transparent);margin:7px 0}.result-row.final{padding-top:11px}.result-row.final .result-label{font-size:1rem;font-weight:600;color:#fff}.final-value{font-size:1.65rem!important;color:var(--accent-light)!important;text-shadow:0 0 18px rgba(139,92,246,.4)}.no-result{text-align:center;color:#fff6;font-size:.95rem;padding:14px}.familiar-line-browser-menu{position:fixed;background:var(--bg-panel);border:1px solid var(--accent-primary);border-radius:6px;z-index:9999;max-height:400px;min-width:350px;display:flex;flex-direction:column;box-shadow:0 8px 32px #000000b3}.browser-header{display:flex;gap:6px;padding:8px;border-bottom:1px solid var(--bg-active);background:var(--bg-hover)}.browser-search-input{flex:1;position:relative}.browser-search-input .search-icon-small{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text-faint);font-size:.7rem}.browser-search-input input{width:100%;padding:6px 8px 6px 26px;border:1px solid var(--bg-active);border-radius:4px;background:var(--bg-panel);color:var(--text-primary);font-size:.75rem;box-sizing:border-box}.browser-search-input input:focus{outline:none;border-color:var(--accent-primary)}.tier-filter-small{padding:6px 8px;border:1px solid var(--bg-active);border-radius:4px;background:var(--bg-panel);color:var(--text-primary);font-size:.7rem;cursor:pointer;min-width:70px}.browser-option.none-option{padding:8px 12px;color:var(--text-muted);cursor:pointer;border-bottom:1px solid var(--bg-active);font-size:.8rem}.browser-option.none-option:hover{background:var(--bg-active)}.browser-option.none-option.selected{background:var(--bg-active);color:var(--text-primary)}.browser-conditions-scroll{overflow-y:auto;flex:1;padding:6px}.browser-conditions-scroll::-webkit-scrollbar{width:5px}.browser-conditions-scroll::-webkit-scrollbar-track{background:var(--bg-panel)}.browser-conditions-scroll::-webkit-scrollbar-thumb{background:var(--bg-active);border-radius:3px}.browser-condition-group{margin-bottom:8px}.browser-condition-label{font-size:.9rem;color:#ffffffb3;padding:4px 8px;background:var(--bg-hover);border-radius:4px;margin-bottom:4px;font-weight:500}.browser-line-option{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:4px;cursor:pointer;transition:background .15s;font-size:.75rem;color:var(--text-secondary)}.browser-line-option:hover{background:var(--bg-active)}.browser-line-text{flex:1;margin-right:8px}.browser-line-tier{font-size:.65rem;font-weight:600;padding:2px 5px;border-radius:3px;background:#0000004d;white-space:nowrap}.familiar-line-display{margin-top:8px;padding:8px 10px;background:var(--bg-panel);border:1px solid var(--bg-active);border-radius:6px;font-size:.75rem}.line-display-condition{color:var(--text-muted);font-size:.7rem;margin-bottom:4px}.line-display-effect{color:var(--text-primary);font-weight:500;margin-bottom:6px}.line-display-stats{display:flex;gap:10px}.line-display-stats .stat-dice{color:var(--accent-primary);font-weight:600}.line-display-stats .stat-mult{color:var(--success);font-weight:600}.browser-filter-row{display:flex;align-items:center;padding:6px 8px;border-bottom:1px solid var(--bg-active);background:var(--bg-hover)}.applicable-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.72rem;color:var(--text-muted)}.applicable-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent-primary);cursor:pointer}.applicable-toggle:hover{color:var(--text-primary)}.toggle-label{-webkit-user-select:none;user-select:none}.line-item.condition-not-met{opacity:.5;border-color:#ef44444d;background:#ef44440d}.line-condition.not-met{color:var(--danger);text-decoration:line-through}.not-met-badge{margin-left:6px;color:var(--danger);font-weight:700;font-size:.8rem}.threshold-config-overlay{padding:12px;display:flex;flex-direction:column;gap:10px}.threshold-config-title{font-size:.9rem;font-weight:600;color:var(--text-primary);text-align:center}.threshold-config-condition{font-size:.8rem;color:var(--text-muted);text-align:center;padding:8px;background:var(--bg-hover);border-radius:4px}.threshold-config-input-row{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.8rem;color:var(--text-secondary)}.threshold-input{width:60px;padding:6px 8px;border:1px solid var(--accent-primary);border-radius:4px;background:var(--bg-panel);color:var(--text-primary);font-size:.85rem;text-align:center}.threshold-input:focus{outline:none;border-color:var(--accent-light)}.threshold-config-effect{font-size:.75rem;color:var(--text-faint);text-align:center;padding:6px;background:var(--bg-panel);border-radius:4px}.threshold-config-buttons{display:flex;gap:8px;margin-top:4px}.threshold-cancel-btn,.threshold-confirm-btn{flex:1;padding:8px 12px;border:none;border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.threshold-cancel-btn{background:var(--bg-active);color:var(--text-muted)}.threshold-cancel-btn:hover{background:var(--bg-active);color:var(--text-primary)}.threshold-confirm-btn{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-dark) 100%);color:#fff}.threshold-confirm-btn:hover{background:linear-gradient(135deg,var(--accent-secondary) 0%,#6a5a9a 100%)}.threshold-config-overlay.solver-threshold{background:var(--bg-elevated);border-radius:6px;margin:8px;border:1px solid var(--accent-primary)}@media(max-width:1100px){.three-column-layout{grid-template-columns:1fr 1fr}.three-column-layout .column:last-child{grid-column:1 / -1}}@media(max-width:700px){.three-column-layout{grid-template-columns:1fr}}@media(max-width:480px){.familiar-dice-page{padding:22px 14px}.page-title,.title-icon{font-size:1.75rem}.dice-section,.add-line-section,.active-lines-section,.results-section{padding:14px}}.familiar-tabs{display:flex;gap:0;margin-bottom:16px;border-radius:8px;overflow:hidden;background:var(--bg-panel);border:1px solid var(--border-default)}.familiar-tab{flex:1;padding:12px 16px;background:var(--bg-elevated);border:none;color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.familiar-tab:hover{background:#8b5cf633;color:var(--accent-light)}.familiar-tab.active{background:var(--accent-gradient)!important;color:#fff!important;box-shadow:0 2px 8px #8b5cf666}.familiar-tab.disabled{color:var(--text-faint);cursor:not-allowed;opacity:.6}.familiar-tab.disabled:hover{background:transparent;color:var(--text-faint)}.solver-content{padding:20px}.solver-placeholder{text-align:center;padding:40px 20px;background:#8b5cf61a;border:1px dashed rgba(139,92,246,.4);border-radius:12px}.solver-placeholder h3{font-size:1.4rem;color:var(--accent-light);margin-bottom:12px}.solver-placeholder p{color:var(--text-muted);font-size:.95rem;line-height:1.5;margin-bottom:20px}.solver-features{display:flex;flex-direction:column;gap:10px;text-align:left;max-width:320px;margin:0 auto}.feature-item{padding:10px 14px;background:#0f101280;border-radius:6px;color:var(--text-muted);font-size:.85rem}.decks-content-v2{padding:12px 0}.decks-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.create-deck-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,var(--accent-primary) 0%,#6366f1 100%);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.create-deck-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #8b5cf666}.decks-count{color:var(--text-muted);font-size:.85rem}.no-decks-message{text-align:center;padding:40px 20px;color:var(--text-muted)}.decks-list-v2{display:flex;flex-direction:column;gap:10px;padding-left:0}.deck-item-v2{background:#0f101299;border:1px solid rgba(139,92,246,.3);border-radius:12px;overflow:visible;transition:all .2s ease;position:relative}.deck-item-v2.expanded{border-color:#ffffff26;background:linear-gradient(135deg,#282a36e6,#1e202af2);box-shadow:0 0 0 1px #ffffff14,0 8px 32px #0006,inset 0 1px #ffffff0d}.deck-item-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:background .2s ease;gap:16px}.deck-item-header:hover{background:#8b5cf614}.deck-item-info{display:flex;align-items:center;gap:16px;flex:1;min-width:0}.deck-item-name{font-weight:600;color:var(--text-primary);font-size:.9rem;background:#8b5cf626;padding:4px 12px;border-radius:6px;border-left:3px solid var(--accent-primary);white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.deck-mini-preview{display:flex;align-items:center;gap:12px}.deck-mini-familiar{display:flex;align-items:center;gap:4px}.deck-mini-portrait{width:28px;height:28px;border-radius:4px;border:2px solid #666;overflow:hidden;background:#0f1012cc;display:flex;align-items:center;justify-content:center;flex-shrink:0}.deck-mini-portrait img{width:100%;height:100%;object-fit:cover}.deck-mini-portrait .mini-placeholder{color:#ffffff4d;font-size:.65rem}.deck-mini-icon{width:14px;height:14px;object-fit:contain;opacity:.8}.deck-total-ap{font-size:.7rem;color:var(--warning-light);font-weight:500;background:#fbbf241f;padding:3px 8px;border-radius:10px;white-space:nowrap;margin-left:4px}.deck-item-actions{display:flex;align-items:center;gap:8px}.deck-mini-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:1rem;background:var(--bg-elevated);color:var(--text-muted)}.deck-mini-btn svg{width:16px;height:16px;color:inherit;fill:currentColor;flex-shrink:0}.deck-mini-btn.load{background:var(--accent-muted);border:1px solid var(--accent-border);color:var(--accent-secondary)}.deck-mini-btn.load svg{color:var(--accent-secondary)!important;fill:var(--accent-secondary)!important}.deck-mini-btn.load:hover{background:var(--accent-primary);border-color:var(--accent-primary)}.deck-mini-btn.load:hover svg{color:#fff;fill:#fff}.deck-mini-btn.delete{background:#ef444433;border:1px solid rgba(239,68,68,.4)}.deck-mini-btn.delete svg{color:var(--danger-light);fill:var(--danger-light)}.deck-mini-btn.delete:hover{background:var(--danger);border-color:var(--danger)}.deck-mini-btn.delete:hover svg{color:#fff;fill:#fff}.deck-mini-btn.delete.confirming{background:var(--danger);border-color:var(--danger);color:#fff;font-size:.65rem;font-weight:600;padding:4px 8px;min-width:50px;animation:confirmPulse .5s ease-in-out infinite alternate}@keyframes confirmPulse{0%{box-shadow:0 0 4px #ef444480}to{box-shadow:0 0 10px #ef4444cc}}.deck-mini-btn.expedition{background:#f59e0b26;border:1px solid rgba(245,158,11,.4);color:var(--warning)}.deck-mini-btn.expedition svg{color:var(--warning)!important;fill:var(--warning)!important}.deck-mini-btn.expedition:hover{background:var(--warning);border-color:var(--warning)}.deck-mini-btn.expedition:hover svg{color:#fff!important;fill:#fff!important}.deck-mini-btn.expedition.active{background:var(--warning);border-color:var(--warning);animation:expeditionPulse 2s ease-in-out infinite}.deck-mini-btn.expedition.active svg{color:#fff!important;fill:#fff!important}@keyframes expeditionPulse{0%,to{box-shadow:0 0 4px #f59e0b80}50%{box-shadow:0 0 12px #f59e0bcc}}.deck-item-v2.on-expedition{border-color:var(--warning);background:linear-gradient(135deg,rgba(245,158,11,.08) 0%,var(--bg-panel) 100%)}.deck-item-v2.on-expedition .deck-item-header{border-color:var(--warning)}.deck-expedition-badge{position:absolute;left:-32px;top:50%;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--warning);border-radius:6px;color:#1a1a1a;font-size:.75rem;box-shadow:0 2px 8px #f59e0b66;animation:expeditionFloat 3s ease-in-out infinite}.deck-expedition-badge svg{font-size:.8rem}@keyframes expeditionFloat{0%,to{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 2px))}}.deck-expand-arrow{color:var(--text-muted);font-size:.7rem;transition:transform .2s ease;margin-left:4px}.deck-expand-arrow.open{transform:rotate(180deg)}.deck-expanded-content{padding:16px;border-top:1px solid rgba(255,255,255,.1);background:#0f101266}.deck-edit-header{display:flex;gap:12px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.deck-name-edit{flex:1;min-width:200px;padding:10px 14px;background:#0f1012b3;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;font-size:1rem;font-weight:500}.deck-name-edit:focus{outline:none;border-color:var(--accent-primary)}.auto-save-hint{font-size:.75rem;color:#fff6;font-style:italic}.deck-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.deck-btn.save{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:var(--success)}.deck-btn.save:hover{background:#22c55e40;border-color:var(--success)}.deck-monsters-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:1000px){.deck-monsters-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.deck-monsters-grid{grid-template-columns:1fr}}.monster-card{display:flex;flex-direction:column;background:#0f1012b3;border-radius:14px;border:3px solid var(--rarity-color, var(--text-faint));overflow:hidden;transition:all .2s ease}.monster-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}.monster-portrait{position:relative;width:100%;height:120px;background:linear-gradient(180deg,#0003,#00000080);display:flex;align-items:center;justify-content:center;border-bottom:2px solid var(--rarity-color, var(--text-faint))}.monster-img{max-width:90%;max-height:100px;object-fit:contain}.monster-type-icon{width:70px;height:70px;object-fit:contain;opacity:.8}.monster-placeholder{font-size:3rem;color:#ffffff26}.rarity-badge{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;box-shadow:0 2px 8px #0000004d}.monster-info{padding:14px;display:flex;flex-direction:column;gap:10px}.monster-name-input{padding:10px 12px;background:#0f1012b3;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;font-size:1rem;font-weight:600;text-align:center}.monster-name-input:focus{outline:none;border-color:var(--accent-primary)}.monster-type-row,.monster-stats-row{display:flex;gap:8px}.monster-select{flex:1;padding:8px 10px;background:#0f1012cc;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fff;font-size:.8rem;cursor:pointer}.monster-select:focus{outline:none;border-color:var(--accent-primary)}.monster-select.rarity{border-width:2px;font-weight:500}.monster-select.dice{background:#8b5cf633}.monster-ap-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f973161a;border-radius:6px;border:1px solid rgba(249,115,22,.3)}.monster-ap-row label{font-size:.8rem;font-weight:600;color:var(--rarity-unique)}.monster-ap-input{flex:1;padding:6px 10px;background:#0f1012b3;border:1px solid rgba(249,115,22,.3);border-radius:4px;color:#fff;font-size:.9rem;text-align:center}.monster-ap-input:focus{outline:none;border-color:var(--rarity-unique)}.monster-line{padding:10px 12px;background:#8b5cf61a;border-radius:8px;border-left:3px solid var(--accent-primary)}.monster-line-condition{font-size:.75rem;color:var(--text-muted);margin-bottom:6px;line-height:1.4}.monster-line-bonuses{display:flex;gap:8px}.line-bonus{font-size:.8rem;font-weight:600;padding:4px 8px;border-radius:4px}.line-bonus.dice{background:#22c55e33;color:var(--success)}.line-bonus.mult{background:#8b5cf633;color:var(--accent-secondary)}.no-line{font-size:.8rem;color:#fff6;font-style:italic}.deck-actions{display:flex;gap:8px}.deck-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease}.deck-action-btn.load{background:linear-gradient(135deg,var(--accent-primary) 0%,#6366f1 100%);color:#fff}.deck-action-btn.load:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.deck-action-btn.save{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:var(--success)}.deck-action-btn.save:hover{background:#22c55e40;border-color:var(--success)}.deck-action-btn.clear{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:var(--danger);flex:0;padding:8px 10px}.deck-action-btn.clear:hover{background:#ef444440;border-color:var(--danger)}.deck-monsters-accordion{display:flex;flex-direction:column;gap:8px}.monster-accordion{background:#1c1e2480;border:2px solid rgba(50,51,56,.3);border-radius:8px;overflow:hidden;transition:all .3s ease}.monster-accordion.expanded{background:#1c1d2199;box-shadow:0 2px 12px #0003}.monster-accordion-header{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background .2s ease}.monster-accordion-header:hover{background:#ffffff08}.monster-mini-portrait{width:42px;height:42px;border-radius:6px;border:1px solid rgba(80,81,88,.3);background:#16171999;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.mini-portrait-img{width:100%;height:100%;object-fit:cover}.mini-portrait-type{width:28px;height:28px;opacity:.7}.mini-portrait-placeholder{font-size:1.2rem;color:#ffffff4d}.monster-summary{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.monster-summary-name{font-size:.9rem;font-weight:500;color:#f4f4f5e6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monster-summary-meta{font-size:.7rem;color:#ffffff80;display:flex;align-items:center;gap:4px}.summary-meta-icon{width:14px;height:14px;object-fit:contain}.meta-dot{color:#ffffff4d}.familiar-ap-badge{color:var(--warning-light);font-weight:500}.familiar-dice-cap{display:flex;align-items:center;gap:3px;cursor:help}.dice-cap-icon{font-size:.75rem;color:var(--info-light)}.dice-cap-label{color:#fff6;font-size:.65rem;text-transform:uppercase}.dice-cap-value{color:var(--info-light);font-weight:600}.monster-line-preview{flex-shrink:0}.monster-line-preview .has-line{padding:3px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.monster-line-preview .no-line-preview{color:#ffffff40;font-size:.75rem;font-style:italic;font-weight:400}.monster-expand-arrow{font-size:.7rem;color:#fff6;transition:transform .3s ease;flex-shrink:0}.monster-expand-arrow.expanded{transform:rotate(180deg)}.monster-accordion-content{padding:12px 16px 16px;border-top:1px solid rgba(50,51,56,.15);background:transparent}.monster-expanded-layout{display:flex;flex-direction:column;align-items:center;gap:16px}.monster-large-portrait{width:185px;height:185px;padding:8px;border-radius:10px;border:2px solid rgba(80,81,88,.4);background:#161719cc;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:0 4px 16px #0000004d;box-sizing:border-box}.large-portrait-img{width:100%;height:calc(100% - 10px);object-fit:contain;border-radius:6px;margin-bottom:10px;scale:1}.large-portrait-type{width:50px;height:50px;opacity:.5}.large-portrait-placeholder{font-size:2rem;color:#ffffff26}.rarity-corner-badge{position:absolute;bottom:0;left:0;right:0;text-align:center;padding:2px 4px;font-size:.6rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.3px;background:#0f1012e6}.monster-expanded-details{width:100%;display:flex;flex-direction:column;gap:12px}.monster-selector-row{display:flex;align-items:center;gap:10px}.monster-selector{flex:1;height:34px;padding:0 8px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:5px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;box-sizing:border-box}.monster-selector:focus{outline:none;border-color:#8b5cf699}.monster-selector option{background:var(--bg-panel);color:var(--text-primary)}.monster-selector optgroup{background:var(--bg-hover);color:var(--text-muted);font-weight:600;font-style:normal}.deck-monster-selector-wrapper{position:relative;flex:1}.deck-monster-selector-btn{width:100%;height:34px;padding:0 10px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:5px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;gap:8px}.deck-monster-selector-btn:hover{border-color:#8b5cf699;background:#1e2028e6}.deck-monster-selector-btn .selector-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deck-monster-selector-menu{background:#161719fa;border:1px solid rgba(80,81,88,.4);border-radius:8px;box-shadow:0 8px 32px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column}.monster-search-container{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(80,81,88,.3);position:sticky;top:0;background:#161719fa;z-index:2}.monster-search-icon{color:#fff6;font-size:.85rem;flex-shrink:0}.monster-search-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:.85rem;outline:none}.monster-search-input::placeholder{color:#fff6}.monster-search-clear{background:transparent;border:none;color:#fff6;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.monster-search-clear:hover{color:#fff}.monster-options-list{overflow-y:auto;flex:1;max-height:280px}.monster-no-results{padding:20px;text-align:center;color:#fff6;font-size:.85rem}.monster-region-group{border-bottom:1px solid rgba(80,81,88,.2)}.monster-region-group:last-child{border-bottom:none}.monster-region-label{padding:8px 12px 4px;font-size:.7rem;font-weight:600;color:#a78bfacc;text-transform:uppercase;letter-spacing:.5px;background:#23242880;position:sticky;top:0;z-index:1}.monster-option{display:flex;align-items:center;gap:10px;padding:6px 12px;cursor:pointer;transition:all .15s ease}.monster-option:hover{background:#8b5cf633}.monster-option-img{width:32px;height:32px;object-fit:cover;border-radius:4px;border:1px solid rgba(80,81,88,.3);background:#0f1012b3}.monster-option-name{flex:1;font-size:.8rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monster-option-icons{display:flex;gap:4px;align-items:center}.monster-option-type-icon,.monster-option-element-icon{width:18px;height:18px;object-fit:contain}.or-divider{font-size:.7rem;color:#fff6;text-transform:uppercase;letter-spacing:.5px}.monster-name-large{flex:1;height:34px;padding:0 10px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:5px;color:var(--text-primary);font-size:.85rem;font-weight:500;box-sizing:border-box}.monster-name-large:focus{outline:none;border-color:#8b5cf699}.monster-stats-grid{display:grid;grid-template-columns:1fr 1fr 1fr 60px;gap:8px}.stat-group{display:flex;flex-direction:column;gap:3px}.stat-group label{font-size:.6rem;color:#ffffff4d;text-transform:uppercase;letter-spacing:.3px;text-align:center}.monster-stat-select,.monster-ap-large{height:34px;padding:0 8px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:5px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;box-sizing:border-box}.monster-stat-select:focus,.monster-ap-large:focus{outline:none;border-color:#8b5cf699}.monster-stat-select option{background:var(--bg-panel);color:var(--text-primary)}.monster-stat-select.rarity-select{border-width:2px}.monster-ap-large{width:100%;max-width:60px;text-align:center;box-sizing:border-box}.monster-line-section{display:flex;flex-direction:column;gap:6px;padding-top:10px;margin-top:4px;border-top:1px solid rgba(50,51,56,.12)}.monster-line-section>label{font-size:.6rem;color:#ffffff59;text-transform:uppercase;letter-spacing:.5px;text-align:center}.current-line-display{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:#16171980;border:1px solid rgba(50,51,56,.2);border-radius:6px}.current-line-text{display:flex;align-items:center;gap:6px;font-size:.75rem;flex-wrap:wrap;line-height:1.5}.line-condition-text{color:#a1a1aab3}.line-arrow-icon{color:#78798080;flex-shrink:0;font-size:.7rem}.line-effect-text{color:#f4f4f5d9}.current-line-actions{display:flex;align-items:center;gap:8px}.current-line-bonuses{display:flex;gap:6px;flex:1}.bonus-tag{padding:2px 5px;border-radius:3px;font-size:.65rem;font-weight:500}.bonus-tag.dice{background:#22c55e26;color:#4ade80e6}.bonus-tag.mult{background:#8b5cf626;color:#a78bfae6}.change-line-btn{padding:4px 10px;background:transparent;border:1px solid rgba(80,81,88,.25);border-radius:4px;color:#a1a1aacc;font-size:.7rem;cursor:pointer;transition:all .2s ease}.change-line-btn:hover{background:#ffffff0d;border-color:#78798066;color:var(--text-primary)}.clear-line-btn{padding:4px 6px;background:transparent;border:1px solid rgba(239,68,68,.25);border-radius:4px;color:#c86464cc;cursor:pointer;transition:all .2s ease}.clear-line-btn:hover{background:#ef44441a;border-color:#ef444480;color:#e88}.add-line-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:transparent;border:1px dashed rgba(50,51,56,.3);border-radius:5px;color:#a1a1aa99;font-size:.75rem;cursor:pointer;transition:all .2s ease}.add-line-btn:hover{background:#ffffff08;border-color:#50515866;border-style:solid;color:#d4d4d8e6}.deck-line-browser{margin-top:8px;background:var(--bg-panel);border:1px solid var(--accent-primary);border-radius:6px;overflow:hidden;box-shadow:0 8px 32px #00000080}.deck-browser-controls{display:flex;gap:6px;padding:8px;background:var(--bg-hover);border-bottom:1px solid var(--bg-active)}.deck-browser-search{flex:1;padding:6px 8px;background:var(--bg-panel);border:1px solid var(--bg-active);border-radius:4px;color:var(--text-primary);font-size:.75rem}.deck-browser-search:focus{outline:none;border-color:var(--accent-primary)}.deck-browser-tier{padding:6px 8px;background:var(--bg-panel);border:1px solid var(--bg-active);border-radius:4px;color:var(--text-primary);font-size:.75rem;cursor:pointer}.deck-browser-tier:focus{outline:none;border-color:var(--accent-primary)}.deck-browser-tier option{background:var(--bg-panel);color:var(--text-primary)}.deck-browser-lines{max-height:280px;overflow-y:auto;padding:8px}.deck-browser-condition{margin-bottom:8px}.deck-browser-condition .condition-header{font-size:.9rem;color:#ffffffb3;padding:4px 8px;background:var(--bg-hover);border-radius:4px;margin-bottom:4px;font-weight:500}.deck-browser-line-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:4px;cursor:pointer;transition:background .15s}.deck-browser-line-item:hover{background:var(--bg-active)}.deck-browser-line-item .line-template{flex:1;font-size:.75rem;color:var(--text-secondary);margin-right:8px}.line-bonuses-preview{display:flex;gap:4px;flex-shrink:0}.bonus-mini{font-size:.65rem;font-weight:600;padding:2px 5px;border-radius:3px;background:#0000004d;white-space:nowrap}.bonus-mini.dice{color:var(--success-light)}.bonus-mini.mult{color:var(--accent-secondary)}.no-lines-found{text-align:center;padding:20px;color:#fff6;font-size:.8rem}.deck-attr-dropdown{position:relative;width:100%}.deck-attr-trigger{width:100%;height:34px;display:flex;align-items:center;gap:6px;padding:0 8px;background:#161719cc;border:1px solid rgba(80,81,88,.35);border-radius:5px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;box-sizing:border-box}.deck-attr-trigger:hover{border-color:#8b5cf680}.deck-attr-icon{width:18px;height:18px;object-fit:contain}.deck-attr-placeholder{color:#fff6}.deck-dropdown-arrow{margin-left:auto;font-size:.6rem;color:#fff6}.deck-attr-menu{position:fixed;z-index:9999;background:var(--bg-panel);border:1px solid var(--accent-primary);border-radius:5px;max-height:200px;overflow-y:auto;box-shadow:0 8px 32px #000000b3;min-width:120px}.deck-attr-option{display:flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;transition:background .15s;font-size:.8rem;color:var(--text-primary)}.deck-attr-option:hover{background:var(--bg-active)}.deck-attr-option.selected{background:#8b5cf64d}.deck-attr-option-icon{width:20px;height:20px;object-fit:contain}.monster-stat-select.rarity-select{font-weight:600}.solver-content{display:flex;flex-direction:column;gap:16px;padding:0;width:100%;min-width:0}.solver-panels{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:16px;width:100%;min-height:500px}.solver-panels-v2{display:grid;grid-template-columns:220px minmax(280px,400px) 1fr;gap:16px;width:100%;min-height:500px}.solver-col{background:linear-gradient(145deg,#232428f2,#1c1d21fa);border:1px solid rgba(139,92,246,.25);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.solver-col-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:linear-gradient(145deg,#8b5cf633,#8b5cf614);border-bottom:1px solid rgba(139,92,246,.2)}.solver-col-header h3{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0}.solver-count-badge{background:#8b5cf666;color:var(--accent-light);font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:10px}.solver-col-body{padding:12px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.solver-col-list{min-width:0;max-height:600px}.solver-col-list .solver-col-body{overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.4) transparent}.solver-col-list .solver-col-body::-webkit-scrollbar{width:6px}.solver-col-list .solver-col-body::-webkit-scrollbar-track{background:transparent}.solver-col-list .solver-col-body::-webkit-scrollbar-thumb{background:#8b5cf666;border-radius:3px}.solver-add-btn-compact{display:flex;align-items:center;justify-content:center;width:100%;padding:10px;background:linear-gradient(145deg,#8b5cf64d,#8b5cf626);border:1px dashed rgba(139,92,246,.5);border-radius:8px;color:var(--accent-light);font-size:1.1rem;cursor:pointer;transition:all .2s;flex-shrink:0}.solver-add-btn-compact:hover{background:linear-gradient(145deg,#8b5cf666,#8b5cf640);border-color:#8b5cf6b3}.solver-familiar-thumbs{display:flex;flex-direction:column;gap:6px}.solver-thumb{position:relative;display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;border:2px solid var(--text-faint);background:#1e2128cc;cursor:pointer;transition:all .2s}.solver-thumb:hover{background:#232428e6;box-shadow:0 2px 8px #0000004d}.solver-thumb.selected{box-shadow:0 0 0 2px #8b5cf6cc,0 4px 12px #8b5cf666;background:#8b5cf626}.solver-thumb-img{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}.solver-thumb-placeholder{width:40px;height:40px;border-radius:6px;background:#8b5cf633;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;color:var(--text-faint);flex-shrink:0}.solver-thumb-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.solver-thumb-name{font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.solver-thumb-meta{display:flex;align-items:center;gap:6px}.solver-thumb-icon{width:16px;height:16px;object-fit:contain}.solver-thumb-line-dot{width:8px;height:8px;background:var(--success);border-radius:50%;box-shadow:0 0 4px #22c55e80;flex-shrink:0;margin-left:auto}.solver-thumb.on-expedition{opacity:.6;position:relative}.solver-thumb.on-expedition:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(245,158,11,.1) 4px,rgba(245,158,11,.1) 8px);pointer-events:none;border-radius:8px}.solver-thumb-expedition-icon{position:absolute;top:4px;right:4px;color:var(--warning);font-size:.7rem;z-index:5;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.solver-col-detail{min-width:0}.solver-detail-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-faint);font-size:.9rem;text-align:center}.solver-detail-content{display:flex;flex-direction:column;gap:16px}.solver-detail-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(139,92,246,.2)}.solver-detail-img{width:64px;height:64px;border-radius:8px;object-fit:cover;border:2px solid rgba(139,92,246,.4)}.solver-detail-img-placeholder{width:64px;height:64px;border-radius:8px;background:#8b5cf633;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;color:var(--text-faint);border:2px solid rgba(139,92,246,.4)}.solver-detail-title{flex:1;display:flex;flex-direction:column;gap:4px}.solver-detail-name{font-size:1.1rem;font-weight:600}.solver-detail-meta{font-size:.85rem;color:var(--text-muted)}.solver-detail-delete{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:var(--danger);padding:8px;border-radius:6px;cursor:pointer;transition:all .2s}.solver-detail-delete:hover{background:#ef44444d}.solver-detail-delete.confirming{background:var(--danger);border-color:var(--danger);color:#fff;font-size:.75rem;font-weight:600;padding:8px 12px;animation:confirmPulse .5s ease-in-out infinite alternate}.solver-detail-fields{display:flex;flex-direction:column;gap:12px}.solver-detail-field{display:flex;flex-direction:column;gap:4px}.solver-detail-field label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.solver-name-with-search{display:flex;gap:8px}.solver-name-with-search input{flex:1;min-width:0}.solver-monster-select-wrapper{position:relative}.solver-monster-select-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:linear-gradient(135deg,var(--bg-hover),var(--bg-elevated));border:1px solid var(--bg-active);border-radius:6px;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .15s ease;white-space:nowrap}.solver-monster-select-btn:hover{background:linear-gradient(135deg,var(--bg-active),var(--bg-hover));color:var(--text-primary);border-color:var(--accent-primary)}.solver-monster-select-dropdown{position:fixed;width:300px;max-height:500px;background:var(--bg-elevated);border:1px solid var(--bg-active);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:9999;overflow:hidden;display:flex;flex-direction:column}.solver-monster-select-dropdown .monster-search-input{border-radius:0}.solver-monster-select-dropdown .monster-search-results{max-height:430px}.solver-detail-field input,.solver-detail-field select{background:var(--bg-panel);border:1px solid rgba(139,92,246,.4);border-radius:6px;padding:8px 10px;color:var(--text-primary);font-size:.9rem}.solver-detail-field select.locked{opacity:.6;cursor:not-allowed;background:var(--bg-deepest);border-color:var(--border-subtle)}.solver-locked-display{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-muted);font-size:.9rem;cursor:not-allowed}.locked-display-icon{width:18px;height:18px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.solver-select-with-icon{display:flex;align-items:center;gap:0;position:relative}.solver-select-with-icon .select-icon{position:absolute;left:8px;width:16px;height:16px;object-fit:contain;pointer-events:none;z-index:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.solver-select-with-icon select{padding-left:30px;width:100%}.solver-attr-dropdown-wrapper{position:relative}.solver-attr-dropdown-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:var(--bg-panel);border:1px solid var(--accent-border);border-radius:6px;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s ease}.solver-attr-dropdown-trigger:hover{border-color:var(--accent-primary);background:var(--bg-elevated)}.solver-attr-icon{width:18px;height:18px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.solver-attr-arrow{margin-left:auto;font-size:.7rem;opacity:.6}.solver-attr-placeholder{color:var(--text-muted)}.solver-attr-dropdown-menu{position:fixed;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border:1px solid var(--accent-border);border-radius:8px;box-shadow:var(--shadow-lg);z-index:9999;max-height:250px;overflow-y:auto}.solver-attr-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:all .15s ease;color:var(--text-primary);font-size:.9rem}.solver-attr-option:hover{background:var(--accent-muted)}.solver-attr-option.selected{background:var(--accent-muted);border-left:3px solid var(--accent-primary)}.solver-attr-option:first-child{border-radius:8px 8px 0 0}.solver-attr-option:last-child{border-radius:0 0 8px 8px}.solver-detail-field label{display:flex;align-items:center;gap:6px}.field-lock-icon{font-size:.7rem;opacity:.5;color:var(--text-muted)}.field-label-icon{width:16px;height:16px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.solver-detail-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.solver-detail-line-section{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid rgba(139,92,246,.2)}.solver-detail-line-section>label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.solver-browse-line-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:linear-gradient(145deg,#8b5cf640,#8b5cf61a);border:1px dashed rgba(139,92,246,.5);border-radius:6px;color:var(--accent-light);font-size:.85rem;cursor:pointer;transition:all .2s}.solver-browse-line-btn:hover{background:linear-gradient(145deg,#8b5cf659,#8b5cf633)}.solver-detail-line{display:flex;align-items:flex-start;gap:8px;padding:10px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:6px}.solver-detail-line-info{flex:1;display:flex;flex-direction:column;gap:4px}.solver-detail-line-condition{font-size:.8rem;color:var(--text-muted);font-style:italic}.solver-detail-line-effect{font-size:.9rem;color:var(--text-primary)}.solver-detail-line-remove{background:transparent;border:none;color:var(--text-muted);padding:4px;cursor:pointer;transition:color .2s}.solver-detail-line-remove:hover{color:var(--danger)}.solver-col-right{display:flex;flex-direction:column;gap:0;background:transparent;border:none}.solver-expedition-compact{background:linear-gradient(145deg,#232428f2,#1c1d21fa);border:1px solid rgba(139,92,246,.25);border-radius:12px;padding:12px;margin-bottom:12px}.solver-expedition-row{display:flex;gap:10px;align-items:flex-end}.solver-expedition-row .solver-expedition-field{flex:1}.solver-run-btn-compact{background:linear-gradient(145deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:6px;padding:8px 14px;color:#fff;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.solver-run-btn-compact:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.solver-run-btn-compact:disabled{opacity:.5;cursor:not-allowed}.solver-hint-inline{font-size:.75rem;color:var(--text-muted);margin:6px 0 0;text-align:center}.solver-results-area{flex:1;background:linear-gradient(145deg,#232428f2,#1c1d21fa);border:1px solid rgba(139,92,246,.25);border-radius:12px;padding:14px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 300px);min-height:300px}.solver-results-area .solver-results-categories{display:flex;flex-direction:column;gap:16px}.solver-results-area .solver-result-familiar{border:2px solid transparent;border-radius:8px;padding:6px}.solver-results-header{padding-bottom:8px;border-bottom:1px solid rgba(139,92,246,.2)}.solver-results-header h4{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0}@media(max-width:1200px){.solver-panels-v2{grid-template-columns:200px minmax(250px,350px) 1fr}}@media(max-width:1000px){.solver-panels-v2{grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr}.solver-col-list{grid-column:1 / -1;max-height:250px}.solver-familiar-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media(max-width:700px){.solver-panels-v2,.solver-detail-row{grid-template-columns:1fr}.solver-expedition-row{flex-direction:column}.solver-run-btn-compact{width:100%}}.solver-panel{background:linear-gradient(145deg,#232428f2,#1c1d21fa);border:1px solid rgba(139,92,246,.25);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.solver-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(145deg,#8b5cf633,#8b5cf614);border-bottom:1px solid rgba(139,92,246,.2)}.solver-panel-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:.3px}.solver-panel-count{background:#8b5cf666;color:var(--accent-light);font-size:.8rem;font-weight:600;padding:2px 10px;border-radius:12px}.solver-panel-body{padding:16px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.solver-panel-familiars{min-width:0}.solver-add-familiar-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;background:linear-gradient(145deg,#8b5cf64d,#8b5cf626);border:1px dashed rgba(139,92,246,.5);border-radius:8px;color:var(--accent-light);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.solver-add-familiar-btn:hover{background:linear-gradient(145deg,#8b5cf666,#8b5cf640);border-color:#8b5cf6b3}.solver-familiars-list{display:flex;flex-direction:column;gap:8px}.solver-panel-expedition .solver-panel-body{justify-content:flex-start}.solver-expedition-fields{display:flex;flex-direction:column;gap:12px}.solver-expedition-field{display:flex;flex-direction:column;gap:6px}.solver-expedition-field label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.solver-select{background:var(--bg-panel);border:1px solid rgba(139,92,246,.4);border-radius:6px;padding:10px 12px;color:var(--text-primary);font-size:.9rem;cursor:pointer;width:100%}.solver-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #8b5cf633}.solver-run-btn{background:linear-gradient(145deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:8px;padding:12px 20px;color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;white-space:nowrap;width:100%;margin-top:8px}.solver-run-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.solver-hint{font-size:.8rem;color:var(--text-muted);text-align:center;margin:8px 0 0}.solver-panel-results .solver-panel-body{gap:16px}.solver-empty-results,.solver-empty-state{display:flex;align-items:center;justify-content:center;height:100%;min-height:120px;color:var(--text-faint);font-size:.9rem;text-align:center;padding:20px}.solver-results-categories{display:flex;flex-direction:column;gap:16px}.solver-section-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 12px}.solver-expedition-section{background:linear-gradient(145deg,#8b5cf626,#232428cc);border:1px solid rgba(139,92,246,.3);border-radius:10px;padding:16px;width:100%;box-sizing:border-box}.solver-expedition-selectors{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}@media(max-width:1200px){.solver-panels{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.solver-panel-familiars{grid-column:1 / -1}}@media(max-width:768px){.solver-panels{grid-template-columns:1fr}.solver-panel-familiars{grid-column:auto}}.solver-run-btn:hover:not(:disabled){background:linear-gradient(145deg,var(--accent-secondary),#9b8ac4);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.solver-run-btn:disabled{opacity:.5;cursor:not-allowed}.solver-results-section{background:#22c55e14;border:1px solid rgba(34,197,94,.3);border-radius:10px;padding:16px;width:100%;box-sizing:border-box}.solver-results-list{display:flex;flex-direction:column;gap:12px}.solver-result-card{background:var(--bg-panel);border:1px solid rgba(139,92,246,.3);border-radius:8px;padding:12px}.solver-result-card.best{border-color:var(--success);box-shadow:0 0 12px #22c55e33}.solver-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.solver-result-rank{font-size:1.1rem;font-weight:700;color:var(--success)}.solver-result-card:not(.best) .solver-result-rank{color:var(--text-muted)}.solver-result-score{font-size:.85rem;color:var(--text-muted)}.solver-result-familiars{display:flex;gap:8px;margin-bottom:10px}.solver-result-familiar{flex:1;background:#23242880;border-radius:6px;padding:8px;display:flex;gap:8px;align-items:center}.solver-result-familiar.matching{background:#8b5cf633;border:1px solid rgba(139,92,246,.4)}.solver-result-img{width:36px;height:36px;border-radius:4px;object-fit:cover}.solver-result-familiar-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.solver-result-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.solver-result-meta{font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.match-badge{font-size:.6rem;font-weight:700;padding:1px 4px;border-radius:3px;margin-left:2px}.match-badge.element{background:var(--rarity-rare);color:#fff}.match-badge.type{background:var(--rarity-unique);color:#fff}.solver-result-lines{font-size:.7rem;color:var(--accent-primary)}.solver-result-stats{display:flex;gap:16px;font-size:.75rem;color:var(--text-muted);padding-top:8px;border-top:1px solid rgba(255,255,255,.05)}.solver-result-actions{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.05)}.solver-result-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:none;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.solver-result-btn.apply{background:linear-gradient(135deg,var(--info),#2563eb);color:#fff}.solver-result-btn.apply:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.solver-result-btn.save{background:linear-gradient(135deg,var(--success),#059669);color:#fff}.solver-result-btn.save:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.solver-result-btn.expedition{background:linear-gradient(135deg,var(--warning),#d97706);color:#fff}.solver-result-btn.expedition:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.solver-result-btn.expedition.confirming{background:linear-gradient(135deg,#dc2626,#b91c1c);animation:expeditionConfirmPulse .5s ease-in-out infinite alternate;min-width:70px}.solver-result-btn.expedition.confirming:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 4px 12px #dc262666}@keyframes expeditionConfirmPulse{0%{box-shadow:0 0 4px #dc262680}to{box-shadow:0 0 10px #dc2626cc}}.solver-familiars-section{background:#23242880;border:1px solid rgba(139,92,246,.2);border-radius:10px;padding:16px;width:100%;box-sizing:border-box}.solver-familiars-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.solver-add-familiar-wrapper{position:relative}.solver-add-btn{display:flex;align-items:center;gap:6px;background:#8b5cf64d;border:1px solid rgba(139,92,246,.5);border-radius:6px;padding:8px 14px;color:var(--accent-light);font-size:.85rem;cursor:pointer;transition:all .2s}.solver-add-btn:hover{background:#8b5cf680}.solver-monster-dropdown{background:var(--bg-panel);border:1px solid rgba(139,92,246,.5);border-radius:8px;box-shadow:0 8px 24px #0006;overflow:hidden}.solver-monster-search{width:100%;padding:10px 12px;background:var(--bg-active);border:none;border-bottom:1px solid rgba(139,92,246,.3);color:var(--text-primary);font-size:.9rem}.solver-monster-search:focus{outline:none;background:var(--bg-active)}.solver-monster-list{max-height:300px;overflow-y:auto}.solver-monster-option{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .15s}.solver-monster-option:hover{background:#8b5cf633}.solver-monster-option.custom{background:#8b5cf61a;border-bottom:1px solid rgba(139,92,246,.2);color:var(--accent-light);font-weight:500}.solver-region-group{border-bottom:1px solid rgba(255,255,255,.05)}.solver-region-label{padding:6px 12px;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--accent-primary);background:#232428cc;position:sticky;top:0}.solver-monster-img{width:28px;height:28px;border-radius:4px;object-fit:cover}.solver-monster-name{flex:1;font-size:.85rem;color:var(--text-primary)}.solver-monster-meta{font-size:.7rem;color:var(--text-muted)}.solver-empty-state{text-align:center;padding:32px;color:var(--text-faint)}.solver-familiars-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.solver-familiar-card{background:var(--bg-panel);border:2px solid var(--bg-active);border-radius:8px;overflow:hidden;transition:all .2s}.solver-familiar-card.expanded{border-color:#8b5cf699;box-shadow:0 4px 16px #0000004d}.solver-familiar-header{display:flex;align-items:center;gap:12px;padding:10px 12px;cursor:pointer;transition:background .15s}.solver-familiar-header:hover{background:#23242880}.solver-familiar-img{width:40px;height:40px;border-radius:6px;object-fit:cover}.solver-familiar-summary{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.solver-familiar-name{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.solver-familiar-meta{font-size:.75rem;color:var(--text-muted)}.solver-familiar-line-count{font-size:.75rem;color:var(--accent-primary);padding:4px 8px;background:#8b5cf626;border-radius:4px}.solver-familiar-delete{padding:6px;background:transparent;border:none;color:var(--text-faint);cursor:pointer;transition:color .15s}.solver-familiar-delete:hover{color:var(--danger)}.solver-familiar-expanded{padding:12px;border-top:1px solid rgba(255,255,255,.1);background:#2324284d}.solver-familiar-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.solver-field{display:flex;flex-direction:column;gap:4px}.solver-field label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.solver-field input,.solver-field select{background:var(--bg-panel);border:1px solid rgba(139,92,246,.3);border-radius:5px;padding:8px 10px;color:var(--text-primary);font-size:.85rem}.solver-field input:focus,.solver-field select:focus{outline:none;border-color:var(--accent-primary)}.solver-familiar-lines{background:#16171980;border-radius:6px;padding:10px}.solver-lines-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.85rem;color:var(--text-primary)}.solver-add-line-btn{display:flex;align-items:center;gap:4px;background:#8b5cf633;border:1px solid rgba(139,92,246,.4);border-radius:4px;padding:5px 10px;color:var(--accent-light);font-size:.75rem;cursor:pointer;transition:all .15s}.solver-add-line-btn:hover{background:#8b5cf666}.solver-no-lines{text-align:center;color:var(--text-faint);font-size:.8rem;padding:16px}.solver-lines-list{display:flex;flex-direction:column;gap:6px}.solver-line-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px;background:#23242880;border-radius:5px;font-size:.8rem}.solver-line-content{display:flex;align-items:center;gap:6px;flex:1;overflow:hidden}.solver-line-condition{color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.solver-line-arrow{color:var(--text-faint);flex-shrink:0}.solver-line-effect{color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.solver-line-meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.solver-line-bonus{font-size:.7rem;padding:2px 6px;border-radius:3px;font-weight:600}.solver-line-bonus.dice{background:#3b82f633;color:var(--info-light)}.solver-line-bonus.mult{background:#f59e0b33;color:var(--warning-light)}.solver-line-remove{background:transparent;border:none;padding:4px;color:var(--text-faint);cursor:pointer;transition:color .15s}.solver-line-remove:hover{color:var(--danger)}.solver-line-browser{background:var(--bg-panel);border:1px solid rgba(139,92,246,.5);border-radius:8px;box-shadow:0 8px 24px #00000080;overflow:hidden;max-height:350px;display:flex;flex-direction:column}.solver-line-browser-header{display:flex;gap:6px;padding:8px;background:var(--bg-active);border-bottom:1px solid rgba(139,92,246,.3)}.solver-line-search{flex:1;background:var(--bg-panel);border:1px solid rgba(139,92,246,.3);border-radius:4px;padding:6px 10px;color:var(--text-primary);font-size:.8rem}.solver-line-search:focus{outline:none;border-color:var(--accent-primary)}.solver-tier-select{background:var(--bg-panel);border:1px solid rgba(139,92,246,.3);border-radius:4px;padding:6px 8px;color:var(--text-primary);font-size:.75rem}.solver-close-browser{background:transparent;border:none;padding:6px;color:var(--text-muted);cursor:pointer}.solver-close-browser:hover{color:var(--text-primary)}.solver-line-browser-list{flex:1;overflow-y:auto;padding:4px}.solver-line-group{margin-bottom:8px}.solver-line-condition-header{padding:6px 8px;font-size:.7rem;color:var(--text-muted);background:#23242880;border-radius:4px;margin-bottom:4px}.solver-line-option{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;cursor:pointer;border-radius:4px;transition:background .15s}.solver-line-option:hover{background:#8b5cf633}.solver-line-text{font-size:.8rem;color:var(--text-primary)}.solver-line-bonuses{display:flex;gap:4px}.solver-line-bonuses .bonus{font-size:.65rem;padding:2px 5px;border-radius:3px;font-weight:600}.solver-line-bonuses .bonus.dice{background:#3b82f633;color:var(--info-light)}.solver-line-bonuses .bonus.mult{background:#f59e0b33;color:var(--warning-light)}.solver-result-lines-breakdown{display:flex;flex-direction:column;gap:4px;margin:8px 0;padding:8px;background:#16171980;border-radius:6px;font-size:.75rem}.solver-line-breakdown-item{display:flex;align-items:center;gap:6px;color:var(--text-muted)}.solver-line-familiar-name{color:var(--accent-light);font-weight:500;min-width:80px}.solver-line-breakdown-item .solver-line-condition{color:var(--text-faint);max-width:none}.solver-line-breakdown-item .solver-line-effect{color:var(--text-primary)}.solver-familiar-line-count.empty{opacity:.5}.solver-add-line-btn.full-width{width:100%;justify-content:center;padding:10px}.solver-line-change{background:#8b5cf633;border:1px solid rgba(139,92,246,.4);border-radius:4px;padding:4px 8px;color:var(--accent-light);font-size:.7rem;cursor:pointer;transition:all .15s}.solver-line-change:hover{background:#8b5cf666}.solver-results-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.solver-result-category{display:flex;flex-direction:column;gap:8px}.solver-category-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:6px 12px;border-radius:4px;width:fit-content}.solver-category-label.best-overall{background:#22c55e33;color:var(--success);border:1px solid rgba(34,197,94,.4)}.solver-category-label.both-match{background:#a855f733;color:var(--rarity-epic);border:1px solid rgba(168,85,247,.4)}.solver-category-label.two-match{background:#3b82f633;color:var(--rarity-rare);border:1px solid rgba(59,130,246,.4)}.solver-category-label.one-match{background:#f9731633;color:var(--rarity-unique);border:1px solid rgba(249,115,22,.4)}.solver-no-matches-hint{padding:12px 16px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:6px;color:var(--warning-light);font-size:.85rem;text-align:center}.bonus-guaranteed{color:var(--info-light)}.bonus-conditional{color:var(--info-light);opacity:.85}.multi-guaranteed{color:var(--success)}.multi-conditional{color:var(--warning-light);opacity:.9}.familiars-collection-content{animation:fadeIn .25s ease-out;padding:16px 0}.collection-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.collection-header h3{margin:0;font-size:1.25rem;color:var(--text-secondary)}.collection-count{background:#8b5cf633;color:var(--accent-secondary);padding:4px 10px;border-radius:12px;font-size:.85rem;font-weight:500}.collection-description{color:var(--text-muted);font-size:.9rem;margin-bottom:16px}.collection-add-section{margin-bottom:20px}.collection-add-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,var(--accent-primary) 0%,#6366f1 100%);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.collection-add-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.collection-empty{padding:40px 20px;text-align:center;background:#1c1d2180;border:1px dashed rgba(120,121,128,.3);border-radius:12px;color:var(--text-muted)}.collection-grid{display:flex;flex-direction:column;gap:12px}.collection-familiar-card{display:flex;align-items:flex-start;gap:14px;padding:14px;background:#1c1d2199;border:2px solid;border-radius:10px;transition:all .2s ease}.collection-familiar-card:hover{background:#1c1d21cc}.collection-familiar-portrait{width:56px;height:56px;border-radius:8px;border:2px solid;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#0f101299}.collection-familiar-portrait img{width:100%;height:100%;object-fit:contain}.collection-familiar-portrait .portrait-placeholder{color:var(--text-faint);font-size:1.5rem}.collection-familiar-info{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.collection-familiar-name{background:#0f101280;border:1px solid rgba(120,121,128,.2);border-radius:6px;padding:8px 10px;color:var(--text-secondary);font-size:.95rem;width:100%}.collection-familiar-name:focus{outline:none;border-color:var(--accent-primary)}.collection-familiar-meta{display:flex;gap:8px;flex-wrap:wrap}.collection-select{background:#0f101280;border:1px solid rgba(120,121,128,.2);border-radius:6px;padding:6px 10px;color:var(--text-secondary);font-size:.85rem;min-width:100px}.collection-select:focus{outline:none;border-color:var(--accent-primary)}.collection-select.rarity{border-width:2px}.collection-familiar-line{font-size:.85rem}.collection-line-display{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:6px;flex-wrap:wrap}.collection-line-display .line-condition{color:var(--text-muted);font-style:italic}.collection-line-display .line-effect{color:var(--accent-secondary)}.collection-line-display .line-clear-btn{margin-left:auto;background:transparent;border:none;color:var(--danger);cursor:pointer;padding:4px;opacity:.7}.collection-line-display .line-clear-btn:hover{opacity:1}.no-line-text{color:var(--text-faint);font-style:italic}.collection-delete-btn{background:transparent;border:none;color:var(--danger);cursor:pointer;padding:8px;opacity:.6;transition:opacity .2s ease;flex-shrink:0}.collection-delete-btn:hover{opacity:1}.deck-slots{display:flex;flex-direction:column;gap:10px;margin-top:12px}.deck-slot{background:#1c1d2199;border:2px solid var(--bg-active);border-radius:8px;overflow:hidden;transition:all .2s ease}.deck-slot.has-familiar{border-width:2px}.deck-slot.expanded{background:#1c1d21e6}.deck-slot-header{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .2s ease}.deck-slot-header:hover{background:#2a2b3080}.slot-number{font-size:.8rem;font-weight:600;color:var(--text-faint);min-width:24px}.slot-portrait{width:36px;height:36px;border-radius:6px;border:2px solid currentColor;overflow:hidden;flex-shrink:0}.slot-portrait img{width:100%;height:100%;object-fit:cover}.slot-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#2a2b3099;color:var(--text-faint);font-size:1rem}.slot-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.slot-name{font-size:.9rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-meta{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.slot-icon{width:14px;height:14px;object-fit:contain}.slot-line-badge{font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:4px;background:#ffffff1a;margin-left:4px}.slot-empty-text{color:var(--text-faint);font-style:italic;font-size:.9rem}.slot-expand-arrow{color:var(--text-faint);font-size:.8rem;transition:transform .2s ease}.slot-expand-arrow.expanded{transform:rotate(180deg)}.deck-slot-content{padding:12px 16px 16px;border-top:1px solid rgba(80,81,88,.3);background:#0f101266}.slot-selector-section{display:flex;flex-direction:column;gap:10px}.slot-selector-section label{font-size:.85rem;color:var(--text-muted);font-weight:500}.slot-selector-dropdown{position:relative;width:100%}.slot-selector-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:6px;border:1px solid var(--bg-active);background:var(--bg-elevated);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color .2s ease}.slot-selector-trigger:hover{border-color:var(--text-faint)}.slot-trigger-content{display:flex;align-items:center;gap:10px}.slot-trigger-portrait{width:28px;height:28px;border-radius:4px;border:2px solid currentColor;overflow:hidden;flex-shrink:0}.slot-trigger-portrait img{width:100%;height:100%;object-fit:cover}.slot-trigger-name{font-weight:500}.slot-trigger-placeholder{color:var(--text-faint)}.slot-trigger-arrow{color:var(--text-faint);font-size:.8rem;margin-left:auto}.slot-selector-menu{background:var(--bg-elevated);border:1px solid var(--bg-active);border-radius:8px;box-shadow:0 8px 24px #00000080;max-height:350px;display:flex;flex-direction:column;overflow:hidden}.slot-selector-menu.open-up{flex-direction:column-reverse}.slot-selector-menu.open-up .slot-selector-search{border-bottom:none;border-top:1px solid var(--bg-hover)}.slot-selector-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--bg-hover)}.slot-search-icon{color:var(--text-faint);font-size:.85rem;flex-shrink:0}.slot-selector-search input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:.9rem;outline:none}.slot-selector-search input::placeholder{color:var(--text-faint)}.slot-selector-options{overflow-y:auto;max-height:260px;scrollbar-width:thin;scrollbar-color:var(--bg-active) transparent}.slot-selector-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .15s ease}.slot-selector-option:hover{background:#8b5cf626}.slot-selector-option.selected{background:#8b5cf640}.slot-option-empty{color:var(--text-faint);font-style:italic}.slot-option-portrait{width:36px;height:36px;border-radius:6px;border:2px solid currentColor;overflow:hidden;flex-shrink:0;background:#2a2b3080}.slot-option-portrait img{width:100%;height:100%;object-fit:cover}.slot-option-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.slot-option-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.slot-option-name{font-weight:500;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-option-icons{display:flex;gap:4px;flex-shrink:0}.slot-option-icon{width:16px;height:16px;object-fit:contain}.slot-option-line{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.slot-option-condition{color:var(--text-primary);max-width:290px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-option-arrow{color:var(--text-faint);font-size:.65rem;flex-shrink:0}.slot-option-effect{color:var(--success);font-weight:500}.slot-selector-option.create-new{display:flex;align-items:center;gap:10px;padding:12px;background:#8b5cf61a;border-bottom:1px solid var(--bg-hover);color:var(--accent-secondary);font-weight:500}.slot-selector-option.create-new:hover{background:#8b5cf640}.slot-option-create-icon,.slot-option-create-text{font-size:.9rem}.familiars-collection-v2{width:100%;min-height:600px;height:600px;animation:fadeIn .25s ease-out;display:flex;flex-direction:column}.collection-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--bg-hover)}.collection-title-row{display:flex;align-items:center;gap:10px}.collection-title-row h3{margin:0;color:var(--text-primary);font-size:1.1rem}.collection-count-badge{background:var(--accent-primary);color:#fff;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:10px}.collection-toolbar-buttons{display:flex;gap:8px}.collection-add-btn-v2{display:flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-dark));border:none;border-radius:6px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.collection-add-btn-v2:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.collection-delete-btn-v2{display:flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,var(--danger),#dc2626);border:none;border-radius:6px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.collection-delete-btn-v2:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.collection-delete-btn-v2:disabled{background:linear-gradient(135deg,var(--text-faint),var(--bg-active));cursor:not-allowed;opacity:.6}.collection-delete-btn-v2.active{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 0 12px #ef444480;animation:deletePulse 1.5s ease-in-out infinite}.collection-undo-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:6px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;animation:fadeIn .2s ease-out}.collection-undo-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b66}@keyframes deletePulse{0%,to{box-shadow:0 0 12px #ef444480}50%{box-shadow:0 0 20px #ef4444cc}}.collection-card-compact.delete-mode{cursor:pointer;position:relative}.collection-card-compact.delete-mode:after{content:"✕";position:absolute;top:4px;right:4px;width:20px;height:20px;background:#ef4444e6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;font-weight:700;opacity:.7;transition:all .2s ease}.collection-card-compact.delete-mode:hover:after{opacity:1;transform:scale(1.1)}.collection-card-compact.delete-mode:hover{border-color:var(--danger)!important;box-shadow:0 0 12px #ef444466}.collection-empty-v2{text-align:center;padding:40px 20px;color:var(--text-faint);min-height:400px;display:flex;align-items:center;justify-content:center}.collection-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;align-items:start;align-content:start;flex:1;overflow-y:auto;overflow-x:visible;padding-bottom:180px;padding-right:8px}.collection-grid-v2::-webkit-scrollbar{width:8px}.collection-grid-v2::-webkit-scrollbar-track{background:#2a2b304d;border-radius:4px}.collection-grid-v2::-webkit-scrollbar-thumb{background:var(--bg-active);border-radius:4px}.collection-grid-v2::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.collection-card-v2{position:relative;background:#1c1d21b3;border:2px solid var(--bg-active);border-radius:10px;overflow:visible;transition:all .2s ease}.collection-card-v2:hover{border-color:var(--rarity-color, var(--bg-active))}.collection-card-v2.expanded{border-color:var(--rarity-color, var(--accent-primary));background:#1c1d21f2}.collection-card-v2.on-expedition{border-color:var(--warning)!important;box-shadow:0 0 12px #f59e0b4d}.collection-card-v2.on-expedition:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 6px,rgba(245,158,11,.05) 6px,rgba(245,158,11,.05) 12px);pointer-events:none;border-radius:8px;z-index:1}.expedition-badge{position:absolute;top:2px;left:2px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--warning);font-size:.85rem;z-index:10;pointer-events:none;animation:expeditionBadgeFloat 3s ease-in-out infinite;background:var(--bg-panel);border-radius:3px;border:1px solid rgba(255,255,255,.3);box-shadow:0 1px 4px #0006}@keyframes expeditionBadgeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.collection-card-compact{display:flex;align-items:center;gap:10px;padding:10px 80px 10px 12px;cursor:pointer;transition:background .15s ease;border-radius:8px;background:#1c1d21b3;position:relative}.collection-card-compact:hover{background:#2a2b3080}.card-deck-badges{position:absolute;right:27px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:flex-start}.deck-badge{background:linear-gradient(135deg,var(--info),#2563eb);color:#fff;font-size:.6rem;font-weight:600;padding:2px 4px;border-radius:3px;box-shadow:0 2px 4px #0006;text-transform:uppercase;letter-spacing:.3px;border:1px solid rgba(255,255,255,.15);transition:all .15s ease;cursor:default;position:relative;margin-top:-6px;width:58px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deck-badge:first-child{margin-top:0}.deck-badge:nth-child(1){z-index:4}.deck-badge:nth-child(2){z-index:3}.deck-badge:nth-child(3){z-index:2}.deck-badge:nth-child(4){z-index:1}.deck-badge:hover{transform:translateY(-2px) scale(1.08);box-shadow:0 4px 12px #3b82f699;z-index:10!important}.card-deck-badges:hover .deck-badge{margin-top:2px}.card-deck-badges:hover .deck-badge:first-child{margin-top:0}.collection-card-v2.expanded .collection-card-compact{border-radius:8px 8px 0 0;background:#1c1d21f2}.card-portrait{width:40px;height:40px;border-radius:6px;border:2px solid currentColor;overflow:hidden;flex-shrink:0;background:#2a2b3080}.card-portrait img{width:100%;height:100%;object-fit:cover}.card-portrait .portrait-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-faint);font-size:1rem}.card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.card-name{font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:151px}.card-meta{display:flex;align-items:center;gap:6px}.card-icon{width:16px;height:16px;object-fit:contain}.card-line-badge{font-size:.7rem;font-weight:600;padding:2px 6px;background:#10b98133;color:var(--success);border-radius:4px;margin-left:4px}.card-expand-icon{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:var(--text-faint);font-size:.7rem;padding:4px}.collection-card-expanded{position:absolute;top:100%;left:-2px;right:-2px;padding:12px;border:2px solid var(--rarity-color, var(--accent-primary));border-top:1px solid var(--bg-hover);border-radius:0 0 10px 10px;background:#0f1012fa;display:flex;flex-direction:column;gap:10px;box-shadow:0 8px 24px #00000080;z-index:51}.edit-row,.edit-name-row{display:flex;gap:8px}.edit-name{flex:1;padding:8px 10px;background:var(--bg-elevated);border:1px solid var(--bg-active);border-radius:5px;color:var(--text-primary);font-size:.9rem;min-width:0}.edit-name:focus{outline:none;border-color:var(--accent-primary)}.edit-monster-dropdown{flex-shrink:0}.edit-monster-dropdown .edit-dropdown-trigger{padding:8px 10px;gap:6px}.edit-dropdown-menu.edit-monster-menu{max-height:500px!important;overflow:hidden;display:flex;flex-direction:column}.monster-search-input{width:100%;padding:8px 10px;background:var(--bg-deepest);border:none;border-bottom:1px solid var(--bg-hover);color:var(--text-primary);font-size:.85rem}.monster-search-input:focus{outline:none;background:var(--bg-elevated)}.monster-search-results{flex:1;overflow-y:auto;max-height:430px;padding-bottom:8px}.monster-region-group{margin-bottom:4px}.monster-region-header{position:sticky;top:0;background:linear-gradient(135deg,var(--bg-hover),var(--bg-elevated));color:var(--text-muted);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:6px 10px;border-bottom:1px solid var(--bg-active);z-index:1}.monster-search-option{display:flex;align-items:center;gap:10px;padding:8px 10px;cursor:pointer;transition:background .15s ease}.monster-search-option:hover{background:#8b5cf633}.monster-search-img{width:32px;height:32px;border-radius:4px;object-fit:cover;background:var(--bg-hover)}.monster-search-info{display:flex;flex-direction:column;gap:2px;min-width:0}.monster-search-name{font-size:.8rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monster-search-meta{display:flex;gap:4px}.monster-search-meta img{width:14px;height:14px}.edit-selects{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;min-width:0}.edit-selects .edit-dropdown-wrapper{min-width:0}.edit-select{padding:6px 8px;background:var(--bg-elevated);border:1px solid var(--bg-active);border-radius:5px;color:var(--text-primary);font-size:.8rem;cursor:pointer}.edit-select:focus{outline:none;border-color:var(--accent-primary)}.edit-select.rarity{border-width:2px}.edit-dropdown-wrapper{position:relative}.edit-dropdown-trigger{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-deepest) 100%);border:1px solid var(--bg-hover);border-radius:6px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .2s ease;min-width:0;overflow:hidden}.edit-dropdown-trigger>span:not(.edit-dropdown-arrow){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.edit-dropdown-trigger:hover:not(.locked){border-color:var(--accent-primary);background:linear-gradient(135deg,#283548 0%,var(--bg-elevated) 100%)}.edit-dropdown-trigger.locked{cursor:not-allowed;opacity:.7;background:var(--bg-panel);border-color:var(--border-subtle)}.edit-dropdown-trigger.locked:hover{border-color:var(--border-subtle);background:var(--bg-panel)}.edit-dropdown-lock{font-size:.65rem;opacity:.5;margin-left:auto}.edit-dropdown-trigger:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #8b5cf633}.edit-dropdown-trigger.rarity{border-width:2px}.edit-dropdown-icon{width:16px;height:16px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));flex-shrink:0}.edit-dropdown-placeholder{color:var(--text-faint);font-style:italic}.edit-dropdown-arrow{margin-left:auto;font-size:.55rem;color:var(--text-faint);transition:transform .2s ease;flex-shrink:0}.edit-dropdown-wrapper:has(.edit-dropdown-menu) .edit-dropdown-arrow{transform:rotate(180deg)}.edit-dropdown-menu{position:fixed;min-width:140px;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-deepest) 100%);border:1px solid var(--bg-active);border-radius:8px;box-shadow:0 12px 32px #0009;z-index:9999;max-height:220px;overflow-y:auto;overflow-x:hidden}.edit-dropdown-menu::-webkit-scrollbar{width:6px}.edit-dropdown-menu::-webkit-scrollbar-track{background:transparent}.edit-dropdown-menu::-webkit-scrollbar-thumb{background:var(--bg-active);border-radius:3px}.edit-dropdown-option{display:flex;align-items:center;gap:10px;padding:10px 12px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;border-left:3px solid transparent}.edit-dropdown-option:hover{background:#8b5cf626;border-left-color:var(--accent-primary)}.edit-dropdown-option.selected{background:#8b5cf640;border-left-color:var(--accent-secondary);color:var(--text-primary)}.edit-dropdown-option img{width:22px;height:22px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.edit-dropdown-option:first-child{border-radius:7px 7px 0 0}.edit-dropdown-option:last-child{border-radius:0 0 7px 7px}.edit-line{flex-direction:column}.edit-line-display{display:flex;align-items:center;gap:6px;padding:8px 10px;background:#2a2b3066;border-radius:5px;font-size:.8rem}.edit-line-condition{color:var(--accent-primary);font-weight:500}.edit-line-arrow{color:var(--text-faint);font-size:.7rem}.edit-line-effect{color:var(--success);font-weight:500}.edit-line-clear{margin-left:auto;background:none;border:none;color:var(--danger);cursor:pointer;padding:2px;opacity:.7;transition:opacity .2s}.edit-line-clear:hover{opacity:1}.edit-add-line-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;background:#8b5cf626;border:1px dashed var(--accent-primary);border-radius:5px;color:var(--accent-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease}.edit-add-line-btn:hover{background:#8b5cf640}.edit-actions{display:flex;justify-content:flex-end;padding-top:6px;border-top:1px solid var(--bg-hover)}.edit-expedition-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;margin-right:8px;background:#f59e0b26;border:1px solid var(--warning);border-radius:5px;color:var(--warning);font-size:.75rem;cursor:pointer;transition:all .2s ease}.edit-expedition-btn:hover{background:#f59e0b40}.edit-expedition-btn.confirming{background:var(--warning);color:#fff;animation:expeditionConfirmPulse .5s ease-in-out infinite alternate}@keyframes expeditionReturnPulse{0%{box-shadow:0 0 4px #f59e0b80}to{box-shadow:0 0 10px #f59e0bcc}}.edit-delete-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#ef444426;border:1px solid var(--danger);border-radius:5px;color:var(--danger);font-size:.75rem;cursor:pointer;transition:all .2s ease}.edit-delete-btn:hover{background:#ef444440}.slot-no-familiars-hint{font-size:.85rem;color:var(--text-faint);margin:8px 0;padding:12px;background:#2a2b3066;border-radius:6px;text-align:center}.slot-familiar-preview{display:flex;gap:12px;margin-top:12px;padding:12px;background:#2a2b3066;border-radius:8px}.slot-preview-portrait{width:64px;height:64px;border-radius:8px;border:2px solid currentColor;overflow:hidden;flex-shrink:0}.slot-preview-portrait img{width:100%;height:100%;object-fit:cover}.slot-preview-info{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.slot-preview-meta{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-muted);flex-wrap:wrap}.slot-preview-icon{width:16px;height:16px;object-fit:contain}.slot-preview-line{display:flex;align-items:center;gap:6px;font-size:.8rem;flex-wrap:wrap;background:#0f101280;padding:8px;border-radius:6px}.slot-line-condition{color:var(--accent-primary);font-weight:500}.slot-line-arrow{color:var(--text-faint);font-size:.7rem}.slot-line-effect{color:var(--success)}.slot-line-bonuses{display:flex;gap:4px;margin-left:auto}.slot-clear-btn{display:flex;align-items:center;gap:6px;margin-top:12px;padding:8px 12px;background:#ef444426;border:1px solid var(--danger);border-radius:6px;color:var(--danger);font-size:.85rem;cursor:pointer;transition:all .2s ease}.slot-clear-btn:hover{background:#ef444440}.toast-notification{position:fixed;bottom:24px;right:24px;min-width:320px;max-width:420px;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border-radius:12px;box-shadow:0 8px 32px #00000080,0 0 0 1px #ffffff1a;z-index:10000;overflow:hidden;animation:toastSlideIn .3s ease-out}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-notification.error{border-left:4px solid var(--danger)}.toast-notification.warning{border-left:4px solid var(--warning)}.toast-notification.success{border-left:4px solid var(--success)}.toast-content{padding:16px}.toast-header{display:flex;align-items:center;gap:10px}.toast-icon{font-size:1.2rem}.toast-notification.error .toast-icon{color:var(--danger)}.toast-notification.warning .toast-icon{color:var(--warning)}.toast-notification.success .toast-icon{color:var(--success)}.toast-message{flex:1;font-weight:600;color:var(--text-primary);font-size:.95rem}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.toast-close:hover{background:#ffffff1a;color:var(--text-primary)}.toast-details{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle);color:var(--text-secondary);font-size:.85rem}.toast-details span{display:block;margin-bottom:8px;color:var(--text-muted)}.toast-details ul{margin:0;padding:0;list-style:none}.toast-details li{padding:4px 0 4px 16px;position:relative;color:var(--text-primary)}.toast-details li:before{content:"•";position:absolute;left:0;color:var(--danger)}.toast-progress{height:3px;background:var(--danger);animation:toastProgress 5s linear forwards}.toast-notification.warning .toast-progress{background:var(--warning)}.toast-notification.success .toast-progress{background:var(--success)}@keyframes toastProgress{0%{width:100%}to{width:0%}}.leaderboard-page{width:100%;min-height:calc(100vh - 70px);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:40px 24px;display:flex;justify-content:center}.leaderboard-container{width:100%;max-width:1200px;display:flex;flex-direction:column;gap:24px}.leaderboard-header{text-align:center;margin-bottom:8px}.leaderboard-title{font-size:2.5rem;font-weight:700;margin:0 0 12px;display:flex;align-items:center;justify-content:center;gap:16px;background:linear-gradient(135deg,#fff,#6322ca,#a5b4fc,#c4b5fd,#6322ca,#fff);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:titleShimmer 6s ease-in-out infinite}.title-icon{color:gold;filter:drop-shadow(0 4px 8px rgba(255,215,0,.3))}@keyframes titleShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.leaderboard-subtitle{font-size:.95rem;color:#9ca3af;margin:0}.period-tabs{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;padding:8px 0}.period-tab{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;color:#d1d5db;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.period-tab:hover{background:#8b5cf61a;border-color:#8b5cf64d;transform:translateY(-2px)}.period-tab.active{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-color:#8b5cf6;color:#fff;box-shadow:0 8px 20px #8b5cf64d}.period-tab svg{font-size:1.1rem}.leaderboard-filters{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;padding:16px;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-size:.9rem;font-weight:500;color:#9ca3af;white-space:nowrap}.filter-select{padding:10px 16px;font-size:.9rem;font-weight:500;color:#e5e7eb;background-color:#1f2937;border:1px solid #374151;border-radius:8px;cursor:pointer;transition:all .2s ease;min-width:150px}.filter-select:hover{border-color:#8b5cf6;background-color:#252f3f}.filter-select:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.loading-state,.error-state,.empty-state{text-align:center;padding:60px 20px;color:#9ca3af}.spinner{width:48px;height:48px;margin:0 auto 16px;border:4px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}.error-state{color:#ef4444;background-color:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:12px}.mock-data-notice{margin-top:12px;font-size:.875rem;color:#fbbf24;font-weight:500}.empty-state{background-color:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.leaderboard-table-wrapper{background-color:#ffffff05;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.05)}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-table thead{background-color:#8b5cf61a;border-bottom:2px solid rgba(139,92,246,.2)}.leaderboard-table th{padding:16px 20px;text-align:left;font-size:.875rem;font-weight:600;color:#c4b5fd;text-transform:uppercase;letter-spacing:.05em}.leaderboard-table tbody tr{border-bottom:1px solid rgba(255,255,255,.05);transition:all .3s ease;position:relative}.leaderboard-table tbody tr:nth-child(1){background:linear-gradient(90deg,rgba(255,215,0,.08),transparent);border-left:3px solid #ffd700}.leaderboard-table tbody tr:nth-child(2){background:linear-gradient(90deg,rgba(192,192,192,.08),transparent);border-left:3px solid #c0c0c0}.leaderboard-table tbody tr:nth-child(3){background:linear-gradient(90deg,rgba(205,127,50,.08),transparent);border-left:3px solid #cd7f32}.leaderboard-table tbody tr:last-child{border-bottom:none}.leaderboard-table tbody tr:hover{background:linear-gradient(90deg,#8b5cf61f,#8b5cf60d);transform:translate(4px);box-shadow:0 4px 16px #8b5cf626}.leaderboard-table td{padding:16px 20px;font-size:.95rem;color:#e5e7eb;vertical-align:middle;height:100%}.leaderboard-table td.exp-gain-col{vertical-align:middle;text-align:center}.rank-col{width:100px}.avatar-col{width:122px;padding-left:8px!important;padding-right:8px!important}.name-col{width:auto;min-width:200px}.level-col{width:100px}.class-col{width:180px}.exp-col,.exp-gain-col{width:140px;text-align:center}.character-avatar{width:112px;height:112px;margin:8px 0;border-radius:12px;overflow:hidden;border:3px solid rgba(209,213,219,.4);background:linear-gradient(135deg,#d1d5db1f,#9ca3af2e);display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #0000004d,0 0 20px #8b5cf61a;position:relative}.character-avatar:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .3s ease}.leaderboard-row:hover .character-avatar{border-color:#8b5cf699;box-shadow:0 6px 20px #8b5cf666,0 0 30px #8b5cf633;transform:scale(1.08) translateY(-2px)}.leaderboard-row:hover .character-avatar:before{opacity:1}.leaderboard-table tbody tr:nth-child(1) .character-avatar{border-color:#ffd70099;box-shadow:0 4px 16px #ffd70066,0 0 24px #ffd70033}.leaderboard-table tbody tr:nth-child(2) .character-avatar{border-color:#c0c0c099;box-shadow:0 4px 16px #c0c0c066,0 0 24px #c0c0c033}.leaderboard-table tbody tr:nth-child(3) .character-avatar{border-color:#cd7f3299;box-shadow:0 4px 16px #cd7f3266,0 0 24px #cd7f3233}.character-avatar img{width:115%;height:115%;object-fit:cover;filter:contrast(1.2) brightness(1.08) saturate(1.2);image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.rank-badge{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:6px 14px;border-radius:8px;font-weight:700;font-size:.9rem;background-color:#ffffff0d;color:#9ca3af;border:1px solid rgba(255,255,255,.1)}.rank-badge.rank-1{background:linear-gradient(135deg,gold,#ffed4e);color:#1f2937;border-color:gold;box-shadow:0 4px 16px #ffd70080,0 0 24px #ffd7004d;animation:pulseGold 2s ease-in-out infinite}@keyframes pulseGold{0%,to{box-shadow:0 4px 16px #ffd70080,0 0 24px #ffd7004d}50%{box-shadow:0 6px 20px #ffd700b3,0 0 32px #ffd70080}}.rank-badge.rank-2{background:linear-gradient(135deg,silver,#e8e8e8);color:#1f2937;border-color:silver;box-shadow:0 4px 16px #c0c0c080,0 0 20px #c0c0c04d}.rank-badge.rank-3{background:linear-gradient(135deg,#cd7f32,#e5a467);color:#1f2937;border-color:#cd7f32;box-shadow:0 4px 16px #cd7f3280,0 0 20px #cd7f324d}.rank-badge svg{font-size:1rem}.character-link{color:#a5b4fc;text-decoration:none;font-weight:600;transition:all .2s ease}.character-link:hover{color:#8b5cf6;text-decoration:underline}.level-badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background:linear-gradient(135deg,#8b5cf640,#7c3aed59);border:1px solid rgba(139,92,246,.5);border-radius:8px;color:#e9d5ff;font-weight:700;font-size:.9rem;box-shadow:0 2px 8px #8b5cf64d;text-shadow:0 1px 2px rgba(0,0,0,.5);transition:all .2s ease}.leaderboard-row:hover .level-badge{box-shadow:0 4px 12px #8b5cf666;transform:scale(1.05)}.exp-gain-value{display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;padding:10px 20px;background:linear-gradient(135deg,#10b98133,#34d39926);border:2px solid rgba(16,185,129,.4);border-radius:8px;color:#10b981;text-shadow:0 0 12px rgba(16,185,129,.6),0 2px 4px rgba(0,0,0,.5);box-shadow:0 2px 8px #10b9814d,0 0 20px #10b98126;transition:all .3s ease}.leaderboard-row:hover .exp-gain-value{background:linear-gradient(135deg,#10b9814d,#34d39940);border-color:#10b98199;color:#34d399;transform:scale(1.08)}.class-col{font-weight:600;color:#d1d5db;text-shadow:0 1px 2px rgba(0,0,0,.3)}.pagination{display:flex;align-items:center;justify-content:center;gap:20px;padding:24px 0}.page-nav-btn{display:flex;align-items:center;gap:10px;padding:12px 24px;font-size:.95rem;font-weight:600;color:#e5e7eb;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.page-nav-btn:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-color:#8b5cf6;color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf64d}.page-nav-btn:disabled{opacity:.3;cursor:not-allowed}.page-info{font-size:.95rem;color:#e5e7eb;font-weight:600;padding:0 16px}@media(max-width:768px){.leaderboard-title{font-size:2rem}.leaderboard-subtitle{font-size:.85rem}.period-tabs{gap:8px}.period-tab{padding:10px 16px;font-size:.85rem}.period-tab span{display:none}.period-tab svg{font-size:1.2rem}.leaderboard-filters{flex-direction:column;gap:12px}.filter-group{width:100%;justify-content:space-between}.filter-select{flex:1;min-width:0}.leaderboard-table-wrapper{overflow-x:auto}.leaderboard-table{min-width:760px}.leaderboard-table th,.leaderboard-table td{padding:12px;font-size:.875rem}.avatar-col{width:88px}.character-avatar{width:80px;height:80px}.class-col{display:none}.pagination{flex-wrap:wrap;gap:12px}.page-nav-btn{padding:10px 18px;font-size:.85rem}}@media(max-width:480px){.leaderboard-page{padding:24px 16px}.leaderboard-title{font-size:1.75rem;flex-direction:column;gap:8px}.period-tab{padding:8px 12px}.level-badge{padding:4px 8px;font-size:.8rem}.rank-badge{padding:4px 10px;font-size:.85rem;gap:6px}.avatar-col{width:68px}.character-avatar{width:60px;height:60px}.exp-gain-col{font-size:.9rem}}.my-characters-page{min-height:calc(100vh - 70px);padding:40px 20px;max-width:1400px;margin:0 auto}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px}.spinner{width:48px;height:48px;border:4px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{color:#a0a0b0;font-size:16px}.auth-required{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:20px}.auth-icon{font-size:80px;color:#8b5cf666}.auth-required h2{font-size:28px;font-weight:700;color:#e8e8f0;margin:0}.auth-required p{font-size:16px;color:#a0a0b0;max-width:400px}.login-btn{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;border:none;padding:14px 32px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #8b5cf64d}.login-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf680}.page-header{margin-bottom:40px;padding-bottom:30px;border-bottom:2px solid rgba(139,92,246,.2)}.header-content{display:flex;align-items:center;gap:20px}.page-icon{font-size:48px;color:#8b5cf6;flex-shrink:0}.header-text h1{font-size:36px;font-weight:800;color:#e8e8f0;margin:0 0 8px;letter-spacing:-.02em}.header-text p{font-size:16px;color:#a0a0b0;margin:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;gap:24px}.empty-icon{font-size:80px;color:#8b5cf64d}.empty-state h2{font-size:24px;font-weight:700;color:#e8e8f0;margin:0}.empty-state p{font-size:16px;color:#a0a0b0;max-width:400px;line-height:1.6}.search-link{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;padding:12px 28px;border-radius:10px;text-decoration:none;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #8b5cf64d}.search-link:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf680}.characters-list{display:flex;flex-direction:column;gap:16px;max-width:1200px;margin:0 auto}.character-row{background:linear-gradient(135deg,#1e192de6,#140f23f2);border:2px solid rgba(100,100,120,.3);border-radius:16px;padding:20px;display:flex;align-items:center;gap:24px;text-decoration:none;position:relative;transition:all .3s ease;overflow:hidden}.character-row:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#8b5cf6,#6d28d9);opacity:0;transition:opacity .3s ease}.character-row:hover{transform:translate(4px);border-color:#8b5cf699;box-shadow:0 8px 24px #8b5cf640}.character-row:hover:before{opacity:1}.row-left{display:flex;align-items:center;gap:16px;min-width:280px;flex-shrink:0}.row-image{width:80px;height:80px;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#8b5cf626,#6d28d926);border:2px solid rgba(139,92,246,.3);flex-shrink:0;position:relative}.row-image:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(139,92,246,.1) 100%);pointer-events:none}.row-image img{width:100%;height:100%;object-fit:cover;image-rendering:crisp-edges;filter:contrast(1.1) brightness(1.05) saturate(1.1);transition:transform .3s ease}.character-row:hover .row-image img{transform:scale(1.1)}.row-main-info{display:flex;flex-direction:column;gap:4px;min-width:150px}.row-name{font-size:22px;font-weight:800;color:#e8e8f0;margin:0;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.3)}.row-class{font-size:14px;color:#8b5cf6;font-weight:600;margin:0;text-transform:uppercase;letter-spacing:.5px}.row-stats{display:flex;gap:12px;flex-shrink:0}.stat-pill{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:10px;min-width:70px;transition:all .2s ease}.character-row:hover .stat-pill{background:#8b5cf626;border-color:#8b5cf680}.stat-pill .stat-label{font-size:10px;color:#808090;text-transform:uppercase;letter-spacing:.5px;font-weight:700}.stat-pill .stat-value{font-size:18px;color:#e8e8f0;font-weight:800;line-height:1}.row-progress{display:flex;flex-direction:column;gap:6px;flex:1;min-width:200px}.progress-info{display:flex;justify-content:space-between;align-items:center;gap:12px}.progress-label{font-size:11px;color:#808090;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.progress-percent{font-size:14px;color:#e8e8f0;font-weight:700}.progress-bar{height:10px;background:#64647833;border-radius:6px;overflow:hidden;border:1px solid rgba(100,100,120,.3)}.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa,#8b5cf6);background-size:200% 100%;border-radius:6px;transition:width .5s ease;box-shadow:0 0 10px #8b5cf680;animation:shimmerProgress 2s ease-in-out infinite}@keyframes shimmerProgress{0%,to{background-position:200% 0}50%{background-position:-200% 0}}.row-daily{display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding:8px 16px;background:linear-gradient(135deg,#22c55e1a,#16a34a26);border:2px solid rgba(34,197,94,.4);border-radius:12px;min-width:140px;flex-shrink:0;transition:all .2s ease}.character-row:hover .row-daily{background:linear-gradient(135deg,#22c55e26,#16a34a33);border-color:#22c55e99;box-shadow:0 4px 12px #22c55e33}.daily-label{font-size:10px;color:#86efaccc;text-transform:uppercase;letter-spacing:.5px;font-weight:700}.daily-value{font-size:20px;color:#86efac;font-weight:900;line-height:1;text-shadow:0 2px 8px rgba(34,197,94,.4)}.daily-percent{font-size:12px;color:#86efacb3;font-weight:600}@media(max-width:1024px){.character-row{flex-wrap:wrap;gap:16px}.row-left{min-width:240px}.row-stats{flex-wrap:wrap}.row-progress{flex-basis:100%}.row-daily{margin-left:auto}}@media(max-width:768px){.character-row{padding:16px;gap:12px}.row-left{min-width:auto;flex-basis:100%}.row-image{width:64px;height:64px}.row-name{font-size:18px}.row-stats{flex-basis:100%;justify-content:space-between}.stat-pill{flex:1;min-width:60px}.row-progress{flex-basis:100%;order:5}.row-daily{flex-basis:100%;order:4;align-items:center;flex-direction:row;justify-content:space-between;min-width:auto}.daily-value{font-size:18px}}@media(max-width:480px){.row-stats{flex-direction:column;gap:8px}.stat-pill{flex-direction:row;justify-content:space-between;width:100%}}@media(max-width:768px){.my-characters-page{padding:30px 15px}.page-header{margin-bottom:30px;padding-bottom:20px}.header-content{gap:15px}.page-icon{font-size:36px}.header-text h1{font-size:28px}.header-text p{font-size:14px}}.hexa-tracker{background:transparent;border-radius:0;padding:20px 60px 40px;color:#fff;width:100%;max-width:100%;box-sizing:border-box}.hexa-page-title-section{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:46px;margin-top:-10px}@keyframes hexaFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.hexa-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;padding:24px 32px;background:linear-gradient(135deg,#2b14504d,#1c1d21f2,#2b14504d,#1c1d21f2 60%,#2b14504d,#1c1d21f2 80%,#2b14504d);border:2px solid rgba(80,81,88,.6);border-radius:14px;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614;gap:24px}.hexa-header-left{display:flex!important;flex-direction:row!important;align-items:center!important;gap:20px!important;flex-wrap:nowrap!important}.hexa-header-left>*{flex-shrink:0}.hexa-divider{width:2px;height:40px;background:linear-gradient(180deg,transparent 0%,rgba(139,92,246,.5) 50%,transparent 100%)}.hexa-header-center{display:flex;align-items:center;gap:12px;flex-wrap:nowrap}.hexa-char-name{margin:0!important;font-size:24px;font-weight:700;color:#f4f4f5;white-space:nowrap;display:inline!important}.hexa-char-class{font-size:14px;color:#a1a1aa;font-weight:500;padding:4px 12px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:6px;display:inline-block!important}.hexa-header-right{display:flex;align-items:center;gap:12px}.hexa-tabs{display:flex;gap:8px;margin-bottom:32px;padding:6px;background:#0000004d;border:1px solid rgba(80,81,88,.4);border-radius:12px;width:fit-content;margin-left:auto;margin-right:auto}.hexa-tab{padding:10px 24px;background:transparent;border:none;border-radius:8px;color:#a1a1aa;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.hexa-tab:hover:not(.disabled){color:#d4d4d8;background:#ffffff0d}.hexa-tab.active{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.hexa-tab.disabled{color:#52525b;cursor:not-allowed;text-decoration:line-through;opacity:.5}.hexa-summary-view{width:100%;max-width:100%;display:flex;flex-direction:column;gap:32px;margin-bottom:32px;padding:0 60px;box-sizing:border-box}.summary-group{width:100%}.summary-group-title{font-size:20px;font-weight:700;margin:0 0 20px;padding-left:16px;position:relative;display:flex;align-items:center;gap:12px}.summary-group-title:before{content:"";width:4px;height:24px;background:currentColor;border-radius:2px;position:absolute;left:0}.summary-skills{display:grid;grid-template-columns:repeat(auto-fill,minmax(450px,1fr));gap:20px}.summary-skill-card{background:linear-gradient(135deg,#1c1d21cc,#141519f2);border:2px solid;border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 20px #0000004d;transition:all .3s ease}.summary-skill-card:hover{transform:translateY(-2px);box-shadow:0 6px 30px #00000080}.summary-skill-header{display:flex;justify-content:space-between;align-items:center}.summary-skill-info{display:flex;align-items:center;gap:12px}.summary-skill-icon{width:48px;height:48px;object-fit:contain;image-rendering:pixelated;filter:contrast(1.05) brightness(1.05) saturate(1);border-radius:8px}.summary-skill-names{display:flex;flex-direction:column;gap:4px}.summary-skill-name{font-size:14px;font-weight:600;line-height:1.2}.summary-skill-level{display:flex;align-items:baseline;gap:4px;padding:8px 16px;background:#0006;border-radius:8px}.summary-level-text{font-size:20px;font-weight:700;color:#fff}.summary-level-max{font-size:14px;font-weight:600;color:#71717a}.summary-progress-bar{position:relative;width:100%;height:24px;background:#0006;border-radius:12px;overflow:hidden;border:1px solid rgba(80,81,88,.4)}.summary-progress-fill{height:100%;transition:width .3s ease;border-radius:12px}.summary-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);z-index:1}.summary-resources{display:grid;grid-template-columns:1fr 1fr;gap:12px}.summary-resource-section{display:flex;flex-direction:column;gap:10px;padding:14px;background:#0000004d;border-radius:10px;border:1px solid rgba(80,81,88,.3)}.summary-resource-section.spent{border-color:#22c55e4d;background:#22c55e0d}.summary-resource-section.remaining{border-color:#ef44444d;background:#ef44440d}.summary-resource-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#a1a1aa}.summary-resource-values{display:flex;gap:16px}.summary-resource-item{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:700;color:#fff}.summary-resource-icon{width:20px;height:20px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}@media(max-width:1200px){.summary-skills{grid-template-columns:1fr}}.hexa-back-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(135deg,#28233c99,#191626b3);border:1px solid rgba(139,92,246,.2);border-radius:6px;color:#e4e4e7;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.hexa-totals{display:flex;gap:24px}.total-item-used{display:flex;flex-direction:column;align-items:flex-end;background:#1c211d99;padding:16px 20px;border-radius:10px;border:2px solid rgba(22,206,53,.4);min-width:160px}.total-item-remaining{display:flex;flex-direction:column;align-items:flex-end;background:#1c211d99;padding:16px 20px;border-radius:10px;border:2px solid rgb(192,17,17);min-width:160px}.total-label{font-size:12px;color:#a1a1aa;margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.total-value{font-size:16px;font-weight:700;margin-left:8px;display:inline-flex;align-items:center;gap:6px;color:#f4f4f5}.total-icon{width:18px;height:18px;object-fit:contain;vertical-align:middle}.hexa-skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.skill-group{background:linear-gradient(180deg,#1c1d21 20%,#0f1012 80%);border:2px solid rgba(80,81,88,.5);border-radius:14px;padding:24px;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614}.group-title{margin:0 0 20px;font-size:18px;font-weight:600;color:#f4f4f5;display:flex;align-items:center;gap:9px;filter:drop-shadow(0 2px 8px rgba(139,92,246,.3))}.group-title:before{content:"";width:4px;height:18px;background:linear-gradient(180deg,#8b5cf6,#6366f1);border-radius:2px}.skills-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.hexa-skill-slot{background:#1c1d2199;border:2px solid rgba(80,81,88,.4);border-radius:10px;padding:16px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:12px;position:relative;overflow:hidden;min-height:320px;width:100%;box-sizing:border-box}.hexa-skill-slot:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(139,92,246,.1) 50%,transparent 100%);transition:left .5s ease}.hexa-skill-slot:hover:before{left:100%}.hexa-skill-slot:after{content:"";position:absolute;bottom:0;left:16px;right:16px;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(139,92,246,.2) 50%,transparent 100%)}.hexa-skill-slot:hover{border-color:#8b5cf699;background:#232428cc;transform:translateY(-2px) scale(1.01);box-shadow:0 8px 24px #8b5cf626,0 0 40px #8b5cf61a,inset 0 1px #ffffff0d}.hexa-skill-slot.selected{border-color:#8b5cf6cc;background:#8b5cf614;box-shadow:0 0 20px #8b5cf640}.skill-icon-wrapper{position:relative;width:64px;height:64px;flex-shrink:0;transition:transform .2s ease;display:flex;align-items:center;justify-content:center}.hexa-skill-slot:hover .skill-icon-wrapper{transform:scale(1.05)}.skill-icon-img{width:100%;height:100%;object-fit:contain;border-radius:10px;background:#0000004d;padding:2px;border:2px solid rgba(80,81,88,.4);transition:border-color .2s ease;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:pixelated;filter:contrast(1.05) brightness(1.05) saturate(1)}.hexa-skill-slot:hover .skill-icon-img{border-color:#8b5cf680;filter:contrast(1.15) brightness(1.1) saturate(1.15)}.skill-icon-fallback{width:64px;height:64px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;text-transform:uppercase;border:2px solid rgba(80,81,88,.4);background:#0000004d;box-sizing:border-box}.skill-key{font-weight:700;color:#a1a1aa}.skill-info{flex:1;display:flex;flex-direction:column;gap:10px;min-width:0;width:100%;justify-content:flex-start}.skill-names{display:grid;grid-template-rows:auto;gap:3px;text-align:center;min-height:90px;justify-content:center;align-content:center;order:1;width:100%}.skill-name{font-size:11.5px;font-weight:600;color:#f4f4f5;line-height:1.3;word-break:break-word;width:100%;display:block}.skill-level{display:flex;align-items:center;justify-content:center;gap:6px;font-size:14px;padding:8px 0;border-top:1px solid rgba(80,81,88,.3);border-bottom:1px solid rgba(80,81,88,.3);order:2}.level-label{color:#a1a1aa;font-size:12px;font-weight:500}.level-input{width:36px;padding:4px;background:#1c1d21cc;border:1px solid rgba(80,81,88,.4);border-radius:6px;color:#f4f4f5;font-size:14px;font-weight:700;text-align:center;transition:all .2s ease}.level-input:focus{outline:none;border-color:#8b5cf699;background:#232428;box-shadow:0 0 0 2px #8b5cf61a}.max-level-input{width:36px;padding:4px;background:#1c1d21cc;border:1px solid rgba(139,92,246,.3);border-radius:6px;color:#d8b4fe;font-size:14px;font-weight:700;text-align:center;transition:all .2s ease}.max-level-input:hover{border-color:#8b5cf680;background:#232428e6}.max-level-input:focus{outline:none;border-color:#8b5cf6cc;background:#232428;box-shadow:0 0 0 2px #8b5cf626}.level-max{font-size:18px;font-weight:600;color:#a1a1aa;margin:0 2px}.next-level-cost{display:flex;gap:8px;font-size:12px;justify-content:center;flex-wrap:nowrap;min-height:24px;align-items:center;order:3;width:100%;box-sizing:border-box}.cost-maxed{font-size:14px;font-weight:700;color:#fff;letter-spacing:.5px;margin-top:1px;padding:4px 8px;background:linear-gradient(135deg,#22c55e,#2df175);border-radius:6px;border:1px solid rgba(34,197,94,.5);display:inline-flex;align-items:center;animation:breathe 6s ease-in-out infinite}@keyframes breathe{0%,to{opacity:.85;box-shadow:0 0 8px #22c55e4d}50%{opacity:1;box-shadow:0 0 16px #22c55e80}}.cost-fragments,.cost-sol-erda{background:#0006;padding:4px 8px;border-radius:6px;font-weight:600;display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(80,81,88,.3);color:#e4e4e7}.cost-icon{width:14px;height:14px;object-fit:contain;vertical-align:middle}.skill-progress-bar{position:relative;width:100%;height:20px;background:#0006;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.1);order:5;margin-top:auto}.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6dd,#8b5cf688);transition:width .3s ease;border-radius:10px}.progress-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);z-index:1}.skill-resources{display:flex;flex-direction:column;gap:4px;order:6;padding:6px 2px 4px;border-top:1px solid rgba(255,255,255,.05);width:100%;box-sizing:border-box;min-height:64px}.resource-row{display:flex;flex-direction:column;align-items:flex-start;gap:3px;font-size:10px;width:100%;min-height:28px}.resource-values-group{display:flex;align-items:center;gap:6px;flex-shrink:0;width:100%;justify-content:center;min-height:18px}.resource-row.spent .resource-label{color:#4ade80}.resource-row.remaining .resource-label{color:#f87171}.resource-label{font-weight:600;font-size:12px;flex-shrink:0;width:100%;text-align:center;min-height:16px}.resource-value{display:flex;align-items:center;gap:2px;color:#d1d5db;font-size:14px;white-space:nowrap;flex-shrink:1;min-width:0;font-variant-numeric:tabular-nums}.resource-icon-small{width:11px;height:11px;object-fit:contain;vertical-align:middle;flex-shrink:0}.skill-actions{display:flex;gap:6px;justify-content:center;order:7}.level-btn{width:30px;height:30px;background:linear-gradient(135deg,#2a2b30,#1c1d21);border:1px solid rgba(80,81,88,.4);border-radius:6px;color:#e4e4e7;font-size:16px;font-weight:700;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.level-btn:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf6,#6366f1);border-color:#8b5cf699;color:#fff;transform:scale(1.08)}.level-btn:disabled{opacity:.3;cursor:not-allowed}.hexa-quick-actions{display:flex;gap:12px;margin-top:24px;padding:0 4px}.action-btn{flex:1;padding:14px 24px;background:linear-gradient(180deg,#1c1d21 20%,#0f1012 80%);border:2px solid rgba(80,81,88,.5);border-radius:10px;color:#f4f4f5;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:1px 4px 16px #0000004d,inset 0 1px #ffffff0d}.action-btn:hover{background:linear-gradient(135deg,#8b5cf6,#6366f1);border-color:#8b5cf699;transform:translateY(-1px);box-shadow:0 6px 20px #8b5cf64d}.hexa-tracker-error{padding:40px;text-align:center;color:#a1a1aa;font-size:16px;background:#1c1d2199;border:2px solid rgba(80,81,88,.4);border-radius:14px;margin:20px 0}@media(max-width:1800px){.hexa-skills-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1200px){.hexa-tracker{padding:40px}.hexa-skills-grid{grid-template-columns:1fr}.skills-row{grid-template-columns:repeat(4,1fr)}}@media(max-width:900px){.skills-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.hexa-tracker{padding:20px}.hexa-header{flex-direction:column;align-items:flex-start;gap:16px;padding:20px}.hexa-totals{flex-direction:column;gap:12px;width:100%}.total-item{min-width:auto}.skills-row{grid-template-columns:1fr}.skill-icon-wrapper,.skill-icon-img,.skill-icon-fallback{width:56px;height:56px}}.overview-tabs{display:flex;gap:12px;padding:0 60px;margin-bottom:30px;justify-content:center}.overview-tab{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);color:#a1a1aa;font-size:16px;font-weight:600;padding:14px 32px;cursor:pointer;border-radius:12px;transition:all .3s ease;font-family:Inter,sans-serif}.overview-tab:hover{color:#f4f4f5;background:#8b5cf61a;border-color:#8b5cf64d;transform:translateY(-2px)}.overview-tab.active{color:#a855f7;background:#8b5cf626;border-color:#a855f7;box-shadow:0 4px 16px #a855f74d}.tracker-tabs{display:flex;gap:8px;padding:0 40px;margin-bottom:20px;border-bottom:2px solid rgba(255,255,255,.1)}.tracker-tab{background:transparent;border:none;color:#a1a1aa;font-size:16px;font-weight:600;padding:12px 24px;cursor:pointer;position:relative;transition:all .3s ease;font-family:Inter,sans-serif}.tracker-tab:hover{color:#f4f4f5;background:#8b5cf61a}.tracker-tab.active{color:#a855f7}.tracker-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:linear-gradient(90deg,#a855f7,#c084fc);box-shadow:0 0 10px #a855f780}.boss-tracker-back{padding:20px 40px;display:flex;justify-content:center}.boss-tracker-back .hexa-back-btn{background:#8b5cf626;border:1px solid rgba(139,92,246,.3);color:#a855f7;padding:12px 24px;font-size:15px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:Inter,sans-serif}.boss-tracker-back .hexa-back-btn:hover{background:#8b5cf640;border-color:#8b5cf680;transform:translateY(-1px)}.hexa-overview-page{min-height:100vh;padding:50px 60px 40px;font-family:Inter,-apple-system,system-ui,sans-serif;color:#f4f4f5;box-sizing:border-box;overflow-x:hidden}.hexa-page-title-section{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:46px;margin-top:10px}.hexa-page-title{display:inline-flex;align-items:center;justify-content:center;margin:0;font-size:2.2rem;font-weight:700;color:#f4f4f5;filter:drop-shadow(0 2px 8px rgba(139,92,246,.4))}.hexa-page-subtitle{margin:8px 0 0;font-size:16px;color:#a1a1aa;font-weight:400}.hexa-page-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:32px;max-width:none}.hexa-section-title{font-size:24px;font-weight:700;margin:0;color:#f4f4f5}.hexa-header-left{display:flex;flex-direction:column;gap:4px}.hexa-header-right{display:flex;gap:12px;align-items:center}.hexa-add-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #8b5cf640}.hexa-add-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666;background:linear-gradient(135deg,#9d7afa,#7577f5)}.hexa-characters-section{max-width:1400px;margin:0 auto}.hexa-section-header{display:flex;align-items:center;gap:12px;margin-bottom:32px}.hexa-section-title{font-size:24px;font-weight:700;margin:0;color:#f4f4f5;position:relative;padding-left:16px}.hexa-section-title:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:24px;background:linear-gradient(180deg,#8b5cf6,#6366f1);border-radius:2px}.hexa-characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px;max-width:1400px}.hexa-character-box{position:relative;transition:transform .3s cubic-bezier(.4,0,.2,1)}.hexa-character-box:hover{transform:translateY(-4px)}.hexa-sortable-item{touch-action:none}.hexa-drag-area{position:absolute;left:0;top:0;bottom:0;width:48px;cursor:grab;z-index:15;background-image:repeating-linear-gradient(to bottom,rgba(113,113,122,.15) 0px,rgba(113,113,122,.15) 4px,transparent 4px,transparent 8px);background-position:center center;background-size:12px 100%;background-repeat:repeat-y;border-radius:16px 0 0 16px;transition:all .2s ease}.hexa-drag-area:hover{background-color:#8b5cf614;background-image:repeating-linear-gradient(to bottom,rgba(139,92,246,.5) 0px,rgba(139,92,246,.5) 4px,transparent 4px,transparent 8px)}.hexa-drag-area:active{cursor:grabbing;background-color:#8b5cf626;background-image:repeating-linear-gradient(to bottom,rgba(139,92,246,.6) 0px,rgba(139,92,246,.6) 4px,transparent 4px,transparent 8px)}.hexa-sortable-item .hexa-char-card{padding-left:52px}.hexa-char-card{width:100%;min-height:180px;background:linear-gradient(135deg,#1c1d21cc,#141519f2);border:2px solid rgba(80,81,88,.5);border-radius:16px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;display:flex;flex-direction:row;align-items:stretch;padding:0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 24px #0006,inset 0 1px #ffffff0d}.hexa-char-card:hover{border-color:#8b5cf699;box-shadow:0 12px 40px #8b5cf64d,0 0 40px #8b5cf626,inset 0 1px #ffffff1a}.hexa-char-info{flex:1;padding:20px;display:flex;flex-direction:column;justify-content:center}.hexa-char-share{margin-top:12px;padding-top:12px;border-top:1px solid rgba(80,81,88,.35);display:flex;justify-content:space-between;align-items:center}.hexa-share-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#71717a}.hexa-share-value{font-size:16px;font-weight:700;color:#e8def1;text-shadow:0 0 10px rgba(139,92,246,.5)}.hexa-char-image{width:160px;min-width:160px;background:linear-gradient(135deg,#8b5cf614,#6366f10d);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border-left:2px solid rgba(139,92,246,.2)}.hexa-char-image img{width:100%;height:100%;object-fit:cover}.hexa-char-name-section{display:flex;flex-direction:column;gap:12px;margin-bottom:18px;align-items:center;text-align:center}.hexa-char-name{font-size:22px;font-weight:700;color:#fff;margin:0;line-height:1.2}.hexa-char-class{font-size:13px;color:#c4b5fd;font-weight:600;padding:5px 12px;background:linear-gradient(135deg,#8b5cf626,#6366f11a);border:1px solid rgba(139,92,246,.3);border-radius:8px;display:inline-block}.hexa-char-stats-grid{display:flex;flex-direction:column;gap:10px}.hexa-stat-section{display:flex;flex-direction:column;gap:10px;padding:14px;background:#0000004d;border:1px solid rgba(80,81,88,.35);border-radius:10px}.hexa-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#71717a;margin-bottom:2px}.hexa-stat-values{display:flex;gap:20px;align-items:center}.hexa-stat-item{display:flex;align-items:center;gap:8px;flex:1}.hexa-stat-icon{width:22px;height:22px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));flex-shrink:0}.hexa-stat-value{font-size:16px;font-weight:700;color:#fff;line-height:1}.hexa-char-remove{position:absolute;top:12px;right:12px;background:linear-gradient(135deg,#ef44441a,#dc26260d);border:1.5px solid rgba(239,68,68,.3);color:#ef4444;width:32px;height:32px;min-width:32px;min-height:32px;max-width:32px;max-height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff0d;font-size:20px;font-weight:300;line-height:1;font-family:Arial,sans-serif;padding:0}.hexa-char-remove svg{width:16px;height:16px}.hexa-char-remove:hover{background:linear-gradient(135deg,#ef444433,#dc262626);border-color:#ef444499;color:#fca5a5;transform:translateY(-2px);box-shadow:0 4px 16px #ef444466,inset 0 1px #ffffff1a}.hexa-char-remove:active{transform:translateY(0);box-shadow:0 2px 8px #ef444466,inset 0 1px #ffffff0d}.remove-icon{font-size:18px;font-weight:400;line-height:1;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.hexa-char-remove:hover .remove-icon{transform:scale(1.15)}.hexa-char-stats{display:flex;flex-direction:column;gap:8px}.hexa-stat-row{display:flex;align-items:center;gap:8px;font-size:14px}.hexa-stat-row img{width:18px;height:18px;object-fit:contain}.hexa-stat-row span{font-weight:600;color:#e4e4e7}.hexa-empty-state{grid-column:1 / -1;padding:60px 40px;text-align:center;background:linear-gradient(135deg,#28233c66,#19162680);border:2px solid rgba(139,92,246,.2);border-radius:20px;box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hexa-empty-icon{font-size:72px;margin-bottom:24px;opacity:.8;filter:drop-shadow(0 4px 12px rgba(139,92,246,.3));display:flex;justify-content:center;color:#8b5cf6}.hexa-empty-icon svg{width:72px;height:72px}.hexa-empty-title{font-size:28px;font-weight:800;margin:0 0 12px;background:linear-gradient(135deg,#fff,#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hexa-empty-description{font-size:16px;color:#a1a1aa;margin:0 0 40px;font-weight:500}.hexa-empty-features{display:flex;flex-direction:column;gap:20px;max-width:500px;margin:0 auto 32px;text-align:left}.hexa-empty-feature{display:flex;align-items:flex-start;gap:16px;padding:20px;background:#0003;border:1px solid rgba(80,81,88,.3);border-radius:12px;transition:all .3s ease}.hexa-empty-feature:hover{background:#8b5cf60d;border-color:#8b5cf64d;transform:translate(4px)}.hexa-empty-feature .feature-icon{font-size:28px;flex-shrink:0;line-height:1;display:flex;align-items:center;justify-content:center;color:#8b5cf6}.hexa-empty-feature .feature-icon svg{width:28px;height:28px}.hexa-empty-feature .feature-text{display:flex;flex-direction:column;gap:4px}.hexa-empty-feature .feature-text strong{font-size:15px;font-weight:700;color:#f4f4f5}.hexa-empty-feature .feature-text span{font-size:13px;color:#a1a1aa;font-weight:500}.hexa-empty-notice{max-width:500px;margin:0 auto 32px;padding:16px 20px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:12px;font-size:14px;color:#d8b4fe;line-height:1.6;display:flex;align-items:flex-start;gap:12px}.hexa-empty-notice .notice-icon{width:20px;height:20px;flex-shrink:0;color:#fbbf24;margin-top:2px}.hexa-empty-notice strong{font-weight:700;color:#e9d5ff}.hexa-empty-add-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #8b5cf666,inset 0 1px #fff3}.hexa-empty-add-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #8b5cf680,inset 0 1px #fff3}.hexa-empty-add-btn:active{transform:translateY(0)}.hexa-tracker-full{min-height:100vh;padding:80px 60px 40px;font-family:Inter,-apple-system,system-ui,sans-serif;color:#f4f4f5;box-sizing:border-box;overflow-x:hidden}.hexa-tracker-header{display:flex;align-items:center;gap:20px;margin-bottom:32px;width:100%}.hexa-back-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#28233c99,#191626b3);border:1px solid rgba(139,92,246,.2);border-radius:10px;color:#e4e4e7;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hexa-back-btn:hover{border-color:#8b5cf666;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;transform:translate(-2px)}.hexa-tracker-header h1{font-size:32px;font-weight:900;margin:0;color:#f4f4f5}.hexa-char-class{font-size:16px;color:#a1a1aa;padding:6px 14px;background:#1c1d21cc;border:1px solid rgba(255,255,255,.06);border-radius:8px}.hexa-tracker-content{width:100%;margin:-50px 0 0}.hexa-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hexa-modal{background:linear-gradient(135deg,#1c1d21fa,#2b145026,#1c1d21fa);border:2px solid rgba(80,81,88,.6);border-radius:24px;padding:40px;max-width:520px;width:90%;box-shadow:0 25px 80px #000c,0 0 60px #8b5cf61a,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:modalSlideUp .3s ease;position:relative}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hexa-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.hexa-modal h2{margin:0;font-size:32px;font-weight:800;background:linear-gradient(135deg,#fff,#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 8px rgba(139,92,246,.3))}.hexa-modal-close{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#a1a1aa;font-size:20px;cursor:pointer;transition:all .2s ease}.hexa-modal-close:hover{background:#ef444433;border-color:#ef444466;color:#f87171;transform:rotate(90deg)}.hexa-mode-selector{display:flex;gap:8px;margin-bottom:28px;background:#0000004d;padding:6px;border-radius:14px;border:1px solid rgba(80,81,88,.4);box-shadow:inset 0 2px 8px #0000004d}.hexa-mode-btn{flex:1;padding:14px;background:transparent;border:none;border-radius:10px;color:#71717a;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s ease;position:relative}.hexa-mode-btn:hover:not(.active){color:#a1a1aa;background:#ffffff0d}.hexa-mode-btn.active{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;box-shadow:0 4px 16px #8b5cf666,inset 0 1px #fff3;transform:translateY(-1px)}.hexa-modal-form{display:flex;flex-direction:column;gap:24px}.hexa-form-label{font-size:15px;font-weight:600;color:#d4d4d8;margin-bottom:12px;display:block}.hexa-modal-input,.hexa-modal-select{width:100%;padding:14px 45px 14px 18px;background:linear-gradient(135deg,#0006,#14141e66);border:2px solid rgba(139,92,246,.3);border-radius:12px;color:#f4f4f5;font-size:16px;font-weight:500;transition:all .3s ease;box-shadow:inset 0 2px 8px #0000004d,0 4px 12px #0003;box-sizing:border-box;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgb(139, 92, 246)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px}.hexa-modal-select:hover{border-color:#8b5cf680;box-shadow:inset 0 2px 8px #0000004d,0 4px 16px #8b5cf633,0 0 20px #8b5cf61a;transform:translateY(-1px)}.hexa-modal-input:focus,.hexa-modal-select:focus{outline:none;border-color:#8b5cf6b3;background:linear-gradient(135deg,#00000080,#14141e80);box-shadow:inset 0 2px 8px #0006,0 0 0 4px #8b5cf626,0 8px 24px #8b5cf64d;transform:translateY(-2px)}.hexa-modal-input::placeholder{color:#52525b}.hexa-modal-select option{background:#1c1d21;color:#f4f4f5;padding:12px;font-weight:500}.hexa-modal-select option:hover{background:#8b5cf633}.hexa-modal-select option:checked{background:linear-gradient(135deg,#8b5cf64d,#6366f133);color:#d8b4fe}.hexa-modal-notice{padding:16px 20px;background:linear-gradient(135deg,#8b5cf614,#6366f10d);border:2px solid rgba(139,92,246,.2);border-radius:12px;color:#d8b4fe;font-size:14px;line-height:1.6;text-align:center;box-shadow:inset 0 1px #ffffff0d}.hexa-modal-error{padding:16px 20px;background:linear-gradient(135deg,#ef444426,#dc26261a);border:2px solid rgba(239,68,68,.4);border-radius:12px;color:#fca5a5;font-size:14px;text-align:center;font-weight:500}.hexa-modal-actions{display:flex;gap:12px;margin-top:8px}.hexa-modal-btn{flex:1;padding:14px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;border:none}.hexa-modal-btn-primary{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;box-shadow:0 4px 20px #8b5cf64d,inset 0 1px #fff3}.hexa-modal-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #8b5cf680,inset 0 1px #fff3}.hexa-modal-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.hexa-modal-btn-secondary{background:#0000004d;border:2px solid rgba(80,81,88,.4);color:#d4d4d8}.hexa-modal-btn-secondary:hover{background:#00000080;border-color:#50515899;color:#f4f4f5}.hexa-saved-characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;max-height:400px;overflow-y:auto;padding:8px}.hexa-saved-char-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;background:linear-gradient(135deg,#1c1d21cc,#141519f2);border:2px solid rgba(139,92,246,.3);border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center}.hexa-saved-char-card:hover{border-color:#8b5cf699;background:linear-gradient(135deg,#8b5cf626,#6366f11a);transform:translateY(-2px);box-shadow:0 8px 24px #8b5cf64d}.hexa-saved-char-img{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid rgba(139,92,246,.4)}.hexa-saved-char-info{display:flex;flex-direction:column;gap:4px;width:100%}.hexa-saved-char-name{font-size:15px;font-weight:600;color:#f4f4f5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hexa-saved-char-class{font-size:12px;color:#8b5cf6e6;font-weight:500}.hexa-saved-char-level{font-size:13px;color:#a1a1aa;font-weight:500}@media(max-width:768px){.hexa-overview-page,.hexa-tracker-full{padding:80px 20px 40px}.hexa-page-header{flex-direction:column;align-items:flex-start;gap:20px}.hexa-page-title{font-size:28px}.hexa-characters-grid{justify-content:center}.hexa-character-box{width:240px}.hexa-tracker-header{flex-direction:column;align-items:flex-start;gap:12px}.hexa-tracker-header h1{font-size:24px}}.boss-tracker{width:100%;font-family:Inter,-apple-system,system-ui,sans-serif;color:#f4f4f5;background:transparent}.boss-tracker-header{margin-bottom:32px;width:100%;display:flex;justify-content:center}.boss-tracker-header h3{font-size:32px;margin:0;font-weight:700;color:#f4f4f5;text-align:center;filter:drop-shadow(0 2px 8px rgba(139,92,246,.4))}.boss-tracker-presets{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border-radius:12px;background:linear-gradient(135deg,#1c1d21b3,#141519e6);border:1px solid rgba(80,81,88,.4);box-shadow:0 8px 24px #00000059,inset 0 1px #ffffff0d;margin-bottom:16px}.boss-tracker-presets-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#a1a1aa}.boss-tracker-presets-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.boss-tracker-preset-btn{padding:8px 14px;border-radius:8px;border:1px solid rgba(139,92,246,.4);background:linear-gradient(135deg,#8b5cf633,#6366f126);color:#e9d5ff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.boss-tracker-preset-btn:hover{border-color:#8b5cf6b3;background:linear-gradient(135deg,#8b5cf659,#6366f140);transform:translateY(-1px);box-shadow:0 6px 16px #8b5cf640}.boss-tracker-preset-btn-secondary{border-color:#71717a80;background:#3f3f4659;color:#d4d4d8}.boss-tracker-preset-btn-secondary:hover{border-color:#94a3b8b3;background:#52525b73;box-shadow:0 6px 16px #52525b40}.boss-tracker-content{display:flex;flex-direction:column;gap:20px;width:100%}.income-summary-compact{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:24px 32px;padding:24px 0;background:linear-gradient(135deg,#2b14504d,#1c1d21f2,#2b14504d,#1c1d21f2 60%,#2b14504d,#1c1d21f2 80%,#2b14504d);border:2px solid rgba(80,81,88,.6);border-radius:14px;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614;width:100%;margin:0 auto 40px;position:relative}.summary-back-btn{position:absolute;left:24px;padding:10px 20px;background:linear-gradient(135deg,#8b5cf640,#6366f133);border:1px solid rgba(139,92,246,.4);border-radius:8px;color:#f4f4f5;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s ease;box-shadow:0 2px 8px #0003}.summary-back-btn:hover{background:linear-gradient(135deg,#8b5cf666,#6366f159);border-color:#8b5cf699;transform:translate(-2px);box-shadow:0 4px 12px #8b5cf64d}.summary-item{display:flex;align-items:center;gap:14px}.summary-divider{width:2px;height:50px;background:linear-gradient(180deg,transparent 0%,rgba(139,92,246,.5) 50%,transparent 100%)}.summary-icon{width:44px;height:44px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(139,92,246,.3))}.summary-details{display:flex;flex-direction:column;gap:2px}.summary-label{font-size:13px;color:#a1a1aa;font-weight:500;letter-spacing:.3px}.summary-value{font-size:20px;color:#e8def1;font-weight:700;text-shadow:0 2px 8px rgba(168,85,247,.3)}.summary-total{display:flex;flex-direction:column;gap:4px}.total-label{font-size:13px;color:#a1a1aa;font-weight:500;letter-spacing:.3px}.total-value{font-size:24px;font-weight:800;color:#e8def1;filter:drop-shadow(0 2px 8px rgba(139,92,246,.4))}.limit-warning{padding:10px 18px;background:linear-gradient(135deg,#6366f133,#8b5cf626);border:2px solid rgba(139,92,246,.4);border-radius:8px;color:#a5b4fc;font-size:13px;font-weight:600;box-shadow:0 2px 8px #8b5cf633;transition:all .3s ease}.limit-warning.at-limit{background:linear-gradient(135deg,#dc262640,#b91c1c33);border:2px solid rgba(220,38,38,.5);color:#fca5a5;box-shadow:0 2px 8px #dc262633}.income-percentage{display:flex;flex-direction:column;gap:4px;text-align:center}.percentage-label{font-size:13px;color:#a1a1aa;font-weight:500;letter-spacing:.3px}.percentage-value{font-size:20px;font-weight:700;color:#22c55e;filter:drop-shadow(0 2px 8px rgba(34,197,94,.3))}.boss-section{margin-bottom:48px;width:100%}.section-title{font-size:22px;font-weight:700;margin:0 0 24px;padding-left:16px;position:relative;color:#a855f7;filter:drop-shadow(0 2px 8px rgba(139,92,246,.3))}.section-title:before{content:"";width:4px;height:28px;background:linear-gradient(180deg,#a855f7,#6366f1);border-radius:2px;position:absolute;left:0;box-shadow:0 0 12px #8b5cf680}.boss-compact-monthly{border:2px solid rgba(234,179,8,.5);background:linear-gradient(135deg,#eab30814,#141519e6);position:relative;box-shadow:0 4px 16px #0000004d,0 0 20px #eab30826,inset 0 1px #ffffff14}.boss-compact-monthly:hover{border-color:#eab308b3;box-shadow:0 8px 24px #0006,0 0 30px #eab30840,inset 0 1px #ffffff1a;transform:translateY(-2px)}.boss-compact-monthly.selected{border-color:#eab308cc;background:linear-gradient(135deg,#eab3081f,#141519f2);box-shadow:0 8px 24px #0006,0 0 35px #eab3084d,inset 0 1px #ffffff1a}.boss-monthly-badge{position:absolute;top:4px;right:4px;background:linear-gradient(135deg,#eab308e6,#ca8a04e6);color:#1c1d21;font-size:8px;font-weight:800;padding:3px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;z-index:10;box-shadow:0 2px 6px #0006,0 0 10px #eab30866;border:1px solid rgba(255,255,255,.2)}.boss-grid-compact{display:grid;grid-template-columns:repeat(10,1fr);gap:12px;width:100%;align-items:start}@media(max-width:1800px){.boss-grid-compact{grid-template-columns:repeat(8,1fr)}}@media(max-width:1600px){.boss-grid-compact{grid-template-columns:repeat(7,1fr)}}@media(max-width:1200px){.boss-grid-compact{grid-template-columns:repeat(6,1fr)}}@media(max-width:900px){.boss-grid-compact{grid-template-columns:repeat(5,1fr)}}@media(max-width:768px){.boss-grid-compact{grid-template-columns:repeat(4,1fr)}}@media(max-width:500px){.boss-grid-compact{grid-template-columns:repeat(2,1fr)}}.boss-compact{display:flex;flex-direction:column;gap:10px;padding:0;background:linear-gradient(180deg,#1c1d21 20%,#0f1012 80%);border:2px solid rgba(80,81,88,.5);border-radius:12px;transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,0 0 22px #8b5cf614;position:relative;overflow:hidden;cursor:pointer;-webkit-user-select:none;user-select:none}.boss-card-content{padding:14px 14px 8px;transition:all .3s ease}.boss-compact:hover .boss-card-content{background:#8b5cf614}.boss-compact:active .boss-card-content{transform:scale(.98)}.boss-name-label{text-align:center;font-size:12px;font-weight:600;color:#a1a1aa;margin-top:8px;transition:color .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.boss-compact:hover .boss-name-label{color:#c4b5fd}.boss-compact.selected .boss-name-label{color:#e9d5ff;font-weight:700}.boss-selected-indicator{position:absolute;top:8px;left:8px;width:24px;height:24px;background:linear-gradient(135deg,#a855f7,#6366f1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;z-index:10;box-shadow:0 2px 8px #8b5cf699,0 0 16px #8b5cf666;animation:checkmarkPop .3s cubic-bezier(.68,-.55,.265,1.55)}@keyframes checkmarkPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.boss-compact:hover{border-color:#8b5cf699;background:linear-gradient(180deg,#23242a 20%,#14151a 80%);transform:translateY(-3px);box-shadow:1px 10px 40px #00000080,inset 0 1px #ffffff14,0 0 28px #8b5cf626}.boss-compact.selected{background:linear-gradient(180deg,#1c1d21f2 20%,#0f1012 80%);border-color:#8b5cf6cc;box-shadow:1px 8px 32px #00000080,inset 0 1px #ffffff14,0 0 30px #8b5cf640}.boss-compact.selected:hover{border-color:#8b5cf6;box-shadow:1px 10px 40px #0009,inset 0 1px #ffffff1a,0 0 35px #8b5cf659}.boss-compact.disabled{opacity:.35;cursor:not-allowed;pointer-events:all;filter:grayscale(.6)}.boss-img{width:100%;max-width:100%;height:80px;object-fit:contain;border-radius:8px;background:#0006;border:2px solid rgba(80,81,88,.3);padding:0;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5)) brightness(1.05) contrast(1.05);display:block;margin:0 auto}.boss-content{display:flex;flex-direction:column;gap:8px;padding:0 14px 14px}.boss-check,.boss-check input[type=checkbox],.boss-check span{display:none}.diff-select{width:100%;padding:10px 36px 10px 12px;background-color:#8b5cf626;background-image:linear-gradient(135deg,transparent 0%,rgba(99,102,241,.1) 100%),url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23c4b5fd' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:0 0,right 12px center;border:2px solid rgba(139,92,246,.4);border-radius:10px;color:#c4b5fd;font-size:13px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff0d;text-align:center;text-transform:uppercase;letter-spacing:.5px;appearance:none}.diff-select option{background:#1c1d21;color:#f4f4f5;padding:12px;font-weight:700;text-transform:uppercase;border:none}.diff-select option:hover{background:linear-gradient(135deg,#8b5cf666,#6366f14d);color:#fff}.diff-select option:checked{background:linear-gradient(135deg,#8b5cf680,#6366f166);color:#fff;font-weight:800}.diff-select:hover{background-color:#8b5cf640;border-color:#8b5cf699;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf633,inset 0 1px #ffffff14}.diff-select:focus{outline:none;border-color:#8b5cf6cc;box-shadow:0 0 0 3px #8b5cf626,0 4px 12px #8b5cf64d,inset 0 1px #ffffff1a}.party-select-compact{width:100%;padding:10px 36px 10px 12px;background-color:#3c3c4666;background-image:linear-gradient(135deg,transparent 0%,rgba(40,40,50,.3) 100%),url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23e4e4e7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:0 0,right 12px center;border:2px solid rgba(113,113,122,.4);border-radius:10px;color:#e4e4e7;font-size:13px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff0d;text-align:center;letter-spacing:.3px;appearance:none}.party-select-compact option{background:#1c1d21;color:#f4f4f5;padding:12px;font-weight:700;border:none}.party-select-compact option:hover{background:linear-gradient(135deg,#8b5cf666,#6366f14d);color:#fff}.party-select-compact option:checked{background:linear-gradient(135deg,#8b5cf680,#6366f166);color:#fff;font-weight:800}.party-select-compact:hover{background-color:#46465080;border-color:#8b5cf680;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf626,inset 0 1px #ffffff14}.party-select-compact:focus{outline:none;border-color:#8b5cf699;box-shadow:0 0 0 3px #8b5cf61a,0 4px 12px #8b5cf633,inset 0 1px #ffffff1a}.party-select-compact:focus{outline:none;border-color:var(--accent-primary, #a855f7);box-shadow:0 0 0 3px #8b5cf626,inset 0 1px 2px #0000004d}.boss-share{text-align:center;padding:8px;background:linear-gradient(135deg,#8b5cf626,#6366f11a);border-radius:8px;font-size:14px;font-weight:700;color:var(--accent-primary, #a855f7);text-shadow:0 1px 4px rgba(139,92,246,.3)}@media(max-width:768px){.boss-tracker{padding:15px}.income-summary-compact{flex-direction:column;width:100%}.summary-total{border-left:none;border-top:2px solid rgba(168,85,247,.3);padding-left:0;padding-top:12px}}.boss-crystal-summary-dashboard{margin-bottom:48px;padding:40px;background:linear-gradient(135deg,#8b5cf608,#141519fa 15% 85%,#8b5cf608);border:2px solid transparent;background-image:linear-gradient(135deg,#141519fa,#141519fa),linear-gradient(135deg,#8b5cf680,#6366f14d,#8b5cf680,#6366f14d,#8b5cf680);background-origin:border-box;background-clip:padding-box,border-box;border-radius:24px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:relative;overflow:hidden;box-shadow:0 12px 48px #00000080,0 0 80px #8b5cf626,inset 0 1px #ffffff14;animation:borderGlow 3s ease-in-out infinite}@keyframes borderGlow{0%,to{box-shadow:0 12px 48px #00000080,0 0 80px #8b5cf626,inset 0 1px #ffffff14}50%{box-shadow:0 12px 48px #00000080,0 0 100px #8b5cf640,inset 0 1px #ffffff1a}}.boss-crystal-summary-dashboard:before{content:"";position:absolute;top:0;left:-50%;width:200%;height:100%;background:linear-gradient(90deg,transparent,rgba(139,92,246,.03),transparent);animation:shimmer 8s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.boss-crystal-summary-title{font-size:28px;font-weight:800;background:linear-gradient(135deg,#f4f4f5,#8b5cf6,#f4f4f5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 32px;text-align:center;text-transform:uppercase;letter-spacing:2px;position:relative;z-index:1;filter:drop-shadow(0 4px 12px rgba(139,92,246,.5))}.boss-crystal-summary-grid{display:grid;grid-template-columns:repeat(5,minmax(180px,1fr));gap:16px;position:relative;z-index:1}.boss-crystal-summary-card{display:flex;align-items:center;gap:20px;padding:18px;background:linear-gradient(135deg,#1c1d2199,#141519cc);border:2px solid rgba(80,81,88,.3);border-radius:16px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.boss-crystal-summary-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(139,92,246,.05) 0%,transparent 50%,rgba(99,102,241,.05) 100%);opacity:0;transition:opacity .4s ease}.boss-crystal-summary-card:hover{border-color:#8b5cf6b3;background:linear-gradient(135deg,#1c1d21cc,#141519f2);transform:translateY(-6px) scale(1.02);box-shadow:0 20px 40px #0006,0 0 40px #8b5cf64d,inset 0 1px #ffffff1a}.boss-crystal-summary-card:hover:before{opacity:1}.boss-crystal-summary-icon{width:52px;height:52px;min-width:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf633,#6366f126);border-radius:14px;border:2px solid rgba(139,92,246,.4);position:relative;transition:all .4s ease;box-shadow:0 4px 16px #8b5cf633,inset 0 1px #ffffff1a}.boss-crystal-summary-card:hover .boss-crystal-summary-icon{transform:rotate(5deg) scale(1.1);border-color:#8b5cf6b3;box-shadow:0 8px 24px #8b5cf666,inset 0 1px #fff3}.boss-crystal-summary-icon:after{content:"";position:absolute;inset:-2px;border-radius:14px;background:linear-gradient(135deg,#8b5cf64d,#6366f133);filter:blur(8px);opacity:0;transition:opacity .4s ease;z-index:-1}.boss-crystal-summary-card:hover .boss-crystal-summary-icon:after{opacity:1}.boss-crystal-summary-icon img{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(139,92,246,.8));transition:filter .4s ease}.boss-crystal-summary-card:hover .boss-crystal-summary-icon img{filter:drop-shadow(0 4px 12px rgba(139,92,246,1))}.boss-crystal-summary-icon-text{font-size:32px;filter:drop-shadow(0 2px 8px rgba(139,92,246,.6));transition:filter .4s ease}.boss-crystal-summary-card:hover .boss-crystal-summary-icon-text{filter:drop-shadow(0 4px 12px rgba(139,92,246,.9))}.boss-crystal-summary-icon-react{width:32px;height:32px;color:#c4b5fd;filter:drop-shadow(0 2px 8px rgba(139,92,246,.8));transition:all .4s ease}.boss-crystal-summary-card:hover .boss-crystal-summary-icon-react{color:#e9d5ff;filter:drop-shadow(0 4px 12px rgba(139,92,246,1));transform:scale(1.1)}.boss-crystal-summary-content{flex:1;display:flex;flex-direction:column;gap:6px}.boss-crystal-summary-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#a1a1aa;transition:color .3s ease}.boss-crystal-summary-card:hover .boss-crystal-summary-label{color:#c4b5fd}.boss-crystal-summary-value{font-size:24px;font-weight:800;background:linear-gradient(135deg,#f4f4f5,#d4d4d8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 8px rgba(139,92,246,.4));transition:all .3s ease;line-height:1.2}.boss-crystal-summary-card:hover .boss-crystal-summary-value{background:linear-gradient(135deg,#fff,#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 4px 12px rgba(139,92,246,.7));transform:scale(1.05)}@media(max-width:1200px){.boss-crystal-summary-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}}@media(max-width:900px){.boss-crystal-summary-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}}@media(max-width:768px){.boss-crystal-summary-dashboard{padding:24px}.boss-crystal-summary-grid{grid-template-columns:1fr;gap:16px}.boss-crystal-summary-title{font-size:22px;margin-bottom:24px}.boss-crystal-summary-card{padding:20px}.boss-crystal-summary-icon{width:56px;height:56px;min-width:56px}.boss-crystal-summary-value{font-size:24px}}.boss-crystal-character-box{position:relative;transition:transform .3s cubic-bezier(.4,0,.2,1)}.boss-crystal-character-box:hover{transform:translateY(-4px)}.boss-crystal-sortable-item{touch-action:none}.boss-crystal-drag-area{position:absolute;left:0;top:0;bottom:0;width:48px;cursor:grab;z-index:15;background-image:repeating-linear-gradient(to bottom,rgba(113,113,122,.15) 0px,rgba(113,113,122,.15) 4px,transparent 4px,transparent 8px);background-position:center center;background-size:12px 100%;background-repeat:repeat-y;border-radius:16px 0 0 16px;transition:all .2s ease}.boss-crystal-drag-area:hover{background-color:#8b5cf614;background-image:repeating-linear-gradient(to bottom,rgba(139,92,246,.5) 0px,rgba(139,92,246,.5) 4px,transparent 4px,transparent 8px)}.boss-crystal-drag-area:active{cursor:grabbing;background-color:#8b5cf626;background-image:repeating-linear-gradient(to bottom,rgba(139,92,246,.6) 0px,rgba(139,92,246,.6) 4px,transparent 4px,transparent 8px)}.boss-crystal-sortable-item .boss-crystal-char-card{padding-left:52px}.boss-crystal-char-card{width:100%;min-height:180px;background:linear-gradient(135deg,#1c1d21cc,#141519f2);border:2px solid rgba(80,81,88,.5);border-radius:16px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;display:flex;flex-direction:row;align-items:stretch;padding:0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 24px #0006,inset 0 1px #ffffff0d}.boss-crystal-char-card:hover{border-color:#8b5cf699;box-shadow:0 12px 40px #8b5cf64d,0 0 40px #8b5cf626,inset 0 1px #ffffff1a}.boss-crystal-char-info{flex:1;padding:20px;display:flex;flex-direction:column;justify-content:center}.boss-crystal-char-share{margin-top:12px;padding-top:12px;border-top:1px solid rgba(80,81,88,.35);display:flex;justify-content:space-between;align-items:center}.boss-crystal-share-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#71717a;max-width:120px}.boss-crystal-share-value{font-size:16px;font-weight:700;color:#e8def1;text-shadow:0 0 10px rgba(139,92,246,.5)}.boss-crystal-char-image{width:160px;min-width:160px;background:linear-gradient(135deg,#8b5cf614,#6366f10d);display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;position:relative;border-left:2px solid rgba(139,92,246,.2)}.boss-crystal-char-image img{width:100%;height:100%;object-fit:contain;object-position:center}.boss-crystal-char-name-section{margin-bottom:16px}.boss-crystal-char-name{font-size:18px;font-weight:700;color:#f4f4f5;margin-bottom:4px;text-shadow:0 2px 8px rgba(0,0,0,.3)}.boss-crystal-char-class{font-size:13px;font-weight:500;color:#a1a1aa;text-transform:capitalize}.boss-crystal-char-stats-grid{display:flex;flex-direction:column;gap:10px}.boss-crystal-stat-section{display:flex;flex-direction:column;gap:10px;padding:14px;background:#0000004d;border:1px solid rgba(80,81,88,.35);border-radius:10px;align-items:center}.boss-crystal-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#71717a;text-align:center}.boss-crystal-stat-values{display:flex;gap:20px;align-items:center}.boss-crystal-stat-values{display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center}.boss-crystal-stat-item{display:flex;align-items:center;justify-content:center;gap:10px}.boss-crystal-stat-icon{width:24px;height:24px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(139,92,246,.4))}.boss-crystal-stat-value{font-size:16px;font-weight:700;color:#f4f4f5;text-shadow:0 2px 4px rgba(0,0,0,.3)}.boss-crystal-char-remove{position:absolute;top:12px;right:12px;background:linear-gradient(135deg,#ef44441a,#dc26260d);border:1.5px solid rgba(239,68,68,.3);color:#ef4444;width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;max-width:32px!important;max-height:32px!important;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff0d;font-size:20px;font-weight:700;line-height:1;padding:0;flex-shrink:0}.boss-crystal-char-remove:hover{background:linear-gradient(135deg,#ef444433,#dc262626);border-color:#ef444499;color:#fca5a5;transform:translateY(-2px);box-shadow:0 4px 16px #ef444466,inset 0 1px #ffffff1a}.boss-crystal-char-remove:active{transform:translateY(0);box-shadow:0 2px 8px #ef444466,inset 0 1px #ffffff0d}.boss-crystal-char-actions{position:absolute;top:12px;right:12px;display:flex;gap:8px;z-index:10}.boss-crystal-char-actions .boss-crystal-char-remove{position:static}.boss-crystal-char-edit{background:linear-gradient(135deg,#8b5cf61a,#7c3aed0d);border:1.5px solid rgba(139,92,246,.3);color:#a78bfa;width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff0d;font-size:16px;padding:0;flex-shrink:0}.boss-crystal-char-edit:hover{background:linear-gradient(135deg,#8b5cf633,#7c3aed26);border-color:#8b5cf699;color:#c4b5fd;transform:translateY(-2px);box-shadow:0 4px 16px #8b5cf666,inset 0 1px #ffffff1a}.boss-crystal-char-edit:active{transform:translateY(0);box-shadow:0 2px 8px #8b5cf666,inset 0 1px #ffffff0d}.boss-crystal-characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px;max-width:1400px;width:100%}@media(max-width:768px){.boss-crystal-characters-grid{grid-template-columns:1fr;gap:16px}.boss-crystal-character-box{width:100%}}.statistics-page{padding:48px 40px 80px;min-height:100vh}.statistics-container{max-width:1800px;margin:0 auto;width:100%}.statistics-header{text-align:center;margin-bottom:40px}.statistics-title{display:inline-flex;align-items:center;gap:12px;font-size:32px;font-weight:800;color:#f4f4f5;margin:0 0 12px}.statistics-title .title-icon{color:#8b5cf6}.statistics-subtitle{color:#a1a1aa;font-size:15px;max-width:600px;margin:0 auto}.statistics-loading,.statistics-error,.statistics-empty{text-align:center;padding:48px 20px;color:#9ca3af}.statistics-spinner{width:48px;height:48px;margin:0 auto 16px;border:4px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:statistics-spin .8s linear infinite}@keyframes statistics-spin{to{transform:rotate(360deg)}}.statistics-error{color:#fbbf24;background-color:#fbbf240d;border:1px solid rgba(251,191,36,.2);border-radius:12px;max-width:400px;margin:0 auto 32px}.statistics-retry{margin-top:12px;background:#8b5cf626;border:1px solid rgba(139,92,246,.4);color:#c4b5fd;padding:8px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease}.statistics-retry:hover{background:#8b5cf640;border-color:#8b5cf699}.statistics-fallback{margin:10px 0 0;color:#9ca3af;font-size:.85rem}.mock-data-notice{text-align:center;padding:12px 20px;margin-bottom:24px;background:#fbbf2414;border:1px solid rgba(251,191,36,.2);border-radius:10px;color:#fbbf24;font-size:14px}.statistics-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:40px}.statistics-card{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#1c1d21cc,#141519f2);border:1px solid rgba(80,81,88,.4);border-radius:16px;box-shadow:0 6px 20px #00000059;transition:all .3s ease}.statistics-card:hover{border-color:#8b5cf680;transform:translateY(-2px);box-shadow:0 10px 30px #0006}.statistics-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;color:#c4b5fd;background:#8b5cf626;border:1px solid rgba(139,92,246,.35);font-size:22px}.statistics-card-content{display:flex;flex-direction:column;gap:6px}.statistics-card-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#a1a1aa}.statistics-card-value{font-size:24px;font-weight:700;color:#f4f4f5}.section-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.3),transparent);margin:48px 0}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}.chart-card{background:linear-gradient(135deg,#1c1d21e6,#141519fa);border:1px solid rgba(80,81,88,.4);border-radius:18px;padding:24px;box-shadow:0 10px 32px #0006}.chart-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.chart-header h3{margin:0;font-size:18px;font-weight:700;color:#f4f4f5}.chart-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;color:#c4b5fd;background:#8b5cf626;border:1px solid rgba(139,92,246,.35);font-size:16px}.badge-chart-card .chart-header{margin-bottom:12px}.badge-chart-card .chart-header h3{font-size:15px}.badge-chart-card .chart-icon{width:32px;height:32px;font-size:14px}.bar-chart-container{width:100%}.bar-chart-container.scrollable-chart{max-height:480px;overflow-y:auto;overflow-x:hidden}.scrollable-chart::-webkit-scrollbar{width:8px}.scrollable-chart::-webkit-scrollbar-track{background:#50515833;border-radius:4px}.scrollable-chart::-webkit-scrollbar-thumb{background:#8b5cf666;border-radius:4px}.scrollable-chart::-webkit-scrollbar-thumb:hover{background:#8b5cf699}.level-chart-fill{display:flex;flex-direction:column}.pie-chart-container{width:100%}.chart-tooltip{background:#141519f2;border:1px solid rgba(139,92,246,.4);border-radius:10px;padding:12px 16px;box-shadow:0 8px 24px #00000080}.chart-tooltip .tooltip-label{margin:0 0 4px;font-size:13px;color:#a1a1aa}.chart-tooltip .tooltip-value{margin:0;font-size:18px;font-weight:700;color:#c4b5fd}.badge-section{margin-top:0}.badge-section-title{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:700;color:#f4f4f5;margin:0 0 8px}.badge-section-title .section-icon{color:#f97316}.badge-section-subtitle{margin:0 0 28px;color:#9ca3af;font-size:14px}.badge-charts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.badge-chart-card{background:linear-gradient(135deg,#1c1d21e6,#141519fa);border:1px solid rgba(80,81,88,.4);border-radius:16px;padding:20px;box-shadow:0 10px 32px #0006}.badge-legend{display:flex;flex-direction:column;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(80,81,88,.3)}.badge-legend-item{display:flex;align-items:center;gap:8px;font-size:12px}.badge-legend-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.badge-legend-name{flex:1;color:#e5e7eb}.badge-legend-value{color:#f4f4f5;font-weight:600;min-width:50px;text-align:right}.badge-legend-percent{color:#9ca3af;font-size:11px;min-width:45px}.statistics-footer{text-align:center;margin-top:48px;padding-top:24px;border-top:1px solid rgba(80,81,88,.3);color:#71717a;font-size:13px}@media(max-width:1400px){.badge-charts-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.statistics-page{padding:40px 24px 60px}.charts-grid{grid-template-columns:1fr}.class-chart-card{order:1}.level-chart-card{order:2}.statistics-summary-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.statistics-page{padding:32px 16px 60px}.statistics-title{font-size:26px}.statistics-summary-grid{grid-template-columns:1fr;gap:16px}.chart-card{padding:16px}.chart-header h3{font-size:16px}.badge-charts-grid{grid-template-columns:1fr}.badge-section-title{font-size:20px}}@media(max-width:480px){.statistics-card{padding:16px}.statistics-card-value{font-size:20px}.badge-legend-item{font-size:12px}.badge-legend-value{min-width:50px}.badge-legend-percent{display:none}}.recharts-cartesian-axis-tick-value{fill:#9ca3af!important}.recharts-legend-item-text{color:#e5e7eb!important}.recharts-default-tooltip{background:#141519f2!important;border:1px solid rgba(139,92,246,.4)!important;border-radius:8px!important}.recharts-pie-label-text{fill:#e5e7eb!important;font-size:11px!important}.archetype-section{margin-top:0}.archetype-map-container{margin-top:24px}.archetype-chart-card{background:linear-gradient(135deg,#1c1d21e6,#141519fa);border:1px solid rgba(80,81,88,.4);border-radius:18px;padding:24px;box-shadow:0 10px 32px #0006}.scatter-chart-wrapper{position:relative}.archetype-loading,.archetype-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#9ca3af}.archetype-empty-hint{margin-top:8px;font-size:13px;color:#6b7280}.quadrant-labels{position:absolute;inset:20px 30px 60px 60px;pointer-events:none}.quadrant-label{position:absolute;font-size:12px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px}.quadrant-label.top-right{top:10%;right:10%}.quadrant-label.top-left{top:10%;left:10%}.quadrant-label.bottom-right{bottom:15%;right:10%}.quadrant-label.bottom-left{bottom:15%;left:10%}.quadrant-buttons-header{text-align:center;color:#9ca3af;font-size:14px;margin:24px 0 0;padding-top:24px;border-top:1px solid rgba(80,81,88,.3)}.quadrant-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:16px}.quadrant-button{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:16px;background:#1c1d2199;border:1px solid rgba(80,81,88,.4);border-radius:12px;cursor:pointer;transition:all .2s ease}.quadrant-button:hover{background:#1c1d21e6;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.quadrant-dot{width:10px;height:10px;border-radius:50%}.quadrant-name{font-size:14px;font-weight:600;color:#f4f4f5}.quadrant-desc{font-size:11px;color:#9ca3af}.scatter-tooltip{min-width:160px}.scatter-tooltip .tooltip-name{margin:0 0 4px;font-size:14px;font-weight:600;color:#f4f4f5}.scatter-tooltip .tooltip-detail{margin:0 0 6px;font-size:12px;color:#a1a1aa}.scatter-tooltip .tooltip-scores{margin:0;font-size:11px;color:#c4b5fd}.player-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.player-modal{background:linear-gradient(135deg,#1c1d21fa,#141519);border:1px solid rgba(80,81,88,.5);border-radius:16px;width:100%;max-width:500px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 50px #00000080}.player-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(80,81,88,.3)}.player-modal-header h3{margin:0;font-size:18px;font-weight:700;color:#f4f4f5;display:flex;align-items:center;gap:10px}.modal-dot{width:12px;height:12px;border-radius:50%}.modal-close{background:transparent;border:none;color:#9ca3af;font-size:18px;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#f4f4f5}.modal-description{margin:0;padding:16px 24px 8px;font-size:13px;color:#a1a1aa}.modal-count{margin:0;padding:0 24px 16px;font-size:12px;color:#8b5cf6;font-weight:500}.modal-loading{display:flex;align-items:center;justify-content:center;padding:40px}.player-list{flex:1;overflow-y:auto;padding:0 24px 24px}.player-list-header{display:grid;grid-template-columns:1fr 80px 100px;gap:12px;padding:12px 0;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;border-bottom:1px solid rgba(80,81,88,.3)}.player-list-item{display:grid;grid-template-columns:1fr 80px 100px;gap:12px;padding:12px 0;border-bottom:1px solid rgba(80,81,88,.2);align-items:center}.player-list-item:last-child{border-bottom:none}.player-info{display:flex;align-items:center;gap:10px;min-width:0}.player-rank{font-size:12px;font-weight:600;color:#8b5cf6;min-width:24px}.player-name{font-size:14px;font-weight:600;color:#f4f4f5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-class{font-size:11px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-level{font-size:13px;font-weight:500;color:#e5e7eb}.player-scores{display:flex;gap:6px}.score-badge{font-size:10px;font-weight:600;padding:3px 6px;border-radius:4px}.score-badge.consistency{background:#22c55e26;color:#86efac}.score-badge.intensity{background:#8b5cf626;color:#c4b5fd}.no-players{text-align:center;padding:24px;color:#6b7280;font-size:14px}@media(max-width:1024px){.quadrant-buttons{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.quadrant-buttons{grid-template-columns:1fr}.player-list-header,.player-list-item{grid-template-columns:1fr 60px 80px;gap:8px}.player-class{display:none}.player-modal{max-height:90vh}}
