@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;600;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}.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}@keyframes titleShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.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}.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}.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-direction:column;gap:8px}.link-divider{display:none}}.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:220px;height:calc(100vh - 70px);background:#1e192df2;border-right:1px solid rgba(139,92,246,.2);padding:30px 20px;overflow-y:auto;z-index:10}.content-section{width:100%;min-height:400px}.character-lookup.has-character .content-section{margin-left:240px;padding:36px;width:calc(100% - 280px);max-width:1600px;transform:scale(.95);transform-origin:top left}.main-grid{display:grid;grid-template-columns:280px 1fr 620px;grid-template-rows:minmax(350px,auto) auto;gap:20px;width:100%;padding-left:20px;align-items:stretch}.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{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))}.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}.statistics-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;box-shadow:1px 8px 32px #0006,inset 0 1px #ffffff0d,inset 0 -1px #00000080,0 0 20px #6478c814}.statistics-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:center;align-items:center;margin-bottom:12px}.calendar-month{font-size:1rem;font-weight:700;color:#e8e8f0;text-shadow:0 0 10px rgba(139,92,246,.3)}.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(6,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-calculator-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.03) 50%,transparent 100%);animation:shimmer 3s infinite;pointer-events:none}.eta-calculator-card:after{content:"";position:absolute;inset:0;border-radius:14px;padding:3px;background:linear-gradient(135deg,rgba(100,120,200,.1) 0%,transparent 40%,transparent 60%,rgba(100,120,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}.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:30px;transition:all .3s ease}.search-header.minimized{justify-content:flex-start;margin-bottom:20px;gap:10px}.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}.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}@keyframes spin{to{transform:rotate(360deg)}}.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 fadeIn{0%{opacity:0}to{opacity:1}}@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,.statistics-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}.statistics-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}.statistics-card{padding:15px}.statistics-card .card-title{font-size:1rem}.heatmap-calendar{padding:10px}}: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%}}
