@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700;900&family=Montserrat:wght@700;800;900&display=swap";:root{--bg-dark: radial-gradient(circle at 50% -20%, #2a124d 0%, #05010a 80%);--amethyst-glow: rgba(157, 78, 221, .5);--amethyst-bright: #9d4ede;--amethyst-light: #c77dff;--glass-border: rgba(255, 255, 255, .1);--glass-surface: rgba(255, 255, 255, .03);--text-primary: #ffffff;--text-secondary: #b79ced;--danger: #ff4444;--accent-gradient: linear-gradient(135deg, #9d4ede 0%, #5a189a 100%);--accent-gradient-hot: linear-gradient(135deg, #c77dff 0%, #7b2cff 45%, #00ffa3 140%);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.18, .9, .22, 1.18);--motion-fast: .18s;--motion-med: .36s;--motion-slow: .62s;--focus-ring: 0 0 0 3px rgba(199, 125, 255, .18), 0 0 0 1px rgba(199, 125, 255, .65);--surface-elevated: rgba(255, 255, 255, .065);--card-dark-bg: #121212;--card-dark-border: rgba(255, 255, 255, .08);--card-dark-shadow: 0 12px 30px rgba(0, 0, 0, .8)}html,body{height:100%;width:100vw;margin:0;padding:0;background:#05010a;background:var(--bg-dark) no-repeat fixed;color:var(--text-primary);font-family:Poppins,sans-serif;overflow:hidden!important;position:fixed;top:0;left:0;overscroll-behavior:none!important;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}*{-webkit-tap-highlight-color:transparent!important;box-sizing:border-box}button,a,.game-card,.action-card,.nav-logo-right{outline:none!important;-webkit-tap-highlight-color:transparent!important;-webkit-user-select:none;user-select:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.game-card:focus-visible,.action-card:focus-visible{box-shadow:var(--focus-ring);border-color:#c77dffc7!important}#app{height:100dvh;width:100vw;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch;padding:env(safe-area-inset-top,20px) 20px calc(100px + env(safe-area-inset-bottom)) 20px;box-sizing:border-box;display:flex;flex-direction:column}::-webkit-scrollbar{width:0px;background:transparent}@keyframes cardEntrance{0%{opacity:0;transform:translate3d(0,22px,0) scale(.965);filter:blur(8px)}to{opacity:1;transform:translateZ(0) scale(1);filter:blur(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translate3d(0,22px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes floatLogo{0%,to{transform:translateY(0)}50%{transform:translateY(-5px);filter:drop-shadow(0 0 15px var(--amethyst-light))}}@keyframes pulse{0%,to{transform:scale(.98);opacity:.72}50%{transform:scale(1.035);opacity:1;filter:drop-shadow(0 0 22px var(--amethyst-bright))}}@keyframes sheenSweep{0%{transform:translate(-130%) skew(-18deg);opacity:0}28%{opacity:.42}to{transform:translate(130%) skew(-18deg);opacity:0}}@keyframes panelReveal{0%{opacity:0;transform:translate3d(18px,0,0) scale(.98)}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes floatDie{0%,to{transform:translateZ(0) rotate(-12deg);filter:drop-shadow(0 0 0 rgba(199,125,255,0))}50%{transform:translate3d(0,-12px,0) rotate(-8deg);filter:drop-shadow(0 18px 34px rgba(157,78,222,.28))}}@keyframes chatPop{0%{opacity:0;transform:translate3d(0,10px,0) scale(.98)}to{opacity:1;transform:translateZ(0) scale(1)}}.fade-in{animation:fadeInUp var(--motion-slow) var(--ease-out) forwards}.pulse-logo{animation:pulse 1.5s infinite ease-in-out}.nav-logo-right{position:fixed;top:calc(15px + env(safe-area-inset-top));right:20px;width:45px;height:45px;z-index:1500;filter:drop-shadow(0 0 10px var(--amethyst-bright));animation:floatLogo 4s ease-in-out infinite}.grid-layout{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:20px;width:100%}.game-card,.action-card{background:var(--glass-surface);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:24px;padding:24px 12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden;transform:translateZ(0);will-change:transform;transition:transform var(--motion-med) var(--ease-spring),border-color var(--motion-med) ease,background var(--motion-med) ease,box-shadow var(--motion-med) ease,filter var(--motion-med) ease;text-align:center;animation:cardEntrance .6s var(--ease-out) backwards;cursor:pointer}.game-card:before,.action-card:before{content:"";position:absolute;inset:-40% auto -40% 0;width:42%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.16),transparent);transform:translate(-140%) skew(-18deg);pointer-events:none}.game-card:hover,.action-card:hover{transform:translateY(-4px) scale(1.015);background:var(--surface-elevated);border-color:#c77dff6b;box-shadow:0 18px 38px #00000057,0 0 28px #9d4ede21}.game-card:hover:before,.action-card:hover:before{animation:sheenSweep .9s var(--ease-out)}.game-card:active,.action-card:active{transform:scale(.965);background:#9d4edd1a;border-color:var(--amethyst-light)}.game-card:nth-child(1){animation-delay:.1s}.game-card:nth-child(2){animation-delay:.15s}.game-card:nth-child(3){animation-delay:.2s}.game-card:nth-child(4){animation-delay:.25s}.game-card:nth-child(5){animation-delay:.3s}.game-card:nth-child(6){animation-delay:.35s}.main-title{font-family:Montserrat,sans-serif;font-weight:900;font-size:2.2rem;text-align:center;text-transform:uppercase;background:linear-gradient(180deg,#ffffff 0%,var(--text-secondary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 10px rgba(157,78,221,.3))}.text-amethyst{color:var(--amethyst-bright);text-shadow:0 0 15px var(--amethyst-glow)}.sidebar-glass{position:fixed;right:-110%;top:0;width:290px;height:100dvh;background:#05020ad9;backdrop-filter:blur(40px) saturate(150%);-webkit-backdrop-filter:blur(40px) saturate(150%);z-index:9000!important;transition:right var(--motion-slow) var(--ease-out),box-shadow var(--motion-med) ease,border-color var(--motion-med) ease;padding:calc(60px + env(safe-area-inset-top)) 20px;border-left:1px solid var(--glass-border);box-sizing:border-box;box-shadow:-15px 0 40px #0009;animation:panelReveal var(--motion-slow) var(--ease-out)}.sidebar-glass.active{right:0!important}.floating-trigger{position:fixed;bottom:calc(25px + env(safe-area-inset-bottom));right:20px;width:62px;height:62px;border-radius:20px;background:var(--accent-gradient);z-index:9999!important;display:flex!important;flex-direction:column;justify-content:center;align-items:center;gap:5px;box-shadow:0 12px 26px #9d4edd57,inset 0 1px #ffffff2e;border:1px solid rgba(255,255,255,.1);transition:transform var(--motion-med) var(--ease-spring),background var(--motion-med) ease,box-shadow var(--motion-med) ease,border-color var(--motion-med) ease;cursor:pointer;visibility:visible!important}.floating-trigger:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 18px 36px #9d4edd6b,0 0 24px #c77dff2e}.floating-trigger.is-active{background:var(--danger)!important;transform:rotate(180deg);box-shadow:0 0 30px #f449;border-color:#f446}.nav-bar{width:26px;height:3px;background:#fff;border-radius:10px;transition:all .4s cubic-bezier(.68,-.6,.32,1.6);transform-origin:center}.floating-trigger.is-active .nav-bar:nth-child(1){transform:translateY(8px) rotate(45deg)}.floating-trigger.is-active .nav-bar:nth-child(2){opacity:0;transform:scale(.2)}.floating-trigger.is-active .nav-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.btn-back-glass,.btn-glass,.btn-primary{width:100%;background:#ffffff0a;border:1px solid var(--glass-border);border-left:3px solid transparent;color:#fff;padding:16px 20px;border-radius:16px;font-family:Montserrat,sans-serif;font-weight:800;font-size:.85rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;position:relative;overflow:hidden;transition:transform var(--motion-med) var(--ease-spring),background var(--motion-med) ease,border-color var(--motion-med) ease,box-shadow var(--motion-med) ease;display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px;box-shadow:0 4px 15px #0003}.btn-back-glass:hover,.btn-glass:hover,.btn-primary:hover{transform:translateY(-2px);background:#ffffff13;border-color:#c77dff6b;box-shadow:0 10px 26px #00000047,0 0 22px #9d4ede1f}.btn-back-glass:active,.btn-glass:active,.btn-primary:active{transform:scale(.975);background:#9d4edd26;border-color:var(--amethyst-light);border-left:3px solid var(--amethyst-bright);box-shadow:0 0 20px #9d4edd66}input[type=text],input[type=email],input[type=password],select,.auth-input{width:100%;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:16px;padding:14px;color:#fff;font-size:16px;font-family:Poppins,sans-serif;outline:none;transition:border-color var(--motion-fast) ease,background var(--motion-fast) ease,box-shadow var(--motion-fast) ease,transform var(--motion-fast) ease;box-sizing:border-box}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,select:focus,.auth-input:focus{border-color:var(--amethyst-bright);background:#9d4edd0d;box-shadow:0 0 15px #9d4edd33}.glass-box{background:var(--glass-surface);border:1px solid var(--glass-border);border-radius:20px;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);box-shadow:0 10px 30px #00000059}.sidebar-btn{background:#ffffff0a;border:1px solid var(--glass-border);color:#fff;font-family:Montserrat,sans-serif;font-weight:800;cursor:pointer}.side-music-toggle{width:100%;height:52px;border:1px solid var(--glass-border);border-radius:999px;background:#ffffff0d;color:#fff;position:relative;overflow:hidden;cursor:pointer;font-family:Montserrat,sans-serif;font-weight:900;letter-spacing:2px;box-shadow:inset 0 1px #ffffff14,0 8px 20px #0000002e;transition:background var(--motion-med) ease,border-color var(--motion-med) ease,box-shadow var(--motion-med) ease,transform var(--motion-fast) ease}.side-music-toggle:hover{transform:translateY(-1px);border-color:#c77dff6b}.side-music-toggle-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;opacity:.34;pointer-events:none}.side-music-toggle-knob{position:absolute;top:5px;left:5px;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffffeb;box-shadow:0 8px 18px #00000059;transition:left var(--motion-med) var(--ease-spring),transform var(--motion-med) var(--ease-spring),box-shadow var(--motion-med) ease}.side-music-toggle-state{position:absolute;top:50%;right:18px;transform:translateY(-50%);font-size:.68rem;color:#ffffff8c;pointer-events:none}.side-music-toggle.is-on{background:linear-gradient(135deg,#9d4eded9,#00ffa347);border-color:#c77dff99;box-shadow:0 0 22px #9d4ede47}.side-music-toggle.is-on .side-music-toggle-knob{left:calc(100% - 45px);box-shadow:0 8px 22px #00ffa338,0 0 0 6px #ffffff0a}.side-music-toggle.is-on .side-music-toggle-state{left:18px;right:auto;color:#fff}.settings-profile-page,.music-center{width:100%;max-width:720px;margin:0 auto;padding:20px 0 120px;color:#fff}.settings-back,.music-back{width:auto!important;display:inline-flex;border-left:none!important;margin-bottom:28px}.settings-profile-header,.music-header{text-align:center;margin-bottom:24px}.settings-kicker{margin:0 0 8px;text-transform:uppercase;letter-spacing:3px;font-size:.72rem;opacity:.55;font-weight:800}.settings-title,.music-title{margin:0}.settings-profile-preview{display:flex;align-items:center;gap:18px;padding:20px;margin-bottom:18px}.settings-avatar-preview{width:72px;height:72px;border-radius:20px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;background:#9d4ede24;border:1px solid rgba(199,125,255,.4);color:var(--amethyst-light);font-size:2rem;font-weight:900;overflow:hidden}.settings-avatar-preview img{width:100%;height:100%;object-fit:cover}.settings-profile-preview h2{margin:0;font-size:1.35rem;text-transform:uppercase}.settings-profile-preview p,.music-playlist p,.music-note p{margin:6px 0 0;opacity:.58;font-size:.82rem;line-height:1.5}.settings-form{display:grid;gap:16px;padding:20px}.settings-form label,.settings-row{display:grid;gap:8px;font-size:.75rem;text-transform:uppercase;letter-spacing:1px;opacity:.9}.settings-check{grid-template-columns:1fr auto;align-items:center}.settings-check input{width:22px;height:22px;accent-color:var(--amethyst-bright)}.settings-save{margin-top:8px}.settings-saved{min-height:18px;margin:0;text-align:center;color:#00ffa3;font-size:.78rem;font-weight:800}.music-now{padding:18px;margin-bottom:18px;text-align:center}.music-now-label{display:block;text-transform:uppercase;letter-spacing:2px;font-size:.68rem;opacity:.5;margin-bottom:6px}.music-now strong{color:var(--amethyst-light);font-size:1.35rem;text-transform:uppercase}.music-now p{margin:6px 0 0;opacity:.65}.music-playlists{display:grid;gap:16px}.music-playlist{padding:18px;position:relative;overflow:hidden;transition:border-color var(--motion-med) ease,background var(--motion-med) ease,transform var(--motion-med) var(--ease-out),box-shadow var(--motion-med) ease}.music-playlist:hover{transform:translateY(-3px);border-color:#c77dff6b;background:#ffffff0e;box-shadow:0 16px 34px #00000047}.music-playlist.is-selected{border-color:#c77dffbf;background:#9d4ede14}.music-playlist-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.music-playlist h2{margin:0;font-size:1rem;text-transform:uppercase}.music-playlist-select,.music-track{border:1px solid var(--glass-border);background:#ffffff0a;color:#fff;border-radius:12px;cursor:pointer;font-family:Montserrat,sans-serif;font-weight:800;transition:transform var(--motion-fast) ease,background var(--motion-fast) ease,border-color var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.music-playlist-select{padding:10px 12px;font-size:.68rem}.music-track-list{display:grid;gap:10px}.music-track{min-height:48px;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:left}.music-playlist-select:hover,.music-track:hover{transform:translateY(-1px);background:#9d4ede1f;border-color:#c77dff75;box-shadow:0 8px 20px #0000003d}.music-track:active,.music-playlist-select:active{transform:scale(.985)}.music-track small{color:var(--amethyst-light);opacity:.8}.music-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}.music-note{padding:14px 18px;margin-top:18px}.dnd-app{width:100%;max-width:1120px;margin:0 auto;padding:20px 0 120px;color:#fff}.dnd-back{width:auto!important;display:inline-flex;border-left:none!important;margin-bottom:22px}.dnd-hero{min-height:260px;border:1px solid var(--glass-border);border-radius:24px;padding:34px;margin-bottom:18px;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;background:linear-gradient(135deg,#280a3cd1,#05010af0),url(https://www.transparenttextures.com/patterns/dark-matter.png);overflow:hidden;box-shadow:0 24px 60px #00000073;position:relative;isolation:isolate;animation:cardEntrance var(--motion-slow) var(--ease-out) backwards}.dnd-hero:after{content:"";position:absolute;inset:-35% -10% auto auto;width:360px;height:360px;background:radial-gradient(circle,rgba(199,125,255,.14),transparent 68%);pointer-events:none;z-index:-1}.dnd-kicker{margin:0 0 10px;text-transform:uppercase;letter-spacing:3px;font-size:.72rem;opacity:.58;font-weight:900}.dnd-hero h1{margin:0;font-family:Montserrat,sans-serif;font-size:clamp(2.4rem,7vw,4.7rem);line-height:.95;letter-spacing:0}.dnd-hero h1 span{color:var(--amethyst-light);text-shadow:0 0 22px var(--amethyst-glow)}.dnd-hero p:last-child{max-width:560px;margin:18px 0 0;opacity:.68;line-height:1.6;font-size:.92rem}.dnd-hero-die{font-family:Montserrat,sans-serif;font-size:clamp(5rem,18vw,12rem);line-height:.8;font-weight:900;color:#c77dff14;transform:rotate(-12deg);flex:0 0 auto;animation:floatDie 4.8s ease-in-out infinite}.dnd-tabs{display:flex;gap:10px;overflow-x:auto;padding:4px 0 18px;margin-bottom:12px}.dnd-tabs button{flex:0 0 auto;border:1px solid var(--glass-border);border-radius:999px;background:#ffffff0a;color:#fff;padding:12px 16px;font-family:Montserrat,sans-serif;font-weight:900;font-size:.76rem;cursor:pointer;transition:transform var(--motion-fast) ease,border-color var(--motion-fast) ease,background var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.dnd-tabs button:hover{transform:translateY(-2px);border-color:#c77dff75;background:#9d4ede1a}.dnd-tabs button.active{border-color:var(--amethyst-light);background:#9d4ede29;color:var(--amethyst-light)}.dnd-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.dnd-panel,.dnd-list-card,.dnd-empty{border:1px solid var(--glass-border);background:var(--glass-surface);color:#fff;border-radius:18px;padding:22px;text-align:left;cursor:pointer;position:relative;overflow:hidden;transition:border-color var(--motion-med) ease,transform var(--motion-med) var(--ease-out),background var(--motion-med) ease,box-shadow var(--motion-med) ease}.dnd-panel:hover,.dnd-list-card:hover{transform:translateY(-3px);border-color:#c77dff75;background:#ffffff0e;box-shadow:0 16px 34px #00000047,0 0 26px #9d4ede1a}.dnd-panel:active{transform:scale(.985);border-color:var(--amethyst-light);background:#9d4ede1a}.dnd-panel span,.dnd-list-card span,.dnd-section-head p,.dnd-muted{display:block;color:#ffffff94;font-size:.8rem;line-height:1.5}.dnd-panel strong,.dnd-list-card strong,.dnd-section-head h2{display:block;margin:8px 0;font-family:Montserrat,sans-serif;font-size:1.2rem;text-transform:uppercase}.dnd-panel p,.dnd-list-card p{margin:0;color:#ffffff9e;font-size:.86rem;line-height:1.55}.dnd-section-head{margin:24px 0 16px}.dnd-section-actions,.dnd-list-card{display:flex;justify-content:space-between;align-items:center;gap:16px}.dnd-card-list{display:grid;gap:14px}.dnd-inline-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.dnd-manual-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:16px}.dnd-manual-list{display:grid;gap:10px;align-content:start}.dnd-manual-card{padding:16px;border-radius:16px;border:1px solid var(--glass-border);background:#ffffff0a;color:#fff;text-align:left;cursor:pointer;transition:transform var(--motion-fast) ease,border-color var(--motion-fast) ease,background var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.dnd-manual-card:hover{transform:translate(4px);border-color:#c77dff75;background:#9d4ede17;box-shadow:0 10px 24px #00000038}.dnd-manual-card.active{border-color:var(--amethyst-light);background:#9d4ede24}.dnd-manual-card strong{display:block;margin-bottom:6px}.dnd-manual-card span{opacity:.58;font-size:.78rem;line-height:1.45}.dnd-manual-card small{display:block;margin-top:10px;opacity:.5;font-size:.68rem;text-transform:uppercase;letter-spacing:1.5px}.dnd-manual-viewer{min-height:680px;overflow:hidden}.dnd-manual-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px;border-bottom:1px solid var(--glass-border)}.dnd-manual-toolbar span{display:block;opacity:.55;font-size:.68rem;text-transform:uppercase;letter-spacing:2px}.dnd-manual-toolbar a{color:#fff;text-decoration:none;border:1px solid var(--glass-border);border-radius:999px;padding:10px 14px;font-weight:900;font-size:.72rem}.dnd-manual-controls{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.dnd-manual-controls button,.dnd-manual-controls input{border:1px solid var(--glass-border);background:#ffffff12;color:#fff;border-radius:999px;padding:10px 14px;font-weight:900;font-size:.72rem}.dnd-manual-controls label{display:flex;align-items:center;gap:8px}.dnd-manual-controls label span,.dnd-manual-controls>span{opacity:.62;font-size:.68rem;text-transform:uppercase;letter-spacing:1.5px}.dnd-manual-controls input{width:88px}.dnd-manual-viewer iframe{width:100%;height:620px;border:0;background:#0000004d}.dnd-sheet{display:grid;gap:16px}.dnd-sheet-grid{padding:18px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.dnd-sheet label,.dnd-row-label{display:grid;gap:8px;color:#ffffffb8;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.dnd-sheet input,.dnd-sheet select,.dnd-sheet textarea,.dnd-session input,.dnd-session select,.dnd-session textarea{width:100%;border:1px solid var(--glass-border);border-radius:14px;padding:13px;background:#ffffff0d;color:#fff;font:inherit;box-sizing:border-box}.dnd-session textarea{min-height:96px;resize:vertical}.dnd-session input[type=color]{height:44px;padding:6px;cursor:pointer}.dnd-sheet input[type=file]{padding:11px;cursor:pointer}.dnd-map-upload span{color:#ffffff80;font-size:.72rem;line-height:1.35;text-transform:none;letter-spacing:0;font-weight:600}.dnd-sheet textarea{min-height:110px;resize:vertical}.dnd-stat-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.dnd-stat{padding:16px;text-align:center}.dnd-stat input{text-align:center;font-size:1.5rem;font-weight:900}.dnd-two-col{display:grid;grid-template-columns:1fr 2fr;gap:16px}.dnd-checks,.dnd-textareas{padding:18px}.dnd-checks{display:grid;gap:10px}.dnd-checks h3{margin:0 0 8px}.dnd-checks label{grid-template-columns:auto 1fr;align-items:center;text-transform:none;letter-spacing:0}.dnd-textareas{display:grid;gap:14px}.dnd-error{color:var(--danger);font-weight:800}.dnd-session{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:grid;grid-template-columns:280px minmax(0,1fr) 320px;background:#05010a;color:#fff;font-family:Poppins,sans-serif;overflow:hidden;animation:fadeInUp var(--motion-slow) var(--ease-out) forwards}.dnd-session-panel{border-color:#9d4ede38;background:#05020ad1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;flex-direction:column;overflow:hidden}.dnd-left-panel{border-right:1px solid rgba(157,78,222,.22);padding:18px;gap:16px;overflow-y:auto}.dnd-chat-panel{border-left:1px solid rgba(157,78,222,.22)}.dnd-session-panel header{display:grid;gap:4px;padding-bottom:14px;border-bottom:1px solid var(--glass-border)}.dnd-session-panel header span{opacity:.5;font-size:.68rem;text-transform:uppercase;letter-spacing:2px;font-weight:900}.dnd-session-panel header strong{font-size:1rem;text-transform:uppercase}.dnd-session-block{display:grid;gap:10px}.dnd-session-block h3{margin:0;font-size:.88rem;text-transform:uppercase}.initiative-form{display:grid;grid-template-columns:1fr 72px;gap:8px}.initiative-list{display:grid;gap:8px}.initiative-item{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--glass-border);border-radius:12px;padding:10px 12px;background:#ffffff0a;transition:transform var(--motion-fast) ease,border-color var(--motion-fast) ease,background var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.initiative-item:hover,.token-list-item:hover{transform:translate(3px);border-color:#c77dff6b;background:#ffffff0f}.initiative-item>div{display:flex;align-items:center;gap:8px}.initiative-item button,.token-list-item button{border:1px solid var(--glass-border);border-radius:999px;background:#ffffff0f;color:#fff;font-size:.64rem;font-weight:900;padding:6px 9px;cursor:pointer}.initiative-item.active{border-color:#00ffa3;background:#00ffa314}.token-list{display:grid;gap:8px}.token-list-item{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--glass-border);border-radius:12px;padding:9px 10px;background:#ffffff0a;transition:transform var(--motion-fast) ease,border-color var(--motion-fast) ease,background var(--motion-fast) ease}.token-list-item span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;font-weight:900}.token-list-item span:before{content:"";display:inline-block;width:9px;height:9px;margin-right:8px;border-radius:50%;background:var(--token-color)}.session-check{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;font-size:.76rem;font-weight:800;color:#ffffffb8}.session-check input{width:auto}.dnd-table-area{position:relative;overflow:hidden;background:#08040d}#tabletop-container,.tabletop-viewport{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.tabletop-viewport{cursor:grab;touch-action:none;background:#05020a}.map-layer{position:absolute;width:4200px;height:4200px;transform-origin:0 0;will-change:transform}.map-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(157,78,222,.13) 1px,transparent 1px),linear-gradient(90deg,rgba(157,78,222,.13) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}.map-image{position:absolute;top:0;left:0;width:2200px;max-width:none;opacity:.92}.map-pdf{position:absolute;top:0;left:0;width:2200px;height:1600px;border:0;background:#00000059;pointer-events:none}.map-fog{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:#0000;transition:background var(--motion-med) ease}.map-fog.active{background:radial-gradient(circle at 50% 50%,#0000001f,#000000ad)}.token{position:absolute;width:62px;height:62px;cursor:pointer;z-index:10;transition:transform var(--motion-fast) ease,filter var(--motion-fast) ease;will-change:transform}.token:hover{transform:scale(1.08);filter:drop-shadow(0 0 18px rgba(199,125,255,.48))}.token.dragging{z-index:1000;filter:brightness(1.2);transform:scale(1.1)}.token-img{width:100%;height:100%;border-radius:50%;border:3px solid var(--amethyst-light);background:#12051e;display:flex;align-items:center;justify-content:center;box-shadow:0 0 18px #9d4ede8c;overflow:hidden;font-weight:900;color:#fff}.token-img img{width:100%;height:100%;object-fit:cover;pointer-events:none}.token-name{position:absolute;top:-24px;left:50%;transform:translate(-50%);background:#05020ae6;border:1px solid rgba(157,78,222,.32);border-radius:8px;padding:4px 8px;white-space:nowrap;font-size:.64rem;font-weight:900;pointer-events:none}.dnd-table-topbar{position:absolute;top:16px;left:16px;right:16px;display:flex;justify-content:space-between;align-items:center;gap:12px;z-index:60;pointer-events:none}.dnd-table-topbar>*{pointer-events:auto}.map-control-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.dnd-table-topbar strong{border:1px solid var(--glass-border);border-radius:999px;background:#05020ac7;padding:11px 18px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);text-align:center}.dnd-dice-bar{position:absolute;left:50%;bottom:18px;transform:translate(-50%);z-index:60;max-width:92%;display:flex;gap:8px;align-items:center;overflow-x:auto;border:1px solid var(--glass-border);border-radius:18px;background:#05020ac7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);padding:10px;box-shadow:0 16px 36px #0000005c}.roll-btn{flex:0 0 auto;min-width:48px;border:0;border-radius:12px;padding:11px 12px;background:var(--accent-gradient);color:#fff;font-weight:900;cursor:pointer;transition:transform var(--motion-fast) var(--ease-spring),filter var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.roll-btn:hover{transform:translateY(-2px) scale(1.04);filter:brightness(1.08);box-shadow:0 8px 20px #9d4ede47}.roll-btn:active{transform:scale(.96)}#rollMod{width:70px;flex:0 0 auto;border:1px solid var(--glass-border);border-radius:12px;background:#ffffff0f;color:#fff;padding:10px}#diceFormula{width:92px;flex:0 0 auto;border:1px solid var(--glass-border);border-radius:12px;background:#ffffff0f;color:#fff;padding:10px;font-weight:900}.dnd-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.dnd-chat-message{border:1px solid var(--glass-border);border-radius:14px;background:#ffffff0a;padding:12px;animation:chatPop var(--motion-med) var(--ease-out) both}.dnd-chat-message.roll{border-color:#c77dff80;background:#9d4ede1f}.dnd-chat-message strong{display:block;color:var(--amethyst-light);font-size:.68rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.dnd-chat-message p{margin:0;font-size:.86rem;line-height:1.45}.dnd-chat-form{display:grid;grid-template-columns:1fr auto;gap:8px;padding:14px;border-top:1px solid var(--glass-border)}.game-setup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#05010a;z-index:11000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;animation:fadeInUp .6s ease-out forwards}.game-setup-logo{width:100px;margin-bottom:30px;filter:drop-shadow(0 0 15px var(--amethyst-bright))}.game-setup-subtitle{opacity:.6;text-align:center;font-size:12px;margin-bottom:30px;letter-spacing:2px}.game-setup-card{background:var(--glass-surface);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:24px;padding:28px 20px;width:100%;max-width:300px;margin-bottom:20px}.game-mode-toggle{display:flex;gap:8px;background:#0000004d;padding:5px;border-radius:12px;margin-bottom:20px}.game-mode-btn{flex:1;padding:12px;border-radius:8px;border:none;background:transparent;color:#fff;font-weight:600;font-size:13px;cursor:pointer;transition:transform var(--motion-fast) ease,background var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.game-mode-btn:hover{transform:translateY(-1px);background:#ffffff14}.game-mode-btn.active{background:var(--amethyst-bright);box-shadow:0 4px 15px #9d4edd66}.game-difficulty-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:20px}.game-difficulty-btn{padding:10px;border-radius:8px;background:#ffffff0d;border:1px solid var(--glass-border);color:#fff;font-size:10px;cursor:pointer;font-weight:800;transition:transform var(--motion-fast) ease,border-color var(--motion-fast) ease,background var(--motion-fast) ease}.game-difficulty-btn:hover{transform:translateY(-1px);border-color:#c77dff75}.game-difficulty-btn.active{background:#9d4edd33;border-color:var(--amethyst-bright)}.game-start-btn{width:100%;margin-top:10px!important}.game-master-wrapper{width:100%;height:100dvh;display:flex;flex-direction:column;justify-content:space-between;align-items:center;position:relative;overflow:hidden;padding:env(safe-area-inset-top,20px) 15px env(safe-area-inset-bottom,20px) 15px;background:radial-gradient(circle at 50% 50%,#1a0b2e,#05010a);animation:fadeInUp .6s cubic-bezier(.2,.8,.2,1) forwards}.game-master-header{width:100%;display:flex;justify-content:space-between;align-items:center;z-index:1000;height:50px;gap:10px}.game-title-small{font-weight:900;font-size:14px;color:var(--text-secondary)}.game-turn-indicator{background:var(--glass-surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);padding:8px 16px;border-radius:50px;font-size:12px;font-weight:800;flex:1;text-align:center}.game-turn-indicator.white-turn{background:#00ffa326;border-color:#00ffa3;color:#00ffa3}.game-turn-indicator.black-turn{background:#ff416c26;border-color:#ff416c;color:#ff416c}.game-exit-btn{padding:8px 16px!important;font-size:12px!important;margin:0!important;width:auto!important}.game-board-container{flex:1;display:flex;align-items:center;justify-content:center;width:100%}.game-chess-board{display:grid;grid-template-columns:repeat(8,1fr);width:90vw;max-width:380px;height:90vw;max-height:380px;border:2px solid var(--glass-border);border-radius:8px;overflow:hidden;box-shadow:0 10px 30px #00000080}.game-chess-square{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;position:relative;transition:transform var(--motion-fast) ease,filter var(--motion-fast) ease,box-shadow var(--motion-fast) ease,background var(--motion-fast) ease}.game-chess-square:hover{filter:brightness(1.08)}.game-chess-square.light{background:#d1d9e0}.game-chess-square.dark{background:#5c7c99}.game-chess-square.selected{background:#f6f669!important;box-shadow:inset 0 0 10px #0003}.game-chess-piece{-webkit-user-select:none;user-select:none;pointer-events:none;color:inherit}.game-card-unit{width:clamp(70px,15vw,95px);height:clamp(100px,22vw,135px);background:var(--card-dark-bg)!important;border:1px solid var(--card-dark-border)!important;border-radius:12px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:8px;box-sizing:border-box;box-shadow:var(--card-dark-shadow);transition:transform var(--motion-med) var(--ease-spring),border-color var(--motion-fast) ease,box-shadow var(--motion-med) ease,filter var(--motion-fast) ease;position:relative;-webkit-user-select:none;user-select:none;cursor:pointer;color:#fff;font-weight:900;font-size:1.4rem}.game-card-unit.back{background:linear-gradient(135deg,#1a1a1a,#050505)!important;border:2px solid var(--amethyst-bright)!important;color:transparent!important}.game-card-unit:active{transform:translateY(-8px) scale(1.05);box-shadow:0 0 20px #9d4edd66!important;border-color:var(--amethyst-bright)!important}.game-card-unit:hover{transform:translateY(-6px) rotate(-1deg);border-color:#c77dffb3!important;box-shadow:0 18px 32px #0000008c,0 0 18px #9d4edd2e!important}.flying-card{position:fixed;z-index:9999;pointer-events:none!important}.game-player-area{width:100%;display:flex;flex-direction:column;align-items:center;background:#0000004d;padding:15px;border-radius:24px 24px 0 0;z-index:10}.game-action-buttons{display:flex;gap:10px;margin-bottom:10px}.game-player-hand{display:flex;gap:10px;padding:15px;overflow-x:auto;width:100%;justify-content:center;box-sizing:border-box}.game-btn-action{background:var(--glass-surface);border:1px solid var(--glass-border);color:#fff;padding:10px 20px;border-radius:16px;font-weight:800;text-transform:uppercase;font-size:12px;cursor:pointer;transition:transform var(--motion-fast) ease,border-color var(--motion-fast) ease,background var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.game-btn-action:hover{transform:translateY(-2px);border-color:#c77dff75;background:#9d4ede1f}.game-btn-action:active{transform:scale(.95);border-color:var(--amethyst-bright);background:var(--amethyst-glow)}.game-opponents-row{display:flex;justify-content:space-evenly;width:100%;padding:10px 0;box-sizing:border-box}.game-bot-pill{background:var(--glass-surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:20px;padding:10px 20px;text-align:center;transition:transform var(--motion-med) var(--ease-out),border-color var(--motion-fast) ease,background var(--motion-fast) ease,box-shadow var(--motion-med) ease;min-width:80px;box-shadow:0 4px 15px #0000004d;font-size:11px}.game-bot-pill.active{border-color:var(--amethyst-bright);background:#9d4edd26;transform:translateY(-5px);box-shadow:0 10px 20px #9d4edd4d}.game-bot-count{font-weight:900;color:var(--amethyst-bright);font-size:16px}.game-master-table{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;width:100%}.game-stack-indicator{color:var(--danger);font-weight:900;height:24px;margin-bottom:15px;text-shadow:0 0 10px rgba(255,65,108,.5)}.game-card-center{display:flex;gap:30px;align-items:center;margin-bottom:20px}.game-color-line{width:100px;height:6px;border-radius:10px;transition:background var(--motion-med) ease,box-shadow var(--motion-med) ease,width var(--motion-med) ease;box-shadow:0 0 20px #9d4edd80}.game-color-picker{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#05020af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10000;grid-template-columns:1fr 1fr;gap:20px;padding:40px;align-content:center}.game-color-tile{height:140px;border-radius:25px;cursor:pointer;border:3px solid rgba(255,255,255,.1);transition:transform var(--motion-fast) ease,border-color var(--motion-fast) ease,filter var(--motion-fast) ease}.game-color-tile:hover{transform:translateY(-3px) scale(1.02);border-color:#ffffff47;filter:brightness(1.05)}.game-color-tile:active{transform:scale(.9)}@media (max-width: 768px){.main-title{font-size:clamp(1.7rem,8vw,2.2rem)!important;line-height:1.08}.game-card,.action-card{padding:18px 10px;gap:8px}.grid-layout{gap:12px}.game-master-wrapper{padding:env(safe-area-inset-top,15px) 12px env(safe-area-inset-bottom,15px) 12px}.game-card-unit{width:clamp(60px,12vw,85px);height:clamp(90px,20vw,125px)}.game-chess-board{width:85vw;height:85vw}.sidebar-glass{right:-110%;width:min(86vw,320px);overflow-y:auto;-webkit-overflow-scrolling:touch}.settings-profile-preview,.music-playlist-head{align-items:stretch;flex-direction:column}.music-actions{grid-template-columns:1fr}.dnd-hero{min-height:220px;padding:24px}.dnd-grid,.dnd-manual-layout,.dnd-two-col{grid-template-columns:1fr}.dnd-sheet-grid{grid-template-columns:1fr 1fr}.dnd-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.dnd-section-actions,.dnd-list-card{align-items:stretch;flex-direction:column}.dnd-session{grid-template-columns:1fr;grid-template-rows:minmax(190px,25dvh) minmax(0,1fr) minmax(210px,28dvh)}.dnd-left-panel{border-right:0;border-bottom:1px solid rgba(157,78,222,.22);padding:14px;gap:12px;min-height:0}.dnd-chat-panel{border-left:0;border-top:1px solid rgba(157,78,222,.22);min-height:0}.dnd-session-panel header{padding-bottom:10px}.dnd-session-block{gap:8px}.initiative-form{grid-template-columns:1fr 64px}.dnd-table-topbar{align-items:stretch;flex-wrap:wrap;top:calc(10px + env(safe-area-inset-top));left:10px;right:10px}.dnd-table-topbar strong{display:none}.map-control-row{width:100%;justify-content:space-between}.dnd-dice-bar{left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));transform:none;max-width:none;border-radius:16px;padding:8px}.roll-btn{min-width:44px;padding:10px 11px}#diceFormula{width:84px}}@media (max-width: 380px){#app{padding-left:14px;padding-right:14px}.grid-layout{grid-template-columns:1fr}.floating-trigger{width:56px;height:56px;right:14px;bottom:calc(18px + env(safe-area-inset-bottom))}.nav-logo-right{right:14px;width:40px;height:40px}.dnd-sheet-grid,.dnd-stat-grid{grid-template-columns:1fr}}@media (min-width: 769px){.sidebar-glass{width:350px}}.fade-out{opacity:0;pointer-events:none;transition:.5s}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}}
