.topbar-container{grid-area:topbar;background:linear-gradient(135deg,rgba(185,103,255,.08),var(--color-bg-elevated));display:flex;justify-content:space-between;align-items:center;padding:0 .75rem;border-bottom:2px solid var(--color-border);box-shadow:0 4px 12px #00000080;z-index:var(--z-topbar);color:var(--color-text-primary);font-family:var(--font-family-base);gap:.5rem}.topbar-section{display:flex;align-items:center;gap:.4rem;flex:1}.topbar-section.center{justify-content:center;flex:0 0 auto}.topbar-section.right{justify-content:flex-end}.player-hp-inline{position:relative;min-width:80px;max-width:120px;flex-shrink:0}.player-hp-bar-bg{height:20px;background:linear-gradient(90deg,#0d0d1a,#1a1a2e);border-radius:10px;overflow:hidden;border:1px solid #000;position:relative}.player-hp-bar-fill{height:100%;background:linear-gradient(90deg,#ff3860,#ff6ec7);transition:width .3s ease-out;box-shadow:inset 0 1px 2px #fff3}.player-hp-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;text-shadow:1px 1px 0 #000,-1px -1px 0 #000;z-index:2}.player-block-badge{display:flex;align-items:center;gap:2px;background:linear-gradient(135deg,#00d4ff,#09c);border:1px solid #66e5ff;border-radius:10px;padding:2px 6px;font-size:.65rem;font-weight:700;color:#0d0d1a;box-shadow:0 0 6px #00d4ff4d;flex-shrink:0}.player-status-pip{display:flex;align-items:center;gap:1px;font-size:.6rem;padding:1px 5px;border-radius:8px;border:1px solid var(--color-border);background:#0006;white-space:nowrap;flex-shrink:0}.player-status-pip.debuff{color:var(--color-accent-red);border-color:#ff386080;background:#ff38601a}.player-status-pip.buff{color:var(--color-accent-green);border-color:#39ff1480;background:#39ff141a}.abandon-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--color-text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;transition:color .2s,border-color .2s}.abandon-btn:hover{color:var(--color-accent-red);border-color:#ff386080}.abandon-confirm{display:flex;align-items:center;gap:6px}.abandon-confirm-text{font-size:.7rem;color:var(--color-accent-red);font-weight:700;white-space:nowrap}.abandon-yes,.abandon-no{font-size:.65rem;font-weight:700;border:1px solid;border-radius:4px;padding:2px 8px;cursor:pointer;font-family:var(--font-family-base)}.abandon-yes{background:#ff386033;border-color:var(--color-accent-red);color:var(--color-accent-red)}.abandon-no{background:#ffffff0d;border-color:var(--color-border);color:var(--color-text-secondary)}.stat{display:flex;align-items:center;gap:.3rem;font-weight:700;font-size:.85rem}.stat.gold{color:var(--color-accent-amber)}.floor-text{font-family:var(--font-family-display);font-size:.9rem;letter-spacing:1px;color:var(--color-text-secondary)}@media(min-width:769px){.topbar-container{padding:0 2rem;gap:.75rem}.topbar-section{gap:.75rem}.player-hp-inline{min-width:120px;max-width:180px}.player-hp-bar-bg{height:24px;border-radius:12px}.player-hp-text{font-size:.75rem}.player-block-badge{padding:3px 8px;font-size:.75rem}.player-status-pip{font-size:.7rem;padding:2px 6px}.stat{font-size:1.1rem}.floor-text{font-size:1.15rem}}.entity-panel{display:flex;flex-direction:column;align-items:center;position:relative}.entity-panel.player{gap:.15rem}.player-info-bar{display:flex;flex-direction:column;align-items:center;gap:.15rem;margin-bottom:.25rem}.player-info-bar .player-name{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-highlight)}.player-info-bar .hp-bar-container.player-hp{width:100px}.player-status-row{display:flex;gap:.25rem;align-items:center;flex-wrap:wrap;justify-content:center}.player-block-inline{display:flex;align-items:center;gap:2px;font-size:.6rem;font-weight:700;color:#00d4ff}.player-status-pip{font-size:.55rem;font-weight:700;padding:1px 4px;border-radius:4px}.player-status-pip.buff{color:#4ade80}.player-status-pip.debuff{color:#f87171}.entity-panel.player .entity-avatar{width:48px;height:48px;font-size:2.5rem}.entity-panel.player .entity-avatar.has-portrait:not(.has-sprite){width:80px;height:80px;border-radius:50%;overflow:hidden;border:2px solid var(--color-text-highlight);box-shadow:0 0 12px #ff6ec766;background-color:var(--color-bg-base)}.player-portrait-img{width:100%;height:100%;object-fit:cover}.entity-panel.player .entity-avatar.has-sprite{width:80px;height:128px;background:var(--color-bg-surface);border:2px solid var(--color-accent-violet);border-radius:8px;overflow:hidden;animation:spriteIdle 3s ease-in-out infinite;box-shadow:0 4px 12px #000c,0 0 10px #b967ff40}.player-sprite-img{width:106%;height:106%;margin:-3% 0 0 -3%;object-fit:cover}@keyframes spriteIdle{0%,to{transform:translateY(0) scaleY(1)}50%{transform:translateY(-3px) scaleY(1.01)}}.entity-panel.player .entity-avatar.has-sprite.anim-lunge{animation:lungeDynamic .3s cubic-bezier(.2,.8,.2,1) forwards}.entity-panel.player .entity-avatar.has-sprite.anim-stagger{animation:spriteStagger .4s cubic-bezier(.36,.07,.19,.97) both}@keyframes spriteStagger{0%{transform:translate(0);filter:brightness(1)}20%{transform:translate(-12px) skew(-5deg);filter:brightness(2) sepia(1) hue-rotate(-50deg) saturate(4)}40%{transform:translate(8px) skew(3deg)}60%{transform:translate(-5px)}80%{transform:translate(3px);filter:brightness(1)}to{transform:translate(0) skew(0)}}.player-info-bar .player-name{font-family:var(--font-family-display);text-shadow:0 2px 4px rgba(0,0,0,.8)}.entity-panel.enemy{width:90px;background:#1a1a2ee6;border:1px solid var(--color-border);border-radius:10px;padding:.25rem .2rem .4rem;gap:.15rem;transition:border-color .3s,box-shadow .3s,transform .2s}.entity-panel.threat-attack{border-color:#ff386080;box-shadow:0 0 12px #ff386026,0 4px 12px #00000080}.entity-panel.threat-defend{border-color:#00d4ff80;box-shadow:0 0 12px #00d4ff26,0 4px 12px #00000080}.entity-panel.threat-buff{border-color:#39ff1480;box-shadow:0 0 12px #39ff1426,0 4px 12px #00000080}.entity-panel.targeted-panel{border-color:var(--color-accent-red);box-shadow:0 0 20px #ff386066,0 0 40px #ff386026;transform:scale(1.05)}.intent-row{display:flex;gap:.25rem;align-items:center;justify-content:center;padding:.15rem 0;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:.1rem;width:100%}.intent-item{display:flex;align-items:center;gap:.15rem;font-weight:700;font-family:var(--font-family-display)}.intent-item.attack{color:var(--color-accent-red)}.intent-item.defend{color:var(--color-accent-blue)}.intent-item.buff{color:var(--color-accent-green)}.intent-value{font-size:.9rem;text-shadow:1px 1px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000}.entity-avatar{width:48px;height:48px;background:transparent;display:flex;align-items:center;justify-content:center;font-size:2.8rem;filter:drop-shadow(0 4px 10px rgba(0,0,0,.8));transition:transform .2s,filter .2s}.enemy-portrait-img{width:100%;height:100%;object-fit:cover;object-position:center 20%;border-radius:6px}.entity-panel.enemy:hover .entity-avatar{transform:translateY(-3px)}.entity-avatar.targeted{filter:drop-shadow(0 0 20px var(--color-accent-red));transform:scale(1.1);z-index:10}.entity-avatar.anim-lunge{animation:lungeDynamic .3s cubic-bezier(.2,.8,.2,1) forwards;z-index:20}.entity-avatar.anim-stagger{animation:stagger .4s cubic-bezier(.36,.07,.19,.97) both}@keyframes lungeDynamic{0%{transform:translate(0)}50%{transform:translate(var(--lunge-x, 0px),var(--lunge-y, -40px)) scale(1.1)}to{transform:translate(0)}}@keyframes stagger{0%{transform:translate(0);filter:brightness(1) sepia(0) hue-rotate(0deg) saturate(1)}20%{transform:translate(-10px);filter:brightness(1.5) sepia(1) hue-rotate(-50deg) saturate(5)}40%{transform:translate(10px)}60%{transform:translate(-5px)}80%{transform:translate(5px);filter:brightness(1) sepia(0) hue-rotate(0deg) saturate(1)}to{transform:translate(0)}}.entity-avatar-container{position:relative;display:inline-block}.floating-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.8rem;font-family:var(--font-family-display);font-weight:900;color:#fff;text-shadow:2px 2px 0 #000,-2px -2px 0 #000,2px -2px 0 #000,-2px 2px 0 #000,0 4px 12px rgba(0,0,0,.8);pointer-events:none;z-index:var(--z-entity-float);animation:floatUpAndFade 1.2s cubic-bezier(.2,.8,.2,1) forwards}.floating-text.damage{color:var(--color-accent-red)}.floating-text.block{color:var(--color-accent-blue)}.floating-text.heal{color:var(--color-accent-green)}.floating-text.status{color:#fff;font-size:.9rem}@keyframes floatUpAndFade{0%{opacity:0;transform:translate(-50%) scale(.5)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:0;transform:translate(-50%,-120%) scale(1)}}.entity-info{width:100%;text-align:center}.entity-name{font-size:.75rem;font-family:var(--font-family-display);font-weight:700;margin-bottom:.15rem;text-shadow:0 2px 4px rgba(0,0,0,.8)}.hp-bar-container{width:80%;position:relative;margin:0 auto .2rem}.hp-text{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;z-index:2;text-shadow:1px 1px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000}.hp-bar-bg{width:100%;height:14px;background:#1a1a2e;border-radius:7px;overflow:hidden;border:1px solid #000}.hp-bar-fill{height:100%;background:linear-gradient(90deg,#ff3860,#ff6ec7);transition:width .3s ease-out}.entity-block{position:absolute;top:-5px;right:0;background:#00d4ff;border:1px solid #fff;border-radius:50%;width:22px;height:22px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;font-size:.6rem;color:#0d0d1a;box-shadow:0 4px 8px #00000080;z-index:10}.status-container{display:flex;justify-content:center;gap:.2rem;flex-wrap:wrap;margin-top:.1rem}.status-icon{background:#00000080;padding:1px 4px;border-radius:10px;font-size:.6rem;border:1px solid var(--color-border);cursor:help}.status-icon.debuff{color:var(--color-accent-red);border-color:#ff386080}.status-icon.buff{color:var(--color-accent-green);border-color:#39ff1480}@media(min-width:769px){.entity-panel.player .entity-avatar{width:70px;height:70px;font-size:3.5rem}.entity-panel.player .entity-avatar.has-sprite{width:140px;height:220px;border-width:3px;border-radius:10px}.player-info-bar .player-name{font-size:.85rem}.player-info-bar .hp-bar-container.player-hp{width:140px}.player-block-inline{font-size:.7rem}.player-status-pip{font-size:.65rem}.entity-panel.enemy{width:140px;padding:.5rem .4rem .6rem;gap:.25rem;border-radius:12px}.intent-row{padding:.2rem 0}.intent-value{font-size:1.1rem}.entity-avatar{width:80px;height:80px;font-size:3.2rem}.floating-text{font-size:2.5rem}.floating-text.status{font-size:1.25rem}.entity-name{font-size:.9rem;margin-bottom:.2rem}.hp-bar-bg{height:16px;border-radius:8px}.hp-text{font-size:.65rem;line-height:10px}.entity-block{width:28px;height:28px;font-size:.7rem;top:-8px;right:5px;border-width:2px}.status-container{gap:.3rem}.status-icon{padding:2px 6px;font-size:.7rem}}.hand-container{position:relative;width:100%;height:var(--card-height);margin-bottom:30px;pointer-events:none;z-index:var(--z-hand)}.card-slot{position:absolute;left:calc(50% + var(--card-offset) * var(--card-spacing) - var(--card-spacing) / 2);bottom:0;transition:left .4s cubic-bezier(.2,.8,.2,1),transform .4s cubic-bezier(.2,.8,.2,1),z-index 0s}.card-slot:has(.card.is-dragging){z-index:var(--z-card-hover)!important}@media(hover:hover){.card-slot:has(.card:hover){z-index:var(--z-card-hover)!important}}.card{width:var(--card-width);height:var(--card-height);background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:6px;padding:.25rem;display:flex;flex-direction:column;pointer-events:auto;cursor:grab;touch-action:none;transition:transform .4s cubic-bezier(.2,.8,.2,1),z-index 0s,margin .4s cubic-bezier(.2,.8,.2,1),box-shadow .3s ease;box-shadow:0 4px 12px #000c;position:relative;transform-origin:bottom center}.card.unplayable{filter:grayscale(100%) brightness(.45);opacity:.5;cursor:not-allowed;pointer-events:none}.card-playing-wrapper{--fly-start-y: -60px;--fly-mid-y: -100px;--fly-end-x: calc(50vw - var(--card-half-width) - 15px);--fly-end-y: -140px;--fly-end-scale: .3;--fly-end-rotate: 25deg;position:absolute;pointer-events:none;z-index:var(--z-card-playing);bottom:0;left:calc(50% - var(--card-half-width));animation:flyToDiscard .8s cubic-bezier(.2,.8,.2,1) forwards}.card-playing-wrapper .card{box-shadow:0 12px 30px #00000080;border-color:#fff}@keyframes flyToDiscard{0%{transform:translateY(var(--fly-start-y)) scale(1.1);opacity:1}40%{transform:translateY(var(--fly-mid-y)) scale(1.1);opacity:1}to{transform:translate(var(--fly-end-x),var(--fly-end-y)) scale(var(--fly-end-scale)) rotate(var(--fly-end-rotate));opacity:0}}.card-draw-anim{--draw-start-x: calc(-50vw + var(--card-half-width) + 15px);--draw-start-y: -140px;animation:flyFromDrawPile .5s cubic-bezier(.2,.8,.2,1) both}@keyframes flyFromDrawPile{0%{transform:translate(var(--draw-start-x),var(--draw-start-y)) scale(0) rotate(-90deg);opacity:0}10%{opacity:1}to{transform:translate(0) scale(1) rotate(0);opacity:1}}.card.is-dragging{cursor:grabbing;transform:translateY(var(--card-hover-lift)) rotate(0) scale(var(--card-hover-scale))!important;z-index:var(--z-card-hover)!important;box-shadow:0 12px 30px #000}@media(hover:hover){.card:hover{cursor:grabbing;transform:translateY(var(--card-hover-lift)) rotate(0) scale(var(--card-hover-scale))!important;z-index:var(--z-card-hover)!important;box-shadow:0 12px 30px #000}}.card.is-drag-moving,.card.is-drag-moving:hover{transform:translate(var(--drag-dx),var(--drag-dy)) scale(1.05)!important;transition:none!important;z-index:9999!important;box-shadow:0 20px 60px #000c!important;pointer-events:none;cursor:grabbing}.card.is-targeting{transform:translateY(var(--card-hover-lift)) rotate(0) scale(var(--card-hover-scale))!important;z-index:var(--z-card-hover)!important;box-shadow:0 12px 30px #000,0 0 20px #ff386080;border-color:#fff;cursor:crosshair}.card.type-attack{border-color:var(--color-accent-red);box-shadow:0 4px 12px #000c,0 0 8px #ff386033}.card.type-skill{border-color:var(--color-accent-blue);box-shadow:0 4px 12px #000c,0 0 8px #00d4ff33}.card.type-power{border-color:var(--color-accent-violet);box-shadow:0 4px 12px #000c,0 0 8px #b967ff33}.card-cost{position:absolute;top:-3px;left:-3px;width:15px;height:15px;background:var(--color-accent-violet);border:1px solid #ffb3e6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.55rem;box-shadow:0 2px 4px #00000080}.card-name{font-family:var(--font-family-display);font-weight:700;font-size:.6rem;text-align:center;margin-bottom:.1rem;text-transform:uppercase}.card-artwork-wrap{position:relative;width:calc(100% + .5rem);margin-left:-.25rem;margin-right:-.25rem;aspect-ratio:4/3;border-radius:3px;overflow:hidden;background-color:var(--color-bg-base)}.card-artwork{width:106%;height:106%;margin:-3% 0 0 -3%;object-fit:cover}.card-type-badge{position:absolute;bottom:3px;left:50%;transform:translate(-50%);font-size:.35rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:.05rem .3rem;background:#000000b3;color:var(--color-text-secondary);border-radius:6px;border:1px solid rgba(255,255,255,.15);white-space:nowrap}.card-artwork-placeholder{width:calc(100% + .5rem);margin-left:-.25rem;margin-right:-.25rem;aspect-ratio:4/3;border-radius:3px;background:linear-gradient(135deg,#ffffff08,#ffffff14,#ffffff08)}.card-desc{font-size:.5rem;line-height:1.15;text-align:center;flex-grow:1;display:flex;align-items:center;justify-content:center}.card.hero-card{border-color:gold;box-shadow:0 4px 12px #000c,0 0 12px #ffd7004d,inset 0 0 20px #ffd7000d;background:linear-gradient(180deg,var(--color-bg-surface) 0%,rgba(255,215,0,.08) 100%)}.card.hero-card .card-cost{background:linear-gradient(135deg,gold,#fa0);border-color:#fff8dc;color:#1a1a2e}.card.hero-card .card-type-badge{background:#ffd70040;border-color:#ffd70080;color:gold}.card.hero-card .card-name{color:gold;text-shadow:0 0 8px rgba(255,215,0,.4)}.card.hero-card.is-dragging{box-shadow:0 12px 30px #000,0 0 25px #ffd70080}@media(hover:hover){.card.hero-card:hover{box-shadow:0 12px 30px #000,0 0 25px #ffd70080}}.card.hero-card.is-targeting{box-shadow:0 12px 30px #000,0 0 20px #ffd70080;border-color:gold}@media(max-width:768px){.hand-container{position:relative;width:100%;height:100%;margin-bottom:0}.card-slot{left:calc(50% + var(--row-offset) * (var(--card-width) + 10px) - var(--card-width) / 2)!important;bottom:calc(50% - (var(--total-rows) * (var(--card-height) + 8px) - 8px) / 2 + var(--row-index) * (var(--card-height) + 8px))!important;transition:left .4s cubic-bezier(.2,.8,.2,1),bottom .4s cubic-bezier(.2,.8,.2,1)}.hand-container .card{transform:translateY(var(--row-lift)) rotate(var(--row-rotation))!important}.hand-container .card.is-targeting{transform:translateY(var(--card-hover-lift)) scale(var(--card-hover-scale))!important}.hand-container .card.is-drag-moving,.hand-container .card.is-drag-moving:hover{transform:translate(var(--drag-dx),var(--drag-dy)) scale(1.05)!important;transition:none!important}}@media(max-width:768px)and (hover:hover){.hand-container .card:hover{transform:translateY(var(--card-hover-lift)) scale(var(--card-hover-scale))!important}}@media(min-width:769px){.hand-container{height:110px;top:0}.card{padding:.5rem;border-width:3px;border-radius:10px}.card-playing-wrapper{--fly-start-y: -80px;--fly-mid-y: -120px;--fly-end-x: calc(50vw - var(--card-half-width) - 9px);--fly-end-y: -180px;--fly-end-scale: 0;--fly-end-rotate: 90deg}.card-draw-anim{--draw-start-x: calc(-50vw + var(--card-half-width) + 9px);--draw-start-y: -180px}.card-cost{width:22px;height:22px;font-size:.75rem;top:-6px;left:-6px;border-width:2px}.card-name{font-size:.85rem;margin-bottom:.15rem}.card-type-badge{font-size:.5rem;padding:.1rem .4rem;bottom:5px;border-radius:8px}.card-artwork-wrap{width:calc(100% + 1rem);margin-left:-.5rem;margin-right:-.5rem;border-radius:5px}.card-artwork-placeholder{width:calc(100% + 1rem);margin-left:-.5rem;margin-right:-.5rem}.card-desc{font-size:.7rem;line-height:1.2}.card.hero-card{border-width:3px}}.targeting-arrow-svg{position:fixed;top:0;left:0;width:100vw;height:100dvh;pointer-events:none;z-index:var(--z-targeting);overflow:visible}.targeting-path{stroke-dasharray:10,10;animation:dash .5s linear infinite}@keyframes dash{to{stroke-dashoffset:-20}}.combat-result-backdrop{position:absolute;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:100;animation:backdrop-fade .3s ease-out forwards;padding:1rem}.combat-result-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem;border-radius:8px;max-width:100%;animation:result-slide-up .5s cubic-bezier(.2,.8,.2,1) forwards}@keyframes result-slide-up{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.combat-result-card.victory{background:#0d1a0df2;border:2px solid var(--color-accent-green);box-shadow:0 10px 30px #00000080,inset 0 0 20px #39ff141a}.combat-result-card.defeat{background:#1a0d14f2;border:2px solid var(--color-accent-red);box-shadow:0 10px 30px #00000080,inset 0 0 20px #ff38601a}.combat-result-icon{margin-bottom:.75rem}.combat-result-icon.victory{color:var(--color-accent-green);filter:drop-shadow(0 0 10px rgba(57,255,20,.5))}.combat-result-icon.defeat{color:var(--color-accent-red);filter:drop-shadow(0 0 10px rgba(255,56,96,.5))}.combat-result-title{font-family:var(--font-family-display);font-size:2rem;margin:0;text-transform:uppercase;letter-spacing:2px;text-shadow:2px 2px 0px rgba(0,0,0,.8)}.combat-result-title.victory{color:var(--color-accent-green)}.combat-result-title.defeat{color:var(--color-accent-red)}.combat-result-stats{font-size:1rem;color:var(--color-text-secondary);margin:.75rem 0 1.25rem}.combat-result-stats strong{color:#fff}.combat-result-gold{color:var(--color-accent-amber)}.combat-result-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.combat-result-btn{font-family:var(--font-family-display);padding:.6rem 1rem;font-size:.9rem;cursor:pointer;border-radius:8px;transition:all .2s ease;text-transform:uppercase;font-weight:700}.combat-result-btn.primary.victory{background-color:var(--color-accent-green);color:#0d0d1a;border:none}.combat-result-btn.primary.defeat{background-color:var(--color-accent-red);color:#fff;border:none}.combat-result-btn.primary:hover{filter:brightness(1.2);transform:scale(1.05)}.combat-result-btn.secondary{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-text-secondary)}.combat-result-btn.secondary:hover{color:#fff;border-color:#fff;background-color:#ffffff1a}@media(min-width:769px){.combat-result-card{padding:3rem}.combat-result-icon{margin-bottom:1rem}.combat-result-title{font-size:3.5rem;letter-spacing:4px}.combat-result-stats{font-size:1.3rem;margin:1.25rem 0 2rem}.combat-result-actions{gap:1rem}.combat-result-btn{padding:.8rem 1.5rem;font-size:1.2rem}}.combat-stage{display:grid;grid-template-rows:var(--topbar-height) 1fr var(--hand-height);grid-template-areas:"topbar" "battlefield" "hand";width:100vw;height:100vh;background:radial-gradient(circle at center 60%,#1a1a2e,#0d0d1a 70%);overflow:hidden;position:relative}.combat-particles{position:absolute;inset:0;background-image:radial-gradient(1px 1px at 10% 20%,rgba(0,212,255,.06),transparent),radial-gradient(1px 1px at 30% 60%,rgba(255,110,199,.04),transparent),radial-gradient(1px 1px at 50% 40%,rgba(0,212,255,.06),transparent),radial-gradient(1px 1px at 70% 80%,rgba(255,110,199,.04),transparent),radial-gradient(1px 1px at 90% 10%,rgba(185,103,255,.05),transparent);background-size:200% 200%;animation:particleFloat 25s linear infinite;pointer-events:none;z-index:0}@keyframes particleFloat{0%{background-position:0% 0%}to{background-position:200% 200%}}.entities-container{grid-area:battlefield;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:.5rem 4vw;overflow:hidden;z-index:1}.player-presence{display:flex;justify-content:center;flex-shrink:0}.enemy-zone{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;align-items:flex-start;padding:.5rem;border-radius:12px;background:#ff386008}.turn-phase-banner{position:absolute;top:calc(var(--topbar-height) + 4px);left:50%;transform:translate(-50%);padding:.25rem 1.5rem;border-radius:20px;font-family:var(--font-family-display);font-weight:700;font-size:.75rem;letter-spacing:2px;text-transform:uppercase;z-index:var(--z-controls);animation:phaseBannerIn .3s ease-out}.turn-phase-banner.enemy-turn{background:#ff386033;border:1px solid rgba(255,56,96,.4);color:var(--color-accent-red);box-shadow:0 0 12px #ff386033}@keyframes phaseBannerIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.table-controls{position:absolute;bottom:calc(var(--hand-height) - 30px);left:0;right:0;display:flex;justify-content:space-between;align-items:flex-end;padding:0 1rem;pointer-events:none;z-index:var(--z-controls)}.controls-left,.controls-right{display:flex;align-items:center;gap:.5rem;pointer-events:auto}.energy-orb{width:44px;height:44px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#ff6ec7,#b967ff 50%,#7c3aed);border:2px solid #ffb3e6;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:900;font-family:var(--font-family-display);color:#fff;box-shadow:0 0 16px #b967ff66,0 4px 12px #0009,inset 0 -4px 8px #0000004d;text-shadow:0 0 8px rgba(255,255,255,.6),1px 1px 2px rgba(0,0,0,.8);position:relative;overflow:hidden}.energy-orb:before{content:"";position:absolute;top:4px;left:8px;width:14px;height:8px;background:radial-gradient(ellipse,rgba(255,255,255,.5),transparent);border-radius:50%;pointer-events:none}.end-turn-button{pointer-events:auto;background:var(--color-bg-elevated);border:2px solid var(--color-border);color:var(--color-text-primary);padding:.5rem 1rem;font-size:.9rem;font-family:var(--font-family-display);font-weight:700;cursor:pointer;box-shadow:0 4px 12px #00000080;transition:all .2s;text-transform:uppercase;letter-spacing:2px}.end-turn-button:hover{background:#3d3d5c;border-color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #000000b3}.end-turn-button:active{transform:translateY(1px);box-shadow:0 2px 8px #00000080}.end-turn-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.deck-table{grid-area:hand;background:linear-gradient(to bottom,#1a1a2ef2,#0d0d1afa);border-top:3px solid #3d3d5c;box-shadow:0 -10px 30px #000c;display:flex;justify-content:center;align-items:flex-end;padding:0 1rem;pointer-events:none;z-index:var(--z-deck-table);transition:opacity .3s ease;box-sizing:border-box;overflow:visible}.deck-table.disabled{opacity:.5}.enemy-info-tooltip{position:absolute;left:50%;top:45%;transform:translate(-50%,-50%);background:#0a0a14f7;border:1px solid rgba(185,103,255,.5);border-radius:10px;padding:12px 16px;z-index:200;min-width:200px;max-width:280px;pointer-events:none;animation:tooltipFadeIn .2s ease-out;box-shadow:0 0 20px #b967ff4d,0 8px 32px #0009}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.enemy-info-name{margin:0 0 4px;font-size:.9rem;font-weight:700;font-family:var(--font-family-display);color:var(--color-text-highlight);text-align:center}.enemy-info-intent{margin:0 0 4px;font-size:.8rem;font-weight:700;color:var(--color-text-primary, #fff)}.enemy-info-line{margin:2px 0;font-size:.7rem;color:var(--color-text-secondary, rgba(255,255,255,.7))}@media(min-width:769px){.entities-container{flex-direction:row;padding:0 2rem;gap:3rem;overflow:hidden}.enemy-zone{gap:1rem 1.5rem;padding:1rem 1.5rem}.turn-phase-banner{font-size:.9rem;padding:.3rem 2rem}.table-controls{bottom:calc(var(--hand-height) - 50px);padding:0 4rem}.energy-orb{width:60px;height:60px;font-size:2rem;border-width:3px}.end-turn-button{padding:1rem 2rem;font-size:1.25rem}.deck-table{padding:0 4rem 1rem}}@keyframes mapDrift1{0%{transform:translate(0) rotate(0) scale(.8);opacity:.25}25%{transform:translate(12px,-18px) rotate(90deg) scale(1.1);opacity:.6}50%{transform:translate(-8px,-30px) rotate(180deg) scale(.85);opacity:.35}75%{transform:translate(-14px,-10px) rotate(270deg) scale(1.15);opacity:.7}to{transform:translate(0) rotate(360deg) scale(.8);opacity:.25}}@keyframes mapDrift2{0%{transform:translate(0) rotate(0) scale(1);opacity:.3}25%{transform:translate(-16px,-8px) rotate(-90deg) scale(.75);opacity:.65}50%{transform:translate(8px,-25px) rotate(-180deg) scale(1.1);opacity:.3}75%{transform:translate(15px,-5px) rotate(-270deg) scale(.9);opacity:.6}to{transform:translate(0) rotate(-360deg) scale(1);opacity:.3}}@keyframes mapDrift3{0%{transform:translate(0) rotate(0) scale(.9);opacity:.4}33%{transform:translate(10px,-22px) rotate(120deg) scale(1.15);opacity:.25}66%{transform:translate(-12px,-8px) rotate(240deg) scale(.7);opacity:.7}to{transform:translate(0) rotate(360deg) scale(.9);opacity:.4}}@keyframes mapParticleDrift{0%{background-position:0% 0%}to{background-position:200% 200%}}@keyframes hintPulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes nodePulse{0%{box-shadow:0 0 #ff6ec766}70%{box-shadow:0 0 0 10px #ff6ec700}to{box-shadow:0 0 #ff6ec700}}.map-view-container{position:absolute;inset:50px 0 0;background:radial-gradient(ellipse at 30% 20%,rgba(185,103,255,.05) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(255,56,96,.04) 0%,transparent 50%),#0d0d1a;overflow:hidden;display:flex;flex-direction:column;align-items:center;padding:1rem}.map-view-container:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,0,0,.06) 2px,rgba(0,0,0,.06) 4px);pointer-events:none;opacity:.4;z-index:0}.map-view-container:after{content:"";position:absolute;inset:0;background-image:radial-gradient(1px 1px at 20% 30%,rgba(185,103,255,.3),transparent),radial-gradient(1px 1px at 50% 70%,rgba(255,110,199,.25),transparent),radial-gradient(1px 1px at 80% 20%,rgba(0,212,255,.25),transparent);background-size:200% 200%;animation:mapParticleDrift 25s linear infinite;pointer-events:none;z-index:0}.map-sparkle{position:absolute;z-index:2;pointer-events:none}.map-sparkle img{width:26px;height:26px;object-fit:contain}.map-sparkle-1{top:12%;left:8%;animation:mapDrift1 9s ease-in-out infinite}.map-sparkle-1 img{filter:drop-shadow(0 0 8px rgba(255,110,199,.5))}.map-sparkle-2{top:40%;right:6%;animation:mapDrift2 11s ease-in-out infinite}.map-sparkle-2 img{filter:drop-shadow(0 0 8px rgba(0,212,255,.5))}.map-sparkle-3{bottom:15%;left:12%;animation:mapDrift3 8s ease-in-out infinite}.map-sparkle-3 img{filter:drop-shadow(0 0 8px rgba(185,103,255,.5))}.map-hint-icon{width:16px;height:16px;object-fit:contain}.map-hint{display:flex;align-items:center;gap:.4rem;padding:.35rem 1rem;background:#b967ff1f;border:1px solid rgba(185,103,255,.3);border-radius:20px;color:#b967ffe6;font-family:var(--font-family-display);font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.75rem;animation:hintPulse 2s ease-in-out infinite;z-index:2;flex-shrink:0}.map-scroll-area{position:relative;width:100%;max-width:600px;flex:1;min-height:0;background:#0000004d;border-radius:8px;border:1px solid rgba(185,103,255,.15);box-shadow:0 0 20px #b967ff0f,inset 0 0 30px #0000004d;overflow:hidden;z-index:1}.map-connections{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.map-floor{position:absolute;width:100%;height:0}.map-node{position:absolute;top:0;transform:translate(-50%,-50%);z-index:5;cursor:pointer;transition:transform .2s,filter .2s}.map-node:not(.available):not(.completed){filter:brightness(.5);cursor:not-allowed}.map-node.completed{filter:grayscale(1);opacity:.5}.map-node.available .node-circle{animation:nodePulse 2s infinite;border-color:#ff6ec799}.map-node.available:hover{transform:translate(-50%,-50%) scale(1.2)}.node-circle{width:36px;height:36px;background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 6px #0009}.node-icon.combat{color:var(--color-text-secondary)}.node-icon.elite{color:#ff3860}.node-icon.rest{color:#39ff14}.node-icon.shop{color:#ffb347}.node-icon.boss{color:#ff3860}.node-icon.unknown{color:#b967ff;font-weight:700;font-size:1.2rem;font-family:var(--font-family-display)}.map-legend{display:flex;gap:1rem;justify-content:center;padding:.5rem 0;margin-top:.5rem;z-index:2;flex-shrink:0}.map-legend-item{display:flex;align-items:center;gap:.25rem;font-size:.6rem;color:var(--color-text-secondary);font-family:var(--font-family-display);text-transform:uppercase;letter-spacing:1px}.map-loading{display:flex;align-items:center;justify-content:center;height:100%;font-family:var(--font-family-display);font-size:1.2rem;color:var(--color-text-secondary)}@media(min-width:769px){.map-view-container{top:60px;padding:2rem}.node-circle{width:44px;height:44px}.node-icon.unknown{font-size:1.5rem}.map-hint{font-size:.8rem;padding:.4rem 1.25rem;margin-bottom:1rem}.map-legend{gap:1.5rem;padding:.75rem 0;margin-top:.75rem}.map-legend-item{font-size:.7rem}}@keyframes restFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes restFlicker{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}@keyframes restGlowPulse{0%,to{box-shadow:0 0 60px #ffa03c40,0 0 120px #ff641e1a}50%{box-shadow:0 0 80px #ffa03c66,0 0 160px #ff641e33}}@keyframes restResultPop{0%{opacity:0;transform:scale(.8)}60%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.rest-container{height:100%;width:100%;display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% 30%,rgba(255,140,50,.08) 0%,transparent 60%),var(--color-bg-base);overflow-y:auto;overflow-x:hidden}.rest-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:1rem 1rem 2rem;animation:restFadeIn .6s ease both}.rest-campfire{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem;margin-top:.5rem}.rest-campfire-glow{position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(circle,rgba(255,160,60,.3) 0%,rgba(255,100,30,.1) 50%,transparent 70%);animation:restGlowPulse 3s ease-in-out infinite}.rest-flame-icon{color:var(--color-accent-amber);filter:drop-shadow(0 0 12px rgba(255,160,60,.6));animation:restFlicker 2s ease-in-out infinite;z-index:1}.rest-deco-icon{position:absolute;width:20px;height:20px;opacity:.3;filter:grayscale(.5)}.rest-deco-left{bottom:0;left:0;transform:rotate(-12deg)}.rest-deco-right{bottom:0;right:0;transform:rotate(12deg)}.rest-title{font-family:var(--font-family-display);font-size:1.8rem;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:3px;margin:0 0 .25rem;text-shadow:0 0 20px rgba(255,160,60,.3);text-align:center}.rest-subtitle{font-size:.8rem;color:var(--color-text-secondary);margin:0 0 1rem;font-style:italic;text-align:center}.rest-hp-display{display:flex;align-items:center;gap:.4rem;font-family:var(--font-family-display);font-size:1rem;color:var(--color-accent-red);margin-bottom:1.25rem;letter-spacing:1px}.rest-hp-icon{color:var(--color-accent-red);fill:var(--color-accent-red)}.rest-choices{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:320px;animation:restFadeIn .6s ease .2s both}.rest-choice{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .25s ease;text-align:left;color:var(--color-text-primary);font-family:var(--font-family-base)}.rest-choice:active{transform:scale(.97)}.rest-choice-heal{border-color:#ff386066}.rest-choice-heal:hover{border-color:var(--color-accent-red);background:#ff386014;box-shadow:0 0 20px #ff386026}.rest-choice-smith{border-color:#ffb34766}.rest-choice-smith:hover{border-color:var(--color-accent-amber);background:#ffb34714;box-shadow:0 0 20px #ffb34726}.rest-choice-icon-wrap{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rest-choice-heal .rest-choice-icon-wrap{background:#ff386026;color:var(--color-accent-red)}.rest-choice-smith .rest-choice-icon-wrap{background:#ffb34726;color:var(--color-accent-amber)}.rest-choice-text{display:flex;flex-direction:column;gap:.15rem}.rest-choice-label{font-family:var(--font-family-display);font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}.rest-choice-desc{font-size:.75rem;color:var(--color-text-secondary);line-height:1.3}.rest-smith-panel{width:100%;max-width:360px;animation:restFadeIn .4s ease both}.rest-smith-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.rest-back-btn{display:flex;align-items:center;gap:.25rem;background:none;border:1px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-family-base);font-size:.75rem;padding:.3rem .6rem;border-radius:6px;cursor:pointer;transition:all .2s;flex-shrink:0}.rest-back-btn:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.rest-smith-title{font-family:var(--font-family-display);font-size:.9rem;color:var(--color-accent-amber);text-transform:uppercase;letter-spacing:1px}.rest-no-cards{font-size:.85rem;color:var(--color-text-secondary);text-align:center;margin:2rem 0;font-style:italic}.rest-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:50vh;overflow-y:auto;padding:2px;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.rest-card-grid::-webkit-scrollbar{width:4px}.rest-card-grid::-webkit-scrollbar-track{background:transparent}.rest-card-grid::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.rest-card-option{display:flex;flex-direction:column;padding:.25rem;background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .2s;color:var(--color-text-primary);font-family:var(--font-family-base);position:relative;text-align:center}.rest-card-option:active{transform:scale(.95)}.rest-card-option:hover{border-color:var(--color-accent-amber);box-shadow:0 0 16px #ffb34733;transform:translateY(-2px)}.rest-card-option.type-attack{border-color:#ff386080}.rest-card-option.type-attack:hover{border-color:var(--color-accent-red);box-shadow:0 0 16px #ff38604d}.rest-card-option.type-skill{border-color:#00d4ff80}.rest-card-option.type-skill:hover{border-color:var(--color-accent-blue);box-shadow:0 0 16px #00d4ff4d}.rest-card-option.type-power{border-color:#b967ff80}.rest-card-option.type-power:hover{border-color:var(--color-accent-violet);box-shadow:0 0 16px #b967ff4d}.rest-card-option.hero{border-color:#ffd70080;background:linear-gradient(180deg,var(--color-bg-surface) 0%,rgba(255,215,0,.06) 100%)}.rest-card-option.hero:hover{border-color:gold;box-shadow:0 0 16px #ffd7004d}.rest-card-cost{position:absolute;top:-4px;left:-4px;width:16px;height:16px;background:var(--color-accent-violet);border:1px solid #ffb3e6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.55rem;box-shadow:0 2px 4px #00000080;z-index:1}.rest-card-option.hero .rest-card-cost{background:linear-gradient(135deg,gold,#fa0);border-color:#fff8dc;color:#1a1a2e}.rest-card-name{font-family:var(--font-family-display);font-size:.55rem;text-transform:uppercase;margin-bottom:.1rem}.rest-card-option.hero .rest-card-name{color:gold}.rest-card-art-wrap{width:calc(100% + .5rem);margin-left:-.25rem;margin-right:-.25rem;aspect-ratio:4/3;border-radius:3px;overflow:hidden;background:var(--color-bg-base)}.rest-card-art{width:106%;height:106%;margin:-3% 0 0 -3%;object-fit:cover}.rest-card-desc{font-size:.45rem;line-height:1.15;color:var(--color-text-secondary);margin-top:.1rem;flex-grow:1}.rest-card-upgrade-hint{display:flex;align-items:center;justify-content:center;gap:.2rem;font-size:.45rem;color:var(--color-accent-amber);margin-top:.2rem;opacity:0;transition:opacity .2s}.rest-card-option:hover .rest-card-upgrade-hint{opacity:1}.rest-result{display:flex;flex-direction:column;align-items:center;gap:1rem;animation:restResultPop .5s ease both;margin-top:1rem}.rest-result-icon{width:56px;height:56px;border-radius:50%;background:#39ff141f;border:2px solid var(--color-accent-green);display:flex;align-items:center;justify-content:center;color:var(--color-accent-green)}.rest-result-text{font-family:var(--font-family-display);font-size:1.1rem;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:1px;text-align:center;margin:0;max-width:280px}.rest-continue-btn{padding:.75rem 2rem;font-family:var(--font-family-display);font-size:1rem;text-transform:uppercase;letter-spacing:2px;background:var(--color-bg-elevated);border:2px solid var(--color-border);color:var(--color-text-primary);border-radius:8px;cursor:pointer;transition:all .25s ease}.rest-continue-btn:hover{border-color:var(--color-accent-amber);box-shadow:0 0 16px #ffb34733;transform:translateY(-2px)}.rest-continue-btn:active{transform:scale(.97)}@media(min-width:769px){.rest-content{padding:2rem 2rem 3rem}.rest-campfire{width:140px;height:140px;margin-bottom:1rem}.rest-flame-icon{width:64px;height:64px}.rest-deco-icon{width:28px;height:28px}.rest-title{font-size:2.5rem;letter-spacing:5px}.rest-subtitle{font-size:1rem;margin-bottom:1.5rem}.rest-hp-display{font-size:1.2rem;margin-bottom:1.5rem}.rest-choices{flex-direction:row;max-width:560px}.rest-choice{flex:1;flex-direction:column;text-align:center;padding:1.5rem 1rem}.rest-choice-icon-wrap{width:56px;height:56px}.rest-choice-text{align-items:center}.rest-choice-label{font-size:1.3rem}.rest-choice-desc{font-size:.85rem;text-align:center}.rest-smith-panel{max-width:600px}.rest-card-grid{grid-template-columns:repeat(4,1fr);gap:12px;max-height:55vh}.rest-card-name{font-size:.7rem}.rest-card-desc{font-size:.55rem}.rest-card-cost{width:20px;height:20px;font-size:.65rem}.rest-card-upgrade-hint{font-size:.55rem}.rest-result-text{font-size:1.4rem;max-width:400px}.rest-continue-btn{padding:1rem 3rem;font-size:1.2rem}}.shop-container{position:fixed;inset:0;background:var(--color-bg-base);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;z-index:100;font-family:var(--font-family-base)}.shop-header{position:relative;text-align:center;padding:1.5rem 1rem 1rem;background:radial-gradient(ellipse at 50% 120%,rgba(255,56,96,.15) 0%,transparent 60%),var(--color-bg-base);border-bottom:2px solid rgba(255,56,96,.3)}.shop-neon-sign{font-family:var(--font-family-display);font-size:1.8rem;text-transform:uppercase;letter-spacing:4px;color:#ff6ec7;text-shadow:0 0 10px rgba(255,110,199,.6),0 0 30px rgba(255,110,199,.3),0 0 60px rgba(255,110,199,.15);margin:0 0 .25rem;animation:shopNeonFlicker 4s ease-in-out infinite}@keyframes shopNeonFlicker{0%,to{text-shadow:0 0 10px rgba(255,110,199,.6),0 0 30px rgba(255,110,199,.3),0 0 60px rgba(255,110,199,.15)}50%{text-shadow:0 0 15px rgba(255,110,199,.8),0 0 40px rgba(255,110,199,.5),0 0 80px rgba(255,110,199,.25)}93%{text-shadow:0 0 10px rgba(255,110,199,.6),0 0 30px rgba(255,110,199,.3)}94%{text-shadow:0 0 2px rgba(255,110,199,.2)}95%{text-shadow:0 0 10px rgba(255,110,199,.6),0 0 30px rgba(255,110,199,.3)}}.shop-tagline{font-size:.75rem;color:var(--color-text-secondary);font-style:italic;letter-spacing:1px;margin:0}.shop-gold-display{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.75rem;font-family:var(--font-family-display);font-size:1.1rem;color:#ffb347;text-shadow:0 0 8px rgba(255,179,71,.4)}.shop-gold-icon{color:#ffb347}.shop-section{padding:1rem 1rem .5rem}.shop-section-title{font-family:var(--font-family-display);font-size:.85rem;text-transform:uppercase;letter-spacing:2px;color:var(--color-text-secondary);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.shop-section-title:after{content:"";flex:1;height:1px;background:linear-gradient(to right,var(--color-border),transparent)}.shop-cards-row{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.shop-card-slot{display:flex;flex-direction:column;align-items:center;gap:.4rem;cursor:pointer;transition:transform .2s ease}.shop-card-slot:hover:not(.shop-card-slot--sold):not(.shop-card-slot--broke){transform:translateY(-4px)}.shop-card-slot--broke{cursor:not-allowed}.shop-card-slot--sold{cursor:default;opacity:0;pointer-events:none;transition:opacity .3s ease}.shop-card-preview{width:var(--card-width);height:var(--card-height);background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:6px;padding:.25rem;display:flex;flex-direction:column;box-shadow:0 4px 12px #000c;position:relative;transition:box-shadow .2s ease,border-color .2s ease}.shop-card-preview.type-attack{border-color:var(--color-accent-red);box-shadow:0 4px 12px #000c,0 0 8px #ff386033}.shop-card-preview.type-skill{border-color:var(--color-accent-blue);box-shadow:0 4px 12px #000c,0 0 8px #00d4ff33}.shop-card-preview.type-power{border-color:var(--color-accent-violet);box-shadow:0 4px 12px #000c,0 0 8px #b967ff33}.shop-card-slot:hover:not(.shop-card-slot--broke) .shop-card-preview{box-shadow:0 8px 24px #000000e6,0 0 20px #ff6ec74d;border-color:#ff6ec7}.shop-card-preview--broke{filter:grayscale(80%) brightness(.5);opacity:.6}.shop-card-cost{position:absolute;top:-3px;left:-3px;width:15px;height:15px;background:var(--color-accent-violet);border:1px solid #ffb3e6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.55rem;box-shadow:0 2px 4px #00000080}.shop-card-name{font-family:var(--font-family-display);font-weight:700;font-size:.6rem;text-align:center;margin-bottom:.1rem;text-transform:uppercase}.shop-card-artwork-wrap{position:relative;width:calc(100% + .5rem);margin-left:-.25rem;margin-right:-.25rem;aspect-ratio:4/3;border-radius:3px;overflow:hidden;background-color:var(--color-bg-base)}.shop-card-artwork{width:106%;height:106%;margin:-3% 0 0 -3%;object-fit:cover}.shop-card-type-badge{position:absolute;bottom:3px;left:50%;transform:translate(-50%);font-size:.35rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:.05rem .3rem;background:#000000b3;color:var(--color-text-secondary);border-radius:6px;border:1px solid rgba(255,255,255,.15);white-space:nowrap}.shop-card-desc{font-size:.5rem;line-height:1.15;text-align:center;flex-grow:1;display:flex;align-items:center;justify-content:center}.shop-price-tag{display:flex;align-items:center;gap:.25rem;font-family:var(--font-family-display);font-size:.85rem;font-weight:700;color:#ffb347;text-shadow:0 0 6px rgba(255,179,71,.3);padding:.15rem .5rem;background:#ffb34714;border:1px solid rgba(255,179,71,.25);border-radius:20px}.shop-price-tag--broke{color:#666;text-shadow:none;border-color:#ffffff1a;background:#ffffff08}.shop-price-icon{width:14px;height:14px}.shop-removal{padding:1rem}.shop-removal-offer{display:flex;align-items:center;justify-content:space-between;background:#ff38600f;border:1px solid rgba(255,56,96,.2);border-radius:8px;padding:.75rem 1rem;cursor:pointer;transition:all .2s ease}.shop-removal-offer:hover:not(.shop-removal-offer--broke){background:#ff38601f;border-color:#ff386066;transform:translateY(-2px);box-shadow:0 4px 16px #ff386026}.shop-removal-offer--broke{cursor:not-allowed;opacity:.5}.shop-removal-info{display:flex;flex-direction:column;gap:.15rem}.shop-removal-title{font-family:var(--font-family-display);font-size:.9rem;text-transform:uppercase;letter-spacing:1px;color:#ff3860;display:flex;align-items:center;gap:.4rem}.shop-removal-desc{font-size:.7rem;color:var(--color-text-secondary);font-style:italic}.shop-removal-overlay{position:fixed;inset:0;background:#000000d9;z-index:200;display:flex;flex-direction:column;padding:1rem;overflow-y:auto}.shop-removal-overlay-header{text-align:center;margin-bottom:1rem;flex-shrink:0}.shop-removal-overlay-title{font-family:var(--font-family-display);font-size:1.2rem;text-transform:uppercase;letter-spacing:2px;color:#ff3860;margin:0 0 .25rem}.shop-removal-overlay-sub{font-size:.75rem;color:var(--color-text-secondary);margin:0}.shop-removal-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;padding-bottom:4rem}.shop-removal-card-slot{display:flex;flex-direction:column;align-items:center;gap:.3rem;cursor:pointer;transition:transform .2s ease}.shop-removal-card-slot:hover{transform:translateY(-4px)}.shop-removal-card-slot:hover .shop-card-preview{border-color:#ff3860;box-shadow:0 8px 24px #000000e6,0 0 20px #ff386066}.shop-removal-cancel{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);font-family:var(--font-family-display);font-size:.9rem;text-transform:uppercase;letter-spacing:1px;padding:.6rem 1.5rem;background:var(--color-bg-elevated);border:2px solid var(--color-border);color:var(--color-text-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;z-index:201}.shop-removal-cancel:hover{border-color:var(--color-text-secondary);transform:translate(-50%) translateY(-2px)}.shop-confirm-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:300}.shop-confirm-dialog{background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:12px;padding:1.5rem;text-align:center;max-width:280px;width:90%;box-shadow:0 8px 32px #000c}.shop-confirm-title{font-family:var(--font-family-display);font-size:1rem;text-transform:uppercase;letter-spacing:1px;margin:0 0 .5rem;color:var(--color-text-primary)}.shop-confirm-price{font-family:var(--font-family-display);font-size:1.2rem;color:#ffb347;margin:0 0 1rem;display:flex;align-items:center;justify-content:center;gap:.3rem}.shop-confirm-buttons{display:flex;gap:.75rem;justify-content:center}.shop-confirm-btn{font-family:var(--font-family-display);font-size:.85rem;text-transform:uppercase;letter-spacing:1px;padding:.5rem 1.25rem;border-radius:6px;cursor:pointer;transition:all .2s ease;border:2px solid}.shop-confirm-btn--buy{background:linear-gradient(135deg,#ff3860,#b967ff);border-color:#ff6ec7;color:#fff}.shop-confirm-btn--buy:hover{background:linear-gradient(135deg,#ff6ec7,#b967ff);transform:translateY(-2px);box-shadow:0 4px 16px #ff6ec766}.shop-confirm-btn--cancel{background:transparent;border-color:var(--color-border);color:var(--color-text-secondary)}.shop-confirm-btn--cancel:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.shop-toast{position:fixed;bottom:5rem;left:50%;transform:translate(-50%);font-family:var(--font-family-display);font-size:.8rem;text-transform:uppercase;letter-spacing:1px;padding:.5rem 1.25rem;background:#39ff1426;border:1px solid rgba(57,255,20,.4);color:#39ff14;border-radius:8px;animation:shopToastIn .3s ease,shopToastOut .3s ease 1.5s forwards;z-index:400;pointer-events:none}@keyframes shopToastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes shopToastOut{0%{opacity:1}to{opacity:0}}.shop-footer{padding:.75rem 1rem 1.5rem;display:flex;justify-content:center;flex-shrink:0}.shop-leave-btn{font-family:var(--font-family-display);font-size:1rem;text-transform:uppercase;letter-spacing:2px;padding:.65rem 2rem;background:var(--color-bg-elevated);border:2px solid var(--color-border);color:var(--color-text-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.shop-leave-btn:hover{border-color:#00d4ff;color:#00d4ff;transform:translateY(-2px);box-shadow:0 4px 16px #00d4ff33}.shop-broke-hint{text-align:center;font-size:.7rem;color:#666;font-style:italic;padding:.25rem 0}.shop-scanlines{position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,0,0,.08) 2px,rgba(0,0,0,.08) 4px);pointer-events:none;opacity:.3;z-index:101}@media(min-width:769px){.shop-header{padding:2rem 2rem 1.25rem}.shop-neon-sign{font-size:2.5rem;letter-spacing:6px}.shop-tagline{font-size:.9rem}.shop-gold-display{font-size:1.3rem}.shop-section{padding:1.5rem 2rem .75rem;max-width:700px;margin:0 auto}.shop-section-title{font-size:1rem}.shop-card-preview{padding:.5rem;border-width:3px;border-radius:10px}.shop-card-cost{width:22px;height:22px;font-size:.75rem;top:-6px;left:-6px;border-width:2px}.shop-card-name{font-size:.85rem;margin-bottom:.15rem}.shop-card-artwork-wrap{width:calc(100% + 1rem);margin-left:-.5rem;margin-right:-.5rem;border-radius:5px}.shop-card-type-badge{font-size:.5rem;padding:.1rem .4rem;bottom:5px;border-radius:8px}.shop-card-desc{font-size:.7rem;line-height:1.2}.shop-price-tag{font-size:1rem}.shop-removal{padding:1rem 2rem;max-width:700px;margin:0 auto}.shop-footer{padding:1rem 2rem 2rem}.shop-leave-btn{font-size:1.1rem;padding:.75rem 2.5rem}}@keyframes mysteryFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes mysteryGlow{0%,to{box-shadow:0 0 12px #b967ff40,inset 0 0 12px #b967ff0d;border-color:#b967ff59}50%{box-shadow:0 0 24px #b967ff73,inset 0 0 20px #b967ff14;border-color:#b967ff8c}}@keyframes mysteryPulse{0%,to{opacity:.06}50%{opacity:.12}}@keyframes mysteryTitleFlicker{0%,90%,to{opacity:1}92%{opacity:.7}94%{opacity:1}96%{opacity:.85}}.mystery-container{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 30%,rgba(185,103,255,.08) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(255,56,96,.04) 0%,transparent 50%),var(--color-bg-base);padding:1rem;box-sizing:border-box;overflow-y:auto;z-index:100}.mystery-container:before{content:"";position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 3px,rgba(0,0,0,.08) 3px,rgba(0,0,0,.08) 6px);pointer-events:none;opacity:.5;z-index:1}.mystery-container:after{content:"";position:fixed;top:10%;left:50%;transform:translate(-50%);width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(185,103,255,.12) 0%,transparent 70%);pointer-events:none;animation:mysteryPulse 4s ease-in-out infinite}.mystery-content{position:relative;z-index:2;max-width:420px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1.25rem;animation:mysteryFadeIn .6s ease both}.mystery-title{font-family:var(--font-family-display);font-size:2rem;color:var(--color-accent-violet);text-transform:uppercase;letter-spacing:3px;text-align:center;margin:0;text-shadow:0 0 20px rgba(185,103,255,.5),0 0 40px rgba(185,103,255,.2);animation:mysteryTitleFlicker 4s ease-in-out infinite}.mystery-description{font-family:var(--font-family-base);font-size:.85rem;line-height:1.6;color:var(--color-text-secondary);text-align:center;margin:0;padding:1rem 1.25rem;background:#1a1a2eb3;border:1px solid rgba(185,103,255,.15);border-radius:8px;animation:mysteryGlow 5s ease-in-out infinite}.mystery-choices{display:flex;flex-direction:column;gap:.75rem;width:100%}.mystery-choice{display:flex;flex-direction:column;gap:.25rem;padding:.85rem 1rem;background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .25s ease;text-align:left;animation:mysteryFadeIn .5s ease both}.mystery-choice:nth-child(1){animation-delay:.15s}.mystery-choice:nth-child(2){animation-delay:.3s}.mystery-choice:nth-child(3){animation-delay:.45s}.mystery-choice:hover{border-color:var(--color-accent-violet);background:var(--color-bg-elevated);box-shadow:0 0 16px #b967ff40,inset 0 0 8px #b967ff0d;transform:translate(4px)}.mystery-choice:active{transform:translate(2px) scale(.98)}.mystery-choice-label{font-family:var(--font-family-display);font-size:1.15rem;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;gap:.5rem}.mystery-choice-label svg{color:var(--color-accent-violet);flex-shrink:0}.mystery-choice-desc{font-family:var(--font-family-base);font-size:.75rem;color:var(--color-text-secondary);padding-left:1.5rem}.mystery-outcome{display:flex;flex-direction:column;align-items:center;gap:1.25rem;width:100%;animation:mysteryFadeIn .5s ease both}.mystery-outcome-text{font-family:var(--font-family-base);font-size:.9rem;line-height:1.6;color:var(--color-text-primary);text-align:center;padding:1rem 1.25rem;background:#1a1a2eb3;border:1px solid rgba(57,255,20,.2);border-radius:8px;box-shadow:0 0 12px #39ff141a;width:100%;box-sizing:border-box}.mystery-continue-btn{font-family:var(--font-family-display);font-size:1.1rem;text-transform:uppercase;letter-spacing:2px;padding:.75rem 2rem;background:var(--color-bg-elevated);border:2px solid var(--color-accent-violet);border-radius:8px;color:var(--color-text-primary);cursor:pointer;transition:all .25s ease}.mystery-continue-btn:hover{background:#b967ff26;box-shadow:0 0 20px #b967ff4d;transform:translateY(-2px)}.mystery-continue-btn:active{transform:translateY(0) scale(.97)}.mystery-icon-decor{width:48px;height:48px;opacity:.5;filter:drop-shadow(0 0 8px rgba(185,103,255,.4));animation:mysteryFadeIn .4s ease both}@media(min-width:769px){.mystery-content{max-width:520px;gap:1.5rem}.mystery-title{font-size:2.8rem;letter-spacing:5px}.mystery-description{font-size:.95rem;padding:1.25rem 1.5rem}.mystery-choice{padding:1rem 1.25rem}.mystery-choice-label{font-size:1.25rem}.mystery-choice-desc{font-size:.8rem}.mystery-icon-decor{width:56px;height:56px}.mystery-container:after{width:500px;height:500px}}.game-over-container{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-color:var(--color-bg-base);background-image:radial-gradient(circle at center,rgba(255,56,96,.1) 0%,transparent 60%);color:var(--color-text-primary);padding:1rem}.game-over-content{display:flex;flex-direction:column;align-items:center;text-align:center;background:#1a0d14e6;padding:1.5rem;border-radius:8px;border:2px solid var(--color-accent-red);box-shadow:0 10px 30px #00000080,inset 0 0 20px #ff386026;animation:fade-in-up .5s ease-out forwards;max-width:100%}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.game-over-icon{color:var(--color-accent-red);margin-bottom:.75rem;filter:drop-shadow(0 0 10px rgba(255,56,96,.5))}.game-over-title{font-family:var(--font-family-display);font-size:2.5rem;color:var(--color-accent-red);margin:0;text-transform:uppercase;letter-spacing:2px;text-shadow:2px 2px 0px rgba(0,0,0,.8)}.game-over-stats{font-size:1.1rem;color:var(--color-text-secondary);margin:1rem 0 1.5rem}.game-over-stats strong{color:#fff}.game-over-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.restart-button,.retry-seed-button{font-family:var(--font-family-display);padding:.6rem 1rem;font-size:.9rem;cursor:pointer;border-radius:8px;transition:all .2s ease;text-transform:uppercase;font-weight:700}.restart-button{background-color:var(--color-accent-red);color:#fff;border:none}.restart-button:hover{filter:brightness(1.2);transform:scale(1.05)}.retry-seed-button{background-color:transparent;color:var(--color-text-secondary);border:1px solid var(--color-text-secondary)}.retry-seed-button:hover{color:#fff;border-color:#fff;background-color:#ffffff1a}@media(min-width:769px){.game-over-container{padding:2rem}.game-over-content{padding:3rem}.game-over-icon{margin-bottom:1rem}.game-over-title{font-size:4rem;letter-spacing:4px}.game-over-stats{font-size:1.5rem;margin:1.5rem 0 2.5rem}.game-over-actions{gap:1rem}.restart-button,.retry-seed-button{padding:.8rem 1.5rem;font-size:1.2rem}}@keyframes sparkleDrift1{0%{transform:translate(0) rotate(0) scale(.8);opacity:.3}25%{transform:translate(15px,-20px) rotate(90deg) scale(1.1);opacity:.7}50%{transform:translate(-5px,-35px) rotate(180deg) scale(.9);opacity:.5}75%{transform:translate(-18px,-15px) rotate(270deg) scale(1.2);opacity:.8}to{transform:translate(0) rotate(360deg) scale(.8);opacity:.3}}@keyframes sparkleDrift2{0%{transform:translate(0) rotate(0) scale(1);opacity:.4}25%{transform:translate(-20px,-10px) rotate(-90deg) scale(.7);opacity:.8}50%{transform:translate(10px,-30px) rotate(-180deg) scale(1.15);opacity:.35}75%{transform:translate(20px,-5px) rotate(-270deg) scale(.85);opacity:.7}to{transform:translate(0) rotate(-360deg) scale(1);opacity:.4}}@keyframes sparkleDrift3{0%{transform:translate(0) rotate(0) scale(.9);opacity:.5}33%{transform:translate(12px,-25px) rotate(120deg) scale(1.2);opacity:.3}66%{transform:translate(-15px,-10px) rotate(240deg) scale(.75);opacity:.8}to{transform:translate(0) rotate(360deg) scale(.9);opacity:.5}}@keyframes sparkleDrift4{0%{transform:translate(0) rotate(0) scale(1.1);opacity:.35}20%{transform:translate(-10px,-30px) rotate(72deg) scale(.8);opacity:.75}40%{transform:translate(18px,-20px) rotate(144deg) scale(1.15);opacity:.4}60%{transform:translate(5px,-40px) rotate(216deg) scale(.7);opacity:.85}80%{transform:translate(-15px,-12px) rotate(288deg) scale(1.05);opacity:.45}to{transform:translate(0) rotate(360deg) scale(1.1);opacity:.35}}@keyframes orbitSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes portalPulse{0%,to{box-shadow:0 0 20px #b967ff4d,0 0 40px #ff6ec726,inset 0 0 30px #00000080;border-color:#b967ff80}50%{box-shadow:0 0 30px #ff386066,0 0 60px #b967ff40,inset 0 0 30px #00000080;border-color:#ff386099}}@keyframes bgDrift{0%{background-position:0% 0%}to{background-position:200% 200%}}.selfie-screen{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;background:radial-gradient(ellipse at 30% 20%,rgba(185,103,255,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(255,56,96,.06) 0%,transparent 50%),var(--color-bg-base);padding:1rem;box-sizing:border-box;overflow:hidden}.selfie-screen:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,0,0,.08) 2px,rgba(0,0,0,.08) 4px);pointer-events:none;opacity:.5;z-index:0}.selfie-screen:after{content:"";position:absolute;inset:0;background-image:radial-gradient(1px 1px at 15% 25%,rgba(185,103,255,.4),transparent),radial-gradient(1px 1px at 35% 65%,rgba(255,110,199,.3),transparent),radial-gradient(1px 1px at 55% 15%,rgba(0,212,255,.3),transparent),radial-gradient(1px 1px at 75% 45%,rgba(185,103,255,.3),transparent),radial-gradient(1px 1px at 85% 85%,rgba(255,56,96,.3),transparent);background-size:200% 200%;animation:bgDrift 20s linear infinite;pointer-events:none;z-index:0}.selfie-sparkle{position:absolute;z-index:1;pointer-events:none}.selfie-sparkle img{width:32px;height:32px;object-fit:contain}.selfie-sparkle-1{top:15%;left:10%;animation:sparkleDrift1 8s ease-in-out infinite}.selfie-sparkle-1 img{filter:drop-shadow(0 0 8px rgba(255,110,199,.6))}.selfie-sparkle-2{top:20%;right:12%;animation:sparkleDrift2 10s ease-in-out infinite}.selfie-sparkle-2 img{filter:drop-shadow(0 0 8px rgba(0,212,255,.6))}.selfie-sparkle-3{bottom:25%;left:15%;animation:sparkleDrift3 7s ease-in-out infinite}.selfie-sparkle-3 img{filter:drop-shadow(0 0 8px rgba(185,103,255,.6))}.selfie-sparkle-4{bottom:18%;right:10%;animation:sparkleDrift4 12s ease-in-out infinite}.selfie-sparkle-4 img{filter:drop-shadow(0 0 8px rgba(255,56,96,.6))}.selfie-back-btn{position:absolute;top:1rem;left:1rem;background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10}.selfie-back-btn:hover{border-color:#fff;color:#fff;background:#ffffff1a}.selfie-title{font-family:var(--font-family-display);font-size:1.5rem;color:var(--color-text-highlight);text-shadow:0 0 20px rgba(255,110,199,.4),0 0 40px rgba(185,103,255,.2);margin:0 0 .25rem;text-transform:uppercase;letter-spacing:2px;z-index:1}.selfie-subtitle{font-size:.85rem;color:var(--color-text-secondary);margin:0 0 1rem;font-style:italic;z-index:1}.selfie-viewport{position:relative;width:250px;height:250px;border-radius:50%;overflow:visible;flex-shrink:0;z-index:1}.selfie-orbit-ring{position:absolute;inset:-12px;border-radius:50%;border:2px dashed rgba(185,103,255,.3);animation:orbitSpin 8s linear infinite;pointer-events:none}.selfie-orbit-ring:before{content:"";position:absolute;top:-4px;left:50%;width:8px;height:8px;border-radius:50%;background:#b967ff;box-shadow:0 0 10px #b967ffcc}.selfie-orbit-ring:after{content:"";position:absolute;bottom:-4px;left:50%;width:6px;height:6px;border-radius:50%;background:#ff6ec7;box-shadow:0 0 10px #ff6ec7cc}.selfie-video{width:250px;height:250px;object-fit:cover;transform:scaleX(-1);opacity:0;transition:opacity .3s ease;border-radius:50%}.selfie-video.ready{opacity:1}.selfie-frame{position:absolute;inset:0;border-radius:50%;border:3px solid rgba(185,103,255,.4);pointer-events:none;animation:portalPulse 3s ease-in-out infinite}.selfie-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:250px;height:250px;border-radius:50%;background:var(--color-bg-surface);color:var(--color-text-secondary);gap:.5rem}.selfie-placeholder p{margin:0;font-size:.8rem}.selfie-error{color:var(--color-accent-red);font-size:.85rem;margin:1.25rem 0 0;text-align:center;max-width:280px;z-index:1}.selfie-actions{display:flex;flex-direction:column;align-items:center;gap:1.25rem;margin-top:2.5rem;z-index:1}.selfie-capture-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-family:var(--font-family-display);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#ff3860,#b967ff);border:2px solid #ff6ec7;color:#fff;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 0 15px #ff6ec74d}.selfie-capture-btn .btn-icon{width:24px;height:24px;object-fit:contain}.selfie-capture-btn:hover{background:linear-gradient(135deg,#ff6ec7,#b967ff);border-color:#ffb3e6;transform:translateY(-2px);box-shadow:0 4px 20px #ff6ec780,0 0 30px #b967ff4d}.selfie-upload-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-family:var(--font-family-display);font-size:.85rem;background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:8px;cursor:pointer;transition:all .2s}.selfie-upload-btn:hover{border-color:#fff;color:#fff;background:#ffffff1a}@keyframes genOrbitSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes genOrbitSpinReverse{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes burstPulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.generating-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;animation:backdrop-fade .3s ease-out forwards;z-index:1}@keyframes backdrop-fade{0%{opacity:0}to{opacity:1}}.generating-portal{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}.generating-orbit{position:absolute;border-radius:50%;border:2px dashed;pointer-events:none}.generating-orbit-1{inset:-16px;border-color:#b967ff59;animation:genOrbitSpin 6s linear infinite}.generating-orbit-1:before{content:"";position:absolute;top:-5px;left:50%;width:10px;height:10px;border-radius:50%;background:#b967ff;box-shadow:0 0 14px #b967ffe6}.generating-orbit-1:after{content:"";position:absolute;bottom:-4px;right:20%;width:6px;height:6px;border-radius:50%;background:#00d4ff;box-shadow:0 0 10px #00d4ffcc}.generating-orbit-2{inset:-32px;border-color:#ff386033;animation:genOrbitSpinReverse 10s linear infinite}.generating-orbit-2:before{content:"";position:absolute;top:10%;right:-5px;width:8px;height:8px;border-radius:50%;background:#ff3860;box-shadow:0 0 12px #ff3860cc}.generating-orbit-2:after{content:"";position:absolute;bottom:15%;left:-4px;width:6px;height:6px;border-radius:50%;background:#ff6ec7;box-shadow:0 0 10px #ff6ec7cc}.generating-selfie{width:180px;height:180px;border-radius:50%;object-fit:cover;border:3px solid var(--color-border);animation:selfie-pulse 2s ease-in-out infinite}@keyframes selfie-pulse{0%,to{border-color:#b967ff80;box-shadow:0 0 25px #b967ff4d,0 0 50px #ff6ec726}50%{border-color:var(--color-text-highlight);box-shadow:0 0 35px #ff6ec780,0 0 70px #b967ff40}}.generating-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.generating-magic-burst{display:flex;align-items:center;gap:.75rem}.generating-burst-icon{color:#b967ff99;animation:burstPulse 2s ease-in-out infinite}.generating-burst-icon.burst-left{animation-delay:0s;color:#ff6ec799}.generating-burst-icon.burst-right{animation-delay:1s;color:#00d4ff99}.generating-spinner{color:var(--color-text-highlight);animation:spin 1.5s linear infinite;filter:drop-shadow(0 0 10px rgba(255,110,199,.6))}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.generating-label{font-family:var(--font-family-display);font-size:.7rem;color:#b967ffb3;text-transform:uppercase;letter-spacing:3px;margin:0}.generating-text{font-family:var(--font-family-display);font-size:1.25rem;color:var(--color-text-highlight);margin:0;letter-spacing:1px;text-shadow:0 0 12px rgba(255,110,199,.4);animation:status-fade 3s ease infinite}@keyframes status-fade{0%{opacity:0;transform:translateY(6px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}@media(min-width:769px){.selfie-title{font-size:2rem}.selfie-subtitle{font-size:1rem;margin-bottom:1.5rem}.selfie-viewport,.selfie-video,.selfie-placeholder{width:320px;height:320px}.selfie-capture-btn{padding:.85rem 2rem;font-size:1.1rem}.selfie-upload-btn{font-size:.95rem;padding:.6rem 1.25rem}.generating-portal{width:260px;height:260px}.generating-selfie{width:240px;height:240px}.generating-text{font-size:1.5rem}}.reveal-screen{display:flex;flex-direction:column;align-items:center;height:100%;width:100%;background:var(--color-bg-base);padding:1.5rem 1rem;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;gap:.75rem}.reveal-header{text-align:center;opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}.reveal-header.visible{opacity:1;transform:translateY(0)}.reveal-archetype{font-family:var(--font-family-display);font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:3px;margin:0 0 .25rem}.reveal-name{font-family:var(--font-family-display);font-size:1.75rem;color:var(--color-text-highlight);text-shadow:0 0 20px rgba(255,110,199,.4);margin:0;text-transform:uppercase;letter-spacing:2px}.reveal-title{font-size:.85rem;color:var(--color-text-secondary);margin:.25rem 0 0;font-style:italic}.reveal-portrait{position:relative;width:140px;height:220px;border-radius:8px;overflow:hidden;border:2px solid var(--color-accent-violet);box-shadow:0 4px 12px #000c,0 0 10px #b967ff40;flex-shrink:0;opacity:0;filter:blur(10px);transform:scale(.9);transition:opacity 1s ease,filter 1.2s ease,transform 1s ease;background-color:var(--color-bg-surface)}.reveal-portrait.visible{opacity:1;filter:blur(0);transform:scale(1)}.reveal-portrait-img{width:106%;height:106%;margin:-3% 0 0 -3%;object-fit:cover}.reveal-traits{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem;opacity:0;transition:opacity .6s ease .3s}.reveal-traits.visible{opacity:1}.reveal-trait{font-size:.7rem;padding:.2rem .5rem;background:#ffffff14;border:1px solid var(--color-border);border-radius:12px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px}.reveal-hero-section{display:flex;flex-direction:column;align-items:center;gap:.4rem;opacity:0;transition:opacity .4s ease}.reveal-hero-section.visible{opacity:1}.reveal-hero-label{font-family:var(--font-family-display);font-size:.65rem;color:gold;text-transform:uppercase;letter-spacing:3px;margin:0;text-shadow:0 0 12px rgba(255,215,0,.4)}.reveal-hero-slot{opacity:0;transform:translateY(20px) scale(.9);animation:hero-reveal .6s ease forwards;animation-play-state:paused;animation-delay:.3s;cursor:pointer}.reveal-hero-section.visible .reveal-hero-slot{animation-play-state:running}.reveal-hero-slot .card{cursor:pointer;touch-action:manipulation}@media(hover:hover){.reveal-hero-slot .card:hover{transform:translateY(-4px) scale(1.05)!important;box-shadow:0 8px 24px #ffd7004d,0 4px 12px #000c}}@keyframes hero-reveal{0%{opacity:0;transform:translateY(20px) scale(.9);filter:blur(4px)}50%{filter:blur(0)}to{opacity:1;transform:translateY(0) scale(1)}}.reveal-cards{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%;max-width:600px;opacity:0;transition:opacity .4s ease}.reveal-cards.visible{opacity:1}.reveal-card-slot{opacity:0;transform:translateY(20px) scale(.9);animation:card-reveal .4s ease forwards;animation-play-state:paused;cursor:pointer}.reveal-card-slot .card{cursor:pointer;touch-action:manipulation}@media(hover:hover){.reveal-card-slot .card:hover{transform:translateY(-4px) scale(1.05)!important;box-shadow:0 8px 24px #ff6ec74d,0 4px 12px #000c}}.reveal-cards.visible .reveal-card-slot{animation-play-state:running}@keyframes card-reveal{to{opacity:1;transform:translateY(0) scale(1)}}.reveal-cta{font-family:var(--font-family-display);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:.75rem 2rem;background:linear-gradient(135deg,#ff3860,#b967ff);border:2px solid #ff6ec7;color:#fff;border-radius:8px;cursor:pointer;margin-top:.5rem;margin-bottom:1rem;flex-shrink:0;opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease,box-shadow .2s,background .2s}.reveal-cta.visible{opacity:1;transform:translateY(0);animation:cta-pulse 2s ease-in-out infinite}@keyframes cta-pulse{0%,to{box-shadow:0 0 10px #ff6ec74d}50%{box-shadow:0 0 25px #ff6ec799}}.reveal-cta:hover{background:linear-gradient(135deg,#ff6ec7,#b967ff);border-color:#ffb3e6;transform:translateY(-2px)}.card-lightbox-overlay{position:fixed;inset:0;background:#000000d9;z-index:1000;display:flex;align-items:center;justify-content:center;animation:lightbox-fade-in .2s ease}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.card-lightbox{position:relative;display:flex;align-items:center;justify-content:center;gap:1rem;max-width:90vw;max-height:90vh}.lightbox-close{position:absolute;top:-40px;right:-8px;background:none;border:none;color:#fff9;cursor:pointer;padding:4px;z-index:1001;transition:color .2s}.lightbox-close:hover{color:#fff}.lightbox-card{--card-width: 240px;--card-height: 340px;pointer-events:none;animation:lightbox-card-pop .25s cubic-bezier(.2,.8,.2,1)}.lightbox-card .card{cursor:default;padding:.6rem;border-width:3px;border-radius:10px}.lightbox-card .card-cost{width:24px;height:24px;font-size:.85rem;top:-6px;left:-6px;border-width:2px}.lightbox-card .card-type-badge{font-size:.6rem;padding:.1rem .5rem;bottom:6px;border-radius:8px}.lightbox-card .card-name{font-size:1rem;margin-bottom:.2rem}.lightbox-card .card-artwork-wrap{width:calc(100% + 1.2rem);margin-left:-.6rem;margin-right:-.6rem}.lightbox-card .card-desc{font-size:.85rem;line-height:1.3}@keyframes lightbox-card-pop{0%{opacity:.5;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.lightbox-nav{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;flex-shrink:0;transition:background .2s,opacity .2s;z-index:1001}.lightbox-nav:hover:not(:disabled){background:#fff3}.lightbox-nav:disabled{opacity:.2;cursor:default}.lightbox-dots{position:absolute;bottom:-44px;left:50%;transform:translate(-50%);display:flex;gap:8px}.lightbox-dot{width:10px;height:10px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:#ffffff26;cursor:pointer;padding:0;transition:background .2s,border-color .2s,transform .2s}.lightbox-dot:hover{background:#ffffff4d}.lightbox-dot.active{background:var(--color-text-highlight);border-color:var(--color-text-highlight);transform:scale(1.3)}@media(min-width:769px){.reveal-screen{padding:2rem;gap:1rem}.reveal-archetype{font-size:.9rem}.reveal-name{font-size:2.5rem}.reveal-title{font-size:1rem}.reveal-portrait{width:180px;height:280px;border-width:3px;border-radius:10px}.reveal-trait{font-size:.75rem;padding:.25rem .6rem}.reveal-hero-label{font-size:.8rem;letter-spacing:4px}.reveal-cards{max-width:800px;gap:.75rem}.reveal-cta{font-size:1.2rem;padding:.85rem 2.5rem;margin-top:1rem}.lightbox-card{--card-width: 300px;--card-height: 420px}.lightbox-card .card-cost{width:28px;height:28px;font-size:.95rem}.lightbox-card .card-type-badge{font-size:.7rem;padding:.15rem .6rem;bottom:8px}.lightbox-card .card-name{font-size:1.15rem}.lightbox-card .card-desc{font-size:.95rem}.lightbox-nav{width:48px;height:48px}}.app-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:0 1rem}.start-button{padding:.75rem 1.5rem;font-size:1rem;cursor:pointer;font-family:var(--font-family-display);background:var(--color-bg-elevated);border:2px solid var(--color-border);color:var(--color-text-primary);font-weight:700;text-transform:uppercase;letter-spacing:1px;transition:all .2s}.start-button.hero-button{background:linear-gradient(135deg,#ff3860,#b967ff);border-color:#ff6ec7;color:#fff;border-radius:8px}.start-button.hero-button:hover{background:linear-gradient(135deg,#ff6ec7,#b967ff);border-color:#ffb3e6;transform:translateY(-2px);box-shadow:0 4px 20px #ff6ec766}.landing-page{height:100%;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg-base)}.landing-page::-webkit-scrollbar{width:4px}.landing-page::-webkit-scrollbar-track{background:var(--color-bg-base)}.landing-page::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes neonPulse{0%,to{text-shadow:0 0 10px rgba(255,110,199,.4),0 0 30px rgba(255,110,199,.2)}50%{text-shadow:0 0 20px rgba(255,110,199,.7),0 0 50px rgba(255,110,199,.4),0 0 80px rgba(255,110,199,.15)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes scrollBounce{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(8px);opacity:.8}}@keyframes ctaGlow{0%,to{box-shadow:0 0 10px #ff6ec74d}50%{box-shadow:0 0 25px #ff6ec799,0 0 50px #b967ff33}}@keyframes ambientWash{0%{opacity:.04}50%{opacity:.08}to{opacity:.04}}.landing-section-title{font-family:var(--font-family-display);font-size:1.4rem;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:3px;margin:0 0 .25rem;text-align:center}.landing-section-desc{font-size:.8rem;color:var(--color-text-secondary);margin:0 0 1.5rem;text-align:center}.landing-hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;box-sizing:border-box;background:url(/assets/hero-bg.webp) center center / cover no-repeat,#0d0d1a;overflow:hidden}.landing-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#0d0d1a8c,#0d0d1a4d 40%,#0d0d1a99),conic-gradient(from 0deg at 50% 50%,#ff38600f,#b967ff0f,#00d4ff0f,#39ff140f,#ff38600f);animation:ambientWash 8s ease-in-out infinite;pointer-events:none}.landing-scanlines{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,0,0,.12) 2px,rgba(0,0,0,.12) 4px);pointer-events:none;opacity:.4}.landing-hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}.landing-title{display:flex;flex-direction:column;align-items:center;gap:0;margin:0 0 1rem}.landing-title-selfie{font-family:var(--font-family-display);font-size:3.5rem;line-height:1;color:var(--color-text-highlight);text-transform:uppercase;letter-spacing:4px;animation:fadeInUp .8s ease both,neonPulse 3s ease-in-out infinite;-webkit-text-stroke:1.5px rgba(0,0,0,.6);paint-order:stroke fill;filter:drop-shadow(0 2px 6px rgba(0,0,0,.9)) drop-shadow(0 0 20px rgba(255,110,199,.4))}.landing-title-the{font-family:var(--font-family-base);font-size:.85rem;color:var(--color-text-secondary);font-style:italic;letter-spacing:6px;text-transform:lowercase;animation:fadeInUp .8s ease .2s both;text-shadow:0 2px 8px rgba(0,0,0,.9)}.landing-title-spire{font-family:var(--font-family-display);font-size:3.5rem;line-height:1;text-transform:uppercase;letter-spacing:4px;background:linear-gradient(90deg,#ff3860,#b967ff,#00d4ff,#39ff14,#ff3860);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:fadeInUp .8s ease .4s both,gradientShift 6s ease infinite;filter:drop-shadow(0 2px 6px rgba(0,0,0,.9)) drop-shadow(0 0 20px rgba(185,103,255,.5))}.landing-tagline{font-family:var(--font-family-display);font-size:1.1rem;color:var(--color-text-primary);letter-spacing:2px;text-transform:uppercase;margin:0 0 .75rem;animation:fadeInUp .8s ease .6s both;text-shadow:0 2px 8px rgba(0,0,0,.9),0 0 20px rgba(0,0,0,.6)}.landing-subtitle{font-size:.85rem;line-height:1.5;color:var(--color-text-secondary);max-width:320px;margin:0 0 2rem;animation:fadeInUp .8s ease .8s both;text-shadow:0 2px 8px rgba(0,0,0,.9),0 0 20px rgba(0,0,0,.6);background:#00000073;padding:.75rem 1rem;border-radius:8px}.landing-cta{display:flex;align-items:center;gap:.5rem;animation:fadeInUp .8s ease 1s both,ctaGlow 2.5s ease-in-out infinite}.landing-scroll-hint{position:absolute;bottom:1.5rem;color:var(--color-text-secondary);animation:scrollBounce 2s ease-in-out infinite;z-index:1}.landing-showcase{padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;background:linear-gradient(180deg,var(--color-bg-base) 0%,var(--color-bg-surface) 50%,var(--color-bg-base) 100%);overflow:hidden;max-width:100%}.landing-enemies{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:320px;margin-bottom:2rem}.landing-enemy-card{border-radius:8px;overflow:hidden;border:2px solid var(--color-border);background:var(--color-bg-surface);animation:float 3s ease-in-out infinite;transition:border-color .3s,box-shadow .3s}.landing-enemy-card:nth-child(1){animation-delay:0s;border-color:#ff3860}.landing-enemy-card:nth-child(2){animation-delay:.15s;border-color:#b967ff}.landing-enemy-card:nth-child(3){animation-delay:.3s;border-color:#00d4ff}.landing-enemy-card:nth-child(4){animation-delay:.45s;border-color:#39ff14}.landing-enemy-card:nth-child(5){animation-delay:.6s;border-color:#ffb347}.landing-enemy-card:nth-child(6){animation-delay:.75s;border-color:#ff6ec7}.landing-enemy-card:nth-child(7){animation-delay:.9s;border-color:#00d4ff}.landing-enemy-card:nth-child(8){animation-delay:1.05s;border-color:#b967ff}.landing-enemy-card img{width:100%;height:100%;object-fit:cover;display:block}@keyframes carouselSpin{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}@keyframes cylinderPulse{0%,to{box-shadow:0 0 40px #b967ff66,0 0 80px #b967ff33,0 0 120px #b967ff1a,inset 0 0 40px #b967ff26;border-color:#b967ff66}50%{box-shadow:0 0 50px #b967ff99,0 0 100px #ff38604d,0 0 150px #b967ff26,inset 0 0 60px #ff386033;border-color:#ff386080}}.landing-carousel-scene{perspective:600px;height:160px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;position:relative}.landing-carousel-cylinder{position:absolute;width:200px;height:140px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(185,103,255,.15) 0%,rgba(185,103,255,.06) 40%,transparent 70%),radial-gradient(ellipse at 30% 40%,rgba(255,56,96,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 60%,rgba(0,212,255,.06) 0%,transparent 50%);border:2px solid rgba(185,103,255,.3);animation:cylinderPulse 4s ease-in-out infinite}.landing-carousel-ring{width:80px;height:60px;position:relative;transform-style:preserve-3d;animation:carouselSpin 12s linear infinite}.landing-carousel-card{position:absolute;width:80px;aspect-ratio:4/3;border-radius:6px;overflow:hidden;border:2px solid var(--color-border);box-shadow:0 4px 12px #000c;transform:rotateY(var(--card-angle)) translateZ(100px)}.landing-carousel-card img{width:100%;height:100%;object-fit:cover;display:block}.landing-steps{padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;overflow:hidden}.landing-steps-grid{display:flex;flex-direction:column;align-items:center;gap:0;max-width:320px;width:100%}.landing-step{background:var(--color-bg-surface);border:1px solid var(--color-border);border-top:3px solid var(--step-color);border-radius:12px;padding:1.5rem 1rem 1.25rem;text-align:center;width:100%;box-sizing:border-box;transition:transform .3s,box-shadow .3s}.landing-step:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000080}.landing-step-number{width:28px;height:28px;border-radius:50%;background:var(--step-color);color:var(--color-bg-base);font-family:var(--font-family-display);font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:-2.25rem auto .75rem}.landing-step-icon{color:var(--step-color);margin-bottom:.5rem}.landing-step-heading{font-family:var(--font-family-display);font-size:1.1rem;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:1px;margin:0 0 .4rem}.landing-step-desc{font-size:.8rem;line-height:1.4;color:var(--color-text-secondary);margin:0}.landing-step-connector{width:2px;height:24px;background:repeating-linear-gradient(to bottom,var(--color-border) 0px,var(--color-border) 4px,transparent 4px,transparent 8px);flex-shrink:0}.landing-final{position:relative;padding:4rem 1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;overflow:hidden}.landing-final-glow{position:absolute;inset:0;background:radial-gradient(ellipse at center 60%,rgba(255,110,199,.12) 0%,transparent 65%);pointer-events:none;animation:ambientWash 4s ease-in-out infinite}.landing-final-heading{font-family:var(--font-family-display);font-size:1.6rem;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:2px;margin:0 0 .5rem;text-shadow:0 0 20px rgba(255,110,199,.2);position:relative}.landing-final-desc{font-size:.9rem;color:var(--color-text-secondary);margin:0 0 2rem;font-style:italic;position:relative}.landing-final .landing-cta{position:relative}@media(min-width:769px){.app-container{padding:0 2rem}.start-button{padding:1rem 2rem;font-size:1.2rem}.landing-title-selfie,.landing-title-spire{font-size:6rem;letter-spacing:8px}.landing-title-the{font-size:1.1rem;letter-spacing:10px}.landing-tagline{font-size:1.4rem;letter-spacing:4px}.landing-subtitle{font-size:1rem;max-width:640px}.landing-section-title{font-size:2rem;letter-spacing:5px}.landing-section-desc{font-size:1rem;margin-bottom:2rem}.landing-enemies{grid-template-columns:repeat(8,1fr);max-width:700px;gap:12px}.landing-carousel-scene{perspective:900px;height:220px}.landing-carousel-ring{width:130px;height:98px}.landing-carousel-card{width:130px;transform:rotateY(var(--card-angle)) translateZ(160px)}.landing-carousel-cylinder{width:320px;height:200px}.landing-steps-grid{flex-direction:row;align-items:flex-start;max-width:800px;gap:0}.landing-step{flex:1}.landing-step-connector{width:40px;height:2px;margin-top:3rem;background:repeating-linear-gradient(to right,var(--color-border) 0px,var(--color-border) 4px,transparent 4px,transparent 8px)}.landing-final{padding:5rem 2rem}.landing-final-heading{font-size:2.5rem}.landing-final-desc{font-size:1.1rem}}:root{--color-bg-base: #0d0d1a;--color-bg-surface: #1a1a2e;--color-bg-elevated: #252540;--color-text-primary: #f0e6d3;--color-text-secondary: #a89b8c;--color-text-highlight: #ff6ec7;--color-accent-red: #ff3860;--color-accent-blue: #00d4ff;--color-accent-green: #39ff14;--color-accent-amber: #ffb347;--color-accent-violet: #b967ff;--color-border: #3d3d5c;--font-family-base: "Space Mono", "Courier New", monospace;--font-family-display: "Bebas Neue", "Impact", sans-serif;--topbar-height: 50px;--hand-height: 280px;--card-width: 70px;--card-height: 100px;--card-spacing: 70px;--card-half-width: 35px;--card-hover-lift: -20px;--card-hover-scale: 1.3;--z-hand: 10;--z-entity-float: 50;--z-topbar: 100;--z-deck-table: 100;--z-card-hover: 100;--z-controls: 150;--z-card-playing: 200;--z-targeting: 1000}@media(min-width:769px){:root{--topbar-height: 60px;--hand-height: 240px;--card-width: 150px;--card-height: 210px;--card-spacing: 100px;--card-half-width: 75px;--card-hover-lift: -50px;--card-hover-scale: 1.08}}body{margin:0;padding:0;background-color:var(--color-bg-base);color:var(--color-text-primary);font-family:var(--font-family-base);height:100vh;width:100vw;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;mix-blend-mode:overlay}#root{height:100%;width:100%}
