:root{font-family:Outfit,Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;--bg-color: #0f0c29;--bg-gradient: linear-gradient(135deg, #0f0c29, #302b63, #24243e);--primary-color: #6a11cb;--secondary-color: #2575fc;--text-color: rgba(255, 255, 255, .9);--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);color:var(--text-color);background:var(--bg-gradient);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;width:100vw;overflow:hidden;background:var(--bg-gradient)}#root{width:100%;height:100vh;display:flex;flex-direction:column}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px;padding:2rem;color:#fff}.btn-primary{background:linear-gradient(45deg,var(--primary-color),var(--secondary-color));border:none;border-radius:8px;padding:12px 24px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 5px 15px #6a11cb66}.btn-secondary{background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px 24px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#ffffff1a;border-color:#fff6}input.input-field{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 16px;color:#fff;width:100%;box-sizing:border-box;font-size:1rem;transition:border-color .3s ease}input.input-field:focus{outline:none;border-color:var(--secondary-color);background:#0000004d}h1,h2,h3{margin:0 0 1rem;font-weight:700}.page-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;padding:20px;box-sizing:border-box;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card{width:90%;height:90%;border-radius:8px;overflow:hidden;box-shadow:-2px 0 5px #00000080;position:relative;transition:transform .2s,box-shadow .2s,opacity .2s;cursor:pointer;-webkit-user-select:none;user-select:none;background-color:#2a2a2a;border:2px solid #555;backface-visibility:hidden;-webkit-font-smoothing:subpixel-antialiased;will-change:transform;touch-action:manipulation}.card[draggable=true]{cursor:grab}.card[draggable=false],.card:not([draggable]){-webkit-user-drag:none;touch-action:pan-y}.card:hover{transform:translateY(-5px);box-shadow:0 8px 12px #00000080;z-index:10}.card[draggable=true]:active{opacity:.5;cursor:grabbing}.card-back{background-image:var(--card-bg, url(/assets/card_back-BBbXbrgz.jpg));background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center}.card-pattern{width:80%;height:80%}.card-front{display:flex;flex-direction:column;padding:0;color:#fff;background-color:#000}.type-creature{border-color:#d7ccc8;box-shadow:0 0 0 1px #3e2723 inset}.type-spell{border-color:#c5cae9;box-shadow:0 0 0 1px #1a237e inset}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:.6rem;font-weight:700}.card-cost{background-color:#0006;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.5rem}.card-image-container{width:100%;height:100%;overflow:hidden;position:relative;background-color:#000}.card-image{width:100%;height:100%;object-fit:cover;display:block}.card-image-placeholder{width:100%;height:100%;background-color:#0000004d}.card-body{font-size:.5rem;background-color:#ffffff1a;padding:2px;border-radius:2px;height:30%}.card-counter{position:absolute;width:24px;height:24px;border-radius:50%;display:flex;justify-content:center;align-items:center;font-weight:700;font-size:.9rem;color:#fff;box-shadow:0 2px 4px #0009;z-index:10;border:2px solid white}.counter-top-left{top:1px;left:1px}.counter-top-right{top:1px;right:1px}.counter-bottom-right{bottom:35px;right:1px}.power-counter{background-color:#d32f2f}.turn-counter{background-color:#1976d2}.turn-counter.negative{background-color:#f57f17}.increment-counter{background-color:#2e7d32}.increment-counter.negative{background-color:#7b1fa2}@keyframes fly-in-opponent{0%{opacity:0;transform:translateY(-300px) scale(.5)}60%{opacity:1;transform:translateY(20px) scale(1.05)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fly-in-player{0%{opacity:0;transform:translateY(300px) scale(1.5)}60%{opacity:1;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-fly-in-opponent{animation:fly-in-opponent .6s cubic-bezier(.22,.61,.36,1) forwards}@media(max-width:768px){.card-counter{font-size:.7rem;width:16px;height:16px}.counter-top-left{top:0;left:0}.counter-top-right{top:0;right:0}.counter-bottom-right{bottom:0;right:0}}.card-marks-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;pointer-events:none;display:flex;justify-content:center;align-items:center;z-index:2}.card-mark{width:50px;height:50px}.mark-image{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 2px black)}.card.has-marks{box-shadow:0 0 15px 4px #a855f7!important;border:2px solid #a855f7!important;z-index:5;animation:mark-pulse 2s infinite ease-in-out}@keyframes mark-pulse{0%{box-shadow:0 0 5px 2px #a855f7}50%{box-shadow:0 0 20px 6px #d8b4fe}to{box-shadow:0 0 5px 2px #a855f7}}.hand{display:flex;justify-content:center;align-items:center;height:140px;padding:0 20px;position:relative;transition:background-color .2s,box-shadow .2s;border-radius:12px}.hand-drag-over{background-color:#ffffff1a;box-shadow:0 0 20px #00bfff66;border:2px dashed rgba(0,191,255,.6)}.hand-player{margin-top:10px}.hand-opponent{margin-bottom:10px;transform:scale(.8)}.hand-card-wrapper{width:100px;height:140px;margin:0 -15px;transition:transform .3s ease-out,margin .3s}.hand-player .hand-card-wrapper:hover{transform:translateY(-20px) scale(1.1);z-index:100!important;margin:0 5px}.hand-opponent .hand-card-wrapper{transform:none}.will-play-face-down{position:relative}.will-play-face-down:before{content:"";position:absolute;inset:-2px 8px 8px -2px;border-radius:8px;border:2px dashed rgba(147,51,234,.9);pointer-events:none;z-index:100}@media(max-width:768px){.hand{height:100px;padding:0 10px}.hand-card-wrapper{width:70px;height:100px;margin:0 -10px}.hand-player .hand-card-wrapper:hover{transform:translateY(-10px) scale(1.1)}.hand-opponent{transform:scale(.7);margin-bottom:5px}}.stack-view-button{position:absolute;bottom:4px;left:4px;background:#00f2ffe6;border:2px solid #00f2ff;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:200;transition:all .2s ease;box-shadow:0 0 10px #00f2ff80;padding:0;pointer-events:auto;-webkit-user-select:none;user-select:none}.stack-view-button:hover{background:#00f2ff;transform:scale(1.15);box-shadow:0 0 20px #00f2ffcc}.stack-view-button:active{transform:scale(1.05)}.stack-view-icon{font-size:1.2rem;filter:drop-shadow(0 0 2px rgba(0,0,0,.5));pointer-events:none}.stack-viewer-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.stack-viewer-container{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #00f2ff;border-radius:16px;box-shadow:0 0 40px #00f2ff4d;max-width:90vw;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.stack-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid rgba(0,242,255,.3);gap:16px}.stack-viewer-header h3{margin:0;color:#00f2ff;font-size:1.5rem;font-weight:700;text-shadow:0 0 10px rgba(0,242,255,.5)}.stack-viewer-count{color:#fff;background:#00f2ff33;padding:4px 12px;border-radius:12px;font-size:.9rem;font-weight:600}.stack-viewer-close{background:#ff323233;border:1px solid #ff3232;color:#ff3232;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.stack-viewer-close:hover{background:#ff323266;transform:scale(1.1)}.stack-viewer-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:24px;overflow-y:auto;max-height:calc(85vh - 80px)}.stack-viewer-card-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;width:140px;margin:0 auto}.stack-viewer-card-wrapper .card{width:100%!important;height:auto!important;aspect-ratio:2.5 / 3.5;transform:none!important;position:relative!important;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;cursor:default}.stack-viewer-card-wrapper .card img,.stack-viewer-card-wrapper .card *{-webkit-user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}.stack-viewer-card-index{background:#00f2ff33;color:#00f2ff;padding:4px 12px;border-radius:8px;font-size:.85rem;font-weight:700;text-shadow:0 0 5px rgba(0,242,255,.5)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.stack-viewer-cards::-webkit-scrollbar{width:8px}.stack-viewer-cards::-webkit-scrollbar-track{background:#0000004d;border-radius:4px}.stack-viewer-cards::-webkit-scrollbar-thumb{background:#00f2ff4d;border-radius:4px}@media(max-width:768px){.stack-viewer-cards{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px}.stack-viewer-card-wrapper{width:100%;max-width:120px}.stack-viewer-container{width:95vw;height:90vh;max-height:90vh}}.card-zone{border:1px dashed #555;border-radius:6px;background-color:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;height:100%;width:auto;max-height:100%;aspect-ratio:2.5 / 3.5;transition:border-color .15s ease-in-out,background-color .15s ease-in-out,box-shadow .15s ease-in-out;overflow:visible;flex-shrink:0}.zone-drag-over{border-color:gold;background-color:#ffd70033;box-shadow:0 0 15px #ffd70080;z-index:10}.zone-content .card{position:absolute!important;inset:0!important;width:95%!important;height:95%!important;margin:0!important;transform:none!important;animation:dropIn .2s ease-out forwards}.zone-content .deck-pile .card{position:absolute!important;inset:auto!important;width:90%!important;height:90%!important;transform:none!important;animation:none!important}.zone-content .deck-pile .card:hover{transform:translateY(-2px)!important}@keyframes dropIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.card-zone:hover{background-color:#000000b3;border-color:#888}.zone-label{position:absolute;font-size:.7rem;color:#aaa;text-transform:uppercase;letter-spacing:1px;pointer-events:none;z-index:0;top:50%;left:50%;transform:translate(-50%,-50%);opacity:1}@media(max-width:768px){.zone-label{font-size:.55rem}}.zone-content{position:absolute;inset:0;z-index:1;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.zone-deck{border-style:solid;border-color:#4a90e2}.zone-exilio{border-color:#e24a4a}.zone-terreno{border-color:#4ae268}.zone-ether{border-color:#d44ae2;background-image:linear-gradient(#0000004d,#0000004d),url(/assets/ether_background-BXaQnM8s.png);background-size:cover;background-position:center}.face-down-indicator{position:absolute;inset:0;background:#280046d9;color:#d8b4fe;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.9rem;letter-spacing:1px;text-shadow:0 0 5px #000;pointer-events:none;z-index:100;border-radius:6px;border:2px dashed #a0f;animation:flash-border 1s infinite alternate;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);text-align:center}@keyframes flash-border{0%{border-color:#a0f;box-shadow:inset 0 0 10px #a0f}to{border-color:#f0f;box-shadow:inset 0 0 20px #f0f}}@media screen and (max-width:768px){.face-down-indicator{font-size:.6rem}}.player-area{display:flex;flex-direction:column;width:100%;height:100%;justify-content:space-between}.board-grid{display:flex;flex-direction:column;gap:10px;padding:0 40px;flex:1;justify-content:center;align-items:center}.board-row{display:flex;justify-content:center;gap:10px;width:100%;height:11vh;min-height:11vh;max-height:11vh;align-items:center}@keyframes attack-pulse{0%{box-shadow:0 0 10px 2px #f006;border-color:#ff5252}50%{box-shadow:0 0 25px 8px #ff0000b3;border-color:red}to{box-shadow:0 0 10px 2px #f006;border-color:#ff5252}}.card.tapped{transform:translateY(-5px)!important;animation:attack-pulse 2s infinite ease-in-out;z-index:20}.context-menu-container{position:fixed;z-index:9999}.context-menu{position:absolute;background:#1e1e1ef2;border:1px solid #555;box-shadow:0 4px 15px #000c;border-radius:6px;padding:4px;min-width:140px;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:10000}.context-menu-item{padding:8px 12px;cursor:pointer;color:#eee;font-size:.85rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none;position:relative;z-index:10001}.context-menu-item:hover{background:#fff3;color:#fff;transform:translate(2px)}.context-menu-overlay{position:fixed;inset:0;z-index:9998;background:transparent}.attack-line-svg{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:20000;filter:drop-shadow(0 0 8px #ff0000)}.attack-arrow{stroke:#ff5252;stroke-width:4;fill:none;opacity:.8;filter:drop-shadow(0 0 5px #ff0000);animation:fadeIn .2s ease-out}.arrow-head{fill:#ff5252;stroke:none;filter:drop-shadow(0 0 5px #ff0000);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:.8}}@keyframes block-pulse{0%{box-shadow:0 0 10px 2px #0064ff66;border-color:#4facfe}50%{box-shadow:0 0 25px 8px #0064ffb3;border-color:#00f2fe}to{box-shadow:0 0 10px 2px #0064ff66;border-color:#4facfe}}.card.blocking{animation:block-pulse 2s infinite ease-in-out;border-color:#4facfe!important;z-index:21}.block-arrow{stroke:#4facfe;stroke-width:4;fill:none;opacity:.8;filter:drop-shadow(0 0 5px #00f2fe);animation:fadeIn .2s ease-out}.arrow-head-block{fill:#4facfe;stroke:none;filter:drop-shadow(0 0 5px #00f2fe)}.deck-search-btn{position:absolute;top:-15px;right:-15px;width:30px;height:30px;border-radius:50%;background:#00f2ffcc;border:2px solid #fff;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;font-size:1.2rem}@media(max-width:768px){.board-grid{padding:0 10px;gap:5px}.board-row{height:8vh;min-height:8vh;max-height:8vh;gap:5px}.deck-count{top:1px;right:1px;left:auto}.deck-search-btn{inset:auto auto -5px -5px}}.mobile-card-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000d9;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .2s ease-out}.mobile-card-modal-content{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:90%;width:320px;position:relative}.enlarged-card-view{width:100%;position:relative;transform-style:preserve-3d;animation:scaleIn .3s cubic-bezier(.175,.885,.32,1.275)}.enlarged-card-view .card{width:100%;height:100%;-webkit-user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}.mobile-actions-container{display:flex;flex-direction:column;gap:10px;width:100%;background:#1e1e1ee6;padding:15px;border-radius:12px;border:1px solid #444;box-shadow:0 4px 20px #00000080}.mobile-action-btn{background:#2a2a2a;border:1px solid #555;color:#fff;padding:12px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s}.mobile-action-btn:active{transform:scale(.95);background:#3a3a3a}.mobile-action-btn.primary{background:#0d47a1;border-color:#1976d2}.mobile-action-btn.danger{border-color:#d32f2f;color:#ff5252}.close-modal-hint{position:absolute;top:20px;right:20px;color:#aaa;font-size:2rem;cursor:pointer;z-index:1}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.marks-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .2s ease-out}.marks-modal-content{background-color:#1e1e1e;border:1px solid #444;border-radius:8px;width:90%;max-width:400px;box-shadow:0 10px 25px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.marks-modal-header{padding:16px;background-color:#252525;border-bottom:1px solid #333;display:flex;justify-content:space-between;align-items:center;color:#fff}.marks-modal-header h3{margin:0;font-size:1.1rem}.close-btn{background:none;border:none;color:#aaa;font-size:1.5rem;cursor:pointer;padding:0 8px}.marks-grid{padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:16px;background-color:#1a1a1a}.mark-item-card{background-color:#2a2a2a;border:2px solid #444;border-radius:8px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .2s}.mark-item-card:hover{background-color:#333;transform:translateY(-2px)}.mark-item-card.active{border-color:#a855f7;background-color:#a855f71a}.mark-icon-wrapper{width:40px;height:40px;display:flex;justify-content:center;align-items:center}.mark-icon-wrapper img{width:100%;height:100%;object-fit:contain}.mark-label{color:#ddd;font-size:.9rem;font-weight:500}.mark-status-badge{font-size:.7rem;padding:4px 8px;border-radius:12px;text-transform:uppercase;font-weight:700}.mark-status-badge.add{background-color:#444;color:#aaa}.mark-status-badge.remove{background-color:#a855f7;color:#fff}.marks-modal-footer{padding:16px;border-top:1px solid #333;display:flex;justify-content:flex-end;background-color:#252525}.marks-done-btn{background-color:#a855f7;color:#fff;border:none;padding:8px 16px;border-radius:4px;font-weight:700;cursor:pointer}.marks-done-btn:hover{background-color:#9333ea}.history-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000}.history-modal{background-color:#1e1e1e;padding:20px;border-radius:8px;width:420px;max-height:80vh;overflow-y:auto;color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;border:1px solid #444}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid #333;padding-bottom:10px}.modal-header h3{margin:0;font-size:1.2rem;color:gold}.close-button{background:none;border:none;color:#999;font-size:1.2rem;cursor:pointer}.close-button:hover{color:#fff}.history-list{display:flex;flex-direction:column;gap:15px}.history-item{background-color:#2a2a2a;padding:15px;border-radius:6px;border:1px solid #333}.history-details{display:flex;flex-direction:column;gap:8px}.history-meta{font-size:.8rem;color:#888}.history-desc{font-size:.9rem;color:#ddd}.history-stats{display:flex;flex-direction:column;gap:6px;margin-top:4px}.stat-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.stat-pill{background-color:#333;padding:4px 10px;border-radius:4px;font-size:.8rem;color:#ccc;flex:1}.power-pill{border-left:3px solid #e74c3c}.turns-pill{border-left:3px solid #3498db}.restore-btn{color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:.85rem;min-height:32px;transition:background-color .2s,transform .1s;white-space:nowrap}.restore-btn:hover{transform:scale(1.03)}.restore-btn:active{transform:scale(.97)}.restore-power{background-color:#c0392b}.restore-power:hover{background-color:#e74c3c}.restore-turns{background-color:#2471a3}.restore-turns:hover{background-color:#3498db}.no-history{color:#888;text-align:center;font-style:italic;margin-top:20px}.opponent-area{display:flex;flex-direction:column;width:100%;height:100%;justify-content:space-between;position:relative;overflow:hidden}.opponent-background{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.9}.opponent-area .board-grid{display:flex;flex-direction:column;gap:10px;padding:0 40px;flex:1;justify-content:center;align-items:center;position:relative;z-index:1}.opponent-area .hand{position:relative;z-index:1}.board-row{display:flex;justify-content:center;gap:10px;flex:1;width:100%;max-height:20vh}.deck-pile{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center}.deck-pile .card{position:absolute;box-shadow:2px 2px #111,4px 4px #111}.deck-count{position:absolute;bottom:1px;right:1px;background-color:#333;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.6rem;border:1px solid #555;z-index:20}@media(max-width:768px){.opponent-area .board-grid{padding:0 10px;gap:5px}.board-row{gap:5px;height:8vh;min-height:8vh;max-height:8vh}.deck-count{top:1px;right:1px;left:auto}}.player-avatar{position:absolute;display:flex;align-items:center;gap:15px;z-index:50;background:#0a0a0ad9;padding:10px;border-radius:40px;border:1px solid rgba(255,255,255,.15);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:220px;box-shadow:0 4px 15px #00000080;pointer-events:auto}.player-avatar.opponent{top:20px;left:20px}.player-avatar.player{bottom:20px;left:20px}.avatar-frame{width:40px;height:40px;border-radius:50%;border:2px solid #00f2ff;overflow:hidden;flex-shrink:0;box-shadow:0 0 10px #00f2ff4d;background:#222;z-index:2}.player-avatar.opponent .avatar-frame{border-color:#ff5252;box-shadow:0 0 10px #ff52524d}.avatar-frame img{width:100%;height:100%;object-fit:cover}.avatar-info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px}.avatar-layout{display:flex;justify-content:space-between;align-items:center;width:90%;margin-bottom:5px}.avatar-left-col{display:flex;flex-direction:column;gap:4px}.avatar-name{color:#fff;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.hp-big-number{font-size:2.5rem;font-weight:900;color:#fff;line-height:1;text-shadow:0 2px 10px rgba(0,0,0,.5);font-family:Roboto,sans-serif}.hp-bar-container{width:90%;height:12px;background-color:#111;border-radius:6px;overflow:hidden;border:1px solid #444;position:relative;box-shadow:inset 0 2px 4px #000c}.hp-bar-fill{height:100%;width:100%;background:linear-gradient(90deg,#00c6ff,#0072ff);border-radius:6px;transition:width .3s ease-out;box-shadow:0 0 8px #00c6ff99;position:relative}.hp-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:#fff3;border-radius:6px 6px 0 0}.player-avatar.opponent .hp-bar-fill{background:linear-gradient(90deg,#ff512f,#dd2476);box-shadow:0 0 8px #dd247699}.avatar-hp-controls{display:flex;align-items:center;gap:8px}.hp-btn{background:#282828cc;border:1px solid #555;color:#fff;width:18px;height:18px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;transition:all .2s;padding:0;line-height:0}.hp-btn:hover{transform:scale(1.2);border-color:#fff}.hp-btn.plus:hover{background:#0f03;color:#0f0;border-color:#0f0}.hp-btn.minus:hover{background:#f003;color:red;border-color:red}@media(max-width:768px){.player-avatar{width:auto;min-width:140px;padding:8px 12px;border-radius:30px;gap:10px;transform:none;background:#0a0a0ae6;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 10px #0009}.player-avatar.player{bottom:10px;left:10px;z-index:60}.player-avatar.opponent{top:10px;left:10px;z-index:60}.avatar-name{display:block;font-size:.75rem;max-width:80px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-big-number{font-size:1.8rem}.avatar-frame{width:45px;height:45px;border-width:2px}.avatar-layout{width:100%;margin-bottom:2px}.avatar-info{gap:2px}.hp-btn{width:24px;height:24px;font-size:16px}}.avatar-nightmare-badge{position:absolute;width:30px;height:30px;background-color:#2d1b3e;border:2px solid #a855f7;color:#e9d5ff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;box-shadow:0 0 10px #a855f799;z-index:100;animation:pulse-badge 2s infinite ease-in-out;pointer-events:none}.avatar-nightmare-badge.top{top:-10px;left:15px}.avatar-nightmare-badge.bottom{bottom:-20px;left:15px}@keyframes pulse-badge{0%{transform:scale(1)}50%{transform:scale(1.15);box-shadow:0 0 15px #a855f7cc}to{transform:scale(1)}}.avatar-frame-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.avatar-frame-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:170%;height:170%;background-size:contain;background-repeat:no-repeat;background-position:center;z-index:10;pointer-events:none}.avatar-frame-wrapper .avatar-frame{position:relative;z-index:5}.game-log-sidebar{width:350px;height:100%;background-color:#151515;border-left:1px solid #333;display:flex;flex-direction:column;flex-shrink:0;box-shadow:-5px 0 15px #00000080;font-family:Inter,system-ui,sans-serif}.sidebar-header{padding:15px;border-bottom:1px solid #333;background-color:#1a1a1a}.sidebar-header h3{margin:0;font-size:1rem;text-transform:uppercase;letter-spacing:1px;color:#00f2ff}.sidebar-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:10px;display:flex;flex-direction:column;background-color:#151515}.unified-feed{display:flex;flex-direction:column;gap:8px}.feed-entry{display:flex;width:100%;box-sizing:border-box;animation:fadeIn .3s ease}.entry-log{padding:8px;background-color:#ffffff0d;border-radius:4px;border-left:3px solid #666;font-size:.8rem;color:#ccc;align-items:flex-start;gap:8px}.log-icon{font-family:Courier New,monospace;font-weight:700;opacity:.5}.log-details{display:flex;flex-direction:column}.log-time{font-size:.7rem;color:#666;margin-bottom:2px}.entry-chat{margin:5px 0}.entry-chat .chat-bubble{background-color:#222;padding:8px 12px;border-radius:2px 12px 12px;max-width:85%;word-wrap:break-word;border:1px solid #333;box-shadow:0 2px 4px #0003}.entry-chat.own-chat{justify-content:flex-end}.entry-chat.own-chat .chat-bubble{background-color:#0d47a1;border-color:#1565c0;border-radius:12px 2px 12px 12px;color:#fff}.chat-sender{display:block;font-size:.7rem;font-weight:700;margin-bottom:2px;color:#00f2ff}.entry-chat.own-chat .chat-sender{color:#82b1ff;text-align:right}.chat-text{font-size:.9rem;line-height:1.4}.chat-input-area{padding:15px;background-color:#1a1a1a;border-top:1px solid #333;display:flex;gap:8px}.chat-input-area input{flex:1;min-width:0;background-color:#0f0f0f;border:1px solid #333;color:#fff;padding:10px;border-radius:4px;outline:none;font-size:.9rem}.chat-input-area input:focus{border-color:#00f2ff}.chat-input-area button{background-color:#00f2ff;color:#000;border:none;padding:0 20px;border-radius:4px;cursor:pointer;font-weight:700;text-transform:uppercase;font-size:.8rem;transition:background-color .2s}.chat-input-area button:hover{background-color:#99faff}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.empty-state{color:#666;font-style:italic;padding:20px;text-align:center}@media(max-width:768px){.game-log-sidebar{position:fixed;top:0;right:0;bottom:70px;width:80%;max-width:none;z-index:2000;border-left:none;box-shadow:0 4px 10px #00000080;background-color:#151515fa;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.game-log-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0000004d;z-index:999}.chat-input-area{padding:10px;padding-bottom:max(10px,env(safe-area-inset-bottom));gap:5px}.chat-input-area button{padding:0 10px;font-size:.75rem}.game-log-overlay{width:100vw;height:100vh}}.phase-menu{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 10px;width:100px;flex-shrink:0;height:100%;gap:30px;isolation:isolate}.elfic-line{position:absolute;top:0;bottom:60px;left:50%;width:3px;background:linear-gradient(to bottom,transparent,#8b6c28 10%,#ffd700 50%,#8b6c28 90%,transparent);transform:translate(-50%);z-index:-10;box-shadow:0 0 8px gold,0 0 15px #00f2ff66;opacity:.8}.phase-menu.disabled{pointer-events:none;cursor:not-allowed;opacity:1;filter:none}.phase-menu.disabled .phase-item{filter:grayscale(1)}.phase-menu.disabled .phase-item.active{filter:grayscale(0);opacity:1;transform:scale(1.15)}.phase-menu.disabled .phase-item.active .phase-circle{border-color:#ff3232;box-shadow:0 0 25px #ff323299}.phase-menu.disabled .phase-item.active .phase-label{color:#ff3232;text-shadow:0 0 5px rgba(255,50,50,.5)}@media(max-width:768px){.phase-menu.disabled .phase-item.active{filter:grayscale(0);opacity:1;transform:scale(1)}}.phase-item{position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;z-index:2;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.phase-item:hover{transform:scale(1.15)}.phase-item.active{transform:scale(1.1);z-index:10}.phase-circle{width:70px;height:70px;border-radius:50%;position:relative;overflow:hidden;box-shadow:0 0 15px #000000e6,inset 0 0 10px #000c;border:2px solid #554422;background-color:#050505;transition:all .3s ease}.phase-item:hover .phase-circle{border-color:gold;box-shadow:0 0 20px #ffd70066}.phase-item.active .phase-circle{border-color:#00f2ff;box-shadow:0 0 25px #00f2ffcc,0 0 50px #00f2ff66;width:80px;height:80px}.phase-bg{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .5s ease;filter:grayscale(.5) brightness(.7)}.phase-item:hover .phase-bg{filter:grayscale(0) brightness(1);transform:scale(1.1)}.phase-item.active .phase-bg{filter:grayscale(0) brightness(1.2);transform:scale(1.1) rotate(0)}.phase-label{margin-top:8px;color:#aaa;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;text-shadow:0 2px 4px black;transition:color .3s ease;white-space:nowrap;background-color:#00000080;padding:2px 6px;border-radius:4px}.phase-item.active .phase-label{color:#00f2ff;text-shadow:0 0 5px rgba(0,242,255,.5);background-color:#000c}.phase-item:before{content:"";position:absolute;top:50%;left:50%;width:10px;height:10px;background:#000;border:1px solid #ffd700;border-radius:50%;transform:translate(-50%,-50%);z-index:-1;box-shadow:0 0 5px gold}.phase-glow{position:absolute;top:50%;left:50%;width:140%;height:140%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(0,242,255,.3) 0%,transparent 70%);z-index:-1;pointer-events:none;animation:pulse-glow 2s infinite ease-in-out}@keyframes pulse-glow{0%{opacity:.5;transform:translate(-50%,-50%) scale(.9)}50%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:.5;transform:translate(-50%,-50%) scale(.9)}}@media(max-width:768px){.phase-menu{position:fixed;top:0;left:0;width:100%;height:60px;flex-direction:row;padding:0;gap:0;background:#000000f2;border-bottom:1px solid #333;z-index:100;justify-content:space-around}.phase-item{transform:none;flex-direction:row;gap:8px;width:45%;height:44px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.phase-item.active{transform:none;background:#00f2ff26;border-color:#00f2ff}.phase-item:hover{transform:none}.phase-circle{width:24px;height:24px;border-width:1px;box-shadow:none}.phase-item.active .phase-circle{width:24px;height:24px;box-shadow:0 0 10px #00f2ff80}.phase-label{display:block;margin-top:0;font-size:.7rem;background:none;padding:0;color:#ccc;text-shadow:none}.phase-item.active .phase-label{color:#00f2ff;text-shadow:0 0 5px rgba(0,242,255,.5);background:none}.elfic-line,.phase-item:before,.phase-glow{display:none}}.dice-roll-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;padding:50px;background:#1e222df2;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 50px #00000080;animation:fadeIn .5s ease-out;max-width:600px;width:100%}.dice-roll-header h3{font-size:24px;margin:0 0 10px;color:#ff6b6b;text-align:center}.dice-roll-header p{color:#a0a0a0;margin:0;text-align:center}.dice-results{display:flex;align-items:center;justify-content:center;gap:60px;width:100%;padding:20px 0;perspective:1000px}.dice-result{display:flex;flex-direction:column;align-items:center;gap:20px;position:relative;z-index:1}.dice-label{font-size:16px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:1px}.dice-vs{font-size:32px;font-weight:800;color:#ff6b6b;opacity:.5}.mystery-scene{width:80px;height:80px;perspective:600px}.mystery-box{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.175,.885,.32,1.275)}.mystery-box.rolling{animation:spinHorizontal .4s infinite linear}.mystery-face{position:absolute;width:100%;height:100%;background:linear-gradient(135deg,#ff6b6b,#fa5252);border:4px solid #c92a2a;border-radius:12px;display:flex;justify-content:center;align-items:center;font-size:42px;font-weight:800;color:#fff;box-shadow:inset 0 0 20px #0003;backface-visibility:hidden}.mystery-face-front{transform:rotateY(0) translateZ(40px)}.mystery-face-back{transform:rotateY(180deg) translateZ(40px)}.mystery-face-right{transform:rotateY(90deg) translateZ(40px)}.mystery-face-left{transform:rotateY(-90deg) translateZ(40px)}.mystery-face-top{transform:rotateX(90deg) translateZ(40px)}.mystery-face-bottom{transform:rotateX(-90deg) translateZ(40px)}@keyframes spinHorizontal{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dice-roll-button{background:linear-gradient(135deg,#ff6b6b,#ff8787);border:none;border-radius:8px;padding:12px 30px;color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #ff6b6b66;position:relative;z-index:10}.dice-roll-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b99}.dice-roll-button:disabled{background:#444;color:#888;cursor:not-allowed;box-shadow:none;transform:none}.dice-start-button{background:linear-gradient(135deg,#4ade80,#22c55e);border:none;border-radius:8px;padding:15px 40px;color:#052e16;font-size:18px;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #4ade8066;animation:pulseButton 2s infinite}@keyframes pulseButton{0%{box-shadow:0 0 #4ade80b3}70%{box-shadow:0 0 0 10px #4ade8000}to{box-shadow:0 0 #4ade8000}}.dice-completion{display:flex;flex-direction:column;align-items:center;gap:20px;animation:fadeIn .5s ease-out}.dice-winner{font-size:18px;font-weight:600;padding:10px 20px;border-radius:10px}.dice-winner.player{background:#4ade8033;color:#4ade80;border:1px solid rgba(74,222,128,.3)}.dice-winner.opponent{background:#ff6b6b33;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}@media(max-width:600px){.dice-roll-container{padding:20px;gap:20px}.dice-vs{font-size:24px}}.action-sidebar{width:70px;background:#000c;border-left:1px solid #333;display:flex;flex-direction:column;align-items:center;padding-top:10px;gap:10px;z-index:90;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media(max-width:1024px){.mobile-only{display:flex!important}}.action-btn{width:60px;height:60px;background:#2a2a2acc;border:1px solid #444;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px;transition:all .2s ease;gap:2px}.btn-icon{font-size:24px;line-height:1;padding-bottom:5px}.btn-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.action-btn:hover:not(:disabled){background:#3a3a3a;border-color:#00f2ff;box-shadow:0 0 5px #00f2ff80;transform:scale(1.1)}.action-btn:active:not(:disabled){transform:scale(.95)}.action-btn:disabled{opacity:.3;cursor:not-allowed;filter:grayscale(1)}.quit-btn{border-color:#ff3232;color:#ff3232}.quit-btn:hover:not(:disabled){background:#ff323233;border-color:red;box-shadow:0 0 10px #f006}.quit-btn .btn-label{color:#ff3232}.nightmare-btn-sidebar{border-color:#a855f7!important;color:#e9d5ff!important;background:#2d1b3ecc!important;gap:0;justify-content:center}.nightmare-btn-sidebar:hover:not(:disabled){background:#3c2350e6!important;box-shadow:0 0 10px #a855f780!important}.nightmare-label-sidebar{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#d8b4fe;margin-bottom:2px}.nightmare-count-sidebar{font-size:22px;font-weight:800;color:#fff;line-height:1;text-shadow:0 0 5px #a855f7}@media(max-width:768px){.action-sidebar{position:fixed;bottom:0;left:0;width:100%;height:60px;flex-direction:row;border-left:none;border-top:1px solid #333;padding-top:0;justify-content:space-evenly;align-items:center;background:#000000e6;z-index:100}.action-btn{width:40px;height:40px;padding:0;justify-content:center;margin-bottom:0!important}.btn-icon{font-size:20px;padding-bottom:0}.btn-label,.nightmare-label-sidebar{display:none}.nightmare-count-sidebar{font-size:16px}}.quit-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;animation:fadeIn .2s ease-out}.quit-modal-container{background:linear-gradient(135deg,#1a0505,#2a0a0a);border:2px solid #ff3232;border-radius:16px;box-shadow:0 0 50px #ff32324d,inset 0 0 20px #ff00001a;padding:32px;max-width:400px;width:90%;text-align:center;animation:scaleUp .3s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden}.quit-modal-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ff3232,#f80,#ff3232);animation:shimmer 2s infinite linear;background-size:200% 100%}.quit-modal-title{color:#ff3232;font-size:1.8rem;font-weight:900;margin-bottom:16px;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 10px rgba(255,50,50,.5)}.quit-modal-message{color:#ddd;font-size:1.1rem;line-height:1.5;margin-bottom:32px}.quit-modal-actions{display:flex;gap:16px;justify-content:center}.quit-modal-btn{padding:12px 24px;border-radius:8px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s ease;border:none;text-transform:uppercase;letter-spacing:1px}.btn-cancel{background:linear-gradient(180deg,#00f2ff,#00a8ff);color:#000;box-shadow:0 0 20px #00f2ff66}.btn-cancel:hover{transform:translateY(-2px);box-shadow:0 0 30px #00f2ff99}.btn-confirm{background:transparent;border:2px solid #ff3232;color:#ff3232}.btn-confirm:hover{background:#ff32321a;box-shadow:0 0 20px #ff32324d}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.token-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;animation:fadeIn .2s ease-out}.token-modal-container{background:linear-gradient(135deg,#05051a,#0a0a2a);border:2px solid #00f2ff;border-radius:16px;box-shadow:0 0 50px #00f2ff4d,inset 0 0 20px #00f2ff1a;padding:24px;max-width:500px;width:90%;text-align:center;position:relative;overflow:hidden}.token-modal-title{color:#00f2ff;font-size:1.5rem;font-weight:700;margin-bottom:24px;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 10px rgba(0,242,255,.5)}.token-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.token-option{background:#ffffff0d;border:1px solid rgba(0,242,255,.3);border-radius:8px;padding:16px 8px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff}.token-option:hover{background:#00f2ff1a;border-color:#00f2ff;transform:translateY(-2px);box-shadow:0 0 15px #00f2ff33}.token-icon{font-size:24px}.token-label{font-size:.9rem;font-weight:600}.token-modal-close{position:absolute;top:10px;right:10px;background:none;border:none;color:#ffffff80;cursor:pointer;font-size:1.2rem}.token-modal-close:hover{color:#fff}.htp-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;animation:fadeIn .3s ease-out}.htp-modal-container{background:linear-gradient(135deg,#0f1020,#1a1a3a);border:2px solid #a06fff;border-radius:16px;box-shadow:0 0 50px #a06fff4d,inset 0 0 20px #a06fff1a;padding:0;width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.htp-modal-header{padding:24px;border-bottom:1px solid rgba(160,111,255,.3);display:flex;justify-content:space-between;align-items:center;background:#0003}.htp-modal-title{color:#a06fff;font-size:1.8rem;font-weight:700;margin:0;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 10px rgba(160,111,255,.5);display:flex;align-items:center;gap:12px}.htp-modal-close{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:1.5rem;transition:color .2s}.htp-modal-close:hover{color:#fff}.htp-modal-body{padding:24px;overflow-y:auto;color:#e0e0e0;line-height:1.6;font-size:1rem}.htp-section{margin-bottom:30px}.htp-section h3{color:#d4bbff;font-size:1.3rem;margin-bottom:12px;border-left:4px solid #a06fff;padding-left:12px}.htp-section p{margin-bottom:12px}.htp-section ul{list-style-type:none;padding-left:20px}.htp-section ul li{margin-bottom:8px;position:relative}.htp-section ul li:before{content:"•";color:#a06fff;font-weight:700;position:absolute;left:-20px}.htp-modal-body::-webkit-scrollbar{width:8px}.htp-modal-body::-webkit-scrollbar-track{background:#0003}.htp-modal-body::-webkit-scrollbar-thumb{background:#a06fff4d;border-radius:4px}.htp-modal-body::-webkit-scrollbar-thumb:hover{background:#a06fff80}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;animation:fadeIn .2s ease-out}.modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid rgba(102,126,234,.5);border-radius:16px;box-shadow:0 0 50px #667eea4d;padding:0;max-width:500px;width:90%;animation:scaleUp .3s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden}.modal-header{padding:1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#667eea1a}.modal-header h2{margin:0;color:#fff;font-size:1.5rem;font-weight:700}.modal-close{background:none;border:none;color:#fff9;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:4px}.modal-close:hover{background:#ffffff1a;color:#fff}.modal-body{padding:2rem}@keyframes scaleUp{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.nightmare-modal{width:300px;background:linear-gradient(135deg,#2d1b3e,#1a0b2e);border:2px solid #a855f7;box-shadow:0 0 20px #a855f766}.nightmare-controls-large{display:flex;justify-content:center;align-items:center;gap:20px;padding:20px}.nightmare-controls-large .control-btn{width:50px;height:50px;border-radius:50%;font-size:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;border:none;transition:all .2s;color:#fff}.nightmare-controls-large .minus{background-color:#ef4444;box-shadow:0 4px #b91c1c}.nightmare-controls-large .minus:active{transform:translateY(2px);box-shadow:0 2px #b91c1c}.nightmare-controls-large .plus{background-color:#22c55e;box-shadow:0 4px #15803d}.nightmare-controls-large .plus:active{transform:translateY(2px);box-shadow:0 2px #15803d}.nightmare-controls-large .count-display{font-size:48px;font-weight:800;color:#e9d5ff;text-shadow:0 0 10px #a855f7;min-width:60px;text-align:center}.mulligan-modal-overlay{position:fixed;inset:0;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:99999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}.mulligan-modal-container{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #ffa500;border-radius:12px;width:90%;max-width:400px;padding:2rem;box-shadow:0 0 30px #ffa50033;text-align:center;animation:slideIn .3s cubic-bezier(.18,.89,.32,1.28)}.mulligan-modal-title{color:orange;font-size:1.8rem;margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 10px rgba(255,165,0,.5)}.mulligan-info-section{background:#0000004d;border-radius:8px;padding:1rem;margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.1)}.mulligan-stat-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;color:#e0e0e0}.mulligan-stat-row:last-child{margin-bottom:0}.mulligan-stat-label{font-size:.9rem;opacity:.8}.mulligan-stat-value{font-weight:700;font-size:1.1rem}.mulligan-stat-value.highlight{color:orange}.mulligan-warning{color:#a0a0a0;font-size:.85rem;margin-bottom:2rem;line-height:1.4;font-style:italic}.mulligan-actions{display:flex;gap:1rem;justify-content:center}.mulligan-btn-cancel,.mulligan-btn-confirm{padding:.8rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:600;transition:all .2s ease;font-size:.9rem;border:1px solid transparent;flex:1}.mulligan-btn-cancel{background:transparent;color:#e0e0e0;border-color:#fff3}.mulligan-btn-cancel:hover{background:#ffffff1a;border-color:#ffffff4d}.mulligan-btn-confirm{background:#ffa5001a;color:orange;border-color:orange}.mulligan-btn-confirm:hover{background:orange;color:#000;box-shadow:0 0 15px #ffa50066}@keyframes slideIn{0%{transform:translateY(20px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.arrow-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:visible}.arrow-path{fill:none;stroke:#f33;stroke-width:4;stroke-linecap:round;filter:drop-shadow(0 0 5px rgba(255,0,0,.5));animation:dash .5s linear infinite;stroke-dasharray:15 10;opacity:.8}.arrow-head{fill:#f33;stroke:none;filter:drop-shadow(0 0 5px rgba(255,0,0,.5))}@keyframes dash{to{stroke-dashoffset:-25}}.disconnection-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#000000f2,#141428f2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.disconnection-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid rgba(255,107,107,.3);border-radius:20px;padding:40px;max-width:500px;width:90%;box-shadow:0 20px 60px #ff6b6b4d;text-align:center;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.disconnection-icon{position:relative;width:80px;height:80px;margin:0 auto 30px;color:#ff6b6b}.disconnection-icon svg{position:relative;z-index:2}.pulse-ring{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border:3px solid #ff6b6b;border-radius:50%;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.pulse-ring.delay-1{animation-delay:.5s}.pulse-ring.delay-2{animation-delay:1s}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(1.8);opacity:0}}.disconnection-title{font-size:32px;font-weight:700;color:#ff6b6b;margin:0 0 15px;text-shadow:0 2px 10px rgba(255,107,107,.5)}.disconnection-message{font-size:18px;color:#a0a0a0;margin:0 0 30px;line-height:1.5}.disconnection-timer{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:15px;padding:20px;margin:0 0 20px}.timer-label{font-size:14px;color:#888;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.timer-value{font-size:48px;font-weight:700;color:#ff6b6b;font-family:Courier New,monospace;text-shadow:0 2px 10px rgba(255,107,107,.5)}.disconnection-progress{width:100%;height:6px;background:#ffffff1a;border-radius:10px;overflow:hidden;margin:0 0 20px}.disconnection-progress-bar{height:100%;background:linear-gradient(90deg,#ff6b6b,#ff8787);border-radius:10px;transition:width 1s linear;box-shadow:0 0 10px #ff6b6b80}.disconnection-warning{font-size:14px;color:#ff6b6b;margin:20px 0 0;opacity:.8}@media(max-width:600px){.disconnection-content{padding:30px 20px}.disconnection-title{font-size:24px}.disconnection-message{font-size:16px}.timer-value{font-size:36px}}.game-over-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000001;display:flex;align-items:center;justify-content:center;animation:fadeIn .5s ease-out}.game-over-card{width:400px;padding:3rem 2rem;border-radius:20px;text-align:center;box-shadow:0 20px 50px #00000080;border:1px solid rgba(255,255,255,.1);transform:scale(.9);animation:scaleUp .5s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes scaleUp{to{transform:scale(1)}}.game-over-card.win{background:linear-gradient(135deg,#1db9541a,#141414f2);border-color:#1db9544d;box-shadow:0 0 30px #1db95433}.game-over-card.lose{background:linear-gradient(135deg,#dc26261a,#141414f2);border-color:#dc26264d;box-shadow:0 0 30px #dc262633}.game-over-card h1{font-size:3rem;margin-bottom:1rem;font-weight:800;letter-spacing:2px;background-clip:text;-webkit-background-clip:text;color:transparent}.game-over-card.win h1{background-image:linear-gradient(to right,#4ade80,#22c55e)}.game-over-card.lose h1{background-image:linear-gradient(to right,#f87171,#ef4444)}.message{color:#ccc;font-size:1.1rem;margin-bottom:2rem;line-height:1.5}.lobby-btn{background:#fff;color:#000;border:none;padding:1rem 2rem;font-size:1rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.lobby-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #fff3}.lobby-btn:active{transform:translateY(0)}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content.glass-panel{background:#14141ef2;border:1px solid rgba(255,255,255,.1);padding:24px;border-radius:12px;max-width:400px;width:90%;color:#fff;box-shadow:0 10px 30px #00000080;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3{margin:0;color:#a0a0ff}.close-btn{background:none;border:none;color:#aaa;font-size:24px;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:#fff}.modal-body{margin-bottom:24px}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.deck-info-display{display:flex;flex-direction:column;gap:16px}.deck-info-item h4{margin:0 0 4px;color:#888;font-size:.9em;text-transform:uppercase}.deck-info-item p{margin:0;font-size:1.1em}.deck-cover-image{width:100%;height:200px;overflow:hidden;border-radius:8px;margin:8px 0;border:1px solid rgba(255,255,255,.1)}.deck-cover-image img{width:100%;height:100%;object-fit:cover}.btn{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-weight:600;transition:all .2s}.btn-primary{background:#4a4aff;color:#fff}.btn-primary:hover{background:#6060ff}.btn-secondary{background:#ffffff1a;color:#fff}.btn-secondary:hover{background:#fff3}.modal-content.deck-search-modal{max-width:900px;width:90%;height:80vh;display:flex;flex-direction:column}.search-bar{margin-bottom:20px}.search-bar input{width:100%;padding:12px;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:16px}.search-bar input:focus{outline:none;border-color:#4a4aff;box-shadow:0 0 10px #4a4aff33}.deck-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;padding-right:8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.deck-grid::-webkit-scrollbar{width:6px}.deck-grid::-webkit-scrollbar-thumb{background-color:#fff3;border-radius:3px}.deck-search-card{cursor:pointer;transition:transform .2s;position:relative}.deck-search-card:hover{transform:scale(1.05);z-index:10}.deck-search-card .card-container{width:100%;aspect-ratio:2.5 / 3.5}.no-results{grid-column:1 / -1;text-align:center;color:#888;margin-top:40px}.permission-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}.permission-modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:30px;border-radius:16px;border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 40px #00000080,0 0 0 1px #ffffff0d;max-width:450px;width:90%;text-align:center;position:relative;overflow:hidden;animation:slideUp .3s ease-out}.permission-modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ff9f43,#ff6b6b)}.permission-modal-header h2{margin:0 0 10px;color:#fff;font-size:1.5rem;font-weight:700}.permission-modal-body{margin-bottom:25px}.permission-modal-body p{color:#a0a0b0;font-size:1rem;line-height:1.5;margin:0}.permission-card-preview{margin:20px 0;display:flex;flex-direction:column;align-items:center;gap:10px}.permission-card-image{max-width:200px;max-height:200px;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 15px #0000004d;border:1px solid rgba(255,255,255,.1);transition:transform .2s}.permission-card-image:hover{transform:scale(1.05)}.permission-card-name{color:#fff;font-weight:600;font-size:.9rem}.permission-details{background:#0003;padding:15px;border-radius:8px;margin-top:15px;border:1px dashed rgba(255,255,255,.1)}.permission-modal-footer{display:flex;gap:15px;justify-content:center}.btn-permission{padding:12px 24px;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none;min-width:120px}.btn-permission.accept{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff;box-shadow:0 4px 15px #2ecc714d}.btn-permission.accept:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2ecc7166}.btn-permission.deny{background:#ffffff1a;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.btn-permission.deny:hover{background:#ff6b6b1a;border-color:#ff6b6b}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.permission-waiting-toast{position:fixed;top:100px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:12px 24px;border-radius:30px;border:1px solid rgba(255,255,255,.2);z-index:9999;display:flex;align-items:center;gap:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 4px 15px #0000004d;animation:fadeIn .3s ease-out}.permission-waiting-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.initial-phase-overlay{position:fixed;inset:0;background:#000;display:flex;align-items:center;justify-content:center;z-index:10050;touch-action:manipulation}.initial-phase-modal{width:min(1100px,95vw);max-height:90vh;background:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;color:#fff;display:flex;flex-direction:column;gap:16px;box-shadow:0 10px 30px #0006}.initial-phase-title{margin:0;font-size:24px}.initial-phase-subtitle{margin:0;color:#ffffffb3}.initial-phase-status{display:flex;justify-content:space-between;font-size:14px;color:#fffc}.initial-phase-status .ready{color:#7dff9a}.initial-phase-status .waiting{color:orange}.initial-hand-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;overflow-y:auto;padding:8px 0}.initial-hand-card{display:flex;justify-content:center;touch-action:pan-y;-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.initial-phase-actions{display:flex;gap:12px;justify-content:flex-end}.initial-phase-btn{border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-weight:600}.initial-phase-btn.mulligan{background:#2f2f46;color:orange;border:1px solid #ffa500}.initial-phase-btn.confirm{background:#2c7a3f;color:#fff}.initial-phase-btn:disabled{opacity:.6;cursor:not-allowed}.nightmare-bg-counter{position:absolute;left:50%;transform:translate(-50%,-50%);z-index:10;pointer-events:none;transition:all .5s ease-in-out;animation:pulse-nightmare 1s infinite ease-in-out}.player-nightmare{top:70%}.opponent-nightmare{top:30%}.nightmare-bg-circle{width:250px;height:250px;border-radius:50%;border:6px solid #a855f7;background:radial-gradient(circle,#2d1b3e66,#0000 70%);display:flex;flex-direction:column;justify-content:center;align-items:center;box-shadow:0 0 60px #a855f733}.nightmare-bg-value{font-size:100px;font-weight:900;color:#e9d5ff;line-height:1;text-shadow:0 0 30px #a855f7;font-family:Inter,sans-serif}.nightmare-bg-label{font-size:16px;letter-spacing:6px;color:#d8b4fe;margin-top:10px;font-weight:700;text-shadow:0 0 10px #a855f7}@keyframes pulse-nightmare{0%{transform:translate(-50%,-50%) scale(.9);opacity:.8}50%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(.9);opacity:.8}}@media(max-width:700px){.nightmare-bg-circle{width:280px;height:280px}.player-nightmare{top:65%}.opponent-nightmare{top:35%}.nightmare-bg-value{font-size:70px}@keyframes pulse-nightmare-mobile{0%{transform:translate(-50%,-50%) scale(.3);opacity:.8}50%{transform:translate(-50%,-50%) scale(.4);opacity:1}to{transform:translate(-50%,-50%) scale(.3);opacity:.8}}.nightmare-bg-counter{animation:pulse-nightmare-mobile 1s infinite ease-in-out}}.game-screen{display:flex;width:100%;height:100%;overflow:hidden}.game-board{display:flex;flex-direction:column;height:100%;flex:1;background-color:#1a1a1a;background-image:linear-gradient(#00000080,#00000080),url(/assets/background-CI8i1OlD.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;padding:10px;box-sizing:border-box}.opponent-section{flex:1;display:flex;flex-direction:column;justify-content:flex-start;padding-bottom:10px}.player-section{flex:1;display:flex;flex-direction:column;justify-content:flex-end;padding-top:10px}.divider{height:2px;background-color:#444;margin:10px 0;display:flex;align-items:center;justify-content:center}.divider-line{width:100%;height:1px;background:linear-gradient(90deg,transparent,#00f2ff,transparent);box-shadow:0 0 10px #00f2ff}.player-section.active-turn{box-shadow:inset 0 0 30px #32ff3233,0 0 10px #32ff324d;background:radial-gradient(ellipse at bottom,rgba(40,200,40,.15) 0%,transparent 40%);border-top:2px solid rgba(50,255,50,.4);transition:all .5s ease;position:relative;animation:green-pulse 2s infinite alternate}.player-section.active-turn:before{content:"SEU TURNO";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:5rem;color:#32ff320d;font-weight:900;pointer-events:none;z-index:0;letter-spacing:10px;animation:pulse-text 3s infinite}.opponent-section.active-turn{box-shadow:inset 0 0 30px #ff320033,0 0 10px #ff32004d;background:radial-gradient(ellipse at top,rgba(200,40,0,.15) 0%,transparent 40%);border-bottom:2px solid rgba(255,50,0,.4);transition:all .5s ease;position:relative;animation:red-pulse 2s infinite alternate}.opponent-section.active-turn:before{content:"TURNO OPONENTE";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:5rem;color:#ff32000d;font-weight:900;pointer-events:none;z-index:0;letter-spacing:10px}@keyframes green-pulse{0%{box-shadow:inset 0 0 20px #32ff321a;border-color:#32ff324d}to{box-shadow:inset 0 0 50px #50ff504d;border-color:#50ff5099}}@keyframes red-pulse{0%{box-shadow:inset 0 0 20px #ff32001a;border-color:#ff32004d}to{box-shadow:inset 0 0 50px #ff50004d;border-color:#ff500099}}@keyframes pulse-text{0%{opacity:.1}50%{opacity:.2}to{opacity:.1}}.turn-notification{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:4rem;font-weight:900;pointer-events:none;background:#000000b3;padding:20px 50px;border-radius:15px;border:3px solid;animation:notification-pop 2s forwards;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;width:auto;max-width:90vw}.turn-notification.player{color:#fff;border-color:#00f2ff;text-shadow:0 0 20px #00f2ff,0 0 40px #00f2ff;box-shadow:0 0 50px #00f2ff80}.turn-notification.opponent{color:#ffdada;border-color:#ff3232;text-shadow:0 0 20px #ff3232,0 0 40px #ff3232;box-shadow:0 0 50px #ff323280}@keyframes notification-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}10%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}20%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.2)}}.reconnection-toast{position:absolute;top:80px;left:50%;transform:translate(-50%);background:#000000d9;border:1px solid #ffaa00;color:#fa0;padding:10px 20px;border-radius:20px;display:flex;align-items:center;gap:12px;z-index:9000;box-shadow:0 0 20px #fa03;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:slide-down .4s cubic-bezier(.175,.885,.32,1.275);font-weight:500;font-size:.95rem;letter-spacing:.5px}.reconnection-toast .spinner{width:18px;height:18px;border:2px solid rgba(255,170,0,.2);border-top-color:#fa0;border-radius:50%;animation:spin 1s linear infinite}@keyframes slide-down{0%{transform:translate(-50%,-40px);opacity:0}to{transform:translate(-50%);opacity:1}}@media(max-width:768px){.game-screen{flex-direction:column;padding-top:60px;padding-bottom:60px;justify-content:center;max-height:calc(100vh - 190px)}.game-board{padding:5px;justify-content:center;flex:1}.player-section,.opponent-section{flex:initial;padding:5px 0}.player-section.active-turn:before,.opponent-section.active-turn:before{font-size:2rem;letter-spacing:5px}.turn-notification{font-size:2rem;padding:10px 20px}}.spectator-view{position:fixed;top:0;left:0;width:100vw;height:calc(100vh - 60px);background:linear-gradient(135deg,#1a1a2e,#16213e);overflow:hidden}.spectator-header{position:fixed;top:0;left:0;right:0;height:60px;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid rgba(255,215,0,.3);display:flex;justify-content:space-between;align-items:center;padding:0 2rem;z-index:1000;box-shadow:0 4px 20px #00000080}.spectator-info{display:flex;align-items:center;gap:1.5rem}.spectator-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.9rem;letter-spacing:.5px;box-shadow:0 4px 15px #667eea66;animation:pulse-badge 2s ease-in-out infinite}@keyframes pulse-badge{0%,to{box-shadow:0 4px 15px #667eea66}50%{box-shadow:0 4px 25px #667eea99}}.spectator-count{color:gold;font-size:.95rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.spectator-controls{display:flex;gap:1rem}.btn-leave{background:#dc3545e6;color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #dc35454d}.btn-leave:hover{background:#c82333;transform:translateY(-2px);box-shadow:0 6px 20px #dc354580}.spectator-notice{background:#ffc107f2;color:#000;padding:.8rem 2rem;border-radius:10px;font-size:.9rem;font-weight:500;z-index:999;box-shadow:0 4px 20px #ffc10766;animation:slide-down .5s ease-out;max-width:calc(100vw - 4rem);white-space:nowrap}@keyframes slide-down{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.spectator-notice p{margin:0;display:flex;align-items:center;gap:.5rem}.spectator-game-container{position:fixed;inset:60px 0;width:100%;height:calc(100vh - 120px);overflow:hidden}.spectator-interaction-blocker{position:fixed;inset:60px 0;width:100%;height:calc(100vh - 120px);z-index:998;pointer-events:none;cursor:not-allowed;background:transparent}.spectator-view .card{pointer-events:auto;cursor:not-allowed!important}.spectator-view .card[draggable=true]{cursor:not-allowed!important;-webkit-user-select:none;user-select:none}.spectator-view .card:active{opacity:1!important;cursor:not-allowed!important}.spectator-error,.spectator-loading{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);overflow:hidden}.error-container,.loading-container{text-align:center;padding:3rem;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d;max-width:500px}.error-container h2{color:#ff6b6b;font-size:2rem;margin-bottom:1rem}.error-container p{color:#fffc;font-size:1.1rem;margin-bottom:2rem}.loading-container h2{color:gold;font-size:1.8rem;margin-bottom:1rem;margin-top:1.5rem}.loading-container p{color:#ffffffb3;font-size:1rem}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,215,0,.2);border-top-color:gold;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.8rem 2rem;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}@media(max-width:768px){.spectator-header{padding:0 1rem;height:50px}.spectator-badge{font-size:.8rem;padding:.4rem .8rem}.spectator-count{font-size:.85rem}.spectator-notice{top:60px;left:1rem;right:1rem;transform:none;font-size:.8rem;padding:.6rem 1rem}.spectator-game-container,.spectator-interaction-blocker{top:50px}}.disclaimer-container{width:100%;padding:.3rem;text-align:center;background-color:#000;color:#888;font-size:.9rem;-webkit-user-select:none;user-select:none;border-top:1px solid #333}.disclaimer-text{margin:0;font-family:Inter,sans-serif;font-style:italic}.App{width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-content{flex:1;width:100%;height:100%;overflow-y:auto;overflow-x:hidden;position:relative}
