:root{margin:0;padding:0}body{margin:0;padding:0}*{outline:none!important;-webkit-tap-highlight-color:transparent!important}*:focus,*:active,*:focus-visible{outline:none!important;box-shadow:none!important}:root{--primary: #e98f11;--primary-dark: #7e5503;--bg-dark: #1A1A1A;--bg-panel: #222222;--text-main: #FFFFFF;--text-accent: #ffb347;--text-sub: #888888;--shadow-sm: 0 4px 0px rgba(0, 0, 0, .1);--shadow-md: 0 8px 0px rgba(0, 0, 0, .2);--shadow-lg: 0 12px 0px rgba(0, 0, 0, .3)}#root{text-align:center;width:100%;height:100vh}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-dark);color:var(--text-main);-webkit-font-smoothing:antialiased}.app-header{background:#000;padding:1.2rem 3rem;border-bottom:3px solid var(--primary);display:flex;align-items:center;justify-content:space-between;z-index:100;height:80px;box-sizing:border-box;color:var(--primary)}.header-left,.header-right{flex:1;display:flex;align-items:center}.header-right{justify-content:flex-end;gap:1rem}.header-center{flex:2;text-align:center}.header-center h1{margin:0;font-size:1.6rem;font-weight:900;letter-spacing:2px;text-transform:uppercase}.header-stats-item{background:#ffffff0d;padding:0 16px;height:36px;display:flex;align-items:center;border-radius:4px;font-weight:900;font-size:.9rem;border:1px solid var(--primary);color:var(--primary);white-space:nowrap}.header-user-name{font-weight:900;font-size:1.1rem;color:#fff;text-transform:uppercase}.back-button{padding:.6rem 1.2rem;background:transparent;border:1px solid var(--primary);border-radius:4px;cursor:pointer;font-weight:800;color:var(--primary);transition:all .2s;display:flex;align-items:center;gap:.5rem}.back-button:hover{background:var(--primary);color:#000}.title-page{background:var(--bg-dark);color:var(--primary);display:flex;justify-content:center;align-items:center;height:100vh}.game-title{font-size:6rem;font-weight:900;color:var(--primary);text-transform:uppercase;text-shadow:5px 5px 0px rgba(0,0,0,1)}.game-logo{width:90vw;max-width:1000px;height:auto;margin-bottom:3rem;filter:drop-shadow(15px 15px 0px rgba(0,0,0,1))}.username-input{padding:1rem 1.5rem;font-size:1.2rem;border-radius:4px;border:2px solid var(--primary);background:#ffffff0d;color:#fff;width:300px;margin-bottom:2rem}.start-button{padding:1.2rem 4rem;font-size:1.5rem;font-weight:900;background:var(--primary);color:#000;border:none;border-radius:4px;box-shadow:6px 6px #000;cursor:pointer}.home-page{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:radial-gradient(circle at center,#222 0%,var(--bg-dark) 70%)}.home-main-container{width:fit-content;margin:0 auto;height:100%;display:flex;flex-direction:column;padding-bottom:4rem;box-sizing:border-box}.home-title-container{padding-top:4rem;display:flex;flex-direction:column;align-items:center;z-index:10;width:100%}.home-title-sub-info{margin-top:.5rem;display:flex;flex-direction:column;align-items:flex-start;width:100%}.home-user-info{display:flex;justify-content:flex-start;width:100%;padding:0;margin-bottom:0;color:var(--primary);font-weight:900;font-size:2.2rem;text-transform:uppercase;letter-spacing:4px;text-shadow:4px 4px 0px rgba(0,0,0,.5)}.home-stats-summary{display:flex;gap:1.5rem;margin-bottom:1.5rem}.stat-item{background:var(--primary);color:#000;padding:.4rem 1.2rem;border-radius:2px;font-weight:900;font-size:.9rem;letter-spacing:1px;box-shadow:4px 4px #00000080}.home-large-title{font-size:12vw;font-weight:900;color:var(--primary);margin:0;text-transform:uppercase;letter-spacing:-.2vw;line-height:1;text-shadow:.8vw .8vw 0px rgba(0,0,0,.5);white-space:nowrap;width:100%;text-align:center}.home-logo{width:60vw;max-width:600px;height:auto;filter:drop-shadow(8px 8px 0px rgba(0,0,0,.5));margin-bottom:1rem}.home-menu{flex:1;margin-top:2rem;width:100%;display:grid;grid-template-columns:1.8fr 1fr;gap:4rem;align-items:stretch;padding:0;min-height:0}.home-menu-left{display:flex;flex-direction:column;align-items:flex-start;width:100%;justify-content:flex-end}.home-menu-cards-row{display:flex;flex-direction:row;gap:2rem;width:100%}.home-menu-right{display:flex;align-items:stretch;width:100%}.menu-card{border-radius:4px;border:3px solid var(--primary);background:var(--bg-dark);cursor:pointer;display:flex;justify-content:center;align-items:center;box-shadow:10px 10px 0 var(--primary-dark);transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.menu-card.landscape{flex:1;height:200px;flex-direction:row;padding:0 30px;gap:1.2rem;justify-content:flex-start}.menu-card.square{width:100%;height:auto;min-height:500px;flex-direction:column;padding:40px;justify-content:center}.menu-card.square .menu-icon{font-size:8rem;margin-bottom:1rem}.menu-card.square .menu-label{font-size:5rem;margin:1.5rem 0;line-height:1.1;letter-spacing:4px;text-transform:uppercase;font-weight:950;font-style:italic;position:relative;z-index:1;width:100%;display:flex;justify-content:center;align-items:center;transition:all .3s ease}.menu-card.square .menu-label:after{content:"";position:absolute;inset:-10px -40px;background:transparent;z-index:-1;transition:all .3s ease;border-top:4px solid var(--primary);border-bottom:4px solid var(--primary)}.menu-card.square .menu-label:before{display:none}.menu-card.square:hover .menu-label{color:#000}.menu-card.square:hover .menu-label:after{background:var(--primary)}.menu-card:hover{transform:scale(1.05);box-shadow:15px 15px 0 var(--primary-dark)!important;z-index:10}.menu-card.landscape:hover,.menu-card.square:hover{transform:scale(1.05)}.menu-text{text-align:left}.menu-icon{font-size:5rem}.landscape .menu-icon{font-size:4rem}.menu-label{font-size:2.5rem;font-weight:900;margin:0;color:var(--primary);text-transform:uppercase;white-space:nowrap}.menu-desc{color:var(--primary);font-weight:700;opacity:.7;margin:4px 0 0}.storage-page{height:100vh;display:flex;flex-direction:column}.storage-tabs-container{padding:1.5rem 3rem 0;display:flex}.storage-tabs-container .tab-buttons{display:flex;align-items:flex-end;gap:4px;padding-left:1rem}.storage-tabs-container .tab-button{height:44px;padding:0 32px;border-radius:10px 10px 0 0;border:1px solid var(--primary);border-bottom:none;background:#000;color:var(--text-sub);cursor:pointer;font-weight:800;transition:all .2s;margin-bottom:-1px}.storage-tabs-container .tab-button.active{height:52px;background:var(--bg-panel);color:var(--primary);border:2px solid var(--primary);border-bottom:none;z-index:2}.storage-content{flex:1;padding:3rem;overflow-y:auto;background-color:var(--bg-panel);border-radius:10px;margin:0 3rem 2rem;border:2px solid var(--primary)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.5rem}.card-grid.mini{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1.5rem;padding:10px;align-items:flex-start}.game-card-wrapper.mini .storage-card{padding:10px;height:180px}.game-card-wrapper.mini .card-image-placeholder{height:60px;font-size:.7rem}.game-card-wrapper.mini .card-info{margin-top:6px}.game-card-wrapper.mini .card-name{font-size:.8rem}.game-card-wrapper.mini .card-stats{display:flex;font-size:.7rem;margin-top:5px;flex-direction:column;align-items:flex-start;gap:2px}.game-card-wrapper.mini .card-level{font-size:.65rem;padding:1px 4px}.storage-card-wrapper{position:relative;width:100%;cursor:pointer;perspective:1000px}.storage-card{background:#000;border:2px solid var(--primary);border-radius:8px;padding:20px;box-shadow:5px 5px #00000080;transition:box-shadow .2s;color:#fff;position:relative;overflow:hidden}.storage-card:hover{box-shadow:0 10px 30px #00000080,8px 8px 0 var(--rarity-color)!important}.card-glare{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%,rgba(0,0,0,.1) 100%);pointer-events:none;border-radius:inherit;z-index:5;mix-blend-mode:soft-light}.ssr-card{box-shadow:0 0 20px #f369ce4d,5px 5px #00000080}.ssr-hologram{position:absolute;inset:0;z-index:3;pointer-events:none;background-image:linear-gradient(110deg,transparent 40%,rgba(255,255,255,.1) 45%,rgba(100,200,255,.15) 50%,rgba(255,100,255,.15) 55%,rgba(255,255,255,.1) 60%,transparent 65%);background-size:250% 250%;mix-blend-mode:overlay;filter:brightness(1.1) contrast(1.1)}.collection-card.ssr-card{box-shadow:0 0 20px #f369ce4d,5px 5px #00000080}.collection-card.ssr-card:after{content:"";position:absolute;inset:-1px;background:linear-gradient(45deg,#f369ce,#004ef5,#11c9c3,#f369ce);z-index:-1;border-radius:inherit;opacity:.3;filter:blur(6px);animation:border-glow 6s linear infinite}@keyframes border-glow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.card-info{margin-top:12px;text-align:left}.card-name{font-weight:900;color:var(--primary);text-transform:uppercase}.card-level{background:var(--primary);color:#000;padding:2px 8px;font-weight:900;display:inline-block;font-size:.8rem;margin-top:4px}.card-stats{margin-top:10px;display:flex;justify-content:space-between;font-size:.85rem;color:#888;font-weight:700}.card-image-container{width:100%;aspect-ratio:3/4;background:#ffffff0d;border:1px solid rgba(233,143,17,.2);display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.card-icon{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.storage-card:hover .card-icon{transform:scale(1.1)}.card-image-placeholder{width:100%;height:100%;display:flex;justify-content:center;align-items:center;color:var(--primary);font-weight:900;text-transform:uppercase}.battle-select-page,.battle-prepare-page{height:100vh;display:flex;flex-direction:column;background-color:var(--bg-dark)}.battle-select-content{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem}.battle-type-container{display:flex;gap:3rem;width:100%;max-width:1000px;justify-content:center}.battle-type-card{flex:1;max-width:400px;background:#000;border:3px solid var(--primary);border-radius:4px;padding:4rem 2rem;cursor:pointer;transition:all .3s;box-shadow:10px 10px #e98f1133}.battle-type-card:hover{transform:translate(-4px,-4px);box-shadow:15px 15px 0 var(--primary)}.battle-type-icon{font-size:5rem;margin-bottom:2rem}.battle-type-title{font-size:2.2rem;font-weight:900;color:var(--primary);margin-bottom:1rem;text-transform:uppercase}.battle-type-desc{color:#fff;opacity:.8;font-weight:600;line-height:1.6}.battle-prepare-content{flex:1;display:flex;padding:2rem;gap:2rem;overflow:hidden}.selection-section{flex:1;background:#000;border:2px solid var(--primary);border-radius:4px;padding:2rem;display:flex;flex-direction:column;box-shadow:8px 8px #00000080;overflow:hidden}.selection-list{flex:1;overflow-y:auto;padding-top:30px;padding-right:1rem}.step-indicator{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem}.step-indicator span{font-weight:700;color:#fff;opacity:.4;padding:.5rem 1rem;cursor:pointer;transition:all .2s}.step-indicator span.active{color:var(--primary);opacity:1;font-weight:900;border-bottom:3px solid var(--primary)}.preview-section{width:500px;display:flex;flex-direction:column;gap:2rem}.vs-container{background:#000;border:3px solid var(--primary);border-radius:4px;padding:2rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem;box-shadow:10px 10px #00000080;min-height:600px;justify-content:flex-start}.player-side,.opponent-side{width:100%;display:flex;flex-direction:column;align-items:center}.preview-card-holder{width:160px;display:flex;flex-direction:column;align-items:center;gap:.5rem}.preview-card-placeholder{width:160px;height:220px;border:2px dashed rgba(233,143,17,.3);display:flex;justify-content:center;align-items:center;color:#ffffff80;font-size:.8rem;font-weight:700;text-align:center;padding:20px}.vs-badge{font-size:2.5rem;font-weight:900;color:var(--primary);font-style:italic;text-shadow:4px 4px 0px #000;margin:.5rem 0}.player-side h3,.opponent-side h3{color:#fff;font-weight:900;text-transform:uppercase;margin-bottom:.5rem;font-size:.9rem}.preview-card{background:#111;border:2px solid var(--primary);border-radius:4px;padding:1.5rem;color:#fff;text-align:center}.preview-chara-name{font-size:1.3rem;font-weight:900;color:var(--primary);margin-bottom:.4rem}.preview-equip-name{font-size:.95rem;color:#888;font-weight:700;margin-bottom:.8rem}.preview-stats-total{display:flex;flex-direction:row;justify-content:space-between;gap:1rem;border-top:1px solid rgba(255,255,255,.1);padding-top:1.2rem;font-size:.85rem;font-weight:800;color:var(--primary);text-align:center;width:100%}.preview-stats-total p{margin:0;white-space:nowrap}.battle-start-button{width:100%;padding:1.5rem;font-size:1.8rem;font-weight:900;border-radius:4px;border:none;background:var(--primary);color:#000;cursor:pointer;box-shadow:8px 8px #000;transition:all .2s;text-transform:uppercase}.battle-start-button:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:10px 10px #000}.battle-start-button:disabled{background:#333;color:#666;cursor:not-allowed;box-shadow:none}.battle-page{background-color:var(--bg-dark)}.battle-arena{flex:1;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:0 2rem 180px;position:relative}.battle-side{width:100%;display:flex;justify-content:center;position:relative}.battle-side.opponent{padding-top:2rem}.battle-side.player{padding-bottom:2rem}.battle-ui{position:fixed;bottom:0;left:0;right:0;background-color:#000;padding:1.5rem 2.5rem;border-top:3px solid var(--primary);z-index:100}.hand-selector{display:flex;justify-content:center;gap:2rem}.chara-plate{background:#000;border:2px solid var(--primary);padding:1rem 1.5rem;width:280px;box-shadow:6px 6px #00000080;position:absolute;z-index:10}.battle-card-stats{display:flex;flex-direction:column;align-items:flex-start;padding-left:10px;gap:2px;margin-top:5px;font-size:.75rem;font-weight:800;color:var(--primary);line-height:1.1;width:100%;box-sizing:border-box}.battle-card-stats.mini{font-size:.65rem;margin-top:2px;padding-left:5px}.battle-side.opponent .chara-plate{top:2rem;left:2rem}.battle-side.player .chara-plate{bottom:2rem;right:2rem}.hp-bar-container{height:12px;background:#111;border:1px solid var(--primary);margin-top:10px}.hp-bar{background:var(--primary);height:100%;transition:width .5s ease;box-shadow:0 0 10px #e98f1180}.hp-text{color:var(--primary);font-weight:900;text-align:right;font-size:.8rem}.battle-center{flex:1;display:flex;justify-content:center;align-items:center;min-height:120px}.battle-cards-container{display:flex;justify-content:center;gap:1.5rem;z-index:5;width:100%}.battle-side.opponent .battle-cards-container{align-items:flex-start}.battle-side.player .battle-cards-container{align-items:flex-end}.battle-card{background:#000;border:3px solid var(--primary);border-radius:4px;padding:10px;display:flex;flex-direction:column;align-items:center;box-shadow:8px 8px #00000080;position:relative;transition:transform .2s;height:fit-content}.battle-card.chara{width:140px;z-index:2}.battle-card.equip{width:90px;z-index:1;margin-bottom:-10px}.battle-card-image{width:100%;aspect-ratio:3/4;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);display:flex;justify-content:center;align-items:center;font-size:.9rem;font-weight:900;color:var(--primary);margin-bottom:8px}.battle-card-image.mini{font-size:.7rem}.battle-card-name{font-size:.8rem;font-weight:900;color:#fff;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:center}.battle-card-name.mini{font-size:.65rem;color:var(--primary)}.battle-card.attacking{animation:attack-anim .5s ease-in-out}.battle-side.player .battle-card.attacking{animation:attack-anim-player .5s ease-in-out}@keyframes attack-anim{0%{transform:translate(0)}50%{transform:translate(60px) rotate(5deg)}to{transform:translate(0)}}@keyframes attack-anim-player{0%{transform:translate(0)}50%{transform:translate(-60px) rotate(-5deg)}to{transform:translate(0)}}.hand-button{background:#000;border:3px solid var(--primary);color:#fff;width:130px;height:150px;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;box-shadow:6px 6px #000;transition:all .2s}.hand-button:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--primary);border-color:var(--primary)}.hand-button.special{background:var(--primary);color:#000;border-color:#000}.special-badge{background:#000;color:var(--primary);padding:2px 8px;font-weight:900;font-size:.7rem}.hand-display{display:flex;align-items:center;gap:3rem;background:#000;padding:1.5rem 3rem;border-radius:4px;box-shadow:10px 10px #e98f1133;border:2px solid var(--primary)}.hand{font-size:4rem}.vs-text{font-size:2.5rem;font-weight:900;color:var(--primary);font-style:italic;text-shadow:4px 4px 0px #000;transition:opacity .25s}.vs-text--waiting{opacity:.2}.hand.player-hand{animation:hand-rise .35s cubic-bezier(.34,1.56,.64,1) both}@keyframes hand-rise{0%{transform:translateY(70px) scale(.4);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.hand.opponent-hand{animation:hand-drop .35s cubic-bezier(.34,1.56,.64,1) both}@keyframes hand-drop{0%{transform:translateY(-70px) scale(.4);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.hand.hand-unknown{animation:hand-wait-pulse .9s ease-in-out infinite}@keyframes hand-wait-pulse{0%,to{transform:scale(.85);opacity:.25}50%{transform:scale(1.1);opacity:.5}}.choose-hand-text{font-size:2.5rem;font-weight:900;color:var(--primary);text-transform:uppercase;letter-spacing:2px;font-style:italic;background:#000;padding:1rem 3rem;border-radius:4px;border:2px solid var(--primary);box-shadow:10px 10px #e98f1133}.finish-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:8rem;font-weight:950;text-transform:uppercase;font-style:italic;z-index:2000;pointer-events:none;white-space:nowrap;letter-spacing:-5px;animation:finish-pop .5s cubic-bezier(.175,.885,.32,1.275) both}.finish-text.victory{color:#fc0;text-shadow:8px 8px 0 #004ef5,-4px -4px 0 #fff,0 0 50px rgba(255,204,0,.5)}.finish-text.lose{color:#f44;text-shadow:8px 8px 0 #4b0082,-4px -4px 0 #000,0 0 50px rgba(255,68,68,.5)}@keyframes finish-pop{0%{transform:translate(-50%,-50%) scale(0) rotate(-20deg);opacity:0}to{transform:translate(-50%,-50%) scale(1) rotate(-10deg);opacity:1}}.damage-popup{position:absolute;top:-60px;left:50%;transform:translate(-50%);font-size:4.5rem;font-weight:950;font-style:italic;text-shadow:4px 4px 0 #000,-2px -2px 0 #000,2px -2px 0 #000,-2px 2px 0 #000,0px 0px 20px rgba(0,0,0,.5);z-index:1000;pointer-events:none;white-space:nowrap;animation:damage-float .8s ease-out forwards}.damage-popup.player{color:#f44}.damage-popup.opponent{color:#fc0}@keyframes damage-float{0%{transform:translate(-50%) translateY(20px) scale(.5);opacity:0}20%{transform:translate(-50%) translateY(-10px) scale(1.3);opacity:1}to{transform:translate(-50%) translateY(-50px) scale(1);opacity:0}}.modal-overlay{position:fixed;inset:0;background:#0000004d;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.strengthen-modal{background:var(--bg-dark);border:3px solid var(--primary);padding:3rem;max-width:650px;width:90%;position:relative;box-shadow:0 0 30px #e98f111a,15px 15px #000;color:#fff}.strengthen-modal h2{color:var(--primary);font-size:2rem;font-weight:900;text-transform:uppercase;margin-top:0;margin-bottom:2rem;text-align:center;letter-spacing:4px}.modal-card-info{display:flex;gap:2.5rem;align-items:center;background:#ffffff08;padding:2rem;border:1px solid rgba(233,143,17,.1);margin-bottom:2rem}.modal-card-visual{width:180px;flex-shrink:0}.modal-card-details{flex:1;text-align:left}.modal-card-details h3{font-size:1.8rem;margin:0 0 1rem;color:#fff;font-weight:900;text-transform:uppercase}.modal-level{font-size:1.2rem;font-weight:800;color:var(--primary);margin-bottom:1.5rem}.modal-stats{display:flex;flex-direction:column;gap:.8rem}.modal-stats p{margin:0;font-size:1.1rem;font-weight:700;display:flex;justify-content:space-between}.modal-stats span.arrow{color:var(--primary);margin:0 1rem}.modal-actions{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.upgrade-cost{font-size:1.2rem;font-weight:800;color:#fff;margin:0}.upgrade-button{width:100%;padding:1.2rem;background:var(--primary);color:#000;font-size:1.5rem;font-weight:900;border:none;cursor:pointer;box-shadow:6px 6px #000;transition:all .2s;text-transform:uppercase}.upgrade-button:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:8px 8px #000}.upgrade-button:disabled{background:#333;color:#666;cursor:not-allowed;box-shadow:none}.close-button{background:transparent;border:1px solid white;color:#fff;padding:.8rem 2rem;font-weight:700;cursor:pointer;opacity:.5;transition:opacity .2s}.close-button:hover{opacity:1}.battle-result-page.win{background-color:var(--bg-dark)}.result-container{background:#000;border:4px solid var(--primary);padding:3rem 4rem;box-shadow:15px 15px #00000080;max-width:500px;width:90%;margin:0 auto}.result-title{color:var(--primary);font-size:5rem;font-weight:900;text-transform:uppercase;text-shadow:6px 6px 0px rgba(0,0,0,1);margin-bottom:2rem}.rewards-section{margin-bottom:3rem;text-align:center}.rewards-section h2{color:#fff;font-size:1.2rem;font-weight:800;text-transform:uppercase;letter-spacing:2px;margin-bottom:2rem}.reward-item{background:#ffffff0d;border:1px solid rgba(233,143,17,.2);margin-bottom:.8rem;padding:.8rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.reward-label{color:#fff;font-weight:800}.reward-value{color:var(--primary);font-weight:900;font-size:1.4rem}.home-button{background:var(--primary);color:#000;padding:1.2rem 4rem;font-weight:900;cursor:pointer}.gacha-page{height:100vh;display:flex;flex-direction:column}.gacha-content{flex:1;padding:1.5rem 3rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;overflow:hidden}.gacha-banner{width:100%;max-width:800px;height:60vh;display:flex;align-items:center;justify-content:center;color:var(--primary);position:relative;overflow:visible}.gacha-banner-bg-text{position:absolute;font-size:18rem;font-weight:950;color:var(--primary-dark);white-space:nowrap;z-index:0;-webkit-user-select:none;user-select:none;font-style:italic;letter-spacing:-.7rem;opacity:.6;pointer-events:none}.gacha-banner-image{width:100%;height:100%;object-fit:contain;border-radius:4px;position:relative;z-index:1}.gacha-actions{margin-top:auto;padding-bottom:2rem}.gacha-button-container{display:flex;gap:2rem}.gacha-button{width:240px;height:120px;border-radius:4px;border:none;font-weight:900;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;justify-content:center;align-items:center}.gacha-button.single{background:transparent;color:var(--primary);border:3px solid var(--primary)}.gacha-button.multi{background:var(--primary);color:#000;box-shadow:6px 6px #000}.gacha-button:hover{transform:translate(-4px,-4px);box-shadow:10px 10px 0 var(--primary)}.gacha-button.multi:hover{box-shadow:10px 10px #000}.gacha-count{font-size:1.4rem}.gacha-cost{font-size:.9rem;opacity:.8}.gacha-effect-page{height:100vh;background-color:#000;display:flex;justify-content:center;align-items:center;color:var(--primary);overflow:hidden;position:relative}.gacha-bg-flash{position:absolute;inset:0;background:#fff;z-index:100;pointer-events:none}.crystal-container{position:relative;width:200px;height:200px;display:flex;justify-content:center;align-items:center}.crystal{width:100px;height:100px;background:var(--primary);clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);margin:0;animation:rotate 3s infinite linear;box-shadow:0 0 50px var(--primary);z-index:5;position:relative}.crystal.ssr{background:linear-gradient(45deg,red,#ffeb00,#0f0,#0ff,#00f,#f0f,red);background-size:400% 400%;animation:rotate 3s infinite linear,rainbow-bg 3s linear infinite;box-shadow:0 0 80px #fffc}@keyframes rainbow-bg{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.energy-ring{position:absolute;width:150px;height:150px;border:4px solid var(--primary);border-radius:50%;animation:ring-pulse 2s ease-out infinite}.energy-ring.ssr{border-color:#fff;box-shadow:0 0 30px #0ff}@keyframes ring-pulse{0%{transform:scale(.5);opacity:1}to{transform:scale(2.5);opacity:0}}.particle{position:absolute;width:4px;height:4px;background:var(--primary);border-radius:50%;pointer-events:none}.particle.ssr{background:#fff;box-shadow:0 0 10px #fff}.effect-text{position:absolute;bottom:20%;font-size:2rem;font-weight:900;letter-spacing:8px;text-transform:uppercase;color:#fff;text-shadow:0 0 20px var(--primary)}@keyframes rotate{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}.gacha-result-page{height:100vh;background-color:var(--bg-dark);display:flex;flex-direction:column;align-items:center;padding:2rem;box-sizing:border-box}.gacha-result-header h1{font-size:3rem;font-weight:900;color:var(--primary);text-transform:uppercase;margin-bottom:2rem}.gacha-result-content{flex:1;width:100%;max-width:1000px;overflow-y:auto;padding:1rem;margin-bottom:2rem}.gacha-result-content::-webkit-scrollbar{width:8px}.gacha-result-content::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px}.result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:2rem;justify-items:center}.result-actions{display:flex;gap:2rem;padding-bottom:1rem;justify-content:center;width:100%;margin-top:1.5rem}.result-grid .storage-card{width:160px;padding:12px}.back-to-home,.back-to-gacha{padding:1.2rem 3rem;border-radius:4px;border:none;font-weight:900;cursor:pointer;transition:all .2s;text-transform:uppercase}.back-to-home{background:transparent;color:#fff;border:2px solid white}.back-to-gacha{background:var(--primary);color:#000;box-shadow:6px 6px #000}.matching-page{display:flex;flex-direction:column;min-height:100vh}.matching-arena{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:3rem;padding:2rem;position:relative;overflow:hidden}.matching-arena:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(233,143,17,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(233,143,17,.06) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.matching-scanline{position:absolute;top:-10%;left:0;right:0;height:40%;background:linear-gradient(to bottom,transparent,rgba(233,143,17,.04) 50%,transparent);animation:scan-down 3s linear infinite;pointer-events:none;z-index:0}@keyframes scan-down{0%{top:-40%}to{top:110%}}.matching-vs-container{display:flex;align-items:center;justify-content:center;gap:2.5rem;width:100%;max-width:560px;z-index:1}.matching-side-label{font-size:.7rem;font-weight:900;letter-spacing:.25em;color:var(--primary);text-transform:uppercase;margin-bottom:.75rem}.matching-player-side,.matching-opponent-side{flex:1;display:flex;flex-direction:column;align-items:center}.matching-card-player{width:110px;height:150px;border:3px solid var(--primary);border-radius:4px;background:#000;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #e98f1159,6px 6px #000;animation:player-card-glow 2s ease-in-out infinite}@keyframes player-card-glow{0%,to{box-shadow:0 0 15px #e98f114d,6px 6px #000}50%{box-shadow:0 0 35px #e98f11bf,6px 6px #000}}.matching-card-unknown{width:110px;height:150px;border:3px solid #3a3a3a;border-radius:4px;background:#111;display:flex;align-items:center;justify-content:center;animation:unknown-flicker 2s ease-in-out infinite}@keyframes unknown-flicker{0%,to{border-color:#2a2a2a;background:#0d0d0d}40%{border-color:#555;background:#181818}60%{border-color:#3a3a3a;background:#111}}.unknown-question{font-size:3rem;font-weight:900;color:#3a3a3a;animation:question-pulse 2s ease-in-out infinite;line-height:1}@keyframes question-pulse{0%,to{color:#2a2a2a}50%{color:#555}}.matching-chara-name{margin-top:.6rem;font-size:.75rem;font-weight:900;color:var(--primary);text-transform:uppercase;letter-spacing:.05em;text-align:center;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.matching-chara-name--unknown{color:#444}.matching-center{display:flex;align-items:center;justify-content:center;width:80px;flex-shrink:0}.matching-radar{position:relative;width:70px;height:70px;display:flex;align-items:center;justify-content:center}.radar-ring{position:absolute;border-radius:50%;border:2px solid var(--primary);animation:radar-expand 2.4s ease-out infinite}.radar-ring.ring-1{animation-delay:0s}.radar-ring.ring-2{animation-delay:.8s}.radar-ring.ring-3{animation-delay:1.6s}@keyframes radar-expand{0%{width:16px;height:16px;opacity:.9}to{width:120px;height:120px;opacity:0}}.matching-vs-text{font-size:1.4rem;font-weight:900;color:var(--primary);text-shadow:0 0 16px var(--primary),0 0 32px rgba(233,143,17,.5);letter-spacing:.1em;z-index:1;animation:vs-glow 1.5s ease-in-out infinite}@keyframes vs-glow{0%,to{text-shadow:0 0 12px var(--primary)}50%{text-shadow:0 0 24px var(--primary),0 0 48px rgba(233,143,17,.6)}}.matching-status{display:flex;flex-direction:column;align-items:center;gap:1rem;z-index:1}.matching-status-text{font-size:1.4rem;font-weight:900;color:var(--primary);letter-spacing:.4em;text-transform:uppercase}.matching-dots{display:flex;gap:.6rem}.matching-dots span{width:9px;height:9px;border-radius:50%;background:var(--primary);animation:dot-bounce 1.4s ease-in-out infinite}.matching-dots span:nth-child(2){animation-delay:.2s}.matching-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{opacity:.2;transform:scale(.7) translateY(0)}40%{opacity:1;transform:scale(1.2) translateY(-4px)}}@media(max-width:768px){.app-header{height:auto;flex-direction:column;padding:1rem}.header-stats-item{width:100%;justify-content:center;margin-top:.5rem}.game-title{font-size:3rem}.home-menu{flex-direction:column;padding:1rem}.menu-card{width:100%;height:auto;flex-direction:row;padding:20px;box-shadow:4px 4px #000}.storage-content{margin:0 1rem 1rem;padding:1rem}.vs-container{flex-direction:column}.battle-side.player .chara-plate{bottom:160px;right:1rem;width:240px;padding:1rem}.gacha-content{padding:1.5rem;gap:2rem}.gacha-banner{height:200px;padding:1.5rem}.gacha-banner h2{font-size:2rem}.gacha-button-container{flex-direction:column;width:100%}.gacha-button{width:100%;height:80px}.gacha-result-header h1{font-size:2.5rem}}
