*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg-primary: #0a0e1a;--color-bg-secondary: #121829;--color-bg-tertiary: #1a2238;--color-bg-glass: rgba(26, 34, 56, .7);--color-accent-primary: #9d4edd;--color-accent-secondary: #c77dff;--color-accent-gold: #ffd60a;--color-accent-red: #ef476f;--color-accent-green: #06ffa5;--neon-purple: #bc13fe;--color-text-primary: #f8f9fa;--color-text-secondary: #adb5bd;--color-text-muted: #6c757d;--color-border: rgba(157, 78, 221, .2);--color-border-light: rgba(255, 255, 255, .1);--color-glass-border: rgba(255, 255, 255, .1);--font-display: "Cinzel", serif;--font-body: "Inter", sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(157, 78, 221, .4);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}body{font-family:var(--font-body);background:linear-gradient(135deg,#0a0e1a,#1a1a2e);color:var(--color-text-primary);min-height:100vh;overflow:hidden}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0a0e1a,#1a1a2e);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .3s ease-in-out}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-content{text-align:center}.loading-title-container{display:flex;flex-direction:column;align-items:center;gap:10px}.loading-logo{width:400px;height:400px}.loading-title{font-family:var(--font-display);font-size:3rem;font-weight:700;filter:drop-shadow(0 0 10px rgba(157,78,221,.5));margin-bottom:var(--space-lg);animation:glow 3s ease-in-out infinite}.loading-spinner{width:60px;height:60px;border:4px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;margin:var(--space-2xl) auto var(--space-md);animation:spin 1s linear infinite,glow 3s ease-in-out infinite}.loading-text{color:var(--color-text-secondary);font-size:1rem}@keyframes spin{to{transform:rotate(360deg)}}@keyframes glow{0%{filter:drop-shadow(0 0 10px rgba(157,78,221,.5))}50%{filter:drop-shadow(0 0 20px rgba(157,78,221,.8))}to{filter:drop-shadow(0 0 10px rgba(157,78,221,.5))}}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0a0e1aa6,#1a1a2ee0),url(/assets/parchment_texture2.png);background-size:cover;background-position:center;background-attachment:fixed;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.auth-container{background:#14141e0d;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid var(--color-glass-border);border-radius:var(--radius-lg);padding:var(--space-2xl);width:100%;max-width:450px;box-shadow:0 8px 32px #00000080;transition:all .4s cubic-bezier(.4,0,.2,1)}.auth-title-container{display:flex;flex-direction:column;align-items:center}.auth-logo{width:200px;height:200px}.auth-title{font-family:var(--font-display);font-size:2.5rem;text-align:center;color:var(--color-text-primary);filter:drop-shadow(0 0 10px rgba(157,78,221,.5));margin-bottom:var(--space-sm);animation:glow 3s ease-in-out infinite}.auth-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-xl)}.auth-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.auth-tab{flex:1;padding:var(--space-md);background:#ffffff0d;border:1px solid var(--color-glass-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-body);font-size:1rem;cursor:pointer;transition:all .3s ease}.auth-tab:hover{border-color:var(--color-accent-primary);background:#ffffff1a;color:var(--color-text-primary)}.auth-tab.active{background:#9d4edd33;border-color:var(--neon-purple);color:#fff;box-shadow:0 0 20px #9d4edd4d}.auth-forms-container{position:relative;transition:height .4s cubic-bezier(.4,0,.2,1);overflow:hidden}.auth-form{display:flex;flex-direction:column;gap:var(--space-md);position:absolute;width:100%;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s ease;transform:translateY(0);opacity:1}.auth-form.auth-hidden{transform:translateY(-20px);pointer-events:none;opacity:0}.auth-input{padding:var(--space-md);background:#0000004d;border:1px solid var(--color-glass-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:1rem;transition:all .3s ease}.auth-input:focus{outline:none;border-color:var(--neon-purple);background:#00000080;box-shadow:0 0 15px #9d4edd33}.role-selector{display:flex;gap:var(--space-md)}.role-option{flex:1;padding:var(--space-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border-light);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:all var(--transition-normal)}.role-option:has(input:checked){border-color:var(--color-accent-primary);background:#9d4edd1a}.role-option input{display:none}.auth-form:not(.auth-hidden) .auth-input{animation:slideIn .3s ease-out backwards}.auth-form:not(.auth-hidden) .auth-input:nth-child(1){animation-delay:.1s}.auth-form:not(.auth-hidden) .auth-input:nth-child(2){animation-delay:.2s}.auth-form:not(.auth-hidden) .auth-input:nth-child(3){animation-delay:.3s}@keyframes slideIn{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}#auth-submit-btn{animation:none}#auth-submit-btn.text-changing{animation:textChange .4s ease-in-out}@keyframes textChange{0%{color:#fff}50%{color:transparent}to{color:#fff}}.btn{padding:var(--space-md) var(--space-lg);background:#ffffff1a;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-primary);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.btn-primary{background:#ffffff1a;border:1px solid var(--color-glass-border);color:#fff;box-shadow:0 4px 16px #0000004d}.btn-primary:hover{background:#fff3;color:#fff;border:1px solid var(--neon-purple);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#ffffff08;border:1px solid rgba(255,255,255,.15);color:var(--color-text-secondary)}.btn-secondary:hover{border-color:var(--color-neon-purple);background:#ffffff14;color:var(--color-text-primary)}.btn-small{padding:var(--space-sm) var(--space-md);font-size:.875rem}.game-screen{display:flex;flex-direction:column;height:100vh;opacity:0;transition:opacity .5s ease-in-out}.game-screen.visible{opacity:1}.game-header{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);padding:var(--space-md) var(--space-xl);display:flex;justify-content:space-between;align-items:center;gap:2rem;box-shadow:var(--shadow-md)}.game-logo{font-family:var(--font-display);font-size:1.5rem;background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.game-selector{display:flex;align-items:center;gap:1rem;flex:1;max-width:500px}.game-select{flex:1;padding:.5rem 1rem;background:#ffffff0d;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:.875rem;font-family:var(--font-body);cursor:pointer;transition:all .3s ease}.game-select:hover{background:#ffffff14;border-color:var(--color-accent-primary)}.game-select:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #9d4edd1a}.game-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}.header-actions{display:flex;gap:var(--space-md);align-items:center}.user-info{color:var(--color-text-secondary);font-size:.875rem}.game-container{display:flex;flex:1;overflow:hidden}.sidebar{width:350px;background:var(--color-bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto}.sidebar-section{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light)}.sidebar-title{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent-gold);margin-bottom:var(--space-md)}.characters-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md);max-height:200px;overflow-y:auto}.character-card{padding:var(--space-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.character-card:hover{border-color:var(--color-accent-primary);transform:translate(4px)}.character-card.active{border-color:var(--color-accent-primary);background:#9d4edd1a}.dice-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-bottom:var(--space-md)}.dice-btn{padding:var(--space-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border-light);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-display);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.dice-btn:hover{border-color:var(--color-accent-gold);background:#ffd60a1a;transform:scale(1.05)}.dice-btn:active{transform:scale(.95);animation:roll .5s ease}@keyframes roll{0%,to{transform:rotate(0) scale(.95)}25%{transform:rotate(90deg) scale(1.1)}50%{transform:rotate(180deg) scale(.9)}75%{transform:rotate(270deg) scale(1.1)}}.dice-modifiers{display:flex;gap:var(--space-sm)}.dice-input{flex:1;padding:var(--space-sm) var(--space-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body)}.dice-input:focus{outline:none;border-color:var(--color-accent-primary)}.checkbox-label{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);font-size:.9rem;cursor:pointer;transition:color .2s;-webkit-user-select:none;user-select:none}.checkbox-label:hover{color:var(--color-text-primary)}.checkbox-label input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1px solid var(--color-border-light);border-radius:3px;background:#ffffff0d;cursor:pointer;position:relative;transition:all .2s}.checkbox-label input[type=checkbox]:checked{background:#ffffff1a;border-color:var(--color-accent-primary);box-shadow:0 0 8px #9d4edd4d}.checkbox-label input[type=checkbox]:checked:after{content:"✓";position:absolute;color:#fff;font-size:12px;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:700}.checkbox-label:hover input[type=checkbox]:not(:checked){border-color:var(--color-text-secondary)}.chat-messages{height:300px;overflow-y:auto;margin-bottom:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md)}.chat-message{margin-bottom:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-left:3px solid var(--color-accent-primary);border-radius:var(--radius-sm)}.chat-message.gm{border-left-color:var(--color-accent-gold)}.chat-message.dice{border-left-color:var(--color-accent-green)}.chat-username{font-weight:600;color:var(--color-accent-secondary);margin-bottom:var(--space-xs);font-size:.875rem}.chat-text{color:var(--color-text-primary)}.chat-timestamp{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.chat-input-container{display:flex;gap:var(--space-sm)}.chat-input{flex:1;padding:var(--space-sm) var(--space-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body)}.chat-input:focus{outline:none;border-color:var(--color-accent-primary)}.game-board{flex:1;position:relative;background:var(--color-bg-primary);overflow:hidden}.board-controls{position:absolute;top:var(--space-lg);right:var(--space-lg);display:flex;gap:var(--space-sm);z-index:10}.control-btn{width:40px;height:40px;background:var(--color-bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.control-btn:hover{border-color:var(--color-accent-primary);background:var(--color-bg-secondary);transform:scale(1.1)}.canvas-container,#game-canvas{width:100%;height:100%}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-accent-primary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-secondary)}.wiki-btn{position:fixed;bottom:20px;left:20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 20px;border-radius:10px;color:var(--color-text-primary);text-decoration:none;font-weight:700;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;z-index:1000;display:flex;align-items:center;gap:8px}.wiki-btn:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d;border-color:var(--color-accent-primary)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23c77dff%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right .7rem top 50%;background-size:.65rem auto;padding-right:2rem!important;cursor:pointer}select option{background-color:var(--color-bg-secondary);color:var(--color-text-primary);padding:10px}input,select,textarea,.form-control{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}:root{--glass-bg: rgba(20, 20, 30, .6);--glass-border: rgba(255, 255, 255, .1);--glass-highlight: rgba(255, 255, 255, .05);--neon-blue: #00f3ff;--neon-purple: #bc13fe;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--dock-width: 80px;--top-bar-height: 40px;--color-accent-primary: #9d4edd;--color-accent-secondary: #c77dff;--color-accent-gold: #ffd60a;--color-accent-red: #ef476f;--color-accent-green: #06ffa5;--section-general: rgba(0, 243, 255, .1);--section-stats: rgba(188, 19, 254, .1);--section-combat: rgba(255, 95, 87, .1);--section-inventory: rgba(255, 204, 0, .1)}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #0000005e;border-radius:16px;color:var(--text-primary);transition:all .3s ease}.glass-btn{background:#ffffff1a;border:1px solid var(--glass-border);color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:Inter,sans-serif}.glass-btn:hover{background:#fff3;border-color:var(--neon-purple);transform:translateY(-1px)}#glass-top-bar{position:fixed;top:0;left:0;right:0;height:var(--top-bar-height);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:1000;border-radius:0 0 16px 16px;border-top:none}.top-bar-title{font-family:var(--font-display);filter:drop-shadow(0 0 10px rgba(157,78,221,.5));animation:glow 2s ease-in-out infinite;font-size:1.2rem;font-weight:500;letter-spacing:2px;text-transform:uppercase}#glass-dock{position:fixed;left:20px;top:50%;transform:translateY(-50%);width:60px;display:flex;flex-direction:column;gap:1rem;padding:1rem 0;align-items:center;z-index:1000}.dock-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);position:relative;background:var(--glass-highlight);border:1px solid var(--glass-border)}.dock-icon:hover{transform:scale(1.1) translate(5px);background:#ffffff1a;border-color:var(--neon-purple);box-shadow:0 0 15px #00f3ff4d}.dock-icon.active{background:#fff3;border-color:var(--neon-purple);box-shadow:0 0 20px #fff6}.dock-tooltip{position:absolute;left:60px;background:#000c;padding:.5rem 1rem;border-radius:4px;font-size:.8rem;opacity:0;pointer-events:none;transition:opacity .2s;white-space:nowrap}.dock-icon:hover .dock-tooltip{opacity:1}#windows-container{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:900}.glass-window{position:absolute;min-width:300px;min-height:200px;max-width:800px;max-height:80vh;display:flex;flex-direction:column;pointer-events:auto;opacity:0;transform:scale(.95);transition:opacity .3s,transform .3s;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #0000005e;border-radius:16px;color:var(--text-primary)}.glass-window.visible{opacity:1;transform:scale(1)}.window-header{padding:.8rem;border-bottom:1px solid var(--glass-border);display:flex;justify-content:space-between;align-items:center;cursor:grab;background:#ffffff05;border-radius:16px 16px 0 0}.window-header:active{cursor:grabbing}.window-title{font-family:var(--font-display);letter-spacing:1px;font-size:.9rem}.window-controls{display:flex;gap:.5rem}.window-btn{width:20px;height:20px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:transform .2s}.btn-close{background:#ff5f57cc;color:#fff;width:24px;height:24px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;transition:transform .2s}.btn-close:hover{transform:scale(1.1);background:#ff5f57}.window-content{flex:1;overflow-y:auto;padding:1rem}.window-footer{padding:1rem;border-top:1px solid var(--glass-border);display:flex;justify-content:flex-end;background:#0003;border-radius:0 0 16px 16px}.btn-upload-avatar:hover{transform:scale(1.1);background:var(--neon-blue);color:#000}#chat-panel{position:fixed;bottom:20px;right:20px;width:400px;height:400px;display:flex;flex-direction:column;z-index:1000;transition:height .3s ease,transform .3s ease;overflow:hidden;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #0000005e;border-radius:16px}.chat-header{padding:.8rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:#ffffff0d;border-radius:16px 16px 0 0}.resize-handle{position:absolute;top:42px;left:1px;width:20px;height:20px;cursor:nwse-resize;z-index:10;pointer-events:auto}.resize-handle:before{content:"⋰";position:absolute;top:2px;left:2px;font-size:20px;opacity:.5;transition:opacity .2s}.resize-handle:hover:before{opacity:.8}.character-sheet-window{width:600px;resize:both;overflow:auto;min-width:400px;min-height:300px}.sheet-section.collapsed .sheet-fields{display:none}.sheet-section.collapsed{padding-bottom:0}.sheet-field-full{grid-column:span 2}.sheet-field label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.form-input,.form-textarea{background:#0000004d;border:1px solid var(--glass-border);color:#fff;padding:.6rem;border-radius:8px;font-family:inherit;transition:border-color .2s;width:100%;box-sizing:border-box}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--neon-blue)}.field-with-action{display:flex;gap:.5rem}.field-with-action .form-input{flex:1}.btn-roll-dice{background:#ffffff1a;border:1px solid var(--glass-border);color:#fff;width:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s}#canvas-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;background:transparent}#chat-panel{position:fixed;bottom:20px;right:20px;width:400px;height:400px;display:flex;flex-direction:column;z-index:1000;transition:height .3s ease,transform .3s ease;overflow:hidden}#chat-panel.collapsed{height:50px;transform:translateY(0)}.chat-header{padding:.8rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:#ffffff0d;border-radius:16px 16px 0 0;position:relative;z-index:11}.chat-content-area{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:.5rem}.chat-messages{flex:1;overflow-y:auto;margin-bottom:.5rem;padding-right:.5rem}.chat-form{display:flex;gap:.5rem;margin-top:auto}#chat-toggle-icon{font-size:.8rem;opacity:.6;transition:transform .3s ease,opacity .2s ease;cursor:pointer}#chat-toggle-icon:hover{opacity:1}.glass-input{background:#0000004d;border:1px solid var(--glass-border);color:#fff;padding:.5rem;border-radius:8px;flex:1}.glass-input:focus{outline:none;border-color:var(--neon-blue)}.btn-roll-dice{background:#ffffff1a;border:1px solid var(--glass-border);color:#fff;width:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .2s}.btn-roll-dice:hover{background:#fff3;border-color:var(--neon-blue);transform:scale(1.05)}.sheet-field-computed{flex-direction:row;align-items:center;justify-content:space-between;background:#0003;padding:.5rem .8rem;border-radius:8px;height:42px;box-sizing:border-box}.computed-value{font-weight:700;color:var(--neon-purple);font-size:1.1rem}.sheet-field-avatar{grid-column:span 2}.avatar-container{display:flex;align-items:center;gap:1rem;background:#0003;padding:.8rem;border-radius:8px}.avatar-image{width:80px;height:80px;border-radius:50%;object-fit:cover;border:1px solid var(--glass-border);box-shadow:0 0 10px #ffffff80}.btn-upload-avatar{padding:.5rem 1rem;background:#ffffff1a;color:#fff;border:1px solid var(--glass-border);border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.btn-upload-avatar:hover{background:#fff3;color:#fff;border-color:var(--neon-purple);transform:translateY(-1px);box-shadow:0 4px 12px #fff6}.btn-upload-avatar:disabled{opacity:.5;cursor:not-allowed;transform:none}@keyframes glow{0%{filter:drop-shadow(0 0 10px rgba(157,78,221,.5))}50%{filter:drop-shadow(0 0 20px rgba(157,78,221,.8))}}.hidden{display:none!important}.scene-manager{margin-top:2rem}.scene-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.scene-list{display:flex;flex-direction:column;gap:.5rem}.scene-card{background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;padding:.75rem;display:flex;justify-content:space-between;align-items:center;transition:all .2s}.scene-card:hover{background:#ffffff1a;border-color:var(--neon-purple)}.scene-card.active{border-color:var(--neon-purple);background:#bc13fe1a}.scene-info{display:flex;align-items:center;gap:.5rem}.scene-name{font-weight:500}.scene-actions{display:flex;gap:.5rem}.btn-settings-scene,.btn-activate-scene,.btn-edit-scene{background:#ffffff0d;border-color:var(--glass-border)}.btn-settings-scene:hover,.btn-activate-scene:hover,.btn-edit-scene:hover{background:#ffffff26;border-color:var(--neon-purple)}.media-library{display:flex;flex-direction:column;gap:1rem}.media-header{display:flex;justify-content:space-between;align-items:center}.media-filters{display:flex;gap:.5rem}.media-upload-zone{border:2px dashed var(--glass-border);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s}.media-upload-zone:hover,.media-upload-zone.drag-over{border-color:var(--neon-blue);background:#00f3ff0d}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-icon{font-size:3rem}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.media-card{background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative}.media-card:hover{border-color:var(--neon-blue);transform:translateY(-2px);box-shadow:0 4px 12px #00f3ff33}.media-card img{width:100%;height:120px;object-fit:cover}.media-info{padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.media-name{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-type{font-size:.7rem}.media-actions{position:absolute;top:.5rem;right:.5rem;opacity:0;transition:opacity .2s}.scene-editor-window{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;width:98vw;height:95vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000080}.scene-editor-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;z-index:2000;display:flex;flex-direction:column}.scene-editor-embedded{width:100%;height:100%;position:relative;display:flex;flex-direction:column;background:#000}.scene-editor-window{flex:1;display:flex;flex-direction:column;height:100%;position:relative}.scene-toolbar{height:50px;background:#14141e0d;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-bottom:1px solid var(--color-glass-border);display:flex;align-items:center;padding:0 1rem;gap:1rem;z-index:10}.toolbar-group{display:flex;gap:.5rem}.toolbar-spacer{flex:1}.scene-toolbar .btn{padding:6px 12px;font-size:13px;height:32px;display:inline-flex;align-items:center}.tool-btn{background:#ffffff0d;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid var(--color-glass-border);color:var(--text-primary);padding:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;transition:all .2s ease-out}.tool-btn:hover{transform:scale(1.1) translateY(1px);background:#ffffff1a;border-color:var(--neon-purple);box-shadow:0 0 20px #ffffff4d}.tool-btn.active{background:#fff3;border-color:var(--neon-purple);box-shadow:0 0 20px #fff6}#zoom-indicator{display:inline-flex;align-items:center;justify-content:center;min-width:60px;padding:0 10px;font-variant-numeric:tabular-nums;color:var(--color-text-secondary);font-weight:600}.scene-viewport{flex:1;position:relative;overflow:hidden;background:linear-gradient(135deg,#0a0e1aa6,#1a1a2ee0),url(/assets/parchment_texture2.png);background-size:cover;background-position:center;background-attachment:fixed;cursor:default}.scene-content{position:absolute;top:0;left:0;width:100%;height:100%;transform-origin:0 0;will-change:transform}.scene-layer{position:absolute;top:0;left:0;width:0;height:0;overflow:visible;pointer-events:none}.scene-object{position:absolute;pointer-events:auto;-webkit-user-select:none;user-select:none}.scene-object img{width:100%;height:100%;display:block;pointer-events:none}.scene-object:hover{cursor:pointer;outline:1px solid rgba(0,243,255,.3)}.fog-canvas{position:absolute;top:0;left:0;pointer-events:none}.fog-canvas.active{pointer-events:auto;cursor:crosshair}.selection-gizmo{position:absolute;pointer-events:none;border:1px solid #00f3ff;box-shadow:0 0 10px #00f3ff33}.gizmo-handle{position:absolute;width:10px;height:10px;background:#fff;border:1px solid #00f3ff;border-radius:50%;pointer-events:auto;z-index:101;transform-origin:center}.gizmo-handle:hover{background:#00f3ff}.gizmo-handle.nw{top:-6px;left:-6px;cursor:nw-resize}.gizmo-handle.ne{top:-6px;right:-6px;cursor:ne-resize}.properties-panel{position:absolute;bottom:20px;left:20px;width:240px;background:#14141e80;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-glass-border);border-radius:8px;padding:15px;box-shadow:0 8px 32px #0006;z-index:1000}.prop-header{font-size:14px;font-weight:700;margin-bottom:10px;color:#eee;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:5px}.properties-panel .prop-row{margin-bottom:8px;font-size:12px;gap:5px}.properties-panel .prop-row label{min-width:20px;width:auto}.properties-panel .prop-input{padding:2px 4px;font-size:12px}.prop-row{display:flex;align-items:center;margin-bottom:12px;font-size:14px;gap:10px}.prop-row label{min-width:80px;color:var(--color-text-secondary);font-weight:500}.prop-input{flex:1;background:#00000080;border:1px solid var(--color-glass-border);border-radius:var(--radius-md);padding:4px 8px;color:var(--color-text-primary);width:100%;transition:all .3s ease}.prop-input:focus{outline:none;border-color:var(--neon-purple);background:#00000080;box-shadow:0 0 15px #9d4edd33}.btn-delete{width:100%;background:#ef476f1a;border:1px solid rgba(239,71,111,.3);color:var(--color-accent-red);padding:8px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:5px}.btn-delete:hover{background:#ef476f33;border-color:var(--color-accent-red);box-shadow:0 0 15px #ef476f4d;color:#ff6b6b}.gizmo-handle.sw{bottom:-6px;left:-6px;cursor:sw-resize}.gizmo-handle.se{bottom:-6px;right:-6px;cursor:se-resize}.gizmo-rotate{position:absolute;top:-25px;left:50%;transform:translate(-50%);width:12px;height:12px;background:#fff;border:1px solid #00f3ff;border-radius:50%;cursor:grab;pointer-events:auto;transform-origin:center}.gizmo-rotate:after{content:"";position:absolute;top:12px;left:50%;width:1px;height:12px;background:#00f3ff;transform:translate(-50%)}.floating-window{position:absolute;background:#14141e80;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--color-glass-border);border-radius:8px;box-shadow:0 12px 48px #00000080;min-width:300px;z-index:1000;display:flex;flex-direction:column}.floating-window-header{padding:.75rem 1rem;background:#ffffff0d;border-bottom:1px solid var(--color-glass-border);display:flex;justify-content:space-between;align-items:center;cursor:move;-webkit-user-select:none;user-select:none}.floating-window-content{padding:1rem;max-height:400px;overflow-y:auto}.floating-window .prop-row input{flex:1;background:#00000080;border:1px solid var(--color-glass-border);border-radius:var(--radius-md);padding:4px 8px;color:var(--color-text-primary);width:100%;transition:all .3s ease}.floating-window .prop-row input:focus{outline:none;border-color:var(--neon-purple);box-shadow:0 0 15px #9d4edd33}.floating-window .prop-row input[type=checkbox]{width:auto;flex:0;cursor:pointer}.floating-window .prop-row input[type=color]{padding:0;height:30px;cursor:pointer}.btn-close-window{background:#ff5f57cc;color:#fff;width:24px;height:24px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;transition:transform .2s}.btn-close-window:hover{transform:scale(1.1);background:#ff5f57}.viewport-frame{position:absolute;border:2px solid var(--color-glass-border);pointer-events:none;z-index:50}.player-mask-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:100;overflow:hidden}.mask-part{position:absolute;background:linear-gradient(135deg,#0a0e1aa6,#1a1a2ee0),url(/assets/parchment_texture2.png);background-size:cover;background-position:center;background-attachment:fixed;pointer-events:none}.scene-editor-window.embedded{border-radius:4px}.layers-dock{position:absolute;right:20px;top:100px;width:220px;background:#14141e80;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-glass-border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 8px 32px #0006;z-index:1000}.dock-header{font-size:12px;text-transform:uppercase;color:#ffffff80;margin-bottom:5px;letter-spacing:1px}.layer-item{display:flex;align-items:center;padding:8px;background:#ffffff0d;border-radius:6px;cursor:pointer;transition:all .2s;border:1px solid transparent}.layer-item:hover{background:#ffffff1a}.layer-item.active{border-color:#646cff;background:#646cff1a}.layer-icon{margin-right:10px;font-size:16px}.scene-editor-window.embedded{width:100%;height:100%;border:none}.layer-name{flex:1;font-size:14px;color:#eee}.layer-focus{background:none;border:none;color:#ffffff4d;cursor:pointer;padding:4px;border-radius:4px}.layer-focus:hover{color:#fff;background:#ffffff1a}.scene-object.invisible{opacity:.5;filter:grayscale(100%)}.grid-overlay{position:absolute;pointer-events:none}.scene-editor-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:2000;background:#000c;display:flex;align-items:center;justify-content:center}.scene-editor-embedded{position:relative;width:100%;height:100%;overflow:hidden;background:#000}.scene-editor-window.embedded{width:100%;height:100%;border:none;border-radius:0;background:transparent;box-shadow:none}.scene-editor-window.embedded .viewport-label{display:none}.ping-marker{position:absolute;pointer-events:none;z-index:1000;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;animation:ping-fade 2s ease-out forwards}.ping-attention .ping-ring{position:absolute;width:20px;height:20px;border-radius:50%;border:2px solid #fff;background:#ffffff80;box-shadow:0 0 10px #ffeb3b;animation:ping-ripple 1.5s ease-out infinite}.ping-danger .ping-icon{font-size:24px;color:#ff3b3b;text-shadow:0 0 10px #000;animation:ping-bounce .5s ease-out infinite alternate}.ping-danger .ping-ring{border-color:#ff3b3b;box-shadow:0 0 15px red}.ping-move .ping-icon{font-size:24px;color:#0f0;text-shadow:0 0 10px #000;transform:rotate(45deg)}.ping-move .ping-ring{border-color:#0f0;box-shadow:0 0 10px #0f0;border-style:dashed}.ping-question .ping-icon{font-size:24px;color:#00bfff;text-shadow:0 0 10px #000;animation:ping-spin 2s linear infinite}.ping-question .ping-ring{border-color:#00bfff;box-shadow:0 0 10px #00bfff}.ping-area .ping-ring{width:100px;height:100px;background:#ffa50033;border:2px solid #ffa500;box-shadow:0 0 20px orange;animation:ping-expand .5s ease-out forwards}@keyframes ping-fade{0%{opacity:1}70%{opacity:1}to{opacity:0}}@keyframes ping-ripple{0%{transform:scale(1);opacity:.8}to{transform:scale(3);opacity:0}}@keyframes ping-bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}@keyframes ping-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes ping-expand{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}#floating-ping-palette{z-index:2000}.ping-btn{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);background:#00000080;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .2s}.ping-btn:hover{background:#ffffff1a;transform:scale(1.1)}.ping-btn.active{border-color:#646cff;background:#646cff33;box-shadow:0 0 10px #646cff80}.dashboard-screen{height:100vh;overflow-y:auto;background:linear-gradient(135deg,#0a0e1aa6,#1a1a2ee0),url(/assets/parchment_texture2.png);background-size:cover;background-position:center;background-attachment:fixed;padding:var(--space-lg);padding-bottom:var(--space-xsl);transition:opacity .5s ease-in-out}.dashboard-screen.fade-out{opacity:0;pointer-events:none}.dashboard-logo{width:50px;height:50px}.dashboard-title-container{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2xl);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.dashboard-title{font-family:var(--font-display);font-size:2rem;filter:drop-shadow(0 0 10px rgba(157,78,221,.5));animation:glow 3s ease-in-out infinite}.dashboard-content{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);align-items:start}#game-list-container,#invitation-list-container{grid-column:1 / -1}#template-list-container{padding:var(--space-lg)}#equipment-manager-container{border-radius:var(--radius-lg);padding:var(--space-lg);height:100%;min-height:400px}#equipment-manager-container .manager-header h4{font-family:var(--font-display);font-size:1.5rem;margin:0}.user-controls{display:flex;justify-content:flex-end;align-items:center;gap:var(--space-md)}.game-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.game-list-header h3{font-family:var(--font-display);font-size:1.5rem;margin:0}.game-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg);max-height:450px;overflow-y:auto;overflow-x:hidden;padding:var(--space-lg)}.game-cards::-webkit-scrollbar{width:8px}.game-cards::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.game-cards::-webkit-scrollbar-thumb{background:#9d4edd80;border-radius:4px}.game-cards::-webkit-scrollbar-thumb:hover{background:#9d4eddcc}.game-card{background:#14141e0d;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid var(--color-glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal);display:flex;flex-direction:column;gap:var(--space-md);box-shadow:0 8px 32px #0006}.game-card:hover{border-color:var(--neon-purple);transform:translateY(-2px);box-shadow:0 12px 40px #9d4edd4d;background:#14141e33}.game-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-sm);min-width:0}.game-name-container{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;overflow:hidden}.game-name{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.game-card-details{display:flex;flex-direction:column;gap:var(--space-xs);color:var(--color-text-secondary);font-size:.875rem}.invitations-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.invitation-card{background:#9d4edd1a;border:1px solid var(--color-accent-primary);border-radius:var(--radius-md);padding:var(--space-md);display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.invitation-actions{display:flex;gap:var(--space-sm)}.gm-panel{border-bottom:1px solid var(--color-accent-gold);padding:var(--space-md)}.gm-panel-header{margin-bottom:var(--space-md)}.gm-panel h3{color:var(--color-accent-gold);font-size:1rem;text-transform:uppercase;letter-spacing:1px}.invite-code-section{background:#0003;padding:var(--space-md);border-radius:8px;border:1px solid rgba(255,255,255,.1)}.code-display{display:flex;gap:10px;align-items:center;margin:var(--space-xs) 0}.code{font-family:Consolas,monospace;font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:2px;background:#ffffff1a;padding:8px 16px;border-radius:8px;border:1px solid var(--color-accent-primary)}.invite-form{display:flex;gap:10px}.invite-form input{flex:1;padding:8px 12px;background:#0003!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:8px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.9rem;transition:all .3s ease}.invite-form input:focus{outline:none;background:#0006!important;border-color:var(--color-accent-primary)!important;box-shadow:0 0 10px #9d4edd33}#template-select,select{padding:8px 12px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.9rem;transition:all .3s ease;cursor:pointer;-webkit-backdrop-filter:none;backdrop-filter:none}#copy-code-btn{padding:8px 12px;background:transparent!important;border:1px solid var(--color-border)!important;border-radius:6px;color:var(--color-text-muted)!important;opacity:1;font-size:.9rem;transition:all .2s ease;cursor:pointer}#copy-code-btn:hover{background:#ffffff1a!important;border-color:var(--color-accent-primary)!important;color:var(--color-text-primary)!important}#template-select option,select option{background-color:#1a2238;color:#fff;padding:10px}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#ffffff1a;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.modal h2{font-family:var(--font-display);margin-bottom:var(--space-md);color:var(--color-accent-gold)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-md);margin-top:var(--space-lg)}.badge{padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge.gm{background:#ffd60a33;color:var(--color-accent-gold);border:1px solid var(--color-accent-gold)}.badge.player{background:#06ffa533;color:var(--color-accent-green);border:1px solid var(--color-accent-green)}.badge.notification{background:var(--color-accent-red);color:#fff}.btn-success{background:var(--color-accent-green);color:var(--color-bg-primary)}.btn-danger{background:#ef476f1a;border:1px solid rgba(239,71,111,.3);color:var(--color-accent-red)}.btn-danger:hover{background:var(--color-accent-red);border-color:var(--color-accent-red);color:#fff;transform:translateY(-1px);box-shadow:0 8px 24px #ef476f4d}.btn-danger:active{transform:translateY(0)}.member-name{font-weight:500;color:var(--color-text-primary)}.kick-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:4px 8px;border-radius:6px;transition:all .2s ease;opacity:.7}.kick-btn:hover{opacity:1;transform:scale(1.1);background:#ffffff0d;border-color:var(--color-accent-red);box-shadow:0 0 10px #ffffff1a}.add-field-icon{font-size:1.5rem}.editor-actions{display:flex;justify-content:flex-end;gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.section-card{background:#0003;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-light)}.section-title-group{display:flex;align-items:center;gap:var(--space-md);flex:1}.section-title-input{background:transparent;border:none;border-bottom:1px dashed var(--color-text-secondary);color:var(--color-accent-gold);font-family:var(--font-display);font-size:1.1rem;padding:4px 0;width:200px;transition:all var(--transition-fast)}.section-title-input:focus{outline:none;border-bottom-color:var(--color-accent-primary);color:var(--color-accent-primary)}.section-count{font-size:.75rem;color:var(--color-text-muted)}.btn-icon{background:transparent;border:none;cursor:pointer;font-size:1.1rem;opacity:.7;transition:all var(--transition-fast);color:var(--color-text-secondary)}.btn-icon:hover{opacity:1;color:var(--color-accent-primary)}.members-section{margin-bottom:var(--space-lg)}.members-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.member-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .2s ease}.member-item:hover{background:#ffffff1a;transform:translate(2px)}.member-info{display:flex;align-items:center;gap:.75rem}.status-indicator{width:10px;height:10px;border-radius:50%;background-color:var(--color-accent-red);box-shadow:0 0 5px var(--color-accent-red);transition:all .1s ease}.status-indicator.online{background-color:var(--color-accent-green);box-shadow:0 0 8px var(--color-accent-green)}.member-name{overflow:hidden;transition:all .3s ease}.accordion-item.active{background:#ffffff0d;border-color:var(--color-accent-primary);box-shadow:0 4px 20px #0003}.accordion-header{padding:var(--space-md);display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;background:#0003;transition:background .2s ease}.accordion-header:hover{background:#ffffff0d}.accordion-title{font-family:var(--font-display);font-size:1.1rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-sm);transition:color .3s ease}.accordion-item.active .accordion-title{color:var(--color-accent-gold)}.accordion-icon{transition:transform .3s ease;font-size:.8rem;opacity:.6}.accordion-item.active .accordion-icon{transform:rotate(180deg);opacity:1;color:var(--color-accent-primary)}.accordion-content{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,padding .3s ease;opacity:0}.accordion-item.active .accordion-content{max-height:2000px;opacity:1;padding:var(--space-md);border-top:1px solid var(--color-border-light)}.action-btn{background:transparent!important;border:1px solid var(--color-border)!important;color:var(--color-text-muted)!important;padding:4px 8px;border-radius:6px;transition:all .2s ease;opacity:.7;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.action-btn:hover{opacity:1;transform:scale(1.1);background:#ffffff0d!important;border-color:var(--color-text-primary)!important;color:var(--color-text-primary)!important;box-shadow:0 0 10px #ffffff1a}.action-btn.danger:hover{background:#ef476f1a!important;border-color:var(--color-accent-red)!important;color:var(--color-accent-red)!important;box-shadow:0 0 10px #ef476f33}.action-btn.primary:hover{background:#9d4edd1a!important;border-color:var(--color-accent-primary)!important;color:var(--color-accent-primary)!important;box-shadow:0 0 10px #9d4edd33}.custom-roll{display:flex;gap:10px;margin-top:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}#dice-expression{background:#0003!important;border:1px solid rgba(255,255,255,.1)!important;color:var(--color-text-primary)!important;padding:8px 12px;border-radius:8px;font-family:Consolas,monospace;font-size:.9rem;transition:all .3s ease;letter-spacing:1px}#dice-expression:focus{background:#0006!important;border-color:var(--color-accent-primary)!important;box-shadow:0 0 10px #9d4edd33}#dice-expression::placeholder{color:#ffffff4d;font-family:var(--font-body);letter-spacing:0}#roll-btn{background:#ffffff1a!important;border:1px solid var(--color-accent-primary)!important;color:var(--color-text-primary)!important;font-weight:600;padding:0 20px;transition:all .2s ease}#roll-btn:hover{background:#fff3!important;transform:translateY(-1px)}.template-card{background:#14141e0d;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid var(--color-glass-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xs);transition:all .3s ease;display:grid;grid-template-columns:minmax(150px,1fr) 2fr minmax(80px,120px) minmax(180px,220px);gap:var(--space-md);align-items:center;box-shadow:0 4px 20px #0006}.template-card:hover{border-color:var(--color-accent-gold);transform:translateY(-2px);box-shadow:0 8px 30px #ffd70033;background:#14141e33}.card-header{display:flex;align-items:center;gap:var(--space-sm);min-width:150px;border-bottom:none}.template-name{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-desc{color:var(--color-text-secondary);font-size:.85rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.template-fields{color:var(--color-accent-gold);font-size:.8rem;font-weight:600;white-space:nowrap;min-width:80px}.card-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.template-grid{padding:var(--space-xs);padding-left:var(--space-lg);padding-right:var(--space-lg);max-height:175px;overflow-y:auto}.template-grid::-webkit-scrollbar{width:8px}.template-grid::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.template-grid::-webkit-scrollbar-thumb{background:#9d4edd80;border-radius:4px}.template-grid::-webkit-scrollbar-thumb:hover{background:#9d4eddcc}.character-sheet-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.character-sheet{background:#14141e99;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--color-glass-border);border-radius:12px;padding:2rem;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.sheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border)}.sheet-header h2{margin:0;color:var(--color-accent-primary)}.sheet-actions{display:flex;gap:.5rem}.sheet-content{display:flex;flex-direction:column;gap:1.5rem}.sheet-section{background:#0003;border:1px solid var(--color-glass-border);border-radius:8px;padding:1rem}.sheet-section-title{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary);border-bottom:1px solid var(--color-glass-border);padding-bottom:.5rem;text-shadow:0 0 10px rgba(157,78,221,.3);cursor:pointer}.sheet-fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.sheet-field{display:flex;flex-direction:column;gap:.25rem}.sheet-field label{font-size:.85rem;color:var(--color-text-muted);font-weight:500}.sheet-field input,.sheet-field textarea,.sheet-field select{width:100%;background:#0000004d;border:1px solid var(--color-glass-border);border-radius:4px;padding:8px;color:var(--color-text-primary);transition:all .3s ease}.sheet-field input:focus,.sheet-field textarea:focus,.sheet-field select:focus{outline:none;border-color:var(--neon-purple);background:#00000080;box-shadow:0 0 15px #9d4edd33}.sheet-field-full{grid-column:1 / -1}.sheet-field-computed{opacity:.8}.computed-value{background:#9d4edd1a;border:1px solid var(--neon-purple);border-radius:4px;padding:.5rem;text-align:center;font-weight:600;color:var(--neon-purple);font-size:1.1rem;box-shadow:0 0 10px #9d4edd1a}.field-with-action{display:flex;gap:.5rem;align-items:center}.field-with-action input{flex:1}.btn-roll-dice{background:#9d4edd33;color:#fff;border:1px solid var(--color-glass-border);border-radius:4px;padding:.5rem;cursor:pointer;font-size:1.2rem;transition:all .2s ease;min-width:40px;box-shadow:0 0 10px #9d4edd33}.btn-roll-dice:hover{background:#9d4edd66;border:1px solid var(--neon-purple);transform:scale(1.1);box-shadow:0 0 20px #9d4edd66}.character-list{display:flex;flex-direction:column;gap:.5rem}.character-card{background:var(--color-bg-secondary);border-radius:4px;padding:.75rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s}.character-card:hover{background:var(--color-bg-tertiary)}.character-info{display:flex;flex-direction:column;gap:.25rem}.character-name{font-weight:600;color:var(--color-text-primary)}.character-template{font-size:.8rem;color:var(--color-text-muted)}.character-sheet-window .window-footer{padding:.75rem 1rem;border-top:1px solid var(--color-glass-border);display:flex;justify-content:flex-end;background:#0003;border-radius:0 0 12px 12px;margin-top:0}.character-sheet-window .window-footer .btn{padding:.4rem 1rem;font-size:.9rem}.avatar-image{cursor:zoom-in;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.avatar-image:hover{transform:scale(1.1);box-shadow:0 0 15px #9d4edd66}.avatar-preview-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:zoom-out;opacity:0;animation:fadeIn .3s cubic-bezier(.4,0,.2,1) forwards}.avatar-preview-modal.closing{animation:fadeOut .3s cubic-bezier(.4,0,.2,1) forwards}.avatar-preview-modal img{max-width:85%;max-height:85%;object-fit:contain;border-radius:12px;box-shadow:0 20px 50px #00000080;transform:scale(.8);opacity:0;animation:zoomIn .4s cubic-bezier(.34,1.56,.64,1) forwards}.avatar-preview-modal.closing img{animation:zoomOut .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes zoomIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes zoomOut{0%{transform:scale(1);opacity:1}to{transform:scale(.8);opacity:0}}.custom-context-menu{position:fixed;background:#14141e80;border:1px solid var(--color-glass-border);border-radius:8px;padding:.5rem;z-index:10000;box-shadow:0 10px 30px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:180px;animation:fadeIn .1s ease-out}.context-menu-item{padding:.5rem 1rem;cursor:pointer;color:var(--color-text-primary);border-radius:4px;transition:background .2s;font-size:.9rem}.context-menu-item:hover{background:#9d4edd33;color:var(--neon-purple)}.inventory-section{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem;margin-top:.5rem;grid-column:1 / -1}.inventory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.25rem}.inventory-header h4{margin:0;font-size:.9rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px}.inventory-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.sheet-item{background:#ffffff0d;border-radius:4px;padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.sheet-item-header{display:flex;justify-content:space-between;align-items:center}.sheet-item-name{font-weight:700;color:var(--color-accent-secondary)}.sheet-item-actions{display:flex;flex-wrap:wrap;gap:.25rem}.btn-roll-action{background:rgba(var(--color-accent-primary-rgb),.2);border:1px solid rgba(var(--color-accent-primary-rgb),.4);color:var(--color-text-primary);border-radius:4px;padding:2px 6px;font-size:.8rem;cursor:pointer;transition:all .2s}.btn-roll-action:hover{background:rgba(var(--color-accent-primary-rgb),.4)}.btn-add-item-custom,.btn-remove-item{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:1rem;padding:0 .25rem}.btn-add-item-custom:hover,.btn-remove-item:hover{color:var(--color-text-primary)}.empty-inv{font-style:italic;color:var(--color-text-secondary);font-size:.8rem;text-align:center}.btn-add-item-custom,.btn-remove-item{background:#ffffff0d;border:1px solid var(--color-glass-border);border-radius:4px;color:var(--color-text-secondary);cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:1.1rem;line-height:1;padding:0}.btn-add-item-custom:hover{background:#fff3;box-shadow:0 0 8px #fff3}.btn-remove-item:hover{background:#ef476f1a;border-color:var(--color-accent-red);color:var(--color-accent-red);box-shadow:0 0 8px #ef476f33}.chat-form{display:flex;gap:10px;padding:10px;background:#0003;border-top:1px solid rgba(255,255,255,.1);border-radius:0 0 16px 16px}.chat-form input{flex:1;padding:8px 12px;background:#0003!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:8px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.9rem;transition:all .3s ease}.chat-form input:focus{flex-direction:column;gap:8px}.chat-message{padding:8px 12px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-left:3px solid var(--color-accent-primary);border-radius:4px 8px 8px 4px;font-size:.9rem;transition:all .2s ease}.chat-message:hover{background:#ffffff12}.chat-message.gm{border-left-color:var(--color-accent-gold);background:#ffd60a0d}.chat-message.dice{border-left-color:var(--color-accent-primary);background:#06ffa50d;font-family:Consolas,monospace}.chat-username{font-size:1rem;font-weight:700;color:var(--color-text-secondary);margin-bottom:2px;display:block}.chat-message.gm .chat-username{font-family:Consolas,monospace;color:var(--color-accent-gold)}.chat-text{color:var(--color-text-primary);line-height:1.4}.chat-timestamp{font-size:.7rem;color:var(--color-text-muted);float:right;margin-left:8px;margin-top:2px}.editor-container{display:flex;flex-direction:column;gap:1.5rem;padding:1rem;color:var(--text-primary);max-width:800px;margin:0 auto}.editor-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--glass-border);margin-bottom:1rem}.presets-bar{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:.5rem 0;margin-bottom:1rem}.btn-preset{background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-secondary);padding:.25rem .75rem;border-radius:12px;font-size:.8rem;cursor:pointer;transition:all .2s ease}.btn-preset:hover{background:var(--color-accent-primary);color:#fff;border-color:var(--color-accent-primary);transform:translateY(-1px)}.section-card{background:#0003;border:1px solid var(--glass-border);border-radius:12px;padding:1.2rem;margin-bottom:1.5rem;transition:border-color .3s}.section-card:hover{border-color:#fff3}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.section-title-group{display:flex;align-items:center;gap:1rem;flex:1}.section-title-input{background:transparent;border:none;border-bottom:1px solid transparent;color:var(--text-primary);font-size:1.1rem;font-weight:600;padding:.25rem;width:250px;transition:all .2s}.section-title-input:focus{outline:none;border-bottom-color:var(--neon-blue);background:#ffffff0d;border-radius:4px 4px 0 0}.section-count{font-size:.75rem;color:var(--text-secondary);background:#ffffff1a;padding:2px 8px;border-radius:10px}.fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}@media (max-width: 768px){.fields-grid{grid-template-columns:1fr}}.field-card{background:#ffffff08;border:1px solid var(--glass-border);border-radius:8px;padding:1rem;transition:transform .2s,border-color .2s,background .2s;position:relative}.field-card:hover{border-color:var(--glass-highlight);background:#ffffff0f;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.field-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}.field-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:6px;font-size:.9rem;color:var(--neon-purple);font-weight:700}.field-config{display:flex;flex-direction:column;gap:.8rem}.btn-add-field-small{width:100%;padding:.8rem;background:#ffffff05;border:1px dashed var(--glass-border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-add-field-small:hover{background:#ffffff0d;border-color:var(--neon-blue);color:var(--neon-blue)}.computed-config{background:#0003;padding:.8rem;border-radius:6px;margin-top:.5rem;border:1px solid rgba(255,255,255,.05)}.btn-icon{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;font-size:1rem}.btn-icon:hover{color:#fff;background:#ffffff1a}.btn-remove-field{background:#ffffff05;border:1px solid var(--glass-border);border-radius:10px;width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:1rem}.btn-remove-field:hover{color:var(--color-accent-red);background:#ef476f1a}.template-header{font-family:var(--font-display);font-size:1.5rem;margin:0}.equipment-manager{display:flex;flex-direction:column;gap:1rem;height:100%;min-height:300px}.manager-header,.items-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.collections-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;padding:.5rem 0}.collection-card{background:#14141e0d;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:8px;padding:1rem;display:flex;flex-direction:column;justify-content:space-between;gap:1rem;transition:all .2s ease}.collection-card:hover{background:#ffffff1a;border-color:var(--color-accent-primary);transform:translateY(-2px)}.collection-info{display:flex;flex-direction:column}.collection-name{font-weight:700;font-size:1.1rem;color:var(--color-text-primary)}.collection-desc{font-size:.85rem;color:var(--color-text-secondary);margin-top:.25rem}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-sm);padding:1rem 0}.item-card{background:#ffffff1a;border:1px solid var(--color-glass-border);border-radius:6px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;transition:all .2s ease}.item-card:hover{background:#fff3;transform:translate(2px)}.item-header{display:flex;justify-content:space-between;align-items:center}.item-name{font-weight:600;color:var(--color-accent-secondary)}.item-controls{display:flex;gap:.25rem;opacity:.5;transition:opacity .2s}.item-card:hover .item-controls{opacity:1}.btn-icon{background:none;border:none;cursor:pointer;font-size:.9rem;padding:2px;opacity:.7}.btn-icon:hover{opacity:1;transform:scale(1.1)}.item-actions-list{display:flex;flex-wrap:wrap;gap:.5rem}.item-action-tag{background:rgba(var(--color-accent-primary-rgb),.2);border:1px solid rgba(var(--color-accent-primary-rgb),.4);border-radius:4px;padding:2px 6px;font-size:.75rem;color:var(--color-text-primary)}.empty-state{text-align:center;color:var(--color-text-secondary);font-style:italic;padding:2rem;width:100%}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.modal-overlay .modal{background:#1e141480;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid var(--color-glass-border);border-radius:16px;padding:2rem;width:90%;max-width:550px;box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;gap:1.5rem;animation:modalSlideUp .1s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.modal-header h3{margin:0;color:var(--color-accent-gold);font-family:var(--font-display);font-size:1.8rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem;margin-bottom:.5rem;letter-spacing:1px}.modal-header h3 .text-accent{color:var(--color-accent-primary);text-shadow:0 0 10px rgba(157,78,221,.4)}.modal-body{display:flex;flex-direction:column;gap:1.2rem}.form-group label{font-size:.9rem;color:var(--color-text-secondary);font-weight:600;margin-bottom:.5rem;display:block;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.form-control{width:100%;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.8rem 1rem;color:var(--color-text-primary);font-family:var(--font-body);font-size:1rem;transition:all .3s ease}.form-control:focus{outline:none;border-color:var(--color-accent-primary);background:#0009;box-shadow:0 0 15px #9d4edd33;transform:translateY(-1px)}.form-control::placeholder{color:#fff3}.divider{display:flex;align-items:center;color:var(--color-accent-gold);font-size:.8rem;font-weight:700;margin:1rem 0;text-transform:uppercase;letter-spacing:2px;font-family:var(--font-display)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(255,214,10,.3),transparent)}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}@keyframes modalSlideUp{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
