@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-gradient: linear-gradient(135deg, #0f2027, #203a43, #2c5364);--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .37);--primary-color: #ff4b2b;--primary-hover: #ff416c;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--input-bg: rgba(0, 0, 0, .2);--input-focus: rgba(255, 255, 255, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-image:var(--bg-gradient);background-size:400% 400%;animation:gradientBG 15s ease infinite;color:var(--text-primary);min-height:100vh;display:flex;flex-direction:column}@keyframes gradientBG{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem}.glass-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:24px;box-shadow:var(--glass-shadow);padding:3rem;width:100%;max-width:420px;transform:translateY(0);transition:transform .3s ease,box-shadow .3s ease}.glass-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px #00000073}.auth-header{text-align:center;margin-bottom:2.5rem}.auth-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(to right,#ff416c,#ff4b2b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.auth-subtitle{color:var(--text-secondary);font-size:.95rem}.form-group{margin-bottom:1.5rem;position:relative}.form-label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.5rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.custom-input{width:100%;padding:1rem 1.2rem;background:var(--input-bg);border:1px solid transparent;border-radius:12px;color:var(--text-primary);font-size:1rem;outline:none;transition:all .3s ease}.custom-input:focus{background:var(--input-focus);border-color:var(--primary-color);box-shadow:0 0 0 4px #ff4b2b1a}.primary-btn{width:100%;padding:1rem;margin-top:1rem;background:linear-gradient(to right,#ff416c,#ff4b2b);border:none;border-radius:12px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ff4b2b66}.primary-btn:active{transform:translateY(1px)}.secondary-btn{width:100%;padding:1rem;margin-top:1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:var(--text-primary);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.secondary-btn:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 8px 20px #0003}.secondary-btn:active{transform:translateY(1px)}.toggle-mode{text-align:center;margin-top:1.5rem;color:var(--text-secondary);font-size:.9rem}.toggle-mode button{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:600;margin-left:.5rem;font-size:.9rem;transition:color .3s ease}.toggle-mode button:hover{color:#fff;text-decoration:underline}.error-msg{color:#ff416c;font-size:.85rem;margin-top:.5rem;text-align:center;background:#ff416c1a;padding:.5rem;border-radius:8px}.dex-overlay{position:absolute;top:0;left:0;width:100%;height:100%;padding:2rem;display:flex;justify-content:center;align-items:center;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dex-container{width:100%;max-width:1200px;height:90vh;display:flex;flex-direction:column;padding:2rem;overflow:hidden}.dex-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}.dex-filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.dex-filter-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);color:var(--text-secondary);padding:.5rem 1.5rem;border-radius:20px;cursor:pointer;font-weight:500;transition:all .3s ease}.dex-filter-btn:hover{background:#ffffff26;color:#fff}.dex-filter-btn.active{background:#fff3;color:#fff;border-color:#fff;box-shadow:0 0 10px #ffffff1a}.dex-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.2rem;padding-right:1rem;padding-bottom:2rem}.dex-grid::-webkit-scrollbar{width:8px}.dex-grid::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}.dex-grid::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.dex-card{background:#0009;border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;position:relative;height:max-content}.dex-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000080;border-color:#ffffff4d}.dex-card.unavailable{filter:grayscale(80%) opacity(.7)}.dex-card-image{width:100%;height:190px;background-size:contain;background-position:center top;position:relative;background-repeat:no-repeat;border-bottom:1px solid rgba(255,255,255,.1);background-color:#111}.dex-faction-badge{position:absolute;top:10px;left:10px;padding:4px 12px;border-radius:12px;font-weight:800;font-size:.9rem;color:#fff;box-shadow:0 2px 10px #00000080;text-shadow:0 1px 2px rgba(0,0,0,.8)}.dex-hp-badge{position:absolute;top:10px;right:10px;background:#000000b3;padding:4px 10px;border-radius:8px;font-weight:700;color:#2ecc71;border:1px solid rgba(46,204,113,.3)}.dex-card-content{padding:.8rem;flex:1;display:flex;flex-direction:column}.dex-card-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.dex-card-title h3{margin:0;font-size:1.1rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.dex-status{font-size:.75rem;padding:2px 8px;border-radius:10px;font-weight:600}.dex-status.available{background:#2ecc7126;color:#2ecc71;border:1px solid rgba(46,204,113,.3)}.dex-status.pending{background:#f39c1226;color:#f39c12;border:1px solid rgba(243,156,18,.3)}.dex-skills-container{display:flex;flex-direction:column;gap:.6rem}.dex-skill{background:#ffffff08;padding:.6rem;border-radius:8px;border-left:3px solid var(--primary-color)}.dex-skill-name{font-weight:700;color:var(--primary-color);font-size:.9rem;margin-bottom:.3rem;display:block}.dex-skill-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.4;margin:0}.lobby-container{min-height:100vh;padding:2rem;max-width:1400px;margin:0 auto}.lobby-content{display:grid;grid-template-columns:2fr 1fr;gap:2rem;height:calc(100vh - 4rem)}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;overflow-y:auto;padding-right:.5rem}.room-card{background:var(--input-bg);border:1px solid var(--glass-border);border-radius:12px;padding:1.2rem;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}.room-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0003;border-color:#fff3}.room-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem;padding-bottom:.8rem;border-bottom:1px solid rgba(255,255,255,.05)}.room-header h4{font-size:1.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:1rem}.room-status{font-size:.75rem;padding:.2rem .6rem;border-radius:100px;background:#2ecc7133;color:#2ecc71;white-space:nowrap}.room-details{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1rem;flex:1}.join-btn{background:#ffffff1a;border:1px solid var(--glass-border);color:#fff;padding:.6rem;border-radius:8px;cursor:pointer;transition:all .2s;font-weight:500}.join-btn:hover{background:var(--primary-color);border-color:var(--primary-color)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.game-container{width:100vw;height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden;background:radial-gradient(circle at center,#2c3e50,#000)}.phase-overlay{position:absolute;inset:0;pointer-events:none;background:transparent;transition:background .5s ease;z-index:1}.phase-overlay.my-turn{background:radial-gradient(circle at center,rgba(46,204,113,.05),transparent 70%)}.layout-top{height:25vh;display:flex;justify-content:space-around;align-items:center;padding:1rem;z-index:2}.player-avatar{background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:12px;width:140px;height:180px;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;padding:.5rem;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 15px #0000004d;position:relative;background-size:cover;background-position:center top}.player-avatar:hover{transform:translateY(-10px) scale(1.05);border-color:var(--primary-color)}.player-avatar.targeted{border-color:#e74c3c;box-shadow:0 0 20px #e74c3c99;transform:scale(1.1)}.player-avatar.flipped{filter:grayscale(100%) sepia(50%) brightness(.7);transform:rotateY(180deg)}.player-avatar.flipped>*{transform:rotateY(180deg)}.flipped-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(0);background:#000c;color:#f1c40f;padding:5px 15px;border-radius:20px;font-weight:700;font-size:1.2rem;border:2px solid #f1c40f;z-index:30;pointer-events:none;box-shadow:0 0 15px #f1c40f80;white-space:nowrap}.player-info-badge{background:#000000b3;width:100%;padding:2px 4px;border-radius:6px;text-align:center;margin-top:auto}.player-role{font-size:.8rem;padding:2px 8px;border-radius:4px;background:#ffffff1a}.player-hp{color:#e74c3c;letter-spacing:2px;font-size:1.1rem}.player-name{font-size:.9rem;font-weight:600;text-align:center;overflow:hidden;text-overflow:ellipsis;max-width:100%}.game-over-modal p{font-size:1.2rem;color:#bdc3c7;margin:10px 0 20px}.active-turn{position:relative;box-shadow:0 0 15px 5px #f1c40f66;border-color:#f1c40f!important;animation:activeBreathing 2s ease-in-out infinite alternate;z-index:10}@keyframes activeBreathing{0%{box-shadow:0 0 10px 2px #f1c40f4d,inset 0 0 10px #f1c40f33}to{box-shadow:0 0 25px 8px #f1c40fcc,inset 0 0 20px #f1c40f80;border-color:#f39c12!important}}.turn-indicator{position:absolute;bottom:-25px;background:#2ecc71;color:#fff;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:700;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #2ecc71b3}70%{box-shadow:0 0 0 10px #2ecc7100}to{box-shadow:0 0 #2ecc7100}}.layout-middle{height:50vh;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:2;pointer-events:none;position:relative}.game-status h3{font-size:2rem;color:#ffffffe6;text-shadow:0 2px 10px rgba(0,0,0,.5);margin-bottom:.5rem}.settlement-stack{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.stack-event{background:#0009;padding:.5rem 1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.1rem;animation:slideIn .3s ease-out forwards}.hero-name-highlight{color:#f1c40f;font-weight:700}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.layout-bottom{height:25vh;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);display:flex;padding:.5rem 1rem;z-index:10;transition:box-shadow .3s ease}.layout-bottom.active-dash{box-shadow:0 -10px 30px #2ecc7133;border-top:1px solid rgba(46,204,113,.5)}.my-left-avatar{width:180px;border-right:1px solid var(--glass-border);padding-right:1rem;position:relative;display:flex;flex-direction:column;align-items:center}.my-avatar-img{width:100%;height:180px;border-radius:12px;border:2px solid var(--glass-border);background-size:cover;background-position:center top;margin-top:auto;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .6s cubic-bezier(.4,0,.2,1)}.my-avatar-img.flipped{filter:grayscale(100%) sepia(50%) brightness(.7);transform:rotateY(180deg)}.my-avatar-img.flipped>*{transform:rotateY(180deg)}.my-judgement-area{position:absolute;top:-30px;left:0;right:0;display:flex;justify-content:center;gap:4px}.player-avatar .my-judgement-area{top:5px;z-index:10}.judgement-badge{background:#9b59b6;color:#fff;padding:2px 6px;font-size:.7rem;border-radius:4px;border:1px solid rgba(255,255,255,.3)}.my-center-equip{flex:0 0 200px;border-right:1px solid var(--glass-border);padding:0 1rem;display:flex;flex-direction:column;justify-content:center;gap:.5rem}.equip-slot{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:4px;font-size:.8rem;color:var(--text-secondary);min-height:30px;display:flex;align-items:center}.equip-slot.filled{background:#ffffffe6;border:1px solid #bdc3c7;color:#2c3e50;justify-content:flex-start}.equip-slot.filled.suit-red .equip-suit-rank{color:#e74c3c}.equip-slot.filled.suit-black .equip-suit-rank{color:#2c3e50}.skill-btn{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;padding:4px 12px;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s;font-weight:700}.skill-btn:hover{background:#fff3;border-color:#f1c40f;color:#f1c40f}.has-tooltip{position:relative}.has-tooltip:hover:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:10px 14px;border-radius:8px;font-size:.9rem;white-space:pre-wrap;width:max-content;max-width:280px;z-index:1000;pointer-events:none;box-shadow:0 4px 15px #00000080;border:1px solid rgba(255,255,255,.2);line-height:1.5;text-align:left;font-weight:400;font-family:system-ui,-apple-system,sans-serif;letter-spacing:.5px}.has-tooltip:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#000000e6;margin-bottom:0;z-index:1000;pointer-events:none}.has-tooltip:not([data-tooltip]):hover:after,.has-tooltip[data-tooltip=""]:hover:after,.has-tooltip:not([data-tooltip]):hover:before,.has-tooltip[data-tooltip=""]:hover:before{display:none}.my-action-bar{display:flex;flex-direction:column;justify-content:center;gap:1rem;border-right:1px solid var(--glass-border);padding:0 1rem;width:140px;position:relative}.response-prompt{position:absolute;bottom:calc(100% + 20px);left:50%;transform:translate(-50%);width:max-content;min-width:220px;z-index:100;box-shadow:0 8px 30px #000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-width:2px!important}.game-btn{padding:.8rem;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:all .2s}.play-btn{background:#e74c3c;color:#fff}.play-btn:hover:not(:disabled){background:#c0392b;transform:scale(1.05)}.play-btn:disabled{background:#7f8c8d;cursor:not-allowed;opacity:.5}.end-btn{background:#f39c12;color:#fff}.end-btn:hover{background:#d35400;transform:scale(1.05)}.my-hand{flex:1;display:flex;align-items:flex-end;gap:-10px;padding-bottom:1rem;overflow:visible}.game-card{width:120px;height:168px;background:#ecf0f1;border-radius:12px;border:1px solid #bdc3c7;display:flex;flex-direction:column;padding:.5rem;cursor:pointer;position:relative;transition:all .2s;box-shadow:-2px 0 10px #0000004d;margin-left:-30px}.game-card:first-child{margin-left:0}.game-card:hover{transform:translateY(-20px) scale(1.05);box-shadow:0 10px 20px #00000080;z-index:20}.game-card.selected{transform:translateY(-30px);border:3px solid #f1c40f;box-shadow:0 0 20px #f1c40fcc;z-index:21}.card-top{display:flex;flex-direction:column;font-size:1.2rem;font-weight:700}.suit-red{color:#e74c3c}.suit-black{color:#2c3e50}.card-name{flex:1;display:flex;justify-content:center;align-items:center;font-size:1.8rem;font-weight:900;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:2px}.card-type{font-size:.75rem;text-align:center;border-top:1px solid #bdc3c7;padding-top:4px}.hero-selection-overlay{position:absolute;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;display:flex;justify-content:center;align-items:center}.selection-modal{padding:3rem;max-width:800px;width:90%;text-align:center;background:#1e2832e6;border:2px solid var(--primary-color);box-shadow:0 0 40px #000c,0 0 20px #f1c40f33}.selection-modal h2{color:#fff;font-size:2rem;margin-bottom:2rem;text-shadow:0 2px 5px rgba(0,0,0,.5)}.hero-options-grid{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.hero-option-card{width:140px;height:196px;background:#2c3e50;border:3px solid #7f8c8d;border-radius:12px;cursor:pointer;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 5px 15px #00000080}.hero-option-card:hover{transform:translateY(-10px) scale(1.1);border-color:#f1c40f;box-shadow:0 15px 30px #f1c40f4d}.hero-option-card img{width:100%;height:100%;object-fit:cover}.hero-option-name{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:#fff;padding:.5rem;font-weight:700;font-size:1.1rem;text-align:center}
