*{box-sizing:border-box}body{color:#f5f0dd;background:#151923;margin:0;font-family:Arial,Helvetica,sans-serif}button,input,select,textarea{font:inherit;border:0;border-radius:10px;padding:10px}button{color:#211800;cursor:pointer;background:#e9b949;font-weight:700}button:disabled{opacity:.45;cursor:not-allowed}input,select,textarea{color:#fff;background:#272e3d;border:1px solid #3b465c}textarea{min-height:90px}header{background:#0d111a;border-bottom:1px solid #30384b;justify-content:space-between;align-items:center;padding:18px 28px;display:flex}h1{color:#e9b949;margin:0}nav a{color:#fff;margin-left:18px;text-decoration:none}.panel{background:#202737;border-radius:18px;max-width:900px;margin:30px auto;padding:24px;overflow:visible;box-shadow:0 8px 30px #0005}.join,.grid{grid-template-columns:1fr 1fr;gap:12px;margin:12px 0;display:grid}.arena{grid-template-columns:1fr 300px;gap:18px;padding:20px;display:grid;overflow:visible}.player{background:#202737;border-radius:18px;padding:18px;overflow:visible}.enemy{background:#2a2034}.center{background:#111722;border-radius:14px;grid-column:1/2;justify-content:center;align-items:center;gap:14px;padding:12px;display:flex}.board,.hand{flex-wrap:wrap;gap:16px;min-height:120px;display:flex;overflow:visible}.log{background:#0d111a;border-radius:18px;max-height:80vh;padding:16px;overflow:auto}.log p{border-bottom:1px solid #30384b;padding-bottom:8px}.winner{color:#211800;text-align:center;background:#e9b949;border-radius:16px;grid-column:1/3;padding:18px;font-size:28px;font-weight:900}.admin{grid-template-columns:420px 1fr;gap:20px;padding:20px;display:grid;overflow:visible}.admin .panel{margin:0}.cardsList,.card-grid{flex-wrap:wrap;align-content:flex-start;gap:20px;display:flex;overflow:visible}.row{background:#202737;border-radius:16px;flex-direction:column;gap:8px;padding:12px;display:flex;overflow:visible}.admin-card-item{background:0 0;border-radius:0;flex-direction:column;align-items:center;padding:0;display:flex;overflow:visible}.admin-card-actions{flex-direction:column;gap:.5rem;width:250px;margin-top:.8rem;display:flex}.admin-card-actions button{width:100%}.pack-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.pack-card{text-align:center;border:2px solid #444;border-radius:12px;min-height:260px;padding:1rem;transition:all .4s;overflow:visible}.pack-card.revealed{transform:scale(1.03)}.card-back{justify-content:center;align-items:center;height:220px;font-size:4rem;display:flex}.card-slot{perspective:900px;flex:0 0 270px;justify-content:center;align-items:center;width:270px;height:410px;display:flex;overflow:visible}.card-slot.small{flex:0 0 170px;width:170px;height:260px}.card{color:#fff;cursor:pointer;background:#000;border:4px solid #7a4d11;border-radius:18px;width:250px;height:380px;min-height:380px;padding:0;display:block;position:relative;overflow:hidden;box-shadow:0 10px 25px #00000073}.card.small{border-width:3px;border-radius:14px;width:150px;height:235px;min-height:235px}.card-bg{object-fit:cover;pointer-events:none;z-index:1;width:100%;height:100%;display:block;position:absolute;inset:0}.card-bg-placeholder{z-index:1;background:#111;justify-content:center;align-items:center;font-size:5rem;display:flex;position:absolute;inset:0}.card-3d{transform-style:preserve-3d;will-change:transform;transition:transform .12s,box-shadow .12s}.card-3d:hover{z-index:10;box-shadow:0 22px 40px #00000080,0 0 24px #ffffff29}.card-shine{pointer-events:none;opacity:0;z-index:20;mix-blend-mode:screen;background:linear-gradient(115deg,#0000 35%,#ffffff0d 42%,#ffffff59 50%,#ffffff14 58%,#0000 65%);transition:opacity .15s,transform .12s;position:absolute;inset:-40%}.rarity-common{border-color:#9aa0a6}.rarity-uncommon{border-color:#3c6;box-shadow:0 10px 25px #00000073,0 0 12px #33cc6659}.rarity-rare{border-color:#39f;box-shadow:0 10px 25px #00000073,0 0 16px #3399ff73}.rarity-epic{border-color:#b347ff;box-shadow:0 10px 25px #00000073,0 0 20px #b347ff8c}.rarity-legendary{border-color:#f90;box-shadow:0 10px 25px #00000073,0 0 26px #ff9900a6}@media (width<=900px){.arena,.admin{grid-template-columns:1fr}.log,.winner{grid-column:auto}header{flex-direction:column;align-items:flex-start;gap:12px}nav a{margin-bottom:8px;margin-left:0;margin-right:12px;display:inline-block}}@media (hover:none){.card-3d{transform:none!important}.card-shine{display:none}}.form-field{flex-direction:column;gap:6px;min-width:0;display:flex}.form-field label{color:#e9b949;font-size:.85rem;font-weight:700}.form-field input,.form-field select,.form-field textarea{width:100%;min-width:0}.form-preview{grid-column:1/-1}.admin form .grid{grid-template-columns:1fr 1fr;align-items:start;gap:14px;display:grid}.admin form.panel{width:100%;max-width:none}.pack-reveal-panel{text-align:center}.pack-opening-scene{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:260px;display:flex}.pack-animation{justify-content:center;align-items:center;width:150px;height:150px;font-size:5rem;animation:.25s ease-in-out infinite alternate packShake;display:flex;position:relative}.pack-animation span{z-index:2;position:relative}.pack-glow{background:radial-gradient(circle,#ffd966e6,#ffd96626 45%,#0000 70%);border-radius:50%;animation:1s ease-in-out infinite alternate packPulse;position:absolute;inset:0}.reveal-grid{justify-content:center}.reveal-card{transition:transform .35s,opacity .35s}.reveal-card.revealed{animation:.6s revealCard}.tcg-card-back{color:#e9b949;background:radial-gradient(circle,#e9b94959,#0000 45%),linear-gradient(135deg,#111722,#202737,#111722);border:4px solid #e9b949;border-radius:18px;justify-content:center;align-items:center;width:250px;height:380px;font-size:5rem;display:flex;box-shadow:0 10px 25px #00000073}.foil:after{content:"";z-index:15;pointer-events:none;mix-blend-mode:screen;background:linear-gradient(120deg,#0000 20%,#ffffff47 45%,#78dcff29 50%,#ff78dc29 55%,#0000 80%);animation:2.5s linear infinite foilMove;position:absolute;inset:0}@keyframes packShake{0%{transform:rotate(-4deg)scale(1)}to{transform:rotate(4deg)scale(1.05)}}@keyframes packPulse{0%{opacity:.45;transform:scale(.9)}to{opacity:1;transform:scale(1.18)}}@keyframes revealCard{0%{opacity:0;transform:rotateY(180deg)scale(.7)}60%{opacity:1;transform:rotateY(0)scale(1.08)}to{opacity:1;transform:rotateY(0)scale(1)}}@keyframes foilMove{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (width<=600px){.admin form .grid{grid-template-columns:1fr}}.tcg-card-back{border-radius:18px;width:250px;height:380px;animation:1.5s infinite cardPulse;overflow:hidden;box-shadow:0 10px 25px #00000073}.tcg-card-back-image{object-fit:cover;width:100%;height:100%;display:block}@keyframes cardPulse{0%{transform:scale(1)}50%{transform:scale(1.04)}to{transform:scale(1)}}.reveal-card{position:relative}.reveal-card.rarity-rare:not(.revealed){animation:1.2s infinite alternate rareGlow}.reveal-card.rarity-epic:not(.revealed){animation:1s infinite alternate epicGlow}.reveal-card.rarity-legendary:not(.revealed){animation:.8s infinite alternate legendaryGlow}@keyframes rareGlow{0%{filter:drop-shadow(0 0 6px #39f)}to{filter:drop-shadow(0 0 18px #39f)}}@keyframes epicGlow{0%{filter:drop-shadow(0 0 8px #b347ff)}to{filter:drop-shadow(0 0 22px #b347ff)drop-shadow(0 0 35px #b347ff)}}@keyframes legendaryGlow{0%{filter:drop-shadow(0 0 10px #fc0)}to{filter:drop-shadow(0 0 25px #fc0)drop-shadow(0 0 45px #f90)drop-shadow(0 0 70px #f60)}}.twitch-login-btn{color:#fff;background:#9146ff;border-radius:12px;justify-content:center;align-items:center;padding:14px 24px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.twitch-login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #9146ff73}.duel-info{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;margin-bottom:12px;padding:12px}.duel-info p{margin:4px 0}.arena{grid-template-columns:minmax(0,1fr) 300px;grid-template-areas:"enemy log""center log""player log"}.player.enemy{grid-area:enemy}.center{grid-area:center}.player:not(.enemy){grid-area:player}.log{grid-area:log}.player:not(.enemy) h3{text-align:center;margin-top:1.2rem}.player:not(.enemy) .hand{justify-content:center;align-items:flex-end;padding-top:1rem}.player:not(.enemy) .board{justify-content:center;min-height:180px}.login-page{background:radial-gradient(circle at top,#9146ff59,#0000 35%),linear-gradient(#151923,#090b10);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{text-align:center;background:#202737eb;border:1px solid #ffffff1f;border-radius:24px;width:100%;max-width:430px;padding:36px;box-shadow:0 24px 80px #0000008c}.login-logo{margin-bottom:12px;font-size:64px}.login-card h1{margin-bottom:12px;font-size:36px}.login-subtitle,.login-footer{color:#c9d1e3;line-height:1.5}.login-subtitle{margin-bottom:28px}.login-footer{margin-top:20px;font-size:.85rem}.twitch-login-btn{color:#fff;background:#9146ff;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;padding:15px 22px;font-weight:800;text-decoration:none;display:inline-flex;box-shadow:0 12px 30px #9146ff59}.twitch-login-btn:hover{transform:translateY(-2px)}.floating-cards{pointer-events:none;position:fixed;inset:0;overflow:hidden}.floating-cards img{opacity:.08;filter:drop-shadow(0 0 10px #ffffff1a);width:120px;animation:8s ease-in-out infinite floatCard;position:absolute}.floating-cards img:first-child{top:10%;left:12%;transform:rotate(-15deg)}.floating-cards img:nth-child(2){animation-delay:1s;top:18%;right:14%;transform:rotate(12deg)}.floating-cards img:nth-child(3){animation-delay:2s;bottom:18%;left:18%;transform:rotate(-8deg)}.floating-cards img:nth-child(4){animation-delay:3s;bottom:12%;right:18%;transform:rotate(18deg)}.floating-cards img:nth-child(5){animation-delay:4s;top:45%;left:50%;transform:rotate(-20deg)}@keyframes floatCard{0%,to{translate:0}50%{translate:0 -25px}}.twitch-login-btn{animation:2.2s infinite twitchPulse}@keyframes twitchPulse{0%,to{box-shadow:0 12px 30px #9146ff59}50%{box-shadow:0 0 35px #9146ffd9}}.effect-editor{flex-direction:column;gap:16px;margin:16px 0;display:flex}.effect-action{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:14px;padding:14px}.effect-action h4{color:#e9b949;margin-top:0}.effect-preview{color:#a7ffba;background:#0d111a;border-radius:12px;padding:14px;font-size:.8rem;overflow:auto}.enemy-hand{justify-content:center;align-items:flex-end;gap:0;min-height:110px;margin:12px 0 20px;display:flex;overflow:visible}.enemy-card-back{object-fit:cover;transform-origin:bottom;border-radius:8px;width:70px;height:100px;margin-left:-24px;box-shadow:0 8px 18px #00000073}.enemy-card-back:first-child{margin-left:0}.enemy-card-back:first-child{transform:rotate(-14deg)}.enemy-card-back:nth-child(2){transform:rotate(-7deg)}.enemy-card-back:nth-child(3){transform:rotate(0)}.enemy-card-back:nth-child(4){transform:rotate(7deg)}.enemy-card-back:nth-child(5){transform:rotate(14deg)}.enemy-card-back:nth-child(n+6){transform:rotate(18deg)}.waiting-room{background:#9146ff1f;border:1px solid #9146ff59;border-radius:12px;margin-top:16px;padding:14px}
