body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body,html{overflow-x:hidden;position:relative;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.loading-overlay{align-items:center;background:#0f172af2;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-content{color:#fff;text-align:center}.loading-content h2{font-size:2rem;margin-bottom:1.5rem}.loading-bar{background:#334155;border-radius:10px;height:20px;margin:0 auto 1rem;overflow:hidden;width:300px}.loading-progress{background:linear-gradient(90deg,#3b82f6,#8b5cf6);height:100%;transition:width .3s ease}.loading-content p{color:#94a3b8;font-size:1.125rem}.app-container{background:linear-gradient(to bottom right,#0f172a,#1e293b,#0f172a);min-height:100vh;overflow-x:hidden;padding:2rem .5rem;position:relative;width:100%}@media (min-width:640px){.app-container{padding:2rem 1rem}}.header{margin:0 auto 1.5rem;max-width:1280px;padding:0 .5rem;text-align:center}@media (min-width:640px){.header{padding:0}}.title{color:#fff;font-size:clamp(1.5rem,5vw,3rem);font-weight:700;-webkit-hyphens:none;hyphens:none;margin-bottom:.5rem;word-break:keep-all}.subtitle,.title{text-align:center}.subtitle{color:#94a3b8;font-size:1.125rem}.filter-container{margin:0 auto 2rem;max-width:1280px;padding:0 .5rem}@media (min-width:640px){.filter-container{padding:0}}.toggle-filters-btn{background-color:#334155;border:2px solid #475569;border-radius:.5rem;color:#cbd5e1;cursor:pointer;display:block;font-weight:600;margin:1rem auto;max-width:200px;padding:.75rem 1.5rem;transition:all .2s;width:100%}.toggle-filters-btn:hover{background-color:#475569;border-color:#64748b}.filter-section{margin-top:1.5rem}.filter-title{color:#cbd5e1;font-size:1rem;font-weight:600;margin-bottom:.75rem;text-align:center}.sort-control-container{justify-content:space-between;margin-bottom:1rem}.sort-control,.sort-control-container{align-items:center;display:flex;gap:.75rem}.sort-label{color:#cbd5e1;font-size:1rem;font-weight:600}@media (max-width:768px){.sort-label{display:none}}.sort-select{background-color:#334155;border:2px solid #475569;border-radius:.5rem;color:#cbd5e1;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1rem;transition:all .2s}.sort-select:hover{background-color:#475569;border-color:#64748b}.sort-select:focus{border-color:#fbbf24;box-shadow:0 0 0 3px #fbbf2433;outline:none}.refresh-btn{align-items:center;background-color:#334155;border:2px solid #475569;border-radius:.5rem;color:#cbd5e1;cursor:pointer;display:inline-flex;justify-content:center;padding:.75rem;transition:all .2s}.refresh-btn:hover{background-color:#475569;border-color:#64748b;transform:scale(1.05)}@media (max-width:640px){.sort-control-container{flex-direction:row;justify-content:space-between}.sort-control{align-items:flex-end;flex-direction:column;gap:.25rem}.sort-label,.sort-select{font-size:.875rem}.sort-select{padding:.5rem .75rem}}.filter-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;padding:0 .25rem}@media (min-width:640px){.filter-buttons{padding:0}}.filter-btn{background-color:#334155;border:2px solid #0000;border-radius:.5rem;color:#cbd5e1;cursor:pointer;font-weight:600;padding:.5rem 1rem;transform:scale(1);transition:all .2s}.filter-btn:hover{transform:scale(1.02)}.filter-btn.active{background-color:#475569;box-shadow:0 10px 15px -3px #0000004d;color:#fff;transform:scale(1.05)}.filter-btn.class-filter{background-color:initial;border-color:var(--class-border)}.filter-btn.class-filter.active{background-color:var(--class-bg);color:#1e293b}.profession-filter{background-color:#1e3a5f;border-color:#3b82f6;color:#cbd5e1}.profession-filter:hover{background-color:#2563eb;color:#fff}.profession-filter.active{background-color:#3b82f6;border-color:#60a5fa;color:#fff}.character-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(1,1fr);margin:0 auto;max-width:100%;padding:0 .75rem;width:100%}@media (min-width:640px){.character-grid{gap:1.5rem;grid-template-columns:repeat(3,1fr);max-width:1280px;padding:0 1rem}}@media (min-width:1500px){.character-grid{grid-template-columns:repeat(4,1fr)}}.card-container{aspect-ratio:2/2.5;cursor:pointer;max-width:100%;perspective:1000px;width:100%}.card{height:100%;position:relative;transform-style:preserve-3d;transition:transform .6s;width:100%}.card.flipped{transform:rotateY(180deg)}.card-face{backface-visibility:hidden;-webkit-backface-visibility:hidden;height:100%;width:100%}.card-back{left:0;position:absolute;top:0;transform:rotateY(180deg)}.card-inner{background-color:#1e293b;border:4px solid;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000004d;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:box-shadow .3s}.card-container:hover .card-inner{box-shadow:0 20px 25px -5px #0000004d}.card-image-container{background-color:#0f172a;flex:1 1;overflow:hidden;position:relative}.card-image-container.full-height{flex:1 1}.ilvl-badge{align-items:center;background:#000000d9;border-radius:.375rem;box-shadow:0 2px 8px #00000080;color:#fbbf24;display:flex;font-size:.875rem;font-weight:700;gap:.4rem;padding:.4rem .6rem;position:absolute;right:.75rem;top:.75rem;z-index:10}.ilvl-badge svg{fill:currentColor;height:16px;width:16px}.card-overlay-info{background:linear-gradient(0deg,#000000f2,#0000);bottom:0;color:#fff;left:0;padding:1.5rem 1rem 1rem;position:absolute;right:0}.professions-list{display:flex;flex-direction:column;gap:.5rem}.profession-item{align-items:center;background-color:#0009;border-radius:.25rem;display:flex;justify-content:space-between;margin-bottom:.25rem;padding:.25rem .75rem}.profession-item:last-child{margin-bottom:0}.profession-name{color:#fff;font-size:.95rem;font-weight:600;text-shadow:0 1px 2px #000c}.profession-level{font-size:.9rem;font-weight:700;text-shadow:0 1px 3px #000000e6}.card-image{height:100%;object-fit:cover;object-position:95% center;transition:transform .3s;width:100%}.card-back .card-image{object-position:90% center}.role-badge{left:.75rem;position:absolute;top:.75rem;z-index:10}.role-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.8));height:32px;width:32px}.card-container:hover .card-image{transform:scale(1.05)}.card-info{padding:.3125rem .75rem}.card-info,.card-info-gradient{background-color:#000;text-align:center}.card-info-gradient{padding:.5rem .75rem}.card-name-bar{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.name-bar-left,.name-bar-right{align-items:center;display:flex;gap:.25rem;min-width:32px}.name-bar-left{justify-content:flex-start}.name-bar-right{justify-content:flex-end}.character-name{color:#1e293b}.character-name,.character-name-gradient{font-size:1.125rem;font-weight:700;margin:0}.character-name-gradient{color:var(--text-color);flex:1 1;text-align:center;text-shadow:0 1px 2px #000c}.ilvl-text{color:#f8b700;font-size:.9rem;font-weight:700;text-shadow:0 1px 2px #000c}.name-bar-right svg{fill:#f8b700;filter:drop-shadow(0 1px 2px rgba(0,0,0,.8));height:13px;width:13px}.name-bar-left .role-icon{filter:drop-shadow(0 1px 2px rgba(0,0,0,.8));height:24px;width:24px}.character-class{color:#475569;font-size:.875rem;font-weight:500;margin:0}.reset-container{margin:2rem auto 0;max-width:1280px;text-align:center}.reset-btn{align-items:center;background-color:#334155;border:none;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000004d;color:#fff;cursor:pointer;display:inline-flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .2s}.reset-btn:hover{background-color:#475569}.instructions{margin:2rem auto 0;max-width:1280px;text-align:center}.instructions p{color:#64748b;font-size:.875rem}@media (max-width:640px){.app-container{padding:1rem .5rem}.character-grid{gap:1rem}.filter-btn{font-size:.875rem;padding:.4rem .8rem}}
/*# sourceMappingURL=main.6afdb08f.css.map*/