.characters-container{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.characters-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.characters-header h1{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin:0;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.back-btn,.shop-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;font-size:.9rem;transition:all .2s ease;cursor:pointer}.back-btn:hover,.shop-btn:hover{background:var(--bg-secondary);border-color:var(--accent-primary)}.shop-btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;color:#fff}.shop-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed66}.characters-main{max-width:1400px;margin:0 auto;padding:2rem}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:var(--text-secondary)}.error-state{color:var(--error)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.layout-container{display:grid;grid-template-columns:1fr 350px;gap:2rem;align-items:start}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.character-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:16px;padding:1.5rem;transition:all .3s ease;cursor:pointer}.character-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #7c3aed33;border-color:var(--accent-secondary)}.character-card.selected{border-color:var(--accent-primary);background:linear-gradient(135deg,rgba(124,58,237,.1),var(--bg-secondary));box-shadow:0 0 20px #7c3aed4d}.character-card.in-dungeon{opacity:.8}.character-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.character-level{background:var(--accent-primary);color:#fff;padding:.25rem .75rem;border-radius:8px;font-weight:700;font-size:.85rem}.character-name{font-size:1.25rem;font-weight:600;margin-bottom:.25rem;text-align:center}.character-class{font-size:.9rem;color:var(--accent-secondary);text-align:center;margin-bottom:1rem}.exp-bar-container{margin-bottom:1rem}.exp-bar{height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-bottom:.25rem}.exp-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:3px;transition:width .5s ease}.exp-text{font-size:.75rem;color:var(--text-secondary);text-align:center;display:block}.dungeon-badge{background:#fbbf2433;border:1px solid #fbbf24;color:#fbbf24;padding:.25rem .75rem;border-radius:8px;font-size:.8rem;text-align:center;margin-bottom:1rem}.character-stats{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;padding:.75rem;background:var(--bg-tertiary);border-radius:12px;margin-bottom:.5rem;font-size:.8rem}.total-stats{text-align:center;font-weight:700;color:var(--accent-secondary);margin-bottom:.75rem;padding:.5rem;background:var(--bg-tertiary);border-radius:8px;font-size:.9rem}.character-avatar{display:flex;align-items:center;justify-content:center;margin-bottom:.5rem;position:relative;min-height:200px}.view-3d-btn{width:100%;padding:.5rem;margin-bottom:.75rem;background:linear-gradient(135deg,#7c3aed33,#a78bfa33);border:1px solid var(--accent-primary);color:var(--accent-secondary);border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.4rem}.view-3d-btn:hover{background:linear-gradient(135deg,#7c3aed4d,#a78bfa4d);transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed4d}.loading-3d{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1}.spinner-small{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.element-icon{font-size:3rem}.character-class-badge{padding:.25rem .75rem;border-radius:8px;font-weight:700;font-size:.9rem}.character-element{font-size:.85rem;color:var(--text-secondary);text-align:center;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.character-element .element-icon{font-size:1rem}.stat-row{display:flex;justify-content:space-between;font-size:.85rem}.stat-row span:first-child{color:var(--text-secondary)}.stat-row span:last-child{font-weight:600;color:var(--text-primary)}.view-equipment-hint{font-size:.75rem;color:var(--text-secondary);text-align:center;opacity:.7}.equipment-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;position:sticky;top:100px}.equipment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.equipment-header h2{margin:0;font-size:1.25rem}.selected-char-name{font-size:.9rem;color:var(--accent-secondary)}.loading-small{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-secondary)}.spinner-small{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.no-equipment{text-align:center;padding:2rem;color:var(--text-secondary)}.no-equipment-icon{font-size:3rem;margin-bottom:.5rem;opacity:.5}.goto-inventory-btn{margin-top:1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s}.goto-inventory-btn:hover{border-color:var(--accent-primary)}.equipment-list{display:flex;flex-direction:column;gap:.75rem}.equipment-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;transition:all .2s}.equipment-item:hover{border-color:var(--accent-primary)}.equipment-icon{font-size:1.5rem}.equipment-info{flex:1;min-width:0}.equipment-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.equipment-slot{font-size:.75rem;color:var(--text-secondary)}.equipment-stats-mini{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.stat-mini{font-size:.7rem;color:var(--success);background:#10b9811a;padding:.125rem .375rem;border-radius:4px}.equipment-rarity{font-weight:700;font-size:.9rem}.unequip-btn-small{background:#ef44441a;border:1px solid transparent;color:var(--error);width:28px;height:28px;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:.8rem}.unequip-btn-small:hover:not(:disabled){background:#ef444433;border-color:var(--error)}.unequip-btn-small:disabled{opacity:.3;cursor:not-allowed}.add-equipment-btn{width:100%;margin-top:1rem;padding:.75rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.add-equipment-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed66}.empty-state{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:16px;padding:3rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-text{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-subtext{font-size:.95rem;color:var(--text-secondary);margin-bottom:1.5rem}.action-btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.action-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #7c3aed66}.primary-btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))}@media(max-width:1024px){.layout-container{grid-template-columns:1fr}.equipment-panel{position:static}}@media(max-width:768px){.characters-main,.characters-header{padding:1rem}.characters-grid{grid-template-columns:1fr;gap:1rem}}
