.characters-grid,.chars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:26px}.char-card{background:var(--card-bg);border:var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);overflow:hidden;position:relative;transition:transform var(--t-base) ease,box-shadow var(--t-smooth) ease;display:flex;flex-direction:column}.char-card:before{content:"";position:absolute;top:0;left:-60%;width:50%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.18),transparent);transform:skew(-18deg);pointer-events:none;z-index:4;transition:left .7s ease}.char-card:hover:before{left:130%}.char-card:hover{transform:translateY(-6px);box-shadow:var(--elev-5),0 20px 36px #0000008c,0 0 0 1px #ff28b480 inset,-6px 0 22px #ff28b459,6px 0 22px #00ffc84d}.char-art,.char-portrait{position:relative;aspect-ratio:420/246;background:radial-gradient(ellipse 80% 70% at 50% 90%,rgba(255,160,40,.5) 0%,transparent 70%),linear-gradient(180deg,var(--accent-hot) 0%,#5b1bb5 50%,#1f0a40 100%);overflow:hidden}.char-art:after,.char-portrait:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 100% at 100% 50%,rgba(0,255,200,.18) 0%,transparent 60%),radial-gradient(ellipse 60% 100% at 0% 50%,rgba(255,40,180,.18) 0%,transparent 60%);mix-blend-mode:screen;pointer-events:none}.char-art img,.char-portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;filter:drop-shadow(0 6px 18px rgba(0,0,0,.45));transition:transform .4s ease}.char-card:hover .char-art img,.char-card:hover .char-portrait img{transform:scale(1.05)}.char-portrait h3,.char-portrait .char-type{display:none}.char-card-locked .char-art{background:repeating-linear-gradient(0deg,rgba(0,255,234,.04) 0 2px,transparent 2px 4px),radial-gradient(ellipse 70% 80% at 50% 50%,rgba(255,40,180,.35) 0%,transparent 70%),linear-gradient(180deg,var(--bg-2) 0%,#0a0220 100%)}.char-locked{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:16px;text-align:center;font-family:var(--font-mono)}.char-locked-glitch{position:relative;font-family:var(--font-display);font-weight:900;font-style:italic;font-size:64px;letter-spacing:6px;color:#fff;text-shadow:-3px 0 0 rgba(255,40,180,.9),3px 0 0 rgba(0,255,234,.9),0 0 30px rgba(255,40,180,.5);animation:lock-flicker 2.6s steps(1) infinite}@keyframes lock-flicker{0%,92%,to{opacity:1;transform:none}93%{opacity:.3;transform:translate(-3px)}93.5%{opacity:1;transform:translate(4px)}94%{opacity:.7;transform:none}97%{opacity:.2}97.5%{opacity:1}}.char-locked-bars{display:flex;flex-direction:column;gap:4px;font-size:10px;letter-spacing:2px;color:#00ffead9;text-transform:uppercase}.char-locked-bars span:last-child{color:#ff28b4e6}.char-body,.char-card>p{padding:18px 20px 22px;display:flex;flex-direction:column;gap:10px;flex:1}.char-card>p{display:block;font-size:13px;color:var(--fg-dim);line-height:1.5;padding-top:0}.char-class-row{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--fg-dim)}.char-class-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.char-class-dot.attack{background:var(--hex-attack)}.char-class-dot.speed{background:var(--hex-speed)}.char-class-dot.defense{background:var(--hex-defense)}.char-class-dot.control{background:var(--hex-control)}.char-class-dot.support{background:var(--hex-support)}.char-name,.char-body h3,.char-card h3{font-family:var(--font-display);font-weight:900;font-style:italic;font-size:22px;letter-spacing:0;line-height:1.05;text-transform:uppercase;color:#fff;text-shadow:-1.5px -1.5px 0 var(--shadow-ink),1.5px -1.5px 0 var(--shadow-ink),-1.5px 1.5px 0 var(--shadow-ink),1.5px 1.5px 0 var(--shadow-ink),var(--elev-2)}.char-desc{font-size:13px;color:var(--fg-dim);line-height:1.5;flex:1}.btn-3d{position:relative;z-index:9999;pointer-events:auto!important;margin-top:12px;padding:10px 16px;background:var(--accent);color:#1a0530;border:2px solid var(--shadow-ink);box-shadow:var(--elev-3);border-radius:var(--r-sm);font-family:var(--font-display);font-weight:900;font-size:14px;text-transform:uppercase;cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-fast)}.btn-3d:hover{transform:translateY(-2px);box-shadow:var(--elev-4),0 0 15px #00ffea66}.btn-3d:active{transform:translateY(2px);box-shadow:var(--elev-1)}@media (max-width: 600px){.characters-grid,.chars-grid{grid-template-columns:repeat(2,1fr);gap:12px}.char-body{padding:12px 10px 14px}.char-name{font-size:16px}.char-desc{font-size:11px}}.char-card.clickable{cursor:pointer}.char-detail-backdrop{position:fixed;inset:0;z-index:1000;background:#08021aeb;backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:center;padding:40px;opacity:0;pointer-events:none;transition:opacity .35s ease}.char-detail-backdrop.active{opacity:1;pointer-events:auto}.char-detail-backdrop .char-modal-content{position:relative;width:95vw;max-width:1180px;max-height:90vh;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(255,40,180,.16) 0%,transparent 55%),radial-gradient(ellipse 70% 60% at 50% 100%,rgba(0,255,234,.14) 0%,transparent 55%),linear-gradient(180deg,#1a0d38fa,#0a0219fc);border:3px solid var(--shadow-ink);border-radius:var(--card-radius);box-shadow:0 0 0 1px #ff28b433 inset,0 25px 70px #000000e6,0 0 55px #00ffea2e;overflow:hidden;display:flex;flex-direction:column;padding:44px;transform:translateY(24px) scale(.94);opacity:0}.char-detail-backdrop.active .char-modal-content{animation:charModalPop .5s cubic-bezier(.16,1,.3,1) forwards}@keyframes charModalPop{to{transform:translateY(0) scale(1);opacity:1}}.char-detail-backdrop .char-modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--magenta),var(--accent),var(--magenta),transparent);background-size:200% 100%;animation:charEdgeFlow 5s linear infinite;opacity:.9}@keyframes charEdgeFlow{to{background-position:200% 0}}.char-detail-backdrop .char-modal-content:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,.022) 0 1px,transparent 1px 4px);pointer-events:none;border-radius:var(--card-radius);z-index:1}.char-modal-body{display:grid;grid-template-columns:340px 1fr;gap:44px;position:relative;z-index:2;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:4px}.char-modal-body::-webkit-scrollbar{width:8px}.char-modal-body::-webkit-scrollbar-track{background:transparent}.char-modal-body::-webkit-scrollbar-thumb{background:#00ffea40;border-radius:var(--r-pill)}.char-modal-body::-webkit-scrollbar-thumb:hover{background:#00ffea66}.char-modal-left{display:flex;flex-direction:column;align-items:center;gap:20px}.char-modal-img-container{position:relative;width:100%;aspect-ratio:4/5;background:radial-gradient(ellipse 80% 60% at 50% 95%,rgba(255,160,40,.35) 0%,transparent 70%),linear-gradient(180deg,var(--accent-hot) 0%,#5b1bb5 50%,#1f0a40 100%);border:3px solid var(--shadow-ink);border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--elev-4),0 14px 30px #00000080,0 0 0 1px #00ffea26 inset}.char-modal-img-container:before{content:"";position:absolute;inset:-40%;background:conic-gradient(from 0deg,transparent 0deg,rgba(0,255,234,.35) 60deg,transparent 140deg,rgba(255,40,180,.35) 220deg,transparent 320deg);animation:charPortraitSpin 9s linear infinite;z-index:0;opacity:.7}@keyframes charPortraitSpin{to{transform:rotate(360deg)}}.char-modal-img-container:after{content:"";position:absolute;inset:3px;border-radius:var(--r-lg);background:linear-gradient(180deg,#14082e00 40%,#0a02198c);box-shadow:0 0 60px #08021ae6 inset;z-index:1;pointer-events:none}.char-modal-img-container img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;object-position:center top;filter:drop-shadow(0 6px 18px rgba(0,0,0,.45));transition:transform .5s ease}.char-modal-img-container:hover img{transform:scale(1.04)}.char-modal-img-container .hud-corner{position:absolute;width:26px;height:26px;border:2px solid var(--accent);z-index:3;pointer-events:none;opacity:.85;filter:drop-shadow(0 0 5px rgba(0,255,234,.6))}.char-modal-img-container .hud-corner.tl{top:12px;left:12px;border-right:0;border-bottom:0;border-top-left-radius:6px}.char-modal-img-container .hud-corner.tr{top:12px;right:12px;border-left:0;border-bottom:0;border-top-right-radius:6px}.char-modal-img-container .hud-corner.bl{bottom:12px;left:12px;border-right:0;border-top:0;border-bottom-left-radius:6px}.char-modal-img-container .hud-corner.br{bottom:12px;right:12px;border-left:0;border-top:0;border-bottom-right-radius:6px}.char-modal-3d-wrap{position:absolute;inset:0;width:100%;height:100%;background:#0c0420d9;display:none;z-index:4}.char-modal-3d-wrap.active{display:block}.char-modal-left .btn-3d{width:100%;margin-top:0}#charModal3DBtn{display:none}.char-modal-right{display:flex;flex-direction:column}.char-modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:3px solid var(--shadow-ink);padding-bottom:18px;padding-right:40px;flex-wrap:wrap;gap:16px;position:relative}.char-modal-header h2{font-family:var(--font-display);font-weight:900;font-style:italic;font-size:42px;line-height:1;text-transform:uppercase;color:#fff;text-shadow:-2px -2px 0 var(--shadow-ink),2px -2px 0 var(--shadow-ink),-2px 2px 0 var(--shadow-ink),2px 2px 0 var(--shadow-ink),var(--elev-3),0 0 24px rgba(255,40,180,.45)}.char-modal-role{display:inline-flex;align-items:center;gap:9px;padding:9px 18px;border-radius:var(--r-pill);background:#ffffff0d;border:2px solid var(--shadow-ink);box-shadow:var(--elev-2),0 0 18px #00ffea1f inset;font-family:var(--font-mono);font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}.char-modal-role .char-class-dot{width:11px;height:11px;box-shadow:0 0 10px currentColor}.char-modal-role .char-class-dot.attack{box-shadow:0 0 10px var(--hex-attack)}.char-modal-role .char-class-dot.speed{box-shadow:0 0 10px var(--hex-speed)}.char-modal-role .char-class-dot.defense{box-shadow:0 0 10px var(--hex-defense)}.char-modal-role .char-class-dot.control{box-shadow:0 0 10px var(--hex-control)}.char-modal-role .char-class-dot.support{box-shadow:0 0 10px var(--hex-support)}.char-modal-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;margin-top:26px}.char-modal-desc-col,.char-modal-stats-col{display:flex;flex-direction:column}.char-modal-desc-text{font-size:14.5px;color:var(--fg-dim);line-height:1.65;margin-bottom:20px;padding:16px 18px;border-radius:var(--r-lg);background:#ffffff08;border-left:3px solid var(--magenta)}.char-modal-subheading{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:13px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--accent);padding-bottom:8px;margin:26px 0 14px;border-bottom:2px solid rgba(0,255,234,.18);text-shadow:0 0 10px rgba(0,255,234,.4)}.char-modal-subheading:before{content:"";width:4px;height:16px;border-radius:2px;background:linear-gradient(180deg,var(--accent),var(--magenta));box-shadow:0 0 8px #00ffea99}.char-modal-desc-col .char-modal-subheading:first-of-type,.char-modal-stats-col .char-modal-subheading:first-of-type{margin-top:0}.char-modal-abilities-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;counter-reset:ability}.char-modal-ability-item{position:relative;background:linear-gradient(180deg,#ffffff0d,#ffffff05);border:1px solid rgba(255,255,255,.06);border-left:4px solid var(--accent);padding:14px 16px 14px 52px;border-radius:0 12px 12px 0;box-shadow:inset 0 0 18px #0003;transition:transform var(--t-snappy) ease,box-shadow var(--t-snappy) ease,border-color var(--t-snappy) ease}.char-modal-ability-item:before{counter-increment:ability;content:counter(ability);position:absolute;left:12px;top:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);background:linear-gradient(180deg,var(--accent),#00c8b3);color:var(--cta-fg);font-family:var(--font-display);font-weight:900;font-size:14px;box-shadow:0 2px #00000059,0 0 12px #00ffea66}.char-modal-ability-item:hover{transform:translate(5px);border-left-color:var(--magenta);box-shadow:inset 0 0 18px #0003,-4px 0 18px #ff28b438}.char-modal-ability-item .ability-name{font-family:var(--font-display);font-weight:700;font-size:13.5px;color:#fff;letter-spacing:.4px}.char-modal-ability-item .ability-desc{font-size:12px;color:var(--fg-dim);line-height:1.55;margin-top:6px}.char-modal-tactics-box{background:#00000047;border:2px solid var(--shadow-ink);border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column;gap:16px;box-shadow:0 0 24px #00000040 inset}.tactics-section{display:flex;flex-direction:column;gap:8px}.tactics-title{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--fg-dim)}.tactics-list{list-style:none;display:flex;flex-direction:column;gap:7px;padding-left:0}.tactics-list li{font-size:13px;line-height:1.45;position:relative;padding-left:26px}.tactics-list li:before{position:absolute;left:0;top:50%;transform:translateY(-50%);width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:11px;font-weight:700}.strengths-list li:before{content:"\2713";color:var(--hex-control);background:#6be24a1f;box-shadow:0 0 8px #6be24a4d}.weaknesses-list li:before{content:"\2715";color:var(--hex-attack);background:#ff4d6d1f;box-shadow:0 0 8px #ff4d6d4d}.tactics-guide-text{font-size:13px;color:var(--fg-dim);line-height:1.55;padding:12px 14px;border-radius:var(--r-md);background:#00ffea0d;border-left:3px solid var(--accent)}.char-modal-stats-list{display:flex;flex-direction:column;gap:16px;background:#00000047;border:2px solid var(--shadow-ink);border-radius:var(--r-lg);padding:18px 20px;box-shadow:0 0 24px #00000040 inset}.char-modal-stat-row{display:flex;flex-direction:column;gap:7px}.char-modal-stat-top{display:flex;justify-content:space-between;align-items:baseline}.char-modal-stat-label{font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--fg-dim)}.char-modal-stat-value{font-family:var(--font-mono);font-weight:800;font-size:15px;color:#fff;text-shadow:0 0 6px rgba(0,255,234,.25)}.char-modal-stat-bar{height:8px;border-radius:var(--r-pill);background:#ffffff12;overflow:hidden;box-shadow:0 1px 2px #0006 inset}.char-modal-stat-fill{display:block;height:100%;width:var(--w, 0%);border-radius:inherit;transform-origin:left center;animation:statGrow .95s cubic-bezier(.2,.8,.2,1) both}.char-modal-stat-fill.hp{background:linear-gradient(90deg,var(--hex-attack),#ff9a3d);box-shadow:0 0 10px #ff4d6d80}.char-modal-stat-fill.speed{background:linear-gradient(90deg,var(--hex-speed),var(--accent));box-shadow:0 0 10px #29c7ff80}.char-modal-stat-fill.collision{background:linear-gradient(90deg,var(--hex-support),var(--magenta));box-shadow:0 0 10px #b070ff80}@keyframes statGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.char-modal-chart-wrap{width:100%;max-width:250px;aspect-ratio:1/1;margin:12px auto 0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,rgba(0,255,234,.08) 0%,transparent 70%),#0000002e;border:2px solid var(--shadow-ink);border-radius:var(--r-lg);padding:12px;box-shadow:0 0 24px #00ffea1a inset}.char-modal-chart-wrap svg{width:100%;height:100%;overflow:visible}.char-modal-close{position:absolute;top:22px;right:22px;width:44px;height:44px;background:#ffffff0d;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-md);color:#fff;font-size:26px;font-weight:300;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all var(--t-base) cubic-bezier(.4,0,.2,1);padding:0;line-height:1}.char-modal-close:hover{background:#ff28b499;border-color:#ff28b4;transform:scale(1.1) rotate(90deg);box-shadow:0 0 20px #ff28b473}@media (max-width: 900px){.char-detail-backdrop{padding:16px}.char-detail-backdrop .char-modal-content{padding:24px;max-height:95vh}.char-modal-body{grid-template-columns:1fr;gap:24px}.char-modal-left{max-width:300px;margin:0 auto}.char-modal-grid{grid-template-columns:1fr;gap:24px}.char-modal-header h2{font-size:32px}.char-modal-close{top:12px;right:12px;width:36px;height:36px;font-size:20px}}
